/* ─────────────────────────────────────────────────────────────────
   FinioPro V2 stylesheet — rebuild 2026-05-20
   Palette: navy-forward, teal accent. NO cream, NO brown, NO warm tones.
   Navy as a major background surface. Teal visible across every screen.
   Density: Rainmaker discipline. Whitespace > components.
   ─────────────────────────────────────────────────────────────── */

:root{
  /* ── core palette ── */
  --navy:#0F223A;
  --navy-1:#16304F;
  --navy-2:#22384E;
  --slate:#0A1828;
  --teal:#457170;
  --teal-soft:#5A8584;
  --teal-on-dark:#67A4A3;

  /* cool, blue-leaning neutrals (never warm) */
  --bg-base:#FFFFFF;
  --bg-paper:#F7F9FC;
  --line:#E5E9EE;
  --line-soft:#EFF2F6;
  --line-on-dark:rgba(255,255,255,.08);
  --line-on-dark-strong:rgba(255,255,255,.14);

  /* type colors */
  --text-strong:#0F223A;
  --text:#2A3845;
  --text-soft:#5A6878;
  --text-muted:#7E8A9A;
  --text-on-dark:#EDF1F6;
  --text-on-dark-soft:#A4B4C7;
  --text-on-dark-muted:#7A8B9F;

  /* ── type ── */
  --display:'Inter Tight','Inter',system-ui,sans-serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;

  /* ── scale ── */
  --content-max:min(1240px,86vw);
  --content-narrow:min(960px,90vw);
  --page-pad:clamp(20px,4vw,56px);
  --section-pad-y:clamp(80px,9vw,140px);

  /* ── shadows ── */
  --shadow-soft:0 1px 2px rgba(15,34,58,.05),0 4px 12px rgba(15,34,58,.04);
  --shadow-card:0 4px 12px rgba(15,34,58,.06),0 16px 36px rgba(15,34,58,.08);
  --shadow-hero:0 24px 64px rgba(15,34,58,.18),0 8px 24px rgba(15,34,58,.10);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{
  background:var(--bg-base);color:var(--text);
  font-family:var(--sans);
  font-size:clamp(14.5px,.95vw,16.5px);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
em{font-style:italic}

.num,.metric,.price,.tier .price,.trust-strip b,.stat,.process-step .ix{
  font-feature-settings:"tnum" 1,"zero" 1;
  font-variant-numeric:tabular-nums slashed-zero;
}

/* ── motion primitives ── */
.reveal{
  opacity:0;transform:translateY(20px);
  transition:opacity .65s cubic-bezier(.22,.61,.36,1),transform .65s cubic-bezier(.22,.61,.36,1);
  will-change:transform,opacity;
}
.reveal.in{opacity:1;transform:translateY(0);will-change:auto}
.reveal-group > .reveal:nth-child(1){transition-delay:0ms}
.reveal-group > .reveal:nth-child(2){transition-delay:80ms}
.reveal-group > .reveal:nth-child(3){transition-delay:160ms}
.reveal-group > .reveal:nth-child(4){transition-delay:240ms}
.reveal-group > .reveal:nth-child(5){transition-delay:320ms}
.reveal-group > .reveal:nth-child(6){transition-delay:400ms}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ─────────── NAV ─────────── */
header.site{
  position:sticky;top:0;z-index:50;background:rgba(15,34,58,.92);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line-on-dark);
}
header.site .row{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--content-max);margin:0 auto;padding:14px var(--page-pad);
}
.brand-logo{display:inline-flex;align-items:center;height:24px}
.brand-logo svg,.brand-logo img{height:24px;width:auto;display:block}
nav.primary{display:flex;gap:clamp(20px,2vw,32px);align-items:center}
nav.primary a{font-size:13.5px;font-weight:500;color:var(--text-on-dark-soft);transition:color .18s;letter-spacing:.005em}
nav.primary a:hover,nav.primary a.active{color:#fff}
nav.primary .cta{
  background:var(--teal);color:#fff;padding:9px 18px;border-radius:8px;
  font-weight:600;font-size:13.5px;letter-spacing:.005em;
  transition:background .18s,transform .18s;
}
nav.primary .cta:hover{background:var(--teal-on-dark);transform:translateY(-1px)}
@media (max-width:820px){
  nav.primary a:not(.cta){display:none}
}

/* ─────────── HERO (navy primary) ─────────── */
section.hero{
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-1) 100%);
  color:var(--text-on-dark);
  padding:clamp(72px,10vw,140px) var(--page-pad) clamp(72px,10vw,140px);
  position:relative;overflow:hidden;
}
section.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:64px 64px;opacity:.6;
}
.hero-inner{
  max-width:var(--content-max);margin:0 auto;
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:clamp(28px,4vw,72px);
  align-items:center;position:relative;z-index:1;
}
@media (max-width:980px){.hero-inner{grid-template-columns:1fr;gap:48px}}
.hero .label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.06em;
  color:var(--teal-on-dark);text-transform:uppercase;margin-bottom:22px;
}
.hero .label .dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--teal-on-dark);
  box-shadow:0 0 0 4px rgba(103,164,163,.18);
}
.hero h1{
  font-family:var(--display);font-weight:700;letter-spacing:-.025em;color:#fff;
  font-size:clamp(38px,5.2vw,72px);line-height:1.02;text-wrap:balance;
  margin-bottom:clamp(18px,2vw,28px);max-width:18ch;
}
.hero .sub{
  font-size:clamp(16px,1.2vw,19px);line-height:1.55;color:var(--text-on-dark-soft);
  max-width:48ch;margin-bottom:clamp(28px,3vw,40px);
}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:clamp(36px,4vw,56px)}

.btn-primary{
  background:var(--teal);color:#fff;padding:14px 28px;border-radius:8px;
  font-size:14px;font-weight:600;letter-spacing:.005em;
  transition:background .18s,transform .18s;display:inline-flex;align-items:center;gap:8px;
}
.btn-primary::after{content:"→";transition:transform .2s}
.btn-primary:hover{background:var(--teal-on-dark);transform:translateY(-1px)}
.btn-primary:hover::after{transform:translateX(3px)}
.btn-ghost-on-dark{
  background:transparent;color:#fff;padding:14px 26px;border-radius:8px;
  font-size:14px;font-weight:600;border:1px solid rgba(255,255,255,.18);
  transition:border-color .18s,background .18s;
}
.btn-ghost-on-dark:hover{border-color:var(--teal-on-dark);background:rgba(103,164,163,.08)}
.btn-ghost{
  background:#fff;color:var(--navy);padding:13px 22px;border-radius:8px;
  font-size:14px;font-weight:600;border:1px solid var(--line);
  transition:border-color .18s,color .18s;
}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}

/* hero trust strip (on navy) */
.trust-strip{
  display:grid;grid-template-columns:1fr;gap:16px;
  padding-top:clamp(20px,2.5vw,32px);border-top:1px solid var(--line-on-dark);
}
@media (min-width:640px){.trust-strip{grid-template-columns:repeat(2,1fr)}}
.trust-strip .item{display:flex;align-items:flex-start;gap:10px}
.trust-strip .item::before{content:"";flex:0 0 auto;width:14px;height:1px;background:var(--teal-on-dark);margin-top:11px}
.trust-strip .item span{font-size:13.5px;color:var(--text-on-dark-soft);line-height:1.45}

/* hero visual right column — clean browser mockup */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.browser{
  width:100%;max-width:720px;background:#fff;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-hero);
  transform:perspective(1800px) rotateY(-4deg) rotateX(2deg);transform-origin:center;
}
.browser .chrome{
  height:38px;background:#f3f5f9;border-bottom:1px solid var(--line);
  display:flex;align-items:center;padding:0 14px;gap:6px;
}
.browser .chrome .d{width:11px;height:11px;border-radius:50%}
.browser .chrome .d.r{background:#e5704a}
.browser .chrome .d.y{background:#f0b13a}
.browser .chrome .d.g{background:#5fb35c}
.browser .chrome .url{
  margin-left:18px;padding:5px 12px;background:#fff;border:1px solid var(--line);border-radius:6px;
  font-family:var(--mono);font-size:11.5px;color:var(--text-muted);min-width:280px;
}
.preview{padding:30px 36px 34px;background:#fff;color:var(--navy)}
.preview .pnav{display:flex;justify-content:space-between;align-items:center;font-size:11px;margin-bottom:30px;color:var(--text-soft)}
.preview .pnav .pbrand{font-family:var(--display);font-weight:700;font-size:14px;color:var(--navy);letter-spacing:-.02em}
.preview .pnav .pbrand em{color:var(--teal);font-style:normal;font-weight:700}
.preview .pnav .plinks{display:flex;gap:14px;font-size:10px}
.preview .pnav .pcta{background:var(--navy);color:#fff;padding:4px 10px;border-radius:5px;font-size:9.5px;font-weight:600}
.preview .plabel{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);font-weight:700;margin-bottom:12px}
.preview .ph1{font-family:var(--display);font-weight:700;font-size:26px;line-height:1.04;color:var(--navy);letter-spacing:-.02em;margin-bottom:10px;max-width:14ch}
.preview .pp{font-size:11px;line-height:1.55;color:var(--text);max-width:42ch;margin-bottom:16px}
.preview .pbtn{display:inline-block;background:var(--navy);color:#fff;padding:6px 14px;border-radius:5px;font-size:9.5px;font-weight:600}
.preview .pphoto{margin-top:18px;height:120px;border-radius:6px;background:linear-gradient(135deg,#22384E 0%,#0A1828 100%);position:relative;overflow:hidden}
.preview .pphoto::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 8px,transparent 8px 16px)}
.preview .pstats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}
.preview .pstats .c{padding:8px 10px;border:1px solid var(--line);border-radius:5px}
.preview .pstats .c b{display:block;font-family:var(--display);font-weight:700;font-size:13px;color:var(--navy);line-height:1}
.preview .pstats .c span{display:block;margin-top:3px;font-size:9.5px;color:var(--text-muted);letter-spacing:.04em}

/* ─────────── SECTION BASE ─────────── */
section.s{padding:var(--section-pad-y) var(--page-pad);position:relative}
section.s .inner{max-width:var(--content-max);margin:0 auto}
section.s .narrow{max-width:var(--content-narrow);margin:0 auto}
section.s .lede{max-width:62ch;margin-bottom:clamp(40px,5vw,72px)}
section.s .label{
  display:inline-block;font-weight:600;font-size:12px;letter-spacing:.06em;
  color:var(--teal);text-transform:uppercase;margin-bottom:18px;
}
section.s .label-on-dark{color:var(--teal-on-dark)}
section.s h2,section.s .lede h2{
  font-family:var(--display);font-weight:700;color:var(--text-strong);
  font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-.022em;text-wrap:balance;
  margin-bottom:18px;max-width:24ch;
}
section.s h2.on-dark{color:#fff}
section.s .lede p,section.s p.kicker{
  font-size:clamp(15px,1.15vw,18px);line-height:1.6;color:var(--text);max-width:60ch;
}
section.s p.kicker.on-dark{color:var(--text-on-dark-soft)}

/* dark section wrapper */
section.dark{background:var(--navy);color:var(--text-on-dark);position:relative;overflow:hidden}
section.dark::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:64px 64px;opacity:.6;
}
section.dark > .inner{position:relative;z-index:1}
section.dark h2{color:#fff}
section.dark p.kicker,section.dark .lede p{color:var(--text-on-dark-soft)}

/* ─────────── PROBLEM (3 cards, white) ─────────── */
.problem .cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2vw,28px)}
@media (max-width:860px){.problem .cards{grid-template-columns:1fr}}
.problem .card{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:30px 28px;display:flex;flex-direction:column;gap:12px;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.problem .card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-card)}
.problem .card .ix{font-size:11.5px;letter-spacing:.08em;color:var(--teal);font-weight:700;text-transform:uppercase}
.problem .card h3{
  font-family:var(--display);font-weight:700;font-size:clamp(18px,1.6vw,22px);
  color:var(--navy);line-height:1.18;letter-spacing:-.012em;
}
.problem .card p{font-size:14.5px;line-height:1.6;color:var(--text)}

/* ─────────── PROCESS (sticky scrollytelling, dark) ─────────── */
.process{background:var(--navy);color:var(--text-on-dark);position:relative}
.process::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:64px 64px;opacity:.6;
  /* clip the texture to the section without using overflow:hidden, which would
     break the sticky positioning of .visual-col inside .scrolly */
}
.process .inner{position:relative;z-index:1}
.process .lede h2{color:#fff}
.process .lede p{color:var(--text-on-dark-soft)}
.process .scrolly{
  position:relative;display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:clamp(32px,5vw,80px);align-items:start;
}
@media (max-width:960px){.process .scrolly{grid-template-columns:1fr}}
.process .steps-col{display:flex;flex-direction:column;gap:clamp(56px,7vw,112px);padding:clamp(24px,3vw,40px) 0 clamp(40vh,50vh,60vh)}
.process .step{
  display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
  opacity:.35;transition:opacity .4s cubic-bezier(.22,.61,.36,1);
}
.process .step.is-active{opacity:1}
.process .step .ix{
  font-family:var(--display);font-weight:700;font-size:30px;color:var(--teal-on-dark);line-height:1;
  min-width:40px;letter-spacing:-.02em;padding-top:4px;
}
.process .step h3{
  font-family:var(--display);font-weight:700;font-size:clamp(22px,2.4vw,30px);
  color:#fff;line-height:1.16;letter-spacing:-.018em;margin-bottom:10px;
}
.process .step p{font-size:15px;line-height:1.65;color:var(--text-on-dark-soft);max-width:50ch}
.process .visual-col{position:sticky;top:120px;height:auto}
.process .stage{
  background:rgba(255,255,255,.04);border:1px solid var(--line-on-dark-strong);border-radius:14px;
  overflow:hidden;aspect-ratio:5/4;display:grid;place-items:stretch;position:relative;
}
.process .stage .panel{
  position:absolute;inset:0;padding:26px 30px;
  opacity:0;transition:opacity .25s cubic-bezier(.22,.61,.36,1) 0s;
  display:flex;flex-direction:column;pointer-events:none;
}
.process .stage .panel.is-active{
  opacity:1;
  transition:opacity .25s cubic-bezier(.22,.61,.36,1) .25s;
  pointer-events:auto;
}
.process .stage .panel .ptitle{font-family:var(--display);font-weight:700;font-size:16px;color:#fff;letter-spacing:-.012em;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.process .stage .panel .ptitle .tag{font-size:10px;background:rgba(103,164,163,.16);color:var(--teal-on-dark);font-weight:700;letter-spacing:.06em;padding:4px 10px;border-radius:999px;text-transform:uppercase;font-family:var(--sans)}
.process .stage .panel ul{list-style:none;display:grid;gap:10px;margin-top:8px}
.process .stage .panel li{font-size:12.5px;color:var(--text-on-dark);padding-left:18px;position:relative;line-height:1.5}
.process .stage .panel li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:1px;background:var(--teal-on-dark)}
.process .stage .panel .grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.process .stage .panel .card{background:rgba(255,255,255,.04);border:1px solid var(--line-on-dark);border-radius:8px;padding:10px 12px}
.process .stage .panel .card b{display:block;font-family:var(--display);font-size:13px;color:#fff;font-weight:700;letter-spacing:-.01em}
.process .stage .panel .card span{display:block;font-size:10.5px;color:var(--text-on-dark-soft);letter-spacing:.04em;margin-top:2px}
.process .stage .panel .progress{margin-top:14px;display:flex;align-items:center;gap:10px}
.process .stage .panel .progress .bar{flex:1;height:6px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden}
.process .stage .panel .progress .fill{height:100%;background:var(--teal-on-dark);width:60%}
.process .stage .panel .progress .pct{font-size:11px;color:var(--text-on-dark-soft);font-weight:600}
.process .stage .panel .ok{display:inline-flex;align-items:center;gap:6px;color:var(--teal-on-dark);font-size:12px;font-weight:700;margin-top:10px}
.process .stage .panel .ok::before{content:"✓";display:inline-block;width:16px;height:16px;border-radius:50%;background:var(--teal-on-dark);color:var(--navy);text-align:center;line-height:16px;font-size:11px}
.process .oneliner{
  margin-top:clamp(48px,5vw,80px);text-align:center;font-family:var(--display);font-weight:600;
  font-size:clamp(20px,2vw,26px);line-height:1.4;color:#fff;letter-spacing:-.012em;
  max-width:54ch;margin-left:auto;margin-right:auto;
}

/* ─────────── EXAMPLES (white) ─────────── */
.examples .cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2vw,28px)}
@media (max-width:880px){.examples .cards{grid-template-columns:1fr}}
.examples .card{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,transform .2s,box-shadow .2s}
.examples .card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-card)}
.examples .card .shot{aspect-ratio:5/3;background:linear-gradient(135deg,#F7F9FC 0%,#EDF1F7 100%);position:relative;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line)}
.examples .card .shot .mini{width:78%;background:#fff;border:1px solid var(--line);border-radius:6px;padding:13px 15px 16px;transform:rotate(-1deg);box-shadow:0 8px 20px rgba(15,34,58,.10)}
.examples .card .shot .mini.s2{transform:rotate(.8deg);background:linear-gradient(180deg,#fff 0%,#F0F4FA 100%)}
.examples .card .shot .mini.s3{transform:rotate(-.6deg);background:linear-gradient(180deg,var(--navy) 0%,#16304F 100%);color:#EDF1F6;border-color:var(--navy-1)}
.examples .card .shot .mini .h{font-family:var(--display);font-size:14px;color:var(--navy);line-height:1.1;margin-bottom:5px;font-weight:700;letter-spacing:-.01em}
.examples .card .shot .mini.s3 .h{color:#fff}
.examples .card .shot .mini .p{font-size:9.5px;color:var(--text);line-height:1.4;margin-bottom:7px}
.examples .card .shot .mini.s3 .p{color:#9BAEC4}
.examples .card .shot .mini .b{display:inline-block;font-size:8px;background:var(--teal);color:#fff;padding:3px 8px;border-radius:999px;font-weight:600}
.examples .card .meta{padding:20px 22px 22px}
.examples .card .meta .tag{font-size:11px;letter-spacing:.08em;color:var(--teal);font-weight:700;text-transform:uppercase;margin-bottom:8px}
.examples .card .meta h3{font-family:var(--display);font-weight:700;font-size:17px;color:var(--navy);line-height:1.2;margin-bottom:6px;letter-spacing:-.012em}
.examples .card .meta p{font-size:13.5px;color:var(--text);line-height:1.55}
.examples .disclaim{margin-top:24px;font-size:12.5px;color:var(--text-muted);text-align:center;font-style:italic}

/* ─────────── COMPLIANCE (dark, dashboard panel) ─────────── */
.compliance{background:var(--navy);color:var(--text-on-dark);position:relative;overflow:hidden}
.compliance::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:48px 48px;opacity:.7;
}
.compliance .inner{position:relative;z-index:1}
.compliance .lede h2{color:#fff}
.compliance .lede p{color:var(--text-on-dark-soft)}
.compliance .panel{
  background:rgba(255,255,255,.025);border:1px solid var(--line-on-dark-strong);border-radius:14px;
  padding:clamp(8px,1vw,16px) clamp(12px,1.5vw,20px);
}
.compliance .panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0}
@media (max-width:800px){.compliance .panel-grid{grid-template-columns:1fr}}
.compliance .panel-grid .row{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:16px 12px;border-bottom:1px solid var(--line-on-dark);
}
.compliance .panel-grid .row:nth-last-child(-n+2){border-bottom:none}
@media (max-width:800px){.compliance .panel-grid .row{border-bottom:1px solid var(--line-on-dark)} .compliance .panel-grid .row:last-child{border-bottom:none}}
.compliance .panel-grid .row .tag{
  font-family:var(--mono);font-size:10.5px;color:var(--teal-on-dark);font-weight:600;
  background:rgba(103,164,163,.10);padding:4px 10px;border-radius:5px;letter-spacing:.02em;white-space:nowrap;
}
.compliance .panel-grid .row .body{font-size:13.5px;line-height:1.5;color:var(--text-on-dark)}
.compliance .panel-grid .row .ok{color:var(--teal-on-dark);font-size:18px;font-weight:700}
.compliance .pull{
  margin-top:clamp(32px,4vw,56px);
  font-family:var(--display);font-style:italic;font-size:clamp(18px,1.8vw,24px);line-height:1.4;color:#fff;
  max-width:62ch;padding:24px 28px;border-left:3px solid var(--teal-on-dark);background:rgba(255,255,255,.02);
}

/* ─────────── AIO (white) ─────────── */
.aio .row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:clamp(28px,4vw,72px);align-items:center}
@media (max-width:960px){.aio .row{grid-template-columns:1fr}}
.aio .badge{display:inline-block;background:var(--teal);color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:6px;margin-left:10px}
.aio .bullets{list-style:none;display:flex;flex-direction:column;gap:0;margin-top:clamp(20px,2.4vw,28px)}
.aio .bullets li{font-size:14.5px;line-height:1.55;color:var(--text);padding:12px 0 12px 22px;position:relative;border-bottom:1px solid var(--line-soft)}
.aio .bullets li:last-child{border-bottom:none}
.aio .bullets li::before{content:"";position:absolute;left:0;top:20px;width:10px;height:1px;background:var(--teal)}
.aio .visual{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 28px;box-shadow:var(--shadow-soft)}
.aio .visual .ai-head{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.aio .visual .ai-head .av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#4a8db5 0%,#3a5d7e 100%);display:grid;place-items:center;color:#fff;font-size:12px;font-weight:700}
.aio .visual .ai-head .name{font-size:13.5px;font-weight:600;color:var(--navy)}
.aio .visual .ai-head .meta{font-size:11.5px;color:var(--text-muted)}
.aio .visual .row-q{color:var(--text-muted);font-size:13px;margin-bottom:14px;font-family:var(--mono)}
.aio .visual .row-q::before{content:"› ";color:var(--teal)}
.aio .visual .row-a{font-size:14px;line-height:1.6;color:var(--text)}
.aio .visual .row-a b{color:var(--navy);font-weight:700}
.aio .visual .source{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-size:11px;color:var(--text-muted);letter-spacing:.04em;display:flex;justify-content:space-between}
.aio .visual .source .pin{color:var(--teal);font-weight:600}

/* ─────────── COPY PROCESS (dark, NEW) ─────────── */
.copyprocess{background:var(--navy-1);color:var(--text-on-dark)}
.copyprocess .row{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:clamp(28px,4vw,72px);align-items:center}
@media (max-width:960px){.copyprocess .row{grid-template-columns:1fr}}
.copyprocess .lede h2{color:#fff;max-width:18ch}
.copyprocess .lede p{color:var(--text-on-dark-soft)}
.copyprocess .visual{background:rgba(255,255,255,.04);border:1px solid var(--line-on-dark-strong);border-radius:14px;padding:28px 30px}
.copyprocess .visual .step{display:grid;grid-template-columns:24px 1fr;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-on-dark);align-items:start}
.copyprocess .visual .step:last-child{border-bottom:none;padding-bottom:0}
.copyprocess .visual .step .n{font-family:var(--display);font-weight:700;font-size:14px;color:var(--teal-on-dark);line-height:1.4}
.copyprocess .visual .step b{display:block;font-family:var(--display);font-weight:600;font-size:14px;color:#fff;letter-spacing:-.005em;margin-bottom:2px}
.copyprocess .visual .step span{font-size:12.5px;color:var(--text-on-dark-soft);line-height:1.5}
.copyprocess .visual .tag{display:inline-block;font-family:var(--mono);font-size:10.5px;color:var(--teal-on-dark);background:rgba(103,164,163,.12);padding:4px 10px;border-radius:5px;letter-spacing:.02em;margin-bottom:14px}

/* ─────────── PRICING (white) ─────────── */
.pricing .tiers{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2vw,24px);margin-top:clamp(32px,4vw,48px)}
@media (max-width:960px){.pricing .tiers{grid-template-columns:1fr;gap:20px}}
.pricing .tier{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 28px;display:flex;flex-direction:column;position:relative;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.pricing .tier:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}
.pricing .tier.popular{border-color:var(--teal);box-shadow:0 12px 32px rgba(69,113,112,.14);transform:translateY(-6px)}
.pricing .tier.popular:hover{transform:translateY(-9px)}
.pricing .tier.popular .pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--teal);color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.pricing .tier h3{font-family:var(--display);font-weight:700;font-size:21px;color:var(--navy);letter-spacing:-.015em;margin-bottom:4px}
.pricing .tier .price{font-family:var(--display);font-weight:700;font-size:clamp(38px,3.6vw,46px);color:var(--navy);line-height:1;letter-spacing:-.025em;margin:12px 0 4px}
.pricing .tier .price-meta{font-size:12.5px;color:var(--text-muted);margin-bottom:20px}
.pricing .tier ul{list-style:none;flex:1;margin-bottom:22px}
.pricing .tier li{font-size:14px;line-height:1.55;color:var(--text);padding:7px 0 7px 22px;position:relative}
.pricing .tier li::before{content:"";position:absolute;left:0;top:15px;width:10px;height:1px;background:var(--teal)}
.pricing .tier .cta{background:var(--navy);color:#fff;padding:12px 22px;border-radius:8px;font-size:13.5px;font-weight:600;align-self:stretch;text-align:center;transition:background .18s}
.pricing .tier.popular .cta{background:var(--teal)}
.pricing .tier .cta:hover{background:var(--teal)}
.pricing .tier.popular .cta:hover{background:var(--teal-on-dark)}
.pricing .support{margin-top:clamp(24px,3vw,40px);text-align:center;max-width:60ch;margin-left:auto;margin-right:auto;font-size:14px;color:var(--text-soft);line-height:1.55}
.pricing .care{margin-top:clamp(20px,2vw,32px);padding:24px 28px;background:var(--bg-paper);border:1px solid var(--line);border-radius:12px;max-width:760px;margin-left:auto;margin-right:auto}
.pricing .care .tag{font-size:11px;letter-spacing:.08em;color:var(--teal);font-weight:700;text-transform:uppercase;margin-bottom:8px}
.pricing .care h4{font-family:var(--display);font-weight:700;font-size:17px;color:var(--navy);margin-bottom:6px;letter-spacing:-.012em}
.pricing .care p{font-size:13.5px;color:var(--text);line-height:1.55}

/* ─────────── ABOUT (dark) ─────────── */
.about{background:var(--navy);color:var(--text-on-dark);position:relative;overflow:hidden}
.about::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:64px 64px;opacity:.6;
}
.about .inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,.6fr) minmax(0,1fr);gap:clamp(28px,4vw,72px);align-items:start}
@media (max-width:960px){.about .inner{grid-template-columns:1fr}}
.about h2{color:#fff}
.about .body p{font-size:15.5px;line-height:1.7;color:var(--text-on-dark-soft);margin-bottom:16px;max-width:62ch}
.about .body p:last-child{margin-bottom:0}

/* ─────────── FINAL CTA (dark, centered) ─────────── */
.final{background:var(--navy);color:var(--text-on-dark);text-align:center;padding:var(--section-pad-y) var(--page-pad);position:relative;overflow:hidden}
.final::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:64px 64px;opacity:.6;
}
.final .inner{position:relative;z-index:1;max-width:60ch;margin:0 auto}
.final h2{font-family:var(--display);font-weight:700;color:#fff;font-size:clamp(32px,3.6vw,52px);line-height:1.06;letter-spacing:-.022em;text-wrap:balance;margin-bottom:18px;max-width:24ch;margin-left:auto;margin-right:auto}
.final p{font-size:16px;color:var(--text-on-dark-soft);max-width:54ch;margin:0 auto 28px;line-height:1.6}
.final .below{margin-top:18px;font-size:12.5px;color:var(--text-on-dark-muted)}
.final .below span{margin:0 6px}

/* ─────────── FOOTER ─────────── */
footer.legal{background:var(--slate);color:var(--text-on-dark-muted);padding:clamp(36px,4vw,64px) var(--page-pad);font-size:12.5px;line-height:1.65}
footer.legal .inner{max-width:var(--content-max);margin:0 auto}
footer.legal .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:28px}
@media (max-width:800px){footer.legal .top{grid-template-columns:1fr;gap:20px}}
footer.legal .brand-logo{margin-bottom:12px}
footer.legal .brand-logo svg{height:22px;width:auto}
footer.legal .col-desc{color:var(--text-on-dark-soft);max-width:32ch;line-height:1.55}
footer.legal a{display:block;color:var(--text-on-dark-soft);padding:3px 0}
footer.legal a:hover{color:#fff}
footer.legal .disclaim{border-top:1px solid var(--line-on-dark);padding-top:22px;font-size:11.5px;color:var(--text-on-dark-muted);line-height:1.65}

/* ─────────── V-BADGE ─────────── */
.v-badge{position:fixed;left:12px;bottom:12px;z-index:80;background:rgba(15,34,58,.92);color:var(--teal-on-dark);padding:6px 12px;border:1px solid rgba(103,164,163,.4);border-radius:6px;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;font-family:var(--mono)}

/* ─────────── PAGE HEADER (for pricing/faq) ─────────── */
.page-header{padding:clamp(72px,9vw,128px) var(--page-pad) clamp(48px,6vw,80px);background:var(--navy);color:var(--text-on-dark);position:relative;overflow:hidden;border-bottom:1px solid var(--line-on-dark)}
.page-header::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);background-size:64px 64px;opacity:.6}
.page-header .inner{position:relative;z-index:1;max-width:var(--content-max);margin:0 auto}
.page-header .label{display:inline-block;font-weight:600;font-size:12px;letter-spacing:.06em;color:var(--teal-on-dark);text-transform:uppercase;margin-bottom:18px}
.page-header h1{font-family:var(--display);font-weight:700;font-size:clamp(36px,4.6vw,64px);line-height:1.02;letter-spacing:-.025em;color:#fff;margin-bottom:16px;max-width:22ch;text-wrap:balance}
.page-header p{font-size:clamp(15px,1.15vw,18px);line-height:1.6;color:var(--text-on-dark-soft);max-width:60ch}

/* ─────────── PRICING FULL PAGE ─────────── */
.pricing-full{background:#fff}
.included{background:var(--bg-paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.included .three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2vw,28px)}
@media (max-width:880px){.included .three{grid-template-columns:1fr}}
.included .block{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 24px}
.included .block .ix{font-size:11.5px;letter-spacing:.08em;color:var(--teal);font-weight:700;text-transform:uppercase;margin-bottom:10px}
.included .block h3{font-family:var(--display);font-weight:700;font-size:18px;color:var(--navy);line-height:1.2;margin-bottom:8px;letter-spacing:-.012em}
.included .block p{font-size:14px;line-height:1.55;color:var(--text)}

.careplan{background:#fff;position:relative}
.careplan-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,400px);gap:clamp(28px,4vw,64px);align-items:start;margin-bottom:clamp(32px,3vw,52px)}
@media (max-width:960px){.careplan-row{grid-template-columns:1fr}}
.careplan-card{background:var(--navy);color:#fff;border-radius:14px;padding:30px 30px;position:relative;overflow:hidden}
.careplan-card::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);background-size:32px 32px;opacity:.6}
.careplan-card > *{position:relative}
.careplan-card .price-row{display:flex;align-items:baseline;gap:6px}
.careplan-card .price{font-family:var(--display);font-weight:700;font-size:46px;color:#fff;line-height:1;letter-spacing:-.025em}
.careplan-card .cycle{font-size:14px;color:var(--text-on-dark-soft)}
.careplan-card .price-meta{font-size:12.5px;color:var(--text-on-dark-soft);margin:6px 0 20px}
.careplan-card ul{list-style:none;margin-bottom:20px}
.careplan-card li{font-size:14px;line-height:1.55;color:var(--text-on-dark);padding:7px 0 7px 18px;position:relative}
.careplan-card li::before{content:"";position:absolute;left:0;top:15px;width:8px;height:1px;background:var(--teal-on-dark)}
.careplan-card .cta{display:inline-block;background:var(--teal-on-dark);color:var(--navy);padding:12px 22px;border-radius:8px;font-size:13.5px;font-weight:700}
.careplan-card .cta:hover{background:#fff}
.careplan-card .footnote{margin-top:14px;font-size:11.5px;color:var(--text-on-dark-soft)}

.careplan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px 28px;margin-top:clamp(24px,3vw,40px)}
@media (max-width:880px){.careplan-grid{grid-template-columns:1fr}}
.careplan-grid .block{padding:20px 0;border-top:1px solid var(--line)}
.careplan-grid .block .ix{font-size:11.5px;letter-spacing:.08em;color:var(--teal);font-weight:700;text-transform:uppercase;margin-bottom:8px}
.careplan-grid .block p{font-size:13.5px;line-height:1.55;color:var(--text)}

/* ─────────── FAQ ─────────── */
.faq-section{background:#fff}
.faq-section .group{margin-bottom:clamp(28px,3vw,44px)}
.faq-section .group h2{font-family:var(--display);font-weight:700;color:var(--navy);font-size:clamp(20px,2vw,28px);line-height:1.16;letter-spacing:-.018em;margin-bottom:6px;display:flex;align-items:center;gap:12px}
.faq-section .group h2 .icon{font-size:.85em;color:var(--teal)}
.faq-section .group .sub{font-size:13px;color:var(--text-muted);margin-bottom:14px}
.faq-section details{padding:18px 22px;border:1px solid var(--line);border-radius:10px;margin-bottom:10px;background:#fff;transition:border-color .18s,box-shadow .2s}
.faq-section details[open]{border-color:var(--teal);box-shadow:var(--shadow-soft)}
.faq-section summary{font-family:var(--display);font-weight:600;color:var(--navy);font-size:16px;line-height:1.3;letter-spacing:-.01em;cursor:pointer;list-style:none;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.faq-section summary::-webkit-details-marker{display:none}
.faq-section summary::after{content:"+";color:var(--teal);font-size:22px;line-height:1;font-weight:400;flex:0 0 auto;transition:transform .2s}
.faq-section details[open] summary::after{transform:rotate(45deg)}
.faq-section details p{margin-top:12px;color:var(--text);font-size:14.5px;line-height:1.6;margin-bottom:8px}
.faq-section details p:last-child{margin-bottom:0}
.faq-section details ul{margin:10px 0 4px 18px;color:var(--text);font-size:14.5px;line-height:1.6}
.faq-section details li{margin-bottom:4px}
