/* Yorro marketing site — extends css/tokens.css (design-system tokens + .t-* classes).
   Built on the Yorro UI-kit conventions; new components added for this page. */

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--color-off-white);color:var(--color-navy-body);-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
button{font-family:var(--font-body);cursor:pointer;border:none;background:none;}
img,svg{display:block;}

.wrap{max-width:var(--max-content);margin:0 auto;padding:0 32px;}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 32px;}

/* ============ Buttons ============ */
.btn{font-size:15px;font-weight:600;padding:15px 30px;border-radius:var(--radius-btn);transition:transform var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease);display:inline-flex;align-items:center;gap:9px;line-height:1;white-space:nowrap;}
.btn .ar{transition:transform var(--dur) var(--ease);}
.btn:hover .ar{transform:translateX(3px);}
.btn-primary{background:var(--color-navy);color:#fff;}
.btn-primary:hover{background:var(--color-navy-lift);transform:translateY(-1px);}
.btn-amber{background:var(--color-amber);color:var(--color-navy);}
.btn-amber:hover{background:var(--color-amber-press);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--color-navy);border:2px solid var(--color-navy);padding:13px 28px;}
.btn-ghost:hover{background:var(--color-navy);color:#fff;}
.btn-ghost-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.35);}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.06);}
.btn-sm{padding:11px 20px;font-size:14px;}
.btn-lg{padding:18px 36px;font-size:16px;}

/* ============ Nav ============ */
.nav{position:sticky;top:0;z-index:80;background:var(--color-off-white);transition:box-shadow var(--dur) var(--ease),background var(--dur) var(--ease),border-color var(--dur) var(--ease);border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(240,239,237,.82);backdrop-filter:blur(12px);border-bottom-color:var(--color-border);}
.nav-inner{height:74px;display:flex;align-items:center;gap:32px;}
.nav-logo{height:30px;}
.nav-links{display:flex;gap:30px;margin-left:auto;margin-right:8px;}
.nav-link{font-size:15px;font-weight:500;color:var(--color-navy-body);transition:color var(--dur-fast);padding:6px 0;border-bottom:2px solid transparent;}
.nav-link:hover{color:var(--color-navy);}
.nav-link.active{color:var(--color-navy);border-bottom-color:var(--color-amber);}

/* mobile nav */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;margin-left:auto;border-radius:var(--radius-md);}
.nav-burger span{display:block;width:22px;height:2px;background:var(--color-navy);border-radius:2px;transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease);margin:0 auto;}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-drawer{display:none;}

/* language switch — deliberately set apart from the nav links, kept low-key */
.lang-switch{display:inline-flex;align-items:center;font-size:12px;font-weight:500;letter-spacing:.08em;color:var(--color-navy-muted);text-transform:uppercase;padding:7px 0 7px 18px;margin-left:16px;border-left:1px solid var(--color-border);transition:color var(--dur-fast) var(--ease);}
.lang-switch:hover{color:var(--color-navy);}
@media(max-width:980px){
  .nav-cta-desktop{display:none;}
  .lang-switch{margin-left:auto;border-left:none;padding-left:0;}
  .nav-burger{display:flex;margin-left:12px;}
  .nav-drawer{position:fixed;top:74px;left:0;right:0;bottom:0;z-index:70;background:var(--color-off-white);display:flex;flex-direction:column;gap:28px;padding:36px 28px calc(36px + env(safe-area-inset-bottom));transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);overflow-y:auto;}
  .nav-drawer.open{opacity:1;transform:none;pointer-events:auto;}
  .nav-drawer-links{display:flex;flex-direction:column;gap:4px;}
  .nav-drawer-link{font-family:var(--font-headline);font-size:26px;font-weight:700;color:var(--color-navy);padding:14px 0;border-bottom:1px solid var(--color-border);}
  .nav-drawer-link.active{color:var(--color-navy);}
  .nav-drawer .btn{align-self:flex-start;margin-top:8px;}
}

/* ============ Generic section scaffolding ============ */
.section{padding:104px 0;position:relative;}
.section.alt{background:var(--color-white);}
.section.navy{background:var(--color-navy);}
.section.tint{background:var(--color-amber-tint);}
.s-label{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-amber);margin-bottom:20px;white-space:nowrap;}
.s-label .sl{font-size:16px;font-weight:400;}
.s-label.on-navy{color:var(--color-amber);}
.s-head{font-family:var(--font-headline);font-size:var(--text-h2);font-weight:700;line-height:1.16;letter-spacing:-0.02em;color:var(--color-navy);max-width:18ch;}
.s-head.wide{max-width:24ch;}
.s-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.navy .s-head,.navy .s-intro,.navy p{color:#fff;}
.s-intro{font-size:var(--text-lead);line-height:1.6;color:var(--color-navy-body);max-width:62ch;margin-top:20px;}

/* slash inline marks */
.sl{color:var(--color-amber);font-weight:700;}
.hl-underline{box-shadow:inset 0 -0.18em 0 var(--color-amber);border-bottom:none;padding:0 .04em;}
.hl-pill{background:var(--color-amber-tint);border-radius:var(--radius-sm);padding:.02em .3em;box-decoration-break:clone;-webkit-box-decoration-break:clone;}
.navy .hl-underline{box-shadow:inset 0 -0.16em 0 var(--color-amber);}

/* headline-accent tweak (data-hl on root) */
[data-hl="pill"] .hl-underline{box-shadow:inset 0 -0.16em 0 var(--color-amber);border-bottom:none;background:var(--color-amber-tint);border-radius:var(--radius-sm);padding:.04em .3em;}
[data-hl="pill"] .navy .hl-underline,[data-hl="pill"] .cta-h .hl-underline{color:var(--color-navy);}
[data-hl="none"] .hl-underline{box-shadow:none;border-bottom:none;background:none;}

/* lift-in on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============ HERO ============ */
.hero{padding:84px 0 100px;position:relative;}
.hero .sub{font-size:var(--text-lead);line-height:1.62;color:var(--color-navy-body);max-width:60ch;}
.hero-ctas{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.hero-note{display:flex;flex-direction:column;gap:5px;font-size:14px;color:var(--color-navy-muted);line-height:1.5;max-width:42ch;}
.hero-note b{color:var(--color-navy);font-weight:600;}
.hero-note .hn-pitch{color:var(--color-amber-press);font-weight:600;}
.hero-head{font-family:var(--font-headline);font-weight:700;letter-spacing:-0.03em;color:var(--color-navy);line-height:1.1;text-wrap:balance;}
.hero-head .setup{display:block;margin-bottom:.34em;}

/* centered variant */
.hero.v-centered{text-align:center;}
.hero.v-centered .hero-head{font-size:clamp(30px,4.2vw,50px);max-width:26ch;margin:0 auto 32px;}
.hero.v-centered .hero-head .setup{max-width:28ch;margin-left:auto;margin-right:auto;}
.hero.v-centered .sub{margin:0 auto 38px;}
.hero.v-centered .hero-ctas{justify-content:center;}

/* split variant */
.hero.v-split{padding-top:100px;}
.hero.v-split .hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;}
.hero.v-split .hero-head{font-size:clamp(34px,4.2vw,52px);}

/* editorial variant */
.hero.v-editorial .hero-head{font-size:clamp(38px,4.8vw,58px);max-width:20ch;margin-bottom:40px;}
.hero.v-editorial .hero-foot{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:end;margin-top:8px;}

/* ============ CTA band (recurring) ============ */
.cta-band{position:relative;overflow:hidden;}
.cta-band .wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;}
.cta-band .cta-h{font-family:var(--font-headline);font-size:var(--text-h2);font-weight:700;letter-spacing:-0.02em;color:#fff;line-height:1.12;max-width:20ch;}
.cta-band .cta-note{display:flex;flex-direction:column;gap:4px;}
.cta-band .cta-note .line{font-size:16px;color:rgba(255,255,255,.72);}
.cta-band .cta-note .nopitch{font-size:15px;font-weight:600;color:var(--color-amber);}
.cta-band .slash-bg{position:absolute;font-family:var(--font-headline);font-weight:700;color:rgba(255,255,255,.04);font-size:520px;line-height:1;right:-30px;top:50%;transform:translateY(-50%);user-select:none;pointer-events:none;}

/* ============ Problem narrative ============ */
.lede-grid{display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:start;}
.prose p,p.prose{font-size:var(--text-body);line-height:1.75;color:var(--color-navy-body);max-width:64ch;}
.prose p+p{margin-top:22px;}
.prose p b,.prose strong,p.prose b{color:var(--color-navy);font-weight:600;}
.side-illo{position:sticky;top:120px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-card);}
.section.alt .side-illo{background:var(--color-off-white);}
.side-illo svg{width:100%;height:auto;}
.side-illo .cap{font-size:13px;color:var(--color-navy-muted);margin-top:14px;line-height:1.5;text-align:center;}

/* pivot statement (eerst je business...) */
.pivot{display:flex;flex-direction:column;align-items:flex-start;gap:0;}
.pivot .big{font-family:var(--font-headline);font-size:var(--text-h1);font-weight:700;line-height:1.12;letter-spacing:-0.025em;color:var(--color-navy);max-width:16ch;}
.navy .pivot .big{color:#fff;}

/* ============ 95% fail / big stat ============ */
.stat-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:64px;align-items:center;}
.stat-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:44px 40px;box-shadow:var(--shadow-card);text-align:center;}
.section.alt .stat-card{background:var(--color-off-white);}
.stat-card .num{font-family:var(--font-headline);font-size:120px;font-weight:700;line-height:.9;letter-spacing:-0.04em;color:var(--color-navy);}
.stat-card .num span{color:var(--color-amber);}
.stat-card .num small{font-size:46px;}
.stat-card .stat-sub{font-size:15px;color:var(--color-navy-body);line-height:1.55;margin-top:18px;max-width:30ch;margin-left:auto;margin-right:auto;}
.stat-card .stat-src{display:block;margin-top:10px;color:var(--color-navy-muted);}
.stat-card .funnel{width:150px;margin:0 auto 12px;}
.stat-card .funnel svg{width:100%;height:auto;}

/* reason list */
.reasons{list-style:none;display:flex;flex-direction:column;gap:16px;margin-top:8px;}
.reasons li{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px 24px;box-shadow:var(--shadow-card);}
.section.alt .reasons li{background:var(--color-off-white);}
.reasons li .rn{font-family:var(--font-headline);font-weight:700;color:var(--color-amber);font-size:18px;line-height:1.4;white-space:nowrap;}
.reasons li p{font-size:16px;line-height:1.55;color:var(--color-navy-body);}

/* ============ Outcomes matrix (2x2) ============ */
.matrix-grid{margin-top:48px;display:grid;grid-template-columns:128px 1fr 1fr;gap:14px;align-items:stretch;}
.mcorner{}
.matrix-colhead{display:flex;align-items:flex-end;justify-content:center;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-navy-muted);text-align:center;padding-bottom:8px;}
.matrix-rowhead{display:flex;align-items:center;justify-content:flex-end;text-align:right;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-navy-muted);padding-right:4px;line-height:1.4;}
.mcell{border-radius:var(--radius-lg);padding:28px;min-height:170px;display:flex;flex-direction:column;gap:10px;justify-content:flex-end;border:1px solid var(--color-border);transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.mcell:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);}
.mcell .mtag{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:7px;}
.mcell .mbody{font-size:16px;line-height:1.5;}
/* wrong-wrong: muted grey */
.mcell.wrong{background:var(--color-off-white);border-color:var(--color-border);}
.section.alt .mcell.wrong{background:#EBEAE6;}
.mcell.wrong .mtag{color:var(--color-navy-muted);}
.mcell.wrong .mbody{color:var(--color-navy-muted);}
/* near-miss: amber */
.mcell.near{background:var(--color-amber-tint);border-color:#F1DFB4;}
.mcell.near .mtag{color:var(--color-amber-press);}
.mcell.near .mtag .dot{width:8px;height:8px;border-radius:50%;background:var(--color-amber);}
.mcell.near .mbody{color:var(--color-navy-body);}
/* winner: solid navy */
.mcell.win{background:var(--color-navy);border-color:var(--color-navy);box-shadow:var(--shadow-card);position:relative;overflow:hidden;}
.mcell.win .mtag{color:var(--color-amber);}
.mcell.win .mwin-name{font-family:var(--font-headline);font-size:22px;font-weight:700;color:#fff;line-height:1.2;}
.mcell.win .mbody{color:rgba(255,255,255,.82);}
.mcell.win .mcheck{position:absolute;top:20px;right:20px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--color-amber);}
.mcell.win .mcheck i{width:17px;height:17px;}

/* numbered outcome label — only shown on mobile when headers are hidden */
.mcell .mlabel{display:none;flex-direction:column;gap:9px;}
.mcell .mnum{font-family:var(--font-headline);font-weight:700;font-size:13px;letter-spacing:.14em;color:var(--color-amber);}
.mcell .mlabel-t{font-family:var(--font-headline);font-weight:700;font-size:20px;line-height:1.25;color:var(--color-navy);letter-spacing:-0.01em;}
.mcell.win .mlabel-t{color:#fff;}
.mcell.near .mnum{color:var(--color-amber-press);}
.mcell .meq{color:var(--color-amber);}
.mcell .mtag .mtag-check{display:none;align-items:center;justify-content:center;}
.mcell .mtag .mtag-check i{width:14px;height:14px;}

.matrix-foot{font-size:16px;line-height:1.6;color:var(--color-navy-body);max-width:62ch;margin-top:30px;}
.matrix-foot b{color:var(--color-navy);font-weight:600;}

/* ============ IMPACT method — shared ============ */
.method-intro-grid{display:grid;grid-template-columns:1fr 380px;gap:64px;align-items:center;margin-top:8px;}
.method-intro-grid .doc-illo{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-card);}
.section.alt .method-intro-grid .doc-illo{background:var(--color-off-white);}
.method-intro-grid .doc-illo svg{width:100%;height:auto;}
.audit-pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-navy);background:var(--color-amber-tint);border:1px solid #F1DFB4;border-radius:999px;padding:7px 16px;margin-top:8px;}
.audit-pill .sl{color:var(--color-amber);}

.impact-stage{margin-top:8px;}

/* letters rail (shared by variants where shown) */
.letrail{display:flex;gap:8px;}
.letrail .let{width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-family:var(--font-headline);font-weight:700;font-size:16px;color:var(--color-navy-muted);background:var(--color-white);transition:all var(--dur) var(--ease);}
.letrail .let.done{color:var(--color-navy);}
.letrail .let.active{background:var(--color-navy);color:#fff;border-color:var(--color-navy);transform:translateY(-2px);}
.letrail .let.opt{border-style:dashed;}

/* ---- Variant SPINE ---- */
.imp-spine{position:relative;margin-top:56px;padding-left:0;}
.imp-spine .rail{position:absolute;left:31px;top:30px;bottom:30px;width:2px;background:var(--color-border);}
.imp-spine .rail .fill{position:absolute;left:0;top:0;width:100%;background:var(--color-amber);height:0;transition:height .15s linear;}
.spine-step{position:relative;display:grid;grid-template-columns:64px 1fr;gap:28px;padding:22px 0;}
.spine-step .node{width:64px;height:64px;border-radius:50%;background:var(--color-white);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-family:var(--font-headline);font-weight:700;font-size:24px;color:var(--color-navy-muted);z-index:2;transition:all var(--dur-slow) var(--ease);}
.section.alt .spine-step .node{background:var(--color-off-white);}
.spine-step.on .node{background:var(--color-navy);color:#fff;border-color:var(--color-navy);box-shadow:0 0 0 6px var(--color-amber-tint);}
.spine-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:28px 32px;display:grid;grid-template-columns:1fr 150px;gap:28px;align-items:center;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);}
.section.alt .spine-card{background:var(--color-off-white);}
.spine-step.on .spine-card{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:#EFD8A8;}
.spine-card .sc-name{font-family:var(--font-headline);font-size:22px;font-weight:700;color:var(--color-navy);margin-bottom:8px;display:flex;align-items:center;gap:10px;}
.spine-card .sc-let{color:var(--color-amber);}
.spine-card p{font-size:15px;line-height:1.6;color:var(--color-navy-body);}
.spine-card .sc-art{width:150px;}
.spine-card .sc-art svg{width:100%;height:auto;}
.optflag{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-navy-muted);border:1px dashed var(--color-border);border-radius:999px;padding:3px 10px;}
.phase-divider{display:flex;align-items:center;gap:16px;margin:34px 0 10px 92px;}
.phase-divider .pd-label{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-navy-muted);white-space:nowrap;}
.phase-divider .pd-line{flex:1;height:1px;background:var(--color-border);}

/* ---- Variant STICKY ---- */
.imp-sticky{display:grid;grid-template-columns:0.92fr 1.08fr;gap:64px;margin-top:48px;align-items:start;}
.sticky-visual{position:sticky;top:108px;align-self:start;}
.sticky-stage{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:40px;aspect-ratio:1/.84;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.section.alt .sticky-stage{background:var(--color-off-white);}
.sticky-stage .sv-art{position:absolute;inset:40px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s var(--ease);}
.sticky-stage .sv-art svg{width:100%;height:100%;}
.sticky-stage .sv-art.show{opacity:1;}
.sticky-letrail{margin-top:24px;justify-content:space-between;}
.sticky-steps{display:flex;flex-direction:column;}
.sticky-step{padding:54px 0;border-top:1px solid var(--color-border);opacity:.4;transition:opacity var(--dur-slow) var(--ease);}
.sticky-step:first-child{border-top:none;}
.sticky-step.on{opacity:1;}
.sticky-step .ss-let{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.sticky-step .ss-l{width:36px;height:36px;border-radius:10px;background:var(--color-amber);color:var(--color-navy);font-family:var(--font-headline);font-weight:700;font-size:19px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
.sticky-step h4{font-family:var(--font-headline);font-size:28px;font-weight:700;color:var(--color-navy);margin-bottom:14px;letter-spacing:-0.01em;}
.sticky-step p{font-size:16px;line-height:1.7;color:var(--color-navy-body);max-width:46ch;}

/* ---- Variant STACK ---- */
.imp-stack{margin-top:48px;padding-bottom:8vh;}
.stack-step{position:sticky;margin-bottom:42px;}
.stack-step:last-child{margin-bottom:0;}
.stack-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 -2px 40px var(--color-shadow);padding:40px 44px;display:grid;grid-template-columns:1fr 200px;gap:40px;align-items:center;min-height:236px;}
.section.alt .stack-card{background:var(--color-off-white);}
.stack-card .stk-let{font-family:var(--font-headline);font-size:64px;font-weight:700;color:var(--color-amber);line-height:.9;}
.stack-card .stk-head{display:flex;align-items:baseline;gap:18px;margin-bottom:14px;flex-wrap:wrap;}
.stack-card h4{font-family:var(--font-headline);font-size:30px;font-weight:700;color:var(--color-navy);letter-spacing:-0.01em;}
.stack-card p{font-size:16px;line-height:1.7;color:var(--color-navy-body);max-width:52ch;}
.stack-card .stk-art{width:200px;}
.stack-card .stk-art svg{width:100%;height:auto;}

/* ============ About / Joris ============ */
.about-grid{display:grid;grid-template-columns:0.82fr 1.18fr;gap:64px;align-items:start;}
.about-photo{position:sticky;top:108px;}
.about-photo-frame{position:relative;display:block;}
.about-photo image-slot{border:1px solid var(--color-border);box-shadow:var(--shadow-card);border-radius:var(--radius-lg);display:block;width:100%;height:auto;aspect-ratio:2/3;}
.about-badge{position:absolute;left:18px;bottom:18px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:var(--color-navy);color:#fff;font-size:13px;font-weight:600;padding:9px 15px;border-radius:var(--radius-sm);}
.about-badge .sl{color:var(--color-amber);}
.founder-prose p{font-size:17px;line-height:1.78;color:var(--color-navy-body);max-width:60ch;}
.founder-prose p+p{margin-top:20px;}
.founder-prose .first::first-letter{font-family:var(--font-headline);font-size:64px;font-weight:700;float:left;line-height:.82;padding:6px 14px 0 0;color:var(--color-navy);}
.pullquote{font-family:var(--font-headline);font-size:28px;font-weight:700;line-height:1.3;letter-spacing:-0.01em;color:var(--color-navy);border-left:4px solid var(--color-amber);padding:6px 0 6px 26px;margin:34px 0;max-width:24ch;}

/* ============ Expectations ============ */
.expect-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:48px;}
.exp-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-card);display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.section.alt .exp-card{background:var(--color-off-white);}
.exp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);}
.exp-card .exp-ic{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-amber-tint);color:var(--color-navy);display:flex;align-items:center;justify-content:center;}
.exp-card .exp-ic i{width:20px;height:20px;}
.exp-card p{font-size:16px;line-height:1.55;color:var(--color-navy-body);}
.exp-card p b{color:var(--color-navy);font-weight:600;}
.exp-card.wide,.section.alt .exp-card.wide{grid-column:1/-1;background:var(--color-navy);border-color:var(--color-navy);}
.exp-card.wide .exp-ic{background:rgba(255,255,255,.08);color:var(--color-amber);}
.exp-card.wide p{color:rgba(255,255,255,.82);}
.exp-card.wide p b{color:#fff;}

/* ============ For whom ============ */
.fit-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;}
.fit-col{border-radius:var(--radius-lg);padding:36px;border:1px solid var(--color-border);}
.fit-col.yes{background:var(--color-white);}
.section.alt .fit-col.yes{background:var(--color-off-white);}
.fit-col.no{background:transparent;border-style:dashed;}
.fit-col h3{font-family:var(--font-headline);font-size:22px;font-weight:700;color:var(--color-navy);margin-bottom:24px;}
.fit-list{list-style:none;display:flex;flex-direction:column;gap:18px;}
.fit-list li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;font-size:16px;line-height:1.5;color:var(--color-navy-body);}
.fit-mark{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.fit-mark i{width:15px;height:15px;}
.fit-col.yes .fit-mark{background:var(--color-navy);color:var(--color-amber);}
.fit-col.no .fit-mark{background:#EBEAE6;color:var(--color-navy-muted);}
.fit-col.no .fit-list li{color:var(--color-navy-muted);}

/* ============ FAQ ============ */
.faq-list{margin-top:44px;max-width:820px;border-top:1px solid var(--color-border);}
.faq-item{border-bottom:1px solid var(--color-border);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 4px;text-align:left;font-family:var(--font-headline);font-size:20px;font-weight:700;color:var(--color-navy);transition:color var(--dur-fast);}
.faq-q>span:first-child{flex:1;}
.faq-q:hover{color:var(--color-navy-lift);}
.faq-tog{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-navy-muted);transition:all var(--dur) var(--ease);}
.faq-tog i{width:16px;height:16px;}
.faq-item.open .faq-tog{transform:rotate(45deg);background:var(--color-navy);color:var(--color-amber);border-color:var(--color-navy);}
.faq-a{max-height:0;overflow:hidden;transition:max-height var(--dur-slow) var(--ease);}
.faq-a-inner{padding:0 4px 28px;font-size:16px;line-height:1.7;color:var(--color-navy-body);max-width:68ch;}
.faq-a-inner p+p{margin-top:14px;}
.faq-a-inner b{color:var(--color-navy);font-weight:600;}
.faq-price{font-family:var(--font-headline);color:var(--color-navy);font-weight:700;}

/* ============ Footer ============ */
.footer{background:var(--color-navy);padding:64px 0 40px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer-logo{height:30px;margin-bottom:18px;}
.footer-tag{font-size:15px;line-height:1.6;color:rgba(255,255,255,.6);max-width:34ch;}
.footer-col h5{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-amber);margin-bottom:16px;}
.footer-col a,.footer-col .fi{display:block;font-size:15px;color:rgba(255,255,255,.72);margin-bottom:11px;transition:color var(--dur-fast);}
.footer-col a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:28px;flex-wrap:wrap;}
.footer-bottom .meta{font-size:13px;color:var(--color-navy-muted);}
.footer-legal{display:flex;gap:22px;}
.footer-legal a{font-size:13px;color:var(--color-navy-muted);transition:color var(--dur-fast) var(--ease);}
.footer-legal a:hover{color:#fff;}

/* ============ Legal pages ============ */
.legal-page{background:var(--color-off-white);min-height:100vh;display:flex;flex-direction:column;}
.legal-nav{height:74px;border-bottom:1px solid var(--color-border);}
.legal-nav .wrap{display:flex;align-items:center;height:100%;gap:24px;}
.legal-nav .nav-logo{height:30px;}
.legal-back{margin-left:auto;display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-navy-muted);transition:color var(--dur-fast) var(--ease);}
.legal-back:hover{color:var(--color-navy);}
.legal-back i{width:16px;height:16px;}
.legal-main{flex:1;padding:80px 0 104px;}
.legal-head{max-width:760px;margin:0 auto 48px;padding:0 32px;}
.legal-head .s-label{margin-bottom:18px;}
.legal-head h1{font-family:var(--font-headline);font-size:clamp(36px,5vw,52px);font-weight:700;letter-spacing:-0.025em;line-height:1.1;color:var(--color-navy);}
.legal-head .updated{margin-top:18px;font-size:14px;color:var(--color-navy-muted);}
.legal-body{max-width:760px;margin:0 auto;padding:0 32px;}
.legal-body h2{font-family:var(--font-headline);font-size:24px;font-weight:700;letter-spacing:-0.01em;color:var(--color-navy);margin:44px 0 14px;}
.legal-body h3{font-family:var(--font-headline);font-size:18px;font-weight:700;color:var(--color-navy);margin:28px 0 10px;}
.legal-body p{font-size:16px;line-height:1.75;color:var(--color-navy-body);margin-bottom:16px;}
.legal-body ul{margin:0 0 18px;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px;}
.legal-body ul li{position:relative;padding-left:26px;font-size:16px;line-height:1.7;color:var(--color-navy-body);}
.legal-body ul li::before{content:"/";position:absolute;left:4px;top:0;color:var(--color-amber);font-weight:700;font-family:var(--font-headline);}
.legal-body a{color:var(--color-navy);font-weight:600;box-shadow:inset 0 -0.12em 0 var(--color-amber);}
.legal-body strong{color:var(--color-navy);font-weight:600;}
.legal-body .legal-callout{background:var(--color-amber-tint);border:1px solid #F1DFB4;border-radius:var(--radius-lg);padding:24px 28px;margin:28px 0;}
.legal-body .legal-callout p:last-child{margin-bottom:0;}
.legal-body table{width:100%;border-collapse:collapse;margin:18px 0 24px;font-size:15px;}
.legal-body table th,.legal-body table td{text-align:left;padding:12px 14px;border:1px solid var(--color-border);vertical-align:top;line-height:1.55;}
.legal-body table th{background:var(--color-white);font-family:var(--font-headline);font-weight:700;color:var(--color-navy);font-size:14px;}
.legal-body table td{color:var(--color-navy-body);}
@media(max-width:560px){
  .legal-main{padding:56px 0 72px;}
  .legal-body table{display:block;overflow-x:auto;white-space:nowrap;}
}

/* ============ Responsive ============ */
.ss-illo{display:none;}
@media(max-width:980px){
  .nav-links{display:none;}
  .hero{padding-top:75px;}
  .hero.v-split .hero-grid{grid-template-columns:1fr;gap:36px;}
  .hero.v-editorial .hero-foot{grid-template-columns:1fr;gap:28px;}
  .s-head{font-size:30px;}
  .lede-grid,.stat-grid,.method-intro-grid,.about-grid{grid-template-columns:1fr;gap:40px;}
  .side-illo,.about-photo{position:static;}

  /* IMPACT sticky -> stacked self-contained cards on mobile */
  .imp-sticky{display:block;margin-top:8px;}
  .sticky-visual{display:none;}
  .sticky-steps{gap:20px;}
  .sticky-step{opacity:1;padding:0;border-top:none;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:28px 24px;}
  .section.alt .sticky-step{background:var(--color-off-white);}
  .sticky-step h4{font-size:24px;margin-bottom:18px;}
  .ss-illo{display:block;width:100%;max-width:260px;margin:0 auto 20px;}
  .ss-illo img{width:100%;height:auto;}
  .sticky-step p{max-width:none;}

  .expect-grid,.fit-grid{grid-template-columns:1fr;}

  /* Matrix -> stacking deck (DOM order already = visual order 1..4) */
  .matrix-grid{display:flex;flex-direction:column;gap:0;padding-bottom:0;}
  .matrix-colhead,.matrix-rowhead,.mcorner{display:none;}
  .mcell{min-height:0;z-index:var(--m-order,0);position:sticky;top:calc(82px + var(--m-order,1)*10px);margin-bottom:16px;justify-content:flex-start;box-shadow:0 -6px 30px rgba(28,35,64,.15);}
  .mcell:hover{transform:none;}
  .mcell .mlabel{display:flex;}
  .matrix-section .matrix-grid.center .mcell{align-items:flex-start;text-align:left;justify-content:flex-start;}
  .matrix-section .matrix-grid.center .mcell .mtag{justify-content:flex-start;}
  /* the winning (last) card does NOT pin — it slides over the stack so the
     paragraph below it is never covered */
  .mcell.win{position:relative;top:auto;margin-bottom:0;overflow:visible;}
  .mcell.win .mcheck{display:none;}
  .mcell.win .mwin-name{display:none;}
  .mcell.win .mtag .sl{display:none;}
  .mcell.win .mtag .mtag-check{display:inline-flex;}
  .matrix-section .matrix-foot{position:relative;z-index:10;background:var(--color-off-white);margin-top:0;padding-top:22px;}

  .spine-card{grid-template-columns:1fr;gap:18px;}
  .spine-card .sc-art{width:120px;}
  .stack-card{grid-template-columns:1fr;gap:24px;}
  .stack-card .stk-art{display:none;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
}
@media(max-width:560px){
  .wrap,.wrap-narrow{padding-left:20px;padding-right:20px;}
  .hero.v-centered .hero-head{font-size:clamp(30px,8vw,40px);}
  .stat-card .num{font-size:88px;}
  .section{padding:72px 0;}
}

/* ============ Layout options (Tweaks) ============ */
/* Matrix — centered text */
.matrix-grid.center .mcell{align-items:center;text-align:center;justify-content:center;}
.matrix-grid.center .mcell .mtag{justify-content:center;}

/* Expect — single centered column */
.expect-grid.single{grid-template-columns:1fr;max-width:660px;margin-left:auto;margin-right:auto;}
.expect-grid.single .exp-card{grid-template-columns:1fr;justify-items:center;text-align:center;gap:16px;}
.expect-grid.single .exp-card .exp-ic{margin:0 auto;}
.expect-grid.single .exp-card.wide{justify-items:center;text-align:center;}
.expect-grid.single .exp-card p{max-width:52ch;}

/* FAQ — centered alignment */
.faq-center .s-label{display:flex;justify-content:center;}
.faq-center .s-head{text-align:center;margin-left:auto;margin-right:auto;}
.faq-center .faq-list{margin-left:auto;margin-right:auto;}

/* Matrix — whole section centered */
.matrix-section.centered .s-label{display:flex;justify-content:center;}
.matrix-section.centered .s-head{margin-left:auto;margin-right:auto;text-align:center;}
.matrix-section.centered .s-intro{margin-left:auto;margin-right:auto;text-align:center;}
.matrix-section.centered .matrix-foot{margin-left:auto;margin-right:auto;text-align:center;}

/* Expect — stacking cards */
.exp-stack{margin-top:48px;padding-bottom:8vh;max-width:860px;margin-left:auto;margin-right:auto;}
.exp-stack-step{position:sticky;margin-bottom:38px;}
.exp-stack-step:last-child{margin-bottom:0;}
.exp-stack-card{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;background:var(--color-off-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 -2px 40px var(--color-shadow);padding:34px 38px;min-height:148px;}
.exp-stack-card .exp-ic{width:54px;height:54px;border-radius:var(--radius-md);background:var(--color-amber-tint);color:var(--color-navy);display:flex;align-items:center;justify-content:center;}
.exp-stack-card .exp-ic i{width:25px;height:25px;}
.exp-stack-card p{font-size:18px;line-height:1.6;color:var(--color-navy-body);}
.exp-stack-card p b{color:var(--color-navy);font-weight:600;}
.exp-stack-card.wide{background:var(--color-navy);border-color:var(--color-navy);}
.exp-stack-card.wide .exp-ic{background:rgba(255,255,255,.08);color:var(--color-amber);}
.exp-stack-card.wide p{color:rgba(255,255,255,.84);}
.exp-stack-card.wide p b{color:#fff;}
@media(max-width:980px){
  .exp-stack-card{grid-template-columns:1fr;gap:16px;}
}
