/* ============================================================
   CiviQ — shared design system
   Monochrome graphite + platinum/steel · glassmorphism · infrastructure-grade
   ============================================================ */

/* ---------- self-hosted fonts (drop .woff2 into /fonts) ----------
   Clash Display + Satoshi: free for commercial use (Fontshare).
   JetBrains Mono: OFL. All self-hosted — no CDN, works offline.
   If the files are absent, the system fallback stacks render cleanly. */
@font-face{ font-family:"Clash Display"; src:url("fonts/ClashDisplay-Medium.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap; }
@font-face{ font-family:"Clash Display"; src:url("fonts/ClashDisplay-Semibold.woff2") format("woff2");
  font-weight:600; font-style:normal; font-display:swap; }
@font-face{ font-family:"Clash Display"; src:url("fonts/ClashDisplay-Bold.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap; }
/* variable axis — lets the home hero hit an in-between weight (650) */
@font-face{ font-family:"Clash Display VF"; src:url("fonts/ClashDisplay-Variable.woff2") format("woff2");
  font-weight:200 700; font-style:normal; font-display:swap; }
@font-face{ font-family:"Satoshi"; src:url("fonts/Satoshi-Regular.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap; }
@font-face{ font-family:"Satoshi"; src:url("fonts/Satoshi-Medium.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap; }
@font-face{ font-family:"Satoshi"; src:url("fonts/Satoshi-Bold.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap; }
@font-face{ font-family:"JetBrains Mono"; src:url("fonts/JetBrainsMono-Regular.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap; }
@font-face{ font-family:"JetBrains Mono"; src:url("fonts/JetBrainsMono-Medium.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap; }

:root{
  --bg:#08080a; --bg-2:#0d0d10;
  --panel:rgba(255,255,255,.035);
  --ink:#f4f5f7; --ink-2:#b7bac2; --ink-3:#83868f;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.15);
  --ice:#cfe0f2; --steel:#8aa6c8;
  --grad:linear-gradient(120deg,#e8eef6,#aebfd6 45%,#7f93b4 100%);
  --grad-line:linear-gradient(90deg,transparent,rgba(207,224,242,.5),transparent);
  --surface:linear-gradient(180deg,#0b0b0d,#070708);
  --glow:rgba(170,191,214,.35);

  --font-display:"Clash Display", system-ui, "Segoe UI", sans-serif;
  --font-sans:"Satoshi", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --r:16px; --r-sm:10px; --r-lg:22px;
  --shell:1200px;
  --pad:clamp(64px,10vh,132px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-sans); line-height:1.7; font-size:16px;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}

/* ---------- ambient background ---------- */
.bg-layer{ position:fixed; inset:0; z-index:-3; pointer-events:none;
  background:
    radial-gradient(1000px 640px at 72% -8%, rgba(170,191,214,.06), transparent 60%),
    radial-gradient(820px 700px at 2% 14%, rgba(120,140,170,.07), transparent 55%),
    linear-gradient(180deg,#0a0a0c 0%, #08080a 45%, #060607 100%); }
.blob{ position:fixed; z-index:-2; pointer-events:none; border-radius:50%;
  filter:blur(80px); opacity:.5; will-change:transform; }
.blob.b1{ width:46vw; height:46vw; left:-12vw; top:-8vw;
  background:radial-gradient(circle at 50% 50%, rgba(150,168,196,.30), transparent 66%); animation:drift1 30s ease-in-out infinite; }
.blob.b2{ width:40vw; height:40vw; right:-10vw; top:8vh;
  background:radial-gradient(circle at 50% 50%, rgba(120,136,164,.24), transparent 66%); animation:drift2 36s ease-in-out infinite; }
.blob.b3{ width:52vw; height:52vw; left:24vw; top:128vh;
  background:radial-gradient(circle at 50% 50%, rgba(110,124,150,.20), transparent 66%); animation:drift3 42s ease-in-out infinite; }
@keyframes drift1{ 0%,100%{transform:translate(0,0)} 50%{transform:translate(5vw,4vh)} }
@keyframes drift2{ 0%,100%{transform:translate(0,0)} 50%{transform:translate(-5vw,5vh)} }
@keyframes drift3{ 0%,100%{transform:translate(0,0)} 50%{transform:translate(-4vw,-5vh)} }
.grain{ position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.035; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ---------- layout ---------- */
.shell{ max-width:var(--shell); margin:0 auto; padding:0 28px; }
.prose{ max-width:68ch; }
section{ scroll-margin-top:108px; }
.band{ padding:var(--pad) 0; }
.divider{ height:1px; max-width:var(--shell); margin:0 auto; background:var(--grad-line); }
.center{ text-align:center; }

a{ color:var(--steel); text-decoration:none; text-underline-offset:3px; }
a:hover{ text-decoration:underline; }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, summary:focus-visible{
  outline:2px solid var(--ice); outline-offset:3px; border-radius:4px; }

.skip{ position:absolute; left:-9999px; top:0; z-index:300; background:var(--ice); color:#0b0b0d;
  padding:10px 16px; font-family:var(--font-mono); font-size:.82rem; border-radius:0 0 8px 0; font-weight:500; }
.skip:focus{ left:0; top:0; }

/* ---------- typography ---------- */
.eyebrow{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-mono);
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-2);
  padding:7px 14px; border:1px solid var(--line-2); border-radius:999px; background:rgba(255,255,255,.03); }
.eyebrow .pip{ width:7px; height:7px; border-radius:50%; background:var(--ice); box-shadow:0 0 12px 2px var(--glow); }
.kicker{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--steel); margin:0 0 16px; max-width:none; }

h1,h2,h3{ font-family:var(--font-display); font-weight:600; color:#fff; text-wrap:balance; }
h1{ font-size:clamp(2.4rem,5.6vw,4.1rem); line-height:1.04; letter-spacing:-.03em; margin:22px 0 22px; }
h2{ font-size:clamp(1.7rem,3.4vw,2.5rem); line-height:1.12; letter-spacing:-.02em; margin:0 0 20px; }
h3{ font-size:1.12rem; line-height:1.25; letter-spacing:-.01em; margin:0 0 10px; }
.display-xl{ font-size:clamp(2.6rem,6.4vw,5rem); }
.grad-text{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.lede{ font-size:clamp(1.06rem,1.7vw,1.28rem); color:var(--ink-2); margin:0 0 32px; max-width:60ch; }
p{ margin:0 0 18px; max-width:72ch; } .muted{ color:var(--ink-3); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:.88rem; font-weight:500;
  padding:13px 20px; border-radius:11px; cursor:pointer; border:1px solid transparent; white-space:nowrap;
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s, background .25s, border-color .25s; }
.btn:hover{ text-decoration:none; } .btn:active{ transform:scale(.97); }
.btn-primary{ color:#0b0b0d; background:var(--grad); background-size:150% 150%; background-position:0% 50%;
  box-shadow:0 10px 34px -12px var(--glow), inset 0 1px 0 rgba(255,255,255,.5); }
.btn-primary:hover{ background-position:100% 50%; transform:translateY(-2px); box-shadow:0 18px 44px -12px var(--glow), inset 0 1px 0 rgba(255,255,255,.6); }
.btn-primary .ico{ display:inline-flex; transition:transform .25s cubic-bezier(.22,1,.36,1); }
.btn-primary:hover .ico{ transform:translateX(3px); }
.btn-ghost{ color:var(--ink); background:rgba(255,255,255,.04); border-color:var(--line-2); }
.btn-ghost:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.3); transform:translateY(-2px); }

/* ---------- nav ---------- */
.nav-wrap{ position:sticky; top:14px; z-index:200; padding:0 18px; }
.nav{ max-width:var(--shell); margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:11px 12px 11px 18px; border-radius:16px; border:1px solid var(--line-2);
  background:rgba(13,13,16,.62); backdrop-filter:blur(16px) saturate(140%); -webkit-backdrop-filter:blur(16px) saturate(140%);
  box-shadow:0 10px 40px -18px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.06); transition:background .3s, box-shadow .3s; }
.nav.scrolled{ background:rgba(10,10,13,.84); box-shadow:0 14px 50px -16px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.07); }
.brand{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600; font-size:1.06rem; letter-spacing:.005em; color:#fff; }
.brand .mark{ width:15px; height:15px; border-radius:5px; background:var(--grad); box-shadow:0 0 14px 1px var(--glow), inset 0 1px 0 rgba(255,255,255,.7); }
.nav-right{ display:flex; align-items:center; gap:8px; }
.nav-links{ display:flex; gap:2px; }
.nav-links a{ font-family:var(--font-mono); font-size:.82rem; color:var(--ink-2); padding:8px 12px; border-radius:8px; display:inline-flex; align-items:center; gap:6px; }
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.06); text-decoration:none; }
.nav-links a.active{ color:#fff; }
.nav-links a.active::after{ content:""; width:5px; height:5px; border-radius:50%; background:var(--ice); box-shadow:0 0 10px 1px var(--glow); }
.nav .btn{ padding:9px 15px; font-size:.8rem; }
.menu-toggle{ display:none; }

/* ---------- centered hero ---------- */
.hero-center{ text-align:center; display:flex; flex-direction:column; align-items:center;
  padding-top:clamp(40px,7vh,86px); padding-bottom:clamp(40px,6vh,72px); }
.hero-center .eyebrow{ margin-bottom:26px; }
.hero-center h1{ font-weight:600; margin:0 auto 24px; max-width:20ch; }
.hero-center h1.wide{ max-width:26ch; }
.hero-center .lede{ margin:0 auto 30px; max-width:60ch; }
.hero-center .hero-cta{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.hero-center .chips{ justify-content:center; }
.hero-center > *{ width:100%; }
/* thesis weight */
.thesis .big{ font-weight:600; }
/* home hero title: heavier + larger, per request (specificity beats .hero-center h1) */
.hero-center.hero-home h1{ font-family:"Clash Display VF","Clash Display",system-ui,sans-serif; font-weight:650; letter-spacing:-.035em; font-size:clamp(2.6rem,6.6vw,4.7rem); line-height:1.0; }

/* ---------- alternating two-column feature ---------- */
/* DOM stays text-first (a11y); .flip swaps columns visually on desktop only */
@media (min-width:681px){
  .bento.flip{ direction:rtl; }
  .bento.flip > *{ direction:ltr; }
}
.feature-media{ display:flex; }
.feature-media > *{ width:100%; }

/* ---------- admin console (governed response) ---------- */
.console{ max-width:940px; margin:0 auto; }
.console-body{ display:grid; grid-template-columns:184px 1fr; }
.console-rail{ border-right:1px solid var(--line); padding:16px 14px; display:flex; flex-direction:column; gap:4px; }
.console-rail .ri{ display:flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:.78rem; color:var(--ink-3);
  padding:9px 11px; border-radius:9px; }
.console-rail .ri.on{ color:#fff; background:rgba(255,255,255,.06); border:1px solid var(--line-2); }
.console-rail .ri .dot{ width:7px; height:7px; border-radius:50%; background:var(--steel); flex:0 0 auto; }
.console-rail .ri.on .dot{ background:var(--ice); box-shadow:0 0 10px 1px var(--glow); }
.console-rail .rail-cap{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); padding:6px 11px 4px; }
.console-main{ padding:22px 22px 24px; }
@media (max-width:640px){
  .console-body{ grid-template-columns:1fr; }
  .console-rail{ flex-direction:row; flex-wrap:wrap; border-right:0; border-bottom:1px solid var(--line); gap:6px; }
  .console-rail .rail-cap{ display:none; }
}

/* ---------- pills as a framed creative asset ---------- */
.asset-box{ position:relative; border:1px solid var(--line-2); border-radius:var(--r-lg); padding:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.012));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 26px 60px -34px rgba(0,0,0,.8); overflow:hidden; }
.asset-box::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; pointer-events:none;
  background:var(--grad-line); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.5; }
.asset-cap{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin:0 0 16px; display:flex; align-items:center; gap:8px; }
.asset-cap .dot{ width:7px; height:7px; border-radius:50%; background:var(--ice); box-shadow:0 0 10px 1px var(--glow); }
.asset-box .chip{ font-size:.82rem; }

/* scattered, irregular pill stack with gentle float */
.scatter{ position:relative; min-height:300px; }
.scatter .chip{ position:absolute; white-space:nowrap; box-shadow:0 14px 30px -18px rgba(0,0,0,.8); }
.scatter .float{ animation:floaty 7s ease-in-out infinite; }
@keyframes floaty{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-8px) } }

/* commodity vs moat stack */
.stackviz{ display:flex; flex-direction:column; gap:12px; }
.stackviz .row{ border:1px solid var(--line); border-radius:12px; padding:14px 16px; font-family:var(--font-mono); font-size:.84rem; color:var(--ink-2);
  display:flex; align-items:center; justify-content:space-between; gap:10px; background:rgba(255,255,255,.02); }
.stackviz .row.dim{ color:var(--ink-3); }
.stackviz .row.moat{ border-color:var(--line-2); background:linear-gradient(180deg,rgba(170,191,214,.1),rgba(138,166,200,.04)); color:#fff;
  box-shadow:0 0 30px -10px var(--glow); }
.stackviz .row .t{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.stackviz .row.moat .t{ color:var(--ice); }

/* ---------- glass card / bento ---------- */
.bento{ display:grid; grid-template-columns:repeat(12,1fr); gap:18px; }
.card{ position:relative; border-radius:var(--r); border:1px solid var(--line); padding:26px; overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05); transition:transform .4s cubic-bezier(.22,1,.36,1), border-color .3s, box-shadow .4s; }
.card::before{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; opacity:0; transition:opacity .35s;
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,0%), rgba(170,191,214,.14), transparent 45%); }
.card::after{ content:""; position:absolute; left:0; right:0; top:0; height:1px; pointer-events:none; opacity:0; transition:opacity .35s; background:var(--grad-line); }
.card:hover{ border-color:var(--line-2); box-shadow:0 26px 60px -30px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.08); }
.card:hover::before{ opacity:1; } .card:hover::after{ opacity:.9; }
.card .cardhead{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.card .cnum{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-3); letter-spacing:.06em; }
.card .cmark{ font-family:var(--font-mono); font-size:.9rem; color:var(--steel); }
.card h3{ margin-bottom:9px; } .card p{ color:var(--ink-2); font-size:.96rem; margin:0; }
.c-3{grid-column:span 3} .c-4{grid-column:span 4} .c-5{grid-column:span 5} .c-6{grid-column:span 6} .c-7{grid-column:span 7} .c-8{grid-column:span 8} .c-12{grid-column:span 12}

/* ---------- chips / stat row ---------- */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:.78rem; color:var(--ink-2);
  padding:8px 14px; border-radius:999px; border:1px solid var(--line-2); background:rgba(255,255,255,.03); }
.chip .pip{ width:6px; height:6px; border-radius:50%; background:var(--steel); }
.statrow{ display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:18px; }
.stat .num{ font-family:var(--font-mono); font-size:clamp(1.6rem,3vw,2.3rem); color:#fff; letter-spacing:-.02em; }
.stat .lbl{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-top:4px; }

/* ---------- evidence panel ---------- */
.evidence{ position:relative; border-radius:var(--r-lg); border:1px solid var(--line-2); overflow:hidden;
  background:linear-gradient(180deg,rgba(20,21,25,.9),rgba(9,9,12,.92));
  backdrop-filter:blur(12px) saturate(140%); -webkit-backdrop-filter:blur(12px) saturate(140%);
  box-shadow:0 30px 70px -28px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.08); }
.evidence::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; pointer-events:none;
  background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.4; }
.ev-bar{ display:flex; align-items:center; gap:8px; padding:13px 16px; border-bottom:1px solid var(--line); }
.tdot{ width:11px; height:11px; border-radius:50%; background:#2b2c30; }
.ev-title{ margin-left:8px; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em; color:var(--ink-3); }
.ev-body{ padding:20px 18px 22px; font-family:var(--font-mono); font-size:.88rem; line-height:1.6; }
.ev-q{ color:var(--ink-3); } .ev-q b{ color:#fff; font-weight:500; }
.ev-a{ color:var(--ink-2); margin-top:12px; }
.ev-checks{ display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.tick{ display:inline-flex; align-items:center; gap:7px; font-size:.74rem; color:#dfe9f4; padding:6px 11px; border-radius:8px;
  background:rgba(170,191,214,.1); border:1px solid rgba(170,191,214,.25); }
.tick .c{ color:var(--ice); }
.ev-source{ display:inline-flex; align-items:center; gap:8px; margin-top:14px; padding:6px 11px; border-radius:8px;
  background:rgba(255,255,255,.04); border:1px solid var(--line-2); color:var(--ink-2); font-size:.76rem; }
.ev-source .pip{ width:6px; height:6px; border-radius:50%; background:var(--steel); }
.ev-audit{ margin-top:16px; padding-top:14px; border-top:1px dashed var(--line-2); color:var(--ink-3); font-size:.74rem; word-break:break-all; }
.ev-audit .k{ color:var(--steel); }

/* ---------- pipeline ---------- */
.flow{ position:relative; margin:0; padding-left:8px; }
.flow::before{ content:""; position:absolute; left:21px; top:10px; bottom:10px; width:2px;
  background:linear-gradient(180deg,rgba(207,224,242,0),rgba(207,224,242,.5) 12%,rgba(138,166,200,.5) 88%,rgba(138,166,200,0)); }
.step{ position:relative; display:grid; grid-template-columns:44px 1fr; gap:16px; align-items:flex-start; padding:11px 0; }
.node{ position:relative; z-index:1; width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:.78rem; color:#dfe9f4; border:1px solid var(--line-2);
  background:linear-gradient(180deg,rgba(22,23,27,.95),rgba(12,12,16,.95)); box-shadow:inset 0 1px 0 rgba(255,255,255,.06); }
.step.gate .node{ border-color:rgba(207,224,242,.5); box-shadow:0 0 22px -4px var(--glow), inset 0 1px 0 rgba(255,255,255,.08); }
.step .sname{ font-family:var(--font-mono); font-size:.96rem; color:#fff; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.tag{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; padding:3px 8px; border-radius:999px;
  color:#dfe9f4; background:rgba(170,191,214,.1); border:1px solid rgba(170,191,214,.3); }
.step .sdesc{ color:var(--ink-2); font-size:.94rem; margin-top:4px; }

/* ---------- comparison table ---------- */
.table-card{ border:1px solid var(--line); border-radius:var(--r); overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)); }
.table-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
table{ border-collapse:collapse; width:100%; min-width:680px; font-size:.92rem; }
caption{ text-align:left; font-family:var(--font-mono); font-size:.76rem; color:var(--ink-3); padding:16px 18px 0; }
th,td{ text-align:left; padding:15px 18px; border-bottom:1px solid var(--line); vertical-align:top; }
thead th{ font-family:var(--font-mono); font-weight:500; font-size:.78rem; letter-spacing:.04em; color:var(--ink-2); border-bottom:1px solid var(--line-2); }
thead th.civiq-h span{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:600; }
tbody th{ font-family:var(--font-sans); font-weight:500; color:var(--ink); }
tbody td{ color:var(--ink-3); }
td.civiq{ color:#eef4fb; font-family:var(--font-mono); font-size:.85rem; }
col.civiq-col{ background:linear-gradient(180deg,rgba(170,191,214,.08),rgba(138,166,200,.04)); }
td.civiq .c{ color:var(--ice); margin-right:7px; }
tbody tr:last-child th, tbody tr:last-child td{ border-bottom:0; }

/* ---------- thesis band ---------- */
.thesis{ position:relative; text-align:center; padding:clamp(88px,16vh,180px) 0; }
.thesis::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(720px 360px at 50% 40%, rgba(170,191,214,.1), transparent 62%); }
.thesis .big{ position:relative; font-family:var(--font-display); font-weight:600; letter-spacing:-.02em; line-height:1.12;
  font-size:clamp(1.9rem,4.6vw,3.3rem); color:#fff; margin:0 auto 24px; max-width:18ch; }
.thesis .sub{ position:relative; color:var(--ink-2); max-width:62ch; margin:0 auto; font-size:1.05rem; }

/* ---------- two-column glass panel ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.panel{ border:1px solid var(--line-2); border-radius:var(--r); padding:clamp(24px,3vw,36px);
  background:var(--panel); box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.panel h4{ font-family:var(--font-mono); font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; margin:0 0 16px; }
.panel.built h4{ color:var(--ice); } .panel.next h4{ color:var(--ink-3); }
.clist{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.clist li{ display:flex; gap:11px; font-size:.95rem; color:var(--ink-2); }
.clist .gm{ flex:0 0 auto; font-family:var(--font-mono); font-size:.88rem; }
.built .gm{ color:var(--ice); } .next .gm{ color:var(--ink-3); }

/* ---------- tenets (numbered) ---------- */
.tenets{ list-style:none; counter-reset:t; margin:0; padding:0; display:grid; gap:2px; }
.tenets li{ counter-increment:t; display:grid; grid-template-columns:72px 1fr; gap:20px; align-items:baseline; padding:22px 0; border-top:1px solid var(--line); }
.tenets li:first-child{ border-top:0; }
.tenets li::before{ content:counter(t,decimal-leading-zero); font-family:var(--font-mono); font-size:1.05rem; color:var(--steel); }
.tenet-h{ font-family:var(--font-display); font-weight:600; color:#fff; font-size:1.25rem; letter-spacing:-.01em; margin:0 0 6px; }
.tenet-p{ color:var(--ink-2); margin:0; font-size:.98rem; }

/* ---------- accordion ---------- */
.acc{ border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.acc details{ border-top:1px solid var(--line); }
.acc details:first-child{ border-top:0; }
.acc summary{ list-style:none; cursor:pointer; padding:20px 22px; font-family:var(--font-mono); font-size:.96rem; color:#fff;
  display:flex; justify-content:space-between; align-items:center; gap:16px; }
.acc summary::-webkit-details-marker{ display:none; }
.acc summary .pm{ color:var(--steel); transition:transform .3s; flex:0 0 auto; }
.acc details[open] summary .pm{ transform:rotate(45deg); }
.acc .acc-body{ padding:0 22px 20px; color:var(--ink-2); font-size:.96rem; }

/* ---------- contact form ---------- */
.form-grid{ display:grid; gap:14px; }
.field{ display:grid; gap:7px; }
.field label{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em; color:var(--ink-2); }
.field input, .field textarea{ width:100%; font-family:var(--font-sans); font-size:.95rem; color:var(--ink);
  background:rgba(255,255,255,.04); border:1px solid var(--line-2); border-radius:10px; padding:12px 14px; transition:border-color .2s, background .2s; }
.field input::placeholder, .field textarea::placeholder{ color:#6a6d75; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--steel); background:rgba(255,255,255,.06); }
.field textarea{ resize:vertical; min-height:96px; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-status{ font-family:var(--font-mono); font-size:.82rem; min-height:1.2em; }
.form-status.ok{ color:var(--ice); } .form-status.err{ color:#e6a3a3; }

/* ---------- timeline / roadmap ---------- */
.roadmap-note{ margin-top:24px; padding-top:20px; border-top:1px solid var(--line); color:var(--ink-3); font-size:.95rem; }

/* ---------- footer ---------- */
footer.site{ padding:clamp(58px,9vh,92px) 0 48px; border-top:1px solid var(--line);
  background:linear-gradient(180deg,transparent,rgba(170,191,214,.03)); margin-top:40px; }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; }
.foot-brand{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600; color:#fff; font-size:1.1rem; margin-bottom:14px; }
.foot-brand .mark{ width:14px; height:14px; border-radius:5px; background:var(--grad); }
.foot-pos{ color:var(--ink-3); font-size:.92rem; max-width:34ch; }
.foot-attrib{ font-family:var(--font-mono); font-size:.78rem; color:var(--ink-3); line-height:1.7; max-width:60ch; margin:18px 0 0; }
.foot-col h5{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); margin:0 0 14px; }
.foot-col a{ display:block; color:var(--ink-3); font-size:.9rem; padding:5px 0; }
.foot-col a:hover{ color:#fff; }
.foot-meta{ display:flex; flex-wrap:wrap; gap:10px; margin-top:34px; padding-top:24px; border-top:1px solid var(--line); }
.foot-copy{ font-family:var(--font-mono); font-size:.74rem; color:#5d6068; letter-spacing:.03em; margin-top:18px; }

/* ---------- reveal ---------- */
.reveal{ opacity:1; }
html.js .reveal{ opacity:0; transform:translateY(18px); filter:blur(6px);
  transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1), filter .7s; }
html.js .reveal.in{ opacity:1; transform:none; filter:none; }
html.js .reveal.snap{ transition:none !important; opacity:1 !important; transform:none !important; filter:none !important; }

/* ============================================================
   Animated governed-response demo (desktop app ⇄ phone app)
   ============================================================ */
.demo-wrap{ width:min(70vw,1060px); margin:0 auto; }
.demo-app{ position:relative; border:1px solid var(--line-2); border-radius:16px; overflow:hidden;
  background:linear-gradient(180deg,rgba(20,22,27,.96),rgba(9,10,13,.97));
  box-shadow:0 44px 100px -34px rgba(0,0,0,.92), inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter:blur(12px) saturate(140%); -webkit-backdrop-filter:blur(12px) saturate(140%); }
.demo-app::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; pointer-events:none; z-index:3;
  background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.4; }

.app-bar{ display:flex; align-items:center; gap:10px; padding:12px 16px; border-bottom:1px solid var(--line); position:relative; }
.app-bar .lights{ display:flex; gap:7px; flex:0 0 auto; }
.app-bar .lights i{ width:11px; height:11px; border-radius:50%; background:#2b2c30; display:block; }
.app-bar .title{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-3); letter-spacing:.04em; }
.app-bar .winbtns{ margin-left:auto; font-family:var(--font-mono); font-size:.8rem; color:var(--ink-3); letter-spacing:.18em; }
.app-bar .ph-time, .app-bar .ph-sig{ display:none; font-family:var(--font-mono); font-size:.76rem; color:var(--ink-2); }

.chat{ display:grid; grid-template-columns:1fr 312px; gap:16px 18px; padding:22px;
  grid-template-areas:"user agents" "bot agents" "compose agents"; align-items:start; }
.msg{ max-width:90%; font-size:.92rem; line-height:1.55; padding:12px 15px; border-radius:15px;
  opacity:0; transform:translateY(8px); transition:opacity .45s ease, transform .45s cubic-bezier(.22,1,.36,1); }
.msg.show{ opacity:1; transform:none; }
.msg .role{ display:block; font-family:var(--font-mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:5px; }
.msg.user{ grid-area:user; justify-self:end; background:var(--grad); color:#0b0b0d; border-bottom-right-radius:5px; }
.msg.user .role{ color:rgba(11,11,13,.6); }
.msg.bot{ grid-area:bot; justify-self:start; background:rgba(255,255,255,.045); border:1px solid var(--line); color:var(--ink-2); border-bottom-left-radius:5px; }
.msg.bot .role{ color:var(--steel); }
.msg .body{ font-family:var(--font-sans); }
.msg.user .body{ font-weight:500; }
.msg .ev-checks{ display:flex; flex-wrap:wrap; gap:7px; margin-top:12px; }
.msg .tick{ font-size:.72rem; }
.msg .ev-source{ margin-top:11px; }
.msg .ev-audit{ margin-top:12px; }
.reveal-soft{ opacity:0; transform:translateY(5px); transition:opacity .4s, transform .4s; }
.reveal-soft.on{ opacity:1; transform:none; }

.agents{ grid-area:agents; border:1px solid var(--line); border-radius:13px; background:rgba(255,255,255,.02);
  padding:14px 13px; align-self:stretch; opacity:.5; transition:opacity .4s; }
.agents.live{ opacity:1; }
.ag-cap{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3);
  display:flex; align-items:center; gap:9px; margin-bottom:12px; }
.ag-cap .dot{ width:7px; height:7px; border-radius:50%; background:var(--ink-3); flex:0 0 auto; }
.agents.live .ag-cap .dot{ background:var(--ice); box-shadow:0 0 10px 1px var(--glow); animation:pulse 1.4s ease-in-out infinite; }
@keyframes pulse{ 50%{ opacity:.4 } }
.ag-list{ display:flex; flex-direction:column; gap:1px; }
.ag{ display:flex; align-items:center; gap:10px; padding:7px 8px; border-radius:8px; font-family:var(--font-mono); font-size:.75rem;
  color:var(--ink-3); opacity:.45; transition:opacity .3s, color .3s, background .3s; }
.ag .nd{ width:15px; height:15px; border-radius:50%; border:1px solid var(--line-2); flex:0 0 auto; position:relative;
  display:flex; align-items:center; justify-content:center; font-size:.62rem; color:var(--ice); }
.ag .nm{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ag .st{ margin-left:auto; font-size:.66rem; color:var(--ink-3); opacity:0; transition:opacity .3s; white-space:nowrap; }
.ag.active{ opacity:1; color:#fff; background:rgba(255,255,255,.05); }
.ag.active .nd{ border-color:var(--ice); }
.ag.active .nd::after{ content:""; position:absolute; inset:-1px; border-radius:50%; border:1.5px solid transparent;
  border-top-color:var(--ice); animation:spin .7s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg) } }
.ag.done{ opacity:1; color:var(--ink-2); }
.ag.done .nd{ border-color:rgba(170,191,214,.55); background:rgba(170,191,214,.12); }
.ag.done .st{ opacity:1; color:var(--steel); }
.ag.gate.done .nd{ border-color:var(--ice); box-shadow:0 0 10px -2px var(--glow); }

.composer{ grid-area:compose; display:flex; align-items:center; gap:10px; padding-top:6px; }
.cinput{ flex:1; position:relative; min-height:44px; display:flex; align-items:center; gap:1px; padding:11px 14px;
  background:rgba(255,255,255,.05); border:1px solid var(--line-2); border-radius:11px; font-family:var(--font-sans); font-size:.92rem; color:#fff; }
.cinput .cph{ position:absolute; left:14px; color:#6a6d75; pointer-events:none; transition:opacity .2s; }
.cinput.typing .cph, .cinput.filled .cph{ opacity:0; }
.tcaret{ display:inline-block; width:2px; height:1.05em; background:var(--ice); margin-left:1px; opacity:0; }
.cinput.typing .tcaret{ opacity:1; animation:blink 1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0 } }
.csend{ width:44px; height:44px; flex:0 0 auto; border:none; border-radius:11px; cursor:pointer; color:#0b0b0d;
  background:var(--grad); display:flex; align-items:center; justify-content:center; font-size:1.05rem;
  box-shadow:0 8px 22px -10px var(--glow); transition:transform .2s; }
.csend:active{ transform:scale(.92); }

.demo-replay{ display:block; margin:18px auto 0; font-family:var(--font-mono); font-size:.78rem; color:var(--ink-2);
  background:rgba(255,255,255,.04); border:1px solid var(--line-2); border-radius:9px; padding:8px 16px; cursor:pointer; transition:background .2s, color .2s; }
.demo-replay:hover{ background:rgba(255,255,255,.08); color:#fff; }

/* phone-app form factor */
@media (max-width:767px){
  .demo-wrap{ width:100%; max-width:430px; }
  .demo-app{ border-radius:34px; padding:8px; }
  .app-bar{ border-bottom:0; padding:10px 18px 8px; }
  .app-bar .lights, .app-bar .winbtns{ display:none; }
  .app-bar .ph-time{ display:block; flex:0 0 auto; }
  .app-bar .title{ position:absolute; left:50%; transform:translateX(-50%); font-size:.7rem; color:var(--ink-2); }
  .app-bar .ph-sig{ display:block; margin-left:auto; letter-spacing:.05em; }
  .chat{ display:flex; flex-direction:column; gap:12px; padding:6px 14px 16px; }
  .msg{ max-width:88%; }
  .agents{ order:0; opacity:1; background:rgba(255,255,255,.03); }
  .composer{ position:sticky; bottom:0; padding:10px 0 4px; background:linear-gradient(180deg,rgba(9,10,13,0),rgba(9,10,13,.9) 30%); }
}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .foot-top{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; }
  .c-3,.c-4,.c-5,.c-6,.c-7,.c-8{ grid-column:span 6; }
}
@media (max-width:680px){
  .nav-links{ display:none; }
  .nav-links.open{ display:flex; position:absolute; top:64px; right:18px; left:18px; flex-direction:column; padding:10px; gap:2px;
    border-radius:14px; border:1px solid var(--line-2); background:rgba(10,10,13,.96);
    backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); box-shadow:0 20px 50px -16px rgba(0,0,0,.9); }
  .nav-links.open a{ padding:12px 14px; font-size:.92rem; }
  .menu-toggle{ display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:10px;
    border:1px solid var(--line-2); background:rgba(255,255,255,.04); cursor:pointer; }
  .menu-toggle .bars, .menu-toggle .bars::before, .menu-toggle .bars::after{ content:""; display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; position:relative; transition:transform .3s, opacity .3s; }
  .menu-toggle .bars::before{ position:absolute; top:-6px; } .menu-toggle .bars::after{ position:absolute; top:6px; }
  .menu-toggle[aria-expanded="true"] .bars{ background:transparent; }
  .menu-toggle[aria-expanded="true"] .bars::before{ transform:translateY(6px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] .bars::after{ transform:translateY(-6px) rotate(-45deg); }
  .c-3,.c-4,.c-5,.c-6,.c-7,.c-8,.c-12{ grid-column:span 12; }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .tenets li{ grid-template-columns:48px 1fr; gap:14px; }
  h1{ font-size:clamp(2.1rem,8.6vw,2.9rem); }
}
@media (max-width:420px){ .foot-top{ grid-template-columns:1fr; } }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *, *::before, *::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  html.js .reveal{ opacity:1; transform:none; filter:none; }
}
@media (prefers-reduced-transparency: reduce){
  .nav, .nav-links.open, .evidence, .panel, .acc{ backdrop-filter:none; -webkit-backdrop-filter:none; background:#0e0e12; }
}
