/* ============================================================
   NYLK — v2 site foundation (shared across all pages)
   Track B editorial: Fraunces + Hanken Grotesk · navy / gold / porcelain
   ============================================================ */
:root{
  --navy-900:#13132b; --navy-800:#1a1a3c; --navy-700:#262654; --navy-600:#3a3a6b; --navy-300:#a9a9c2;
  --gold-700:#a9854b; --gold-600:#bd9659; --gold-500:#c9a96e; --gold-400:#d8bd8c; --gold-200:#ece0c8;
  --porc-050:#faf8f4; --porc-100:#f6f2ec; --porc-200:#efe9e0; --porc-300:#e4dccf;
  --ink:#20203a; --ink-muted:#54607e; --ink-subtle:#7c7c9a; --rule:#e4dccf;
  --display:"Fraunces",Georgia,serif; --body:"Hanken Grotesk","Segoe UI",system-ui,sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; font-family:var(--body); color:var(--ink); background:var(--porc-100); font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; letter-spacing:-.02em; line-height:1.08; color:var(--navy-700); margin:0; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 32px; }
.eyebrow{ font-size:12.5px; letter-spacing:.22em; text-transform:uppercase; font-weight:600; color:var(--gold-700); margin:0; }
.eyebrow--on{ color:var(--gold-400); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:15.5px; border-radius:100px; padding:15px 30px; cursor:pointer; border:1px solid transparent; transition:background .2s,color .2s,border-color .2s,transform .06s; font-family:var(--body); }
.btn:active{ transform:translateY(1px); }
.btn--gold{ background:var(--gold-500); color:var(--navy-900); box-shadow:0 6px 20px -6px rgba(201,169,110,.5); position:relative; overflow:hidden; }
.btn--gold::after{ content:""; position:absolute; top:0; left:-60%; width:40%; height:100%; background:linear-gradient(100deg, transparent, rgba(255,255,255,.45), transparent); transform:skewX(-18deg); }
.btn--gold:hover::after{ animation:sheen .8s ease; }
@keyframes sheen{ to{ left:130%; } }
.btn--gold:hover{ background:var(--gold-400); transform:translateY(-2px); box-shadow:0 12px 28px -8px rgba(201,169,110,.6); }
.btn--navy{ background:var(--navy-700); color:#fff; }
.btn--navy:hover{ background:var(--navy-600); transform:translateY(-2px); }
.btn--ghost{ color:#fff; border-color:rgba(255,255,255,.28); }
.btn--ghost:hover{ border-color:var(--gold-400); color:var(--gold-400); transform:translateY(-2px); }
.btn--line{ color:var(--navy-700); border-color:rgba(38,38,84,.3); background:transparent; }
.btn--line:hover{ border-color:var(--gold-600); color:var(--gold-700); transform:translateY(-2px); }
.btn--sm{ padding:11px 22px; font-size:14px; }
.tlink{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:15px; color:var(--gold-700); transition:gap .25s var(--ease), color .2s; }
.tlink:hover{ gap:13px; color:var(--navy-700); }
.navy .tlink, .tlink--on{ color:var(--gold-400); }
.navy .tlink:hover{ color:#fff; }

/* ---------- reveal system (JS-gated) ---------- */
.fade{ opacity:1; animation:fadeUp .9s var(--ease); }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(20px);} to{ opacity:1; transform:none;} }
.rv{ opacity:1; transform:none; }
.js .rv{ opacity:0; transform:translateY(20px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.js .rv.in{ opacity:1; transform:none; }
.js .stagger > *{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js .stagger.in > *{ opacity:1; transform:none; }
.js .stagger.in > *:nth-child(2){ transition-delay:.09s; }
.js .stagger.in > *:nth-child(3){ transition-delay:.18s; }
.js .stagger.in > *:nth-child(4){ transition-delay:.27s; }
.js .stagger.in > *:nth-child(5){ transition-delay:.36s; }
.js .stagger.in > *:nth-child(6){ transition-delay:.45s; }
.hw{ display:inline-block; opacity:0; transform:translateY(24px); animation:wordUp .72s var(--ease) var(--d,0s) forwards; }
@keyframes wordUp{ to{ opacity:1; transform:none; } }
.grule{ width:54px; height:3px; background:var(--gold-500); margin:0 0 24px; transform-origin:left; }
.js .grule{ transform:scaleX(0); transition:transform .85s var(--ease) .15s; }
.js .rv.in .grule, .js .in .grule{ transform:scaleX(1); }
@media (prefers-reduced-motion:reduce){
  .fade{ animation:none; } .js .rv{ opacity:1; transform:none; transition:none; }
  .js .stagger > *{ opacity:1; transform:none; transition:none; }
  .hw{ opacity:1; transform:none; animation:none; }
  .js .grule{ transform:none; transition:none; }
  html{ scroll-behavior:auto; }
  .btn--gold:hover::after{ animation:none; }
}

/* ---------- waves ---------- */
.wave{ display:block; width:100%; height:90px; }
.wave svg{ display:block; width:100%; height:100%; }
.wave--flow svg{ width:200%; animation:waveflow 22s linear infinite; }
@keyframes waveflow{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .wave--flow svg{ animation:none; width:100%; } }
.wave--foot{ position:absolute; left:0; right:0; bottom:-1px; }

/* ---------- progress + scroll droplet ---------- */
.scrollbar{ position:fixed; top:0; left:0; height:3px; width:0; z-index:60; background:linear-gradient(90deg, var(--gold-600), var(--gold-400)); box-shadow:0 0 10px rgba(201,169,110,.6); transition:width .1s linear; }
.scrolldrop{ position:fixed; right:16px; top:96px; bottom:96px; width:2px; background:rgba(201,169,110,.16); border-radius:2px; z-index:25; pointer-events:none; }
.scrolldrop__d{ position:absolute; left:50%; top:0; transform:translate(-50%,-50%); width:13px; height:17px; }
.scrolldrop__d svg{ width:100%; height:100%; filter:drop-shadow(0 0 6px rgba(201,169,110,.8)); }
@media (max-width:920px){ .scrolldrop{ display:none; } }

/* ---------- nav ---------- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:50; transition:background .35s ease, box-shadow .35s ease; }
.nav--solid{ background:rgba(19,19,43,.88); backdrop-filter:saturate(150%) blur(12px); box-shadow:0 1px 0 rgba(201,169,110,.18), 0 8px 30px -16px rgba(0,0,0,.6); }
.nav__in{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding:22px 32px; max-width:var(--maxw); margin:0 auto; transition:padding .35s ease; }
.nav--solid .nav__in{ padding:14px 32px; }
.brand{ display:flex; align-items:center; gap:14px; flex:none; }
.brand img{ height:52px; width:auto; transition:height .35s ease; }
.nav--solid .brand img{ height:44px; }
.nav__links{ display:flex; align-items:center; gap:26px; }
.nav__links a{ color:rgba(255,255,255,.82); font-size:14.5px; font-weight:500; transition:color .2s; position:relative; }
.nav__links a:hover{ color:#fff; }
.nav__links a[aria-current="page"]{ color:#fff; }
.nav__links a[aria-current="page"]::after{ content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px; background:var(--gold-500); border-radius:2px; }
.nav__login{ color:var(--gold-400) !important; }
.nav__cta{ font-size:14px; font-weight:600; color:var(--navy-900) !important; background:var(--gold-500); padding:11px 22px; border-radius:100px; transition:background .2s; }
.nav__cta:hover{ background:var(--gold-400); }
.nav__burger{ display:none; width:44px; height:44px; border:none; background:transparent; cursor:pointer; flex-direction:column; justify-content:center; align-items:center; gap:5px; z-index:70; }
.nav__burger span{ display:block; width:22px; height:2px; background:#fff; border-radius:2px; transition:transform .35s var(--ease), opacity .25s; }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media (max-width:1020px){ .nav__links{ display:none; } .nav__burger{ display:flex; } }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:65; background:linear-gradient(180deg, var(--navy-900), var(--navy-800)); display:flex; flex-direction:column; justify-content:center; padding:90px 40px 48px; opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s; }
.drawer.open{ opacity:1; visibility:visible; }
.drawer a{ display:block; font-family:var(--display); font-size:clamp(28px,6vw,40px); font-weight:500; color:#fff; padding:10px 0; letter-spacing:-.01em; opacity:0; transform:translateY(16px); transition:opacity .5s var(--ease), transform .5s var(--ease), color .2s; }
.drawer.open a{ opacity:1; transform:none; }
.drawer a:hover{ color:var(--gold-400); }
.drawer a[aria-current="page"]{ color:var(--gold-400); }
.drawer.open a:nth-child(2){ transition-delay:.05s } .drawer.open a:nth-child(3){ transition-delay:.1s }
.drawer.open a:nth-child(4){ transition-delay:.15s } .drawer.open a:nth-child(5){ transition-delay:.2s }
.drawer.open a:nth-child(6){ transition-delay:.25s } .drawer.open a:nth-child(7){ transition-delay:.3s }
.drawer.open a:nth-child(8){ transition-delay:.35s }
.drawer__foot{ margin-top:34px; display:flex; flex-direction:column; gap:14px; opacity:0; transition:opacity .5s var(--ease) .4s; }
.drawer.open .drawer__foot{ opacity:1; }
.drawer__foot .btn{ justify-content:center; }
.drawer__foot .call{ text-align:center; color:var(--navy-300); font-size:14px; }
.drawer__foot .call a{ display:inline; font-family:var(--body); font-size:14px; color:var(--gold-400); padding:0; opacity:1; transform:none; }
body.drawer-lock{ overflow:hidden; }

/* ---------- page hero (subpages) ---------- */
.phero{ position:relative; background:
    radial-gradient(900px 500px at 82% -12%, #23234e 0%, rgba(35,35,78,0) 58%),
    linear-gradient(180deg, var(--navy-900), var(--navy-800)); color:#fff; overflow:hidden; }
.phero__drop{ position:absolute; right:-190px; top:46%; transform:translateY(-50%); width:640px; max-width:none; opacity:.05; filter:brightness(0) invert(1); pointer-events:none; }
.phero__in{ position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:168px 32px 120px; }
.phero--tight .phero__in{ padding-bottom:96px; }
.phero .eyebrow{ color:var(--gold-400); }
.phero h1{ color:#fff; font-size:clamp(38px,5.2vw,64px); max-width:18ch; margin:22px 0 0; }
.phero h1 em{ font-style:italic; font-weight:500; color:var(--gold-400); }
.phero__lead{ font-size:clamp(17px,2vw,20px); line-height:1.65; color:var(--navy-300); margin:24px 0 0; max-width:56ch; }
.phero__actions{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; margin:36px 0 0; }
.phero .wave{ position:absolute; left:0; right:0; bottom:-1px; z-index:3; }

/* ---------- sections ---------- */
section{ position:relative; }
.sec{ padding:96px 0; }
.sec--wave{ padding-bottom:118px; }
.sec__head{ text-align:center; max-width:62ch; margin:0 auto 56px; }
.sec__head h2{ font-size:clamp(30px,4vw,46px); margin:14px 0 0; }
.sec__head p{ color:var(--ink-muted); font-size:18px; margin:18px auto 0; max-width:54ch; }
.porc{ background:var(--porc-100); } .porc2{ background:var(--porc-050); }
.navy{ background:var(--navy-800); color:#fff; }
.navy h2,.navy h3{ color:#fff; }
.navy .sec__head p{ color:var(--navy-300); }
.lead2{ display:grid; grid-template-columns:1.05fr 1fr; gap:60px; align-items:center; }
.lead2 h2{ font-size:clamp(28px,3.6vw,42px); max-width:17ch; }
.lead2 > div > p, .lead2 .p{ font-size:17px; color:var(--ink-muted); line-height:1.7; margin:18px 0 0; max-width:54ch; }
.navy .lead2 > div > p, .navy .lead2 .p{ color:var(--navy-300); }
@media (max-width:920px){ .lead2{ grid-template-columns:1fr; gap:40px; } }

/* ---------- cards: tiles / cats / reasons ---------- */
.tiles{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.tiles--4{ grid-template-columns:repeat(4,1fr); gap:22px; }
.tile{ background:#fff; border:1px solid var(--rule); border-radius:16px; padding:28px 24px; transition:transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.tile:hover{ transform:translateY(-6px); box-shadow:0 24px 48px -22px rgba(20,20,46,.28); border-color:var(--gold-200); }
.tile__ic{ width:40px; height:40px; color:var(--gold-600); margin-bottom:16px; }
.tile h3{ font-size:20px; margin:0 0 10px; }
.tile p{ font-size:14px; line-height:1.55; color:var(--ink-muted); margin:0; }
.cats{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.cat{ background:#fff; border:1px solid var(--rule); border-radius:14px; padding:22px; transition:transform .3s var(--ease), border-color .3s; }
.cat:hover{ transform:translateY(-4px); border-color:var(--gold-200); }
.cat .k{ font-family:var(--display); font-weight:600; font-size:18px; color:var(--navy-700); }
.cat p{ font-size:13.5px; color:var(--ink-muted); margin:8px 0 0; line-height:1.5; }
.reasons{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.reason{ background:#fff; border:1px solid var(--rule); border-radius:18px; padding:34px 32px; transition:transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.reason:hover{ transform:translateY(-6px); box-shadow:0 24px 48px -22px rgba(20,20,46,.26); border-color:var(--gold-200); }
.reason__ic{ width:46px; height:46px; color:var(--navy-700); margin-bottom:16px; }
.reason h3{ font-size:22px; margin:0 0 12px; }
.reason p{ font-size:15px; color:var(--ink-muted); line-height:1.6; margin:0; }
.navy .tile, .navy .cat, .navy .reason{ background:rgba(255,255,255,.05); border-color:rgba(201,169,110,.25); }
.navy .tile p, .navy .cat p, .navy .reason p{ color:var(--navy-300); }
.navy .cat .k{ color:#fff; }

/* ---------- steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; position:relative; padding-top:46px; }
.steps__track{ position:absolute; left:6%; right:6%; top:7px; height:2px; background:linear-gradient(90deg, rgba(201,169,110,.12), rgba(201,169,110,.32), rgba(201,169,110,.12)); border-radius:2px; overflow:hidden; }
.steps__track i{ position:absolute; top:0; left:0; height:100%; width:0; background:linear-gradient(90deg, var(--gold-600), var(--gold-400)); border-radius:2px; box-shadow:0 0 14px 2px rgba(201,169,110,.8); transition:width 2.4s cubic-bezier(.4,0,.2,1); }
.steps__track i::after{ content:""; position:absolute; right:-5px; top:50%; width:11px; height:11px; margin-top:-5.5px; border-radius:50%; background:var(--gold-400); box-shadow:0 0 14px 4px rgba(201,169,110,.85); opacity:0; transition:opacity .3s; }
.steps.go .steps__track i::after{ opacity:1; }
@media (max-width:920px){ .steps__track{ display:none; } }
.step{ position:relative; }
.steps.go .step.lit .step__n{ text-shadow:0 0 26px rgba(201,169,110,.5); }
.step__n{ font-family:var(--display); font-weight:600; font-size:54px; color:var(--gold-500); line-height:1; opacity:.92; transition:transform .4s var(--ease); }
.step:hover .step__n{ transform:translateY(-4px) scale(1.04); }
.step h3{ font-size:20px; margin:16px 0 10px; }
.step p{ font-size:14.5px; color:var(--navy-300); line-height:1.6; margin:0; }
.porc .step p, .porc2 .step p{ color:var(--ink-muted); }

/* ---------- badge band ---------- */
.bband{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.bband div{ display:flex; align-items:center; gap:13px; }
.bband svg{ width:34px; height:34px; flex:none; color:var(--gold-400); }
.bband span{ font-size:13.5px; line-height:1.4; font-weight:500; color:var(--navy-300); }
.porc .bband svg, .porc2 .bband svg{ color:var(--navy-700); }
.porc .bband span, .porc2 .bband span{ color:var(--ink-muted); }
@media (max-width:920px){ .bband{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .bband{ grid-template-columns:1fr; } }

/* ---------- comparison table ---------- */
.cmp{ background:#fff; border:1px solid var(--rule); border-radius:20px; overflow:hidden; box-shadow:0 30px 70px -40px rgba(20,20,46,.35); }
.cmp table{ width:100%; border-collapse:collapse; }
.cmp th, .cmp td{ padding:16px 20px; text-align:center; border-bottom:1px solid var(--porc-200); font-size:14.5px; }
.cmp tr:last-child td{ border-bottom:none; }
.cmp td:first-child, .cmp th:first-child{ text-align:left; font-weight:500; color:var(--ink); width:42%; }
.cmp thead th{ background:var(--navy-800); color:#fff; font-family:var(--display); font-size:16px; font-weight:600; letter-spacing:0; padding:20px; border-bottom:none; }
.cmp thead th small{ display:block; font-family:var(--body); font-weight:400; font-size:11.5px; color:var(--navy-300); margin-top:4px; letter-spacing:.02em; }
.cmp thead th.hl{ background:var(--navy-700); color:var(--gold-400); position:relative; }
.cmp tbody tr:nth-child(even){ background:var(--porc-050); }
.cmp tbody tr:hover{ background:rgba(236,224,200,.35); }
.cmp .yes, .cmp .no, .cmp .part{ display:inline-grid; place-items:center; width:26px; height:26px; border-radius:50%; }
.cmp .yes{ background:rgba(201,169,110,.16); color:var(--gold-700); }
.cmp .no{ color:#b9b9cb; }
.cmp .part{ color:var(--ink-subtle); font-size:11px; font-weight:700; letter-spacing:.02em; }
.cmp .yes svg{ width:14px; height:14px; }
.cmp .no svg{ width:12px; height:12px; }
.js .cmp .yes{ transform:scale(0); transition:transform .45s var(--ease); }
.js .cmp.in .yes{ transform:scale(1); }
.js .cmp.in tbody tr:nth-child(1) .yes{ transition-delay:.1s } .js .cmp.in tbody tr:nth-child(2) .yes{ transition-delay:.18s }
.js .cmp.in tbody tr:nth-child(3) .yes{ transition-delay:.26s } .js .cmp.in tbody tr:nth-child(4) .yes{ transition-delay:.34s }
.js .cmp.in tbody tr:nth-child(5) .yes{ transition-delay:.42s } .js .cmp.in tbody tr:nth-child(6) .yes{ transition-delay:.5s }
.js .cmp.in tbody tr:nth-child(7) .yes{ transition-delay:.58s }
@media (prefers-reduced-motion:reduce){ .js .cmp .yes{ transform:none; transition:none; } }
@media (max-width:760px){ .cmp{ overflow-x:auto; } .cmp table{ min-width:640px; } }

/* ---------- pricing plans ---------- */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start; }
.plan{ background:#fff; border:1px solid var(--rule); border-radius:18px; padding:34px 30px; position:relative; transition:transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.plan:hover{ transform:translateY(-6px); box-shadow:0 26px 52px -24px rgba(20,20,46,.3); border-color:var(--gold-200); }
.plan--feature{ border-color:var(--gold-500); box-shadow:0 0 0 1px var(--gold-500); }
.plan--feature:hover{ box-shadow:0 0 0 1px var(--gold-500), 0 26px 52px -22px rgba(201,169,110,.4); }
.plan__badge{ position:absolute; top:-13px; left:30px; background:var(--gold-500); color:var(--navy-900); font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:5px 13px; border-radius:100px; }
.plan__name{ font-family:var(--display); font-weight:600; font-size:24px; color:var(--navy-700); }
.plan__for{ font-size:13px; color:var(--ink-subtle); margin-top:4px; }
.plan__price{ font-family:var(--display); font-weight:600; font-size:38px; color:var(--navy-700); margin:18px 0 0; letter-spacing:-.02em; }
.plan__price small{ font-family:var(--body); font-size:13px; color:var(--ink-subtle); font-weight:500; }
.plan__renew{ font-size:14px; color:var(--ink-muted); margin-top:4px; }
.plan__incl{ list-style:none; margin:20px 0 0; padding:0; display:grid; gap:10px; }
.plan__incl li{ position:relative; padding-left:26px; font-size:14.5px; color:var(--ink); }
.plan__incl li::before{ content:"✓"; position:absolute; left:0; color:var(--gold-600); font-weight:700; }
.plan__note{ font-size:12px; color:var(--ink-subtle); margin-top:16px; }
.plan__cta{ margin-top:16px; width:100%; justify-content:center; }
.pricing__foot{ text-align:center; margin-top:26px; font-size:14px; color:var(--ink-subtle); }

/* ---------- accordion ---------- */
.acc{ border:1px solid var(--rule); border-radius:16px; background:#fff; overflow:hidden; }
.acc + .acc{ margin-top:14px; }
.acc__q{ display:flex; align-items:center; gap:16px; width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:22px 24px; font-family:var(--display); font-weight:600; font-size:18.5px; color:var(--navy-700); transition:background .25s; }
.acc__q:hover{ background:var(--porc-050); }
.acc__q .ind{ margin-left:auto; width:30px; height:30px; border-radius:50%; border:1px solid var(--rule); display:grid; place-items:center; flex:none; transition:transform .4s var(--ease), background .25s, border-color .25s; }
.acc__q .ind svg{ width:14px; height:14px; color:var(--gold-700); }
.acc.open .acc__q .ind{ transform:rotate(45deg); background:var(--navy-700); border-color:var(--navy-700); }
.acc.open .acc__q .ind svg{ color:var(--gold-400); }
.acc__a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.acc__a > div{ padding:0 24px 24px; font-size:15.5px; color:var(--ink-muted); line-height:1.7; max-width:72ch; }
.acc__a a{ color:var(--gold-700); font-weight:600; }
.acc--navy{ background:rgba(255,255,255,.05); border-color:rgba(201,169,110,.25); }
.acc--navy .acc__q{ color:#fff; }
.acc--navy .acc__q:hover{ background:rgba(255,255,255,.04); }
.acc--navy .acc__a > div{ color:var(--navy-300); }

/* ---------- stories ---------- */
.filters{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin:0 0 46px; }
.chip{ border:1px solid var(--rule); background:#fff; color:var(--ink-muted); border-radius:100px; padding:10px 20px; font-size:13.5px; font-weight:600; cursor:pointer; transition:all .25s var(--ease); font-family:var(--body); }
.chip:hover{ border-color:var(--gold-500); color:var(--gold-700); }
.chip[aria-pressed="true"]{ background:var(--navy-700); border-color:var(--navy-700); color:#fff; }
.fstory{ display:grid; grid-template-columns:1.05fr .95fr; gap:0; background:var(--navy-800); border-radius:22px; overflow:hidden; box-shadow:0 40px 90px -40px rgba(19,19,43,.55); }
.fstory__body{ padding:52px 54px; color:#fff; display:flex; flex-direction:column; }
.fstory__body h3{ color:#fff; font-size:clamp(26px,3vw,36px); margin:16px 0 0; }
.fstory__body > p{ color:var(--navy-300); font-size:16px; line-height:1.7; margin:18px 0 0; }
.fstory__stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:auto; padding-top:34px; }
.fstat .v{ font-family:var(--display); font-weight:600; font-size:clamp(24px,2.6vw,34px); color:var(--gold-400); line-height:1; letter-spacing:-.02em; }
.fstat .l{ font-size:12px; color:var(--navy-300); margin-top:8px; line-height:1.35; }
.fstory__visual{ position:relative; background:radial-gradient(120% 100% at 70% 20%, #2c2c5e, var(--navy-900)); min-height:380px; display:grid; place-items:center; overflow:hidden; }
.fstory__visual img.wm{ position:absolute; width:420px; opacity:.06; filter:brightness(0) invert(1); right:-120px; bottom:-60px; }
@media (max-width:920px){ .fstory{ grid-template-columns:1fr; } .fstory__visual{ min-height:280px; order:-1; } .fstory__body{ padding:36px 28px; } }
.scards{ display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:24px; }
.scard{ background:#fff; border:1px solid var(--rule); border-radius:18px; overflow:hidden; transition:transform .35s var(--ease), box-shadow .35s, border-color .35s, opacity .4s var(--ease); display:flex; flex-direction:column; }
.scard:hover{ transform:translateY(-5px); box-shadow:0 24px 48px -22px rgba(20,20,46,.25); border-color:var(--gold-200); }
.scard.hide{ opacity:.18; filter:saturate(.4); transform:scale(.985); }
.scard__top{ padding:30px 30px 0; }
.scard__cat{ display:inline-block; font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:var(--gold-700); background:rgba(201,169,110,.12); border:1px solid var(--gold-200); padding:5px 12px; border-radius:100px; }
.scard h3{ font-size:24px; margin:16px 0 10px; }
.scard__sum{ font-size:14.5px; color:var(--ink-muted); line-height:1.65; margin:0; }
.scard__stats{ display:flex; gap:26px; padding:20px 30px; }
.scard__stats .v{ font-family:var(--display); font-weight:600; font-size:22px; color:var(--navy-700); }
.scard__stats .l{ font-size:11.5px; color:var(--ink-subtle); margin-top:2px; line-height:1.3; }
.scard__more{ border-top:1px solid var(--porc-200); margin-top:auto; }
.scard__toggle{ display:flex; align-items:center; gap:8px; width:100%; background:none; border:none; cursor:pointer; padding:16px 30px; font-family:var(--body); font-weight:600; font-size:14px; color:var(--gold-700); transition:background .25s; }
.scard__toggle:hover{ background:var(--porc-050); }
.scard__toggle .ind{ margin-left:auto; transition:transform .4s var(--ease); display:grid; place-items:center; }
.scard.open .scard__toggle .ind{ transform:rotate(180deg); }
.scard__toggle .ind svg{ width:16px; height:16px; }
.scard__detail{ max-height:0; overflow:hidden; transition:max-height .6s var(--ease); }
.scard__detail > div{ padding:4px 30px 28px; }
.scard__detail h4{ font-size:12px; font-family:var(--body); letter-spacing:.16em; text-transform:uppercase; color:var(--gold-700); margin:18px 0 8px; }
.scard__detail p, .scard__detail li{ font-size:14.5px; color:var(--ink-muted); line-height:1.65; margin:0; }
.scard__detail ul{ margin:6px 0 0; padding-left:18px; display:grid; gap:5px; }
@media (max-width:860px){ .scards{ grid-template-columns:1fr; } }

/* ---------- resource documents ---------- */
.docs{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.doc{ background:#fff; border:1px solid var(--rule); border-radius:18px; padding:26px; display:flex; flex-direction:column; position:relative; overflow:hidden; transition:transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.doc::before{ content:""; position:absolute; top:0; left:26px; right:26px; height:2px; background:linear-gradient(90deg, var(--gold-500), rgba(201,169,110,0)); opacity:0; transition:opacity .3s; }
.doc:hover{ transform:translateY(-6px); box-shadow:0 26px 52px -24px rgba(20,20,46,.28); border-color:var(--gold-200); }
.doc:hover::before{ opacity:1; }
.doc__no{ font-family:var(--display); font-weight:600; font-size:13px; color:var(--gold-600); letter-spacing:.1em; }
.doc__ic{ width:44px; height:44px; border-radius:12px; background:rgba(201,169,110,.13); display:grid; place-items:center; margin:14px 0 16px; }
.doc__ic svg{ width:22px; height:22px; color:var(--gold-700); }
.doc h3{ font-size:20px; line-height:1.2; margin:0 0 8px; }
.doc p{ font-size:13.5px; color:var(--ink-muted); line-height:1.6; margin:0 0 18px; }
.doc__meta{ font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-subtle); font-weight:600; margin-bottom:14px; margin-top:auto; }
.doc__btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; font-weight:600; font-size:13.5px; color:var(--navy-700); border:1px solid rgba(38,38,84,.25); border-radius:100px; padding:11px 20px; cursor:pointer; background:transparent; transition:all .25s; font-family:var(--body); }
.doc__btn:hover{ background:var(--navy-700); color:#fff; border-color:var(--navy-700); }
.doc__btn svg{ width:15px; height:15px; }
.doc--flag{ grid-column:span 1; }
@media (max-width:980px){ .docs{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .docs{ grid-template-columns:1fr; } }

/* gate modal */
.gatewrap{ position:fixed; inset:0; z-index:80; display:grid; place-items:center; padding:20px; background:rgba(19,19,43,.72); backdrop-filter:blur(6px); opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s; }
.gatewrap.open{ opacity:1; visibility:visible; }
.gate{ background:var(--porc-050); border-radius:20px; max-width:520px; width:100%; padding:40px 38px; position:relative; box-shadow:0 50px 120px -30px rgba(0,0,0,.6); transform:translateY(16px) scale(.98); transition:transform .35s var(--ease); }
.gatewrap.open .gate{ transform:none; }
.gate::before{ content:""; position:absolute; top:0; left:38px; right:38px; height:2px; background:var(--gold-500); }
.gate__x{ position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:50%; border:1px solid var(--rule); background:#fff; cursor:pointer; display:grid; place-items:center; color:var(--ink-muted); transition:all .2s; }
.gate__x:hover{ color:var(--navy-700); border-color:var(--gold-500); }
.gate__x svg{ width:14px; height:14px; }
.gate h3{ font-size:24px; margin:14px 0 8px; }
.gate p{ font-size:14.5px; color:var(--ink-muted); line-height:1.6; margin:0 0 20px; }
.gate label{ display:block; font-size:12px; letter-spacing:.08em; text-transform:uppercase; font-weight:600; color:var(--gold-700); margin:0 0 7px; }
.gate input[type="email"], .gate input[type="text"]{ width:100%; font-family:inherit; font-size:15.5px; padding:13px 16px; border-radius:10px; border:1px solid var(--rule); background:#fff; color:var(--ink); margin-bottom:14px; }
.gate input:focus{ outline:none; border-color:var(--gold-500); box-shadow:0 0 0 3px rgba(201,169,110,.25); }
.gate .btn{ width:100%; justify-content:center; }
.gate__skip{ display:block; text-align:center; margin-top:14px; font-size:13px; color:var(--ink-subtle); background:none; border:none; cursor:pointer; font-family:var(--body); text-decoration:underline; text-underline-offset:3px; }
.gate__skip:hover{ color:var(--navy-700); }
.gate__fine{ font-size:11.5px; color:var(--ink-subtle); margin-top:16px; line-height:1.5; text-align:center; }
.gate .hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* ---------- newsletter band ---------- */
.newsband{ background:linear-gradient(120deg, rgba(201,169,110,.14), rgba(201,169,110,.04)); border:1px solid rgba(201,169,110,.4); border-radius:20px; padding:34px 38px; display:grid; grid-template-columns:1.2fr .8fr; gap:30px; align-items:center; }
.newsband h3{ color:#fff; font-size:24px; margin:8px 0 8px; }
.newsband p{ color:var(--navy-300); font-size:14.5px; line-height:1.6; margin:0; }
.newsband form{ display:flex; gap:10px; }
.newsband input{ flex:1; font-family:inherit; font-size:15px; padding:13px 16px; border-radius:100px; border:1px solid rgba(255,255,255,.2); background:rgba(255,255,255,.07); color:#fff; min-width:0; }
.newsband input::placeholder{ color:#8a8ab0; }
.newsband input:focus{ outline:none; border-color:var(--gold-400); }
.newsband .btn{ flex:none; }
@media (max-width:860px){ .newsband{ grid-template-columns:1fr; } .newsband form{ flex-direction:column; } }

/* ---------- pull quote band ---------- */
.quote{ text-align:center; max-width:820px; margin:0 auto; }
.quote blockquote{ margin:0; font-family:var(--display); font-size:clamp(24px,3.2vw,36px); font-weight:500; line-height:1.4; color:var(--navy-700); }
.navy .quote blockquote{ color:#fff; }
.quote blockquote em{ font-style:italic; color:var(--gold-700); }
.navy .quote blockquote em{ color:var(--gold-400); }
.quote cite{ display:block; font-style:normal; font-size:14px; color:var(--ink-subtle); margin-top:20px; }
.navy .quote cite{ color:var(--navy-300); }
.quote::before{ content:""; display:block; width:54px; height:3px; background:var(--gold-500); margin:0 auto 30px; }

/* ---------- stat band ---------- */
.statband{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.pstat{ background:rgba(255,255,255,.05); border:1px solid rgba(201,169,110,.28); border-radius:16px; padding:26px 20px; text-align:center; }
.pstat .v{ font-family:var(--display); font-weight:600; font-size:clamp(28px,3.4vw,40px); color:var(--gold-400); line-height:1; letter-spacing:-.02em; }
.pstat .l{ font-size:12.5px; color:var(--navy-300); margin-top:10px; line-height:1.4; }
.porc .pstat, .porc2 .pstat{ background:#fff; border-color:var(--rule); }
.porc .pstat .v, .porc2 .pstat .v{ color:var(--gold-700); }
.porc .pstat .l, .porc2 .pstat .l{ color:var(--ink-muted); }
@media (max-width:920px){ .statband{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .statband{ grid-template-columns:1fr; } .pstat{ display:flex; align-items:center; gap:14px; text-align:left; } .pstat .l{ margin-top:0; } }

/* ---------- CTA ---------- */
.cta{ position:relative; background:var(--navy-800); color:#fff; }
.cta__card{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.cta .trust2{ display:grid; grid-template-columns:1fr 1fr; gap:16px 24px; margin-top:34px; }
.cta .trust2 div{ display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--gold-400); font-weight:600; }
.cta .trust2 svg{ width:18px; height:18px; flex:none; }
.cta h2{ color:#fff; font-size:clamp(30px,4vw,46px); max-width:14ch; }
.cta > .wrap > div > p, .cta__lead{ color:var(--navy-300); font-size:18px; margin:18px 0 0; max-width:46ch; line-height:1.6; }
.panelform{ background:rgba(255,255,255,.05); border:1px solid rgba(201,169,110,.3); border-radius:18px; padding:34px 32px; }
.panelform .form__call{ font-size:13.5px; color:var(--navy-300); text-align:center; margin-top:14px; }
.panelform .form__call a{ color:var(--gold-400); font-weight:600; }
@media (max-width:920px){ .cta__card{ grid-template-columns:1fr; gap:32px; } }

/* ---------- forms (contact) ---------- */
.field label{ display:block; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; font-weight:600; color:var(--gold-700); margin:0 0 7px; }
.field input, .field textarea, .field select{ width:100%; font-family:inherit; font-size:15.5px; padding:14px 16px; border-radius:10px; border:1px solid var(--rule); background:#fff; color:var(--ink); }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--gold-500); box-shadow:0 0 0 3px rgba(201,169,110,.22); }
.field{ margin-bottom:18px; }
.field textarea{ min-height:130px; resize:vertical; }
.formgrid{ display:grid; grid-template-columns:1fr 1fr; gap:0 18px; }
@media (max-width:640px){ .formgrid{ grid-template-columns:1fr; } }
.form__msg{ font-size:14px; margin-top:14px; min-height:20px; }
.form__msg.ok{ color:var(--gold-700); } .form__msg.err{ color:#b3401f; }
.navy .form__msg.ok{ color:var(--gold-400); } .navy .form__msg.err{ color:#ffb3a6; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* ---------- footer ---------- */
.foot{ background:var(--navy-900); color:var(--navy-300); padding:72px 0 40px; }
.foot__in{ display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr; gap:40px; align-items:start; }
.foot .brand img{ height:50px; }
.foot__sub{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-400); margin-top:12px; }
.foot__tag{ font-family:var(--display); font-style:italic; font-size:18px; color:var(--gold-400); margin-top:8px; }
.foot__blurb{ font-size:13.5px; line-height:1.6; margin-top:16px; max-width:34ch; }
.foot__col h4{ font-family:var(--body); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-400); font-weight:700; margin:0 0 14px; }
.foot__col a, .foot__col span{ display:block; font-size:14.5px; color:var(--navy-300); margin-bottom:9px; transition:color .2s; }
.foot__col a:hover{ color:#fff; }
.foot__legal{ margin-top:48px; padding-top:22px; border-top:1px solid rgba(255,255,255,.08); font-size:12px; color:#6f6f92; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }
@media (max-width:920px){ .foot__in{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .foot__in{ grid-template-columns:1fr; } }

/* ---------- misc responsive ---------- */
@media (max-width:920px){
  .tiles{ grid-template-columns:1fr 1fr; } .tiles--4{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr; }
  .reasons{ grid-template-columns:1fr; } .plans{ grid-template-columns:1fr; }
}
@media (max-width:520px){
  .wrap,.nav__in{ padding-left:22px; padding-right:22px; }
  .tiles,.tiles--4,.cats,.steps{ grid-template-columns:1fr; }
  .sec{ padding:72px 0; } .sec--wave{ padding-bottom:110px; }
}
