/* ============================================================================
   PMFtracker redesign v2: brand-true evolution.
   Light indigo/slate system, editorial type, instrument details.
   Sora / Instrument Serif / JetBrains Mono.
   ========================================================================== */

:root{
  --bg:#ffffff;
  --bg-soft:#f8fafc;
  --panel:#ffffff;
  --ink:#0f172a;
  --body:#334155;
  --muted:#64748b;
  --dim:#64748b;
  --line:#e2e8f0;
  --line-2:#c7d2fe;
  --indigo:#4f46e5;
  --indigo-2:#6366f1;
  --indigo-soft:#eef2ff;
  --violet:#818cf8;
  --amber:#f59e0b;
  --good:#059669;
  --warn:#b45309;
  --bad:#dc2626;
  --grad:linear-gradient(120deg,#4f46e5 0%,#6366f1 55%,#818cf8 110%);
  --grad-deep:linear-gradient(135deg,#0f172a 0%,#312e81 100%);
  --font-ui:'Sora',sans-serif;
  --font-serif:'Instrument Serif',serif;
  --font-mono:'JetBrains Mono',monospace;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --wrap:1200px;
  --shadow-lg:0 30px 80px -24px rgba(79,70,229,.28);
  --shadow-sm:0 1px 2px rgba(15,23,42,.05);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg)}
body{
  font-family:var(--font-ui);
  color:var(--body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:.02em}
.serif-i{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:0}
::selection{background:rgba(99,102,241,.25)}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
.wrap-narrow{max-width:820px}

a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible{
  outline:3px solid var(--indigo-2);outline-offset:3px;border-radius:4px;
}

.skip-link{
  position:fixed;top:.6rem;left:.6rem;z-index:300;transform:translateY(-300%);
  background:var(--indigo);color:#fff;font-weight:600;font-size:.85rem;
  padding:.6rem 1rem;border-radius:8px;transition:transform .2s;
}
.skip-link:focus-visible{transform:none}
main section[id],section[id]{scroll-margin-top:5.5rem}

.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:100%;z-index:120;
  background:var(--grad);transform-origin:0 50%;transform:scaleX(0);
}

/* ============================================================================
   Nav
   ========================================================================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,border-color .3s,box-shadow .3s;border-bottom:1px solid transparent;background:rgba(255,255,255,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.nav.is-stuck{background:rgba(255,255,255,.88);border-bottom-color:var(--line);box-shadow:0 12px 30px -24px rgba(15,23,42,.35)}
.nav-inner{
  max-width:var(--wrap);margin:0 auto;padding:.85rem clamp(1.25rem,4vw,3rem);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.nav-logo img{height:28px;width:auto}
.nav-links{display:flex;gap:1.25rem;align-items:center}
.nav-links a{
  font-size:.9rem;font-weight:500;color:var(--muted);position:relative;transition:color .2s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-5px;height:2px;width:100%;border-radius:2px;
  background:var(--grad);transform:scaleX(0);transform-origin:100% 50%;
  transition:transform .35s var(--ease-out);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:0 50%}
/* Tools dropdown */
.nav-drop{position:relative;display:flex;align-items:center}
.nav-drop-toggle{
  font-size:.9rem;font-weight:500;color:var(--muted);cursor:pointer;
  display:inline-flex;align-items:center;gap:.35rem;transition:color .2s;
}
.nav-drop-toggle::after{
  content:"";width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;opacity:.55;transition:transform .15s ease;
}
.nav-drop:hover .nav-drop-toggle,.nav-drop:focus-within .nav-drop-toggle{color:var(--ink)}
.nav-drop:hover .nav-drop-toggle::after,.nav-drop:focus-within .nav-drop-toggle::after{transform:rotate(180deg)}
.nav-drop-menu{
  position:absolute;top:100%;left:50%;min-width:252px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 24px 60px -24px rgba(79,70,229,.4);padding:.5rem;
  display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translate(-50%,8px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:1000;
}
.nav-drop:hover .nav-drop-menu,.nav-drop:focus-within .nav-drop-menu{
  opacity:1;visibility:visible;transform:translate(-50%,0);
}
.nav-drop-menu a{
  display:block;padding:.55rem .75rem;border-radius:8px;
  color:var(--ink);font-size:.92rem;font-weight:500;white-space:nowrap;
}
.nav-drop-menu a::after{display:none}
.nav-drop-menu a:hover{background:var(--indigo-soft);color:var(--indigo)}

.nav-toggle{display:none;background:#fff;border:1px solid var(--line);border-radius:999px;width:42px;height:42px;cursor:pointer;position:relative}
.nav-toggle i{position:absolute;left:12px;right:12px;height:2px;border-radius:2px;background:var(--ink);transition:transform .3s var(--ease-out)}
.nav-toggle i:first-child{top:16px}
.nav-toggle i:last-child{bottom:16px}
.nav-toggle[aria-expanded="true"] i:first-child{transform:translateY(4px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] i:last-child{transform:translateY(-4px) rotate(-45deg)}
@media (max-width:1080px){
  .nav-toggle{display:block;order:3}
  .nav-cta{order:2;margin-left:auto}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;gap:0;padding:.5rem 1.25rem 1rem;
    background:rgba(255,255,255,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);align-items:stretch;
    max-height:calc(100vh - 70px);overflow-y:auto;
  }
  .nav-links.is-open{display:flex}
  .nav-links a{padding:.85rem 0;font-size:1rem;border-bottom:1px solid var(--line)}
  .nav-links a:last-child{border-bottom:none}
  .nav-drop{display:block;width:100%}
  .nav-drop-toggle{width:100%;padding:.85rem 0;font-size:1rem;border-bottom:1px solid var(--line)}
  .nav-drop-menu{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:none;padding:.25rem 0 .25rem 1rem;min-width:0;
  }
  .nav-drop-menu a{border-bottom:none;padding:.55rem 0}
}

/* ============================================================================
   Buttons
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-ui);font-weight:600;font-size:.95rem;
  padding:.85rem 1.5rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;position:relative;white-space:nowrap;
  transition:box-shadow .3s,background .3s,border-color .3s,color .3s;
  will-change:transform;
}
.btn-arrow{display:inline-block;transition:transform .25s var(--ease-out)}
.btn:hover .btn-arrow{transform:translateX(4px)}
.btn:hover .btn-arrow.down{transform:translateY(4px)}
.btn-primary{
  background:var(--grad);color:#fff;
  box-shadow:0 10px 30px -10px rgba(79,70,229,.55);
}
.btn-primary:hover{box-shadow:0 16px 44px -10px rgba(79,70,229,.7)}
.btn-line{border-color:var(--line-2);color:var(--indigo);background:#fff}
.btn-line:hover{background:var(--indigo-soft);border-color:var(--indigo-2)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:#fff;padding:.6rem 1.15rem;font-size:.85rem;box-shadow:var(--shadow-sm)}
.btn-ghost:hover{border-color:var(--line-2);color:var(--indigo)}
.btn-invert{background:#fff;color:var(--indigo);box-shadow:0 14px 40px -14px rgba(0,0,0,.4)}
.btn-invert:hover{box-shadow:0 20px 55px -14px rgba(0,0,0,.5)}
.btn-xl{font-size:1.1rem;padding:1.1rem 2.2rem}

/* ============================================================================
   Kickers + headings + sections
   ========================================================================== */
.kicker{
  font-family:var(--font-mono);font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.2em;color:var(--indigo);
  display:flex;align-items:center;gap:.7rem;margin-bottom:1.3rem;
}
.line-kicker::before{content:"";width:2.2rem;height:2px;border-radius:2px;background:var(--grad)}
.h2{
  font-size:clamp(2rem,4.8vw,3.3rem);line-height:1.07;font-weight:700;
  letter-spacing:-.02em;color:var(--ink);margin-bottom:1.1rem;
}
.h2 .serif-i{font-size:1.06em;color:transparent;background:var(--grad);-webkit-background-clip:text;background-clip:text}
.section-sub{color:var(--muted);max-width:58ch;font-size:1.06rem;margin-bottom:3rem}
.section{padding:clamp(4.5rem,9vw,7.5rem) 0;position:relative}
.section-foot{margin-top:2.4rem}
.section-foot a{color:var(--indigo);font-family:var(--font-mono);font-size:.85rem;font-weight:700}
.section-foot a:hover{text-decoration:underline}

.split .w{display:inline-block;overflow:hidden;vertical-align:top}
.split .w>i{display:inline-block;font-style:inherit;transform:translateY(110%)}

/* ============================================================================
   Hero
   ========================================================================== */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(7rem,12vw,9.5rem) 0 0;
  background:
    radial-gradient(60% 45% at 78% 10%,rgba(99,102,241,.10),transparent 70%),
    radial-gradient(50% 40% at 12% 30%,rgba(129,140,248,.08),transparent 70%),
    var(--bg);
}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero-inner{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center}
.hero-kicker{justify-content:center;background:var(--indigo-soft);border:1px solid var(--line-2);border-radius:999px;padding:.45rem 1rem;margin-bottom:1.6rem}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 3px rgba(5,150,105,.15);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.4}}
.hero-h1{
  font-size:clamp(2.7rem,7vw,5.6rem);line-height:1.02;font-weight:800;
  letter-spacing:-.03em;color:var(--ink);margin-bottom:1.4rem;
}
.h1-line{display:block;overflow:hidden;padding-bottom:.08em}
.h1-word{display:inline-block}
.js .h1-word{transform:translateY(115%)}
.h1-word.ghost{color:#94a3b8}
.h1-word.serif-i{font-weight:400}
.h1-word.ghost.serif-i{text-decoration:line-through;text-decoration-thickness:.045em;text-decoration-color:var(--bad)}
.h1-word.grad{color:transparent;background:var(--grad);-webkit-background-clip:text;background-clip:text}
.hero-sub{color:var(--muted);font-size:clamp(1rem,1.6vw,1.2rem);max-width:60ch;margin:0 auto 2rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:center;margin-bottom:1.2rem}
.hero-checks{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem 1.6rem;justify-content:center;margin-bottom:1rem}
.hero-checks li{
  font-family:var(--font-mono);font-size:.78rem;color:var(--muted);letter-spacing:.02em;
  display:flex;align-items:center;gap:.45rem;
}
.hero-checks li::before{content:"✓";color:var(--good);font-weight:700}
.risk-line{font-family:var(--font-mono);font-size:.75rem;color:var(--muted);letter-spacing:.04em}

.hero-shot-wrap{position:relative;z-index:2;margin-top:2.8rem}
.hero-shot{
  border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;
  box-shadow:var(--shadow-lg);
  transform:perspective(1400px) rotateX(6deg);
  transform-origin:50% 0;
}
.hero-shot img{width:100%}
.shot-chip{
  position:absolute;font-size:.7rem;letter-spacing:.1em;color:var(--body);
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:12px;padding:.7rem 1rem;
  box-shadow:0 16px 40px -14px rgba(15,23,42,.35);
}
.shot-chip b{color:var(--good);font-weight:700;margin-left:.35rem}
.chip-a{top:6%;right:1%}
.chip-b{bottom:10%;left:1%}
@media (max-width:640px){.chip-a,.chip-b{display:none}}

/* ============================================================================
   Marquee
   ========================================================================== */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:var(--bg-soft);margin-top:clamp(3rem,6vw,5rem)}
.marquee-track{display:flex;align-items:center;width:max-content;padding:.95rem 0;animation:marquee 28s linear infinite}
.marquee-track span{
  font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.18em;color:var(--muted);white-space:nowrap;margin-right:3rem;
}
.marquee-track em{color:var(--indigo-2);font-style:normal;font-size:.6rem;margin-right:3rem}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================================
   Problem stats
   ========================================================================== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
.stat-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.9rem 1.75rem;
  position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:border-color .25s,box-shadow .25s;
}
.stat-card::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .35s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(99,102,241,.08),transparent 65%);
}
.stat-card:hover{border-color:var(--line-2);box-shadow:0 18px 40px -18px rgba(79,70,229,.35)}
.stat-card:hover::before{opacity:1}
.stat-num{
  font-size:clamp(2.8rem,5.5vw,4.2rem);font-weight:700;line-height:1;
  color:transparent;background:var(--grad);-webkit-background-clip:text;background-clip:text;
  font-variant-numeric:tabular-nums;margin-bottom:1rem;
}
.stat-unit{font-size:.45em}
.stat-meter{height:6px;border-radius:999px;background:#eef2f7;overflow:hidden;margin-bottom:1.2rem}
.stat-meter span{display:block;height:100%;width:0;border-radius:inherit;background:var(--grad);transition:width 1.4s var(--ease-out)}
.stat-card.is-in .stat-meter span{width:var(--w)}
.stat-card h3{font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:.55rem;line-height:1.35}
.stat-card p{color:var(--muted);font-size:.92rem}
@media (max-width:900px){.stats{grid-template-columns:1fr;max-width:480px}}

/* ============================================================================
   How it works: Collect / Track / Act
   ========================================================================== */
.work{background:var(--bg-soft)}
.steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:1.2rem;align-items:stretch}
.step{
  background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.6rem 1.5rem;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;transition:border-color .25s,box-shadow .25s;
}
.step::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .35s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(99,102,241,.07),transparent 65%);
}
.step:hover{border-color:var(--line-2);box-shadow:0 22px 50px -20px rgba(79,70,229,.35)}
.step:hover::before{opacity:1}
.step-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.step-num{
  font-size:.8rem;font-weight:700;color:var(--indigo);
  background:var(--indigo-soft);border:1px solid var(--line-2);border-radius:999px;padding:.3rem .7rem;
}
.step-time{font-size:.72rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.step-img{border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:1.2rem;background:var(--bg-soft)}
.step-img img{width:100%;transition:transform .6s var(--ease-out)}
.step:hover .step-img img{transform:scale(1.04)}
.step h3{font-size:1.35rem;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.step-lead{color:var(--indigo);font-weight:600;font-size:.92rem;margin-bottom:.9rem}
.step-list{list-style:none}
.step-list li{
  padding:.34rem 0 .34rem 1.6rem;position:relative;font-size:.9rem;color:var(--muted);
}
.step-list li::before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:700}
.step-arrow{
  align-self:center;font-size:1.6rem;color:var(--indigo-2);font-weight:700;
  animation:nudge 2.2s ease-in-out infinite;
}
@keyframes nudge{50%{transform:translateX(6px)}}
@media (max-width:980px){
  .steps{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .step-arrow{transform:rotate(90deg);animation:none;justify-self:center}
}

/* ============================================================================
   Solution suite (tabs)
   ========================================================================== */
.suite{display:grid;grid-template-columns:1fr 1.35fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.suite-tabs{display:flex;flex-direction:column;gap:.9rem}
.suite-tab{
  text-align:left;background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:1.2rem 1.3rem 1rem;cursor:pointer;font:inherit;position:relative;overflow:hidden;
  transition:border-color .25s,box-shadow .25s,background .25s;
}
.suite-tab:hover{border-color:var(--line-2)}
.suite-tab.is-active{border-color:var(--indigo-2);box-shadow:0 18px 44px -20px rgba(79,70,229,.4);background:linear-gradient(180deg,#fff, #fbfbff)}
.suite-tab-title{display:block;font-weight:700;color:var(--ink);font-size:1.05rem;margin-bottom:.35rem}
.suite-tab-desc{display:block;color:var(--muted);font-size:.88rem;line-height:1.55;margin-bottom:.8rem}
.suite-bar{display:block;height:3px;border-radius:999px;background:#eef2f7;overflow:hidden}
.suite-bar i{display:block;height:100%;width:0;background:var(--grad)}
.suite-tab.is-active .suite-bar i{animation:suitebar var(--suite-ms,6000ms) linear forwards}
@keyframes suitebar{from{width:0}to{width:100%}}
.suite-view{
  border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;
  box-shadow:var(--shadow-lg);position:relative;
}
.suite-panel{display:none}
.suite-panel.is-active{display:block;animation:panelIn .5s var(--ease-out)}
@keyframes panelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.suite-panel img{width:100%}
@media (max-width:900px){
  .suite{grid-template-columns:1fr}
  .suite-view{order:-1}
}

/* ============================================================================
   Interactive demo (gauge)
   ========================================================================== */
.demo{background:var(--bg-soft)}
.demo-panel{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);
  background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:clamp(1.8rem,4vw,3rem);align-items:center;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.demo-panel::before{
  content:"";position:absolute;inset:auto -20% -50% -20%;height:70%;
  background:radial-gradient(ellipse at 50% 100%,rgba(99,102,241,.07),transparent 70%);
  pointer-events:none;
}
.demo-gauge{position:relative;text-align:center}
.gauge-svg{width:100%;max-width:380px;margin:0 auto;display:block;overflow:visible}
.gauge-track{stroke:#e2e8f0;stroke-width:14;stroke-linecap:round}
.gauge-band{stroke:rgba(129,140,248,.35);stroke-width:14;stroke-linecap:butt}
.gauge-fill{stroke:url(#gaugeGrad);stroke-width:14;stroke-linecap:round}
.gauge-bench{stroke:var(--amber);stroke-width:2;stroke-dasharray:3 4}
.gauge-bench-label{fill:var(--muted);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.gauge-readout{margin-top:-4.6rem;position:relative}
.gauge-score{
  font-size:clamp(3.2rem,6.5vw,4.6rem);font-weight:700;line-height:1;color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.gauge-pct{font-size:.4em;color:var(--muted)}
.gauge-moe{color:var(--indigo);font-size:.85rem;margin-top:.3rem;font-weight:700}
.gauge-verdict{margin-top:.8rem;font-weight:700;font-size:1rem;min-height:1.6em;color:var(--ink)}
.gauge-verdict.is-below{color:var(--bad)}
.gauge-verdict.is-close{color:var(--warn)}
.gauge-verdict.is-above{color:var(--good)}
.demo-controls{position:relative}
.ctrl{margin-bottom:1.5rem}
.ctrl label{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;font-size:.92rem;color:var(--muted);margin-bottom:.65rem}
.ctrl label b{color:var(--ink)}
.ctrl output{color:var(--indigo);font-size:1rem;font-weight:700}
input[type=range]{
  width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;
  background:linear-gradient(90deg,var(--indigo-2) var(--fill,50%),#e2e8f0 var(--fill,50%));
  cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;
  background:#fff;border:6px solid var(--indigo);
  box-shadow:0 2px 10px rgba(79,70,229,.35);transition:transform .15s;
}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.12)}
input[type=range]::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;background:#fff;border:6px solid var(--indigo);
  box-shadow:0 2px 10px rgba(79,70,229,.35);
}
.demo-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin:.3rem 0 1rem}
.chip{
  font-size:.72rem;letter-spacing:.04em;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:.45rem .85rem;background:#fff;
  transition:color .3s,border-color .3s;
}
.demo-note{font-size:.8rem;color:var(--muted);margin-bottom:1.5rem;max-width:46ch}
@media (max-width:900px){.demo-panel{grid-template-columns:1fr}}

/* ============================================================================
   Method quotes
   ========================================================================== */
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.quote{
  border:1px solid var(--line);border-radius:18px;padding:1.9rem 1.8rem;background:#fff;
  position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:border-color .25s,box-shadow .25s;
}
.quote:hover{border-color:var(--line-2);box-shadow:0 18px 44px -20px rgba(79,70,229,.3)}
.quote blockquote{
  font-family:var(--font-serif);font-style:italic;font-size:1.22rem;line-height:1.5;
  color:var(--ink);margin-bottom:1.3rem;
}
.quote figcaption b{display:block;font-weight:700;color:var(--ink);font-size:.95rem}
.quote figcaption span{color:var(--muted);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em}
.founder-note{
  margin-top:1.3rem;display:flex;gap:1.2rem;align-items:center;
  border:1px solid var(--line-2);border-radius:18px;padding:1.4rem 1.7rem;
  background:linear-gradient(92deg,var(--indigo-soft),#fff);
}
.founder-note img{border-radius:50%;flex-shrink:0}
.founder-note p{color:var(--body);font-size:.98rem}
.founder-note b{display:block;color:var(--ink);font-size:.8rem;margin-top:.4rem;font-family:var(--font-mono);font-weight:700;letter-spacing:.04em}
@media (max-width:820px){.quotes{grid-template-columns:1fr}}

/* ============================================================================
   Pricing
   ========================================================================== */
.pricing{background:var(--bg-soft)}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:960px}
.plan{
  border:1px solid var(--line);border-radius:22px;padding:2.1rem 1.9rem;background:#fff;
  position:relative;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
}
.plan-hot{border-color:var(--indigo-2);box-shadow:0 28px 70px -28px rgba(79,70,229,.45)}
.plan-pop{
  position:absolute;top:-.85rem;left:1.9rem;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  background:var(--grad);color:#fff;border-radius:999px;padding:.35rem .9rem;font-weight:700;
}
.plan h3{font-size:1.3rem;font-weight:700;color:var(--ink)}
.plan-tag{color:var(--muted);font-size:.9rem;margin:.3rem 0 1.3rem}
.plan-price{display:flex;align-items:baseline;gap:.7rem;margin-bottom:1.6rem}
.plan-price s{color:#94a3b8;font-size:1.1rem}
.plan-price b{font-size:2.5rem;font-weight:700;color:var(--ink)}
.plan-price span{font-size:.72rem;color:var(--indigo);text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.plan ul{list-style:none;margin-bottom:1.9rem;flex:1}
.plan li{padding:.42rem 0 .42rem 1.7rem;position:relative;font-size:.92rem;color:var(--body)}
.plan li.in::before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:700}
.plan li.out{color:#94a3b8;text-decoration:line-through;text-decoration-color:rgba(148,163,184,.6)}
.plan li.out::before{content:"×";position:absolute;left:0;color:#cbd5e1}
.plan li.all{color:var(--ink);font-weight:700}
.plan li.bonus{color:var(--ink)}
.plan li.bonus::before{content:"★";color:var(--amber)}
.plan-btn{justify-content:center}
@media (max-width:820px){.plans{grid-template-columns:1fr}}

/* ============================================================================
   FAQ
   ========================================================================== */
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  padding:1.35rem 0;font-weight:700;font-size:1.05rem;color:var(--ink);transition:color .2s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--indigo)}
.faq-x{position:relative;width:14px;height:14px;flex-shrink:0}
.faq-x::before,.faq-x::after{
  content:"";position:absolute;top:50%;left:0;width:100%;height:2px;border-radius:2px;
  background:var(--indigo);transform:translateY(-50%);transition:transform .3s var(--ease-out);
}
.faq-x::after{transform:translateY(-50%) rotate(90deg)}
.faq-item[open] .faq-x::after{transform:translateY(-50%) rotate(0deg)}
.faq-a{overflow:hidden}
.faq-a p{color:var(--muted);padding:0 0 1.5rem;max-width:64ch;font-size:.97rem}

/* ============================================================================
   Finale
   ========================================================================== */
.finale{
  position:relative;overflow:hidden;text-align:center;
  padding:clamp(5.5rem,11vw,9rem) 0;
  background:
    radial-gradient(70% 90% at 50% 120%,rgba(129,140,248,.35),transparent 70%),
    var(--grad-deep);
}
.finale-inner{position:relative;z-index:2}
.finale-h2{
  font-size:clamp(2.4rem,6.5vw,4.8rem);line-height:1.05;font-weight:800;letter-spacing:-.03em;
  color:#fff;margin-bottom:2.2rem;
}
.finale-h2 .serif-i{color:transparent;background:linear-gradient(92deg,#a5b4fc,#e0e7ff);-webkit-background-clip:text;background-clip:text}
.finale .risk-line{margin-top:1.2rem;color:#c7d2fe}
.finale-readout{margin-top:3rem;font-size:.72rem;letter-spacing:.18em;color:#8b93d6}

/* ============================================================================
   Footer (brand dark)
   ========================================================================== */
.foot{background:#0b1020;color:#cbd5e1;padding:4rem 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.foot-brand img{height:24px;width:auto;margin-bottom:1rem}
.foot-brand p{color:#8b93ad;font-size:.9rem;margin-bottom:.8rem}
.foot-brand a{color:#cbd5e1;font-size:.8rem}
.foot-brand a:hover{color:#fff}
.foot-col{display:flex;flex-direction:column;gap:.55rem}
.foot-col h4{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:#8b93ad;margin-bottom:.5rem;font-weight:700}
.foot-col a{color:#cbd5e1;font-size:.88rem;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-legal{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  border-top:1px solid rgba(255,255,255,.1);padding-top:1.6rem;
  font-size:.72rem;color:#8b93ad;letter-spacing:.04em;
}
.foot-legal a:hover{color:#cbd5e1}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ============================================================================
   Cookie banner
   ========================================================================== */
.cookie-bar{
  position:fixed;left:50%;bottom:1rem;transform:translateX(-50%);z-index:180;
  width:min(680px,calc(100vw - 2rem));
  display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:1rem 1.2rem;box-shadow:0 24px 60px -20px rgba(15,23,42,.35);
}
.cookie-bar[hidden]{display:none}
.cookie-bar p{font-size:.82rem;color:var(--muted);flex:1 1 320px;margin:0}
.cookie-bar p a{color:var(--indigo);text-decoration:underline}
.cookie-actions{display:flex;gap:.6rem}
.cookie-actions .btn{padding:.55rem 1rem;font-size:.82rem}
@media (max-width:560px){.cookie-actions{width:100%;justify-content:flex-end}}

/* ============================================================================
   Reduced motion
   ========================================================================== */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .js .h1-word,.split .w>i{transform:none!important}
  .marquee-track{animation:none}
  .hero-canvas{display:none}
  .hero-shot{transform:none}
  .suite-tab.is-active .suite-bar i{animation:none;width:100%}
}
