/* ================================================
   HOVR vs Joby — editorial / FT-interactive style
   ================================================ */

:root {
  --bg: #fcf9f3;          /* warm off-white */
  --bg-2: #f5efe5;        /* warmer card */
  --ink: #1a1814;         /* near-black */
  --ink-2: #4a443d;       /* secondary text */
  --ink-3: #8a8278;       /* tertiary */
  --rule: #1a1814;
  --rule-2: #d8cfc1;
  --hovr: #c8553d;
  --joby: #2e5c8a;
  --serif: 'Source Serif 4', 'Source Serif Pro', 'Georgia', serif;
  --sans:  'Inter', 'Helvetica Neue', system-ui, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; border-bottom: 1px solid currentColor; }
a:hover { opacity: 0.65; }

button { font-family: inherit; cursor: pointer; }

/* ================ TOPBAR ================ */
.ev-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  padding: 14px 32px;
  background: rgba(252, 249, 243, 0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--rule-2);
}
.ev-topbar-mark { display: flex; gap: 6px; }
.ev-mark-dot { width: 10px; height: 10px; border-radius: 50%; }
.ev-topbar-title {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.ev-vs { color: var(--ink-3); font-style: italic; padding: 0 4px; }
.ev-topbar-nav {
  display: flex;
  gap: 24px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.ev-topbar-nav a { border: none; color: var(--ink-2); }
.ev-topbar-nav a:hover { color: var(--ink); opacity: 1; }

/* ================ SHARED ================ */
.ev-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 10px;
}
.ev-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 96px 32px;
  border-top: 1px solid var(--rule-2);
}
.ev-section-head { max-width: 760px; margin-bottom: 40px; }
.ev-h2 {
  font-family: var(--serif);
  font-size: 44px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 500;
  margin: 0 0 16px;
  text-wrap: balance;
}
.ev-section-lede {
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0;
  text-wrap: pretty;
  max-width: 64ch;
}

/* Reveal */
.ev-reveal { opacity: 0; transform: translateY(18px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.ev-reveal.in { opacity: 1; transform: none; }

/* ================ HERO ================ */
.ev-hero {
  max-width: 1320px;
  margin: 0 auto;
  padding: 56px 32px 80px;
  display: grid;
  grid-template-columns: minmax(380px, 1fr) minmax(420px, 1.1fr);
  gap: 56px;
  align-items: center;
}
.ev-hero-text { max-width: 560px; }
.ev-h1 {
  font-family: var(--serif);
  font-size: 64px;
  line-height: 1.02;
  letter-spacing: -0.025em;
  font-weight: 500;
  margin: 16px 0 24px;
  text-wrap: balance;
}
.ev-h1-em {
  font-style: italic;
  color: var(--hovr);
}
.ev-lede {
  font-family: var(--serif);
  font-size: 21px;
  line-height: 1.5;
  color: var(--ink-2);
  margin: 0 0 28px;
  text-wrap: pretty;
}
.ev-lede-em { color: var(--ink); font-weight: 500; }
.ev-hero-cta { display: flex; gap: 16px; align-items: center; }
.ev-cta {
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--bg);
  padding: 12px 20px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 0;
  transition: background .2s, color .2s;
}
.ev-cta:hover { background: var(--bg); color: var(--ink); opacity: 1; }
.ev-cta-ghost {
  border: 1px solid var(--rule-2);
  padding: 12px 20px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
}
.ev-cta-ghost:hover { border-color: var(--ink); opacity: 1; }

.ev-hero-globe {
  position: relative;
  background: var(--bg-2);
  border: 1px solid var(--rule-2);
  height: 560px;
  overflow: hidden;
}
.ev-globe-legend {
  position: absolute;
  bottom: 14px;
  left: 14px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--ink-2);
  background: rgba(252,249,243,0.86);
  padding: 10px 12px;
  border: 1px solid var(--rule-2);
  display: flex; flex-direction: column; gap: 4px;
}
.ev-leg-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.ev-leg-sub { color: var(--ink-3); }
.ev-leg-hint { color: var(--ink-3); margin-top: 4px; padding-top: 6px; border-top: 1px solid var(--rule-2); }

/* ================ SPEC CARDS ================ */
.ev-spec-grid-outer { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.ev-spec {
  background: var(--bg-2);
  border-top: 3px solid var(--ink);
  padding: 28px 28px 24px;
}
.ev-spec-head { display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px; }
.ev-spec-name { font-family: var(--serif); font-size: 26px; font-weight: 500; letter-spacing: -0.01em; }
.ev-spec-maker { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); }
.ev-spec-tag { font-family: var(--serif); font-style: italic; font-size: 17px; margin: 16px 0 22px; }
.ev-spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--rule-2); }
.ev-spec-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule-2);
}
.ev-spec-row:nth-child(odd) { padding-right: 16px; border-right: 1px solid var(--rule-2); }
.ev-spec-row:nth-child(even) { padding-left: 16px; }
.ev-spec-k { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-3); }
.ev-spec-v { font-family: var(--serif); font-size: 16px; font-weight: 500; }
.ev-spec-cert { font-family: var(--mono); font-size: 11px; color: var(--ink-3); margin-top: 18px; }

/* ================ SIMULATOR ================ */
.ev-sim { display: flex; flex-direction: column; gap: 24px; }
.ev-sim-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; }
.ev-sim-title { font-family: var(--serif); font-size: 28px; font-weight: 500; letter-spacing: -0.01em; margin: 0 0 4px; }
.ev-sim-meta { font-family: var(--mono); font-size: 12px; color: var(--ink-3); }

.ev-playbtn {
  border: 1px solid var(--ink);
  background: var(--bg);
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
}
.ev-playbtn:hover { background: var(--ink); color: var(--bg); }

.ev-picker { display: flex; flex-wrap: wrap; gap: 6px; }
.ev-chip {
  display: inline-flex; align-items: baseline; gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--rule-2);
  background: transparent;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--ink-2);
  border-radius: 0;
  transition: all .15s;
}
.ev-chip:hover { border-color: var(--ink); color: var(--ink); }
.ev-chip.active { background: var(--ink); border-color: var(--ink); color: var(--bg); }
.ev-chip.cat-urban.active { background: var(--joby); border-color: var(--joby); }
.ev-chip.cat-regional.active,
.ev-chip.cat-remote.active { background: var(--hovr); border-color: var(--hovr); }
.ev-chip-name { font-weight: 500; }
.ev-chip-meta { font-family: var(--mono); font-size: 10px; opacity: 0.7; letter-spacing: 0.04em; }

.ev-note {
  font-family: var(--serif);
  font-style: italic;
  font-size: 15px;
  color: var(--ink-2);
  border-left: 2px solid var(--rule-2);
  padding-left: 14px;
  max-width: 80ch;
}

.ev-sim-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* timeline */
.ev-timeline {
  background: var(--bg-2);
  border: 1px solid var(--rule-2);
  padding: 18px;
  display: flex; flex-direction: column; gap: 14px;
}
.ev-timeline-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.ev-timeline-name { display: flex; align-items: baseline; gap: 8px; }
.ev-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }
.ev-acft-name { font-family: var(--serif); font-size: 17px; font-weight: 500; }
.ev-acft-arch { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); }
.ev-timeline-clock { font-family: var(--mono); font-size: 11px; color: var(--ink-2); display: flex; gap: 6px; align-items: baseline; }
.ev-clock-phase { font-weight: 600; color: var(--ink); text-transform: uppercase; letter-spacing: 0.08em; }
.ev-clock-sep { color: var(--ink-3); }
.ev-clock-time { color: var(--ink); }
.ev-clock-total { color: var(--ink-3); }

.ev-phasebar {
  position: relative;
  display: flex;
  height: 38px;
  border: 1px solid var(--rule-2);
  background: var(--bg);
  overflow: hidden;
}
.ev-phaseseg {
  position: relative;
  display: flex; flex-direction: column; justify-content: center;
  padding: 0 8px;
  color: rgba(255,255,255,0.92);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: opacity .25s;
  overflow: hidden; min-width: 0;
}
.ev-phaselabel { white-space: nowrap; overflow: hidden; text-overflow: clip; }
.ev-phasemins { font-size: 9px; opacity: 0.78; }
.ev-playhead {
  position: absolute;
  top: 0; bottom: 0;
  width: 2px;
  background: var(--ink);
  box-shadow: 0 0 0 1px rgba(252,249,243,0.6);
  pointer-events: none;
}

.ev-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--rule-2); }
.ev-stat { background: var(--bg-2); padding: 10px 12px; }
.ev-stat-label { font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); margin-bottom: 4px; }
.ev-stat-val { font-family: var(--serif); font-size: 20px; font-weight: 500; letter-spacing: -0.01em; }

/* incompatible state */
.ev-incompat {
  background: var(--bg-2);
  border: 1px solid var(--rule-2);
  border-left: 3px solid var(--hovr);
  padding: 24px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 200px; justify-content: center;
}
.ev-incompat-flag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; color: var(--hovr); text-transform: uppercase; }
.ev-incompat-reason { font-family: var(--serif); font-size: 17px; color: var(--ink); max-width: 50ch; line-height: 1.4; }

/* compare table */
.ev-sim-compare { margin-top: 8px; }
.ev-cmp { width: 100%; border-collapse: collapse; font-size: 14px; }
.ev-cmp thead th {
  text-align: right;
  padding: 10px 14px;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-3);
  font-weight: 500;
  border-bottom: 1px solid var(--ink);
}
.ev-cmp thead th:first-child { text-align: left; }
.ev-cmp tbody td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--rule-2);
}
.ev-cmp-label { font-family: var(--serif); font-size: 15px; }
.ev-cmp-val { text-align: right; font-family: var(--mono); font-size: 13px; color: var(--ink-2); font-variant-numeric: tabular-nums; }
.ev-cmp-val.win { color: var(--ink); font-weight: 600; position: relative; }
.ev-cmp-val.win::after {
  content: ''; position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  width: 4px; height: 4px; background: currentColor; border-radius: 50%;
}
.ev-cmp-delta { text-align: right; font-family: var(--mono); font-size: 11px; color: var(--ink-3); font-variant-numeric: tabular-nums; }

/* cost breakdown */
.ev-sim-costs { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ev-cost { border: 1px solid var(--rule-2); padding: 18px; background: var(--bg); }
.ev-cost-head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
.ev-cost-name { font-family: var(--serif); font-size: 16px; font-weight: 500; flex: 1; }
.ev-cost-total { font-family: var(--mono); font-size: 12px; color: var(--ink-2); }
.ev-cost-stack { display: flex; flex-direction: column; gap: 6px; }
.ev-cost-row { display: grid; grid-template-columns: 90px 1fr 60px 36px; gap: 10px; align-items: center; }
.ev-cost-key { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-2); }
.ev-cost-bar { background: var(--bg-2); height: 10px; position: relative; overflow: hidden; }
.ev-cost-fill { height: 100%; }
.ev-cost-val { font-family: var(--mono); font-size: 11px; text-align: right; font-variant-numeric: tabular-nums; }
.ev-cost-pct { font-family: var(--mono); font-size: 10px; color: var(--ink-3); text-align: right; }

/* ================ SEAT-MILE NOTE ================ */
.ev-seatmile-note {
  font-family: var(--serif);
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-2);
  background: var(--bg-2);
  padding: 12px 16px;
  border-left: 2px solid var(--ink-3);
  max-width: 80ch;
}
.ev-seatmile-note strong { color: var(--ink); font-weight: 600; }

/* ================ CERTIFICATION TIMELINE ================ */
.ev-section-cert { background: var(--bg); }
.ev-cert { display: flex; flex-direction: column; gap: 32px; }
.ev-cert-head {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 32px;
  align-items: center;
  padding: 24px 32px;
  background: var(--bg-2);
  border: 1px solid var(--rule-2);
}
.ev-cert-bignum { display: flex; flex-direction: column; gap: 4px; }
.ev-cert-bignum:last-child { text-align: right; align-items: flex-end; }
.ev-cert-acft { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; font-weight: 600; }
.ev-cert-pct {
  font-family: var(--serif);
  font-size: 88px;
  line-height: 1;
  font-weight: 500;
  letter-spacing: -0.04em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.ev-cert-pct span { font-size: 38px; color: var(--ink-3); margin-left: 4px; font-weight: 400; }
.ev-cert-sub { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.04em; }
.ev-cert-gap {
  text-align: center;
  border-left: 1px solid var(--rule-2);
  border-right: 1px solid var(--rule-2);
  padding: 0 24px;
}
.ev-cert-gap-num { font-family: var(--serif); font-size: 36px; font-weight: 500; letter-spacing: -0.02em; color: var(--ink); }
.ev-cert-gap-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); margin: 4px 0; }
.ev-cert-gap-sub { font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.04em; }

.ev-cert-track { padding: 16px 0; }
.ev-cert-track-label { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
.ev-cert-track-name { font-family: var(--serif); font-size: 18px; font-weight: 500; flex: 1; }
.ev-cert-track-pct { font-family: var(--mono); font-size: 14px; font-weight: 600; letter-spacing: 0.04em; }

.ev-cert-bar {
  position: relative;
  height: 56px;
  background: transparent;
  margin: 8px 0 36px;
}
.ev-cert-bar-bg {
  position: absolute;
  left: 0; right: 0;
  top: 50%; transform: translateY(-50%);
  height: 4px;
  background: var(--rule-2);
}
.ev-cert-bar-fill {
  position: absolute;
  left: 0;
  top: 50%; transform: translateY(-50%);
  height: 4px;
  transition: width 0.6s cubic-bezier(.2,.7,.2,1);
}
.ev-cert-divider {
  position: absolute;
  top: 0; bottom: 0;
  width: 1px;
  background: var(--rule-2);
}
.ev-cert-pin {
  position: absolute;
  top: 50%;
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 2px solid;
  transform: translate(-50%, -50%);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform .15s, opacity .25s;
  z-index: 2;
}
.ev-cert-pin:hover { transform: translate(-50%, -50%) scale(1.25); z-index: 5; }
.ev-cert-pin.partial { background: var(--bg) !important; box-shadow: inset 0 0 0 4px currentColor; }
.ev-cert-pin-num {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  color: var(--bg);
  pointer-events: none;
}
.ev-cert-pin.pending .ev-cert-pin-num { color: var(--ink-3); }
.ev-cert-pin.partial .ev-cert-pin-num { color: var(--bg); }

.ev-cert-tip {
  position: absolute;
  bottom: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink);
  color: var(--bg);
  padding: 10px 14px;
  width: 240px;
  font-family: var(--sans);
  font-size: 12px;
  line-height: 1.4;
  z-index: 10;
  pointer-events: none;
  text-align: left;
}
.ev-cert-tip::after {
  content: '';
  position: absolute;
  top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--ink);
}
.ev-cert-tip-num { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; opacity: 0.7; text-transform: uppercase; }
.ev-cert-tip-name { font-family: var(--serif); font-size: 14px; font-weight: 500; margin: 4px 0 6px; }
.ev-cert-tip-status { font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 0; }
.ev-cert-tip-status.done { color: #6fcf97; }
.ev-cert-tip-status.partial { color: #f2c94c; }
.ev-cert-tip-status.pending { color: #999; }
.ev-cert-tip-note { font-family: var(--serif); font-size: 12px; opacity: 0.8; margin-top: 6px; font-style: italic; }

.ev-cert-axis {
  position: relative;
  height: 18px;
  margin-top: -28px;
}
.ev-cert-axis span {
  position: absolute;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  text-transform: uppercase;
  white-space: nowrap;
}

.ev-cert-legend {
  display: flex;
  gap: 24px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-2);
}
.ev-cert-band {
  display: inline-block;
  width: 18px; height: 4px;
  margin-right: 8px;
  vertical-align: middle;
}

.ev-cert-caveat {
  background: var(--bg-2);
  border-left: 3px solid var(--ink);
  padding: 20px 24px;
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  max-width: 84ch;
}
.ev-cert-caveat strong { font-weight: 600; }

@media (max-width: 960px) {
  .ev-cert-head { grid-template-columns: 1fr; gap: 16px; padding: 20px; }
  .ev-cert-bignum:last-child { text-align: left; align-items: flex-start; }
  .ev-cert-gap { border: none; padding: 0; border-top: 1px solid var(--rule-2); border-bottom: 1px solid var(--rule-2); padding: 12px 0; }
  .ev-cert-pct { font-size: 60px; }
}

/* ================ RANGE REALITY (hero) ================ */
.ev-range { display: flex; flex-direction: column; gap: 14px; padding: 16px; }
.ev-range-cities { display: flex; gap: 6px; }
.ev-range-city {
  border: 1px solid var(--rule-2); background: transparent;
  padding: 6px 14px; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2);
}
.ev-range-city.active { background: var(--ink); border-color: var(--ink); color: var(--bg); }
.ev-range-counts {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: center;
  padding: 8px 0;
}
.ev-range-count { text-align: center; }
.ev-range-count-num { font-family: var(--serif); font-size: 56px; font-weight: 500; line-height: 1; letter-spacing: -0.03em; }
.ev-range-count-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; color: var(--ink-2); margin-top: 4px; line-height: 1.3; }
.ev-range-count-vs { font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--ink-3); }
.ev-range-map { background: var(--bg); border: 1px solid var(--rule-2); }
.ev-range-foot { font-family: var(--serif); font-size: 13px; font-style: italic; color: var(--ink-2); padding: 0 4px; }

/* ================ CROSSOVER CHART ================ */
.ev-cross { display: flex; flex-direction: column; gap: 28px; }

/* Panel 1 — magnitude callouts */
.ev-cross-mag {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border: 1px solid var(--rule-2); background: var(--bg-2);
}
.ev-mag-card {
  padding: 28px 32px;
  border-right: 1px solid var(--rule-2);
}
.ev-mag-card:last-child { border-right: none; }
.ev-mag-card.joby-cant { background: repeating-linear-gradient(45deg, transparent, transparent 8px, rgba(46,92,138,0.04) 8px, rgba(46,92,138,0.04) 9px); }
.ev-mag-eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-3);
}
.ev-mag-num {
  font-family: var(--serif); font-size: 76px; font-weight: 500;
  line-height: 1; letter-spacing: -0.04em; margin: 8px 0 6px;
}
.ev-mag-sub { font-family: var(--serif); font-size: 17px; color: var(--ink); line-height: 1.35; }
.ev-mag-detail { font-family: var(--mono); font-size: 11px; color: var(--ink-2); margin-top: 10px; letter-spacing: 0.02em; }
.ev-mag-ratio { color: var(--ink-3); }

/* Panel 2 — chart */
.ev-cross-chart { background: var(--bg); border: 1px solid var(--rule-2); padding: 8px; }

/* Panel 3 — decomposition */
.ev-decomp-head {
  display: flex; justify-content: space-between; align-items: flex-end; gap: 32px;
  padding-top: 20px; border-top: 1px solid var(--rule-2);
}
.ev-decomp-head-h { font-family: var(--serif); font-size: 26px; font-weight: 500; letter-spacing: -0.015em; margin-top: 4px; }
.ev-eyebrow-sm { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); }
.ev-decomp-slider { display: flex; align-items: center; gap: 14px; min-width: 380px; }
.ev-decomp-slider input[type="range"] { flex: 1; accent-color: var(--ink); }
.ev-decomp-slider-val {
  font-family: var(--serif); font-size: 22px; font-weight: 500;
  min-width: 70px; text-align: right; letter-spacing: -0.01em;
}
.ev-decomp-presets { display: flex; gap: 4px; }
.ev-decomp-preset {
  border: 1px solid var(--rule-2); background: transparent;
  font-family: var(--mono); font-size: 11px; padding: 4px 8px; color: var(--ink-2);
  cursor: pointer;
}
.ev-decomp-preset.active { background: var(--ink); border-color: var(--ink); color: var(--bg); }

.ev-decomp { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }
.ev-decomp-bars { display: flex; gap: 28px; align-items: flex-end; justify-content: center; padding: 24px 30px; background: var(--bg-2); border: 1px solid var(--rule-2); }
.ev-decomp-col { display: flex; flex-direction: column; align-items: center; }
.ev-decomp-bar-wrap { display: flex; align-items: flex-end; }
.ev-decomp-bar { display: flex; flex-direction: column-reverse; width: 90px; }
.ev-decomp-seg {
  width: 100%; position: relative; overflow: hidden;
  border-bottom: 1px solid rgba(252,249,243,0.18);
}
.ev-decomp-seg:last-child { border-bottom: none; }
.ev-decomp-seg-inner {
  display: flex; justify-content: space-between; align-items: center;
  padding: 2px 8px; height: 100%;
  font-family: var(--mono); font-size: 10px; color: rgba(252,249,243,0.95);
  letter-spacing: 0.02em;
}
.ev-decomp-seg-label { white-space: nowrap; }
.ev-decomp-seg-val { font-weight: 600; }
.ev-decomp-no {
  width: 90px; height: 180px; border: 1.5px dashed; opacity: 0.5;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: var(--ink-3);
}
.ev-decomp-no-x { font-family: var(--serif); font-style: italic; font-size: 18px; }
.ev-decomp-no-sub { font-family: var(--mono); font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase; margin-top: 6px; }
.ev-decomp-bar-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; margin-top: 12px; font-weight: 600; }
.ev-decomp-bar-total { font-family: var(--serif); font-size: 28px; font-weight: 500; letter-spacing: -0.02em; margin-top: 4px; }
.ev-decomp-bar-sub { font-family: var(--mono); font-size: 11px; color: var(--ink-2); margin-top: 2px; }

.ev-decomp-readout {
  padding: 24px 28px; background: var(--ink); color: var(--bg);
  display: flex; flex-direction: column; gap: 14px;
}
.ev-decomp-readout-d { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(252,249,243,0.6); }
.ev-decomp-readout-copy { font-family: var(--serif); font-size: 19px; line-height: 1.4; }
.ev-decomp-readout-detail { font-family: var(--mono); font-size: 11px; color: rgba(252,249,243,0.55); line-height: 1.6; margin-top: auto; padding-top: 12px; border-top: 1px solid rgba(252,249,243,0.15); }

/* Readout visual viz — comparison bars */
.ev-decomp-readout-viz { display: flex; flex-direction: column; gap: 10px; padding: 8px 0; }
.ev-decomp-readout-viz-row { display: flex; align-items: center; gap: 12px; }
.ev-decomp-readout-viz-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: rgba(252,249,243,0.7); width: 50px; }
.ev-decomp-readout-viz-track { flex: 1; position: relative; height: 28px; background: rgba(252,249,243,0.06); display: flex; align-items: center; }
.ev-decomp-readout-viz-bar { height: 100%; transition: width 0.25s ease, background 0.25s ease; }
.ev-decomp-readout-viz-val { position: absolute; right: 10px; font-family: var(--serif); font-size: 16px; font-weight: 500; color: #fcf9f3; }
.ev-decomp-readout-viz-na { padding-left: 12px; font-family: var(--serif); font-style: italic; color: rgba(252,249,243,0.5); font-size: 13px; }
.ev-decomp-readout-viz-axis { font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; color: rgba(252,249,243,0.45); text-align: right; }

.ev-cross-foot { font-family: var(--serif); font-size: 14px; font-style: italic; color: var(--ink-2); max-width: 80ch; }

@media (max-width: 960px) {
  .ev-cross-mag { grid-template-columns: 1fr; }
  .ev-mag-card { border-right: none; border-bottom: 1px solid var(--rule-2); }
  .ev-decomp-head { flex-direction: column; align-items: stretch; }
  .ev-decomp-slider { min-width: 0; }
  .ev-decomp { grid-template-columns: 1fr; }
}

/* ================ MARKET CAP ================ */
.ev-mkt { display: flex; flex-direction: column; gap: 36px; }
.ev-mkt-placeholder-banner {
  background: #fdf3d8; border: 1px solid #d9b64a; padding: 12px 18px;
  font-family: var(--mono); font-size: 12px; color: #6b4d10; letter-spacing: 0.02em;
}
.ev-mkt-stats {
  display: grid; grid-template-columns: 1fr 1fr 1.2fr; gap: 0;
  border: 1px solid var(--rule-2); background: var(--bg-2);
}
.ev-mkt-stat { padding: 24px 28px; border-right: 1px solid var(--rule-2); }
.ev-mkt-stat-eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; font-weight: 600; }
.ev-mkt-stat-num { font-family: var(--serif); font-size: 56px; font-weight: 500; letter-spacing: -0.03em; line-height: 1; margin: 8px 0 4px; }
.ev-mkt-stat-sub { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.06em; text-transform: uppercase; }
.ev-mkt-stat-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--rule-2); }
.ev-mkt-stat-grid > div { display: flex; flex-direction: column; }
.ev-mkt-stat-grid span { font-family: var(--serif); font-size: 18px; font-weight: 500; }
.ev-mkt-stat-grid label { font-family: var(--mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin-top: 2px; }
.ev-mkt-stat-ratio {
  padding: 24px 28px; background: var(--ink); color: var(--bg);
  display: flex; flex-direction: column; justify-content: center; gap: 12px;
}
.ev-mkt-stat-ratio-num { font-family: var(--serif); font-size: 88px; font-weight: 500; letter-spacing: -0.04em; line-height: 1; color: #f3dccf; }
.ev-mkt-stat-ratio-label { font-family: var(--serif); font-size: 15px; line-height: 1.45; }

.ev-mkt-panel { display: flex; flex-direction: column; gap: 14px; }
.ev-mkt-panel-head { padding-bottom: 4px; }
.ev-mkt-panel-h { font-family: var(--serif); font-size: 26px; font-weight: 500; letter-spacing: -0.015em; margin-top: 4px; }
.ev-mkt-panel-lede { font-family: var(--serif); font-size: 15px; font-style: italic; color: var(--ink-2); margin-top: 6px; max-width: 80ch; }
.ev-mkt-chart { background: var(--bg); border: 1px solid var(--rule-2); padding: 8px; }

@media (max-width: 960px) {
  .ev-mkt-stats { grid-template-columns: 1fr; }
  .ev-mkt-stat { border-right: none; border-bottom: 1px solid var(--rule-2); }
}

/* ================ ECONOMICS ================ */
.ev-section-econ { background: linear-gradient(to bottom, var(--bg), var(--bg-2) 30%, var(--bg-2)); border-top: 1px solid var(--rule-2); }
.ev-econ { display: flex; flex-direction: column; gap: 28px; }
.ev-econ-controls { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; max-width: 720px; }
.ev-control label { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); }
.ev-control-row { display: flex; align-items: center; gap: 14px; margin-top: 8px; }
.ev-control-row input[type=range] {
  flex: 1;
  -webkit-appearance: none;
  background: transparent;
  height: 22px;
}
.ev-control-row input[type=range]::-webkit-slider-runnable-track {
  height: 1px; background: var(--ink);
}
.ev-control-row input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--ink);
  margin-top: -9px;
  cursor: ew-resize;
}
.ev-control-row input[type=range]::-moz-range-track { height: 1px; background: var(--ink); }
.ev-control-row input[type=range]::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%; background: var(--ink); border: none;
}
.ev-control-val { font-family: var(--serif); font-size: 22px; font-weight: 500; min-width: 60px; }

.ev-econ-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.ev-econ-block { background: var(--bg); border: 1px solid var(--rule-2); padding: 24px; }
.ev-econ-title { font-family: var(--serif); font-size: 22px; font-weight: 500; letter-spacing: -0.01em; }
.ev-econ-sub { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-3); margin-bottom: 18px; }
.ev-econ-row { display: grid; grid-template-columns: 60px 1fr 130px; gap: 12px; align-items: center; padding: 8px 0; }
.ev-econ-name { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; }
.ev-econ-bar { background: var(--bg-2); height: 14px; position: relative; overflow: hidden; }
.ev-econ-fill { height: 100%; transition: width .6s cubic-bezier(.2,.7,.2,1); }
.ev-econ-num { font-family: var(--serif); font-size: 22px; font-weight: 500; text-align: right; color: var(--ink-3); font-variant-numeric: tabular-nums; }
.ev-econ-num.win { color: var(--ink); }
.ev-econ-incompat { font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--ink-2); padding: 24px; background: var(--bg); border: 1px solid var(--rule-2); }

/* ================ TAKEAWAY ================ */
.ev-takeaway { padding-bottom: 120px; }
.ev-take-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; margin-top: 32px; }
.ev-take-card { background: var(--bg-2); border-left: 3px solid var(--ink); padding: 24px; }
.ev-take-name { font-family: var(--serif); font-size: 20px; font-weight: 500; letter-spacing: -0.01em; margin-bottom: 12px; }
.ev-take-card p { font-family: var(--serif); font-size: 16px; line-height: 1.55; color: var(--ink-2); margin: 0; }

/* ================ FOOTER ================ */
.ev-foot { border-top: 1px solid var(--rule-2); padding: 32px; }
.ev-foot-row { max-width: 1200px; margin: 0 auto; display: flex; gap: 16px; flex-wrap: wrap; font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.04em; }

/* ================ RESPONSIVE ================ */
@media (max-width: 960px) {
  .ev-hero { grid-template-columns: 1fr; }
  .ev-hero-globe { height: 420px; }
  .ev-h1 { font-size: 44px; }
  .ev-h2 { font-size: 32px; }
  .ev-spec-grid-outer { grid-template-columns: 1fr; }
  .ev-sim-grid { grid-template-columns: 1fr; }
  .ev-sim-costs { grid-template-columns: 1fr; }
  .ev-econ-controls { grid-template-columns: 1fr; }
  .ev-econ-grid { grid-template-columns: 1fr; }
  .ev-take-grid { grid-template-columns: 1fr; }
  .ev-topbar { grid-template-columns: 60px 1fr; padding: 12px 20px; }
  .ev-topbar-nav { display: none; }
  .ev-section { padding: 64px 20px; }
}
