/* =========================================================
   Spec2TestAI — AgileAI Labs
   Shared design system. Pure static CSS (S3-hostable).
   ========================================================= */

:root{
  --bg:#070A12;
  --bg-2:#0A0F1C;
  --panel:rgba(255,255,255,.028);
  --panel-2:rgba(255,255,255,.05);
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --fg:#EAF0FA;
  --dim:#94A0B8;
  --faint:#5E6B86;
  --teal:#34E7CE;
  --violet:#8B7BF7;
  --hue:0deg;
  --g1y:-10%;
  --g2y:0%;
  --amber:#F4A85C;
  --coral:#FF8266;
  --grad:linear-gradient(100deg,#34E7CE 0%,#6CC6F0 42%,#8B7BF7 100%);
  --grad-soft:linear-gradient(100deg,rgba(52,231,206,.16),rgba(139,123,247,.16));
  --r-sm:10px;
  --r:16px;
  --r-lg:22px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Sora",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  background:transparent;
  color:var(--fg);
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(139,123,247,.35)}

/* ambient page glow */
body::before{
  content:"";
  position:fixed;inset:-25%;z-index:-1;
  background:
    radial-gradient(1200px 820px at 80% var(--g1y),rgba(139,123,247,.40),transparent 60%),
    radial-gradient(1000px 720px at 5% var(--g2y),rgba(52,231,206,.30),transparent 58%),
    radial-gradient(820px 680px at 50% 118%,rgba(108,120,200,.24),transparent 60%);
  filter:hue-rotate(var(--hue));
  transition:filter .2s linear;
  animation:drift 20s ease-in-out infinite;
  will-change:transform,filter;
  pointer-events:none;
}
@keyframes drift{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(-7%,5%,0) scale(1.14)}
  100%{transform:translate3d(0,0,0) scale(1)}
}
body::after{
  content:"";
  position:fixed;inset:0;z-index:-1;
  background-image:linear-gradient(rgba(150,170,230,.10) 1px,transparent 1px),linear-gradient(90deg,rgba(150,170,230,.10) 1px,transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(135% 95% at 50% -5%,#000 35%,transparent 82%);
          mask-image:radial-gradient(135% 95% at 50% -5%,#000 35%,transparent 82%);
  opacity:1;
  pointer-events:none;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:16px;top:16px;z-index:100;background:var(--fg);color:#000;padding:10px 16px;border-radius:8px}

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.02em;line-height:1.08;margin:0}
h1{font-size:clamp(2.4rem,6vw,4.3rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.9rem);letter-spacing:-.025em}
h3{font-size:1.18rem;letter-spacing:-.01em;line-height:1.25}
p{margin:0}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--dim);line-height:1.6}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);display:inline-flex;align-items:center;gap:9px;margin:0 0 18px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--teal),transparent)}
.eyebrow.v{color:var(--violet)}
.eyebrow.v::before{background:linear-gradient(90deg,var(--violet),transparent)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;transition:background .3s,border-color .3s,backdrop-filter .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(7,10,18,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:28px;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:600;font-size:1.12rem;letter-spacing:-.02em}
.brand .mark{width:30px;height:30px;flex:none}
.brand b{font-weight:600}
.brand span{color:var(--teal)}
.nav-links{display:flex;align-items:center;gap:26px;margin-left:8px}
.nav-links a{font-size:.93rem;color:var(--dim);transition:color .2s;font-weight:450}
.nav-links a:hover{color:var(--fg)}
.nav-spacer{flex:1}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;background:none;border:0;color:var(--fg);cursor:pointer;padding:6px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:500;font-size:.96rem;
  padding:13px 22px;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:transform .15s var(--ease),box-shadow .25s,background .25s,border-color .2s;white-space:nowrap;
}
.btn .arr{transition:transform .2s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:var(--grad);color:#04121A;box-shadow:0 0 0 0 rgba(52,231,206,.0)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px -10px rgba(52,231,206,.55)}
.btn-ghost{background:rgba(255,255,255,.04);border-color:var(--line-2);color:var(--fg)}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-sm{padding:10px 18px;font-size:.9rem}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.82rem;letter-spacing:.02em;color:var(--teal);transition:gap .2s}
.link-arrow:hover{gap:11px}

/* ---------- layout primitives ---------- */
section{position:relative}
.sec{padding:96px 0}
.sec-tight{padding:64px 0}
.center{text-align:center}
.mw-720{max-width:720px}
.mw-640{max-width:640px}
.mx{margin-left:auto;margin-right:auto}

/* ---------- hero ---------- */
.hero{padding:78px 0 64px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin-bottom:22px}
.hero .lead{max-width:480px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-note{margin-top:26px;font-family:var(--mono);font-size:.78rem;color:var(--faint);letter-spacing:.04em}

/* hero columns (prevent / no-code) */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:34px}
.duo-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px;backdrop-filter:blur(4px)}
.duo-card .tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal)}
.duo-card.alt{border-color:rgba(139,123,247,.45);background:linear-gradient(180deg,rgba(139,123,247,.08),transparent)}
.duo-card.alt .tag{color:var(--violet)}
.duo-card h3{margin:12px 0 7px;font-size:1.06rem}
.duo-card p{font-size:.92rem;color:var(--dim);line-height:1.5}

/* execution console signature */
.console{
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.018));
  border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:0 40px 120px -40px rgba(108,120,200,.5),inset 0 1px 0 rgba(255,255,255,.06);
}
.console-bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:.74rem;color:var(--faint)}
.dot{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.14)}
.console-bar .t{margin-left:8px;letter-spacing:.04em}
.console-body{padding:20px 20px 22px;font-family:var(--mono);font-size:.83rem;line-height:1.9;min-height:268px}
.cline{opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}
.cline.show{opacity:1;transform:none}
.cline .pfx{color:var(--faint);user-select:none}
.cline .step{color:var(--fg)}
.cline .think{color:var(--violet)}
.cline .act{color:var(--teal)}
.cline .ok{color:#5BE3B0}
.cline .ok::before{content:"✓ ";font-weight:700}
.caret{display:inline-block;width:8px;height:1.05em;background:var(--teal);vertical-align:-2px;margin-left:2px;animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}

/* ---------- marquee / proof ---------- */
.proof{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:56px}
.proof div{background:var(--bg);padding:26px 22px}
.proof .num{font-family:var(--display);font-weight:600;font-size:2rem;letter-spacing:-.02em}
.proof .num.g{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.proof .lbl{font-size:.82rem;color:var(--dim);margin-top:5px;line-height:1.4}

/* ---------- section heading ---------- */
.sechead{max-width:680px;margin-bottom:48px}
.sechead.center{margin-left:auto;margin-right:auto}
.sechead p{color:var(--dim);margin-top:16px;font-size:1.05rem}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:16px}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:26px;
  transition:transform .25s var(--ease),border-color .25s,background .25s;position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-4px);border-color:var(--line-2);background:var(--panel-2)}
.card .ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--grad-soft);border:1px solid var(--line);margin-bottom:18px}
.card .ic svg{width:21px;height:21px;stroke:var(--teal);fill:none;stroke-width:1.6}
.card h3{margin-bottom:9px}
.card p{font-size:.95rem;color:var(--dim);line-height:1.55}
.card.feat{border-color:rgba(139,123,247,.4)}
.card.feat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(139,123,247,.06),transparent 50%);pointer-events:none}
.card .foot{margin-top:18px}

.badge{font-family:var(--mono);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;padding:5px 10px;border-radius:999px;border:1px solid var(--line-2)}
.badge.flag{color:var(--violet);border-color:rgba(139,123,247,.4);background:rgba(139,123,247,.08)}
.badge.pat{color:var(--amber);border-color:rgba(244,168,92,.35);background:rgba(244,168,92,.07)}
.badge.partner{color:var(--teal);border-color:rgba(52,231,206,.3);background:rgba(52,231,206,.06)}
.card-top{display:flex;align-items:center;gap:10px;margin-bottom:16px}

/* ---------- budget leak ---------- */
.leak{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:8px}
.leak .big{font-family:var(--display);font-weight:600;font-size:2.6rem;color:var(--amber);letter-spacing:-.02em}
.leak p{color:var(--dim);font-size:.96rem;margin-top:6px}
.src{font-family:var(--mono);font-size:.72rem;color:var(--faint);margin-top:26px;letter-spacing:.03em}

/* ---------- cost curve ---------- */
.curve{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;align-items:end;height:300px;margin-top:14px;padding-top:30px}
.bar-wrap{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.bar{width:100%;max-width:84px;border-radius:8px 8px 0 0;background:linear-gradient(180deg,var(--coral),rgba(255,130,102,.45));height:0;transition:height 1.1s var(--ease);position:relative}
.bar.prevent{background:linear-gradient(180deg,var(--teal),rgba(52,231,206,.4));box-shadow:0 0 30px -6px rgba(52,231,206,.5)}
.bar .v{position:absolute;top:-26px;left:0;right:0;text-align:center;font-family:var(--mono);font-size:.86rem;color:var(--fg)}
.bar-lbl{font-family:var(--mono);font-size:.74rem;color:var(--dim);margin-top:12px;letter-spacing:.03em;text-align:center}

/* ---------- resilience layers ---------- */
.layers{display:grid;grid-template-columns:1fr 1fr;gap:0 40px}
.layer{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.layer .n{font-family:var(--mono);font-size:.8rem;color:var(--teal);width:26px;flex:none;padding-top:2px}
.layer h3{font-size:1rem;margin-bottom:3px}
.layer p{font-size:.88rem;color:var(--dim);line-height:1.45}

/* ---------- checklist ---------- */
.checks{display:grid;grid-template-columns:1fr 1fr;gap:8px 40px}
.chk{display:flex;gap:11px;align-items:flex-start;padding:9px 0;font-size:.96rem}
.chk svg{width:19px;height:19px;flex:none;stroke:var(--teal);fill:none;stroke-width:2;margin-top:3px}

/* ---------- testimonial ---------- */
.quote-wrap{border:1px solid var(--line);border-radius:var(--r-lg);padding:54px;background:var(--grad-soft);position:relative;overflow:hidden}
.quote-wrap .mark{font-family:var(--display);font-size:5rem;line-height:.5;color:var(--violet);opacity:.5}
.quote{font-family:var(--display);font-weight:500;font-size:clamp(1.3rem,2.5vw,1.85rem);letter-spacing:-.02em;line-height:1.34;margin:18px 0 30px;max-width:920px}
.byline{display:flex;align-items:center;gap:14px}
.byline .av{width:46px;height:46px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;color:#04121A}
.byline .nm{font-weight:600;font-size:.98rem}
.byline .ro{font-size:.86rem;color:var(--dim)}

/* ---------- stack / step row ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;position:relative}
.step .n{font-family:var(--mono);font-size:.8rem;color:var(--violet);margin-bottom:14px}
.step h3{font-size:1.02rem;margin-bottom:6px}
.step p{font-size:.88rem;color:var(--dim);line-height:1.45}

/* old vs new */
.vs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.vs .col{border:1px solid var(--line);border-radius:var(--r);padding:26px}
.vs .col.new{border-color:rgba(139,123,247,.4);background:linear-gradient(180deg,rgba(139,123,247,.06),transparent)}
.vs .h{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.vs .col.new .h{color:var(--violet)}
.vs li{list-style:none;padding:8px 0;font-size:.96rem;color:var(--dim)}
.vs ul{margin:0;padding:0}

/* partners */
.partners{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.chip{font-family:var(--mono);font-size:.82rem;letter-spacing:.02em;color:var(--dim);border:1px solid var(--line);border-radius:999px;padding:9px 16px;transition:border-color .2s,color .2s}
.chip:hover{border-color:var(--line-2);color:var(--fg)}
.chip b{color:var(--teal);font-weight:500}

/* trust */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 32px}
.trust .it{display:flex;gap:12px;align-items:center;font-size:.96rem;padding:8px 0}
.trust .it svg{width:20px;height:20px;flex:none;stroke:var(--teal);fill:none;stroke-width:1.6}

/* video */
.video{position:relative;border:1px solid var(--line-2);border-radius:var(--r-lg);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(52,231,206,.06),rgba(139,123,247,.08));overflow:hidden;cursor:pointer;transition:border-color .25s}
.video:hover{border-color:rgba(52,231,206,.45)}
.video .play{width:74px;height:74px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;box-shadow:0 0 50px -8px rgba(52,231,206,.55);transition:transform .2s var(--ease)}
.video:hover .play{transform:scale(1.06)}
.video .play svg{width:26px;height:26px;fill:#04121A;margin-left:4px}
.video .cap{position:absolute;left:20px;bottom:18px;font-family:var(--mono);font-size:.76rem;color:var(--dim);letter-spacing:.03em}
.video .ovr{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.video .ovr .txt{font-family:var(--mono);font-size:.82rem;color:var(--dim)}

/* big CTA */
.bigcta{border:1px solid var(--line-2);border-radius:var(--r-lg);padding:64px 40px;text-align:center;background:var(--grad-soft);position:relative;overflow:hidden}
.bigcta h2{margin-bottom:14px}
.bigcta p{color:var(--dim);max-width:520px;margin:0 auto 30px}

/* divider hairline accent */
.accent-rule{height:1px;background:linear-gradient(90deg,transparent,var(--line-2),transparent);margin:0}

/* footer */
.footer{border-top:1px solid var(--line);padding:64px 0 40px;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.foot-grid h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:0 0 16px;font-weight:500}
.foot-grid a{display:block;color:var(--dim);font-size:.92rem;padding:5px 0;transition:color .2s}
.foot-grid a:hover{color:var(--fg)}
.foot-brand p{color:var(--dim);font-size:.92rem;margin-top:14px;max-width:280px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);font-size:.82rem;color:var(--faint);font-family:var(--mono);letter-spacing:.03em}

/* breadcrumb */
.crumb{font-family:var(--mono);font-size:.8rem;color:var(--faint);letter-spacing:.04em;padding-top:34px}
.crumb a{color:var(--teal)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .g-3,.steps{grid-template-columns:1fr 1fr}
  .layers,.checks{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:16px}
  .nav-links{display:none}
  .menu-btn{display:block}
  .nav.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:var(--bg-2);border-bottom:1px solid var(--line);padding:18px 24px;gap:14px}
  .duo,.proof,.g-2,.g-3,.steps,.vs,.leak,.trust,.foot-grid{grid-template-columns:1fr}
  .proof div{padding:22px}
  .sec{padding:64px 0}
  .quote-wrap,.bigcta{padding:34px 24px}
  .curve{gap:8px}
  .hero-cta .btn,.bigcta .btn{width:100%;justify-content:center}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .cline{opacity:1;transform:none;transition:none}
  .caret{animation:none}
  .bar{transition:none}
  body::before{animation:none}
}

/* ---- logo + scroll flair + video embed ---- */
.brand .logo{height:30px;width:auto;display:block;filter:drop-shadow(0 4px 14px rgba(139,123,247,.45))}
.footer .brand .logo{height:34px}
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--grad);z-index:60;will-change:transform}
.video-frame{border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;background:#000;box-shadow:0 40px 120px -50px rgba(108,120,200,.55)}
.video-frame video{display:block;width:100%;height:auto;background:#000}

/* ---- impact counters (cumulative, understated) ---- */
.impact{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:42px 0}
.impact-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);display:block;text-align:center;margin-bottom:28px}
.impact-row{display:grid;grid-template-columns:repeat(3,1fr)}
.impact-item{text-align:center;padding:4px 24px;position:relative}
.impact-item + .impact-item::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:48px;width:1px;background:var(--line)}
.impact-num{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,3.3vw,2.5rem);letter-spacing:-.02em;line-height:1;color:var(--fg);font-variant-numeric:tabular-nums}
.impact-num .u{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-left:1px}
.impact-lbl{font-size:.85rem;color:var(--dim);margin-top:11px;line-height:1.4}
@media(max-width:760px){
  .impact-row{grid-template-columns:1fr;gap:30px}
  .impact-item + .impact-item::before{display:none}
}

/* ---- request a demo modal + form ---- */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding:5vh 20px;overflow-y:auto}
.modal.open{display:flex}
.modal-overlay{position:fixed;inset:0;background:rgba(4,6,12,.74);backdrop-filter:blur(8px)}
.modal-card{position:relative;width:100%;max-width:540px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02));border:1px solid var(--line-2);border-radius:var(--r-lg);padding:34px;box-shadow:0 50px 140px -40px rgba(108,120,200,.6);animation:modalIn .3s var(--ease)}
@keyframes modalIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:15px;right:15px;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--dim);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1}
.modal-close:hover{color:var(--fg);border-color:var(--line-2)}
.modal-card h2{font-size:1.5rem;margin-bottom:6px}
.modal-card .sub{color:var(--dim);font-size:.95rem;margin-bottom:22px;line-height:1.5}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.field{margin-bottom:14px}
.field label{display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.field label .req{color:var(--violet)}
.field input,.field select,.field textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:11px 13px;color:var(--fg);font-family:var(--body);font-size:.95rem;transition:border-color .2s,box-shadow .2s}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(52,231,206,.14)}
.field textarea{resize:vertical;min-height:78px}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238893AC' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
.field select option{background:#0A0F1C;color:var(--fg)}
.field.invalid input,.field.invalid select{border-color:var(--coral)}
.field .err{color:var(--coral);font-size:.78rem;margin-top:5px;display:none}
.field.invalid .err{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.consent{display:flex;gap:9px;align-items:flex-start;font-size:.86rem;color:var(--dim);margin:4px 0 18px;cursor:pointer;line-height:1.45}
.consent input{width:auto;margin:3px 0 0;accent-color:#8B7BF7}
.modal .btn-primary{width:100%;justify-content:center}
.form-note{font-family:var(--mono);font-size:.7rem;color:var(--faint);text-align:center;margin-top:14px;letter-spacing:.02em}
.form-msg{display:none;text-align:center;padding:18px 0 6px}
.form-msg.show{display:block}
.form-msg .ico{width:56px;height:56px;border-radius:50%;background:var(--grad-soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.form-msg.err .ico{background:rgba(255,130,102,.1)}
.form-msg h2{margin-bottom:6px}
.form-msg .btn{margin-top:18px}
.is-submitting{opacity:.6;pointer-events:none}
@media(max-width:560px){.grid2{grid-template-columns:1fr}.modal-card{padding:26px 20px}}

/* ---- contact / about ---- */
.contact-lbl{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:7px}
.contact-val{display:inline-block;font-family:var(--display);font-size:1.25rem;font-weight:500;color:var(--fg);line-height:1.35;letter-spacing:-.01em}
a.contact-val{transition:color .2s}
a.contact-val:hover{color:var(--teal)}

/* ---- leadership / people ---- */
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.person{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;transition:transform .25s var(--ease),border-color .25s,background .25s}
.person:hover{transform:translateY(-3px);border-color:var(--line-2);background:var(--panel-2)}
.person .pn{font-family:var(--display);font-weight:600;font-size:1.14rem;letter-spacing:-.01em;line-height:1.2}
.person .pr{font-family:var(--mono);font-size:.73rem;letter-spacing:.04em;color:var(--dim);margin-top:7px;line-height:1.45}
.person.lead{border-color:rgba(52,231,206,.22)}
.person.lead .pr{color:var(--teal)}
@media(max-width:980px){.people{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.people{grid-template-columns:1fr}}

/* ---- legal / prose ---- */
.legal{max-width:760px}
.legal h2{font-size:1.4rem;margin:40px 0 12px}
.legal p{color:var(--dim);line-height:1.7;margin-bottom:14px}
.legal ul{margin:0 0 14px;padding:0;list-style:none}
.legal ul li{color:var(--dim);line-height:1.6;padding:6px 0 6px 24px;position:relative}
.legal ul li::before{content:"";position:absolute;left:4px;top:15px;width:6px;height:6px;border-radius:50%;background:var(--grad)}
.legal a{color:var(--teal)}
.legal .eff{font-family:var(--mono);font-size:.8rem;color:var(--faint);letter-spacing:.04em;margin-bottom:30px}

/* ---- console: live status pill + success flash ---- */
.cstat{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.cstat .sd{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}
.cstat.run{color:var(--amber)}
.cstat.run .sd{animation:cpulse 1s ease-in-out infinite}
.cstat.done{color:#5BE3B0}
@keyframes cpulse{0%,100%{opacity:1}50%{opacity:.25}}
.console.flash{animation:cflash 1.2s var(--ease)}
@keyframes cflash{0%,100%{box-shadow:0 40px 120px -40px rgba(108,120,200,.5),inset 0 1px 0 rgba(255,255,255,.06)}30%{box-shadow:0 0 0 1px rgba(91,227,176,.55),0 0 44px -6px rgba(91,227,176,.5),inset 0 1px 0 rgba(255,255,255,.06)}}

/* ---- FAQ accordion + CTA band ---- */
.faq-group{margin-top:46px}
.faq-group:first-of-type{margin-top:6px}
.faq-group .sechead{margin-bottom:18px}
.qa{border:1px solid var(--line);border-radius:14px;background:var(--panel);margin:12px 0;overflow:hidden;transition:border-color .25s var(--ease),background .25s var(--ease)}
.qa[open]{border-color:rgba(52,231,206,.34);background:rgba(255,255,255,.045)}
.qa summary{list-style:none;cursor:pointer;padding:19px 56px 19px 22px;position:relative;font-family:var(--display);font-weight:600;font-size:1.05rem;line-height:1.45;color:var(--fg)}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:#fff}
.qa summary:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:8px}
.qa summary::before,.qa summary::after{content:"";position:absolute;top:50%;background:var(--teal);transition:opacity .28s var(--ease),transform .28s var(--ease)}
.qa summary::after{right:22px;width:13px;height:2px;margin-top:-1px}
.qa summary::before{right:27.5px;width:2px;height:13px;margin-top:-6.5px}
.qa[open] summary::before{opacity:0;transform:scaleY(0)}
.qa-body{padding:0 22px 22px;color:var(--dim);line-height:1.7;font-size:1rem;animation:qafade .35s var(--ease)}
.qa-body p{margin:0 0 12px}
.qa-body p:last-child,.qa-body ul:last-child{margin-bottom:0}
.qa-body ul{margin:8px 0 14px;padding-left:20px}
.qa-body li{margin:6px 0}
.qa-body strong{color:var(--fg);font-weight:600}
.qa-body code{font-family:var(--mono);font-size:.9em;background:rgba(255,255,255,.06);border:1px solid var(--line);padding:2px 8px;border-radius:6px;color:var(--teal)}
@keyframes qafade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.cta-band{border:1px solid var(--line);border-radius:var(--r-lg,22px);background:
  radial-gradient(120% 140% at 50% -20%,rgba(52,231,206,.10),transparent 60%),
  radial-gradient(120% 140% at 50% 120%,rgba(139,123,247,.12),transparent 60%),var(--panel);
  padding:54px 32px}
@media (prefers-reduced-motion:reduce){.qa-body{animation:none}.qa summary::before,.qa summary::after,.qa{transition:none}}

/* legal: subsection heading */
.legal h3{font-size:1.08rem;margin:26px 0 10px;color:var(--fg)}
