/**
 * Surevix marketing site — design tokens & components
 * Navbar + hero (extend as sections are built)
 */
:root {
    --sv-primary-orange: #f2994a;
    --sv-primary-navy: #002147;
    --sv-text-white: #ffffff;
    --sv-text-gray: #7a7a7a;
    --sv-navbar-bg: #ffffff;
    --sv-body-bg: #ffffff;
    --sv-hero-overlay: rgba(0, 33, 71, 0.78);
    --sv-hero-min-height: clamp(28rem, 78vh, 40rem);
    /* Mulish is the Google Fonts successor to Muli (same design family) */
    --sv-font-sans: "Mulish", "Muli", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --sv-font-hero: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --sv-section-muted-bg: #f4f5f9;
    --sv-heading-color: #212529;
    --sv-accent-green: #1fa67a;
    --sv-text-body: #5c6368;
    --sv-about-offset-bg: #e8eaed;
    --sv-services-section-bg: #f5f7fa;
    --sv-service-bar-overlay: rgba(18, 38, 58, 0.9);
    --sv-service-feature-overlay: rgba(0, 33, 71, 0.88);
    --sv-services-cta-orange: #f49c4f;
    --transition: all 0.3s ease;
}

/* ——— Base ——— */
body.site-page {
    font-family: var(--sv-font-sans);
    color: var(--sv-primary-navy);
    background-color: var(--sv-body-bg);
}

.btn {
    border-radius: 0 !important;
}

button {
    border-radius: 0 !important;
}

/* ——— Navbar ——— */
.site-navbar {
    background: var(--sv-navbar-bg);
    box-shadow: 0 1px 0 rgba(0, 33, 71, 0.06);
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
}

.site-navbar .navbar-brand {
    padding-top: 0;
    padding-bottom: 0;
    margin-right: 1.5rem;
}

.site-navbar .site-logo {
    height: auto;
    max-height: 5rem;
    width: auto;
    display: block;
}

.site-nav .nav-link {
    color: var(--sv-primary-navy) !important;
    font-weight: 600;
    font-size: 0.9375rem;
    padding: 0.5rem 0.85rem !important;
    position: relative;
}

.site-nav .nav-link:hover,
.site-nav .nav-link:focus {transition: var(--transition);
    color: var(--sv-primary-orange) !important;
}

.site-nav .nav-link.active {
    color: var(--sv-primary-navy) !important;
}

.site-nav .nav-link.active::after {
    content: "";
    position: absolute;
    left: 0.85rem;
    right: 0.85rem;
    bottom: 0.2rem;
    height: 3px;
    background: var(--sv-primary-navy);
    border-radius: 2px;
}

.site-nav .dropdown-toggle::after {
    margin-left: 0.35em;
    vertical-align: 0.15em;
}

.site-call {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    text-decoration: none;
    color: inherit;
}

.site-call:hover {
    color: inherit;transition: var(--transition);
}

.site-call__icon {
    width: 44px;
    height: 44px;
    object-fit: contain;
    flex-shrink: 0;
}

.site-call__label {
    font-size: 0.7rem;
    letter-spacing: 0.06em;
    color: var(--sv-text-gray);
    text-transform: uppercase;
    line-height: 1.2;
}

.site-call__number {
    font-weight: 700;
    font-size: 1rem;
    color: var(--sv-primary-navy);
    line-height: 1.2;
}

.site-btn-inquire {
    --bs-btn-color: var(--sv-text-white);
    --bs-btn-bg: var(--sv-primary-orange);
    --bs-btn-border-color: var(--sv-primary-orange);
    --bs-btn-hover-bg: #e07f35;
    --bs-btn-hover-border-color: #e07f35;
    --bs-btn-hover-color: var(--sv-text-white);
    --bs-btn-active-bg: #d17430;
    --bs-btn-active-border-color: #d17430;
    font-weight: 700;
    font-size: 0.8125rem;
    letter-spacing: 0.04em;
    padding: 0.55rem 1.15rem;
    border-radius: 0.25rem;
    text-transform: uppercase;
    white-space: nowrap;
}

.site-navbar-actions {
    gap: 1rem;
}

@media (max-width: 991.98px) {
    .site-navbar-actions {
        flex-direction: column;
        align-items: flex-start !important;
        padding-top: 1rem;
        width: 100%;
    }

    .site-nav .nav-link.active::after {
        left: 0;
        right: auto;
        width: 3rem;
    }
}

/* ——— Hero ——— */
.site-hero {
    position: relative;
    min-height: var(--sv-hero-min-height);
    color: var(--sv-text-white);
    overflow: hidden;
    font-family: var(--sv-font-hero);
}

.site-hero .carousel {
    position: absolute;
    inset: 0;
}

.site-hero .carousel-inner {
    height: 100%;
}

.site-hero .carousel-item {
    height: 100%;
    position: relative;
}

.site-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.site-hero__overlay {
    position: absolute;
    inset: 0;
    background: var(--sv-hero-overlay);
    z-index: 1;
    pointer-events: none;
}

.site-hero-control.carousel-control-prev,
.site-hero-control.carousel-control-next {
    z-index: 4;
    width: 3rem;
    opacity: 0.85;
}

.site-hero .carousel-control-prev-icon,
.site-hero .carousel-control-next-icon {
    filter: none;
    background-color: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    background-size: 60% 60%;
}

.site-hero-inner {
    position: relative;
    z-index: 2;
    min-height: var(--sv-hero-min-height);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 3.5rem 1rem 4rem;
}

.site-hero__title {
    font-weight: 600;
    line-height: 1.2;
    max-width: 52rem;
    margin-left: auto;
    margin-right: auto;
}

.site-hero__title-line {
    display: block;
    font-size: clamp(3.35rem, 3.5vw, 2rem);
    color: var(--sv-text-white);
}

.site-hero__title-accent {
    display: block;
    font-size: clamp(3.35rem, 3.5vw, 2rem);
    color: var(--sv-primary-orange);
    margin-top: 0.15em;
}

.site-hero-stats {
    margin-top: 2rem;
    width: 100%;
    max-width: 58rem;
}

.site-hero-stat {
    border: 1px solid rgba(255, 255, 255, 0.55);
    background: rgba(0, 0, 0, 0.12);
    padding: 0.85rem 1rem;
    text-align: left;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.65rem;    width: 90%;

}

.site-hero-stat__value {
    display: block;
      font-size: clamp(1.2rem, 1.7vw, 2.45rem);
    font-weight: 600;;
     color: var(--sv-text-white);
    line-height: 0.95;
    letter-spacing: -0.01em;
    flex-shrink: 0;
}

.site-hero-stat__label {
    display: block;
    font-size: clamp(1.1rem, 1.1vw, 1.1rem);
    font-weight: 500;
    color: var(--sv-primary-orange);
    line-height: 1.35;
    margin-top: 0;
    max-width: 8.2rem;
}

.site-hero-ctas {
    margin-top: 2.25rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

.site-btn-hero {
    --bs-btn-color: var(--sv-text-white);
    --bs-btn-bg: var(--sv-primary-orange);
    --bs-btn-border-color: var(--sv-primary-orange);
    --bs-btn-hover-bg: #e07f35;
    --bs-btn-hover-border-color: #e07f35;
    --bs-btn-hover-color: var(--sv-text-white);
    font-weight: 500;
    font-size: 1rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    padding: 0.75rem 1.35rem;
    border-radius: 0.25rem;
}

@media (max-width: 575.98px) {
    .site-hero-stat {
        padding: 0.75rem 0.55rem;
        gap: 0.45rem;
    }

    .site-hero-stat__value {
        font-size: 1.65rem;
    }

    .site-hero-stat__label {
        font-size: 0.78rem;
        max-width: 4.8rem;
    }
}

/* ——— Trusted partners (Owl Carousel) ——— */
.site-section--partners {
    background-color: var(--sv-section-muted-bg);
    padding-top: 3.25rem;
    padding-bottom: 3.25rem;
}

.site-section--partners .site-section__title {
    font-family: var(--sv-font-sans);
    font-weight: 700;
    font-size: clamp(1.25rem, 2.5vw, 2.25rem);
    color: var(--sv-heading-color);
    text-align: center;
    margin-bottom: 2.25rem;
}

/* Owl ships display:none until .owl-loaded — if jQuery/CDN fails the row stays blank */
.site-partners-carousel.owl-carousel {
    display: block !important;
    width: 100%;
}

.site-partners-carousel .owl-stage {
    display: flex;
    align-items: center;
}

.site-partners-carousel .owl-item {
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-partners-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1.25rem;
    min-height: 5.5rem;
     border-radius: 0.35rem;
}

.site-partners-logo img {
    max-height: 3rem;
    width: auto;
    max-width: 100%;
    object-fit: contain;
}

@media (min-width: 768px) {
    .site-partners-logo img {
        max-height: 5.25rem;
    }
}

/* If Owl/jQuery never loads, still show logos in a simple row */
.site-partners-carousel--no-js {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 1.5rem 2rem;
}

.site-partners-carousel--no-js .item {
    flex: 0 0 auto;
}

/* ——— About Us ——— */
.site-section--about {
    background-color: var(--sv-body-bg);
    overflow: hidden;
}

.site-about-media {
    position: relative;
    padding: 0 0 1.35rem 1.35rem;
    max-width: 100%;
}

.site-about-media__offset {
    position: absolute;
    left: 0;
    top: -1.25rem;
    width: 72%;
    height: 62%;
    background: var(--sv-about-offset-bg);
    z-index: 0;
    border-radius: 0.2rem;
}

.site-about-media__frame {
    position: relative;
    z-index: 1;
    margin: 0;
    border-radius: 0.25rem;
    overflow: hidden;
}

.site-about-media__frame img {
    display: block;
    width: 100%;
    height: auto;
}

.site-about-copy {
    position: relative;
    padding: 0.5rem 0 0.5rem 1.5rem;
}

@media (max-width: 991.98px) {
    .site-about-copy {
        padding-left: 0;
        padding-top: 1.5rem;
    }
}

.site-about-copy__pattern {
    position: absolute;
    top: -10%;
    right: -15%;
    width: 85%;
    height: 120%;
    background-repeat: no-repeat;
    background-position: top right;
    background-size: contain;
    opacity: 0.14;
    pointer-events: none;
    z-index: 0;
}

.site-about-copy__inner {
    position: relative;
    z-index: 1;
}


 
.site-about-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
    margin-bottom: 0;
}

.site-about-kicker__line {
    display: inline-block;
    width: 2.75rem;
    height: 3px;
    background: var(--sv-accent-green);
    border-radius: 2px;
    flex-shrink: 0;
}

.site-about-title {
    font-family: var(--sv-font-sans);
    font-weight: 700;
    font-size: clamp(1.65rem, 3.2vw, 2.35rem);
    line-height: 1.25;
    color: var(--sv-heading-color);
    margin-top: 1rem;
    margin-bottom: 1.25rem;
}

.site-about-lead {
    font-size: 1.2rem;
    line-height: 1.7;
    color: var(--sv-text-body);
    margin-bottom: 1.5rem;
    max-width: 34rem;
    font-weight: 600;
}
.site-about-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
    max-width: 34rem;
}

.site-about-list li {
    position: relative;
    padding-left: 1.35rem;
    margin-bottom: 0.95rem;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--sv-text-body);    line-height: 1.45;
}

.site-about-list li:last-child {
    margin-bottom: 0;
}

.site-about-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: var(--sv-primary-orange);
}

.site-about-more {
    font-size: 1rem;
    font-weight: 700;
    color: var(--sv-primary-orange);
    text-decoration: none;
}

.site-about-more:hover {
    color: #e07f35;
    text-decoration: underline;transition: var(--transition);
}

/* ——— Services (4×2 grid) ——— */
.site-services {
    background-color: var(--sv-services-section-bg);
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
}

.site-services-grid {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 1fr;
    grid-template-areas:
        "intro"
        "c1"
        "c2"
        "c3"
        "c4"
        "c5"
        "c6"
        "cta";
}

@media (min-width: 768px) {
    .site-services-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-areas:
            "intro intro"
            "c1 c2"
            "c3 c4"
            "c5 c6"
            "cta cta";
    }
}

@media (min-width: 992px) {
    .site-services-grid {
        grid-template-columns: repeat(4, 1fr);
        grid-template-areas:
            "intro c1 c2 c3"
            "c4 c5 c6 cta";
    }
}

.site-services-grid__intro {
    grid-area: intro;
    align-self: center;
    padding: 0.25rem 0 0.5rem;
}

@media (min-width: 992px) {
    .site-services-grid__intro {
        padding-right: 0.75rem;
    }
}

.site-services-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
    margin-bottom: 0;
}

.site-services-kicker__line {
    display: inline-block;
    width: 2.75rem;
    height: 3px;
    background: var(--sv-accent-green);
    border-radius: 2px;
    flex-shrink: 0;
}

.site-services-title {
    font-family: var(--sv-font-sans);
    font-weight: 700;
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    color: var(--sv-heading-color);
    margin: 0.85rem 0 0;
}

.site-service-card {
    position: relative;
    grid-area: var(--svc-area, auto);
    min-height: 19rem;
    border-radius: 0px;
    overflow: hidden;
    box-shadow: 0 0.35rem 1.25rem rgba(0, 33, 71, 0.1);
    margin-bottom: 15px;
}
.site-service-card--c1 {
    --svc-area: c1;
}

.site-service-card--c2 {
    --svc-area: c2;
}

.site-service-card--c3 {
    --svc-area: c3;
}

.site-service-card--c4 {
    --svc-area: c4;
}

.site-service-card--c5 {
    --svc-area: c5;
}

.site-service-card--c6 {
    --svc-area: c6;
}

.site-service-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.site-service-card__bar {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 1rem 0.85rem;
    background: var(--sv-service-bar-overlay);
    text-align: center;
    transition: opacity 0.25s ease;
}

.site-service-card__bar h3 {
    margin: 0;
    font-size: 0.9375rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--sv-text-white);
    line-height: 1.35;
}

.site-service-card__veil {
    position: absolute;
    inset: 0;
    background: var(--sv-service-feature-overlay);
    opacity: 0;
    transition: opacity 0.25s ease;
    pointer-events: none;
}

.site-service-card__body {
    position: absolute;
    inset: 0;
    z-index: 2;
    min-height: 17rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 1.5rem 1.25rem;
    color: var(--sv-text-white);
    opacity: 0;
    visibility: hidden;
    transform: translateY(4px);
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
}

.site-service-card__body h3 {
    margin: 0 0 0.65rem;
    font-size: 1.125rem;
    font-weight: 700;
    text-transform: none;
    letter-spacing: normal;
    color: var(--sv-text-white);
}

.site-service-card__body p {
    margin: 0 0 1rem;
    font-size: 0.9rem;
    font-weight: 400;
    line-height: 1.55;
    opacity: 0.95;
    max-width: 16rem;
}

.site-service-card__body a {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--sv-text-white);
    text-decoration: none;
}

.site-service-card__body a:hover {
    text-decoration: underline;transition: var(--transition);transition: var(--transition);
}

.site-service-card:hover .site-service-card__bar,
.site-service-card:focus-within .site-service-card__bar {
    opacity: 0;transition: var(--transition);
}

.site-service-card:hover .site-service-card__veil,
.site-service-card:focus-within .site-service-card__veil {
    opacity: 1;transition: var(--transition);
}

.site-service-card:hover .site-service-card__body,
.site-service-card:focus-within .site-service-card__body {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);transition: var(--transition);
}

.site-services-cta {
    grid-area: cta;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 19rem;
    padding: 2rem 1.5rem;
    background: var(--sv-text-white);
    border-radius: 0rem;
    box-shadow: 0 0.35rem 1.25rem rgba(0, 33, 71, 0.1);
    margin-bottom: 15px;
}

.site-services-cta__text {
    margin: 0 0 1.5rem;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--sv-text-body);
    line-height: 1.45;
    max-width: 14rem;
}

.site-services-cta__btn {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--sv-text-white);
    background: var(--sv-services-cta-orange);
    border: none;
    border-radius: 0.2rem;
    transition: background 0.2s ease, transform 0.15s ease; transition: var(--transition);
}

.site-services-cta__btn:hover {
    background: var(--sv-primary-orange);
    color: var(--sv-text-white);transition: var(--transition);
}

/* ——— Stats Strip ——— */
.site-stats {
    background: var(--sv-body-bg);
    padding-top: 3.25rem;
    padding-bottom: 3.25rem;
}

.site-stats__grid {
    display: grid;
    gap: 1.5rem 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 992px) {
    .site-stats__grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 1.75rem 1.25rem;
    }
}

.site-stats__item {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.75rem 0.5rem;
    border-radius: 0.35rem;
    transition: transform 0.2s ease;
}

.site-stats__icon-wrap {
    width: 5.75rem;
    height: 5.75rem;
    padding: 0.7rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    background: #f9fafb;
    border-radius: 0.2rem;
    transition: background-color 0.2s ease, border-radius 0.2s ease;
}

.site-stats__icon {
    width: 100%;
    max-width: 5.1rem;
    max-height: 5.1rem;
    height: 100%;
    object-fit: contain;
    transition: opacity 0.2s ease;
}

.site-stats__icon--hover {
    display: none;
}

.site-stats__item:hover,
.site-stats__item:focus-within {
    transform: translateY(-1px);transition: var(--transition);
}

.site-stats__item:hover .site-stats__icon-wrap,
.site-stats__item:focus-within .site-stats__icon-wrap {
    background: #1fa67a;
    border-radius: 50%;transition: var(--transition);
}

.site-stats__item:hover .site-stats__icon--default,
.site-stats__item:focus-within .site-stats__icon--default {
    display: none;transition: var(--transition);
}

.site-stats__item:hover .site-stats__icon--hover,
.site-stats__item:focus-within .site-stats__icon--hover {
    display: block;transition: var(--transition);
}

.site-stats__value {
    margin: 0;
    font-family: var(--sv-font-sans);
    font-size: clamp(2rem, 4vw, 2.6rem);
    font-weight: 700;
    line-height: 1;
    color: var(--sv-primary-orange);
    margin-top: 15px;
}
.site-stats__label {
    margin: 0.35rem 0 0;
    font-size: 1.02rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #111827;
    line-height: 1.2;
}

/* ——— Why Choose Us ——— */
.site-why {
    background: var(--sv-body-bg);
    padding-top: 0;
    padding-bottom: 0;
    background-color: #072549;
    background-image: url("/images/Why-choose-us-BG.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.site-why__layout {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
    overflow: hidden;
}

@media (min-width: 992px) {
    .site-why__layout {
        grid-template-columns: 52% 48%;
        min-height: 31rem;
    }
}

.site-why__content {
    position: relative;
    z-index: 1;
    color: var(--sv-text-white);
    padding: 2.5rem 2rem 2.5rem 2rem;
}

@media (min-width: 992px) {
    .site-why__content {
        padding: 2.6rem 3rem 2.6rem 3.25rem;
    }
}

.site-why__kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
}

.site-why__kicker-line {
    width: 4.3rem;
    height: 3px;
    border-radius: 2px;
    background: var(--sv-accent-green);
}

.site-why__title {
    margin: 1rem 0 0;
    font-family: var(--sv-font-sans);
    font-size: clamp(1.7rem, 3.1vw, 2.2rem);
    line-height: 1.2;
    font-weight: 600;
    color: var(--sv-text-white);
    max-width: 28rem;
}

.site-why__list {
    list-style: none;
    margin: 2rem 0 0;
    padding: 0;
    max-width: 30rem;
}

.site-why__list li {
    position: relative;
    padding-left: 1.55rem;
    margin-bottom: 1.5rem;
    font-size: clamp(1.05rem, 1.7vw, 1.3rem);
    font-weight: 600;
    line-height: 1.35;
    color: var(--sv-text-white);
}

.site-why__list li:last-child {
    margin-bottom: 0;
}

.site-why__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.52em;
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--sv-primary-orange);
}

.site-why__cta {
    display: inline-block;
    margin-top: 2rem;
    background: var(--sv-primary-orange);
    color: var(--sv-text-white);
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0.06em;
    padding: 0.82rem 1.1rem;
    border-radius: 0 !important;
}

.site-why__cta:hover {
    color: var(--sv-text-white);
    background: #e7863a;transition: var(--transition);
}

.site-why__media {
    min-height: 18rem;
    background-image: url("/images/Why-choose-us.jpg");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-color: transparent;
}

@media (min-width: 992px) {
    .site-why__media {
        width: 86%;
        justify-self: start;
        background-position: center;
    }
}

@media (max-width: 991.98px) {
    .site-why__media {
        background-size: cover;
        background-position: center;
        min-height: 20rem;
    }
}

/* ——— Industries Carousel ——— */
.site-industries {
    padding: 3.25rem 0 2.5rem;
    background: #f5f7fa;
}

.site-industries__title {
    margin: 0 0 2.1rem;
    text-align: center;
    font-family: var(--sv-font-sans);
    font-size: clamp(1.7rem, 3vw, 2.5rem);
    font-weight: 600;
    color: #111827;
}

.site-industries-carousel .owl-stage {
    display: flex;
    align-items: stretch;
}

.site-industries-carousel .owl-item {
    display: flex;
    justify-content: center;
}

.site-industries-card {
    width: 100%;
    max-width: 10.5rem;
    text-align: center;
    padding: 0.35rem 0.25rem 0.8rem;
    margin-inline: auto;
}

.site-industries-card__icon {
    width: 6.2rem;
    height: 6.2rem;
    padding: 0.75rem;
    margin: 0 auto 0.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border-radius: 0.2rem;
    transition: background-color 0.2s ease, border-radius 0.2s ease;
    position: relative;
    overflow: hidden;
}

.site-industries-card__icon-img {
    position: absolute;
    inset: 0;
    margin: auto;
    width: 65%;
    height: 65%;
    object-fit: contain;
    display: block;
    transition: opacity 0.2s ease;
}

.site-industries-card__icon-img--hover {
    opacity: 0;
}

.site-industries-card:hover .site-industries-card__icon,
.site-industries-card:focus-within .site-industries-card__icon {
    background: #1fa67a;
    border-radius: 999px;transition: var(--transition);
}

.site-industries-card:hover .site-industries-card__icon-img--default,
.site-industries-card:focus-within .site-industries-card__icon-img--default {
    opacity: 0;transition: var(--transition);
}

.site-industries-card:hover .site-industries-card__icon-img--hover,
.site-industries-card:focus-within .site-industries-card__icon-img--hover {
    opacity: 1;transition: var(--transition);
}

.site-industries-card__label {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.01em;
    color: #1f2937;
}

.site-industries__cta {
    display: inline-block;
    margin-top: 1.75rem;
    padding: 0.85rem 2.7rem;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 700;
    font-size: 0.82rem;
    color: #fff;
    background: var(--sv-primary-orange);
}

.site-industries__cta:hover {
    color: #fff;
    background: #e7863a;transition: var(--transition);
}

/* ——— Team Carousel ——— */
.site-team {
    background: var(--sv-body-bg);
    padding: 2.9rem 0 2rem;
    overflow: hidden;
}
.owl-dots { margin-top: 20px;}
.site-team__header {
    margin-bottom: 2.1rem;
}

.site-team__kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
}

.site-team__kicker-line {
    width: 2.75rem;
    height: 3px;
    border-radius: 2px;
    background: var(--sv-accent-green);
}

.site-team__title {
    margin: 0.55rem 0 0;
    font-family: var(--sv-font-sans);
    font-size: clamp(1.75rem, 3vw, 2.85rem);
    line-height: 1.12;
    font-weight: 700;
    color: #111827;
}


.site-team__dots--left {
    left: -4.5rem;
    top: 0.8rem;
}
.site-team__dots {
    position: absolute;
    width: 8rem;
    height: 12rem;
    background-image: url(/images/Dot-bg.png);
    background-repeat: no-repeat;
    background-size: contain;
    opacity: 0.65;
    pointer-events: none;
    z-index: 0;
}


 
.site-team__dots--left {
    left: -4.5rem;
    top: 0.8rem;
}

.site-team__dots--right {
    right: -7.3rem;
    bottom: 2.2rem;
}

.site-team-carousel {
    position: relative;
    z-index: 1;
}

.site-team-carousel .owl-stage-outer {
    overflow: visible;
}

.site-team-carousel .owl-stage {
    display: flex;
    align-items: flex-end;
}

.site-team-card {
    text-align: center;
    padding: 0.25rem 0.35rem 0.85rem;
}

.site-team-card__image-wrap {
    display: flex;
    justify-content: center;
}

.site-team-card__image {
    width: min(100%, 19.6rem);
    height: 18.2rem;
    object-fit: cover;
    object-position: center top;
}

.site-team-card__meta {
    display: inline-block;
    min-width: 13.2rem;
    margin-top: -1.35rem;
    padding: 0.72rem 1.1rem 0.68rem;
    background: #fff;
    box-shadow: 0 0.55rem 1rem rgba(0, 33, 71, 0.12);
}

.site-team-card__name {
    margin: 0;
    color: var(--sv-primary-orange);
    font-size: 1.12rem;
    font-weight: 600;
    line-height: 1.2;
}

.site-team-card__role {
    margin: 0.2rem 0 0;
    color: #4b5563;
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.2;
}

.site-team-card__exp {
    margin: 0.18rem 0 0;
    color: #111827;
    font-size: 0.95rem;
    font-weight: 800;
    line-height: 1.2;
}

.site-team-carousel .owl-item:not(.center) .site-team-card {
    opacity: 0.93;
}

.site-team-carousel .owl-item.center .site-team-card {
    opacity: 1;
}

.site-team-carousel.owl-theme .owl-dots {
    margin-top: 1rem;
}

.site-team-carousel.owl-theme .owl-dots .owl-dot span {
    width: 0.58rem;
    height: 0.58rem;
    margin: 0.28rem 0.26rem;
    background: #0b2c50;
    opacity: 1;
}

.site-team-carousel.owl-theme .owl-dots .owl-dot.active span {
    background: #1fa67a;
}

@media (max-width: 767.98px) {
    .site-team__dots {
        display: none;
    }

    .site-team-card__image {
        width: min(100%, 17rem);
        height: 19.4rem;
    }
    .site-hero__title-line,.site-hero__title-accent {
         font-size: clamp(2.35rem, 3.5vw, 2rem);
     }

     .site-hero-stat{ width: 100%;}
}

/* ——— Full-height parallax CTA ——— */
.site-parallax-cta {
    position: relative;
    min-height: 340px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-image: url("/images/IT-solution-service-section.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    overflow: hidden;
}

.site-parallax-cta__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(4, 33, 68, 0.68) 0%, rgba(4, 33, 68, 0.62) 100%);
    z-index: 1;
}

.site-parallax-cta__content {
    position: relative;
    z-index: 2;
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.site-parallax-cta__title {
    margin: 0 0 1.5rem;
    color: #fff;
    font-family: var(--sv-font-sans);
    font-size: clamp(1.7rem, 3vw, 3rem);
    line-height: 1.18;
    font-weight: 600;
}

.site-parallax-cta__btn {
    display: inline-block;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
    background: var(--sv-primary-orange);
    padding: 0.86rem 2rem;
    border-radius: 0rem;
}

.site-parallax-cta__btn:hover {
    color: #fff;
    background: #e7863a;transition: var(--transition);
}

/* Mobile browsers often disable/lag fixed attachment; use scroll for stability */
@media (max-width: 991.98px) {
    .site-parallax-cta {
        min-height: 300px;
        background-attachment: scroll;
    }
}

/* ——— Clients Carousel ——— */
.site-clients {
    background: var(--sv-section-muted-bg);
    padding: 3rem 0 2.6rem;
}

.site-clients__header {
    margin-bottom: 1.9rem;
}

.site-clients__kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
}

.site-clients__kicker-line {
    width: 2.75rem;
    height: 3px;
    border-radius: 2px;
    background: var(--sv-accent-green);
}

.site-clients__title {
    margin: 0.55rem 0 0;
    font-family: var(--sv-font-sans);
    font-size: clamp(2rem, 2.6vw, 3.2rem);
    line-height: 1.14;
    font-weight: 700;
    color: #111827;
}

.site-clients-carousel .owl-stage {
    display: flex;
    align-items: center;
}

.site-client-logo {
    height: 7rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.45rem 0.65rem;
}

.site-client-logo img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* ——— Testimonials ——— */
.site-testimonials {
    background: #f7f8fa;
    padding: 3.2rem 0 3.1rem;
}

.site-testimonials__kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
}

.site-testimonials__kicker-line {
    width: 2.75rem;
    height: 3px;
    border-radius: 2px;
    background: var(--sv-accent-green);
}

.site-testimonials__title {
    margin: 0.7rem 0 0;
    font-family: var(--sv-font-sans);
    font-size: clamp(2rem, 2.4vw, 3rem);
    line-height: 1.2;
    font-weight: 700;
    color: #111827;
    max-width: 22rem;
}
.site-testimonial-card {
    position: relative;
    background: #27aa72;
    color: #fff;
    padding: 2.35rem 4rem 2.35rem 4rem;
}
.site-testimonial-card::after {
    content: "";
    position: absolute;
    left: 2.45rem;
    bottom: -1.55rem;
    width: 5.8rem;
    height: 1.75rem;
    background: #27aa72;
    clip-path: polygon(0 0, 100% 0, 0 100%);
}

.site-testimonial-card__quote-mark {
    position: absolute;
    right: 0;
    top: 0;
    width: 3rem;
    height: 3rem;
    background: #0d2f56;
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-testimonial-card__quote-mark img {
    width: 2.2rem;
    height: auto;
}


 
.owl-carousel .owl-item img {
    display: block;
    width: 100%;
}
.site-testimonial-card__stars img {
    /* width: 6.25rem; */
    max-width: 30%;
    /* height: auto; */
    display: block;
}

.site-testimonial-card__text {
    margin: 0.52rem 0 0;
    font-size:1rem;
    font-weight: 500;
    line-height: 1.75;
    max-width: 31rem;
}

.site-testimonial-card__author {
    margin: 0.6rem 0 0;
    font-size: 1.08rem;
    font-weight: 500;
}

.site-testimonial-carousel.owl-theme .owl-dots {
    margin-top: 0.95rem;
    text-align: center;
}

.site-testimonial-carousel.owl-theme .owl-dots .owl-dot span {
    width: 0.58rem;
    height: 0.58rem;
    margin: 0.28rem 0.26rem;
    background: #0b2c50;
    opacity: 1;
}

.site-testimonial-carousel.owl-theme .owl-dots .owl-dot.active span {
    background: #1fa67a;
}

@media (max-width: 991.98px) {
    .site-testimonials {
        padding: 2.7rem 0 2.5rem;
    }

    .site-testimonial-card {
        padding-right: 3.25rem;
    }
}

/* ——— FAQ ——— */
.site-faq {
    background: #fff;
    padding: 3.3rem 0;
}

.site-faq__media {
    overflow: hidden;
}

.site-faq__media img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 31rem;
    object-fit: cover;
}

.site-faq__content {
    position: relative;
    padding-top: 0.25rem;
}

.site-faq__content::after {
    content: "";
    position: absolute;
    right: -5%;
    top: 0;
    width: 55%;
    height: 100%;
    background: url("/images/BG-design.png") top right / contain no-repeat;
    opacity: 0.13;
    pointer-events: none;
    z-index: 0;
}

.site-faq__kicker,
.site-faq__title,
.site-faq-accordion {
    position: relative;
    z-index: 1;
}

.site-faq__kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
}

.site-faq__kicker-line {
    width: 2.75rem;
    height: 3px;
    border-radius: 2px;
    background: var(--sv-accent-green);
}

.site-faq__title {
    margin: 1.65rem 0 1.65rem;
    font-family: var(--sv-font-sans);
    font-size: clamp(1.95rem, 2.9vw, 3.2rem);
    line-height: 1.2;
    font-weight: 700;
    color: #111827;
    max-width: 30rem;
}

.site-faq-accordion .accordion-item {
    border: 1px solid #e7ebef;
    border-radius: 0;
    margin-bottom: 0.8rem;
    overflow: hidden;
    background: #fff;
}

.site-faq-accordion .accordion-item:last-child {
    margin-bottom: 0;
}

.site-faq-accordion .accordion-button {
    box-shadow: none;
    padding: 0.95rem 3rem 0.95rem 1.25rem;
    font-size: 1.12rem;
    font-weight: 600;
    color: #25303b;
    background: #fff;
    border:1px solid #f3f4f4;
    border-bottom: 2px solid var(--sv-primary-orange);
}

.site-faq-accordion .accordion-button::after {
    content: "+";
    background-image: none;
    transform: none;
    width: auto;
    height: auto;
    font-size: 1.9rem;
    line-height: 1;
    color: var(--sv-primary-orange);
    font-weight: 300;
    margin-top: -0.15rem;
}

.site-faq-accordion .accordion-button:not(.collapsed) {
    color: #fff;
    background: var(--sv-primary-orange);
}

.site-faq-accordion .accordion-button:not(.collapsed)::after {
    content: "−";
    color: #fff;
}

.site-faq-accordion .accordion-body {
    padding: 0.9rem 1.25rem 1rem;
    color: #2d3742;
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.75;
    border:1px solid #f3f4f4;border-top: none;
}

@media (max-width: 991.98px) {
    .site-faq {
        padding: 2.6rem 0;
    }

    .site-faq__media img {
        min-height: 21rem;
    }

    .site-faq__content::after {
        display: none;
    }
}

/* ——— News & Articles ——— */
.site-news {
    background: #fff;
    padding: 3.1rem 0 2.8rem;
}

.site-news::before {
    content: "";
    position: absolute;
}

.site-news .container::before {
    content: "";
    position: absolute;
    left: -2.8rem;
    top: 2.6rem;
    width: 13rem;
    height: 17rem;
    background: url("/images/BG-design-left.png") left center / contain no-repeat;
    opacity: 0.12;
    pointer-events: none;
    z-index: 0;
}

.site-news__header {
    margin-bottom: 1.9rem;
    position: relative;
    z-index: 1;
}

.site-news__kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sv-primary-orange);
}

.site-news__kicker-line {
    width: 2.75rem;
    height: 3px;
    border-radius: 2px;
    background: var(--sv-accent-green);
}

.site-news__title {
    margin: 0.55rem 0 0;
    font-family: var(--sv-font-sans);
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1.15;
    font-weight: 700;
    color: #111827;
}

.site-news-card {
    background: #fff;
    border: 1px solid #edf1f4;
    box-shadow: 0 0.4rem 1.1rem rgba(0, 33, 71, 0.1);
    position: relative;
    z-index: 1;
    height: 100%;
}

.site-news-card__image-wrap {
    position: relative;
    overflow: hidden;
}

.site-news-card__image {
    display: block;
    width: 100%;
    height: 12.2rem;
    object-fit: cover;
}

.site-news-card__date {
    position: absolute;
    left: 0;
    bottom: -1px;
    background: var(--sv-primary-orange);
    color: #111827;
    font-size: 1.15rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.8rem 0.9rem 0.8rem;
}

.site-news-card__date::after {
    content: "";
    position: absolute;
    right: 1px;
    top: 0;
    width: 1.45rem;
    height: 100%;
    background: var(--sv-primary-orange);
    transform: translateX(100%);
    clip-path: polygon(0 0, 100% 100%, 0 100%);
}

.site-news-card__body {
    padding: 0.85rem 1.1rem 0.95rem;
}

.site-news-card__title {
    margin: 0;
    font-family: var(--sv-font-sans);
    font-size: 1.3rem;
    line-height: 1.25;
    font-weight: 600;
    color: #0a0a0a;
    /* max-width: 12.4rem; */
}

.site-news-card__meta {
    margin: 0.45rem 0 0;
    font-size: 0.66rem;
    font-weight: 600;
    color: #000;
}

@media (max-width: 991.98px) {
    .site-news {
        padding: 2.6rem 0 2.4rem;
    }

    .site-news .container::before {
        display: none;
    }

    .site-news-card__title {
        max-width: none;
    }
}

/* ——— Final CTA + Footer ——— */
.site-footer-cta {
    background: var(--sv-primary-orange);
    padding: 2.35rem 0;
}
.site-footer-cta__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
}

.site-footer-cta__copy h2 {
    margin: 0;
    font-family: var(--sv-font-sans);
    font-size: 1.6rem;
    line-height: 1.05;
    font-weight: 700;
    text-transform: uppercase;
    color: #000000;
}

.site-footer-cta__copy p {
    margin: 0.5rem 0 0;
    font-size: 1.2rem;
    line-height: 1.35;
    font-weight: 600;
    color: #fff;
    text-transform: none;
    max-width: 26rem;
}

.site-footer-cta__actions {
    display: flex;
    gap: 0.8rem;
    flex-shrink: 0;
}

.site-footer-cta__btn {
    display: inline-block;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 1rem;
    font-weight: 700;
    color: var(--sv-primary-orange);
    background: #fff;
    border: 1px solid #f3f4f6;
    padding: 0.8rem 1.15rem;
    min-width: 12.1rem;
    text-align: center;
}

.site-footer-cta__btn:hover {
    color: #fff;
    background: #0d2f56; transition: var(--transition);transition: var(--transition);
}

.site-footer {
    background: #f4f5f9;
    padding: 1.8rem 0 1.3rem;
    color: #374151;
}

.site-footer__brand img {
    width: 12.4rem;
    height: auto;
}

.site-footer__social {
    display: flex;
    gap: 0.55rem;
    margin-top: 0.7rem;
}

.site-footer__social a {
    width: 1.55rem;
    height: 1.55rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.site-footer__social img {
    width: 1.4rem;
    height: 1.4rem;
    object-fit: contain;
}

.site-footer__title {
    position: relative; /* important */
    margin: 0 0 1rem;
    font-size: 1.65rem;
    font-weight: 600;
    color: #1f2937;
    border-bottom: 2px solid #aab1bb;
    padding-bottom: 0.2rem;
    max-width: 9.6rem;
}

.site-footer__title::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 40%;
    height: 2px;
    background-color: var(--sv-primary-orange);
}
.site-footer__links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.site-footer__links li {
    margin-bottom: 0.25rem;
}

.site-footer__links a {
    text-decoration: none;
    color: #9d9ea2;
    font-size: 1rem;
    font-weight: 600;
}

.site-footer__links a:hover {
    color: #0d2f56; transition: var(--transition);transition: var(--transition);
}

.site-footer__contact {
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer__contact li {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    margin-bottom: 0.65rem;
    color: #6b7280;
    font-size: 1rem;
    line-height: 1.45;
    font-weight: 600;
}

.site-footer__contact img {
    width: 0.95rem;
    height: 0.95rem;
    margin-top: 0.1rem;
    object-fit: contain;
}

.site-footer__contact a {
    color: #4b5563;
    text-decoration: none;
}

.site-footer__contact a:hover {
    color: #0d2f56;transition: var(--transition);
}

.site-footer__copyright {
    margin-top: 0;
    text-align: center;
    background: #08284c;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1;
    padding: 0.7rem 0.7rem;
}

@media (max-width: 991.98px) {
    .site-footer-cta__row {
        flex-direction: column;
        align-items: flex-start;
    }

    .site-footer-cta__actions {
        width: 100%;
        flex-wrap: wrap;
    }

    .site-footer-cta__btn {
        min-width: 10rem;
    }

    .site-footer {
        padding-top: 1.5rem;
    }
}

/* ——— About page ——— */
.site-page--about .site-nav .nav-link.active {
    color: var(--sv-primary-orange) !important;
}

.site-page--about .site-nav .nav-link.active::after {
    background: var(--sv-primary-orange);
}

.site-about-hero {
    position: relative;
    min-height: clamp(22rem, 42vh, 22rem);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-family: var(--sv-font-hero);
}
.site-about-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.site-about-hero__overlay {
    position: absolute;
    inset: 0;
  }

.site-about-hero__inner {
    position: relative;
    z-index: 2;
    padding: 3rem 1rem;
    text-align: center;
}

.site-about-hero__title {
    margin: 0;
    font-weight: 700;
    line-height: 1.1;
    font-size: clamp(2.5rem, 6vw, 3.75rem);
}

.site-about-hero__title-line {
    color: var(--sv-text-white);
    margin-right: 0.35em;
}

.site-about-hero__title-accent {
    color: var(--sv-primary-orange);
}

.site-about-intro {
    background: var(--sv-body-bg);
}

.site-about-intro__copy {
    color: #808185;
    font-size: 1.05rem;
    line-height: 1.75;
}

.site-about-intro__copy p {
    margin-bottom: 1.1rem;
}

.site-about-intro__copy p:last-child {
    margin-bottom: 0;
}

.site-about-intro__lead {
    font-weight: 600;
    color: #808185;
    font-size: 1.05rem;
}

.site-about-intro__col-media {
    display: flex;
    flex-direction: column;
}

.site-about-intro__figure {
    position: relative;
    flex: 1 1 auto;
    width: 100%;
    min-height: 16rem;
    border-radius: 0.35rem;
    overflow: hidden;
    box-shadow: 0 12px 40px rgba(0, 33, 71, 0.12);
}

@media (min-width: 992px) {
    .site-about-intro__figure {
        min-height: 0;
        height: 100%;
    }
}

.site-about-intro__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.site-about-vision {
    position: relative;
    background: #031a33;
    color: var(--sv-text-white);
    padding: 3.5rem 0;
    overflow: hidden;
}

.site-about-vision--slider {
    padding: 0;
    overflow: visible;
    /* Minimum row height; row grows so Core Values fits without scroll */
    --vision-slide-h: clamp(36rem, 72vh, 56rem);
    --vision-image-mobile-h: 22rem;
}

.site-about-vision--slider .site-about-vision__pattern {
    z-index: 0;
}

.site-about-vision__carousel {
    position: relative;
    z-index: 1;
    padding-bottom: 0;
}

.site-about-vision__carousel .carousel-inner {
    overflow: visible;
}

@media (max-width: 991.98px) {
    .site-about-vision-slide > .row {
        min-height: 0;
    }

    .site-about-vision__col-media {
        height: var(--vision-image-mobile-h);
        min-height: var(--vision-image-mobile-h);
        max-height: var(--vision-image-mobile-h);
        flex: 0 0 auto;
    }

    .site-about-vision__figure {
        height: 100%;
        min-height: 0;
    }
}

@media (min-width: 992px) {
    .site-about-vision-slide > .row {
        min-height: var(--vision-slide-h);
        height: auto;
        align-items: stretch;
    }

    .site-about-vision__col-media {
        height: auto;
        min-height: var(--vision-slide-h);
        max-height: none;
        align-self: stretch;
    }

    .site-about-vision__col-copy {
        height: auto;
        min-height: var(--vision-slide-h);
        max-height: none;
        overflow-y: visible;
    }
}

.site-about-vision__pattern {
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background-size: cover;
    background-position: right center;
    background-repeat: no-repeat;
    pointer-events: none;
}

.site-about-vision__col-media {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 16rem;
}

@media (min-width: 992px) {
    .site-about-vision__col-media {
        align-self: stretch;
    }
}

.site-about-vision__figure {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 auto;
    width: 100%;
    min-height: 16rem;
    margin: 0;
    overflow: hidden;
    border-radius: 0;
    background: transparent;
}

@media (min-width: 992px) {
    .site-about-vision__figure {
        min-height: 0;
        height: 100%;
    }
}

.site-about-vision__img {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    object-position: center;
}

.site-about-vision__col-copy {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 2rem 1.25rem 2.5rem;
}

@media (min-width: 992px) {
    .site-about-vision__col-copy {
        justify-content: center;
        align-items: center;
        padding: 1rem 1.5rem;
    }
}

.site-about-vision__content {
    width: 100%;
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    padding: 0.35rem 0.4rem 0.55rem;
}

@media (min-width: 992px) {
    .site-about-vision__content {
        padding: 0.65rem 1rem 0.8rem;
    }
}

@media (min-width: 1200px) {
    .site-about-vision__content {
        max-width: 38rem;
        padding: 0.8rem 1.35rem 1rem;
    }
}

.site-about-vision__icon-wrap {
    margin-bottom: 0.65rem;
}

.site-about-vision__icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4.5rem;
    height: 4.5rem;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.2);
}

.site-about-vision__icon {
    width: 2.75rem;
    height: auto;
    max-height: 2.75rem;
    display: block;
    object-fit: contain;
}

.site-about-vision__title {
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: 800;
    color: #f28c28;
    margin-bottom: 0.65rem;
}

.site-about-vision__lead {
    color: #ffffff;
    font-size: 1.05rem;
    line-height: 1.75;
    font-weight: 500;
}

.site-about-core-values {
    margin: 0;
    padding: 0.25rem 0.15rem 0.2rem;
}

.site-about-core-values__item {
    margin: 0;
    padding: 0.2rem 0;
    border: 0;
}

.site-about-core-values__name {
    font-size: 1rem;
    font-weight: 800;
    color: #f28c28;
    margin: 0 0 0.2rem;
    line-height: 1.25;
}

.site-about-core-values__text {
    color: #ffffff;
    font-size: 0.94rem;
    line-height: 1.5;
    margin: 0;
}

.site-about-core-values__item + .site-about-core-values__item .site-about-core-values__name {
    margin-top: 0.35rem;
}

.site-about-vision__control {
    width: 2.75rem;
    height: 2.75rem;
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
    opacity: 0.92;
    border-radius: 50%;
    background: rgba(0, 33, 71, 0.55);
    z-index: 5;
}

.site-about-vision__control:hover {
    opacity: 1;
    background: rgba(0, 33, 71, 0.78);
}

.site-about-vision__control--prev {
    left: 0.65rem;
}

.site-about-vision__control--next {
    right: 0.65rem;
}

@media (max-width: 991.98px) {
    .site-about-vision__control {
        width: 2.35rem;
        height: 2.35rem;
    }

    .site-about-vision__control--prev {
        left: 0.35rem;
    }

    .site-about-vision__control--next {
        right: 0.35rem;
    }
}

.site-about-journey {
    position: relative;
    background: var(--sv-section-muted-bg);
    overflow: hidden;
}

.site-about-journey::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: min(42%, 28rem);
    height: 100%;
    pointer-events: none;
    opacity: 0.22;
    background-image: radial-gradient(circle at 1px 1px, rgba(0, 33, 71, 0.2) 1px, transparent 0);
    background-size: 22px 22px;
    mask-image: linear-gradient(to left, black, transparent);
}

.site-about-journey .container {
    position: relative;
    z-index: 1;
}

.site-about-journey__header {
    max-width: 44rem;
}

.site-about-journey__kicker {
    font-weight: 600;
    font-size: clamp(1.85rem, 2.8vw + 0.85rem, 2.5rem);
    color: var(--sv-primary-orange);
    letter-spacing: 0.02em;
}

.site-about-journey__subtitle {
    color: var(--sv-primary-navy);
    font-weight: 600;
    font-size: 1rem;
    line-height: 1.5;
}

.site-about-journey__panel {
    max-width:100%;
    margin-left: auto;
    margin-right: auto;
    padding: 1.35rem 1.5rem;
    background: #fff;
    border-radius: 0.35rem;
    box-shadow: 0 8px 28px rgba(0, 33, 71, 0.08);
}

.site-about-journey__panel-text {
    color: #5c6368;
    font-size: 1.02rem;
    line-height: 1.7;
    font-weight: 500;
}

.site-about-timeline__items {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    gap: 0.35rem;
    position: relative;
    padding: 0.5rem 0;
}

.site-about-timeline__items::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 3px;
    background: var(--sv-primary-orange);
    transform: translateY(-50%);
    z-index: 0;
}

.site-about-timeline__item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    z-index: 1;
    min-width: 0;
    cursor: pointer;
    border-radius: 0.25rem;
    outline: none;
    transition: background-color 0.15s ease;
}

.site-about-timeline__item:hover {
    background-color: rgba(0, 33, 71, 0.04);
}

.site-about-timeline__item:focus-visible {
    outline: 2px solid var(--sv-primary-orange);
    outline-offset: 2px;
}

.site-about-timeline__label,
.site-about-timeline__year {
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.25;
    min-height: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.2rem;
}

.site-about-timeline__year {
    color: var(--sv-primary-navy);
    font-weight: 800;
}

.site-about-timeline__label {
    color: var(--sv-accent-green);
    font-weight: 700;
}

@media (min-width: 768px) {
    .site-about-timeline__label,
    .site-about-timeline__year {
        font-size: 0.92rem;
    }
}

.site-about-timeline__mid {
    height: 2.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-about-timeline__node {
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    background: #fff;
    border: 3px solid var(--sv-primary-navy);
    box-shadow: 0 0 0 2px #fff;
    transition: border-color 0.15s ease, background-color 0.15s ease;
}

.site-about-timeline__item.is-selected .site-about-timeline__node,
.site-about-timeline__item:hover .site-about-timeline__node,
.site-about-timeline__item:focus-visible .site-about-timeline__node {
    border-color: var(--sv-accent-green);
    background: var(--sv-accent-green);
}

.site-about-commitment {
    background: #fff;
    padding: 3.3rem 0;
}

.site-about-commitment__header {
    max-width: 48rem;
}

.site-about-commitment__kicker {
    font-weight: 600;
    font-size: clamp(1.9rem, 3vw, 2.7rem);
    color: var(--sv-primary-orange);
    letter-spacing: 0.02em;
}

.site-about-commitment__subtitle {
    color: #111827;
    font-weight: 600;
    font-size: 1.05rem;
    line-height: 1.55;
}

.site-about-commitment__media {
    position: relative;
    height: 100%;
    display: flex;
    overflow: hidden;
    border-radius: 0;
}

.site-about-commitment__media::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 38%;
    max-width: 9rem;
    background: url("/images/BG-design-left.png") left center / auto 115% no-repeat;
    opacity: 0.2;
    pointer-events: none;
    z-index: 1;
}

.site-about-commitment__figure {
    flex: 1 1 auto;
    height: 100%;
    margin: 0;
}

.site-about-commitment__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

@media (min-width: 992px) {
    .site-about-commitment .row.align-items-stretch {
        align-items: stretch !important;
    }

    .site-about-commitment__media,
    .site-about-commitment__figure {
        height: 100%;
        min-height: 0;
    }
}

@media (max-width: 991.98px) {
    .site-about-commitment {
        padding: 2.6rem 0;
    }

    .site-about-commitment__img {
        min-height: 21rem;
        height: 21rem;
    }

    .site-about-commitment__figure {
        height: 21rem;
    }

    .site-about-commitment__media::before {
        opacity: 0.14;
    }
}

/* Accordion: same + / − treatment as .site-faq-accordion; green titles, orange +, green − when open */
.site-about-commitment-accordion .accordion-item {
    border: 1px solid #e7ebef;
    border-radius: 0;
    margin-bottom: 0.85rem;
    overflow: hidden;
    background: #fff;
}

.site-about-commitment-accordion .accordion-item:last-child {
    margin-bottom: 0;
}

.site-about-commitment-accordion .accordion-button {
    box-shadow: none !important;
    padding: 0.95rem 3rem 0.95rem 1.25rem;
    font-size: 1.08rem;
    font-weight: 600;
    color: var(--sv-accent-green);
    background: #fff;
    border: 0;
    border-radius: 0;
}

.site-about-commitment-accordion .accordion-button::after {
    content: "+";
    background-image: none !important;
    transform: none !important;
    width: auto;
    height: auto;
    font-size: 1.9rem;
    line-height: 1;
    font-weight: 300;
    color: var(--sv-primary-orange);
    margin-top: -0.15rem;
}

.site-about-commitment-accordion .accordion-button:not(.collapsed) {
    color: var(--sv-accent-green);
    background: #fff;
    border-bottom: 1px solid #e7ebef;
}

.site-about-commitment-accordion .accordion-button:not(.collapsed)::after {
    content: "−";
    color: var(--sv-accent-green);
}

.site-about-commitment-accordion .accordion-body {
    padding: 0.85rem 1.25rem 1.1rem;
    color: #111827;
    font-size: 0.98rem;
    font-weight: 500;
    line-height: 1.75;
    border: 0;
    background: #fff;
}

.site-about-commitment-accordion .accordion-item:has(.accordion-collapse.show) .accordion-body,
.site-about-commitment-accordion .accordion-collapse.show .accordion-body {
     border-top: 1px solid #e7ebef;
}

.site-about-commitment-accordion .accordion-collapse {
    border: 0;
}

@media (max-width: 767.98px) {
    .site-about-timeline__items {
        flex-direction: column;
        gap: 1rem;
        padding: 0;
    }

    .site-about-timeline__items::before {
        display: none;
    }

    .site-about-timeline__item {
        display: grid;
        grid-template-columns: auto 1fr;
        grid-template-rows: auto auto;
        align-items: center;
        text-align: left;
        gap: 0.35rem 0.85rem;
        background: #fff;
        border: 1px solid #e2e8f0;
        border-radius: 0.4rem;
        padding: 0.85rem 1rem;
    }

    .site-about-timeline__mid {
        grid-column: 1;
        grid-row: 1 / span 2;
        height: auto;
    }

    .site-about-timeline__label,
    .site-about-timeline__year {
        min-height: 0;
        justify-content: flex-start;
        padding: 0;
        font-size: 0.94rem;
    }

    .site-about-timeline__item--year-first .site-about-timeline__year {
        grid-column: 2;
        grid-row: 1;
    }

    .site-about-timeline__item--year-first .site-about-timeline__label {
        grid-column: 2;
        grid-row: 2;
    }

    .site-about-timeline__item--label-first .site-about-timeline__label {
        grid-column: 2;
        grid-row: 1;
    }

    .site-about-timeline__item--label-first .site-about-timeline__year {
        grid-column: 2;
        grid-row: 2;
    }
}
