/* ═══════════════════════════════════════════════════════════
   724Transfer4You — Design System v2
   ═══════════════════════════════════════════════════════════ */

@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&family=Raleway:wght@600;700;800;900&display=swap");

/* ── Design Tokens ── */
:root {
    --orange:        #ff8f16;
    --orange-dark:   #e07800;
    --orange-light:  #fff0d9;
    --navy:          #002873;
    --navy-mid:      #003fa0;
    --navy-light:    #e8edf7;
    --green:         #00a54c;
    --green-dark:    #007a38;
    --green-light:   #d0f0e1;
    --dark:          #0d1b2a;
    --text:          #1a2332;
    --text-mid:      #4a5568;
    --text-light:    #8494a7;
    --white:         #ffffff;
    --bg:            #f7f9fc;
    --border:        #dde5f0;
    --shadow:        0 4px 24px rgba(0,40,115,0.08);
    --radius:        10px;
    --radius-sm:     6px;
    --radius-lg:     18px;
    --radius-full:   9999px;
    --font-body:     'Poppins', system-ui, -apple-system, sans-serif;
    --font-display:  'Raleway', Georgia, serif;
    --duration:      .25s;
    --ease:          cubic-bezier(.4,0,.2,1);

    /* compat aliases used by other pages */
    --c-navy:        var(--navy);
    --c-gold:        var(--orange);
    --c-gold-hover:  var(--orange-dark);
    --c-gold-light:  rgba(255,143,22,.14);
    --c-gold-glow:   rgba(255,143,22,.30);
    --c-white:       var(--white);
    --c-off-white:   var(--bg);
    --c-gray-50:     #f3f5f8;
    --c-gray-100:    #e8edf2;
    --c-gray-200:    #d1d9e4;
    --c-gray-300:    #b0bdd0;
    --c-text:        var(--text);
    --c-text-muted:  var(--text-mid);
    --c-text-soft:   #64748b;
    --c-text-on-dark:      rgba(255,255,255,.93);
    --c-text-on-dark-muted:rgba(255,255,255,.60);
    --c-text-on-dark-soft: rgba(255,255,255,.38);
    --c-border:      rgba(0,40,115,.08);
    --c-border-mid:  rgba(0,40,115,.13);
    --c-border-dark: rgba(255,255,255,.10);
    --c-success:     var(--green);
    --c-danger:      #E74C3C;
    --shadow-xs:     0 1px 2px rgba(0,40,115,.05);
    --shadow-sm:     0 2px 8px rgba(0,40,115,.06);
    --shadow-md:     0 8px 30px rgba(0,40,115,.10);
    --shadow-lg:     0 16px 48px rgba(0,40,115,.14);
    --shadow-xl:     0 24px 64px rgba(0,40,115,.18);
    --header-h:      66px;
    --container:     min(1200px, 100% - 48px);
    --container-sm:  min(960px, 100% - 48px);
    --container-xs:  min(720px, 100% - 48px);
    --ff-body:       var(--font-body);
    --ff-display:    var(--font-display);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;max-width:100%}
body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
img,svg{display:block;max-width:100%}
img{height:auto}
input,button,textarea,select{font:inherit}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;outline:none;background:none}

/* ── Base ── */
body.website-body{
    font-family:var(--font-body);
    font-size:1rem;
    line-height:1.65;
    color:var(--text);
    background:var(--white);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
}
::selection{background:var(--orange-light);color:var(--navy)}

h1,h2,h3,h4{font-family:var(--font-display)}

/* ── Container ── */
.container{width:var(--container);margin-inline:auto}
.container--sm{width:var(--container-sm);margin-inline:auto}
.container--xs{width:var(--container-xs);margin-inline:auto}

/* ══════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════ */
.navbar{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:transparent;box-shadow:none;
    transition:background .3s,box-shadow .3s;
}
.navbar.scrolled{
    background:var(--navy-mid)!important;
    box-shadow:0 4px 20px rgba(0,63,160,.35)!important;
}

.nav-inner{
    display:flex;align-items:center;justify-content:space-between;
    height:var(--header-h);gap:12px;
}

/* Logo */
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo-block{display:flex;flex-direction:column;align-items:flex-start;gap:2px;line-height:1.15}
.logo-tagline{
    font-family:var(--font-body);font-size:10px;font-weight:400;font-style:italic;
    color:rgba(255,255,255,.82);letter-spacing:.02em;white-space:nowrap;
}
.navbar.scrolled .logo-tagline{color:rgba(255,255,255,.78)}
.logo-main{
    font-family:var(--font-display);font-size:22px;font-weight:900;
    color:var(--white);letter-spacing:-.5px;white-space:nowrap;
}
.logo-main span{color:var(--orange)}

/* scrolled vs not-scrolled states */
.navbar.scrolled .nav-links a{color:rgba(255,255,255,.85)}
.navbar.scrolled .nav-links a:hover{color:var(--white)}
.navbar.scrolled .nav-ctrl{color:rgba(255,255,255,.85)}
.navbar.scrolled .nav-ctrl:hover{background:rgba(255,255,255,.12);color:var(--white);border-color:rgba(255,255,255,.2)}
.navbar.scrolled .logo-main{color:var(--white)}
.navbar.scrolled .hamburger span{background:var(--white)}

.navbar:not(.scrolled) .nav-links a{color:rgba(255,255,255,.90)}
.navbar:not(.scrolled) .nav-links a:hover{color:var(--white)}
.navbar:not(.scrolled) .nav-ctrl{color:rgba(255,255,255,.90)}
.navbar:not(.scrolled) .nav-ctrl:hover{background:rgba(255,255,255,.15);color:var(--white);border-color:rgba(255,255,255,.25)}
.navbar:not(.scrolled) .logo-main{color:var(--white)}
.navbar:not(.scrolled) .logo-main span{color:var(--orange)}
.navbar:not(.scrolled) .hamburger span{background:var(--white)}

/* solid header for sub-pages */
.navbar--solid{background:var(--navy-mid)!important;box-shadow:0 4px 20px rgba(0,63,160,.35)!important}

/* Desktop Nav Links */
.nav-links{display:flex;align-items:center;gap:28px;flex:1;justify-content:center}
.nav-links a{font-size:14px;font-weight:500;white-space:nowrap;transition:color .2s}

/* Nav Controls */
.nav-controls{display:flex;align-items:center;gap:3px;flex-shrink:0}
.nav-dd{position:relative}
.nav-ctrl{
    display:flex;align-items:center;gap:5px;
    padding:7px 10px;border-radius:var(--radius-sm);
    font-size:13px;font-weight:600;
    border:1.5px solid transparent;
    transition:all .2s;white-space:nowrap;
}
.nav-ctrl:focus{outline:none}
.nav-ctrl--user{padding:7px 10px}
.nav-ctrl--user i{font-size:18px;color:var(--white)}
.navbar .user-dd.open .nav-ctrl--user i{color:var(--navy)}
.nav-ctrl:hover,.nav-dd.open .nav-ctrl{
    background:var(--navy-light);border-color:var(--border);color:var(--navy);
}
.dd-arrow{font-size:10px!important;opacity:.6;transition:transform .25s}
.nav-dd.open .dd-arrow{transform:rotate(180deg)}

/* Dropdown Menu */
.dd-menu{
    position:absolute;top:calc(100% + 8px);right:0;
    background:var(--white);border:1px solid var(--border);
    border-radius:var(--radius);
    box-shadow:0 8px 32px rgba(0,40,115,.12);
    min-width:185px;max-height:320px;overflow-y:auto;overscroll-behavior:contain;padding:6px;
    opacity:0;visibility:hidden;transform:translateY(-6px);
    transition:all .2s ease;z-index:200;
    scrollbar-width:thin;scrollbar-color:var(--c-gray-300) transparent;
}
.dd-menu::-webkit-scrollbar{width:5px}
.dd-menu::-webkit-scrollbar-track{background:transparent}
.dd-menu::-webkit-scrollbar-thumb{background:var(--c-gray-300);border-radius:var(--radius-full)}
.nav-dd.open .dd-menu{opacity:1;visibility:visible;transform:none}
.dd-menu a{
    display:flex;align-items:center;gap:10px;
    width:100%;padding:9px 12px;border-radius:6px;
    font-size:13px;font-weight:500;color:var(--text);
    transition:background .15s;
}
.dd-menu a:hover{background:var(--navy-light);color:var(--navy)}
.dd-menu a.dd-active{background:var(--navy);color:var(--white)}
.dd-lang-badge{
    display:inline-flex;align-items:center;justify-content:center;
    width:28px;height:20px;border-radius:4px;flex-shrink:0;
    font-size:10px;font-weight:700;letter-spacing:.04em;
    background:var(--navy-light);color:var(--navy);
}
.dd-menu a.dd-active .dd-lang-badge{background:rgba(255,255,255,.2);color:var(--white)}
.dd-divider{height:1px;background:var(--border);margin:5px 0}
.dd-label{
    font-size:11px;font-weight:600;color:var(--text-light);
    text-transform:uppercase;letter-spacing:.08em;padding:6px 12px 4px;
}
.dd-sym{font-weight:700;width:20px;display:inline-block;flex-shrink:0}

/* Hamburger */
.hamburger{
    display:none;flex-direction:column;justify-content:center;
    gap:5px;padding:6px;border-radius:8px;flex-shrink:0;
}
.hamburger span{
    display:block;width:22px;height:2px;background:var(--navy);
    border-radius:2px;transition:all .3s;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile Menu */
.mobile-menu{
    display:none;position:fixed;top:var(--header-h);left:0;right:0;
    background:var(--white);box-shadow:0 12px 32px rgba(0,40,115,.12);
    padding:12px 24px 24px;z-index:999;border-top:2px solid var(--orange);
}
.mobile-menu.open{display:block}
.mob-nav-links a{
    display:block;padding:13px 0;font-weight:500;font-size:15px;
    color:var(--text);border-bottom:1px solid var(--border);
}
.mob-nav-links a:hover{color:var(--navy)}
.mob-login{
    display:block;text-align:center;padding:13px;
    background:var(--navy);color:var(--white)!important;
    font-weight:700;font-size:15px;border-radius:var(--radius-sm);margin-top:16px;
}

@media(max-width:900px){
    .nav-links{display:none}
    .nav-inner{justify-content:flex-start;gap:6px}
    .nav-controls{margin-left:auto;gap:0}
    .nav-ctrl{padding:6px 7px;font-size:12px;gap:3px}
    .hamburger{display:flex;padding:5px;flex-shrink:0}
    .navbar .logo{flex-shrink:1;min-width:0}
    .navbar .logo-block{max-width:100%;align-items:center}
    .navbar .logo-tagline{
        display:block;white-space:normal;text-align:center;
        font-size:9px;max-width:min(200px,46vw);line-height:1.25;
    }
}
@media(max-width:768px){
    .user-dd{display:none}
    .hamburger{display:flex}
}
@media(max-width:500px){
    .nav-inner{gap:6px}
    .nav-ctrl{padding:5px 6px;font-size:11px;gap:2px}
}

/* ══════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════ */
.btn{
    display:inline-flex;align-items:center;justify-content:center;
    gap:.5rem;padding:.72rem 1.65rem;
    font-family:var(--font-body);font-size:.9rem;font-weight:600;
    line-height:1.2;border-radius:var(--radius-sm);
    border:1.5px solid transparent;cursor:pointer;
    transition:all var(--duration) var(--ease);
}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--c-gold-glow)}

.btn--primary{
    background:var(--orange);color:#fff;font-weight:700;border-color:transparent;
    box-shadow:0 4px 16px rgba(255,143,22,.30);
}
.btn--primary:hover{
    background:var(--orange-dark);
    box-shadow:0 8px 24px rgba(255,143,22,.38);transform:translateY(-1px);
}
.btn--secondary{background:var(--white);color:var(--text);border-color:var(--border)}
.btn--secondary:hover{border-color:var(--orange);color:var(--orange-dark)}

.btn--ghost{background:rgba(255,255,255,.08);color:var(--white);border-color:rgba(255,255,255,.22)}
.btn--ghost:hover{background:rgba(255,255,255,.16);border-color:var(--orange)}

.btn--outline{background:transparent;color:var(--orange);border-color:var(--orange)}
.btn--outline:hover{background:var(--orange);color:#fff}

.btn--dark{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn--dark:hover{background:var(--navy-mid)}

.btn--sm{padding:.42rem .9rem;font-size:.8rem}
.btn--lg{padding:.9rem 2.2rem;font-size:1rem}
.btn--block{width:100%}
.btn--icon-only{width:44px;height:44px;padding:0;border-radius:var(--radius-sm)}

/* ══════════════════════════════════════════
   TYPOGRAPHY
   ══════════════════════════════════════════ */
.h1,.h2,.h3,.h4{font-family:var(--font-display);font-weight:800;letter-spacing:-.01em;line-height:1.18}
.h1{font-size:clamp(2.2rem,5vw,3.5rem)}
.h2{font-size:clamp(1.5rem,3vw,2.25rem)}
.h3{font-size:clamp(1.1rem,2vw,1.4rem)}
.h4{font-size:1.1rem;font-family:var(--font-body);font-weight:700}

.lead{font-size:1.05rem;line-height:1.75;color:var(--text-mid);max-width:40rem}

.sec-title{
    font-family:var(--font-display);text-align:left;
    font-size:clamp(22px,3vw,38px);font-weight:800;
    color:var(--navy);line-height:1.18;margin-bottom:10px;
}
.sec-sub{
    text-align:left;font-size:15px;color:var(--text-mid);
    max-width:560px;margin:0 0 40px;line-height:1.1;
}

.eyebrow{
    display:inline-flex;align-items:center;gap:.5rem;
    font-size:.68rem;font-weight:700;letter-spacing:.18em;
    text-transform:uppercase;color:var(--orange);margin-bottom:.85rem;
}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--orange);border-radius:1px}

.text-muted{color:var(--text-mid)}
.text-center{text-align:center}
.text-white{color:var(--white)}

/* ══════════════════════════════════════════
   SECTIONS
   ══════════════════════════════════════════ */
.section{padding:56px 0}
.section--sm{padding:clamp(3rem,6vw,4.5rem) 0}
.section--dark{background:var(--navy);color:rgba(255,255,255,.93)}
.section--light{background:var(--bg)}
.section--gray{background:var(--c-gray-50)}

.section__header{text-align:center;max-width:640px;margin:0 auto clamp(3rem,5vw,4rem)}
.section__header .eyebrow{justify-content:center}
.section__header .lead{margin-inline:auto}

/* ══════════════════════════════════════════
   GRID
   ══════════════════════════════════════════ */
.grid{display:grid;gap:clamp(1.5rem,3vw,2rem)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:991px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:575px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

/* ══════════════════════════════════════════
   CARDS
   ══════════════════════════════════════════ */
.card{
    background:var(--white);border:1px solid var(--border);
    border-radius:var(--radius);overflow:hidden;
    transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.card__body{padding:1.5rem 1.6rem}
.card__img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}

/* Feature Card */
.feature-card{
    background:var(--white);border:1px solid var(--border);
    border-radius:var(--radius);padding:2.25rem 1.85rem;
    position:relative;overflow:hidden;transition:all var(--duration) var(--ease);
}
.feature-card::after{
    content:"";position:absolute;top:0;left:0;right:0;
    height:3px;background:linear-gradient(90deg,var(--orange),transparent);
    opacity:0;transition:opacity var(--duration) var(--ease);
}
.feature-card:hover{border-color:rgba(255,143,22,.20);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.feature-card:hover::after{opacity:1}
.feature-card__icon{
    width:56px;height:56px;border-radius:14px;
    background:var(--c-gold-light);color:var(--orange);
    display:flex;align-items:center;justify-content:center;margin-bottom:1.35rem;
}
.feature-card__title{font-size:1.05rem;font-weight:700;margin-bottom:.4rem}
.feature-card__text{font-size:.9rem;color:var(--text-mid);line-height:1.65}

/* Vehicle Card */
.vehicle-card{
    background:var(--white);border:1px solid var(--border);
    border-radius:var(--radius);overflow:hidden;position:relative;
    transition:all var(--duration) var(--ease);
}
.vehicle-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.vehicle-card__img-wrap{overflow:hidden}
.vehicle-card__img{
    width:100%;aspect-ratio:16/9;object-fit:cover;display:block;
    transition:transform .45s ease;
}
.vehicle-card:hover .vehicle-card__img{transform:scale(1.04)}
.vehicle-card__badge{
    position:absolute;top:.85rem;right:.85rem;z-index:2;
    background:var(--orange);color:#fff;
    font-size:.65rem;font-weight:700;padding:.28rem .65rem;
    border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;
}
.vehicle-card__body{padding:1.4rem 1.5rem}
.vehicle-card__name{font-size:1.1rem;font-weight:700;margin-bottom:.25rem}
.vehicle-card__desc{font-size:.88rem;color:var(--text-mid);line-height:1.55;margin-bottom:.85rem}
.vehicle-card__meta{display:flex;gap:1rem;font-size:.78rem;color:var(--text-light);font-weight:500}
.vehicle-card__meta span{display:flex;align-items:center;gap:.3rem}

/* Step Card */
.step-card{text-align:center;padding:2rem 1.5rem}
.step-card__no{
    display:inline-flex;align-items:center;justify-content:center;
    width:52px;height:52px;border-radius:var(--radius-full);
    background:var(--navy);color:var(--orange);
    font-weight:800;font-size:1.15rem;margin-bottom:1.35rem;
    box-shadow:0 6px 20px rgba(0,40,115,.22);
}
.step-card__title{font-size:1.05rem;font-weight:700;margin-bottom:.45rem}
.step-card__text{font-size:.9rem;color:var(--text-mid);line-height:1.65}

/* Testimonial Card */
.testimonial-card{
    background:rgba(0,40,115,.08);border:1px solid rgba(0,40,115,.10);
    border-radius:var(--radius);padding:2rem;
    transition:all var(--duration) var(--ease);
}
.testimonial-card:hover{border-color:var(--c-gold-glow);transform:translateY(-3px)}
.testimonial-card__stars{color:var(--orange);font-size:.92rem;letter-spacing:.1em;margin-bottom:1rem}
.testimonial-card__text{
    font-size:.93rem;color:var(--text);line-height:1.75;margin-bottom:1.35rem;font-style:italic;
}
.testimonial-card__author{display:flex;align-items:center;gap:.8rem}
.testimonial-card__avatar{
    width:42px;height:42px;border-radius:var(--radius-full);flex-shrink:0;
    background:var(--navy);color:var(--white);
    font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;
}
.testimonial-card__name{font-weight:600;font-size:.88rem;color:var(--dark)}
.testimonial-card__route{font-size:.78rem;color:var(--text-mid)}

/* Destination Card */
.dest-card{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.dest-card__img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .45s ease}
.dest-card:hover .dest-card__img{transform:scale(1.06)}
.dest-card__overlay{
    position:absolute;inset:0;
    background:linear-gradient(180deg,transparent 30%,rgba(0,40,115,.82) 100%);
    display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;
}
.dest-card__name{font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:.15rem}
.dest-card__country{font-size:.82rem;color:rgba(255,255,255,.65)}

/* ══════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════ */
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:.4rem}
.form-input,
.form-textarea,
select.form-input{
    width:100%;padding:.68rem .95rem;
    font-family:var(--font-body);font-size:.92rem;color:var(--text);
    background:var(--white);border:1.5px solid var(--border);
    border-radius:var(--radius-sm);
    transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}
.form-input:focus,.form-textarea:focus,select.form-input:focus{
    outline:none;border-color:var(--navy);
    box-shadow:0 0 0 3px rgba(0,40,115,.10);
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-light)}
.form-row{display:grid;gap:1rem}
@media(min-width:576px){.form-row--2{grid-template-columns:repeat(2,1fr)}}

/* Validation */
.form-input.input-validation-error,
.form-textarea.input-validation-error,
select.form-input.input-validation-error{
    border-color:var(--c-danger)!important;
    background-color:rgba(231,76,60,.06);
    box-shadow:0 0 0 3px rgba(231,76,60,.12)!important;
}
.form-input.input-validation-error:focus,
.form-textarea.input-validation-error:focus,
select.form-input.input-validation-error:focus{
    border-color:var(--c-danger)!important;
    box-shadow:0 0 0 3px rgba(231,76,60,.2)!important;
}
.form-input.input-validation-error::placeholder,
.form-textarea.input-validation-error::placeholder{color:rgba(231,76,60,.55)}
span.field-validation-error{display:block;font-size:.8125rem;font-weight:500;color:var(--c-danger);line-height:1.35;margin-top:.28rem}
span.field-validation-valid{display:none}

/* Validation Banner */
.site-form-validation-banner{
    display:flex;gap:.85rem;align-items:flex-start;
    padding:.95rem 1.1rem;margin-bottom:1.25rem;
    border-radius:var(--radius-sm);border:1px solid transparent;text-align:start;
}
.site-form-validation-banner[hidden]{display:none!important}
.site-form-validation-banner:not([hidden]){display:flex}
.site-form-alert--warning{background:rgba(255,143,22,.12);border-color:rgba(255,143,22,.35);color:var(--text)}
.site-form-alert--danger{background:rgba(231,76,60,.08);border-color:rgba(231,76,60,.28);color:var(--text)}
.site-form-alert__icon{flex-shrink:0;width:22px;height:22px;margin-top:.1rem;color:var(--orange)}
.site-form-alert--danger .site-form-alert__icon{color:var(--c-danger)}
.site-form-alert__title{display:block;font-size:.9rem;font-weight:700;margin:0 0 .2rem;line-height:1.35}
.site-form-alert__text{margin:0;font-size:.84rem;font-weight:500;color:var(--text-mid);line-height:1.45}
.partner-form-messages-data{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ══════════════════════════════════════════
   STATS
   ══════════════════════════════════════════ */
.stats{display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:center}
.stat{text-align:center;min-width:130px}
.stat__value{
    font-family:var(--font-display);font-size:2.5rem;font-weight:900;
    color:var(--orange);line-height:1;margin-bottom:.3rem;font-variant-numeric:tabular-nums;
}
.stat__label{font-size:.85rem;color:rgba(255,255,255,.65);font-weight:500}

/* ══════════════════════════════════════════
   CTA BANNER
   ══════════════════════════════════════════ */
.cta-banner{
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);
    border-radius:var(--radius-lg);padding:clamp(3rem,6vw,4.5rem);
    text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before{
    content:"";position:absolute;top:-40%;right:-15%;
    width:500px;height:500px;border-radius:50%;
    background:radial-gradient(circle,var(--c-gold-glow) 0%,transparent 70%);pointer-events:none;
}
.cta-banner__title{
    font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.1rem);
    font-weight:800;color:var(--white);margin-bottom:.75rem;position:relative;
}
.cta-banner__text{
    font-size:1rem;color:rgba(255,255,255,.60);
    margin-bottom:1.75rem;position:relative;max-width:480px;margin-inline:auto;
}
.cta-banner__actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;position:relative}

/* ══════════════════════════════════════════
   PAGE HERO (inner pages)
   ══════════════════════════════════════════ */
.page-hero{
    background:var(--navy);
    padding:calc(var(--header-h) + clamp(1.5rem,3vw,2.5rem)) 0 clamp(1.5rem,3vw,2.5rem);
    position:relative;overflow:hidden;
}
.page-hero::before{
    content:"";position:absolute;top:0;right:-10%;
    width:600px;height:600px;border-radius:50%;
    background:radial-gradient(circle,rgba(255,143,22,.06) 0%,transparent 70%);pointer-events:none;
}
.page-hero::after{
    content:"";position:absolute;bottom:0;left:0;right:0;
    height:1px;background:linear-gradient(90deg,transparent,var(--c-gold-glow),transparent);
}
.page-hero .h1{color:var(--white);margin-bottom:.5rem;font-size:clamp(1.5rem,3vw,2.15rem)}
.page-hero .lead{color:rgba(255,255,255,.60);font-size:.95rem}
.page-hero .eyebrow{margin-bottom:.5rem}

/* ══════════════════════════════════════════
   CONTACT SUBMITTED
   ══════════════════════════════════════════ */
.contact-submitted{text-align:center;max-width:560px;margin:0 auto;padding:1rem 0 2rem}
.contact-submitted__icon{
    width:80px;height:80px;border-radius:50%;
    background:var(--c-gold-light);color:#2ecc71;
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 1.5rem;
}
.contact-submitted__title{
    font-family:var(--font-display);font-weight:800;
    font-size:clamp(1.5rem,3vw,2rem);color:var(--navy);
    margin-bottom:1rem;
}
.contact-submitted__text{
    font-size:1.05rem;line-height:1.8;color:var(--text-mid);margin-bottom:2rem;
}
.contact-submitted__actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════
   ABOUT SECTION
   ══════════════════════════════════════════ */
.about-section{padding:clamp(3.5rem,7vw,5.5rem) 0}
.about-block{text-align:center;max-width:780px;margin:0 auto clamp(3rem,5vw,4rem)}
.about-block__eyebrow{
    display:block;font-size:.72rem;font-weight:700;letter-spacing:.22em;
    text-transform:uppercase;color:var(--orange);margin-bottom:.75rem;
}
.about-block__title{
    font-family:var(--font-display);font-weight:800;letter-spacing:-.01em;
    font-size:clamp(1.75rem,4vw,2.75rem);line-height:1.18;
    color:var(--navy);margin-bottom:1.5rem;
}
.about-block__text{
    font-size:1.05rem;line-height:1.85;color:var(--text-mid);max-width:700px;margin:0 auto;
}
.about-feature{text-align:center;padding:2rem 1.5rem}
.about-feature__icon{
    width:72px;height:72px;border-radius:50%;
    background:var(--c-gold-light);color:var(--orange);
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 1.25rem;
    transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}
.about-feature:hover .about-feature__icon{
    transform:translateY(-4px);box-shadow:0 8px 24px rgba(255,143,22,.18);
}
.about-feature__title{
    font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:.5rem;
}
.about-feature__text{
    font-size:.9rem;color:var(--text-mid);line-height:1.7;max-width:320px;margin:0 auto;
}

/* ══════════════════════════════════════════
   FAQ ACCORDION
   ══════════════════════════════════════════ */
.faq{max-width:760px}
.faq details{
    border:1px solid var(--border);border-radius:var(--radius-sm);
    background:var(--white);margin-bottom:.75rem;overflow:hidden;
    transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}
.faq details[open]{border-color:rgba(255,143,22,.22);box-shadow:var(--shadow-sm)}
.faq summary{
    padding:1.15rem 1.35rem;font-weight:600;font-size:.95rem;
    cursor:pointer;list-style:none;display:flex;
    justify-content:space-between;align-items:center;gap:1rem;
    transition:color var(--duration) var(--ease);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
    content:"+";font-weight:300;font-size:1.5rem;
    color:var(--orange);line-height:1;transition:transform .2s ease;
}
.faq details[open] summary{color:var(--orange-dark)}
.faq details[open] summary::after{content:"\2212"}
.faq__answer{
    padding:0 1.35rem 1.2rem;margin:0;
    font-size:.92rem;color:var(--text-mid);line-height:1.75;
    border-top:1px solid var(--border);
}

/* ══════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════ */
footer.site-footer{background:#001a50;padding:56px 0 0}

.footer-top{
    display:grid;grid-template-columns:2.2fr 1fr 1fr 1.1fr;
    gap:52px;padding-bottom:48px;
}
.foot-brand .logo-block{display:flex;flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:4px}
.foot-brand .logo-tagline{
    font-family:var(--font-body);font-size:11px;font-weight:400;font-style:italic;
    color:rgba(255,255,255,.55);letter-spacing:.02em;max-width:260px;line-height:1.3;
}
.foot-brand .logo-main{color:var(--white)}
.foot-brand .logo-main span{color:var(--orange)}
.foot-brand p{font-size:14px;color:rgba(255,255,255,.48);line-height:1.7;max-width:280px;margin-top:14px}

.foot-social{display:flex;gap:10px;margin-top:20px}
.soc-btn{
    width:38px;height:38px;border-radius:9px;
    background:rgba(255,255,255,.08);
    display:flex;align-items:center;justify-content:center;
    color:rgba(255,255,255,.6);font-size:14px;transition:all .25s;
}
.soc-btn:hover{background:var(--orange);color:var(--white)}

.foot-col h4{
    font-size:12px;font-weight:700;color:rgba(255,255,255,.9);
    text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;font-family:var(--font-body);
}
.foot-col ul{display:flex;flex-direction:column;gap:10px}
.foot-col ul li a{font-size:14px;color:rgba(255,255,255,.48);transition:color .25s}
.foot-col ul li a:hover{color:var(--orange)}

.foot-contact{display:flex;flex-direction:column;gap:12px}
.foot-contact-item{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.55)}
.foot-contact-item i{color:var(--orange);width:16px;text-align:center}

.foot-bottom{
    border-top:1px solid rgba(255,255,255,.07);
    padding:20px 0;display:flex;align-items:center;
    justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.foot-bottom p{font-size:13px;color:rgba(255,255,255,.32)}
.foot-bottom-links{display:flex;gap:22px}
.foot-bottom-links a{font-size:13px;color:rgba(255,255,255,.32);transition:color .25s}
.foot-bottom-links a:hover{color:rgba(255,255,255,.75)}

/* Footer accordion icon (hidden on desktop) */
.acc-icon{display:none}

@media(max-width:1100px){
    .footer-top{grid-template-columns:1fr 1fr;gap:36px}
    .foot-brand{grid-column:span 2}
}
@media(max-width:768px){
    .footer-top{grid-template-columns:1fr 1fr;gap:28px;padding-bottom:0}
    footer.site-footer{padding-top:0}
    .foot-brand{grid-column:span 2;background:#002060;margin:0 -24px;padding:28px 24px}
    .soc-btn{width:46px;height:46px;font-size:17px}
    .foot-col h4{font-size:15px;font-weight:700;letter-spacing:.02em;text-transform:none}
    .acc-icon{
        display:block;width:18px;height:18px;flex-shrink:0;
        transition:transform .3s ease;opacity:.6;
    }
    .foot-col--acc h4{
        display:flex;align-items:center;justify-content:space-between;
        cursor:pointer;font-size:22px;padding:8px 0;margin-bottom:0;
        border-top:1px solid rgba(255,255,255,.10);user-select:none;
    }
    .foot-col--acc.open h4 .acc-icon{transform:rotate(180deg)}
    .foot-col--acc .acc-body{display:none;padding-bottom:12px}
    .foot-col--acc.open .acc-body{display:block}
    .foot-col--acc ul li,
    .foot-col--acc .foot-contact-item{padding:5px 0;border-bottom:1px solid rgba(255,255,255,.06)}
    .foot-col--acc ul li:last-child,
    .foot-col--acc .foot-contact-item:last-child{border-bottom:none}
    .foot-col{grid-column:span 1}
    .foot-bottom{flex-direction:column;text-align:center}
}
@media(max-width:480px){
    .footer-top{grid-template-columns:1fr}
    .foot-brand{grid-column:span 1}
}

/* ══════════════════════════════════════════
   UTILITIES
   ══════════════════════════════════════════ */
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

.flex{display:flex}.flex-col{flex-direction:column}
.items-center{align-items:center}.justify-center{justify-content:center}
.gap-sm{gap:.5rem}.gap{gap:1rem}.gap-lg{gap:1.5rem}.gap-xl{gap:2rem}
.flex-wrap{flex-wrap:wrap}

.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-5{margin-top:3rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}

.split{display:grid;gap:3rem;align-items:center}
@media(min-width:992px){.split{grid-template-columns:1fr 1fr}}

.rounded{border-radius:var(--radius)}
.rounded-lg{border-radius:var(--radius-lg)}

@media(max-width:991px){.hide-mobile{display:none!important}}
@media(min-width:992px){.hide-desktop{display:none!important}}

/* Checklist */
.checklist{display:flex;flex-direction:column;gap:.7rem;font-size:.92rem;color:var(--text-mid)}
.checklist li{position:relative;padding-left:1.5rem}
.checklist li::before{
    content:"";position:absolute;left:0;top:.5rem;
    width:8px;height:8px;border-radius:50%;
    background:var(--orange);box-shadow:0 0 0 3px var(--c-gold-light);
}

/* ══════════════════════════════════════════
   SCROLL ANIMATIONS
   ══════════════════════════════════════════ */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .65s ease,transform .65s ease}
.fade-up.is-visible{opacity:1;transform:translateY(0)}
.fade-up-delay-1{transition-delay:.1s}
.fade-up-delay-2{transition-delay:.2s}
.fade-up-delay-3{transition-delay:.3s}

/* reveal system (new) */
.reveal{opacity:1;transform:none;transition:opacity .65s ease,transform .65s ease}
.reveal.pre{opacity:0;transform:translateY(24px)}
.reveal.visible{opacity:1;transform:none}
