/* ============================================================================
   sections.css — SECTION COMPONENT styles. One block type = one labelled group.
   Each group is rendered by the matching function in components.js.
   Add a new component => add its CSS here + its renderer there. Reused across
   pages: same component, different content.
   ============================================================================ */

/* ═══ hero (eyebrow + headline + sub + cta + meta strip) ═══ */
.hero{padding-top:clamp(150px,20vh,230px);padding-bottom:clamp(80px,10vh,128px);background:var(--surface);color:var(--dtext);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(950px 520px at 76% 4%,rgba(43,181,199,.11),transparent 70%);pointer-events:none}
.hero .inner{position:relative;z-index:1}
.hero .eyebrow{margin-bottom:26px;display:inline-block}
.hero h1{font-size:clamp(48px,7.6vw,104px);line-height:.95;letter-spacing:-.04em;margin-bottom:30px;max-width:15ch}
.hero h1 .hl{color:var(--teal)}
.hero .sub{font-size:clamp(17px,1.7vw,22px);color:var(--dmuted);max-width:60ch;line-height:1.5;margin-bottom:38px}
.hero .sub b{color:var(--dtext);font-weight:500}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-meta{display:flex;gap:clamp(20px,4vw,56px);flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--dborder)}
.hero-meta .m{display:flex;flex-direction:column;gap:5px}
.hero-meta .m .mk{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--dmuted2)}
.hero-meta .m .mv{font-family:var(--display);font-weight:600;font-size:16px;color:var(--dtext)}
.hero-meta .m .mv .o{color:var(--orange)}

/* ═══ checklist-filter (dynamic verdict-escalation; logic in components.js) ═══ */
.fit{background:var(--white)}
.fit .eyebrow{margin-bottom:24px;display:inline-block;color:var(--lmuted2)}
.fit h2{font-size:clamp(34px,4.4vw,56px);max-width:18ch;margin-bottom:22px;line-height:1.04;font-weight:700;letter-spacing:-.025em}
.fit h2 .hl{color:var(--teal)}
.fit .lede{font-size:clamp(17px,1.5vw,20px);color:var(--lmuted);max-width:54ch;margin-bottom:clamp(48px,6vh,72px)}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(40px,5vw,80px)}
.check{display:flex;gap:16px;align-items:flex-start;padding:20px 14px;border-bottom:1px solid var(--lborder);cursor:pointer;border-radius:6px;transition:background .15s;user-select:none}
.check:hover{background:var(--light)}
.check .box{width:24px;height:24px;border:1.5px solid var(--lborder);border-radius:5px;flex-shrink:0;margin-top:1px;position:relative;transition:border-color .15s,background .15s,transform .12s}
.check .tick{font-family:var(--mono);color:var(--teal);font-size:15px;opacity:0;transition:opacity .15s;line-height:1;position:absolute;top:3px;left:4px}
.check.on{background:rgba(43,181,199,.07)}
.check.on:hover{background:rgba(43,181,199,.11)}
.check.on .box{border-color:var(--teal);background:var(--teal);transform:scale(1.05)}
.check.on .tick{opacity:1;color:#062d33}
.check .txt{font-size:16.5px;color:var(--ltext);line-height:1.5;transition:font-weight .1s}
.check.on .txt{font-weight:500}
.fit-result{margin-top:clamp(44px,5vh,68px);padding:clamp(28px,3vw,40px);background:var(--light);border-left:3px solid var(--teal);display:flex;gap:24px;align-items:center;justify-content:space-between;flex-wrap:wrap;transition:background .3s,border-color .3s}
.rt-wrap{flex:1;min-width:280px}
.fit-result .face{display:none;font-family:var(--display);font-weight:700;font-size:30px;line-height:1;margin-bottom:12px;color:var(--teal)}
.fit-result[data-state="done"] .face{display:block}
.fit-result .rt{font-family:var(--display);font-weight:600;font-size:clamp(19px,1.9vw,24px);color:var(--ltext);max-width:48ch;line-height:1.3;transition:color .3s}
.fit-result .rt .hl{color:var(--teal);transition:color .3s}
.fit-result[data-state="good"]{background:rgba(30,140,78,.08);border-left-color:var(--green)}
.fit-result[data-state="good"] .rt .hl{color:var(--green)}
.fit-result[data-state="warn"]{background:rgba(212,145,10,.08);border-left-color:var(--orange)}
.fit-result[data-state="warn"] .rt .hl{color:var(--orange)}
.fit-result[data-state="alarm"]{background:rgba(163,41,43,.08);border-left-color:var(--red)}
.fit-result[data-state="alarm"] .rt .hl{color:var(--red)}
.fit-result[data-state="done"]{background:var(--surface);border-left-color:var(--teal)}
.fit-result[data-state="done"] .rt{color:var(--dtext)}
.fit-result[data-state="done"] .rt .hl{color:var(--teal)}
.fit-result .btn{flex-shrink:0}
@media(max-width:760px){.checks{grid-template-columns:1fr}}

/* ═══ reframe-band (warm-dark turn: eyebrow + headline + body) ═══ */
.reframe{background:var(--warm-dark);color:var(--warm-text)}
.reframe .eyebrow{margin-bottom:24px;display:inline-block;color:var(--teal)}
.reframe h2{font-size:clamp(34px,4.4vw,58px);line-height:1.02;letter-spacing:-.025em;max-width:17ch;margin-bottom:26px;color:var(--warm-text)}
.reframe h2 .hl{color:var(--teal)}
.reframe p{font-size:clamp(17px,1.6vw,21px);color:var(--warm-muted);max-width:56ch;line-height:1.6;margin-bottom:18px}
.reframe p b{color:var(--warm-text);font-weight:500}

/* ═══ findings-grid (research stats; e.g. why-now band) ═══ */
.whynow{background:var(--light)}
.whynow .eyebrow{margin-bottom:24px;display:inline-block;color:var(--lmuted2)}
.whynow h2{font-size:clamp(32px,4.2vw,54px);line-height:1.04;letter-spacing:-.02em;max-width:18ch;margin-bottom:22px}
.whynow h2 .hl{color:var(--orange)}
.whynow .lede{font-size:clamp(17px,1.5vw,20px);color:var(--lmuted);max-width:52ch;margin-bottom:clamp(48px,6vh,76px)}
.findings{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--lborder);border:1px solid var(--lborder)}
.finding{background:var(--white);padding:clamp(30px,3vw,42px) clamp(28px,2.8vw,36px);display:flex;flex-direction:column;gap:10px}
.finding .fn{font-family:var(--mono);font-size:13px;letter-spacing:.12em;color:var(--lmuted2)}
.finding .big{font-family:var(--display);font-weight:600;font-size:clamp(19px,2vw,25px);line-height:1.18;letter-spacing:-.01em;color:var(--ltext)}
.finding .big .em{color:var(--orange)}
.finding .sup{font-size:15.5px;color:var(--lmuted);line-height:1.55}
.finding .src{font-family:var(--mono);font-size:11px;color:var(--lmuted2);letter-spacing:.02em;margin-top:auto;padding-top:14px;line-height:1.5}
.whynow-close{margin-top:clamp(48px,6vh,72px)}
.whynow-close p{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.4vw,32px);line-height:1.22;letter-spacing:-.015em;max-width:34ch;color:var(--ltext)}
.whynow-close .em{color:var(--teal)}
@media(max-width:760px){.findings{grid-template-columns:1fr}}

/* ═══ door-cards (light self-select; feat variant = dark card) ═══ */
.doors{background:var(--white)}
.doors .lead{margin-bottom:clamp(40px,5vh,60px)}
.doorgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.doorgrid{grid-template-columns:1fr}}
.door{background:var(--light);border:1px solid var(--lborder);border-radius:8px;padding:clamp(26px,3vw,38px);display:flex;flex-direction:column;gap:14px;transition:transform .15s,border-color .15s}
.door:hover{transform:translateY(-3px);border-color:var(--lmuted2)}
.door.door-feat{background:var(--surface);border-color:var(--surface)}
.door .d-k{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal)}
.door h3{font-family:var(--display);font-weight:700;font-size:clamp(21px,2.2vw,27px);letter-spacing:-.02em;line-height:1.08;color:var(--ltext)}
.door.door-feat h3{color:var(--dtext)}
.door p{font-size:15px;color:var(--lmuted);line-height:1.55;flex:1}
.door.door-feat p{color:var(--dmuted)}
.door .d-go{font-family:var(--body);font-weight:600;font-size:14.5px;color:var(--teal);display:inline-flex;align-items:center;gap:7px;margin-top:4px}
.door .d-go .arr{font-family:var(--mono);font-size:13px}
.door .d-free{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--green)}

/* ═══ operator / proof-quote (operator spine + single named quote) ═══ */
.operator{background:var(--light)}
.op-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,84px);align-items:center}
@media(max-width:820px){.op-grid{grid-template-columns:1fr;gap:36px}}
.op-l .eyebrow{margin-bottom:24px;display:inline-block;color:var(--lmuted2)}
.op-l h2{font-size:clamp(30px,3.6vw,46px);line-height:1.05;letter-spacing:-.025em;max-width:16ch;margin-bottom:24px}
.op-l h2 .hl{color:var(--teal)}
.op-l p{font-size:clamp(16px,1.5vw,18.5px);color:var(--lmuted);line-height:1.62;margin-bottom:18px;max-width:50ch}
.op-l p b{color:var(--ltext);font-weight:600}
.op-spine{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--lborder);margin-top:8px}
.op-spine .sp{flex:1;min-width:150px;padding:18px 0;border-bottom:1px solid var(--lborder)}
.op-spine .sp .n{font-family:var(--display);font-weight:700;font-size:clamp(22px,2.4vw,30px);color:var(--ltext);letter-spacing:-.02em;line-height:1}
.op-spine .sp .n .u{color:var(--lmuted2);font-size:.55em;font-weight:600}
.op-spine .sp .l{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--lmuted2);margin-top:6px;line-height:1.4}
.op-r{background:var(--white);border:1px solid var(--lborder);border-radius:8px;padding:clamp(30px,3.5vw,46px)}
.op-r .quote{font-family:var(--display);font-weight:500;font-size:clamp(19px,2.1vw,25px);color:var(--ltext);line-height:1.36;letter-spacing:-.015em;margin-bottom:22px}
.op-r .attr{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--lmuted2);line-height:1.6}
.op-r .more{margin-top:26px;padding-top:22px;border-top:1px solid var(--lborder);font-family:var(--body);font-weight:600;font-size:14.5px;color:var(--teal);display:inline-flex;align-items:center;gap:7px}
.op-r .more .arr{font-family:var(--mono);font-size:13px}

/* ═══ cta-close (centrifugal close; the shared footer renders below it) ═══ */
.close{background:var(--surface);color:var(--dtext);position:relative;overflow:hidden}
.close::after{content:"";position:absolute;inset:0;background:radial-gradient(800px 460px at 50% 110%,rgba(43,181,199,.10),transparent 70%);pointer-events:none}
.close .inner{position:relative;z-index:1}
.close-main{text-align:center;max-width:30ch;margin:0 auto}
.close-main .eyebrow{margin-bottom:22px;display:inline-block}
.close-main h2{font-size:clamp(36px,5vw,68px);line-height:1.0;letter-spacing:-.03em;margin-bottom:30px;color:var(--dtext)}
.close-main h2 .hl{color:var(--teal)}
.close-main p{font-size:clamp(16px,1.5vw,19px);color:var(--dmuted);line-height:1.55;margin-bottom:36px}
.close-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.close-main .eyebrow:empty{display:none}

/* ═══ hero variant: compact (offer / interior pages — no glow, no meta) ═══ */
.hero-compact{padding-top:clamp(130px,18vh,200px);padding-bottom:clamp(56px,7vh,90px)}
.hero-compact::after{display:none}
.hero-compact h1{font-size:clamp(44px,6.5vw,84px);line-height:.98;letter-spacing:-.035em;max-width:16ch;margin-bottom:28px}
.hero-compact .sub{font-size:clamp(17px,1.6vw,21px);max-width:60ch;line-height:1.55;margin-bottom:0}

/* ═══ menu-rows (offer product accordion + free-entry cards) ═══ */
.menu{background:var(--light)}
.menu .lead{max-width:62ch;margin-bottom:clamp(48px,6vh,72px)}
.menu .lead .eyebrow{margin-bottom:20px;display:inline-block;color:var(--lmuted2)}
.menu .lead h2{font-size:clamp(28px,3vw,40px);line-height:1.1;margin-bottom:18px;max-width:20ch}
.menu .lead h2 .hl{color:var(--teal)}
.menu .lead p{font-size:17px;color:var(--lmuted);line-height:1.6}
.product{background:var(--white);border:1px solid var(--lborder);margin-bottom:18px;border-radius:3px;overflow:hidden}
.product summary{list-style:none;cursor:pointer;padding:clamp(28px,3vw,40px);display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.product summary::-webkit-details-marker{display:none}
.p-head-l{display:flex;flex-direction:column;gap:10px}
.p-status{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;width:fit-content}
.p-status .dot{width:7px;height:7px;border-radius:50%}
.s-live{color:var(--green)} .s-live .dot{background:var(--green)}
.s-dev{color:var(--orange)} .s-dev .dot{background:var(--orange)}
.s-req{color:var(--teal)} .s-req .dot{background:var(--teal)}
.s-free{color:var(--teal)} .s-free .dot{background:var(--teal)}
.product h3{font-size:clamp(24px,2.6vw,34px);letter-spacing:-.02em;line-height:1.05}
.p-sub{font-size:15.5px;color:var(--lmuted);line-height:1.5;max-width:52ch}
.p-head-r{display:flex;flex-direction:column;align-items:flex-end;gap:8px;text-align:right}
.p-price{font-family:var(--display);font-weight:700;font-size:clamp(28px,3vw,40px);color:var(--orange);letter-spacing:-.02em;line-height:1;white-space:nowrap}
.p-price.p-price-muted{font-size:clamp(18px,1.8vw,22px);color:var(--lmuted);font-weight:600}
.p-price small{display:block;font-family:var(--mono);font-size:11.5px;color:var(--lmuted2);font-weight:400;letter-spacing:.04em;margin-top:7px;text-transform:none}
.p-toggle{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:var(--teal);display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.p-toggle .pl{font-size:17px;transition:transform .2s;display:inline-block}
.product[open] .p-toggle .pl{transform:rotate(45deg)}
.p-body{padding:0 clamp(28px,3vw,40px) clamp(30px,3.4vw,44px);border-top:1px solid var(--lborder)}
.p-body-inner{padding-top:clamp(26px,3vh,38px)}
.product.featured{border-color:var(--ltext)}
.product.featured summary{background:var(--white)}
.psprints{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(32px,4vw,64px);margin-bottom:30px}
.psprint{display:grid;grid-template-columns:34px 1fr auto;gap:12px;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--lborder)}
.psprint .pn{font-family:var(--mono);font-size:12px;color:var(--lmuted2)}
.psprint .pt{font-family:var(--display);font-weight:600;font-size:16px;color:var(--ltext);letter-spacing:-.01em}
.psprint .pp{font-family:var(--mono);font-size:12.5px;color:var(--orange);white-space:nowrap}
.psprint.audit .pn,.psprint.audit .pt{color:var(--teal)}
@media(max-width:680px){.psprints{grid-template-columns:1fr}}
.pnote{font-size:15px;color:var(--lmuted);line-height:1.6;max-width:60ch;margin-bottom:26px}
.pnote b{color:var(--ltext);font-weight:600}
.pcta{display:flex;gap:12px;flex-wrap:wrap}
.dev-body p{font-size:15.5px;color:var(--lmuted);line-height:1.65;max-width:60ch;margin-bottom:16px}
.dev-body p b{color:var(--ltext);font-weight:600}
.dev-includes{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 26px}
.dev-includes span{font-family:var(--mono);font-size:12px;letter-spacing:.02em;color:var(--lmuted);background:var(--light);border:1px solid var(--lborder);padding:7px 12px;border-radius:3px}
.partner-pull{background:var(--light);border-left:3px solid var(--teal);padding:20px 22px;margin-bottom:26px;font-size:15.5px;line-height:1.6;color:var(--ltext);max-width:62ch}
.partner-pull b{color:var(--teal);font-weight:600}
.plink{display:inline-block;margin-top:8px;font-family:var(--body);font-weight:600;font-size:14px;color:var(--teal)}
.plink:hover{text-decoration:underline}
.entries{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.entry{background:var(--surface);color:var(--dtext);border-radius:3px;padding:clamp(28px,3vw,40px);display:flex;flex-direction:column;gap:14px;transition:transform .15s}
.entry:hover{transform:translateY(-3px)}
.entry .p-status{margin-bottom:2px}
.entry h3{font-size:clamp(22px,2.2vw,28px);color:var(--dtext)}
.entry p{font-size:15.5px;color:var(--dmuted);line-height:1.6;flex:1}
.entry .elink{font-family:var(--body);font-weight:600;font-size:15px;color:var(--teal);display:inline-flex;align-items:center;gap:8px;margin-top:4px}
.entry .elink .arr{font-family:var(--mono);font-size:13px}
.entry.thinking{background:var(--white);color:var(--ltext);border:1px solid var(--lborder)}
.entry.thinking h3{color:var(--ltext)}
.entry.thinking p{color:var(--lmuted)}
@media(max-width:680px){.entries{grid-template-columns:1fr}}

/* ═══ triangle (Win / Keep / Hand-over arc — NOT a loop) ═══ */
.fits{background:var(--white)}
.fits .eyebrow{margin-bottom:24px;display:inline-block;color:var(--lmuted2)}
.fits h2{font-size:clamp(30px,3.4vw,46px);max-width:18ch;margin-bottom:22px;line-height:1.05}
.fits h2 .hl{color:var(--teal)}
.fits .lede{font-size:17px;color:var(--lmuted);max-width:58ch;margin-bottom:clamp(44px,5vh,64px);line-height:1.6}
.tri{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--lborder);border:1px solid var(--lborder)}
.tcol{background:var(--white);padding:clamp(26px,2.8vw,36px);display:flex;flex-direction:column;gap:12px}
.tcol .tstage{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--lmuted2)}
.tcol .tnum{font-family:var(--mono);font-size:13px;color:var(--teal)}
.tcol h4{font-family:var(--display);font-weight:600;font-size:clamp(19px,2vw,23px);color:var(--ltext);letter-spacing:-.01em;line-height:1.1}
.tcol .tjob{font-family:var(--display);font-weight:500;font-size:15px;color:var(--teal)}
.tcol p{font-size:14.5px;color:var(--lmuted);line-height:1.55}
@media(max-width:760px){.tri{grid-template-columns:1fr}}

/* ═══ partner-band (offer is its sanctioned home) ═══ */
.partners{background:var(--light2)}
.partners .eyebrow{margin-bottom:24px;display:inline-block;color:var(--lmuted2)}
.partners h2{font-size:clamp(28px,3vw,42px);max-width:20ch;margin-bottom:22px;line-height:1.06}
.partners h2 .hl{color:var(--teal)}
.partners .lede{font-size:17px;color:var(--lmuted);max-width:58ch;margin-bottom:clamp(40px,5vh,60px);line-height:1.6}
.ptiers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px)}
.ptier{display:flex;flex-direction:column;gap:10px;padding-top:22px;border-top:2px solid var(--teal)}
.ptier .pt-n{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--lmuted2)}
.ptier h4{font-family:var(--display);font-weight:600;font-size:20px;color:var(--ltext);letter-spacing:-.01em}
.ptier p{font-size:15px;color:var(--lmuted);line-height:1.6}
@media(max-width:760px){.ptiers{grid-template-columns:1fr;gap:28px}}
