/* ============================================================================
   Mallo — chart supplement.
   Adds categorical colour tokens and SVG/D3 component styles that aren't
   in mallo.css (the base design system stylesheet).
   ============================================================================ */

/* Categorical colours + chart tokens — light */
:root {
  --cat1: var(--berry);        /* #a53860 */
  --cat2: #1baf7a;
  --cat3: #eda100;
  --cat4: #0083a0;
  --series-1: var(--accent-soft);  /* #da627d */
  --baseline: var(--track);
  --axis-ink: var(--label);
  --axis-line: var(--line-hd);
}

/* Dark overrides */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --cat1: var(--accent);   /* #ffa5ab */
    --cat2: #22d495;
    --cat3: #f5c842;
    --cat4: #33b8d4;
    --series-1: var(--accent);
    --baseline: var(--track);
  }
}
:root[data-theme="dark"] {
  --cat1: var(--accent);
  --cat2: #22d495;
  --cat3: #f5c842;
  --cat4: #33b8d4;
  --series-1: var(--accent);
  --baseline: var(--track);
}

/* ── SVG line chart (playoff odds, career minis) ────────────────────────── */
.fg-line {
  fill: none;
  stroke: var(--traj-stroke);
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.fg-line.fg-muted {
  stroke: var(--line-hd);
  stroke-width: 1px;
  opacity: 0.6;
}
.fg-dot {
  stroke: none;
}
.fg-label {
  font: 600 11px var(--font-mono);
  fill: var(--ink);
  dominant-baseline: middle;
}
.fg-cross {
  stroke: var(--ink3);
  stroke-width: 1px;
  stroke-dasharray: 3 3;
  pointer-events: none;
}

/* Mallo index bars */
.fg-bar { rx: 3px; }
.fg-base {
  stroke: var(--ink3);
  stroke-width: 1px;
  stroke-dasharray: 3 3;
}
.fg-baselabel {
  fill: var(--ink3);
  font: 600 9.5px var(--font-mono);
}
.fg-cat {
  fill: var(--ink2);
  font: 600 11px var(--font-mono);
  letter-spacing: .04em;
}
.fg-val {
  fill: var(--ink-strong);
  font: 700 12px var(--font-mono);
}

/* D3 axis */
.axis path,
.axis line {
  stroke: var(--axis-line);
  stroke-width: 1px;
}
.axis text {
  fill: var(--axis-ink);
  font: 600 10px var(--font-mono);
}

/* ── Tooltip ────────────────────────────────────────────────────────────── */
.chart-tip {
  position: fixed;
  z-index: 100;
  pointer-events: none;
  background: var(--surface);
  border: 1px solid var(--surface-line);
  border-radius: 10px;
  padding: 9px 12px;
  font: 13px var(--font-body);
  color: var(--ink);
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
  min-width: 140px;
}
.chart-tip .d {
  font: 600 10px var(--font-mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--label);
  margin-bottom: 6px;
}
.chart-tip div {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 2px 0;
  font-size: 12.5px;
}
.chart-tip .k {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.chart-tip b {
  margin-left: auto;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 12px;
}

/* ── Career mini chart grid ─────────────────────────────────────────────── */
.minis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.mini .label {
  font: 600 9.5px var(--font-mono);
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--label);
  margin-bottom: 6px;
}
@media (max-width: 560px) {
  .minis { grid-template-columns: 1fr; }
}
