/* =========================================================
   LEVANTE CONSULTING LIMITED
   Design System & Global Styles
   Brand: Navy #0E2558  |  Gold #C99F50
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Brand */
  --navy-900:#081231;
  --navy-800:#0b1c46;
  --navy:#0e2558;
  --navy-600:#163a7a;
  --navy-500:#1f4b9c;
  --gold:#c99f50;
  --gold-300:#e0b968;
  --gold-600:#a87f3a;
  --gold-soft:#f4ead4;

  /* Neutrals */
  --ink:#1a2235;
  --slate:#46506a;
  --muted:#6b7488;
  --line:#e7e9f0;
  --line-2:#eef0f6;
  --paper:#ffffff;
  --cream:#f8f7f3;
  --mist:#f3f5f9;

  /* Effects */
  --shadow-sm:0 2px 8px rgba(14,37,88,.06);
  --shadow:0 14px 40px -16px rgba(14,37,88,.22);
  --shadow-lg:0 40px 80px -28px rgba(14,37,88,.34);
  --ring:0 0 0 4px rgba(201,159,80,.28);

  /* Layout */
  --container:1200px;
  --radius:14px;
  --radius-lg:24px;
  --radius-xl:30px;
  --gut:clamp(20px,5vw,40px);

  /* Type */
  --font-head:"Sora","Plus Jakarta Sans",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --t-fast:.2s;
  --t:.45s;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}

/* ---------- Headings ---------- */
h1,h2,h3,h4{font-family:var(--font-head);color:var(--navy);line-height:1.1;margin:0;font-weight:700;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,5.4vw,4.2rem);font-weight:800}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
p{margin:0 0 1rem}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--slate);line-height:1.7}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gut)}
.section{padding:clamp(64px,9vw,128px) 0}
.section--tight{padding:clamp(48px,6vw,84px) 0}
.center{text-align:center}
.mw-720{max-width:720px}
.mw-640{max-width:640px}
.mx-auto{margin-inline:auto}
.grid{display:grid;gap:clamp(20px,2.4vw,32px)}
@media(min-width:680px){.cols-2{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}}
@media(min-width:680px) and (max-width:899px){.cols-4{grid-template-columns:repeat(2,1fr)}}

/* ---------- Eyebrow / kicker ---------- */
.kicker{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-head);font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold-600);
  margin-bottom:1rem;
}
.kicker::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-300));border-radius:2px}
.kicker--center::after{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--gold-300),var(--gold));border-radius:2px}
.kicker--center{justify-content:center}
.kicker--light{color:var(--gold-300)}

.section-head{margin-bottom:clamp(36px,5vw,60px)}
.section-head .lead{margin-top:1rem}

/* ---------- Bars motif (echoes the logo) ---------- */
.bars{display:flex;flex-direction:column;gap:5px;width:42px}
.bars span{height:7px;border-radius:3px;background:var(--gold);display:block}
.bars span:nth-child(1){width:100%}
.bars span:nth-child(2){width:78%;margin-left:14%}
.bars span:nth-child(3){width:60%}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--gold);--fg:#241a06;
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-head);font-weight:600;font-size:1rem;
  padding:.95rem 1.7rem;border-radius:999px;border:1px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;
  position:relative;overflow:hidden;isolation:isolate;
  transition:transform var(--t-fast) var(--ease),box-shadow var(--t) var(--ease),background var(--t-fast);
  box-shadow:0 10px 24px -10px rgba(201,159,80,.7);
}
.btn svg{width:1.1em;height:1.1em;transition:transform var(--t) var(--ease)}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,var(--gold-300),var(--gold));opacity:0;transition:opacity var(--t)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 38px -12px rgba(201,159,80,.85)}
.btn:hover::after{opacity:1}
.btn:hover svg{transform:translateX(4px)}
.btn:active{transform:translateY(-1px)}
.btn--navy{--bg:var(--navy);--fg:#fff;box-shadow:0 12px 28px -12px rgba(14,37,88,.6)}
.btn--navy::after{background:linear-gradient(120deg,var(--navy-600),var(--navy-500))}
.btn--ghost{--bg:transparent;--fg:var(--navy);border-color:var(--line);box-shadow:none}
.btn--ghost::after{background:var(--mist)}
.btn--ghost:hover{box-shadow:var(--shadow-sm)}
.btn--outline-light{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.4);box-shadow:none}
.btn--outline-light::after{background:rgba(255,255,255,.12)}
.btn--lg{padding:1.1rem 2.1rem;font-size:1.08rem}
.btn--block{display:flex;width:100%}

.link-arrow{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-head);font-weight:600;color:var(--navy);position:relative}
.link-arrow svg{width:1.05em;transition:transform var(--t) var(--ease)}
.link-arrow::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:100%;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform var(--t) var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}
.link-arrow:hover::after{transform:scaleX(1)}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background var(--t),box-shadow var(--t),padding var(--t),border-color var(--t);
  padding:18px 0;border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  box-shadow:0 10px 30px -18px rgba(14,37,88,.3);
  padding:10px 0;border-bottom-color:var(--line-2);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0;z-index:2}
.brand img{height:40px;width:auto;transition:height var(--t)}
.scrolled .brand img{height:34px}
.brand .logo-light{display:none}
.brand .logo-dark{display:block}

.nav-links{display:flex;align-items:center;gap:.35rem}
.nav-links a{
  font-family:var(--font-head);font-weight:500;font-size:.97rem;color:var(--navy);
  padding:.55rem .95rem;border-radius:999px;position:relative;transition:color var(--t-fast),background var(--t-fast)
}
.nav-links a::after{content:"";position:absolute;left:50%;bottom:.32rem;width:0;height:2px;background:var(--gold);border-radius:2px;transform:translateX(-50%);transition:width var(--t) var(--ease)}
.nav-links a:hover{color:var(--navy-600)}
.nav-links a:hover::after,.nav-links a.active::after{width:18px}
.nav-links a.active{color:var(--navy)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-cta .btn{padding:.7rem 1.3rem;font-size:.95rem}

/* Header over dark hero (transparent state) */
.site-header.on-dark:not(.scrolled){--hue:#fff}
.site-header.on-dark:not(.scrolled) .nav-links a{color:rgba(255,255,255,.9)}
.site-header.on-dark:not(.scrolled) .nav-links a:hover{color:#fff}
.site-header.on-dark:not(.scrolled) .brand .logo-dark{display:none}
.site-header.on-dark:not(.scrolled) .brand .logo-light{display:block}
.site-header.on-dark:not(.scrolled) .burger span{background:#fff}

/* Burger */
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);background:rgba(255,255,255,.6);border-radius:12px;cursor:pointer;position:relative;z-index:1101}
.burger span{position:absolute;left:11px;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:transform var(--t) var(--ease),opacity var(--t-fast),top var(--t)}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:28px}
body.menu-open .burger span:nth-child(1){top:22px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:22px;transform:rotate(-45deg)}
body.menu-open .burger{background:#fff}

/* Mobile drawer */
.mobile-menu{
  position:fixed;inset:0 0 0 auto;width:min(360px,86vw);z-index:1100;
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy-800) 100%);
  transform:translateX(100%);transition:transform var(--t) var(--ease-out);
  padding:96px 32px 32px;display:flex;flex-direction:column;gap:.4rem;
  box-shadow:-30px 0 60px -30px rgba(0,0,0,.6);
}
body.menu-open .mobile-menu{transform:translateX(0)}
.mobile-menu a{font-family:var(--font-head);font-weight:600;font-size:1.22rem;color:#fff;padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateX(20px);transition:opacity .4s,transform .4s,color var(--t-fast)}
.mobile-menu a span{color:var(--gold-300);font-size:.85rem}
body.menu-open .mobile-menu a{opacity:1;transform:translateX(0)}
body.menu-open .mobile-menu a:nth-child(1){transition-delay:.08s}
body.menu-open .mobile-menu a:nth-child(2){transition-delay:.14s}
body.menu-open .mobile-menu a:nth-child(3){transition-delay:.2s}
body.menu-open .mobile-menu a:nth-child(4){transition-delay:.26s}
body.menu-open .mobile-menu a:nth-child(5){transition-delay:.32s}
.mobile-menu a:hover{color:var(--gold-300)}
.mobile-menu .btn{margin-top:1.4rem}
.mobile-menu .mm-social{display:flex;gap:.8rem;margin-top:auto;padding-top:1.5rem}
.mobile-menu .mm-social a{border:none;padding:0;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.1);justify-content:center;color:#fff}
.mobile-menu .mm-social a svg{width:18px}
.overlay{position:fixed;inset:0;background:rgba(8,18,49,.5);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t);z-index:1050}
body.menu-open .overlay{opacity:1;visibility:visible}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;overflow:hidden;color:#fff;background:var(--navy);padding:clamp(140px,18vh,210px) 0 clamp(80px,10vw,130px)}
.hero__bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(110% 90% at 12% 0%,#16306e 0%,transparent 55%),
  radial-gradient(120% 100% at 100% 10%,#1b3f86 0%,transparent 50%),
  linear-gradient(160deg,var(--navy-900) 0%,var(--navy) 45%,var(--navy-800) 100%)}
.hero__grid{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(120% 90% at 30% 10%,#000 0%,transparent 70%);mask-image:radial-gradient(120% 90% at 30% 10%,#000 0%,transparent 70%)}
.hero__glow{position:absolute;border-radius:50%;filter:blur(70px);z-index:0;opacity:.55;animation:float 16s var(--ease) infinite}
.hero__glow.g1{width:420px;height:420px;background:radial-gradient(circle,#2a59b8,transparent 65%);top:-120px;right:-80px}
.hero__glow.g2{width:360px;height:360px;background:radial-gradient(circle,rgba(201,159,80,.5),transparent 65%);bottom:-140px;left:-60px;animation-delay:-6s}
.hero .container{position:relative;z-index:2}
.hero__layout{display:grid;gap:clamp(40px,5vw,64px);align-items:center}
@media(min-width:980px){.hero__layout{grid-template-columns:1.06fr .94fr}}
.hero h1{color:#fff;margin-bottom:1.4rem}
.hero h1 .hl{color:var(--gold-300);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.14em;background:linear-gradient(90deg,var(--gold),transparent);border-radius:3px;transform:scaleX(0);transform-origin:left;animation:swipe 1s var(--ease) .8s forwards}
.hero .lead{color:rgba(255,255,255,.82);max-width:560px}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.hero__stats{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,4vw,3rem);margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.12)}
.hero__stats .num{font-family:var(--font-head);font-weight:800;font-size:clamp(1.7rem,3vw,2.3rem);color:#fff;line-height:1}
.hero__stats .lbl{font-size:.86rem;color:rgba(255,255,255,.62);margin-top:.4rem}
.hero__stats .gold{color:var(--gold-300)}

/* trust strip */
.trust{display:flex;align-items:center;gap:.8rem;margin-top:1.6rem;color:rgba(255,255,255,.66);font-size:.92rem}
.trust .dots{display:flex}
.trust .dots i{width:30px;height:30px;border-radius:50%;border:2px solid var(--navy);margin-left:-8px;background:linear-gradient(135deg,var(--gold-300),var(--gold-600));display:block}
.trust .dots i:first-child{margin-left:0}

/* Animated reveal for hero text */
.hero [data-stagger]{opacity:0;transform:translateY(26px);animation:rise .9s var(--ease-out) forwards}
.hero [data-stagger="1"]{animation-delay:.1s}
.hero [data-stagger="2"]{animation-delay:.25s}
.hero [data-stagger="3"]{animation-delay:.4s}
.hero [data-stagger="4"]{animation-delay:.55s}
.hero [data-stagger="5"]{animation-delay:.7s}

/* Hero visual card */
.hero-visual{position:relative}
.hero-card{
  background:linear-gradient(150deg,rgba(255,255,255,.13),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-xl);
  padding:26px;backdrop-filter:blur(8px);box-shadow:var(--shadow-lg);position:relative;overflow:hidden
}
.hero-card::before{content:"";position:absolute;top:-40%;right:-30%;width:60%;height:80%;background:radial-gradient(circle,rgba(201,159,80,.25),transparent 70%)}
.hero-card h3{color:#fff;font-size:1.1rem;margin-bottom:.2rem}
.hero-card .sub{color:rgba(255,255,255,.6);font-size:.85rem;margin-bottom:1.4rem}
.hero-card svg{width:100%;height:auto;display:block}
.float-chip{
  position:absolute;background:#fff;color:var(--navy);border-radius:14px;padding:.7rem 1rem;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:.6rem;font-family:var(--font-head);font-weight:600;font-size:.9rem;
  animation:float 6s var(--ease) infinite
}
.float-chip i{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--gold-soft);color:var(--gold-600)}
.float-chip i svg{width:18px}
.float-chip.fc1{top:-20px;left:-22px}
.float-chip.fc2{bottom:-18px;right:-14px;animation-delay:-3s}
.float-chip .pct{color:var(--gold-600)}

/* =========================================================
   GENERIC PAGE HERO (inner pages)
   ========================================================= */
.page-hero{position:relative;overflow:hidden;color:#fff;background:var(--navy);padding:clamp(140px,17vh,200px) 0 clamp(56px,7vw,90px)}
.page-hero__bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(100% 120% at 85% 0%,#1b3f86 0%,transparent 55%),
  linear-gradient(160deg,var(--navy-900),var(--navy) 60%)}
.page-hero__grid{position:absolute;inset:0;z-index:0;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:44px 44px;-webkit-mask-image:radial-gradient(100% 100% at 70% 0%,#000,transparent 75%);mask-image:radial-gradient(100% 100% at 70% 0%,#000,transparent 75%)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;max-width:14ch}
.page-hero .lead{color:rgba(255,255,255,.8);max-width:620px;margin-top:1rem}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:1.2rem}
.breadcrumb a:hover{color:var(--gold-300)}
.breadcrumb span{color:var(--gold-300)}

/* =========================================================
   CARDS
   ========================================================= */
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,34px);position:relative;overflow:hidden;height:100%;
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t)
}
.card::before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:linear-gradient(180deg,var(--gold),var(--gold-600));transform:scaleY(0);transform-origin:top;transition:transform var(--t) var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleY(1)}
.card__icon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;margin-bottom:1.3rem;background:linear-gradient(145deg,var(--navy),var(--navy-600));color:var(--gold-300);box-shadow:0 12px 26px -12px rgba(14,37,88,.5);transition:transform var(--t) var(--ease)}
.card:hover .card__icon{transform:rotate(-6deg) scale(1.06)}
.card__icon svg{width:28px;height:28px}
.card h3{margin-bottom:.6rem;font-size:1.28rem}
.card p{color:var(--slate);margin-bottom:1rem;font-size:.98rem}
.card .num-tag{position:absolute;top:24px;right:26px;font-family:var(--font-head);font-weight:800;font-size:2.4rem;color:var(--line);line-height:1;transition:color var(--t)}
.card:hover .num-tag{color:var(--gold-soft)}

/* Feature list */
.flist{display:flex;flex-direction:column;gap:.7rem;margin:0;padding:0}
.flist li{display:flex;gap:.7rem;align-items:flex-start;color:var(--slate)}
.flist li svg{flex-shrink:0;width:22px;height:22px;color:var(--gold-600);margin-top:.2rem}

/* =========================================================
   SECTIONS: backgrounds
   ========================================================= */
.bg-cream{background:var(--cream)}
.bg-mist{background:var(--mist)}
.bg-navy{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.bg-navy h2,.bg-navy h3{color:#fff}
.bg-navy .lead{color:rgba(255,255,255,.8)}
.bg-navy .kicker{color:var(--gold-300)}
.deco-bars{position:absolute;opacity:.07;z-index:0;pointer-events:none}

/* Split media + text */
.split{display:grid;gap:clamp(36px,5vw,64px);align-items:center}
@media(min-width:920px){.split{grid-template-columns:1fr 1fr}.split--wide-text{grid-template-columns:1.1fr .9fr}}
.split__media{position:relative}

/* Stat band */
.statband{display:grid;gap:1.6rem;text-align:center}
@media(min-width:600px){.statband{grid-template-columns:repeat(4,1fr)}}
.statband .num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.2rem,4vw,3.2rem);background:linear-gradient(120deg,var(--gold-300),var(--gold-600));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.bg-navy .statband .num{background:linear-gradient(120deg,#fff,var(--gold-300));-webkit-background-clip:text;background-clip:text;color:transparent}
.statband .lbl{color:var(--muted);margin-top:.5rem;font-size:.95rem}
.bg-navy .statband .lbl{color:rgba(255,255,255,.7)}
.statband .item{position:relative}
.statband .item:not(:last-child)::after{content:"";position:absolute;right:-.8rem;top:15%;height:70%;width:1px;background:var(--line)}
.bg-navy .statband .item:not(:last-child)::after{background:rgba(255,255,255,.14)}
@media(max-width:599px){.statband .item::after{display:none!important}}

/* Process steps */
.steps{display:grid;gap:1.4rem;counter-reset:step}
@media(min-width:760px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{position:relative;padding-top:2.2rem}
.step__n{font-family:var(--font-head);font-weight:800;font-size:1.05rem;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:#fff;color:var(--navy);border:2px solid var(--gold);box-shadow:var(--shadow-sm);position:relative;z-index:2}
.bg-navy .step__n{background:var(--navy-800);color:var(--gold-300);border-color:rgba(201,159,80,.5)}
.step h3{font-size:1.18rem;margin:1rem 0 .5rem}
.step p{color:var(--slate);font-size:.96rem}
.bg-navy .step p{color:rgba(255,255,255,.72)}
.steps .step::before{content:"";position:absolute;top:calc(2.2rem + 26px);left:52px;right:-1.4rem;height:2px;background:repeating-linear-gradient(90deg,var(--line) 0 8px,transparent 8px 16px)}
.bg-navy .steps .step::before{background:repeating-linear-gradient(90deg,rgba(255,255,255,.2) 0 8px,transparent 8px 16px)}
@media(max-width:759px){.steps .step::before{display:none}}
.steps .step:last-child::before{display:none}

/* Progress bars (why us) */
.bar-row{margin-bottom:1.5rem}
.bar-row .top{display:flex;justify-content:space-between;font-family:var(--font-head);font-weight:600;margin-bottom:.5rem}
.bar-row .top .v{color:var(--gold-600)}
.bg-navy .bar-row .top{color:#fff}.bg-navy .bar-row .top .v{color:var(--gold-300)}
.track{height:9px;border-radius:99px;background:var(--line);overflow:hidden}
.bg-navy .track{background:rgba(255,255,255,.14)}
.track .fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold-600),var(--gold-300));width:0;transition:width 1.4s var(--ease-out)}

/* Accordion */
.acc{border:1px solid var(--line);border-radius:var(--radius);background:#fff;margin-bottom:1rem;overflow:hidden;transition:box-shadow var(--t),border-color var(--t)}
.acc[open]{box-shadow:var(--shadow-sm);border-color:var(--gold-soft)}
.acc summary{list-style:none;cursor:pointer;padding:1.15rem 1.4rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:var(--font-head);font-weight:600;color:var(--navy);font-size:1.05rem}
.acc summary::-webkit-details-marker{display:none}
.acc summary .ic{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--mist);display:grid;place-items:center;transition:transform var(--t) var(--ease),background var(--t)}
.acc[open] summary .ic{transform:rotate(45deg);background:var(--gold);color:#fff}
.acc .body{padding:0 1.4rem 1.3rem;color:var(--slate)}

/* Quote / testimonial */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,4vw,42px);position:relative;height:100%}
.quote .mark{font-family:Georgia,serif;font-size:4rem;line-height:.6;color:var(--gold);height:30px;display:block}
.quote p{font-size:1.06rem;color:var(--ink);font-style:italic}
.quote .who{display:flex;align-items:center;gap:.9rem;margin-top:1.2rem}
.quote .who .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-600));color:var(--gold-300);display:grid;place-items:center;font-family:var(--font-head);font-weight:700}
.quote .who b{display:block;font-family:var(--font-head);color:var(--navy)}
.quote .who span{font-size:.85rem;color:var(--muted)}

/* Marquee */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee__track{display:flex;gap:3.4rem;width:max-content;animation:scrollx 32s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--slate);display:inline-flex;align-items:center;gap:3.4rem;white-space:nowrap}
.marquee__track span::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* CTA band */
.cta{position:relative;overflow:hidden;border-radius:clamp(20px,3vw,34px);padding:clamp(40px,6vw,72px);color:#fff;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-800) 60%,#0a1a44 100%);box-shadow:var(--shadow-lg)}
.cta::before{content:"";position:absolute;top:-50%;right:-10%;width:50%;height:200%;background:radial-gradient(circle,rgba(201,159,80,.28),transparent 60%)}
.cta__inner{position:relative;z-index:2;display:grid;gap:1.6rem;align-items:center}
@media(min-width:860px){.cta__inner{grid-template-columns:1.4fr auto}}
.cta h2{color:#fff}
.cta p{color:rgba(255,255,255,.82);margin:.7rem 0 0;max-width:50ch}

/* =========================================================
   FORMS
   ========================================================= */
.form{display:grid;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field.row2{display:grid;gap:1.1rem}
@media(min-width:560px){.field.row2{grid-template-columns:1fr 1fr}}
.field label{font-family:var(--font-head);font-weight:600;font-size:.9rem;color:var(--navy)}
.field label .req{color:var(--gold-600)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);
  padding:.92rem 1.05rem;border:1.5px solid var(--line);border-radius:12px;background:#fff;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);width:100%
}
.field textarea{resize:vertical;min-height:140px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,159,80,.16)}
.field input::placeholder,.field textarea::placeholder{color:#9aa2b4}
.form .hint{font-size:.85rem;color:var(--muted)}
.form-note{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--muted)}
.form-note svg{width:18px;flex-shrink:0;color:var(--gold-600);margin-top:.15rem}
.form-status{display:none;padding:.9rem 1.1rem;border-radius:12px;font-size:.95rem;align-items:center;gap:.6rem}
.form-status.show{display:flex}
.form-status.ok{background:#eaf7ee;color:#1f7a3d;border:1px solid #bfe6cb}
.form-status.err{background:#fdeeee;color:#b5392f;border:1px solid #f3c9c5}
.honeypot{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.btn.loading{pointer-events:none;opacity:.75}
.btn .spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn.loading .spinner{display:inline-block}
.btn.loading .label,.btn.loading svg.ar{display:none}

/* Contact info cards */
.info-card{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem;border-radius:var(--radius);border:1px solid var(--line);background:#fff;transition:transform var(--t) var(--ease),box-shadow var(--t)}
.info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.info-card .ic{flex-shrink:0;width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--gold-soft);color:var(--gold-600)}
.info-card .ic svg{width:22px}
.info-card b{font-family:var(--font-head);color:var(--navy);display:block;margin-bottom:.15rem}
.info-card a,.info-card span{color:var(--slate);font-size:.96rem}
.info-card a:hover{color:var(--gold-600)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--navy-900);color:rgba(255,255,255,.7);position:relative;overflow:hidden;padding-top:clamp(56px,7vw,90px)}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold-600),var(--gold-300),var(--gold-600))}
.footer-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(31,75,156,.32),transparent 65%);top:-220px;right:-120px;filter:blur(40px)}
.footer-grid{display:grid;gap:clamp(32px,4vw,48px);position:relative;z-index:2}
@media(min-width:780px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr}}
.footer-brand img{height:46px;margin-bottom:1.2rem}
.footer-brand p{color:rgba(255,255,255,.62);font-size:.96rem;max-width:34ch}
.footer h4{color:#fff;font-size:1rem;margin-bottom:1.1rem;font-family:var(--font-head)}
.footer-col a{display:block;color:rgba(255,255,255,.66);padding:.32rem 0;font-size:.96rem;transition:color var(--t-fast),padding-left var(--t-fast)}
.footer-col a:hover{color:var(--gold-300);padding-left:.3rem}
.footer-contact li{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.9rem;color:rgba(255,255,255,.68);font-size:.95rem}
.footer-contact li svg{width:20px;flex-shrink:0;color:var(--gold-300);margin-top:.15rem}
.footer-contact a:hover{color:var(--gold-300)}
.socials{display:flex;gap:.6rem;margin-top:1.4rem}
.socials a{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#fff;transition:transform var(--t) var(--ease),background var(--t),color var(--t)}
.socials a svg{width:18px}
.socials a:hover{transform:translateY(-4px);background:var(--gold);color:var(--navy-900)}
.footer-bottom{margin-top:clamp(36px,5vw,56px);border-top:1px solid rgba(255,255,255,.1);padding:1.6rem 0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:.88rem;position:relative;z-index:2}
.footer-bottom .legal{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer-bottom a:hover{color:var(--gold-300)}

/* newsletter mini */
.fnews{display:flex;gap:.5rem;margin-top:1rem;max-width:320px}
.fnews input{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:10px;padding:.7rem .9rem;font-family:inherit}
.fnews input::placeholder{color:rgba(255,255,255,.5)}
.fnews input:focus{outline:none;border-color:var(--gold-300)}
.fnews button{border:none;cursor:pointer;background:var(--gold);color:var(--navy-900);border-radius:10px;width:46px;display:grid;place-items:center;transition:background var(--t)}
.fnews button:hover{background:var(--gold-300)}
.fnews button svg{width:18px}

/* =========================================================
   Back to top + preloader
   ========================================================= */
.to-top{position:fixed;right:24px;bottom:24px;width:52px;height:52px;border-radius:50%;border:none;background:var(--navy);color:#fff;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(16px) scale(.9);transition:opacity var(--t),transform var(--t),visibility var(--t),background var(--t);z-index:900}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.to-top:hover{background:var(--gold);color:var(--navy-900)}
.to-top svg{width:22px}

.preloader{position:fixed;inset:0;z-index:3000;background:var(--navy);display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.preloader.done{opacity:0;visibility:hidden}
.preloader .pl-bars{display:flex;flex-direction:column;gap:7px;width:64px}
.preloader .pl-bars span{height:11px;border-radius:4px;background:var(--gold);transform-origin:left;animation:plbar 1.1s var(--ease) infinite}
.preloader .pl-bars span:nth-child(1){width:100%;animation-delay:0s}
.preloader .pl-bars span:nth-child(2){width:75%;margin-left:18%;animation-delay:.15s}
.preloader .pl-bars span:nth-child(3){width:55%;animation-delay:.3s}

/* =========================================================
   REVEAL ANIMATIONS (JS toggles .in)
   ========================================================= */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-reveal="left"]{transform:translateX(-40px)}
[data-reveal="right"]{transform:translateX(40px)}
[data-reveal="scale"]{transform:scale(.94)}
[data-reveal].in{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}
[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}
[data-delay="5"]{transition-delay:.5s}[data-delay="6"]{transition-delay:.6s}

/* =========================================================
   KEYFRAMES
   ========================================================= */
@keyframes rise{to{opacity:1;transform:none}}
@keyframes swipe{to{transform:scaleX(1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes scrollx{to{transform:translateX(-50%)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes plbar{0%,100%{transform:scaleX(.4);opacity:.5}50%{transform:scaleX(1);opacity:1}}
@keyframes dash{to{stroke-dashoffset:0}}
@keyframes growbar{from{transform:scaleY(0)}to{transform:scaleY(1)}}

/* animated SVG line draw util */
.draw{stroke-dasharray:1000;stroke-dashoffset:1000}
.in .draw{animation:dash 2.2s var(--ease-out) forwards}

/* =========================================================
   RESPONSIVE NAV
   ========================================================= */
@media(max-width:980px){
  .nav-links,.nav-cta .btn{display:none}
  .burger{display:block}
}

@media(max-width:560px){
  body{font-size:16px}
  .hero__stats{gap:1.3rem 1.8rem}
  .to-top{right:16px;bottom:16px;width:46px;height:46px}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1;transform:none}
}
