/* Payoff Pitch design system. See DESIGN.md. */

@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal; font-weight: 600; font-display: swap;
  src: url('fonts/barlow-condensed-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal; font-weight: 700; font-display: swap;
  src: url('fonts/barlow-condensed-700.woff2') format('woff2');
}

:root {
  --ink-0: oklch(0.155 0.013 262);
  --ink-1: oklch(0.196 0.015 262);
  --ink-2: oklch(0.248 0.017 262);
  --line: oklch(0.31 0.016 262);
  --text-1: oklch(0.95 0.006 255);
  --text-2: oklch(0.72 0.012 255);
  --text-3: oklch(0.555 0.014 258);
  --ember: oklch(0.73 0.17 52);
  --ember-press: oklch(0.66 0.16 52);
  --ember-ink: oklch(0.17 0.03 52);
  --up: oklch(0.78 0.15 158);
  --down: oklch(0.68 0.16 22);
  --up-bg: oklch(0.78 0.15 158 / 0.10);
  --down-bg: oklch(0.68 0.16 22 / 0.10);
  --row-line: oklch(0.235 0.014 262);
  --display: 'Barlow Condensed', 'Arial Narrow', sans-serif;
  --ui: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --ease: cubic-bezier(0.165, 0.84, 0.44, 1);
  --rail: 304px;
}

* { box-sizing: border-box; }
html { color-scheme: dark; }
body {
  margin: 0;
  background: var(--ink-0);
  color: var(--text-1);
  font-family: var(--ui);
  font-size: 0.9375rem;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
}

button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; }

/* ---------- header ---------- */
.top {
  border-bottom: 1px solid var(--line);
  background: var(--ink-0);
  position: sticky; top: 0; z-index: 30;
}
.top-inner {
  max-width: 1200px; margin: 0 auto; padding: 14px 20px 8px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.wordmark {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none;
  font-family: var(--display); font-weight: 700; font-size: 1.7rem;
  letter-spacing: 0.01em; text-transform: uppercase; line-height: 1;
}
.wordmark em { font-style: normal; color: var(--ember); }
.plate { width: 24px; height: 24px; }
.plate .pl { fill: var(--ember); }
.plate .ar { fill: none; stroke: var(--ink-0); stroke-width: 2.6; stroke-linecap: round; stroke-linejoin: round; }

.top-right { display: flex; align-items: center; gap: 14px; }
.datebar { display: flex; align-items: center; gap: 4px; }
.datebar-label {
  font-family: var(--display); font-weight: 600; font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-3); margin-right: 4px;
}
.auth-btn {
  border: 1px solid var(--line); border-radius: 7px; padding: 7px 14px;
  font-family: var(--display); font-weight: 600; font-size: 0.92rem;
  text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-2);
  transition: color 150ms var(--ease), border-color 150ms var(--ease);
  white-space: nowrap;
}
.auth-btn:hover { color: var(--ember); border-color: var(--ember); }
.auth-btn.signed { color: var(--ember); border-color: var(--line); font-variant-numeric: tabular-nums; }
.datebtn {
  width: 34px; height: 34px; border-radius: 6px;
  font-size: 1.25rem; color: var(--text-2); line-height: 1;
  transition: background 150ms var(--ease), color 150ms var(--ease);
}
.datebtn:hover { background: var(--ink-1); color: var(--text-1); }
.datebtn:focus-visible, button:focus-visible, a:focus-visible { outline: 2px solid var(--ember); outline-offset: 2px; }
.dateline { text-align: center; min-width: 150px; }
.dateline > span { display: block; }
#date-label { font-family: var(--display); font-weight: 600; font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.03em; }
.freshness { font-size: 0.72rem; color: var(--text-3); }

.tabs {
  max-width: 1200px; margin: 0 auto; padding: 0 12px;
  display: flex; gap: 2px; overflow-x: auto;
}
.tabs a {
  padding: 9px 14px 11px;
  text-decoration: none;
  font-family: var(--display); font-weight: 600; font-size: 1.05rem;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-3);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color 150ms var(--ease);
}
.tabs a:hover { color: var(--text-2); }
.tabs a[aria-current] { color: var(--text-1); border-bottom-color: var(--ember); }
.count { color: var(--text-3); font-size: 0.85em; }
.tabs a[aria-current] .count { color: var(--ember); }

/* ---------- layout ---------- */
#main {
  max-width: 1200px; margin: 0 auto;
  padding: 24px 20px 80px;
}
@media (min-width: 1080px) {
  #main { padding-right: calc(var(--rail) + 40px); }
}

.view-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px; flex-wrap: wrap; margin: 4px 0 18px;
}
.view-head h2 {
  margin: 0;
  font-family: var(--display); font-weight: 700; font-size: 1.6rem;
  text-transform: uppercase; letter-spacing: 0.02em;
}
.view-head .sub { color: var(--text-3); font-size: 0.85rem; max-width: 62ch; }

.controls { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.toggle {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 0.82rem; color: var(--text-2); cursor: pointer; user-select: none;
}
.toggle input { accent-color: var(--ember); width: 15px; height: 15px; margin: 0; }
.search {
  background: var(--ink-1); border: 1px solid var(--line); border-radius: 6px;
  color: var(--text-1); font: inherit; font-size: 0.85rem;
  padding: 6px 10px; width: 170px;
}
.search::placeholder { color: var(--text-3); }
.search:focus { outline: 2px solid var(--ember); outline-offset: 0; border-color: transparent; }

/* ---------- shared row anatomy ---------- */
.rows { display: flex; flex-direction: column; }
.row {
  border-top: 1px solid var(--line);
  padding: 14px 4px;
}
.row:last-child { border-bottom: 1px solid var(--line); }

.num {
  font-family: var(--display); font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.unit { font-size: 0.62em; color: var(--text-3); font-weight: 600; letter-spacing: 0.04em; }

.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  font-size: 0.74rem; line-height: 1;
  padding: 5px 8px; border-radius: 5px;
  background: var(--ink-1); color: var(--text-2);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.chip.up { color: var(--up); background: var(--up-bg); }
.chip.down { color: var(--down); background: var(--down-bg); }

.add {
  border: 1px solid var(--line); border-radius: 6px;
  padding: 6px 12px;
  font-family: var(--display); font-weight: 600; font-size: 0.92rem;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--text-2);
  transition: border-color 150ms var(--ease), color 150ms var(--ease), background 150ms var(--ease);
  white-space: nowrap;
}
.add:hover { border-color: var(--ember); color: var(--ember); }
.add:active { background: var(--ink-1); }
.add[data-in-slip] { background: var(--ember); border-color: var(--ember); color: var(--ember-ink); }
.add:disabled { opacity: 0.4; cursor: default; }

.expand-btn {
  color: var(--text-3); font-size: 0.78rem;
  padding: 4px 8px; border-radius: 5px;
  transition: color 150ms var(--ease);
}
.expand-btn:hover { color: var(--text-1); background: var(--ink-1); }
.detail { padding: 12px 4px 4px; }

/* ---------- slate ---------- */
.game-row { padding: 16px 4px; }
/* Fixed columns so win% and total line up vertically across every game. */
.game { display: grid; grid-template-columns: 70px 1fr 84px 70px; gap: 16px; align-items: center; }
.g-when { font-variant-numeric: tabular-nums; }
.g-time { display: block; color: var(--text-2); font-size: 0.9rem; font-weight: 600; }
.g-time.live { color: var(--ember); }
.g-status { display: block; color: var(--text-3); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em; margin-top: 2px; }

.g-matchup { display: flex; flex-direction: column; gap: 9px; min-width: 0; }
.g-team { display: grid; grid-template-columns: auto auto 1fr auto; gap: 9px; align-items: baseline; }
.g-tname { font-weight: 600; font-size: 1rem; white-space: nowrap; }
.g-trec { color: var(--text-3); font-size: 0.76rem; font-variant-numeric: tabular-nums; white-space: nowrap; }
.g-tpit { color: var(--text-2); font-size: 0.82rem; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.g-score { font-family: var(--display); font-weight: 700; font-size: 1.25rem; text-align: right; }

.g-col { text-align: right; min-height: 1px; }
.g-big { font-size: 1.65rem; }
.g-big.tot { color: var(--text-2); }
.g-sub { font-size: 0.68rem; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.04em; margin-top: 1px; }
.mlbar { width: 100%; height: 4px; border-radius: 2px; background: var(--ink-2); margin-top: 6px; overflow: hidden; }
.mlbar i { display: block; height: 100%; background: var(--ember); }

.g-expand { margin-top: 12px; }

.slip-add { align-items: center; gap: 8px; margin-top: 14px; }
.slip-add-label { font-family: var(--display); font-weight: 600; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-3); margin-right: 2px; }

.game-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 14px; }
.fgroup h4 {
  margin: 0 0 8px; font-family: var(--display); font-weight: 600; font-size: 0.95rem;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-3);
}
.flist { margin: 0; padding: 0; list-style: none; font-size: 0.82rem; }
.flist li { display: flex; justify-content: space-between; gap: 12px; padding: 3px 0; color: var(--text-2); }
.flist .fv { font-variant-numeric: tabular-nums; color: var(--text-1); }
.flist .fv.up { color: var(--up); }
.flist .fv.down { color: var(--down); }
.btnrow { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }

.list-note {
  padding: 8px 4px 2px; color: var(--text-3); font-size: 0.78rem;
  font-variant-numeric: tabular-nums;
}
.list-note .pos, .rec-foot .pos { color: var(--up); }
.list-note .neg, .rec-foot .neg { color: var(--down); }

.slot-tag {
  font-family: var(--display); font-weight: 600; font-size: 0.72rem;
  line-height: 1; padding: 2px 5px; border-radius: 4px;
  font-variant-numeric: tabular-nums; letter-spacing: 0.02em;
}
.slot-tag.confirmed { background: var(--up-bg); color: var(--up); }
.slot-tag.projected { background: var(--ink-2); color: var(--text-3); }

.slip-note {
  font-size: 0.74rem; color: var(--text-3); line-height: 1.4;
  padding: 0 0 12px;
}

/* ---------- stats ---------- */
.seg { display: inline-flex; border: 1px solid var(--line); border-radius: 7px; overflow: hidden; }
.seg-btn {
  padding: 6px 15px; font-family: var(--display); font-weight: 600; font-size: 0.95rem;
  text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-3);
  transition: color 150ms var(--ease), background 150ms var(--ease);
}
.seg-btn + .seg-btn { border-left: 1px solid var(--line); }
.seg-btn:hover { color: var(--text-1); }
.seg-btn.active { background: var(--ember); color: var(--ember-ink); }

.stats-scroll {
  max-height: 78vh; overflow: auto; margin-top: 6px;
  border: 1px solid var(--line); border-radius: 10px;
}
.stats-table {
  border-collapse: separate; border-spacing: 0; width: 100%;
  font-variant-numeric: tabular-nums; font-size: 0.84rem; white-space: nowrap;
}
.stats-table th {
  position: sticky; top: 0; z-index: 2;
  background: var(--ink-1); color: var(--text-3);
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600;
  text-align: right; padding: 10px 13px; cursor: pointer; user-select: none;
  border-bottom: 1px solid var(--line);
}
.stats-table th.l { text-align: left; }
.stats-table th:hover { color: var(--text-1); }
.stats-table th.sorted { color: var(--ember); }
.stats-table th .arrow { margin-left: 3px; font-size: 0.85em; }
.stats-table td {
  position: relative; text-align: right; padding: 7px 13px;
  color: var(--text-2); border-bottom: 1px solid var(--row-line);
}
.stats-table tbody tr:last-child td { border-bottom: 0; }
.stats-table td.l { text-align: left; color: var(--text-1); font-weight: 600; }
.stats-table tbody tr:hover td { background: var(--ink-1); }
/* sticky name/team column */
.stats-table th.l, .stats-table td.l { position: sticky; left: 0; }
.stats-table th.l { z-index: 3; }
.stats-table td.l { z-index: 1; background: var(--ink-0); }
.stats-table tbody tr:hover td.l { background: var(--ink-1); }
.cbar {
  position: absolute; right: 0; top: 4px; bottom: 4px;
  background: oklch(0.72 0.155 55 / 0.16); border-radius: 3px 0 0 3px; pointer-events: none;
}
.stats-table td.sortcol { color: var(--text-1); }
.cv { position: relative; z-index: 1; }

/* ---------- bets ---------- */
.num.pos { color: var(--up); }
.num.neg { color: var(--down); }

.token-form { max-width: 460px; margin-top: 8px; }
.auth-card { max-width: 380px; display: flex; flex-direction: column; gap: 10px; }
.auth-tabs { display: flex; gap: 4px; margin-bottom: 4px; }
.auth-tab {
  padding: 7px 14px; font-family: var(--display); font-weight: 600; font-size: 0.98rem;
  text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-3);
  border-bottom: 2px solid transparent; transition: color 150ms var(--ease);
}
.auth-tab.active { color: var(--text-1); border-bottom-color: var(--ember); }
.auth-tab:hover { color: var(--text-2); }
.whoami { font-size: 0.85rem; color: var(--text-2); font-weight: 600; font-variant-numeric: tabular-nums; }

/* account page */
.acct-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; max-width: 760px; }
.acct-card { border: 1px solid var(--line); border-radius: 12px; padding: 18px; }
.acct-card h3 { margin: 0 0 14px; font-family: var(--display); font-weight: 600; font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.03em; }
.acct-field { display: block; margin-bottom: 10px; }
.acct-field > span { display: block; font-size: 0.76rem; color: var(--text-3); margin-bottom: 4px; }

/* first-run intro */
.intro-overlay {
  position: fixed; inset: 0; z-index: 80; display: flex; align-items: center; justify-content: center;
  background: oklch(0.1 0.01 262 / 0.72); padding: 20px; overflow-y: auto;
}
.intro-card {
  background: var(--ink-1); border: 1px solid var(--line); border-radius: 14px;
  padding: 26px; max-width: 480px; width: 100%; box-shadow: 0 16px 48px oklch(0 0 0 / 0.5);
}
.intro-card h2 { margin: 0 0 8px; font-family: var(--display); font-weight: 700; font-size: 1.7rem; text-transform: uppercase; letter-spacing: 0.02em; }
.intro-lede { margin: 0 0 16px; color: var(--text-2); font-size: 0.9rem; line-height: 1.5; }
.intro-tabs { list-style: none; margin: 0 0 16px; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.intro-tabs li { display: grid; grid-template-columns: 76px 1fr; gap: 12px; align-items: baseline; }
.intro-tabs b { font-family: var(--display); font-weight: 600; font-size: 0.92rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--ember); }
.intro-tabs span { color: var(--text-3); font-size: 0.85rem; line-height: 1.4; }
.intro-fine { margin: 0 0 16px; color: var(--text-3); font-size: 0.78rem; }

.cron-status {
  font-size: 0.82rem; padding: 9px 14px; border-radius: 8px; margin-bottom: 20px;
  border: 1px solid var(--line);
}
.cron-status.ok { color: var(--text-3); }
.cron-status.warn { color: var(--text-2); }
.cron-status.bad { color: var(--down); background: var(--down-bg); border-color: transparent; }

.row.bet { padding: 16px 4px; }
.bet-head { display: flex; justify-content: space-between; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.bet-title { display: flex; align-items: baseline; gap: 10px; font-weight: 600; font-size: 1rem; flex-wrap: wrap; }
.bet-status {
  font-family: var(--display); font-weight: 600; font-size: 0.72rem; line-height: 1;
  padding: 3px 7px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.04em;
  background: var(--ink-2); color: var(--text-3);
}
.bet-status.s-won { background: var(--up-bg); color: var(--up); }
.bet-status.s-lost { background: var(--down-bg); color: var(--down); }
.bet-status.s-pending { background: oklch(0.72 0.155 55 / 0.12); color: var(--ember); }
.bet-pl { display: flex; align-items: baseline; gap: 12px; font-variant-numeric: tabular-nums; }
.bet-stake { color: var(--text-3); font-size: 0.85rem; }
.bet-profit { font-family: var(--display); font-weight: 700; font-size: 1.15rem; }
.bet-profit.pos { color: var(--up); }
.bet-profit.neg { color: var(--down); }
.bet-legs { list-style: none; margin: 10px 0 0; padding: 0; }
.bet-legs li { display: flex; justify-content: space-between; gap: 12px; padding: 4px 0; font-size: 0.85rem; color: var(--text-2); }
.bet-legs .ld { color: var(--text-3); font-size: 0.78rem; }
.bet-legs .lp { color: var(--text-3); font-variant-numeric: tabular-nums; flex: none; }
.bet-foot { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.bet-meta { color: var(--text-3); font-size: 0.78rem; }
.bet-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.mini {
  border: 1px solid var(--line); border-radius: 5px; padding: 4px 10px;
  font-size: 0.8rem; color: var(--text-2);
  transition: color 150ms var(--ease), border-color 150ms var(--ease);
}
.mini:hover { color: var(--text-1); border-color: var(--text-3); }
.mini.danger:hover { color: var(--down); border-color: var(--down); }

.boost-chip {
  font-family: var(--display); font-weight: 600; font-size: 0.72rem; line-height: 1;
  padding: 3px 7px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.03em;
  background: oklch(0.72 0.155 55 / 0.14); color: var(--ember);
}
.boost-row {
  display: flex; align-items: center; gap: 8px; font-size: 0.85rem; color: var(--text-2);
  user-select: none; cursor: pointer;
}
.boost-row input[type=checkbox] { accent-color: var(--ember); width: 15px; height: 15px; margin: 0; }
.boost-row span { flex: 1; }

.slip-logform { padding: 12px 0 4px; display: flex; flex-direction: column; gap: 8px; }
.slip-logrow { display: flex; gap: 8px; }
.mini-in {
  flex: 1; min-width: 0; background: var(--ink-2); border: 1px solid var(--line); border-radius: 6px;
  color: var(--text-1); font: inherit; font-size: 0.88rem; padding: 8px 10px;
}
.mini-in.wide { width: 100%; }
.mini-in::placeholder { color: var(--text-3); }
.mini-in:focus { outline: 2px solid var(--ember); outline-offset: 0; border-color: transparent; }

.toast {
  position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 12px);
  background: var(--ink-2); color: var(--text-1); border: 1px solid var(--line);
  padding: 10px 18px; border-radius: 8px; font-size: 0.88rem; z-index: 60;
  opacity: 0; transition: opacity 200ms var(--ease), transform 200ms var(--ease);
  box-shadow: 0 8px 28px oklch(0 0 0 / 0.4);
}
.toast.show { opacity: 1; transform: translate(-50%, 0); }

/* ---------- record / calibration ---------- */
.rec-summary {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px; margin: 14px 0 32px;
}
.rec-card { border: 1px solid var(--line); border-radius: 10px; padding: 14px 16px; }
.rec-market { font-family: var(--display); font-weight: 600; font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-2); margin-bottom: 10px; }
.rec-nums { display: flex; gap: 22px; align-items: baseline; }
.rec-nums .num { font-size: 1.7rem; }
.rec-lbl { display: block; font-size: 0.68rem; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.05em; margin-top: 2px; }
.rec-foot { margin-top: 12px; font-size: 0.8rem; color: var(--text-3); font-variant-numeric: tabular-nums; }
.rec-h3 { font-family: var(--display); font-weight: 600; font-size: 1.2rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-2); margin: 8px 0 4px; }

.rec-table {
  width: 100%; border-collapse: collapse; margin: 0 0 28px;
  font-variant-numeric: tabular-nums; font-size: 0.86rem;
}
.rec-table th {
  text-align: right; color: var(--text-3); font-weight: 600;
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em;
  padding: 4px 12px 8px 0; border-bottom: 1px solid var(--line);
}
.rec-table th:first-child, .rec-table td:first-child { text-align: left; }
.rec-table th:last-child, .rec-table td:last-child { width: 32%; padding-right: 0; }
.rec-table td { padding: 8px 12px 8px 0; color: var(--text-2); border-bottom: 1px solid oklch(0.255 0.014 262); }
.rec-table td:first-child { color: var(--text-1); font-weight: 600; }
.calbar { position: relative; height: 8px; border-radius: 4px; background: var(--ink-2); margin-top: 2px; }
.calbar i { position: absolute; top: -2px; width: 2px; height: 12px; border-radius: 1px; transform: translateX(-1px); }
.calbar-pred { background: var(--text-3); }
.calbar-act { background: var(--ember); height: 14px; top: -3px; }

/* ---------- dingers ---------- */
.dinger { display: grid; grid-template-columns: 34px minmax(150px, 1.2fr) 86px 2fr auto; gap: 14px; align-items: center; }
.rank { color: var(--text-3); font-size: 0.95rem; font-family: var(--display); font-weight: 600; text-align: right; }
.d-batter .bname { font-weight: 600; display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.lineup-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--up); flex: none; }
.d-batter .bmeta { color: var(--text-3); font-size: 0.76rem; }
.d-prob { text-align: right; }
.d-prob .num { font-size: 1.85rem; }
.d-prob .sub { display: block; font-size: 0.7rem; color: var(--text-3); }

/* ---------- arms ---------- */
.arm { display: grid; grid-template-columns: minmax(160px, 1.1fr) 92px 1fr auto; gap: 14px; align-items: center; }
.a-name { font-weight: 600; }
.a-meta { color: var(--text-3); font-size: 0.78rem; }
.a-k { text-align: right; }
.a-k .num { font-size: 1.85rem; }
.a-k .sub { display: block; font-size: 0.7rem; color: var(--text-3); }
.kprobs { display: flex; gap: 14px; font-variant-numeric: tabular-nums; font-size: 0.84rem; color: var(--text-2); flex-wrap: wrap; }
.kprobs b { color: var(--text-1); font-weight: 600; }

.k-custom { display: inline-flex; align-items: center; gap: 6px; padding-left: 4px; }
.k-custom-in {
  width: 46px; background: var(--ink-2); border: 1px solid var(--line); border-radius: 5px;
  color: var(--text-1); font: inherit; font-size: 0.85rem; padding: 5px 6px; text-align: center;
}
.k-custom-in:focus { outline: 2px solid var(--ember); outline-offset: 0; border-color: transparent; }
.k-plus { color: var(--text-3); font-size: 0.82rem; }
.k-custom-prob { color: var(--ember); font-size: 0.82rem; font-variant-numeric: tabular-nums; min-width: 34px; font-weight: 600; }

.arsenal { width: 100%; border-collapse: collapse; font-size: 0.8rem; font-variant-numeric: tabular-nums; }
.arsenal th {
  text-align: right; font-weight: 600; color: var(--text-3);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em;
  padding: 2px 10px 6px 0; border-bottom: 1px solid var(--line);
}
.arsenal th:first-child, .arsenal td:first-child { text-align: left; }
.arsenal td { padding: 5px 10px 5px 0; color: var(--text-2); border-bottom: 1px solid oklch(0.255 0.014 262); }
.arsenal td:first-child { color: var(--text-1); }
.starts { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.start-pill {
  font-size: 0.74rem; color: var(--text-2);
  background: var(--ink-1); border-radius: 5px; padding: 5px 8px;
  font-variant-numeric: tabular-nums;
}

/* ---------- parlays ---------- */
.parlay { padding: 16px 4px; }
.tier-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin: 30px 0 2px; }
.tier-head:first-of-type { margin-top: 14px; }
.tier-head h3 {
  margin: 0; font-family: var(--display); font-weight: 700; font-size: 1.25rem;
  text-transform: uppercase; letter-spacing: 0.03em; color: var(--ember);
}
.tier-blurb { color: var(--text-3); font-size: 0.82rem; }
.parlay-note { color: var(--text-3); font-size: 0.82rem; margin: 6px 0 2px; max-width: 64ch; }

.parlay-head { display: flex; align-items: baseline; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.parlay-head h3 {
  margin: 0; font-family: var(--display); font-weight: 700; font-size: 1.3rem;
  text-transform: uppercase; letter-spacing: 0.02em;
}
.parlay-odds { display: flex; gap: 16px; align-items: baseline; }
.parlay-odds .num { font-size: 1.5rem; }
.parlay-legs { margin: 10px 0 0; padding: 0; list-style: none; }
.parlay-legs li {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 7px 0; font-size: 0.88rem;
  border-top: 1px solid oklch(0.255 0.014 262);
}
.parlay-legs .lp { color: var(--text-2); font-variant-numeric: tabular-nums; flex: none; }
.parlay-legs .ld { color: var(--text-3); font-size: 0.78rem; }
.method-list { margin: 8px 0 0; display: grid; grid-template-columns: max-content 1fr; gap: 6px 18px; align-items: baseline; max-width: 72ch; }
.method-list dt { font-weight: 600; color: var(--text-1); font-size: 0.86rem; white-space: nowrap; }
.method-list dd { margin: 0; color: var(--text-3); font-size: 0.86rem; line-height: 1.45; }
.method-details { margin-top: 18px; max-width: 72ch; }
.method-details > summary {
  cursor: pointer; color: var(--text-2); font-size: 0.85rem; font-weight: 600;
  padding: 6px 0; list-style: revert; user-select: none;
}
.method-details > summary:hover { color: var(--text-1); }
.method-details h4 { margin: 14px 0 2px; font-family: var(--display); font-weight: 600; font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-3); }
.method-details p { margin: 4px 0; color: var(--text-3); font-size: 0.84rem; line-height: 1.5; }

.methodology { margin-top: 40px; color: var(--text-2); font-size: 0.85rem; max-width: 70ch; }
.methodology > h3 { font-family: var(--display); font-weight: 600; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-3); margin: 0; }
.methodology h3 { font-family: var(--display); font-weight: 600; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-3); margin: 22px 0 6px; }
.methodology p { margin: 6px 0; }

/* ---------- slip ---------- */
.slip {
  position: fixed; z-index: 40;
  background: var(--ink-1);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  box-shadow: 0 8px 32px oklch(0 0 0 / 0.35);
}
@media (min-width: 1080px) {
  .slip {
    top: 118px; right: max(20px, calc((100vw - 1200px) / 2 - 10px));
    width: var(--rail);
    border-radius: 10px;
    max-height: calc(100vh - 140px);
  }
}
@media (max-width: 1079px) {
  .slip {
    left: 0; right: 0; bottom: 0;
    border-radius: 12px 12px 0 0;
    border-bottom: 0;
    max-height: 72vh;
    padding-bottom: env(safe-area-inset-bottom);
  }
}
.slip-head {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 12px 16px;
  text-align: left; width: 100%;
}
.slip-title { font-family: var(--display); font-weight: 700; font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.04em; }
.slip-title .count { color: var(--ember); }
.slip-summary { font-size: 0.78rem; color: var(--text-3); font-variant-numeric: tabular-nums; }
.slip-body { overflow-y: auto; display: none; border-top: 1px solid var(--line); }
.slip[data-open] .slip-body { display: block; }
.slip-legs { list-style: none; margin: 0; padding: 4px 16px; }
.slip-legs li {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 9px 0; font-size: 0.85rem;
  border-bottom: 1px solid oklch(0.265 0.014 262);
}
.slip-legs li:last-child { border-bottom: 0; }
.slip-legs .ll { min-width: 0; }
.slip-legs .ld { color: var(--text-3); font-size: 0.74rem; }
.slip-legs .lp { color: var(--text-2); font-variant-numeric: tabular-nums; flex: none; }
.slip-remove {
  color: var(--text-3); flex: none; width: 26px; height: 26px; border-radius: 5px;
  font-size: 1rem; line-height: 1;
}
.slip-remove:hover { color: var(--down); background: var(--down-bg); }
.slip-empty { color: var(--text-3); font-size: 0.83rem; padding: 14px 16px 18px; }
.slip-foot { padding: 12px 16px 16px; border-top: 1px solid var(--line); }
.slip-math { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.slip-math .num { font-size: 1.6rem; }
.slip-math .lbl { font-size: 0.7rem; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.05em; display: block; }
.slip-actions { display: flex; gap: 8px; }
.btn-primary {
  flex: 1;
  background: var(--ember); color: var(--ember-ink);
  border-radius: 7px; padding: 9px 14px;
  font-family: var(--display); font-weight: 700; font-size: 1rem;
  letter-spacing: 0.04em; text-transform: uppercase;
  transition: background 150ms var(--ease);
}
.btn-primary:hover { background: var(--ember-press); }
.btn-quiet {
  border: 1px solid var(--line); border-radius: 7px; padding: 9px 14px;
  color: var(--text-2); font-size: 0.85rem;
  transition: color 150ms var(--ease), border-color 150ms var(--ease);
}
.btn-quiet:hover { color: var(--down); border-color: var(--down); }

/* ---------- skeleton / empty / error ---------- */
.skel { border-top: 1px solid var(--line); padding: 18px 4px; }
.skel .bar {
  height: 14px; border-radius: 4px; background: var(--ink-1);
  animation: pulse 1.4s ease-in-out infinite;
}
.skel .bar + .bar { margin-top: 10px; width: 60%; }
@keyframes pulse { 50% { opacity: 0.45; } }
@media (prefers-reduced-motion: reduce) {
  .skel .bar { animation: none; }
  * { transition-duration: 1ms !important; }
}
.empty { padding: 48px 20px; text-align: center; color: var(--text-2); }
.empty h3 { font-family: var(--display); font-weight: 600; font-size: 1.3rem; text-transform: uppercase; letter-spacing: 0.03em; margin: 0 0 8px; }
.empty p { margin: 0 auto; max-width: 46ch; color: var(--text-3); font-size: 0.88rem; }
.retry { margin-top: 16px; }

/* ---------- footer ---------- */
.foot {
  border-top: 1px solid var(--line);
  margin-top: 20px;
}
.foot > * { max-width: 1200px; margin-left: auto; margin-right: auto; padding-left: 20px; padding-right: 20px; }
.foot-rg {
  padding-top: 18px; color: var(--text-2); font-size: 0.8rem; line-height: 1.5; max-width: 90ch;
}
.foot-rg strong { color: var(--text-1); }
.foot-rg a { color: var(--ember); text-decoration: none; }
.foot-rg a:hover { text-decoration: underline; }
.foot-src { padding-top: 12px; color: var(--text-3); font-size: 0.76rem; max-width: 90ch; line-height: 1.5; }
.foot-copy { padding-top: 10px; padding-bottom: 28px; color: var(--text-3); font-size: 0.76rem; }
.foot-copy a { color: var(--text-2); text-decoration: none; }
.foot-copy a:hover { color: var(--ember); }

/* ---------- responsive ---------- */
@media (max-width: 720px) {
  .game {
    grid-template-columns: 1fr 1fr; gap: 6px 14px; align-items: end;
    grid-template-areas: "when when" "matchup matchup" "win tot";
  }
  .game > :nth-child(1) { grid-area: when; }
  .game > :nth-child(2) { grid-area: matchup; margin-top: 4px; }
  .game > :nth-child(3) { grid-area: win; }
  .game > :nth-child(4) { grid-area: tot; }
  .g-when { display: flex; gap: 10px; align-items: baseline; }
  .g-status { margin-top: 0; }
  .g-col { text-align: left; }
  .g-team { grid-template-columns: auto auto 1fr auto; }
}
@media (max-width: 860px) {
  .dinger { grid-template-columns: 26px 1fr 80px; }
  .dinger .chips { grid-column: 2 / -1; }
  .dinger .add { grid-column: 2 / -1; justify-self: start; }
  .arm { grid-template-columns: 1fr 86px; }
  .arm .kprobs { grid-column: 1 / -1; }
  .arm .add { grid-column: 1 / -1; justify-self: start; }
  .game-detail { grid-template-columns: 1fr; }
  #main { padding-bottom: 140px; }
  .top-inner { flex-wrap: wrap; padding: 12px 14px 6px; }
  .wordmark { font-size: 1.4rem; }
  #main { padding-left: 14px; padding-right: 14px; }
}
