/* ============================================================================
   Calibrated — "Instrument Panel"
   A dark blue-slate calibration instrument. The page opens with the shape of
   its honesty (a reliability sparkline + Brier), not a pick. The signature is a
   signed-log-odds diverging driver chart on a gold zero-axis.
   Tokens are CSS custom properties; gold is STRUCTURAL only (never small text).
   ============================================================================ */

:root {
  --radar-slate: #0F1626;   /* page background — cool, instrument, not generic dark */
  --panel:       #1A2237;   /* card/panel surface — raised by value, not shadow */
  --readout:     #D8DCE8;   /* primary text */
  --gold:        #C8A82A;   /* STRUCTURAL only: zero-axis, ticks, hairlines, committed badge */
  --ct-blue:     #3B78D4;   /* Team A pole + Team A driver bars (CT side) */
  --t-amber:     #D98030;   /* Team B pole + Team B driver bars (T side) */
  --shade:       #7E93AE;   /* muted secondary text — >=4.5:1 (AA) on --panel and --radar-slate */
  --shade-dim:   #4A5B73;   /* hairlines + decorative pseudo-content ONLY — never a text colour */

  --hair: 1px solid color-mix(in srgb, var(--gold) 42%, transparent);
  --hair-dim: 1px solid color-mix(in srgb, var(--shade) 28%, transparent);

  --fs-display: 'Space Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --fs-body: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --fs-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', 'Cascadia Code', monospace;

  --sp-1: 8px; --sp-2: 16px; --sp-3: 24px; --sp-4: 32px;
  --maxw: 880px;
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--radar-slate);
  color: var(--readout);
  font-family: var(--fs-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.mono { font-family: var(--fs-mono); font-variant-numeric: tabular-nums; }

a { color: var(--readout); }
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: 0;
}

/* ---- Sticky calibration header (the hero — proof, never a pick) ----------- */
.cal-header {
  position: sticky; top: 0; z-index: 10;
  background: color-mix(in srgb, var(--radar-slate) 92%, black);
  border-bottom: var(--hair);
  backdrop-filter: blur(6px);
}
.cal-header__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  min-height: 56px;
  padding: var(--sp-1) var(--sp-2);
  display: flex; align-items: center; gap: var(--sp-2);
}
.wordmark {
  font-family: var(--fs-display);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 15px;
  text-decoration: none;
  white-space: nowrap;
}
.cal-instrument {
  display: flex; align-items: center; gap: var(--sp-1);
  margin-left: auto;
}
.reliability { display: block; width: 52px; height: 52px; flex: none; }
.cal-metric { display: flex; flex-direction: column; line-height: 1.15; }
.cal-metric__value { font-size: 19px; font-weight: 500; }
.cal-metric__value .cal-metric__k {
  font-family: var(--fs-display); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--shade); margin-right: 6px;
}
.cal-metric__label {
  font-family: var(--fs-body); font-size: 11px; color: var(--shade);
  letter-spacing: 0.01em;
}
.cal-stamp { font-size: 11px; color: var(--shade); white-space: nowrap; }

/* ---- Thesis line ---------------------------------------------------------- */
.cal-thesis {
  max-width: var(--maxw);
  margin: var(--sp-3) auto var(--sp-1);
  padding: 0 var(--sp-2);
  font-size: 17px;
  color: var(--readout);
}
.cal-thesis b { font-weight: 500; }

/* ---- Slate ---------------------------------------------------------------- */
.slate { max-width: var(--maxw); margin: 0 auto; padding: var(--sp-2); }
.slate__meta {
  font-family: var(--fs-display);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--shade);
  padding-bottom: var(--sp-1);
  border-bottom: var(--hair-dim);
  margin-bottom: var(--sp-2);
}
.slate__status { /* loading / error / empty messages */
  padding: var(--sp-3) 0; color: var(--shade); font-size: 15px;
}
.slate__status strong { color: var(--readout); font-weight: 500; }

/* ---- Match card ----------------------------------------------------------- */
.card {
  background: var(--panel);
  border: var(--hair);
  padding: var(--sp-2);
  margin-bottom: var(--sp-2);
}
.card__head {
  display: flex; align-items: baseline; gap: var(--sp-1);
  flex-wrap: wrap;
}
.card__tourney {
  font-family: var(--fs-display); font-weight: 500;
  font-size: 13px; letter-spacing: 0.04em;
}
.card__meta { font-size: 12px; color: var(--shade); }
.card__head .badge { margin-left: auto; }

/* tier badges */
.badge {
  font-family: var(--fs-display);
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 3px 8px; white-space: nowrap;
}
.badge--committed { background: var(--gold); color: var(--radar-slate); }
.badge--thin {
  color: var(--t-amber);
  border: 1px solid color-mix(in srgb, var(--t-amber) 60%, transparent);
  background: transparent;
}

/* thin-data caveat band (persistent, non-dismissible) */
.card__thinband {
  margin: var(--sp-1) 0 0;
  padding: 8px 10px;
  font-size: 12.5px;
  color: color-mix(in srgb, var(--t-amber) 88%, var(--readout));
  background: color-mix(in srgb, var(--t-amber) 12%, transparent);
  border-left: 2px solid var(--t-amber);
}

/* ---- Probability gauge ---------------------------------------------------- */
.gauge { margin-top: var(--sp-2); }
.gauge__teams {
  display: flex; justify-content: space-between; gap: var(--sp-1);
  font-family: var(--fs-display); font-weight: 700; font-size: 18px;
  margin-bottom: 6px;
}
.gauge__teams .team--b { text-align: right; }
.gauge__bar {
  position: relative; height: 14px;
  background: var(--t-amber);              /* team B fills the right remainder */
  overflow: hidden;
}
.gauge__fill--a {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--ct-blue);              /* team A from the left to the split */
}
.gauge__tick {
  position: absolute; top: -3px; bottom: -3px; width: 2px;
  background: var(--gold);                  /* the calibration split tick */
  transform: translateX(-1px);
}
.gauge__pcts {
  display: flex; justify-content: space-between;
  font-size: 15px; margin-top: 6px;
}
.gauge__pcts .pct--a { color: color-mix(in srgb, var(--ct-blue) 60%, var(--readout)); }
.gauge__pcts .pct--b { color: color-mix(in srgb, var(--t-amber) 60%, var(--readout)); }
.gauge__winner {
  margin-top: 8px; font-size: 13px; color: var(--shade);
  font-family: var(--fs-display); letter-spacing: 0.02em;
}
.gauge__winner strong { color: var(--readout); font-weight: 700; }
.gauge__override {
  margin-top: 4px; font-size: 12.5px; color: var(--shade);
  font-style: italic;
}

/* ---- Driver chart (THE signature) ----------------------------------------- */
.drivers { margin-top: var(--sp-2); padding-top: var(--sp-1); border-top: var(--hair-dim); }
.drivers__head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 10px;
}
.drivers__label {
  font-family: var(--fs-display); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--shade);
}
.drivers__poles { font-size: 11px; color: var(--shade); display: flex; gap: 14px; }
.drivers__poles .pole--a { color: color-mix(in srgb, var(--ct-blue) 70%, var(--readout)); }
.drivers__poles .pole--b { color: color-mix(in srgb, var(--t-amber) 70%, var(--readout)); }

.driver {
  display: grid;
  grid-template-columns: 116px 1fr 1px 1fr 56px;
  align-items: center;
  column-gap: 8px;
  padding: 5px 0;
}
.driver__name { font-size: 13px; color: var(--readout); }
.driver__track { height: 12px; display: flex; }
.driver__track--left { justify-content: flex-end; }   /* anchor bar to the axis */
.driver__track--right { justify-content: flex-start; }
.driver__axis { align-self: stretch; background: var(--gold); width: 1px; }
.driver__bar {
  height: 100%; min-width: 3px;
  transform-origin: var(--bar-origin, center);
}
.driver__bar--a { background: var(--ct-blue); }
.driver__bar--b { background: var(--t-amber); }
.driver__track--left .driver__bar  { --bar-origin: right; }
.driver__track--right .driver__bar { --bar-origin: left; }
.driver__bar--limited {
  background: repeating-linear-gradient(
    90deg,
    var(--limit-color) 0 4px,
    transparent 4px 8px);
  opacity: 0.85;
}
.driver__bar--a.driver__bar--limited { --limit-color: var(--ct-blue); }
.driver__bar--b.driver__bar--limited { --limit-color: var(--t-amber); }
.driver__value { font-family: var(--fs-mono); font-size: 12.5px; text-align: right; color: var(--readout); }
.driver__flag { font-size: 11px; color: var(--shade); }

/* the mobile-only directional chip (favored team) — hidden on desktop */
.driver__chip { display: none; }

.drivers__caption {
  margin-top: 8px; font-size: 11px; color: var(--shade);
}

/* ---- Card footer: commitment + coverage ----------------------------------- */
.card__foot { margin-top: var(--sp-2); padding-top: var(--sp-1); border-top: var(--hair-dim); }
.card__caveat { font-size: 12.5px; color: var(--shade); margin: 0 0 var(--sp-1); }

.commit { margin-bottom: var(--sp-1); }
.commit__row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.commit__label {
  font-family: var(--fs-display); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--shade);
}
.commit__hash { font-size: 12.5px; color: var(--readout); word-break: break-all; }
.commit__toggle {
  font-family: var(--fs-body); font-size: 11.5px;
  background: transparent; color: var(--shade);
  border: var(--hair-dim); padding: 2px 8px; cursor: pointer;
}
.commit__toggle:hover { color: var(--readout); }
.commit__scope { margin: 6px 0 0; font-size: 11.5px; color: var(--shade); line-height: 1.5; }

.coverage { font-size: 11.5px; color: var(--shade); }

/* ---- Withheld section ----------------------------------------------------- */
.withheld { margin-top: var(--sp-4); }
.withheld__head {
  font-family: var(--fs-display); font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--shade);
  padding-bottom: var(--sp-1); border-bottom: var(--hair-dim);
}
.wrow {
  display: flex; align-items: baseline; gap: var(--sp-1); flex-wrap: wrap;
  padding: 10px 0; border-bottom: var(--hair-dim);
}
.wrow__teams { font-family: var(--fs-display); font-weight: 500; font-size: 14px; color: var(--shade); }
.wrow__teams::before { content: "○ "; color: var(--shade-dim); }
.wrow__meta { font-size: 12px; color: var(--shade); }
.wrow__reason { font-size: 12.5px; color: var(--shade); flex-basis: 100%; }

/* ---- Methodology / honesty block ------------------------------------------ */
.methodology {
  max-width: var(--maxw); margin: var(--sp-4) auto 0; padding: var(--sp-3) var(--sp-2);
  border-top: var(--hair-dim);
}
.methodology h2 {
  font-family: var(--fs-display); font-size: 13px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--shade); margin: 0 0 var(--sp-1);
}
.methodology p { font-size: 13.5px; color: var(--shade); max-width: 62ch; margin: 0 0 10px; }
.methodology strong { color: var(--readout); font-weight: 500; }

/* ---- Legal footer --------------------------------------------------------- */
.legal {
  border-top: var(--hair-dim);
  color: var(--shade); font-size: 12px; line-height: 1.7;
  padding: var(--sp-2); text-align: center;
}
.legal .age { color: var(--shade); font-weight: 600; }
.legal a { color: var(--shade); }

/* ---- Responsive: collapse the diverging chart to a chip list (<560px) ------ */
@media (max-width: 560px) {
  .cal-header__inner { flex-wrap: wrap; min-height: 0; gap: var(--sp-1); }
  .cal-instrument { margin-left: 0; order: 3; flex-basis: 100%; }
  .cal-stamp { order: 2; margin-left: auto; }

  .driver {
    grid-template-columns: 1fr auto auto;
    column-gap: 10px;
  }
  .driver__track, .driver__axis { display: none; }     /* hide the two-track chart */
  .driver__chip {
    display: inline-flex; align-items: center; gap: 4px;
    font-family: var(--fs-display); font-size: 11px; font-weight: 500;
    padding: 1px 7px; white-space: nowrap;
  }
  .driver__chip--a { color: var(--ct-blue); border: 1px solid color-mix(in srgb, var(--ct-blue) 50%, transparent); }
  .driver__chip--b { color: var(--t-amber); border: 1px solid color-mix(in srgb, var(--t-amber) 50%, transparent); }
  .drivers__poles { display: none; }
}

/* ---- Motion: driver bars grow outward from the gold axis on first paint ---- */
@media (prefers-reduced-motion: no-preference) {
  .card--enter .driver__bar { animation: grow-bar 360ms cubic-bezier(.2,.7,.3,1) both; }
  .card--enter .driver__bar { animation-delay: calc(var(--row, 0) * 45ms); }
  @keyframes grow-bar { from { transform: scaleX(0); } to { transform: scaleX(1); } }
}
