/* ═══════════════════════════════════════════════════════════
   Pegify · How It Works — Page-specific styles
   ═══════════════════════════════════════════════════════════ */

/* ─── Hero ─── */
.hero{position:relative;padding:148px 32px 80px;overflow:hidden}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(26,26,26,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(26,26,26,.05) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 80%);pointer-events:none}
.hero-inner{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;position:relative}
.hero-eye{display:inline-flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--green);margin-bottom:32px}
.hero-eye::before{content:"";width:22px;height:2px;background:var(--green)}
.hero h1{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(54px,7.4vw,128px);line-height:.9;letter-spacing:-0.045em;margin:0;text-transform:uppercase;text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--orange)}
.hero h1 u{text-decoration:none;background:var(--mint);padding:0 .14em;border-radius:8px;display:inline-block;transform:rotate(-1deg)}
.hero-sub{margin-top:28px;max-width:520px;font-size:18px;color:var(--muted);line-height:1.55}
.hero-cta-row{margin-top:36px;display:flex;gap:12px;align-items:center}
.btn-hero{padding:18px 28px;border-radius:999px;background:var(--ink);color:var(--sheet);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:14px;box-shadow:0 18px 36px rgba(20,20,20,.22);transition:background .25s,box-shadow .25s}
.btn-hero:hover{background:var(--orange);box-shadow:0 22px 44px rgba(255,125,47,.32)}
.btn-hero i{font-size:18px}
.btn-hero-ghost{padding:18px 26px;border-radius:999px;border:1.5px solid var(--ink);color:var(--ink);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;transition:all .25s}
.btn-hero-ghost:hover{background:var(--ink);color:var(--sheet)}

/* ─── Loop diagram ─── */
.loop-wrap{position:relative;aspect-ratio:1/1;max-width:640px;margin-left:auto;width:100%}
.loop-svg{width:100%;height:100%;position:relative;z-index:2}
.loop-svg .ring-bg{fill:none;stroke:var(--line);stroke-width:1.5;stroke-dasharray:4 8}
.loop-svg .ring-fg{fill:none;stroke:var(--orange);stroke-width:2.5;stroke-linecap:round}
.loop-svg .stage{cursor:pointer}
.loop-svg .stage circle{fill:var(--sheet);stroke:var(--ink);stroke-width:1.5;transition:fill .25s,r .35s cubic-bezier(.2,.8,.2,1)}
.loop-svg .stage:hover circle,.loop-svg .stage.active circle{fill:var(--ink)}
.loop-svg .stage:hover text,.loop-svg .stage.active text{fill:var(--paper)}
.loop-svg .stage text{fill:var(--ink);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;text-anchor:middle;transition:fill .25s}
.loop-svg .stage .ico{font-family:"Phosphor",sans-serif;fill:var(--orange);font-size:18px;text-anchor:middle}
.loop-svg .stage:hover .ico,.loop-svg .stage.active .ico{fill:var(--mint)}
.loop-svg .arrow{fill:var(--orange)}
.loop-svg .center text{font-family:'Space Grotesk',sans-serif;font-weight:700;text-anchor:middle;fill:var(--ink)}
.loop-svg .center .big{font-size:32px;letter-spacing:-0.04em}
.loop-svg .center .small{font-size:10px;letter-spacing:.24em;fill:var(--muted)}
.loop-spin{position:absolute;inset:6%;border:1px dashed rgba(26,26,26,.18);border-radius:999px;animation:spin 60s linear infinite;pointer-events:none}
.loop-spin.two{inset:14%;animation-duration:90s;animation-direction:reverse;border-color:rgba(35,71,43,.2)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── Stat strip ─── */
.stat-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--sheet);padding:32px 32px}
.stat-strip-inner{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat-strip .item{display:flex;flex-direction:column;gap:4px;padding-left:18px;border-left:2px solid var(--ink)}
.stat-strip .item:nth-child(2){border-color:var(--orange)}
.stat-strip .item:nth-child(3){border-color:var(--green)}
.stat-strip .item:nth-child(4){border-color:var(--muted)}
.stat-strip .v{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:36px;letter-spacing:-0.035em;line-height:1}
.stat-strip .l{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ─── Stage blocks ─── */
.stage-block{padding:160px 32px;position:relative;overflow:hidden}
.stage-inner{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.stage-block.alt .stage-inner{grid-template-columns:1fr 1fr;direction:rtl}
.stage-block.alt .stage-inner > *{direction:ltr}
.stage-eye{display:flex;align-items:center;gap:12px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--green)}
.stage-eye .num{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;border:1px solid var(--line);color:var(--ink);font-family:'JetBrains Mono',monospace;font-weight:500;font-size:11px;letter-spacing:.06em}
.stage-eye .name{color:var(--orange);font-weight:700}
.stage-block h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(48px,6vw,108px);line-height:.92;letter-spacing:-0.045em;margin:24px 0 24px;text-transform:uppercase;text-wrap:balance}
.stage-block h2 em{font-style:normal;color:var(--orange)}
.stage-block h2 u{text-decoration:none;background:var(--mint);padding:0 .14em;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
.stage-block .lede{font-size:18px;line-height:1.55;color:var(--ink-2);max-width:520px}
.stage-block .bullets{margin-top:28px;display:grid;gap:10px}
.stage-block .bullets .b{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--ink-2)}
.stage-block .bullets .b i{color:var(--orange);font-size:18px;flex-shrink:0;margin-top:1px}
.stage-block .bullets .b b{color:var(--ink);font-weight:700;display:block;font-family:'Space Grotesk',sans-serif;font-size:14px;letter-spacing:-0.005em}
.stage-block.alt{background:var(--sheet);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ─── Visual mock containers ─── */
.visual{position:relative;background:var(--sheet);border:1px solid var(--line);border-radius:24px;padding:28px;box-shadow:0 28px 60px rgba(20,20,20,.08);transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.visual::before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(50% 100% at 50% 0%,var(--orange),transparent 60%);opacity:.07;pointer-events:none}

/* Brief mock */
.brief-mock{display:flex;flex-direction:column;gap:14px}
.brief-mock .top{display:flex;align-items:center;justify-content:space-between;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.brief-mock .top .live{display:inline-flex;align-items:center;gap:6px;color:var(--green)}
.brief-mock .top .live .dot{width:7px;height:7px;border-radius:999px;background:var(--green);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.brief-mock .title-input{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:32px;letter-spacing:-0.025em;line-height:1.05;color:var(--ink);border-bottom:2px solid var(--ink);padding-bottom:10px}
.brief-mock .title-input .caret{display:inline-block;width:3px;height:30px;background:var(--orange);margin-left:4px;vertical-align:-6px;animation:blink 1.2s steps(2,end) infinite}
@keyframes blink{50%{opacity:0}}
.brief-mock .fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.brief-mock .field{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.brief-mock .field .l{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.brief-mock .field .v{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;margin-top:4px;letter-spacing:-0.015em}
.brief-mock .field .v.g{color:var(--green)}
.brief-mock .field .v.o{color:var(--orange)}
.brief-mock .criteria{background:var(--paper);border:1px dashed var(--line);border-radius:14px;padding:14px;display:grid;gap:6px}
.brief-mock .criteria .h{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.brief-mock .criteria .row{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-2)}
.brief-mock .criteria .row i{color:var(--green);font-size:14px}

/* ─── Plan: routing matrix ─── */
.routing{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:14px}
.routing .top{display:flex;justify-content:space-between;align-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.routing .top b{color:var(--ink)}
.routing .matrix{display:grid;grid-template-columns:160px repeat(4,1fr);gap:6px}
.routing .head{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:6px 8px;text-align:center}
.routing .label{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;color:var(--ink);padding:14px 12px;background:var(--sheet);border-radius:10px;display:flex;align-items:center;gap:10px}
.routing .label i{color:var(--muted);font-size:16px}
.routing .cell{border-radius:10px;background:var(--sheet);border:1px solid var(--line);height:56px;display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;transition:all .3s}
.routing .cell.on{background:var(--ink);color:var(--mint);border-color:var(--ink)}
.routing .cell.on::before{content:"\25CF";margin-right:4px;color:var(--mint)}
.routing .cell.try{background:var(--mint);color:var(--green);border-color:var(--mint)}
.routing .footer{display:flex;justify-content:space-between;align-items:center;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);padding-top:6px}
.routing .footer b{color:var(--green);font-weight:600}

/* ─── Run: memory graph ─── */
.memory-graph{background:var(--ink);color:var(--sheet);border-radius:24px;padding:28px;position:relative;overflow:hidden;aspect-ratio:1/0.85}
.memory-graph .gtop{display:flex;justify-content:space-between;align-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.memory-graph .gtop b{color:var(--mint);font-weight:700}
.memory-graph .gtop .live{display:inline-flex;align-items:center;gap:6px}
.memory-graph .gtop .live .dot{width:7px;height:7px;border-radius:999px;background:var(--orange);animation:pulse 1.6s infinite}
.memory-graph svg{width:100%;height:100%;position:absolute;inset:0;padding:60px 28px 28px}
.mg-node{cursor:none}
.mg-node circle{fill:var(--sheet);stroke:var(--orange);stroke-width:2;transition:fill .25s,stroke .25s,r .35s cubic-bezier(.2,.8,.2,1)}
.mg-node:hover circle{fill:var(--orange);r:14}
.mg-node text{fill:var(--paper);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:10px;text-anchor:middle;letter-spacing:.04em;text-transform:uppercase}
.mg-edge{stroke:rgba(255,255,255,.3);stroke-width:1.4;stroke-dasharray:4 4;fill:none}
.mg-edge.flow{stroke:var(--orange);stroke-dasharray:none;stroke-width:2;animation:dashFlow 1.2s linear infinite;stroke-dasharray:6 6}
@keyframes dashFlow{to{stroke-dashoffset:-12}}
.mg-pegi{font-size:13px;fill:var(--mint);font-weight:600}

/* ─── Verify: criteria list ─── */
.verify-mock{background:var(--sheet);border:1px solid var(--line);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:14px}
.verify-mock .vh{display:flex;justify-content:space-between;align-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.verify-mock .vh .res{color:var(--green);font-weight:700}
.verify-mock .verdict{background:var(--mint);color:var(--green);border-radius:14px;padding:18px 20px;display:flex;align-items:center;gap:14px}
.verify-mock .verdict .ico{width:42px;height:42px;border-radius:999px;background:var(--green);color:var(--mint);display:grid;place-items:center;font-size:22px}
.verify-mock .verdict b{display:block;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:18px;letter-spacing:-0.02em}
.verify-mock .verdict span{display:block;font-size:12px;opacity:.75;margin-top:2px}
.verify-mock .row{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:12px 14px;background:var(--paper);border:1px solid var(--line);border-radius:12px}
.verify-mock .row .chk{width:24px;height:24px;border-radius:6px;background:var(--mint);color:var(--green);display:grid;place-items:center;font-size:14px}
.verify-mock .row.fail .chk{background:#ffd9b8;color:#8a3a0a}
.verify-mock .row b{display:block;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;letter-spacing:-0.01em}
.verify-mock .row span{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);margin-top:2px}
.verify-mock .row .meas{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--green);font-weight:600;padding:4px 10px;border-radius:999px;background:var(--mint)}

/* ─── Ship: artifact viewer ─── */
.ship-mock{background:var(--sheet);border:1px solid var(--line);border-radius:20px;overflow:hidden}
.ship-mock .stop{background:var(--ink);color:var(--sheet);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase}
.ship-mock .stop .pill{background:var(--mint);color:var(--green);padding:4px 10px;border-radius:999px;font-size:10px}
.ship-mock .files{padding:6px}
.ship-mock .file{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:14px 16px;border-radius:12px;transition:background .2s}
.ship-mock .file:hover{background:var(--paper)}
.ship-mock .file .ico{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;color:#fff;font-size:18px}
.ship-mock .file:nth-child(1) .ico{background:var(--orange)}
.ship-mock .file:nth-child(2) .ico{background:var(--green)}
.ship-mock .file:nth-child(3) .ico{background:var(--ink)}
.ship-mock .file:nth-child(4) .ico{background:#8a3aff}
.ship-mock .file b{display:block;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;letter-spacing:-0.01em}
.ship-mock .file span{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);margin-top:2px}
.ship-mock .file .size{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted)}
.ship-mock .sfoot{border-top:1px solid var(--line);padding:18px 20px;display:flex;justify-content:space-between;align-items:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.ship-mock .sfoot b{color:var(--green);font-weight:700}

/* ─── Deep principles (3 cards) ─── */
.principles{background:var(--ink);color:var(--sheet);padding:160px 32px;position:relative;overflow:hidden}
.principles::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 20% 100%,rgba(255,125,47,.18),transparent 60%);pointer-events:none}
.principles-head{max-width:1480px;margin:0 auto 64px;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end}
.principles-head h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(44px,5.6vw,96px);line-height:.92;letter-spacing:-0.04em;margin:0;text-transform:uppercase}
.principles-head h2 em{font-style:normal;color:var(--orange)}
.principles-head p{max-width:360px;margin:0;font-size:16px;color:rgba(255,255,255,.6);text-align:right}
.principle-grid{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;perspective:1400px}
.principle{background:#22221f;border:1px solid rgba(255,255,255,.08);border-radius:28px;padding:32px;display:flex;flex-direction:column;gap:18px;min-height:460px;position:relative;overflow:hidden;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.2,.8,.2,1),border-color .3s;will-change:transform}
.principle::before{content:"";position:absolute;inset:auto -20% -60% -20%;height:80%;background:radial-gradient(60% 100% at 50% 0%,var(--orange),transparent 65%);opacity:0;transition:opacity .4s;pointer-events:none}
.principle:hover{border-color:rgba(255,255,255,.2)}
.principle:hover::before{opacity:.22}
.principle .pi-ico{width:64px;height:64px;border-radius:18px;background:rgba(191,244,199,.1);color:var(--mint);display:grid;place-items:center;font-size:30px}
.principle h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:30px;letter-spacing:-0.025em;line-height:1;margin:0;text-transform:uppercase}
.principle p{margin:0;font-size:15px;line-height:1.55;color:rgba(255,255,255,.7)}
.principle .tag{align-self:flex-start;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mint);padding:5px 10px;border-radius:999px;background:rgba(191,244,199,.1)}
.principle .footnote{margin-top:auto;font-family:'JetBrains Mono',monospace;font-size:12px;color:rgba(255,255,255,.4);padding-top:16px;border-top:1px dashed rgba(255,255,255,.12)}
.principle .footnote b{color:var(--orange);font-weight:600}

/* ─── Before / After ─── */
.ba{padding:160px 32px;background:var(--sheet);position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ba-head{max-width:1480px;margin:0 auto 64px;text-align:center}
.ba-head h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(48px,6vw,108px);line-height:.92;letter-spacing:-0.04em;margin:0;text-transform:uppercase;text-wrap:balance}
.ba-head h2 em{font-style:normal;color:var(--orange)}
.ba-head p{max-width:520px;margin:22px auto 0;font-size:17px;color:var(--muted);line-height:1.5}
.ba-grid{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;position:relative}
.ba-col{border-radius:28px;padding:36px;min-height:460px;display:flex;flex-direction:column;gap:16px}
.ba-col.before{background:var(--paper);border:1.5px solid var(--line)}
.ba-col.after{background:var(--ink);color:var(--sheet);border:1.5px solid var(--ink)}
.ba-col h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:38px;letter-spacing:-0.035em;line-height:1;margin:0;text-transform:uppercase}
.ba-col .stamp{align-self:flex-start;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.ba-col.before .stamp{background:#ffd9b8;color:#8a3a0a}
.ba-col.after .stamp{background:var(--mint);color:var(--green)}
.ba-col .row{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:12px;background:var(--sheet);border:1px solid var(--line);font-size:14px;color:var(--ink-2)}
.ba-col.before .row{background:var(--sheet)}
.ba-col.after .row{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.85)}
.ba-col .row i{font-size:18px;flex-shrink:0}
.ba-col.before .row i{color:#8a3a0a}
.ba-col.after .row i{color:var(--mint)}
.ba-vs{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:999px;background:var(--orange);color:#fff;display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 14px 28px rgba(255,125,47,.4);z-index:3}

/* ─── FAQ ─── */
.faq{padding:160px 32px;background:var(--paper);position:relative}
.faq-head{max-width:1480px;margin:0 auto 56px;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end}
.faq-head h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(48px,6vw,108px);line-height:.92;letter-spacing:-0.04em;margin:0;text-transform:uppercase}
.faq-head h2 em{font-style:normal;color:var(--orange)}
.faq-head p{max-width:360px;margin:0;font-size:16px;color:var(--muted);text-align:right;line-height:1.5}
.faq-list{max-width:1100px;margin:0 auto;display:flex;flex-direction:column}
.faq-item{border-top:1.5px solid var(--ink);padding:24px 0;cursor:none;transition:padding .35s}
.faq-item:last-child{border-bottom:1.5px solid var(--ink)}
.faq-item .q{display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(20px,2.4vw,32px);letter-spacing:-0.02em;line-height:1.15;text-transform:uppercase}
.faq-item .q .toggle{flex-shrink:0;width:44px;height:44px;border-radius:999px;border:1.5px solid var(--ink);display:grid;place-items:center;font-size:20px;transition:all .35s cubic-bezier(.2,.8,.2,1)}
.faq-item.open .q .toggle{background:var(--ink);color:var(--sheet);transform:rotate(45deg)}
.faq-item .a{max-height:0;overflow:hidden;transition:max-height .55s cubic-bezier(.2,.8,.2,1),padding .35s,opacity .35s;opacity:0;color:var(--ink-2);font-size:16px;line-height:1.55;max-width:760px}
.faq-item.open .a{max-height:400px;padding:20px 0 8px;opacity:1}

/* ─── CTA ─── */
.cta{padding:160px 32px;background:var(--ink);color:var(--sheet);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 60% at 20% 100%,rgba(255,125,47,.22),transparent 60%);pointer-events:none}
.cta-inner{max-width:1280px;margin:0 auto;text-align:center;position:relative}
.cta-stamp{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;background:var(--mint);color:var(--green);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:36px}
.cta-stamp .dot{width:7px;height:7px;border-radius:999px;background:var(--green);animation:pulse 1.6s infinite}
.cta h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(60px,8vw,160px);line-height:.86;letter-spacing:-0.05em;margin:0 0 32px;text-transform:uppercase;text-wrap:balance}
.cta h2 em{font-style:normal;color:var(--orange)}
.cta p{max-width:560px;margin:0 auto 48px;font-size:18px;color:rgba(255,255,255,.65);line-height:1.5}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-cta-primary{padding:22px 38px;border-radius:999px;background:var(--sheet);color:var(--ink);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;align-items:center;gap:14px;transition:background .25s,color .25s,box-shadow .25s}
.btn-cta-primary:hover{background:var(--orange);color:#fff;box-shadow:0 22px 44px rgba(255,125,47,.32)}
.btn-cta-primary i{font-size:18px}
.btn-cta-ghost{padding:22px 32px;border-radius:999px;border:1.5px solid rgba(255,255,255,.25);color:var(--sheet);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;letter-spacing:.06em;text-transform:uppercase;transition:all .25s}
.btn-cta-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}

/* ─── Page-specific responsive ─── */
@media (max-width:1080px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .loop-wrap{max-width:520px;margin:0 auto}
  .stage-inner,.stage-block.alt .stage-inner{grid-template-columns:1fr;gap:40px;direction:ltr}
  .principles-head,.faq-head{grid-template-columns:1fr;gap:16px}
  .principles-head p,.faq-head p{text-align:left}
  .principle-grid{grid-template-columns:1fr;gap:16px}
  .principle{min-height:auto}
  .ba-grid{grid-template-columns:1fr;gap:18px}
  .ba-vs{display:none}
  .stat-strip-inner{grid-template-columns:1fr 1fr;gap:20px}
}
@media (max-width:900px){
  .stage-block,.principles,.ba,.faq,.cta{padding:96px 20px}
  .hero{padding:120px 20px 56px}
  .routing .matrix{grid-template-columns:120px repeat(4,1fr)}
  .routing .cell{height:44px;font-size:10px}
  .routing .label{font-size:12px}
}
@media (max-width:600px){
  .stat-strip-inner{grid-template-columns:1fr 1fr;gap:14px}
  .routing .matrix{display:flex;flex-direction:column;gap:8px}
  .routing .head{display:none}
}
