body {
    font-family: 'Open Sans', sans-serif !important;
    color: #303030 !important;
    font-size: 14px !important;
    line-height: 1.6;
    background-color: #efefef !important;
}
.color-red{
    color: #c92236;
}
.color-blue{
    color: #042973;
}
.header {
    position: fixed !important;
    top: 0px;
    left: 0px;
    right: 0;
    background-color: #fff;
    z-index: 1000;
    padding: 7px 0 !important;
    box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.2);
}
.header .logo-gtel{
    width: 120px;
    margin: -5px 0;
}
.header .logo-csgt {
    width: 90px;
    height: auto;
}
.header .hotline {
    font-size: 15px;
    font-weight: 600;
}
.header-contact div {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    line-height: 1.6;
}
.header-contact svg {
    flex-shrink: 0;
    vertical-align: middle;
}
@media (max-width: 575px) {
    .header .logo-csgt {
        width: 80px;
    }
    .header .logo-gtel {
        width: 110px;
    }
    .header .hotline {
        font-size: 12px;
    }
}
.header .line{
    padding: 0 20px;
}
.footer{
    padding: 10px 0 !important;
    background: #29abdf;
    color: #fff;
    text-align: center;
}
.wrapper-content{
    padding: 140px 0 30px !important;
    min-height: calc(100vh - 42px) !important;
}
@media (max-width: 576px) {
    .wrapper-content{
        padding: 120px 0 30px !important;
    }
}
.wrapper-content .title h1{
    font-size: 25px;
    font-weight: 700;
    color: #042973;
}
.wrapper-content .document-content .select2-container {
    width: 100% !important;
}
.wrapper-content .document-content{
    background: #fff;
    padding: 30px;
}
.wrapper-content .document-content label{
    font-weight: 600;
    margin-bottom: 5px;
}
.wrapper-content .document-content h6{
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 15px;
}
.wrapper-content .document-content #frm-order .btn{
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 10px 30px;
    margin-top:10px;
    background-color: #29abdf;
}
.wrapper-content .document-content .form-group{
    margin-bottom: 15px;
}
.wrapper-content .document-content .form-control{
    font-size: 14px;
}
.wrapper-content .document-content .form-control::placeholder {
    font-size: 13px;
    color: #adb9ca !important;
}
.wrapper-content .document-content .form-control:focus {
    box-shadow: 0 0 0 0 rgba(0, 123, 255, 0.25) !important;
    border-color: #ced4da !important;
}

.wrapper-content .document-content .select2-selection {
    height: 38px;
    overflow: auto;
}

.select2-container--default .select2-selection--single .select2-selection__rendered{
    line-height: 35px !important;
    color: #495057 !important;
}
.select2-container--default .select2-selection--single{
    border: 1px solid #ced4da !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow{
    height: 35px !important;
}
label.error{
    width: 100%;
    color: #c92236;
    font-weight: 400 !important;
    margin-top: 3px;
    font-size: 13px !important;
}
.cal-loading {
    position: fixed;
    left: 0px;
    top: 0px;
    width: 100%;
    display: none;
    height: 100%;
    z-index: 9999;
    background: url(../img/loadding.gif) 50% 40% no-repeat rgba(0, 0, 0, 0.3);
    background-size: 220px auto;
}
.modal-noti .modal-body {
    padding: 25px 30px;
    text-align: center;
}
.modal-noti .modal-title {
    margin: 0 auto;
}
.modal-noti .modal-header .close {
    padding: 0;
    margin: 0;
}
.modal-noti .modal-title {
    font-size: 18px;
    font-weight: 700;
    color: #042973;
}
.swal-title {
    font-family: 'Open Sans', sans-serif !important;
    color: #000 !important;
    font-weight: 700 !important;
    font-size: 20px !important;
}
.swal-text {
    font-family: 'Open Sans', sans-serif !important;
    color: #777 !important;
    font-weight: 400 !important;
    text-align: center;
    line-height: 1.6;
    font-size: 14px;
}
.swal-overlay--show-modal .swal-modal {
  will-change: auto !important;
}

.btn-attention {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #fff3cd;
    border: 1px solid #ffc107;
    border-radius: 6px;
    padding: 6px 14px;
    color: #c0392b;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95rem;
    text-decoration: none;
    transition: background 0.2s;
}
.btn-attention:hover { background: #ffe8a1; color: #c0392b; text-decoration: none; }
.btn-attention .collapse-icon {
    font-size: 0.75rem;
    transition: transform 0.25s ease;
    display: inline-block;
}
.btn-attention[aria-expanded="true"] .collapse-icon { transform: rotate(180deg); }
.btn-attention .label-more { font-size: 0.8rem; color: #888; font-weight: 400; }