/* ============================================================
   ChargeCatalyst — section & component styles
   ============================================================ */

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  padding-top: 120px; padding-bottom: 70px; overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
/* engineered dot grid */
.hero-bg .grid {
  position: absolute; inset: -2px;
  background-image:
    linear-gradient(rgba(27, 95, 224, 0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(27, 95, 224, 0.10) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 95% 85% at 72% 32%, #000 32%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 95% 85% at 72% 32%, #000 32%, transparent 80%);
  animation: griddrift 28s linear infinite;
}
@keyframes griddrift { to { background-position: 56px 56px, 56px 56px; } }
.hero-bg .glow {
  position: absolute; width: 62vw; height: 62vw; right: -14vw; top: -18vw;
  background: radial-gradient(circle, rgba(27, 95, 224, 0.10) 0%, transparent 62%);
  filter: blur(6px);
}
.hero-bg .glow2 {
  position: absolute; width: 50vw; height: 50vw; left: -16vw; bottom: -22vw;
  background: radial-gradient(circle, oklch(0.4 0.08 250 / 0.4) 0%, transparent 64%);
}
.hero-in { position: relative; z-index: 2; width: 100%;
  display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(30px, 5vw, 72px); align-items: center; }

.hero-tag {
  display: inline-flex; align-items: center; gap: 12px; margin-bottom: 30px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fg-dim);
}
.hero-tag .chip {
  color: var(--volt); border: 1px solid var(--volt-deep);
  border-radius: 2px; padding: 4px 9px; background: var(--volt-glow);
}
.hero h1 {
  font-family: var(--font-disp); font-weight: 800;
  letter-spacing: -0.035em; line-height: 0.95;
  font-size: clamp(2.7rem, 6.6vw, 5.4rem);
  text-wrap: balance;
}
.hero h1 .ln { display: block; overflow: hidden; }
.hero h1 em {
  font-style: normal; position: relative; color: var(--volt); white-space: nowrap;
}
.hero h1 em::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0.06em; height: 3px;
  background: var(--volt); opacity: 0.45;
}
.hero-sub {
  margin-top: 28px; max-width: 46ch; font-size: clamp(1.05rem, 1.45vw, 1.3rem);
  color: var(--fg-2); line-height: 1.5; text-wrap: pretty;
}
.hero-sub b { color: var(--fg); font-weight: 600; }
.hero-cta { margin-top: 38px; display: flex; gap: 14px; flex-wrap: wrap; }

/* hero instrument readout panel */
.readout { padding: 0; }
.readout .ro-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px; border-bottom: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--fg-dim);
}
.readout .ro-head .live { display: flex; align-items: center; gap: 7px; color: var(--volt); }
.readout .ro-head .live .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--volt); animation: pulse 2.4s infinite; }
.ro-body { padding: 20px 16px 8px; }
.ro-row { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 4px; }
.ro-row .k { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-dim); }
.ro-row .v { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); }
.ro-row .v b { color: var(--volt); }
.ro-track {
  height: 26px; margin: 9px 0 22px; display: flex; align-items: stretch;
}
.ro-foot {
  border-top: 1px solid var(--line); padding: 13px 16px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.05em;
  color: var(--fg-faint); text-transform: uppercase; display:flex; justify-content: space-between;
}

/* hero panel status rows (qualitative, no figures) */
.ro-status { display: flex; align-items: baseline; justify-content: space-between; padding: 7px 0; border-bottom: 1px dotted var(--line-dim); }
.ro-status:last-of-type { border-bottom: 0; }
.ro-status .sk { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-dim); }
.ro-status .sv { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); display: inline-flex; align-items: center; gap: 7px; }
.ro-status .sv.volt { color: var(--volt); }
.ro-status .ck { color: var(--volt-deep); font-size: 12px; }
.ro-status .ck.on { color: var(--volt); }

/* the two-product mini cards under hero on the visual side */
.ro-split { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line);
  border-top: 1px solid var(--line); }
.ro-split > div { background: var(--ink-1); padding: 14px 16px; }
.ro-split .lab { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--volt); }
.ro-split .nm { font-family: var(--font-disp); font-stretch: 112%; font-weight: 700; font-size: 14px; margin-top: 6px; }
.ro-split .ds { font-size: 11.5px; color: var(--fg-dim); margin-top: 4px; line-height: 1.4; }

/* marquee strip of asset types beneath hero */
.assets-strip {
  border-top: 1px solid var(--line-dim); border-bottom: 1px solid var(--line-dim);
  background: var(--ink-1); overflow: hidden; position: relative; z-index: 2;
}
.assets-track { display: flex; gap: 56px; padding: 16px 0; white-space: nowrap;
  width: max-content; animation: marq 32s linear infinite; }
.assets-strip:hover .assets-track { animation-play-state: paused; }
.assets-track span { font-family: var(--font-mono); font-size: 12.5px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--fg-dim); display: inline-flex; align-items: center; gap: 56px; }
.assets-track span::after { content: "—"; color: var(--volt); }
@keyframes marq { to { transform: translateX(-50%); } }

/* ============================================================
   PROBLEM — phantom megawatts
   ============================================================ */
.prob-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,64px); align-items: center; margin-top: 56px; }
.phantom-viz { padding: 28px; }
.pv-head { display:flex; justify-content: space-between; align-items: baseline; margin-bottom: 24px; }
.pv-head .ttl { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.pv-bar-wrap { margin-bottom: 26px; }
.pv-bar-label { display:flex; justify-content: space-between; align-items: baseline; margin-bottom: 9px; }
.pv-bar-label .name { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-2); }
.pv-bar-label .pct { font-family: var(--font-disp); font-stretch: 110%; font-weight: 800; font-size: 20px; }
.pv-bar { height: 46px; background: var(--ink); border: 1px solid var(--line); border-radius: 2px; overflow: hidden; position: relative; }
.pv-fill { height: 100%; position: relative; transition: width 1.3s var(--ease); }
.pv-fill.committed { background: linear-gradient(90deg, var(--ink-3), var(--ink-2)); border-right: 1px solid var(--phantom); }
.pv-fill.committed::after { content:""; position:absolute; inset:0;
  background: repeating-linear-gradient(135deg, oklch(0.56 0.022 250 / 0.5) 0 2px, transparent 2px 7px); }
.pv-fill.delivered { background: linear-gradient(90deg, var(--volt-deep), var(--volt)); box-shadow: 0 0 30px -4px var(--volt-glow); }
.pv-gap-note { font-family: var(--font-mono); font-size: 12px; color: var(--fg-faint); margin-top: 9px; letter-spacing: 0.04em; }

.alarm-card { margin-top: 4px; border: 1px solid oklch(0.70 0.175 42 / 0.4);
  background: oklch(0.70 0.175 42 / 0.07); border-radius: 3px; padding: 18px 20px; display:flex; gap:16px; align-items: flex-start; }
.alarm-card .ic { width: 34px; height: 34px; flex: none; border: 1px solid var(--alarm); border-radius: 50%;
  display:flex; align-items:center; justify-content:center; color: var(--alarm); font-family: var(--font-mono); font-weight:600; }
.alarm-card .tx b { color: var(--alarm); }
.alarm-card .tx { font-size: 14px; color: var(--fg-2); line-height: 1.45; }
.alarm-card .tx .mono { display:block; font-size: 10.5px; color: var(--fg-faint); margin-top: 5px; letter-spacing: 0.05em; }

.prob-stats { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 3px; overflow: hidden; }
.prob-stats .st { background: var(--ink-1); padding: 22px 24px; }
.prob-stats .st .n { font-family: var(--font-disp); font-stretch: 116%; font-weight: 800; font-size: clamp(2rem,3.6vw,2.9rem); letter-spacing: -0.02em; line-height: 1; }
.prob-stats .st .n.bad { color: var(--phantom); }
.prob-stats .st .l { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-dim); margin-top: 10px; line-height: 1.4; }

/* ============================================================
   PLATFORM — architecture diagram (between VPP & EMS)
   ============================================================ */
.arch { margin-top: 52px; display: flex; flex-direction: column; }

.arch-tier { border: 1px solid var(--line); border-radius: 3px; background: var(--ink-1);
  padding: 16px 22px; display: grid; grid-template-columns: 220px 1fr; gap: 22px; align-items: center; }
.arch-tier + .arch-tier { margin-top: 12px; }
.at-label { display: flex; flex-direction: column; gap: 3px; }
.at-label .at-n { font-family: var(--font-disp); font-stretch: 112%; font-weight: 800; font-size: 16px; letter-spacing: -0.01em; }
.at-label .at-s { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-dim); }
.at-body { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.at-note { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.03em; color: var(--fg-faint); }
.chip { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 7px 13px; border: 1px solid var(--line); border-radius: 2px; color: var(--fg-2); background: var(--ink); }
.arch-tier.market { background: var(--ink-2); }
.arch-tier.market .chip { border-color: var(--line); color: var(--fg); }
.arch-tier.access { padding: 13px 22px; }
.arch-tier.access .at-n { font-size: 14px; }
.arch-tier.grid-tier .chip.asset { border-color: var(--line); color: var(--fg-2); }

/* flow connectors */
.arch-flow { display: flex; align-items: center; justify-content: center; gap: 16px; height: 38px; }
.arch-flow .ff { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--volt); }
.arch-flow .fdiv { width: 1px; height: 16px; background: var(--line); }

/* ChargeCatalyst layer — the hero */
.arch-cc { position: relative; border: 1.5px solid var(--volt); border-radius: 4px; padding: 0;
  background: linear-gradient(180deg, rgba(27,95,224,0.08), rgba(27,95,224,0.02));
  box-shadow: 0 0 70px -34px var(--volt-glow); overflow: hidden; }
.cc-bar { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  padding: 14px 22px; border-bottom: 1px solid var(--volt-line, rgba(27,95,224,0.28)); background: rgba(27,95,224,0.06); }
.cc-id { display: flex; align-items: center; gap: 11px; font-family: var(--font-disp); font-stretch: 115%;
  font-weight: 800; font-size: 19px; letter-spacing: -0.01em; }
.cc-mark { width: 16px; height: 16px; background: var(--volt); border-radius: 3px; }
.cc-kind { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--volt); }

.cc-flow { display: grid; grid-template-columns: 1fr auto 1fr; gap: 0; align-items: stretch; }
.cc-side { padding: 22px; display: flex; flex-direction: column; gap: 7px; }
.cc-side.right { text-align: right; align-items: flex-end; }
.cc-side-h { display: flex; align-items: center; gap: 9px; font-family: var(--font-disp); font-stretch: 112%; font-weight: 700; font-size: 16px; }
.cc-side.right .cc-side-h { flex-direction: row-reverse; }
.cc-side-h .num { font-family: var(--font-mono); font-size: 12px; color: var(--volt); font-weight: 500; }
.cc-side-d { font-size: 13.5px; color: var(--fg-dim); line-height: 1.45; max-width: 28ch; }
.cc-arrow { margin-top: auto; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--volt); padding-top: 8px; }
.cc-model { width: 232px; padding: 22px 20px; border-left: 1px solid var(--volt-line, rgba(27,95,224,0.28));
  border-right: 1px solid var(--volt-line, rgba(27,95,224,0.28)); background: rgba(27,95,224,0.05);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; }
.cm-h { font-family: var(--font-disp); font-stretch: 115%; font-weight: 800; font-size: 18px; letter-spacing: -0.01em; }
.cm-d { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.02em; color: var(--fg-dim); line-height: 1.4; }
.cm-core { margin-top: 4px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--volt); border: 1px solid var(--volt); border-radius: 2px; padding: 4px 10px; }

/* microgrid single-line schematic */
.arch-scene { margin-top: 12px; border: 1px solid var(--line); border-radius: 3px; background: var(--ink-2); padding: 18px 24px 14px; }
.arch-scene .scene-label { display: flex; flex-direction: row; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.arch-scene .scene-label .at-n { font-family: var(--font-disp); font-stretch: 112%; font-weight: 800; font-size: 16px; letter-spacing: -0.01em; }
.arch-scene .scene-label .at-s { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--volt); }
.mg { width: 100%; height: auto; display: block; margin-top: 8px; }
.mg .st { fill: none; stroke: var(--fg); stroke-width: 1.6; stroke-linejoin: round; stroke-linecap: round; }
.mg .ac { fill: none; stroke: var(--volt); stroke-width: 1.8; stroke-linejoin: round; stroke-linecap: round; }
.mg .acf { fill: var(--volt-glow); stroke: var(--volt); stroke-width: 1.8; stroke-linejoin: round; }
.mg .fav { fill: var(--volt-glow); stroke: none; }
.mg .bus { fill: none; stroke: var(--volt); stroke-width: 1.6; stroke-dasharray: 2 6; stroke-linecap: round; }
.mg .busline { fill: none; stroke: var(--volt); stroke-width: 1.6; stroke-dasharray: 2 6; stroke-linecap: round; }
.mg .drop line { stroke: var(--volt); stroke-width: 1.4; }
.mg .node circle { fill: var(--volt); }
.mg .nodef { fill: var(--volt); }
.mg .mglbl text { font-family: var(--font-mono); fill: var(--fg-dim); font-size: 13px; letter-spacing: 0.12em; }
.mg .emsx { font-family: var(--font-mono); fill: var(--volt); font-size: 13px; font-weight: 600; letter-spacing: 0.06em; }

/* ============================================================
   WORKED EXAMPLE — EV journey + before/after
   ============================================================ */
/* shared line-art */
.linart .st { fill: none; stroke: var(--fg); stroke-width: 1.6; stroke-linejoin: round; stroke-linecap: round; }
.linart .ac { fill: none; stroke: var(--volt); stroke-width: 1.8; stroke-linejoin: round; stroke-linecap: round; }
.linart .acf { fill: var(--volt-glow); stroke: var(--volt); stroke-width: 1.6; stroke-linejoin: round; }
.linart .acf2 { fill: var(--volt); }
.linart .fav { fill: var(--volt-glow); }
.linart .knob { fill: var(--volt); }
.linart .ground { stroke: var(--line); stroke-width: 1.4; }
.linart .muted { fill: var(--line-dim); }

/* journey band */
.journey { margin-top: 46px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.jstep { position: relative; background: var(--ink-1); border: 1px solid var(--line); border-radius: 4px; padding: 24px 20px 24px; }
.jstep .jicon { width: 40px; height: 40px; display: block; }
.jstep .jn { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; color: var(--volt); margin-top: 16px; }
.jstep .jt { font-family: var(--font-disp); font-stretch: 112%; font-weight: 700; font-size: 18px; letter-spacing: -0.01em; color: var(--fg); margin-top: 5px; }
.jstep .jc { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.02em; color: var(--fg-dim); margin-top: 9px; line-height: 1.4; }
.jstep:not(:last-child)::after { content: "→"; position: absolute; right: -12px; top: 40px;
  color: var(--volt); font-family: var(--font-mono); font-size: 15px; z-index: 2; }

/* before / after */
.xform { margin-top: 16px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch; }
.xpanel { padding: 26px 28px 30px; border: 1px solid var(--line); display: flex; flex-direction: column; align-items: center; text-align: center; }
.xpanel.before { background: var(--ink-2); border-radius: 4px 0 0 4px; }
.xpanel.after { background: var(--ink-1); border: 1.5px solid var(--volt); border-radius: 0 4px 4px 0; box-shadow: 0 0 70px -36px var(--volt-glow); }
.xtag { align-self: flex-start; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-faint); }
.xpanel.after .xtag { color: var(--volt); }
.xchips { display: flex; flex-wrap: wrap; gap: 7px; justify-content: center; margin-top: 20px; min-height: 26px; }
.xchip { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 6px 11px; border: 1px solid var(--volt); border-radius: 2px; color: var(--volt); background: var(--volt-glow); }
.xchip.ghost { border-color: var(--line-dim); color: var(--fg-faint); background: transparent; }
.xups { display: flex; gap: 30px; justify-content: center; margin: 12px 0 2px; color: var(--volt); font-family: var(--font-mono); font-size: 15px; }
.xar { color: var(--fg-faint); font-size: 17px; margin: 12px 0 2px; }
.linart.bsite, .linart.asite { width: 100%; max-width: 230px; height: auto; margin: 8px 0 2px; }
.xpanel.before .linart .st { stroke: var(--phantom); }
.xpanel.before .linart .muted { fill: var(--line); }
.xcap { font-family: var(--font-disp); font-stretch: 112%; font-weight: 700; font-size: 17px; color: var(--fg); margin-top: 16px; }
.xpanel.before .xcap { color: var(--fg-2); }
.xsub { font-size: 13.5px; color: var(--fg-dim); margin-top: 7px; max-width: 32ch; line-height: 1.45; }
.xmid { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 9px; padding: 0 20px; }
.xmid .xarrow { color: var(--volt); font-size: 24px; }
.xmid .xlabel { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }

/* ============================================================
   AGENT DETAIL — stages
   ============================================================ */
.split-head { display: flex; flex-direction: column; align-items: flex-start; gap: 16px; }
.split-head .lede { max-width: 62ch; }
.stages { margin-top: 52px; display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.stage { position: relative; padding: 26px 24px 28px; }
.stage .sn { font-family: var(--font-mono); font-size: 12px; color: var(--volt); letter-spacing: 0.1em; }
.stage .stt { font-family: var(--font-disp); font-stretch: 116%; font-weight: 800; font-size: 22px; margin-top: 14px; letter-spacing: -0.01em; }
.stage ul { list-style: none; margin-top: 18px; display: grid; gap: 10px; }
.stage li { font-size: 14px; color: var(--fg-2); display: flex; gap: 10px; align-items: baseline; line-height: 1.4; }
.stage li::before { content: ""; width: 6px; height: 6px; flex: none; background: var(--volt); transform: translateY(1px); }

.ops { margin-top: 52px; display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 22px; align-items: stretch; }
.ops-list { display: grid; gap: 14px; }
.ops-item { padding: 20px 22px; display:flex; gap: 18px; align-items: flex-start; }
.ops-item .oi-n { font-family: var(--font-mono); font-size: 12px; color: var(--volt); padding-top: 2px; }
.ops-item .oi-t { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 16px; }
.ops-item .oi-d { font-size: 13.5px; color: var(--fg-dim); margin-top: 5px; line-height: 1.45; }
.ops-viz { padding: 26px; display: flex; flex-direction: column; justify-content: center; gap: 18px; }
.ops-viz .ovt { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.wave { width: 100%; height: 120px; }

/* ============================================================
   CASE STUDY — revenue stack before/after
   ============================================================ */
.ba { margin-top: 56px; display: grid; grid-template-columns: 1fr auto 1fr; gap: 0; align-items: stretch; }
.ba-col { padding: 30px; }
.ba-col.before { border: 1px solid var(--line); border-radius: 3px 0 0 3px; background: var(--ink-1); }
.ba-col.after { border: 1px solid var(--volt-deep); border-radius: 0 3px 3px 0;
  background: linear-gradient(var(--ink-1),var(--ink-1)) padding-box, linear-gradient(120deg, var(--volt-deep), transparent) border-box;
  box-shadow: 0 0 70px -34px var(--volt-glow); }
.ba-arrow { display:flex; align-items:center; justify-content:center; width: 64px; color: var(--volt); }
.ba-tag { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.ba-col.after .ba-tag { color: var(--volt); }
.ba-cap { font-size: 13px; color: var(--fg-dim); margin-top: 6px; }
.rev-rows { margin-top: 24px; display: grid; gap: 2px; }
.rev-row { display:flex; align-items: center; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px solid var(--line-dim); }
.rev-row .rl { font-size: 13.5px; color: var(--fg-2); display:flex; align-items:center; gap:10px; }
.rev-row .rl .mk { width: 16px; height: 16px; flex:none; border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 12px; font-family: var(--font-mono); }
.rev-row.off .rl { color: var(--fg-faint); }
.rev-row.off .mk { border: 1px solid var(--line); color: var(--fg-faint); }
.rev-row.on .mk { background: var(--volt); color: var(--ink); }
.rev-row .rv { font-family: var(--font-mono); font-size: 13px; color: var(--fg-dim); white-space: nowrap; }
.rev-row.on .rv { color: var(--fg); }
.ba-total { display:flex; align-items: baseline; justify-content: space-between; margin-top: 22px; padding-top: 18px; }
.ba-total .tl { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.ba-total .tv { font-family: var(--font-disp); font-stretch: 116%; font-weight: 800; font-size: clamp(1.7rem,2.8vw,2.4rem); letter-spacing: -0.02em; }
.ba-col.after .ba-total .tv { color: var(--volt); }
.ba-foot { margin-top: 30px; text-align: center; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.05em; color: var(--fg-dim); }
.ba-foot b { color: var(--volt); }

/* ============================================================
   MARKET — TAM/SAM/SOM + compounding
   ============================================================ */
.mkt { margin-top: 56px; display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(28px,4vw,56px); align-items: center; }
.tam { position: relative; aspect-ratio: 1; max-width: 460px; width: 100%; margin: 0 auto; }
.tam-ring { position: absolute; border-radius: 50%; display: flex; align-items: flex-start; justify-content: center;
  border: 1px solid var(--line); }
.tam-ring .rl { margin-top: 14px; text-align: center; }
.tam-ring .rl .rn { font-family: var(--font-disp); font-stretch: 116%; font-weight: 800; letter-spacing: -0.02em; }
.tam-ring .rl .rk { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-dim); margin-top: 2px; }
.tam-tam { inset: 0; background: oklch(0.20 0.014 248 / 0.4); }
.tam-tam .rn { font-size: clamp(2rem,3.6vw,2.8rem); }
.tam-sam { inset: 18%; background: oklch(0.225 0.015 248 / 0.6); border-color: var(--line); }
.tam-sam .rn { font-size: clamp(1.5rem,2.6vw,2rem); }
.tam-som { inset: 38%; background: var(--volt-glow); border-color: var(--volt-deep); box-shadow: 0 0 50px -16px var(--volt-glow); }
.tam-som .rl { margin-top: 0; position: absolute; top: 50%; transform: translateY(-50%); }
.tam-som .rn { font-size: clamp(1.4rem,2.4vw,1.9rem); color: var(--volt); }
.mkt-notes { display: grid; gap: 18px; }
.mkt-note { display: grid; grid-template-columns: auto 1fr; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--line-dim); }
.mkt-note .mn { font-family: var(--font-disp); font-stretch: 114%; font-weight: 800; font-size: 20px; }
.mkt-note .mt b { display:block; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); margin-bottom: 5px; }
.mkt-note .mt { font-size: 13.5px; color: var(--fg-dim); line-height: 1.5; }

.compound { margin-top: 50px; display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 3px; overflow: hidden; }
.compound .cstep { background: var(--ink-1); padding: 24px 22px; position: relative; }
.compound .cstep:last-child { background: linear-gradient(180deg, var(--volt-glow), var(--ink-1)); }
.compound .cstep .cs-sites { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-dim); }
.compound .cstep .cs-rev { font-family: var(--font-disp); font-stretch: 114%; font-weight: 800; font-size: clamp(1.3rem,2.2vw,1.8rem); letter-spacing: -0.02em; margin-top: 12px; }
.compound .cstep:last-child .cs-rev { color: var(--volt); }
.compound .cstep .cs-bar { height: 4px; margin-top: 16px; background: var(--volt); border-radius: 2px; }

/* ============================================================
   TRACTION — pipeline table
   ============================================================ */
.pipe { margin-top: 52px; border: 1px solid var(--line); border-radius: 3px; overflow: hidden; }
.pipe-row { display: grid; grid-template-columns: 1.4fr 1.6fr auto; gap: 20px; align-items: center;
  padding: 20px 26px; border-bottom: 1px solid var(--line-dim); transition: background 0.2s; }
.pipe-row:last-child { border-bottom: 0; }
.pipe-row:hover { background: var(--ink-1); }
.pipe-row.hdr { background: var(--ink-1); border-bottom: 1px solid var(--line); }
.pipe-row.hdr span { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.pipe-row .pname { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 16px; }
.pipe-row .pscope { font-size: 13.5px; color: var(--fg-dim); line-height: 1.4; }
.pstatus { justify-self: end; display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 6px 12px; border-radius: 2px; border: 1px solid var(--line); white-space: nowrap; }
.pstatus .d { width: 7px; height: 7px; border-radius: 50%; }
.pstatus.signed { border-color: var(--volt-deep); color: var(--volt); }
.pstatus.signed .d { background: var(--volt); }
.pstatus.active { border-color: var(--line); color: var(--fg-2); }
.pstatus.active .d { background: oklch(0.70 0.12 200); }
.pstatus.talk { border-color: var(--line); color: var(--fg-dim); }
.pstatus.talk .d { background: var(--phantom); }

/* ============================================================
   BEYOND EV + COMPETITION
   ============================================================ */
.beyond { margin-top: 50px; display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.beyond .bc { padding: 26px 22px; min-height: 160px; display: flex; flex-direction: column; justify-content: space-between; transition: transform 0.3s var(--ease), border-color 0.3s; }
.beyond .bc:hover { transform: translateY(-4px); }
.beyond .bc .bn { font-family: var(--font-mono); font-size: 12px; color: var(--volt); letter-spacing: 0.08em; }
.beyond .bc .bt { font-family: var(--font-disp); font-stretch: 114%; font-weight: 800; font-size: 19px; letter-spacing: -0.01em; }
.beyond .bc .bd { font-size: 12.5px; color: var(--fg-dim); margin-top: 8px; line-height: 1.4; }

.compete { margin-top: 56px; display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 3px; overflow: hidden; }
.compete .cr { display: grid; grid-template-columns: 0.9fr 1.1fr 1fr; gap: 24px; padding: 20px 26px; background: var(--ink); align-items: center; }
.compete .cr.h span { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.compete .cr.h { background: var(--ink-1); }
.compete .cr .who { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 15px; }
.compete .cr .lack { font-size: 13px; color: var(--fg-dim); display:flex; gap:9px; align-items:baseline; }
.compete .cr .lack::before { content: "✕"; color: var(--phantom); font-size: 12px; }
.compete .cr .have { font-size: 13px; color: var(--fg-2); display:flex; gap:9px; align-items:baseline; }
.compete .cr .have::before { content: ""; width:7px; height:7px; background: var(--volt); flex:none; transform: translateY(4px); }

/* ============================================================
   TEAM
   ============================================================ */
.team { margin-top: 52px; display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.member { padding: 0; overflow: hidden; }
.member .photo { aspect-ratio: 4/3; background: var(--ink); border-bottom: 1px solid var(--line); position: relative; }
.member image-slot { width: 100%; height: 100%; }
.member .info { padding: 24px 26px 28px; }
.member .mrole { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--volt); }
.member .mname { font-family: var(--font-disp); font-stretch: 116%; font-weight: 800; font-size: 26px; margin-top: 8px; letter-spacing: -0.01em; }
.member .mbio { font-size: 13.5px; color: var(--fg-dim); margin-top: 12px; line-height: 1.5; }
.member .mlinks { margin-top: 16px; display: flex; gap: 10px; }
.member .mlinks a { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--fg-2); border: 1px solid var(--line); padding: 6px 11px; border-radius: 2px; transition: all 0.2s; }
.member .mlinks a:hover { border-color: var(--volt); color: var(--volt); }
.team-meta { margin-top: 22px; display: flex; gap: 30px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-dim); }
.team-meta b { color: var(--fg-2); }

/* ============================================================
   CONTACT / CLOSE
   ============================================================ */
.close { position: relative; overflow: hidden; }
.close .close-bg { position:absolute; inset:0; z-index:0; pointer-events:none;
  background: radial-gradient(ellipse 60% 90% at 50% 120%, var(--volt-glow), transparent 60%); }
.close-in { position: relative; z-index: 2; text-align: center; max-width: 880px; margin: 0 auto; }
.close h2 { font-family: var(--font-disp); font-stretch: 125%; font-weight: 900; letter-spacing: -0.025em;
  line-height: 0.95; font-size: clamp(2.4rem, 6vw, 5rem); }
.close .csub { margin-top: 24px; font-size: clamp(1.05rem,1.5vw,1.3rem); color: var(--fg-2); max-width: 56ch; margin-inline: auto; }
.close-cta { margin-top: 38px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.close-mails { margin-top: 40px; display: inline-flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.mail-card { border: 1px solid var(--line); border-radius: 3px; padding: 16px 22px; text-align: left; transition: border-color 0.2s; background: var(--glass); }
.mail-card:hover { border-color: var(--volt-deep); }
.mail-card .who { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 14px; }
.mail-card .role { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-dim); margin-top: 2px; }
.mail-card .addr { font-family: var(--font-mono); font-size: 12.5px; color: var(--volt); margin-top: 10px; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { border-top: 1px solid var(--line); padding-block: 48px; }
.foot-in { display: flex; justify-content: space-between; align-items: flex-start; gap: 30px; flex-wrap: wrap; }
.foot .brand .word { font-size: 16px; }
.foot .ftag { color: var(--fg-dim); font-size: 13.5px; margin-top: 12px; max-width: 30ch; }
.foot-meta { text-align: right; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em; color: var(--fg-faint); line-height: 1.8; text-transform: uppercase; }
.foot-meta a:hover { color: var(--volt); }

/* ============================================================
   VISION STATEMENT
   ============================================================ */
.statement .big-stmt {
  font-family: var(--font-disp); font-stretch: 110%; font-weight: 700;
  letter-spacing: -0.02em; line-height: 1.08;
  font-size: clamp(1.9rem, 4.4vw, 3.4rem);
  margin-top: 30px; max-width: 18ch; text-wrap: balance;
}
.statement .stmt-sub {
  margin-top: 30px; max-width: 56ch; color: var(--fg-2);
  font-size: clamp(1.02rem, 1.4vw, 1.25rem); line-height: 1.55; text-wrap: pretty;
}

/* ============================================================
   WHO WE WORK WITH
   ============================================================ */
.work-grid { margin-top: 52px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.work-card { padding: 26px 24px 28px; min-height: 210px; display: flex; flex-direction: column;
  transition: transform 0.3s var(--ease), border-color 0.3s; }
.work-card:hover { transform: translateY(-4px); border-color: var(--volt-deep); }
.work-card .wc-k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--volt); }
.work-card .wc-t { font-family: var(--font-disp); font-stretch: 114%; font-weight: 800; font-size: 20px; letter-spacing: -0.01em; margin-top: 14px; }
.work-card .wc-d { font-size: 13.5px; color: var(--fg-dim); margin-top: 12px; line-height: 1.5; }

/* ============================================================
   DIFFERENTIATORS
   ============================================================ */
.diff { margin-top: 40px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.diff-item { padding: 24px 26px; }
.diff-item .dt { font-family: var(--font-disp); font-stretch: 112%; font-weight: 700; font-size: 17px;
  display: flex; align-items: baseline; gap: 11px; }
.diff-item .dt::before { content: ""; width: 8px; height: 8px; background: var(--volt); flex: none; transform: translateY(2px); }
.diff-item .dd { font-size: 13.5px; color: var(--fg-dim); margin-top: 10px; line-height: 1.5; padding-left: 19px; }

/* before/after role label sizing */
.ba-total .tv.tv-sm { font-size: clamp(1.2rem, 2vw, 1.6rem); }

/* ============================================================
   AGENT STAGES — calm rows, not cards
   ============================================================ */
.stages { margin-top: 44px; display: grid; grid-template-columns: 1fr; gap: 1px; background: var(--line-dim);
  border: 1px solid var(--line-dim); border-radius: 3px; overflow: hidden; }
.stage-row { display: grid; grid-template-columns: 52px 180px 1fr; gap: 28px; align-items: baseline;
  background: var(--ink); padding: 26px 28px; transition: background 0.2s; }
.stage-row:hover { background: var(--ink-1); }
.stage-row .sn { font-family: var(--font-mono); font-size: 13px; color: var(--volt); letter-spacing: 0.05em; }
.stage-row .stt { font-family: var(--font-disp); font-stretch: 112%; font-weight: 800; font-size: 20px; letter-spacing: -0.01em; }
.stage-row .sd { font-size: 14.5px; color: var(--fg-dim); line-height: 1.55; max-width: 60ch; }

/* ============================================================
   FIRMNESS OPS — calm rows + viz
   ============================================================ */
.ops { margin-top: 44px; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 22px; align-items: stretch; }
.ops-list { display: grid; gap: 1px; background: var(--line-dim);
  border: 1px solid var(--line-dim); border-radius: 3px; overflow: hidden; }
.ops-row { display: flex; gap: 22px; align-items: flex-start; background: var(--ink); padding: 24px 26px; transition: background 0.2s; }
.ops-row:hover { background: var(--ink-1); }
.ops-row .oi-n { font-family: var(--font-mono); font-size: 13px; color: var(--volt); padding-top: 2px; }
.ops-row .oi-t { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 16px; }
.ops-row .oi-d { font-size: 14px; color: var(--fg-dim); margin-top: 6px; line-height: 1.5; }
.ovt-legend { display: flex; gap: 22px; font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-dim); }
.ovt-legend span { display: inline-flex; align-items: center; gap: 7px; }
.ovt-legend .lg { width: 16px; height: 0; border-top-width: 2px; border-top-style: solid; }
.ovt-legend .lg.solid { border-color: var(--volt); }
.ovt-legend .lg.dash { border-top-style: dashed; border-color: var(--phantom); }

/* ============================================================
   AUDIENCE
   ============================================================ */
.aud-grid { margin-top: 48px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--line-dim); border: 1px solid var(--line-dim); border-radius: 3px; overflow: hidden; }
.aud-card { background: var(--ink); padding: 30px 28px; min-height: 190px;
  display: flex; flex-direction: column; transition: background 0.2s; }
.aud-card:hover { background: var(--ink-1); }
.aud-card .ac-t { font-family: var(--font-disp); font-stretch: 112%; font-weight: 800; font-size: 19px;
  letter-spacing: -0.01em; padding-bottom: 14px; border-bottom: 1px solid var(--volt-deep); margin-bottom: 16px; align-self: flex-start; }
.aud-card .ac-d { font-size: 14px; color: var(--fg-dim); line-height: 1.55; }

/* ============================================================
   HERO MOTTO — Plan · Operate · Prove
   ============================================================ */
.hero-motto { margin-top: 26px; display: inline-flex; align-items: center; gap: 16px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; }
.hero-motto span { color: var(--fg-2); }
.hero-motto i { width: 5px; height: 5px; background: var(--volt); display: inline-block; }

/* ============================================================
   ONE ENVELOPE — one block, four programs
   ============================================================ */
.envelope { margin-top: 52px; padding: clamp(22px, 3.4vw, 38px); }
.env-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(26px, 4vw, 56px); align-items: stretch; }
.env-left { display: flex; flex-direction: column; }
.env-col { flex: 1; min-height: 300px; display: flex; flex-direction: column; }
.env-ceil { position: relative; height: 0; border-top: 1.5px dashed var(--phantom); }
.env-ceil span { position: absolute; right: 0; top: -9px; background: var(--panel); padding: 0 0 0 10px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.env-reserve { height: 46px; position: relative;
  background-image: repeating-linear-gradient(45deg, transparent 0 8px, var(--line-dim) 8px 9px); }
.env-reserve span { position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-faint); }
.env-fill { flex: 1; min-height: 150px; border: 1px solid var(--volt); border-top: none;
  background: linear-gradient(180deg, var(--volt-soft, rgba(27,95,224,0.16)), rgba(27,95,224,0.05));
  position: relative; display: flex; flex-direction: column; justify-content: center; padding: 0 22px; gap: 7px; }
.env-fill::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--volt); }
.env-fill-l { font-family: var(--font-disp); font-weight: 800; font-size: clamp(17px, 1.9vw, 22px); letter-spacing: -0.01em; color: var(--fg); }
.env-fill-s { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em; color: var(--volt-deep); }
.env-axis { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-top: 12px; }
.env-axis span:first-child { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.env-axis span:last-child { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--fg-faint); }
.env-right { display: flex; flex-direction: column; }
.env-rhead { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--volt); padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 4px; }
.env-prog { display: grid; grid-template-columns: 16px 1fr auto; align-items: baseline; gap: 14px;
  padding: 16px 0; border-bottom: 1px solid var(--line-dim); }
.env-prog .ep-tick { width: 10px; height: 10px; background: var(--volt); transform: translateY(2px); }
.env-prog .ep-n { font-family: var(--font-disp); font-weight: 700; font-size: clamp(16px, 1.7vw, 19px); letter-spacing: -0.01em; }
.env-prog .ep-c { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-dim); }
.env-rbase { margin-top: 16px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.03em; color: var(--fg-faint); }
.env-foot { margin-top: 28px; text-align: center; font-family: var(--font-mono); font-size: 12.5px;
  letter-spacing: 0.04em; color: var(--fg-dim); }
.env-foot b { color: var(--volt); }

/* (legacy envelope styles retained below, unused) */
.env-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  padding-bottom: 18px; border-bottom: 1px solid var(--line); margin-bottom: 26px; }
.env-head .eh-t { font-family: var(--font-disp); font-stretch: 114%; font-weight: 800; font-size: 19px; letter-spacing: -0.01em; }
.env-head .eh-s { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--volt); }
.env-ceiling { position: relative; height: 0; border-top: 1.5px dashed var(--phantom); margin-bottom: 22px; }
.env-ceiling span { position: absolute; right: 0; top: -9px; background: var(--ink-1); padding-left: 10px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-dim); }
.env-tracks { display: grid; gap: 16px; }
.env-track { display: grid; grid-template-columns: 168px 1fr; gap: 22px; align-items: center; }
.et-meta { display: flex; flex-direction: column; gap: 3px; }
.et-meta .et-n { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 15px; }
.et-meta .et-c { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-faint); }
.et-bar { position: relative; height: 30px; background: var(--ink);
  border: 1px solid var(--line-dim); border-radius: 2px; }
.et-bar.thin { height: 30px; }
.et-bar .blk { position: absolute; top: 4px; bottom: 4px; border-radius: 1px;
  background: linear-gradient(180deg, var(--volt), var(--volt-deep)); box-shadow: 0 0 18px -6px var(--volt-glow); }
.et-bar .blk.evt { background: repeating-linear-gradient(135deg, var(--volt) 0 3px, var(--volt-deep) 3px 6px); }
.env-base { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line);
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.env-base span:first-child { font-family: var(--font-disp); font-stretch: 110%; font-weight: 700; font-size: 14px; color: var(--fg-2); }
.env-base span:last-child { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-faint); }
.env-foot { margin-top: 26px; text-align: center; font-family: var(--font-mono); font-size: 12.5px;
  letter-spacing: 0.04em; color: var(--fg-dim); }
.env-foot b { color: var(--volt); }

/* ============================================================
   WHY — 4 pillars
   ============================================================ */
.why { margin-top: 48px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px;
  background: var(--line-dim); border: 1px solid var(--line-dim); border-radius: 3px; overflow: hidden; }
.why-item { background: var(--ink); padding: 30px 30px 34px; transition: background 0.2s; }
.why-item:hover { background: var(--ink-1); }
.why-item .wt { font-family: var(--font-disp); font-stretch: 114%; font-weight: 800; font-size: 19px;
  letter-spacing: -0.01em; display: flex; align-items: baseline; gap: 12px; }
.why-item .wt::before { content: ""; width: 9px; height: 9px; background: var(--volt); flex: none; transform: translateY(2px); }
.why-item .wd { font-size: 14px; color: var(--fg-dim); margin-top: 12px; line-height: 1.55; padding-left: 21px; }

/* contact address line */
.close-addr { margin-top: 32px; font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-faint); }

/* ============================================================
   WHY-NOW ASSET ROW
   ============================================================ */
.statement .asset-row { margin-top: 36px; display: flex; flex-wrap: wrap; align-items: center; }
.statement .asset-row span { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--fg-dim); display: inline-flex; align-items: center; }
.statement .asset-row span:not(:last-child)::after { content: "·"; color: var(--volt); margin: 0 16px; }

/* ============================================================
   PLATFORM THESIS — physics-based agents at scale
   ============================================================ */
.stack-thesis { margin-top: 36px; max-width: 76ch; font-size: clamp(1rem, 1.35vw, 1.2rem);
  color: var(--fg-2); line-height: 1.55; text-wrap: pretty; }
.stack-thesis b { color: var(--fg); font-weight: 600; }

/* ============================================================
   CREDIT KARMA CALLOUT — Firmness Engine
   ============================================================ */
.ck-callout { margin-top: 44px; padding: clamp(26px, 3.8vw, 46px); }
.ck-tag { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-dim); }
.ck-quote { font-family: var(--font-disp); font-stretch: 116%; font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.04; font-size: clamp(1.7rem, 3.6vw, 2.8rem); margin-top: 16px; text-wrap: balance; }
.ck-body { margin-top: 22px; max-width: 72ch; font-size: clamp(1rem, 1.35vw, 1.2rem); color: var(--fg-2); line-height: 1.55; text-wrap: pretty; }
.ck-body b { color: var(--fg); font-weight: 600; }
.ck-foot { margin-top: 28px; display: flex; align-items: center; gap: 14px; font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--volt); }
.ck-foot .ck-line { width: 34px; height: 1.5px; background: var(--volt); display: inline-block; }

/* ============================================================
   STANDARDS & PARTICIPATION — credibility strip
   ============================================================ */
.standards { margin-top: 48px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--line-dim); border: 1px solid var(--line-dim); border-radius: 3px; overflow: hidden; }
.std-col { background: var(--ink); padding: 26px 24px 30px; transition: background 0.2s; }
.std-col:hover { background: var(--ink-1); }
.std-h { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--volt); padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-bottom: 16px; }
.std-b { font-size: 13.5px; color: var(--fg-dim); line-height: 1.55; }

/* ============================================================
   SITE ASSESSOR — agentic consoles
   ============================================================ */
.agstages { margin-top: 44px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.agstage { display: flex; flex-direction: column; overflow: hidden; }
.ag-head { display: flex; align-items: center; gap: 11px; padding: 15px 18px; border-bottom: 1px solid var(--line); }
.ag-head .ag-n { font-family: var(--font-mono); font-size: 12px; color: var(--volt); }
.ag-head .ag-name { font-family: var(--font-disp); font-weight: 800; font-size: 17px; letter-spacing: -0.01em; }
.ag-head .ag-live { margin-left: auto; display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); }
.ag-head .ag-live .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--volt); animation: pulse 2.4s infinite; }
.ag-console { background: var(--ink-2); padding: 17px 18px; flex: 1; display: flex; flex-direction: column; gap: 9px;
  font-family: var(--font-mono); font-size: 12.5px; line-height: 1.3; border-bottom: 1px solid var(--line); }
.ag-line { color: var(--fg-2); display: flex; align-items: baseline; gap: 7px; flex-wrap: wrap; }
.ag-line .pr { color: var(--volt); font-weight: 700; }
.ag-line .tool { font-size: 12px; letter-spacing: 0.01em; color: var(--volt-deep); background: var(--ink-1);
  border: 1px solid var(--line); border-radius: 3px; padding: 1px 7px; }
.ag-line .ok { color: var(--volt); margin-left: auto; }
.ag-out { margin-top: auto; padding-top: 6px; color: var(--fg); display: flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 12.5px; }
.ag-out .ar { color: var(--volt); font-weight: 700; }
.ag-out .cur { display: inline-block; width: 7px; height: 13px; background: var(--volt); transform: translateY(2px); }
@media (prefers-reduced-motion: no-preference) { .ag-out .cur { animation: curblink 1.05s steps(1) infinite; } }
@keyframes curblink { 50% { opacity: 0; } }
.ag-cap { padding: 14px 18px; font-size: 13px; color: var(--fg-dim); line-height: 1.45;
  min-height: calc(2.9em + 28px); }  /* reserve 2 lines so the divider aligns across cards */

/* ============================================================
   RESPONSIVE (additions)
   ============================================================ */
@media (max-width: 960px) {
  .hero-in { grid-template-columns: 1fr; }
  .hero-vis { max-width: 440px; }
  .prob-grid, .mkt, .ops, .ba { grid-template-columns: 1fr; }
  .stage-row { grid-template-columns: 40px 1fr; gap: 12px 20px; }
  .stage-row .sd { grid-column: 2; }
  .aud-grid { grid-template-columns: 1fr 1fr; }
  .why { grid-template-columns: 1fr; }
  .env-track { grid-template-columns: 120px 1fr; gap: 16px; }
  .standards { grid-template-columns: 1fr 1fr; }
  .agstages { grid-template-columns: 1fr; }
  .env-grid { grid-template-columns: 1fr; gap: 30px; }
  .env-col { min-height: 240px; }
  .arch-tier { grid-template-columns: 1fr; gap: 12px; }
  .cc-flow { grid-template-columns: 1fr; }
  .cc-side, .cc-side.right { text-align: left; align-items: flex-start; }
  .cc-side.right .cc-side-h { flex-direction: row; }
  .cc-model { width: auto; border-left: none; border-right: none;
    border-top: 1px solid var(--volt-line, rgba(27,95,224,0.28));
    border-bottom: 1px solid var(--volt-line, rgba(27,95,224,0.28)); }
  .cc-arrow { display: none; }
  .journey { grid-template-columns: 1fr 1fr; gap: 14px; }
  .jstep:nth-child(2)::after { display: none; }
  .xform { grid-template-columns: 1fr; }
  .xpanel.before { border-radius: 4px 4px 0 0; }
  .xpanel.after { border-radius: 0 0 4px 4px; }
  .xmid { padding: 14px 0; }
  .xmid .xarrow { transform: rotate(90deg); }
  .ba { gap: 16px; }
  .ba-col.before { border-radius: 3px; } .ba-col.after { border-radius: 3px; }
  .ba-arrow { width: auto; height: 40px; transform: rotate(90deg); }
  .stages { grid-template-columns: 1fr; }
  .compound { grid-template-columns: 1fr 1fr; }
  .beyond { grid-template-columns: 1fr 1fr; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .diff { grid-template-columns: 1fr; }
  .team { grid-template-columns: 1fr; }
  .cc-agents { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .nav-links { display: none; }
  .nav-status { display: none; }
  .menu-btn { display: inline-flex; }
  .prob-stats { grid-template-columns: 1fr; }
  .compound { grid-template-columns: 1fr; }
  .beyond { grid-template-columns: 1fr; }
  .work-grid { grid-template-columns: 1fr; }
  .compete .cr { grid-template-columns: 1fr; gap: 8px; }
  .compete .cr.h { display: none; }
  .aud-grid { grid-template-columns: 1fr; }
  .stage-row { grid-template-columns: 1fr; gap: 6px; }
  .env-track { grid-template-columns: 1fr; gap: 8px; }
  .env-track .et-meta { flex-direction: row; align-items: baseline; gap: 10px; }
  .standards { grid-template-columns: 1fr; }
  .pipe-row { grid-template-columns: 1fr; gap: 8px; }
  .pipe-row.hdr { display: none; }
  .pstatus { justify-self: start; }
  .ro-split { grid-template-columns: 1fr; }
  .foot-in { flex-direction: column; } .foot-meta { text-align: left; }
}

/* team photos — circular founder avatars (real <img> in place of the omelette drop-slot) */
.member .photo {
  aspect-ratio: auto; height: auto;
  display: flex; align-items: center; justify-content: center;
  padding: 40px 0 30px; background: var(--ink-2);
  border-bottom: 1px solid var(--line);
}
.member .photo .avatar {
  width: 156px; height: 156px; flex: none;
  border-radius: 50%; padding: 4px; display: block;
  background: var(--line);
}
.member .photo .avatar-a { background: linear-gradient(140deg, #2BC4A8, #1B5FE0); }
.member .photo .avatar-b { background: linear-gradient(140deg, #1B5FE0, #8B5CF6); }
.member .photo .avatar img {
  width: 100%; height: 100%; display: block;
  border-radius: 50%; object-fit: cover; object-position: 50% 28%;
  background: var(--ink-1); box-shadow: 0 0 0 3px var(--ink-1);
}

/* ---- typography tuning: smaller headlines, tighter gaps, body unchanged ---- */
.section { padding-block: clamp(60px, 8vw, 108px); }
.hero h1 { font-size: clamp(2.4rem, 5.4vw, 4.3rem); }
h2.head { font-size: clamp(1.7rem, 3.6vw, 2.7rem); margin-top: 18px; }
.close h2 { font-size: clamp(2rem, 4.8vw, 3.6rem); }
.statement .big-stmt { font-size: clamp(1.7rem, 3.6vw, 2.7rem); margin-top: 22px; }
.lede { margin-top: 18px; }
.hero-sub { margin-top: 22px; }
.statement .stmt-sub { margin-top: 22px; }

/* ---- firm-capacity track inside the readout panel ---- */
.firmbar { display: flex; gap: 3px; height: 100%; }
.firmbar .seg { flex: 1; border-radius: 1px; }
.seg.solid { background: var(--volt); }
.seg.ghost {
  background: repeating-linear-gradient(135deg, var(--phantom) 0 2px, transparent 2px 5px);
  border: 1px dashed rgba(154, 171, 188, 0.7);
}

/* ---- a11y: screen-reader-only ---- */
.sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ---- de-animate blinking-dot badges (reads as AI tell) ---- */
.dot { animation: none !important; }
.nav-status .dot, .ag-live .dot, .live .dot { animation: none !important; box-shadow: none !important; }

/* ---- mobile nav: working dropdown menu ---- */
@media (max-width: 680px) {
  .menu-btn { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px;
    padding: 0; color: var(--fg); background: transparent; border: 1px solid var(--line); border-radius: 2px;
    cursor: pointer; transition: border-color 0.2s, color 0.2s; }
  .menu-btn:hover { border-color: var(--volt); color: var(--volt); }
  .nav-links { display: flex; flex-direction: column; gap: 0; align-items: stretch;
    position: absolute; top: 66px; left: 0; right: 0;
    background: rgba(247,250,252,0.97); backdrop-filter: blur(14px) saturate(1.2);
    border-bottom: 1px solid var(--line); padding: 4px var(--pad) 12px;
    opacity: 0; transform: translateY(-10px); pointer-events: none;
    transition: opacity 0.2s var(--ease), transform 0.2s var(--ease); }
  .nav.open .nav-links { opacity: 1; transform: none; pointer-events: auto; }
  .nav-links a { padding: 13px 2px; font-size: 13px; border-bottom: 1px solid var(--line-dim); }
  .nav-links a:last-child { border-bottom: 0; }
  .nav-links a::after { display: none; }
}
