
.bso-contact-page {
    position: relative !important;
    overflow: hidden !important;
    background: #ffffff !important;
    color: #263055 !important;
}

.bso-contact-section {
    position: relative !important;
    padding: 78px 0 !important;
}

.bso-contact-soft {
    background:
        radial-gradient(780px 360px at 8% 4%, rgba(20, 92, 255, .10), transparent 62%),
        radial-gradient(640px 320px at 92% 8%, rgba(255, 235, 55, .15), transparent 58%),
        linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%) !important;
    overflow: hidden !important;
}

.bso-contact-white {
    background: #ffffff !important;
}

.bso-contact-dark {
    background:
        radial-gradient(650px 320px at 12% 0%, rgba(20, 92, 255, .22), transparent 60%),
        radial-gradient(520px 260px at 90% 8%, rgba(255, 235, 55, .18), transparent 58%),
        linear-gradient(135deg, #0d3371 0%, #081f4b 100%) !important;
    color: #ffffff !important;
    overflow: hidden !important;
}

.bso-contact-soft::before,
.bso-contact-dark::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background-image:
        linear-gradient(rgba(13, 51, 113, .04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(13, 51, 113, .04) 1px, transparent 1px) !important;
    background-size: 46px 46px !important;
    pointer-events: none !important;
}

.bso-contact-dark::before {
    background-image:
        linear-gradient(rgba(255, 255, 255, .055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .055) 1px, transparent 1px) !important;
}

.bso-contact-kicker {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 14px !important;
    border-radius: 999px !important;
    background: rgba(13, 51, 113, .08) !important;
    color: #0d3371 !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    margin-bottom: 16px !important;
}

.bso-contact-kicker-light {
    background: rgba(255, 255, 255, .12) !important;
    color: #ffeb37 !important;
    border: 1px solid rgba(255, 255, 255, .14) !important;
}

.bso-contact-dot {
    width: 8px !important;
    height: 8px !important;
    min-width: 8px !important;
    border-radius: 50% !important;
    background: #15b8a6 !important;
    box-shadow: 0 0 0 5px rgba(21, 184, 166, .14) !important;
}

.bso-contact-title {
    color: #111653 !important;
    font-size: clamp(30px, 3.7vw, 48px) !important;
    line-height: 1.1 !important;
    letter-spacing: -.035em !important;
    font-weight: 750 !important;
    margin-bottom: 14px !important;
}

.bso-contact-title-light {
    color: #ffffff !important;
}

.bso-contact-desc {
    color: #4d5578 !important;
    font-size: 17px !important;
    line-height: 1.7 !important;
    margin-bottom: 0 !important;
}

.bso-contact-desc-light {
    color: rgba(255, 255, 255, .76) !important;
}

.bso-contact-card {
    height: 100% !important;
    padding: 30px !important;
    border-radius: 30px !important;
    background: rgba(255, 255, 255, .90) !important;
    border: 1px solid rgba(13, 51, 113, .10) !important;
    box-shadow: 0 22px 62px rgba(13, 51, 113, .085) !important;
    backdrop-filter: blur(10px) !important;
    transition: all .22s ease !important;
}

.bso-contact-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 30px 78px rgba(13, 51, 113, .12) !important;
}

.bso-contact-card-head {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    margin-bottom: 22px !important;
}

.bso-contact-icon {
    width: 54px !important;
    height: 54px !important;
    min-width: 54px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 18px !important;
    background: linear-gradient(135deg, #0d3371, #081f4b) !important;
    color: #ffeb37 !important;
    box-shadow: 0 16px 34px rgba(13, 51, 113, .20) !important;
}

.bso-contact-icon svg {
    width: 25px !important;
    height: 25px !important;
    fill: currentColor !important;
}

.bso-contact-card h3 {
    color: #111653 !important;
    font-size: 22px !important;
    line-height: 1.25 !important;
    font-weight: 700 !important;
    margin: 0 !important;
}

.bso-contact-address {
    color: #4d5578 !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
    margin-bottom: 22px !important;
}

.bso-contact-address strong {
    color: #111653 !important;
    font-weight: 700 !important;
}

.bso-contact-divider {
    height: 1px !important;
    width: 100% !important;
    background: rgba(13, 51, 113, .10) !important;
    margin: 22px 0 !important;
}

.bso-contact-row {
    display: flex !important;
    gap: 13px !important;
    align-items: flex-start !important;
    padding: 14px !important;
    border-radius: 18px !important;
    background: #f8fbff !important;
    border: 1px solid rgba(13, 51, 113, .08) !important;
}

.bso-contact-row + .bso-contact-row {
    margin-top: 12px !important;
}

.bso-contact-row-icon {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 13px !important;
    background: rgba(13, 51, 113, .08) !important;
    color: #0d3371 !important;
}

.bso-contact-row-icon.bso-whatsapp {
    background: rgba(21, 184, 166, .12) !important;
    color: #15b8a6 !important;
}

.bso-contact-row-icon svg {
    width: 17px !important;
    height: 17px !important;
    fill: currentColor !important;
}

.bso-contact-label {
    display: block !important;
    color: #111653 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
}

.bso-contact-sub {
    display: block !important;
    color: #66708d !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    margin-top: 2px !important;
}

.bso-contact-link {
    color: #145cff !important;
    text-decoration: none !important;
    font-weight: 700 !important;
    word-break: break-word !important;
}

.bso-contact-link:hover {
    text-decoration: underline !important;
}

.bso-contact-hours {
    padding: 18px !important;
    border-radius: 22px !important;
    background:
        radial-gradient(300px 160px at 92% 0%, rgba(255, 235, 55, .18), transparent 60%),
        #f8fbff !important;
    border: 1px solid rgba(13, 51, 113, .09) !important;
}

.bso-contact-hours h4 {
    display: flex !important;
    align-items: center !important;
    gap: 9px !important;
    color: #111653 !important;
    font-size: 16px !important;
    line-height: 1.3 !important;
    font-weight: 700 !important;
    margin-bottom: 14px !important;
}

.bso-contact-hours h4 svg {
    width: 16px !important;
    height: 16px !important;
    fill: #0d3371 !important;
}

.bso-contact-hours ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.bso-contact-hours li {
    display: flex !important;
    justify-content: space-between !important;
    gap: 16px !important;
    color: #4d5578 !important;
    font-size: 14px !important;
    padding: 9px 0 !important;
    border-bottom: 1px solid rgba(13, 51, 113, .08) !important;
}

.bso-contact-hours li:last-child {
    border-bottom: 0 !important;
    padding-bottom: 0 !important;
}

.bso-contact-hours strong,
.bso-contact-hours .bso-hour-value {
    color: #111653 !important;
    font-weight: 700 !important;
    text-align: right !important;
}

.bso-contact-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 5px 10px !important;
    border-radius: 999px !important;
    background: rgba(21, 184, 166, .12) !important;
    color: #0f766e !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
}

.bso-contact-secondary-office {
    margin-top: 20px !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(13, 51, 113, .10) !important;
}

.bso-contact-secondary-office h5 {
    color: #111653 !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    margin-bottom: 7px !important;
}

.bso-contact-secondary-office p {
    color: #66708d !important;
    font-size: 14px !important;
    line-height: 1.65 !important;
    margin-bottom: 0 !important;
}

.bso-contact-image-card {
    position: relative !important;
    padding: 18px !important;
    border-radius: 30px !important;
    background:
        radial-gradient(420px 220px at 50% 0%, rgba(255, 235, 55, .17), transparent 62%),
        #ffffff !important;
    border: 1px solid rgba(13, 51, 113, .10) !important;
    box-shadow: 0 24px 66px rgba(13, 51, 113, .09) !important;
}

.bso-contact-image-card img {
    width: 100% !important;
    height: auto !important;
    border-radius: 24px !important;
    box-shadow: none !important;
}

.bso-contact-content-card {
    position: relative !important;
    padding: 32px !important;
    border-radius: 30px !important;
    background: #ffffff !important;
    border: 1px solid rgba(13, 51, 113, .10) !important;
    box-shadow: 0 22px 60px rgba(13, 51, 113, .075) !important;
}

.bso-contact-content-card h3 {
    color: #111653 !important;
    font-size: clamp(28px, 3vw, 42px) !important;
    line-height: 1.12 !important;
    letter-spacing: -.03em !important;
    font-weight: 750 !important;
    margin-bottom: 16px !important;
}

.bso-contact-content-card p {
    color: #4d5578 !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin-bottom: 18px !important;
}

.bso-contact-content-card .lead {
    font-size: 17px !important;
    line-height: 1.75 !important;
}

.bso-contact-content-card strong {
    color: #111653 !important;
    font-weight: 750 !important;
}

.bso-contact-content-card a {
    color: #145cff !important;
    text-decoration: none !important;
    font-weight: 650 !important;
}

.bso-contact-content-card a:hover {
    text-decoration: underline !important;
}

.bso-contact-check-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 22px 0 !important;
}

.bso-contact-check-list li {
    display: flex !important;
    align-items: center !important;
    gap: 13px !important;
    padding: 13px 0 !important;
    border-bottom: 1px solid rgba(13, 51, 113, .08) !important;
}

.bso-contact-check-list li:last-child {
    border-bottom: 0 !important;
}

.bso-contact-check-icon {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: rgba(21, 184, 166, .12) !important;
    color: #0f766e !important;
}

.bso-contact-check-icon svg {
    width: 16px !important;
    height: 16px !important;
    fill: currentColor !important;
}

.bso-contact-check-list span {
    color: #111653 !important;
    font-size: 17px !important;
    line-height: 1.4 !important;
    font-weight: 560 !important;
}

.bso-contact-cta-box {
    position: relative !important;
    padding: 42px !important;
    border-radius: 34px !important;
    background:
        radial-gradient(520px 260px at 85% 0%, rgba(255, 235, 55, .20), transparent 60%),
        linear-gradient(135deg, #0d3371, #081f4b) !important;
    box-shadow: 0 28px 80px rgba(13, 51, 113, .18) !important;
    overflow: hidden !important;
}

.bso-contact-cta-box h2 {
    color: #ffffff !important;
    font-size: clamp(30px, 3.7vw, 48px) !important;
    line-height: 1.1 !important;
    letter-spacing: -.035em !important;
    font-weight: 760 !important;
    margin-bottom: 16px !important;
}

.bso-contact-cta-box p {
    color: rgba(255, 255, 255, .76) !important;
    font-size: 18px !important;
    line-height: 1.7 !important;
    margin-bottom: 28px !important;
}

.bso-contact-btn-yellow {
    min-height: 54px !important;
    padding: 0 28px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 16px !important;
    background: #ffeb37 !important;
    color: #0d3371 !important;
    text-decoration: none !important;
    font-size: 15px !important;
    font-weight: 750 !important;
    border: 0 !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, .16) !important;
    transition: all .22s ease !important;
}

.bso-contact-btn-yellow:hover {
    color: #0d3371 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 22px 44px rgba(0, 0, 0, .20) !important;
}

@media (max-width: 991px) {
    .bso-contact-section {
        padding: 56px 0 !important;
    }

    .bso-contact-card,
    .bso-contact-content-card,
    .bso-contact-cta-box {
        padding: 26px !important;
        border-radius: 26px !important;
    }
}

@media (max-width: 575px) {
    .bso-contact-section {
        padding: 46px 0 !important;
    }

    .bso-contact-card,
    .bso-contact-content-card,
    .bso-contact-cta-box {
        padding: 21px !important;
        border-radius: 22px !important;
    }

    .bso-contact-card-head {
        align-items: flex-start !important;
    }

    .bso-contact-hours li {
        flex-direction: column !important;
        gap: 4px !important;
    }

    .bso-contact-hours .bso-hour-value {
        text-align: left !important;
    }

    .bso-contact-btn-yellow {
        width: 100% !important;
    }
}

.bso-contact-row-icon.bso-email {
    background: rgba(20, 92, 255, .10) !important;
    color: #145cff !important;
}

.bso-contact-row-icon.bso-support {
    background: rgba(21, 184, 166, .12) !important;
    color: #0f766e !important;
}

.bso-contact-row-icon.bso-ticket {
    background: rgba(255, 201, 40, .18) !important;
    color: #0d3371 !important;
}

.hover-lift {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.hover-lift:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.05) !important;
}
.hover-lift-lg {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.hover-lift-lg:hover {
    transform: translateY(-3px);
    box-shadow: 0 15px 30px rgba(0,0,0,0.15) !important;
}
.rounded-4 {
    border-radius: 1rem !important;
}
