/* =========================================================================
   CONSTRAINT DYNAMICS — NEXT ORGANIZATION/FUNDING DRAFT
   The Proof Observatory
   ---
   Design intent: a premium, observatory-grade infrastructure surface.
   Cinematic but bounded. Ambient field, signed events drifting in depth,
   trust-field cursor, scroll rail, HUD metadata. Theory-site craft level,
   funding-grade voice.
   ========================================================================= */

/* ─── Tokens ──────────────────────────────────────────────────────────── */
:root {
  /* Surfaces */
  --bg: #020209;
  --s0: #04040b;
  --s1: #08081a;
  --s2: #0d0d23;
  --s3: #14142d;

  /* Brand accents (kept consistent with theory site) */
  --gold: #c8a96e;
  --gold-bright: #e8c988;
  --gold-glow: #f5dfa0;
  --teal: #4ecdc4;
  --teal-deep: #2a9b94;
  --ember: #e8724a;
  --violet: #9b91e0;
  --green: #7bdcb5;
  --amber: #dfae52;

  /* Text */
  --txt: #ede9e0;
  --txt-2: #b8b4ae;
  --txt-3: #8a8580;
  --txt-4: #5a5666;
  --txt-5: #36344a;

  /* Glass + lines */
  --glass: rgba(255, 255, 255, 0.022);
  --glass-2: rgba(255, 255, 255, 0.04);
  --b-1: rgba(255, 255, 255, 0.05);
  --b-2: rgba(255, 255, 255, 0.09);
  --b-3: rgba(255, 255, 255, 0.16);
  --b-gold: rgba(200, 169, 110, 0.22);
  --b-gold-strong: rgba(200, 169, 110, 0.42);
  --b-teal: rgba(78, 205, 196, 0.24);
  --b-violet: rgba(155, 145, 224, 0.28);
  --b-ember: rgba(232, 114, 74, 0.30);

  /* Type */
  --serif: "Cinzel", "Trajan Pro", Georgia, serif;
  --display: "Cinzel", "Trajan Pro", Georgia, serif;
  --narr: "Fraunces", "Iowan Old Style", Georgia, serif;
  --mono: "JetBrains Mono", "DM Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --label: "DM Mono", "JetBrains Mono", ui-monospace, monospace;

  /* Layout */
  --maxw: 1180px;
  --pad: 32px;
  --r: 14px;
  --r-2: 22px;

  /* Motion */
  --ease: cubic-bezier(.2,.8,.2,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
*::before, *::after { box-sizing: border-box; }

::selection { background: rgba(200, 169, 110, 0.22); color: var(--txt); }

html {
  scroll-behavior: smooth;
  font-size: 16px;
  background: var(--bg);
  overflow-x: hidden;
}

body {
  background: var(--bg);
  color: var(--txt-2);
  font-family: var(--narr);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.65;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ─── Ambient field (the proof observatory) ───────────────────────────── */

/* persistent ambient gradient floor */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 720px 520px at 8% 4%, rgba(200,169,110,.06), transparent 65%),
    radial-gradient(ellipse 620px 440px at 92% 12%, rgba(78,205,196,.04), transparent 62%),
    radial-gradient(ellipse 880px 600px at 50% 105%, rgba(155,145,224,.028), transparent 70%);
}

/* CRT scanlines, very subtle */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9000;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent 0,
    transparent 2px,
    rgba(0,0,0,.018) 2px,
    rgba(0,0,0,.018) 4px
  );
  mix-blend-mode: multiply;
}

/* film grain layer */
.grain {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: .015;
}
.grain::before {
  content: "";
  position: absolute;
  inset: -200%;
  width: 400%;
  height: 400%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  animation: grain-shift .42s steps(8) infinite;
}
@keyframes grain-shift {
  0%   { transform: translate(0, 0); }
  50%  { transform: translate(-5%, 4%); }
  100% { transform: translate(0, 0); }
}

/* full-page proof field canvas (background WebGL) */
.proof-field {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: .55;
}

/* faint horizon line — anchors every section */
.horizon {
  position: fixed;
  left: 0; right: 0;
  top: 50vh;
  height: 1px;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,0.08) 35%, rgba(78,205,196,0.06) 65%, transparent);
  opacity: .55;
}

/* ─── Cursor aura (trust-field) ───────────────────────────────────────── */
.aura, .aura-trail {
  position: fixed;
  left: 0; top: 0;
  border-radius: 50%;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: 0;
  transition: opacity .55s var(--ease);
  will-change: transform, opacity;
}
.aura {
  width: 520px; height: 520px;
  z-index: 9998;
  background: radial-gradient(circle at 50% 50%,
    rgba(200,169,110,0.13) 0%,
    rgba(78,205,196,0.06) 28%,
    rgba(155,145,224,0.03) 50%,
    transparent 64%);
}
.aura-trail {
  width: 160px; height: 160px;
  z-index: 9999;
  background: radial-gradient(circle at 50% 50%,
    rgba(78,205,196,0.18) 0%,
    rgba(255,244,212,0.05) 42%,
    transparent 72%);
}

@media (hover: none), (prefers-reduced-motion: reduce) {
  .aura, .aura-trail { display: none; }
}

/* ─── Scroll progress ─────────────────────────────────────────────────── */
.progress {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 2px;
  z-index: 1001;
  background: rgba(255,255,255,.04);
}
.progress > i {
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold-bright) 35%, var(--teal) 75%, var(--violet) 100%);
  box-shadow: 0 0 14px rgba(200,169,110,.5);
  transition: width .12s linear;
}

/* ─── Section rail (right edge dots) ──────────────────────────────────── */
.rail {
  position: fixed;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 800;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-end;
}
.rail button {
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px 0;
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(232,228,223,0.32);
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  transition: color .3s var(--ease);
}
.rail button:hover { color: var(--txt); }
.rail button .lbl {
  opacity: 0;
  min-width: 64px;
  text-align: right;
  transition: opacity .3s var(--ease);
}
.rail button.on { color: var(--gold); }
.rail button.on .lbl { opacity: 1; }
.rail button .bar {
  width: 6px;
  height: 1px;
  background: currentColor;
  transition: width .3s var(--ease);
}
.rail button.on .bar { width: 24px; }
.rail button .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  border: 1px solid rgba(232,228,223,0.3);
  background: transparent;
  transition: all .3s var(--ease);
}
.rail button.on .dot {
  background: var(--gold);
  border-color: var(--gold);
  box-shadow: 0 0 12px rgba(200,169,110,.55);
}
@media (max-width: 880px) { .rail { display: none; } }

/* ─── Navigation ──────────────────────────────────────────────────────── */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 60px;
  z-index: 500;
  display: flex;
  align-items: center;
  padding: 0 28px;
  background: rgba(2,2,9,0.78);
  backdrop-filter: blur(28px) saturate(1.4);
  -webkit-backdrop-filter: blur(28px) saturate(1.4);
  border-bottom: .5px solid var(--b-1);
}
.nav::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.16) 50%, transparent);
  pointer-events: none;
}
.nav-brand { display: flex; align-items: center; gap: 12px; }
.nav-mark {
  width: 18px; height: 18px;
  position: relative;
}
.nav-mark::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, var(--gold) 0%, transparent 70%);
  filter: drop-shadow(0 0 8px rgba(200,169,110,.55));
  animation: markBreath 5s ease-in-out infinite;
}
.nav-mark::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  border: 1px solid rgba(200,169,110,.5);
}
@keyframes markBreath {
  0%, 100% { opacity: .6; transform: scale(1); }
  50%      { opacity: 1;  transform: scale(1.06); }
}
.nav-name {
  font-family: var(--display);
  font-size: 14px;
  font-weight: 400;
  letter-spacing: .2em;
  color: var(--txt);
}
.nav-tag {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .14em;
  color: var(--txt-4);
  background: rgba(200,169,110,.06);
  border: .5px solid rgba(200,169,110,.16);
  padding: 2px 8px;
  border-radius: 5px;
  text-transform: uppercase;
}
.nav-links {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav-links a {
  font-family: var(--label);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--txt-3);
  padding: 7px 13px;
  border-radius: 7px;
  transition: color .2s, background .2s;
}
.nav-links a:hover { color: var(--txt); background: rgba(255,255,255,.04); }
.nav-links a[aria-current="page"] { color: var(--txt); background: rgba(255,255,255,.045); }
.nav-cta {
  color: var(--gold) !important;
  background: rgba(200,169,110,.06) !important;
  border: .5px solid rgba(200,169,110,.28);
  margin-left: 8px;
}
.nav-cta:hover { background: rgba(200,169,110,.12) !important; border-color: rgba(200,169,110,.44); }
.nav-status {
  display: flex; align-items: center; gap: 7px;
  margin-left: 14px;
  font-family: var(--label);
  font-size: 9.5px; letter-spacing: .07em;
  color: var(--txt-3);
}
.nav-status .pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 7px rgba(123,220,181,.6);
  animation: pulse 3s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: .6; }
  50%      { opacity: 1; }
}

.menu-btn {
  display: none;
  background: rgba(255,255,255,.04);
  border: .5px solid var(--b-1);
  color: var(--txt-2);
  padding: 7px 14px;
  border-radius: 8px;
  font-family: var(--label);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
}

/* ─── Layout ──────────────────────────────────────────────────────────── */
main { position: relative; z-index: 2; }

.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--pad);
  position: relative;
}
.wrap.narrow { max-width: 880px; }
.wrap.wide   { max-width: 1280px; }

.section {
  padding: 110px 0;
  position: relative;
  z-index: 2;
}
.section.tight { padding: 70px 0; }

.divline {
  height: .5px;
  background: linear-gradient(90deg, transparent, var(--b-2) 50%, transparent);
  margin: 0 auto;
  max-width: var(--maxw);
}

/* ─── Type primitives ─────────────────────────────────────────────────── */
.eye {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--txt-4);
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 14px;
}
.eye::before {
  content: "⬡";
  color: var(--gold);
  opacity: .8;
  font-size: 11px;
}
.eye.no-mark::before { content: ""; display: none; }

h1, h2, h3, h4 { font-family: var(--display); color: var(--txt); font-weight: 300; letter-spacing: .04em; }
h1 { font-size: clamp(40px, 6.4vw, 84px); line-height: 1.04; letter-spacing: .025em; }
h2 { font-size: clamp(26px, 3.8vw, 44px); line-height: 1.12; }
h3 { font-size: clamp(18px, 2.4vw, 24px); line-height: 1.25; }
h4 { font-size: 15px; letter-spacing: .08em; line-height: 1.35; }

h1 .gold, h2 .gold, h3 .gold { color: var(--gold); font-weight: 400; }
h1 em, h2 em { font-style: italic; color: var(--gold); font-weight: 300; }

p {
  font-family: var(--narr);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.78;
  color: var(--txt-2);
  max-width: 64ch;
}
p strong { color: var(--txt); font-weight: 400; }
p em { color: var(--gold); font-style: italic; font-weight: 300; }
p.lede {
  font-size: clamp(17px, 1.8vw, 21px);
  line-height: 1.7;
  color: var(--txt);
  font-weight: 200;
  max-width: 60ch;
}

.lbl {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--txt-4);
  font-weight: 500;
}

.section-eye {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: var(--txt-4);
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}
.section-eye::before {
  content: "";
  width: 24px;
  height: .5px;
  background: var(--gold);
  opacity: .7;
}
.section-eye .num { color: var(--gold); font-weight: 500; }

/* ─── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 26px;
  border-radius: 100px;
  font-family: var(--label);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform .35s var(--ease), background .25s, border-color .25s, box-shadow .25s, color .25s;
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}
.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 35%, rgba(255,255,255,.08) 50%, transparent 65%);
  transform: translateX(-100%);
  pointer-events: none;
}
.btn:hover::after { animation: shimmer .8s var(--ease); }
@keyframes shimmer { to { transform: translateX(180%); } }

.btn-primary {
  background: linear-gradient(135deg, rgba(200,169,110,.22), rgba(200,169,110,.09));
  border-color: rgba(200,169,110,.5);
  color: var(--gold-bright);
  box-shadow: 0 0 0 0 rgba(200,169,110,0), inset 0 1px 0 rgba(255,255,255,.06);
}
.btn-primary:hover {
  background: linear-gradient(135deg, rgba(200,169,110,.32), rgba(200,169,110,.16));
  border-color: rgba(200,169,110,.7);
  box-shadow: 0 8px 36px rgba(200,169,110,.18);
  transform: translateY(-1px);
}
.btn-primary .arrow { transition: transform .3s; }
.btn-primary:hover .arrow { transform: translateX(3px); }

.btn-ghost {
  background: rgba(255,255,255,.025);
  border-color: var(--b-2);
  color: var(--txt-2);
}
.btn-ghost:hover {
  background: rgba(255,255,255,.05);
  border-color: var(--b-3);
  color: var(--txt);
  transform: translateY(-1px);
}

.btn-teal {
  background: linear-gradient(135deg, rgba(78,205,196,.18), rgba(78,205,196,.06));
  border-color: rgba(78,205,196,.4);
  color: #aef0ea;
}
.btn-teal:hover {
  background: linear-gradient(135deg, rgba(78,205,196,.26), rgba(78,205,196,.1));
  border-color: rgba(78,205,196,.6);
  transform: translateY(-1px);
}

.btn-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

/* magnetic wrapper */
.mag { display: inline-block; transition: transform .4s var(--ease); }

/* ─── Hero ────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100vh;
  padding: 104px 0 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  isolation: isolate;
}
.hero-canvas {
  position: absolute;
  top: 74px;
  right: 0;
  bottom: 0;
  width: min(66vw, 860px);
  z-index: 0;
  pointer-events: none;
  opacity: .58;
  mix-blend-mode: screen;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.35) 16%, #000 34%, #000 100%);
  mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.35) 16%, #000 34%, #000 100%);
}
.hero-veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(2,2,9,.98) 0%, rgba(2,2,9,.86) 34%, rgba(2,2,9,.34) 68%, rgba(2,2,9,.74) 100%),
    radial-gradient(ellipse 90% 60% at 50% 50%, rgba(2,2,9,0) 0%, rgba(2,2,9,.55) 65%, rgba(2,2,9,.95) 100%);
}
.hero-inner {
  position: relative;
  z-index: 2;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--pad);
  width: 100%;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 980px) { .hero-inner { grid-template-columns: 1fr; gap: 36px; } }

@media (max-width: 1180px) {
  .hero-canvas {
    top: 86px;
    width: min(58vw, 620px);
    opacity: .42;
  }
}

@media (max-width: 980px) {
  .hero-canvas {
    top: 88px;
    width: min(52vw, 520px);
    opacity: .26;
  }
  .hero-veil {
    background:
      linear-gradient(90deg, rgba(2,2,9,.98) 0%, rgba(2,2,9,.94) 58%, rgba(2,2,9,.62) 100%),
      radial-gradient(ellipse 95% 54% at 76% 24%, rgba(78,205,196,.055), transparent 58%);
  }
}

.hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 5px 14px;
  margin-bottom: 22px;
  background: rgba(200,169,110,.06);
  border: .5px solid rgba(200,169,110,.22);
  border-radius: 100px;
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .32em;
  color: var(--gold);
  text-transform: uppercase;
}
.hero-tag .pulse {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px rgba(123,220,181,.65);
  animation: pulse 2.6s ease-in-out infinite;
}

.hero-title {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(42px, 6.3vw, 82px);
  line-height: 0.99;
  letter-spacing: .02em;
  color: var(--txt);
}
.hero-title .ln {
  display: block;
}
.hero-title .ln-2 {
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 50%, var(--gold) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 400;
}
.hero-title .ln-3 {
  font-style: italic;
  font-weight: 300;
  color: var(--txt-2);
  font-size: .82em;
}
.hero-sub {
  margin-top: 22px;
  font-family: var(--narr);
  font-size: clamp(15px, 1.6vw, 18px);
  line-height: 1.68;
  color: var(--txt-2);
  font-weight: 300;
  max-width: 62ch;
}
.hero-sub strong { color: var(--txt); font-weight: 400; }
.hero-sub em { color: var(--gold); font-style: italic; }

.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 30px;
}

.hero-meta {
  margin-top: 38px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: rgba(4,4,12,.7);
  border: .5px solid var(--b-1);
  border-radius: 16px;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  overflow: hidden;
  max-width: 720px;
}
.hero-meta-cell {
  padding: 16px 18px;
  border-right: .5px solid var(--b-1);
  position: relative;
}
.hero-meta-cell:last-child { border-right: none; }
.hero-meta-cell::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.18), transparent);
}
.hero-meta-lbl {
  font-family: var(--label);
  font-size: 8px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 5px;
}
.hero-meta-val {
  font-family: var(--display);
  font-size: 14.5px;
  letter-spacing: .04em;
  color: var(--gold);
  line-height: 1.25;
}
.hero-meta-sub {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .04em;
  color: var(--txt-3);
  margin-top: 3px;
}
@media (max-width: 720px) {
  .hero-meta { grid-template-columns: repeat(2, 1fr); }
  .hero-meta-cell:nth-child(2) { border-right: none; }
}

.welcome-section {
  padding-top: 88px;
}
.welcome-band {
  display: grid;
  grid-template-columns: minmax(280px, .8fr) minmax(0, 1.35fr);
  gap: clamp(28px, 5vw, 74px);
  align-items: stretch;
  padding: clamp(28px, 5vw, 56px) 0;
  border-top: .5px solid var(--b-gold);
  border-bottom: .5px solid var(--b-1);
  position: relative;
}
.welcome-band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 580px 180px at 0% 0%, rgba(200,169,110,.07), transparent 68%),
    linear-gradient(90deg, rgba(255,255,255,.018), transparent 58%);
}
.welcome-band > * {
  position: relative;
  z-index: 1;
}
.welcome-copy h2 {
  margin-top: 16px;
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(30px, 4vw, 54px);
  line-height: 1.08;
  letter-spacing: .02em;
  color: var(--txt);
}
.welcome-copy p {
  margin-top: 18px;
  max-width: 56ch;
  color: var(--txt-2);
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 1.78;
}
.welcome-lanes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-left: .5px solid var(--b-1);
}
.welcome-lane {
  min-height: 220px;
  padding: 22px 22px 24px;
  border-right: .5px solid var(--b-1);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 11px;
  transition: background .28s var(--ease), border-color .28s var(--ease), transform .28s var(--ease);
}
.welcome-lane:hover {
  background: rgba(255,255,255,.028);
  border-color: var(--b-gold);
  transform: translateY(-2px);
}
.welcome-lane:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 4px;
}
.welcome-lane .lane-k {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
}
.welcome-lane strong {
  font-family: var(--display);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.25;
  color: var(--txt);
}
.welcome-lane span:last-child {
  color: var(--txt-3);
  font-size: 13.5px;
  line-height: 1.65;
}
@media (max-width: 980px) {
  .welcome-band {
    grid-template-columns: 1fr;
  }
  .welcome-lanes {
    border-left: 0;
  }
}
@media (max-width: 720px) {
  .welcome-section {
    padding-top: 56px;
  }
  .welcome-lanes {
    grid-template-columns: 1fr;
    border-top: .5px solid var(--b-1);
  }
  .welcome-lane {
    min-height: auto;
    padding: 18px 0 20px;
    border-right: 0;
    border-bottom: .5px solid var(--b-1);
  }
  .welcome-lane:last-child {
    border-bottom: 0;
  }
  .welcome-lane:hover {
    background: transparent;
    transform: none;
  }
}

@media (max-width: 720px) {
  :root { --pad: 22px; }
  .nav { padding: 0 18px; }
  .nav-brand { gap: 9px; min-width: 0; }
  .nav-name {
    font-size: 12px;
    letter-spacing: .16em;
    line-height: 1.25;
  }
  .nav-tag { display: none; }
  .hero {
    min-height: auto;
    padding: 104px 0 46px;
    justify-content: flex-start;
  }
  .hero-canvas { display: none; }
  .hero-veil {
    background:
      radial-gradient(ellipse 95% 54% at 50% 22%, rgba(78,205,196,.07), transparent 58%),
      linear-gradient(180deg, rgba(2,2,9,.34), rgba(2,2,9,.88) 72%, rgba(2,2,9,.98));
  }
  .hero-inner {
    padding: 0 var(--pad);
    gap: 28px;
  }
  .hero-tag {
    max-width: 100%;
    white-space: normal;
    font-size: 8px;
    line-height: 1.55;
    letter-spacing: .22em;
    border-radius: 12px;
  }
  .hero-title {
    font-size: clamp(31px, 9.8vw, 48px);
    line-height: 1.08;
    letter-spacing: 0;
    max-width: 100%;
  }
  .hero-title .ln-3 { font-size: .78em; }
  .hero-sub {
    margin-top: 20px;
    font-size: 15px;
    line-height: 1.7;
  }
  .hero-actions {
    margin-top: 28px;
    width: 100%;
  }
  .hero-actions .mag,
  .hero-actions .btn {
    width: 100%;
  }
  .hero-actions .btn {
    justify-content: center;
    text-align: center;
    white-space: normal;
    line-height: 1.45;
  }
  .hero-meta {
    margin-top: 34px;
    border-radius: 12px;
  }
  .hero-meta-cell { padding: 14px 13px; }
  .hero-meta-lbl { letter-spacing: .18em; }
  .hero-meta-val { font-size: 12.5px; }
  .scroll-hint { display: none; }
}

@media (max-width: 420px) {
  .hero-title { font-size: clamp(29px, 9vw, 37px); }
  .hero-tag { letter-spacing: .18em; }
}

/* hero right column — the live event ticker / aside panel */
.hero-aside {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* ─── Live event ticker (proof console) ───────────────────────────────── */
.ticker {
  background: rgba(4,4,12,.72);
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-gold);
  border-radius: 14px;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  overflow: hidden;
  position: relative;
}
.ticker-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border-bottom: .5px solid var(--b-1);
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .14em;
  color: var(--txt-3);
}
.ticker-bar .left { display: flex; gap: 12px; align-items: center; }
.ticker-bar .right { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.ticker-bar .session { color: var(--gold); }
.ticker-bar .pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 7px rgba(123,220,181,.6);
  animation: pulse 2.4s infinite;
}

.ticker-flow {
  display: flex;
  align-items: stretch;
  border-bottom: .5px solid var(--b-1);
  background:
    linear-gradient(90deg, transparent, rgba(200,169,110,0.025) 50%, transparent),
    rgba(4,4,12,.45);
}
.flow-node {
  flex: 1;
  padding: 14px 12px;
  text-align: center;
  position: relative;
}
.flow-node .role {
  font-family: var(--label);
  font-size: 8.5px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 4px;
}
.flow-node .name {
  font-family: var(--display);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--txt);
}
.flow-node.gate .name { color: var(--gold); }
.flow-arrow {
  flex: 0 0 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  color: var(--txt-4);
}
.flow-arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 6px;
  right: 6px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: .35;
}
.flow-arrow .pkt {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 8px var(--gold);
  position: relative;
  animation: pktFly 2.4s linear infinite;
}
@keyframes pktFly {
  0%   { transform: translateX(-22px); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateX(22px); opacity: 0; }
}

.ticker-rows {
  padding: 4px 0;
  max-height: 360px;
  overflow: hidden;
  position: relative;
}
.t-row {
  display: grid;
  grid-template-columns: 28px auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 14px;
  font-family: var(--label);
  font-size: 11px;
  border-bottom: .5px solid rgba(255,255,255,.025);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
}
.t-row.in { opacity: 1; transform: translateY(0); }
.t-row .seq { color: var(--txt-4); font-size: 10px; letter-spacing: .12em; }
.t-row .verb {
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  border: .5px solid currentColor;
  white-space: nowrap;
}
.verb-allow    { color: #98d6cf; background: rgba(78,205,196,.06); }
.verb-quar     { color: var(--amber); background: rgba(223,174,82,.06); }
.verb-deny     { color: var(--ember); background: rgba(232,114,74,.06); }
.verb-approve  { color: var(--violet); background: rgba(155,145,224,.06); }
.verb-verify   { color: var(--gold); background: rgba(200,169,110,.06); }
.t-row .desc { color: var(--txt-2); }
.t-row .desc .arg { color: var(--txt-3); }
.t-row .sig { color: var(--txt-4); font-size: 10px; }

.ticker-foot {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .12em;
  color: var(--txt-3);
  border-top: .5px solid var(--b-1);
}
.ticker-foot .sig-ok { color: var(--green); margin-left: auto; display: flex; gap: 7px; align-items: center; }
.ticker-foot .sig-ok::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 7px rgba(123,220,181,.55);
}

/* hero-aside trust card */
.trust-card {
  background: rgba(4,4,12,.72);
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-teal);
  border-radius: 14px;
  padding: 18px 20px;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  position: relative;
  overflow: hidden;
}
.trust-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, var(--teal), transparent);
  opacity: .45;
}
.trust-card .tc-eye {
  font-family: var(--label);
  font-size: 8.5px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 10px;
}
.trust-card .tc-title {
  font-family: var(--display);
  font-size: 14.5px;
  letter-spacing: .06em;
  color: var(--txt);
  margin-bottom: 7px;
}
.trust-card .tc-body {
  font-family: var(--narr);
  font-size: 13.5px;
  font-weight: 300;
  line-height: 1.65;
  color: var(--txt-3);
}

/* scroll hint */
.scroll-hint {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  font-family: var(--label);
  font-size: 8.5px;
  letter-spacing: .32em;
  color: var(--txt-4);
  text-transform: uppercase;
  z-index: 3;
  animation: scrollNudge 2.6s ease-in-out infinite;
}
@keyframes scrollNudge {
  0%, 100% { opacity: .35; transform: translate(-50%, 0); }
  50%      { opacity: .7;  transform: translate(-50%, 5px); }
}
.scroll-hint .chev {
  width: 14px; height: 8px;
  position: relative;
}
.scroll-hint .chev::before, .scroll-hint .chev::after {
  content: ""; position: absolute;
  width: 8px; height: 1.5px;
  background: var(--txt-4);
  border-radius: 1px;
}
.scroll-hint .chev::before { left: 0; transform: rotate(36deg); top: 1px; }
.scroll-hint .chev::after  { right: 0; transform: rotate(-36deg); top: 1px; }

/* ─── Page hero (interior pages) ──────────────────────────────────────── */
.page-hero {
  position: relative;
  padding: 160px 0 60px;
  overflow: hidden;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: .5;
}
.page-hero .wrap { position: relative; z-index: 2; }
.page-hero .reveal {
  opacity: 1;
  transform: none;
}
.crumb {
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 22px;
}
.crumb a { color: var(--gold); }
.crumb a:hover { color: var(--gold-bright); }

/* ─── Reveal motion ───────────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
  will-change: transform, opacity;
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: .08s; }
.reveal-d2 { transition-delay: .16s; }
.reveal-d3 { transition-delay: .24s; }
.reveal-d4 { transition-delay: .32s; }

/* ─── Section heads ───────────────────────────────────────────────────── */
.head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  margin-bottom: 56px;
  align-items: end;
}
@media (max-width: 880px) {
  .head { grid-template-columns: 1fr; gap: 22px; margin-bottom: 36px; }
}
.head .h-l h2 { margin-top: 12px; }
.head .h-r p { color: var(--txt-3); max-width: 56ch; margin-left: auto; }
@media (max-width: 880px) { .head .h-r p { margin-left: 0; } }

/* ─── Pillars (3-card system) ─────────────────────────────────────────── */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 880px) {
  .pillars { grid-template-columns: 1fr; }
}
.pillar {
  background: rgba(6,6,18,.62);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  padding: 28px 24px;
  position: relative;
  overflow: hidden;
  transition: border-color .35s var(--ease), transform .35s var(--ease), background .35s var(--ease);
}
.pillar::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.18), transparent);
}
.pillar:hover {
  border-color: rgba(200,169,110,.22);
  background: rgba(8,8,22,.72);
  transform: translateY(-2px);
}
.pillar .num {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 14px;
}
.pillar .num .accent { color: var(--gold); }
.pillar h3 { margin-bottom: 10px; font-size: 18px; }
.pillar p { font-size: 14px; line-height: 1.7; color: var(--txt-3); }
.pillar .accent-line {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  opacity: 0;
  transition: opacity .35s;
}
.pillar:hover .accent-line { opacity: .5; }
.pillar.gold   .accent-line { background: linear-gradient(90deg, var(--gold), transparent); }
.pillar.teal   .accent-line { background: linear-gradient(90deg, var(--teal), transparent); }
.pillar.violet .accent-line { background: linear-gradient(90deg, var(--violet), transparent); }
.pillar.ember  .accent-line { background: linear-gradient(90deg, var(--ember), transparent); }
.pillar.amber  .accent-line { background: linear-gradient(90deg, var(--amber), transparent); }
.pillar.green  .accent-line { background: linear-gradient(90deg, var(--green), transparent); }

/* split layout */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 880px) {
  .split { grid-template-columns: 1fr; gap: 32px; }
}

/* ─── Lattice (Six-node company stack diagram) ────────────────────────── */
.lattice {
  margin-top: 36px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  background: rgba(4,4,12,.72);
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-gold);
  border-radius: 18px;
  overflow: hidden;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  position: relative;
}
.lattice::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.32) 50%, transparent);
}
.lattice-cell {
  padding: 26px 20px 22px;
  border-right: .5px solid var(--b-1);
  position: relative;
  transition: background .35s, transform .35s;
  cursor: default;
  min-height: 220px;
  display: flex;
  flex-direction: column;
}
.lattice-cell:last-child { border-right: none; }
.lattice-cell:hover {
  background: rgba(8,8,24,.55);
  transform: translateY(-2px);
}
.lattice-cell .verb {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.lattice-cell .verb .glyph {
  font-size: 13px;
  font-family: var(--display);
}
.lattice-cell .product {
  font-family: var(--display);
  font-size: 14.5px;
  letter-spacing: .04em;
  color: var(--txt);
  line-height: 1.25;
  margin-bottom: 9px;
}
.lattice-cell .role {
  font-family: var(--narr);
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--txt-3);
  flex: 1;
  margin-bottom: 12px;
}
.lattice-cell .tag {
  font-family: var(--label);
  font-size: 8.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--txt-4);
  padding: 3px 8px;
  border-radius: 5px;
  background: rgba(255,255,255,.025);
  border: .5px solid var(--b-1);
  align-self: flex-start;
}
.lattice-cell.shipping .tag {
  color: var(--green);
  background: rgba(123,220,181,.06);
  border-color: rgba(123,220,181,.22);
}
.lattice-cell.core .tag {
  color: var(--gold);
  background: rgba(200,169,110,.06);
  border-color: rgba(200,169,110,.22);
}
.lattice-cell.research .tag {
  color: var(--violet);
  background: rgba(155,145,224,.06);
  border-color: rgba(155,145,224,.22);
}
/* per-column accent strip */
.lattice-cell::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  opacity: .55;
}
.lattice-cell.c-remember::after  { background: linear-gradient(90deg, var(--violet), transparent); }
.lattice-cell.c-verify::after    { background: linear-gradient(90deg, var(--gold), transparent); }
.lattice-cell.c-act::after       { background: linear-gradient(90deg, var(--teal), transparent); }
.lattice-cell.c-coordinate::after{ background: linear-gradient(90deg, var(--amber), transparent); }
.lattice-cell.c-handoff::after   { background: linear-gradient(90deg, var(--green), transparent); }
.lattice-cell.c-endure::after    { background: linear-gradient(90deg, var(--ember), transparent); }

.lattice-cell.c-remember .product   { color: var(--violet); }
.lattice-cell.c-verify .product     { color: var(--gold); }
.lattice-cell.c-act .product        { color: var(--teal); }
.lattice-cell.c-coordinate .product { color: var(--amber); }
.lattice-cell.c-handoff .product    { color: var(--green); }
.lattice-cell.c-endure .product     { color: var(--ember); }

@media (max-width: 1080px) {
  .lattice { grid-template-columns: repeat(3, 1fr); }
  .lattice-cell:nth-child(3n) { border-right: none; }
  .lattice-cell:nth-child(n+4) { border-top: .5px solid var(--b-1); }
}
@media (max-width: 640px) {
  .lattice { grid-template-columns: repeat(2, 1fr); }
  .lattice-cell { border-right: .5px solid var(--b-1); }
  .lattice-cell:nth-child(2n) { border-right: none; }
  .lattice-cell:nth-child(n+3) { border-top: .5px solid var(--b-1); }
}

/* ─── Console (proof console / kv) ────────────────────────────────────── */
.console {
  background: rgba(4,4,12,.7);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  overflow: hidden;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  position: relative;
}
.console::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.16), transparent);
}
.console-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 16px;
  border-bottom: .5px solid var(--b-1);
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .14em;
  color: var(--txt-3);
}
.console-bar .left { display: flex; align-items: center; gap: 12px; }
.console-bar .right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.console-bar .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px rgba(123,220,181,.55);
  animation: pulse 3s infinite;
}
.console-bar .session-id { color: var(--gold); }

.console-foot {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-top: .5px solid var(--b-1);
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--txt-3);
}
.console-foot .sig-chain {
  margin-left: auto;
  color: var(--green);
  display: flex;
  align-items: center;
  gap: 7px;
}
.console-foot .sig-chain::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px rgba(123,220,181,.55);
}

.kv { padding: 4px 0; }
.kv-row {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 12px 18px;
  border-bottom: .5px solid rgba(255,255,255,.025);
}
.kv-row:last-child { border-bottom: none; }
.kv-key {
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--txt-4);
}
.kv-val {
  font-family: var(--narr);
  font-size: 14px;
  color: var(--txt-2);
}
.kv-tag {
  font-family: var(--label);
  font-size: 8.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(200,169,110,.06);
  border: .5px solid rgba(200,169,110,.18);
  white-space: nowrap;
}
@media (max-width: 720px) {
  .ticker-bar,
  .ticker-foot,
  .console-bar,
  .console-foot {
    align-items: flex-start;
    flex-direction: column;
    gap: 7px;
  }
  .ticker-bar .right,
  .ticker-foot .sig-ok,
  .console-bar .right,
  .console-foot .sig-chain {
    margin-left: 0;
  }
  .ticker-flow {
    display: grid;
    grid-template-columns: 1fr;
  }
  .flow-arrow {
    min-height: 24px;
    transform: rotate(90deg);
    justify-self: center;
  }
  .t-row {
    grid-template-columns: 26px 1fr;
    gap: 8px 10px;
    align-items: start;
  }
  .t-row .desc {
    grid-column: 1 / -1;
    padding-left: 36px;
  }
  .t-row .sig { display: none; }
  .kv-row { grid-template-columns: 1fr; gap: 6px; padding: 14px 16px; }
  .kv-tag { justify-self: start; }
}

/* ─── Topology diagram ────────────────────────────────────────────────── */
.topo {
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.topo-row {
  display: grid;
  gap: 12px;
}
.topo-row.r-2 { grid-template-columns: 1fr 1fr; }
.topo-row.r-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 720px) {
  .topo-row.r-2,
  .topo-row.r-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .topo-row.r-2,
  .topo-row.r-4 { grid-template-columns: 1fr; }
  .topo-flow::before,
  .topo-flow::after { display: none; }
}
.topo-flow {
  text-align: center;
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--txt-4);
  padding: 4px 0;
  position: relative;
}
.topo-flow::before, .topo-flow::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 14%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: .35;
}
.topo-flow::before { left: 22%; }
.topo-flow::after { right: 22%; }
.topo-node {
  background: rgba(255,255,255,0.022);
  border: .5px solid var(--b-1);
  border-radius: 11px;
  padding: 16px 18px;
  position: relative;
}
.topo-node .name {
  font-family: var(--display);
  font-size: 13px;
  letter-spacing: .06em;
  color: var(--txt);
  display: block;
  margin-bottom: 5px;
}
.topo-node .desc {
  font-family: var(--label);
  font-size: 10.5px;
  letter-spacing: .04em;
  color: var(--txt-3);
}
.topo-node.gate {
  border-color: var(--b-gold);
  background: linear-gradient(180deg, rgba(200,169,110,.08), rgba(200,169,110,.02));
}
.topo-node.gate .name { color: var(--gold); }
.topo-node.proof {
  border-color: var(--b-teal);
  background: linear-gradient(180deg, rgba(78,205,196,.08), rgba(78,205,196,.02));
}
.topo-node.proof .name { color: var(--teal); }

/* ─── Funding-specific blocks ─────────────────────────────────────────── */
.fund-headline {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 56px;
  align-items: center;
  background: rgba(4,4,12,.7);
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-gold);
  border-radius: 18px;
  padding: 38px 38px;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  position: relative;
  overflow: hidden;
}
.fund-headline::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.42), transparent);
}
.fund-headline::after {
  content: "";
  position: absolute;
  inset: -40% -10% auto auto;
  width: 360px;
  height: 360px;
  background: radial-gradient(circle, rgba(200,169,110,.07), transparent 65%);
  pointer-events: none;
}
@media (max-width: 880px) {
  .fund-headline { grid-template-columns: 1fr; gap: 28px; padding: 28px 22px; }
}
.fund-amount {
  font-family: var(--display);
  font-size: clamp(56px, 8vw, 96px);
  font-weight: 300;
  letter-spacing: .015em;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 50%, var(--gold) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.fund-tag {
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.fund-tag::before {
  content: "";
  width: 22px;
  height: .5px;
  background: var(--gold);
}
.fund-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 11px 0;
  border-bottom: .5px solid rgba(255,255,255,.04);
  font-family: var(--label);
  font-size: 11.5px;
  letter-spacing: .04em;
}
.fund-row:last-child { border-bottom: none; }
.fund-row .k {
  color: var(--txt-4);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  white-space: nowrap;
}
.fund-row .v {
  color: var(--txt-2);
  text-align: right;
  font-family: var(--narr);
  font-size: 13.5px;
}

.funding-track-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
@media (max-width: 860px) { .funding-track-grid { grid-template-columns: 1fr; } }

.fund-track {
  background:
    linear-gradient(180deg, rgba(255,255,255,.044), rgba(255,255,255,.018)),
    rgba(5,5,16,.72);
  border: .5px solid var(--b-1);
  border-top-color: var(--b-gold);
  border-radius: var(--r);
  padding: 30px 28px;
  min-height: 430px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  overflow: hidden;
}
.fund-track::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 420px 180px at 0% 0%, rgba(200,169,110,.11), transparent 64%),
    radial-gradient(ellipse 320px 160px at 100% 100%, rgba(78,205,196,.055), transparent 70%);
  opacity: .72;
}
.fund-track > * { position: relative; z-index: 1; }
.fund-track.bridge { border-top-color: var(--b-teal); }
.fund-track .track-label {
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
}
.fund-track.bridge .track-label { color: var(--teal); }
.fund-track h3 {
  font-size: clamp(26px, 3.2vw, 38px);
  color: var(--txt);
  line-height: 1.08;
}
.fund-track p {
  color: var(--txt-3);
  font-size: 14.5px;
  line-height: 1.75;
}
.fund-track .track-list {
  display: grid;
  gap: 10px;
  margin-top: auto;
  padding-top: 4px;
}
.fund-track .track-list span {
  border-top: .5px solid rgba(255,255,255,.055);
  padding-top: 10px;
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--txt-3);
}
.fund-track .track-list strong {
  color: var(--txt-2);
  font-weight: 400;
  text-transform: none;
  letter-spacing: .02em;
}

/* tracks (use of funds) */
.tracks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
@media (max-width: 720px) { .tracks { grid-template-columns: 1fr; } }
.track {
  background: rgba(6,6,18,.62);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  padding: 26px 24px;
  position: relative;
  overflow: hidden;
  transition: border-color .3s, transform .3s, background .3s;
}
.track::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: linear-gradient(180deg, var(--gold), transparent);
  opacity: .45;
}
.track:hover {
  border-color: rgba(200,169,110,.2);
  background: rgba(8,8,22,.72);
  transform: translateY(-2px);
}
.track .step {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.track h4 { margin-bottom: 9px; font-size: 16px; color: var(--txt); }
.track p { font-size: 13.5px; color: var(--txt-3); margin-bottom: 14px; }
.track .out {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--teal);
}

/* funder fit grid */
.funders {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 880px) { .funders { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .funders { grid-template-columns: 1fr; } }
.funder {
  padding: 22px 20px;
  background: rgba(6,6,18,.6);
  border: .5px solid var(--b-1);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
  transition: border-color .3s, background .3s, transform .3s;
}
.funder:hover {
  border-color: rgba(200,169,110,.2);
  background: rgba(8,8,22,.72);
  transform: translateY(-2px);
}
.funder .role {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 9px;
}
.funder h4 {
  font-size: 14px;
  margin-bottom: 7px;
  color: var(--txt);
  letter-spacing: .04em;
}
.funder p { font-size: 12.5px; color: var(--txt-3); line-height: 1.6; }

/* ─── Proof bundles row ───────────────────────────────────────────────── */
.bundles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 28px;
}
@media (max-width: 880px) { .bundles { grid-template-columns: 1fr; } }
.bundle {
  background: rgba(6,6,18,.62);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  padding: 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color .3s, transform .3s;
}
.bundle:hover { border-color: var(--b-gold); transform: translateY(-2px); }
.bundle .ext {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  border: .5px solid var(--b-gold);
  border-radius: 4px;
  padding: 2px 7px;
  align-self: flex-start;
}
.bundle h4 { font-size: 14.5px; }
.bundle p { font-size: 12.5px; color: var(--txt-3); flex: 1; }
.bundle .open {
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--teal);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.bundle .open .arrow { transition: transform .3s; }
.bundle:hover .open .arrow { transform: translateX(3px); }

/* ─── Golem / evidence surfaces ───────────────────────────────────────── */
.surface-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  gap: 16px;
  margin-bottom: 34px;
}
@media (max-width: 980px) { .surface-grid { grid-template-columns: 1fr; } }

.surface-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    rgba(5,5,16,.74);
  border: .5px solid var(--b-1);
  border-top-color: var(--b-gold);
  border-radius: var(--r);
  padding: 24px 24px;
  min-height: 290px;
  display: flex;
  flex-direction: column;
  gap: 13px;
  position: relative;
  overflow: hidden;
  transition: transform .32s var(--ease), border-color .32s var(--ease), background .32s var(--ease);
}
.surface-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 420px 180px at 8% 0%, rgba(200,169,110,.12), transparent 62%),
    radial-gradient(ellipse 300px 160px at 100% 100%, rgba(78,205,196,.06), transparent 70%);
  opacity: .65;
}
.surface-card > * { position: relative; z-index: 1; }
.surface-card.primary {
  min-height: 340px;
  border-top-color: var(--b-teal);
}
.surface-card:hover {
  transform: translateY(-2px);
  border-color: var(--b-gold);
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.024)),
    rgba(5,5,16,.82);
}
.surface-card .ext,
.app-card .num,
.metric-card .k {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
}
.surface-card h3 {
  font-size: clamp(24px, 3vw, 34px);
  color: var(--txt);
}
.surface-card p {
  font-size: 14px;
  color: var(--txt-3);
  flex: 1;
}
.metric-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.metric-strip span {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .08em;
  color: var(--txt-3);
  border: .5px solid var(--b-1);
  border-radius: 999px;
  padding: 5px 8px;
  background: rgba(255,255,255,.025);
}
.surface-card .open {
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--teal);
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 880px) { .metric-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .metric-grid { grid-template-columns: 1fr; } }
.metric-card {
  background: rgba(6,6,18,.68);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  padding: 22px 22px;
  min-height: 140px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.metric-card strong {
  display: block;
  font-family: var(--display);
  font-size: clamp(32px, 5vw, 52px);
  line-height: 1.05;
  color: var(--gold);
  font-weight: 300;
  letter-spacing: .02em;
  margin: 12px 0;
}
.metric-card .s {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--txt-4);
}

.app-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 980px) { .app-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px) { .app-grid { grid-template-columns: 1fr; } }
.app-card {
  background: rgba(6,6,18,.64);
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-2);
  border-radius: var(--r);
  padding: 24px 22px;
  min-height: 210px;
  transition: transform .32s var(--ease), border-color .32s var(--ease);
}
.app-card:hover { transform: translateY(-2px); border-color: var(--b-gold); }
.app-card.gold { border-top-color: var(--b-gold); }
.app-card.teal { border-top-color: var(--b-teal); }
.app-card.violet { border-top-color: var(--b-violet); }
.app-card.ember { border-top-color: var(--b-ember); }
.app-card h3 {
  margin: 14px 0 8px;
  font-size: 18px;
}
.app-card p {
  font-size: 13.5px;
  color: var(--txt-3);
  line-height: 1.65;
}

/* ─── Mechanism-first Golem diagrams ─────────────────────────────────── */
.mechanism-flow {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin: 34px 0;
}
.mechanism-step {
  position: relative;
  min-height: 178px;
  padding: 20px 16px;
  border: .5px solid var(--b-1);
  border-top-color: var(--b-gold);
  border-radius: var(--r);
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    rgba(6,6,18,.66);
  overflow: hidden;
}
.mechanism-step::after {
  content: "";
  position: absolute;
  right: -18px;
  top: 50%;
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, var(--gold), transparent);
  opacity: .7;
}
.mechanism-step:last-child::after { display: none; }
.mechanism-step .idx,
.diagram-label {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
}
.mechanism-step h3 {
  margin: 16px 0 8px;
  font-size: 16px;
  color: var(--txt);
}
.mechanism-step p {
  font-size: 12.5px;
  line-height: 1.65;
  color: var(--txt-3);
}
.mechanism-step.teal { border-top-color: var(--b-teal); }
.mechanism-step.violet { border-top-color: var(--b-violet); }
.mechanism-step.ember { border-top-color: var(--b-ember); }

.coordinate-panel {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 18px;
  margin-top: 32px;
}
.coordinate-node {
  border: .5px solid var(--b-teal);
  border-radius: var(--r);
  background:
    radial-gradient(ellipse 360px 260px at 50% 30%, rgba(78,205,196,.12), transparent 64%),
    rgba(5,5,16,.72);
  min-height: 390px;
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.coordinate-node::before {
  content: "";
  position: absolute;
  width: 240px;
  height: 240px;
  border: .5px solid rgba(200,169,110,.24);
  border-radius: 50%;
  box-shadow: 0 0 80px rgba(78,205,196,.09);
}
.coordinate-node::after {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 30px rgba(200,169,110,.62);
}
.coordinate-node .axis {
  position: absolute;
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--txt-4);
}
.coordinate-node .axis.x { bottom: 22px; left: 24px; right: 24px; border-top: .5px solid rgba(255,255,255,.12); padding-top: 10px; }
.coordinate-node .axis.y { top: 24px; bottom: 24px; left: 24px; writing-mode: vertical-rl; border-right: .5px solid rgba(255,255,255,.12); padding-right: 10px; }
.coordinate-node .center-label {
  position: relative;
  z-index: 2;
  transform: translateY(58px);
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--teal);
}
.coordinate-fields {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.coordinate-field,
.anchor-chip,
.state-card {
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  background: rgba(6,6,18,.62);
  padding: 17px 16px;
}
.coordinate-field h4,
.state-card h4 {
  font-size: 14px;
  margin-bottom: 8px;
  color: var(--txt);
}
.coordinate-field p,
.state-card p {
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--txt-3);
}

.anchor-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 30px;
}
.anchor-chip {
  min-height: 150px;
  border-top-color: var(--b-gold);
}
.anchor-chip .symbol {
  font-family: var(--display);
  font-size: 28px;
  color: var(--gold);
  margin-bottom: 12px;
}
.anchor-chip h3 { font-size: 15px; margin-bottom: 8px; }
.anchor-chip p { font-size: 12.5px; line-height: 1.6; color: var(--txt-3); }

.state-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-top: 30px;
}
.state-card { min-height: 160px; }
.state-card .diagram-label { color: var(--teal); }
.state-card.verified { border-top-color: var(--b-teal); }
.state-card.rejected { border-top-color: var(--b-ember); }
.state-card.tension { border-top-color: var(--b-violet); }
.state-card.silence { border-top-color: var(--b-gold); }

.dream-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 30px;
}
.dream-tile {
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  background: rgba(6,6,18,.6);
  padding: 15px 14px;
  min-height: 126px;
}
.dream-tile .n {
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gold);
}
.dream-tile h4 {
  margin: 10px 0 6px;
  font-size: 13.5px;
}
.dream-tile p {
  font-size: 12px;
  line-height: 1.55;
  color: var(--txt-3);
}

@media (max-width: 1100px) {
  .mechanism-flow { grid-template-columns: repeat(3, 1fr); }
  .mechanism-step::after { display: none; }
  .anchor-band { grid-template-columns: repeat(2, 1fr); }
  .state-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 820px) {
  .coordinate-panel { grid-template-columns: 1fr; }
  .coordinate-node { min-height: 300px; }
  .dream-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
  .mechanism-flow,
  .coordinate-fields,
  .anchor-band,
  .state-grid,
  .dream-grid { grid-template-columns: 1fr; }
}

.capture-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
@media (max-width: 900px) { .capture-grid { grid-template-columns: 1fr; } }
.capture-card {
  background: rgba(6,6,18,.64);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.capture-card img {
  width: 100%;
  display: block;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-bottom: .5px solid var(--b-1);
}
.capture-placeholder-screen {
  aspect-ratio: 16 / 10;
  border-bottom: .5px solid var(--b-1);
  display: grid;
  place-items: center;
  padding: 28px;
  background:
    linear-gradient(135deg, rgba(200,169,110,.08), rgba(78,205,196,.035)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 26px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 24px),
    rgba(4,4,12,.82);
}
.capture-placeholder-screen span {
  border: .5px solid var(--b-gold);
  border-radius: 999px;
  padding: 8px 12px;
  font-family: var(--label);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  background: rgba(2,2,9,.62);
}
.capture-card figcaption {
  padding: 18px 18px 20px;
}
.capture-title {
  font-family: var(--display);
  font-size: 18px;
  color: var(--txt);
  margin-bottom: 8px;
}
.capture-card p {
  font-size: 13.5px;
  color: var(--txt-3);
  line-height: 1.7;
}

/* ─── Threat/control/evidence table (security) ────────────────────────── */
.tce {
  background: rgba(4,4,12,.7);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  overflow: hidden;
}
.tce-head, .tce-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
  padding: 14px 18px;
  border-bottom: .5px solid var(--b-1);
}
.tce-head {
  background: rgba(255,255,255,.025);
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--txt-4);
}
.tce-row {
  font-size: 13px;
  color: var(--txt-2);
  line-height: 1.55;
}
.tce-row:last-child { border-bottom: none; }
.tce-row .threat { color: var(--ember); font-family: var(--label); font-size: 11px; letter-spacing: .04em; }
.tce-row .control { color: var(--gold); font-family: var(--label); font-size: 11px; letter-spacing: .04em; }
.tce-row .evidence { color: var(--txt-2); font-family: var(--narr); font-size: 13px; }
@media (max-width: 720px) {
  .tce-head { display: none; }
  .tce-row { grid-template-columns: 1fr; gap: 6px; padding: 16px 14px; }
}

/* ─── In/Out bounded scope blocks ─────────────────────────────────────── */
.scope {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 720px) { .scope { grid-template-columns: 1fr; } }
.scope-card {
  background: rgba(6,6,18,.62);
  border: .5px solid var(--b-1);
  border-radius: var(--r);
  padding: 24px 22px;
}
.scope-card.in   { border-top: .5px solid var(--b-teal); }
.scope-card.out  { border-top: .5px solid var(--b-ember); }
.scope-card h3 { font-size: 17px; margin-bottom: 12px; }
.scope-card.in h3 { color: var(--teal); }
.scope-card.out h3 { color: var(--ember); }
.scope-card ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-family: var(--narr);
  font-size: 13.5px;
  color: var(--txt-2);
}
.scope-card li {
  position: relative;
  padding-left: 18px;
}
.scope-card li::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--gold);
  opacity: .55;
  font-size: 11px;
  top: 4px;
}
.scope-card.out li::before { content: "✕"; color: var(--ember); }

/* ─── CTA banner ──────────────────────────────────────────────────────── */
.cta {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 32px;
  background: linear-gradient(135deg, rgba(200,169,110,.06), rgba(78,205,196,.04));
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-gold);
  border-radius: 18px;
  padding: 36px 36px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.4), transparent);
}
.cta::after {
  content: "";
  position: absolute;
  inset: -50% -20% auto auto;
  width: 460px;
  height: 460px;
  background: radial-gradient(circle, rgba(78,205,196,.06), transparent 65%);
  pointer-events: none;
}
@media (max-width: 880px) {
  .cta { grid-template-columns: 1fr; padding: 28px 22px; }
}
.cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
@media (max-width: 880px) { .cta-actions { justify-content: flex-start; } }

/* ─── Footer ──────────────────────────────────────────────────────────── */
footer.foot {
  position: relative;
  z-index: 2;
  margin-top: 80px;
  border-top: .5px solid var(--b-1);
  background: rgba(2,2,9,.6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.foot-inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 50px var(--pad) 26px;
  display: grid;
  grid-template-columns: 1.3fr .8fr .8fr .8fr;
  gap: 36px;
}
@media (max-width: 880px) { .foot-inner { grid-template-columns: 1fr; gap: 24px; } }
.foot-brand .name {
  font-family: var(--display);
  font-size: 16px;
  letter-spacing: .14em;
  color: var(--txt);
  display: block;
  margin-bottom: 10px;
}
.foot-brand p {
  font-size: 13px;
  color: var(--txt-3);
  max-width: 38ch;
}
.foot-col .h {
  display: block;
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--txt-4);
  margin-bottom: 14px;
}
.foot-col a {
  display: block;
  font-family: var(--narr);
  font-size: 13px;
  color: var(--txt-3);
  padding: 4px 0;
  transition: color .25s;
}
.foot-col a:hover { color: var(--txt); }

.foot-meta {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 18px var(--pad) 28px;
  display: flex;
  align-items: center;
  gap: 16px;
  border-top: .5px solid var(--b-1);
  font-family: var(--label);
  font-size: 10px;
  letter-spacing: .12em;
  color: var(--txt-4);
  flex-wrap: wrap;
}
.foot-meta .right { margin-left: auto; }

/* ─── Hero video frame ────────────────────────────────────────────────── */
.hero-video {
  margin-top: 26px;
  background: rgba(4,4,12,.72);
  border: .5px solid var(--b-1);
  border-top: .5px solid var(--b-gold);
  border-radius: 14px;
  overflow: hidden;
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  position: relative;
}
.hero-video::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: .5px;
  background: linear-gradient(90deg, transparent, rgba(200,169,110,.32), transparent);
}
.video-bar {
  display: flex;
  justify-content: space-between;
  padding: 9px 14px;
  border-bottom: .5px solid var(--b-1);
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .12em;
  color: var(--txt-3);
}
.video-bar .left { display: flex; gap: 10px; align-items: center; }
.video-bar .left .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px rgba(123,220,181,.6);
  animation: pulse 3s infinite;
}
.video-bar .runtime { color: var(--gold); }
.hero-video video {
  display: block;
  width: 100%;
  height: auto;
  background: var(--bg);
}
.hero-video .poster-fallback {
  display: none;
  width: 100%;
}

/* ─── Mobile menu ─────────────────────────────────────────────────────── */
@media (max-width: 880px) {
  .menu-btn { display: inline-flex; margin-left: auto; }
  .nav-links {
    position: fixed;
    top: 60px; left: 0; right: 0; bottom: 0;
    z-index: 1200;
    min-height: calc(100vh - 60px);
    overflow-y: auto;
    background: #020209;
    backdrop-filter: blur(20px);
    flex-direction: column;
    align-items: stretch;
    padding: 28px 28px 80px;
    gap: 0;
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s, transform .3s;
  }
  .nav-links.menu-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .nav-links a {
    font-size: 18px;
    padding: 14px 4px;
    border-bottom: .5px solid var(--b-1);
    border-radius: 0;
    letter-spacing: .12em;
  }
  .nav-cta { background: transparent !important; border: none; margin-left: 0; }
  .nav-status { display: none; }
}

/* ─── Reduced motion ──────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .15s !important;
  }
  .reveal { opacity: 1 !important; transform: none !important; }
  .hero-canvas, .proof-field, .grain { display: none !important; }
  .horizon { opacity: .25; }
}

/* ─── Misc helpers ────────────────────────────────────────────────────── */
.muted { color: var(--txt-3); }
.gold-text { color: var(--gold); }
.teal-text { color: var(--teal); }
.violet-text { color: var(--violet); }
.ember-text { color: var(--ember); }
.mono { font-family: var(--mono); }
.mb-12 { margin-bottom: 12px; }
.mb-20 { margin-bottom: 20px; }
.mb-32 { margin-bottom: 32px; }
.mt-12 { margin-top: 12px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mt-44 { margin-top: 44px; }
.text-center { text-align: center; }

/* small inline status pill */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 3px 10px;
  border-radius: 100px;
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  border: .5px solid currentColor;
}
.pill .d {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 6px currentColor;
}
.pill.ok    { color: var(--green); background: rgba(123,220,181,.06); }
.pill.gold  { color: var(--gold);  background: rgba(200,169,110,.06); }
.pill.teal  { color: var(--teal);  background: rgba(78,205,196,.06); }
.pill.violet{ color: var(--violet); background: rgba(155,145,224,.06); }
.pill.ember { color: var(--ember); background: rgba(232,114,74,.06); }

/* big quote / pullquote */
.pullquote {
  font-family: var(--narr);
  font-size: clamp(20px, 2.6vw, 28px);
  font-style: italic;
  font-weight: 200;
  line-height: 1.55;
  color: var(--txt);
  padding-left: 22px;
  border-left: 2px solid var(--gold);
  position: relative;
  max-width: 56ch;
}
.pullquote .src {
  display: block;
  margin-top: 14px;
  font-family: var(--label);
  font-size: 10px;
  font-style: normal;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--txt-4);
}

/* timeline */
.timeline { display: flex; flex-direction: column; gap: 0; }
.timeline-row {
  display: grid;
  grid-template-columns: 130px 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 16px 0;
  border-bottom: .5px solid rgba(255,255,255,.04);
}
.timeline-row:last-child { border-bottom: none; }
.timeline-row .when {
  font-family: var(--label);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
}
.timeline-row .what {
  font-family: var(--narr);
  font-size: 14px;
  color: var(--txt-2);
  line-height: 1.55;
}
.timeline-row .out {
  font-family: var(--label);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--teal);
  white-space: nowrap;
}
@media (max-width: 720px) {
  .timeline-row { grid-template-columns: 1fr; gap: 6px; padding: 14px 0; }
  .timeline-row .out { justify-self: start; }
}
