/* ============================================================
   Caprock Stakes — design tokens + component styles
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap");

/* -- Night Rail (dark, default) ----------------------------- */
:root {
  --bg-0:        #0B0F14;
  --bg-1:        #111821;
  --bg-2:        #1A2430;
  --line:        #24303D;
  --line-strong: #3A4A5C;

  --ink-0: #F2F5F8;
  --ink-1: #C6D0DA;
  --ink-2: #8A97A6;
  --ink-3: #5C6977;

  --accent:    #C8A24A;
  --accent-hi: #E6C173;
  --pos:       #4FB286;
  --neg:       #D2795A;
  --info:      #6FA8DC;
  --turf:      #3F7A52;
  --dirt:      #8C6A3A;

  --star-tint:    color-mix(in oklab, var(--accent) 6%,  var(--bg-1));
  --star-pill-bg: color-mix(in oklab, var(--accent) 18%, var(--bg-0));
  --pos-tint:     color-mix(in oklab, var(--pos)    14%, var(--bg-0));
  --neg-tint:     color-mix(in oklab, var(--neg)    14%, var(--bg-0));
  --zero-bg:      var(--bg-2);

  --font-sans: "IBM Plex Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  --ls-caps: 0.12em;
  --ls-meta: 0.04em;

  --r-chip: 2px;
  --r-card: 4px;
  --r-nav:  8px;
}

/* -- Paddock Day (light) ------------------------------------ */
:root[data-theme="light"] {
  --bg-0:        #F5F1E8;
  --bg-1:        #FFFFFF;
  --bg-2:        #EDE6D4;
  --line:        #D8CFB7;
  --line-strong: #8A7A52;

  --ink-0: #1A1812;
  --ink-1: #3A3628;
  --ink-2: #6F6850;
  --ink-3: #A59D83;

  --accent:    #9C7A1F;
  --accent-hi: #B99434;
  --pos:       #2E8C5F;
  --neg:       #B74F2C;
  --info:      #2B66A3;
  --turf:      #2F6A44;
  --dirt:      #7A5A2C;

  --star-tint:    color-mix(in oklab, var(--accent)  7%, var(--bg-1));
  --star-pill-bg: color-mix(in oklab, var(--accent) 14%, var(--bg-1));
  --pos-tint:     color-mix(in oklab, var(--pos)    10%, var(--bg-1));
  --neg-tint:     color-mix(in oklab, var(--neg)    10%, var(--bg-1));
  --zero-bg:      var(--bg-2);
}

/* ============================================================
   Base
   ============================================================ */
* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg-0);
  color: var(--ink-1);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.45;
  font-feature-settings: "tnum" 1, "ss01" 1;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--info); text-decoration: none; }
a:hover { color: var(--accent-hi); }

/* ============================================================
   Auth gate (preserved for gate.js)
   ============================================================ */
html.gate-locked body > *:not(#gate-veil) { visibility: hidden; }
html:not(.gate-locked) #gate-veil { display: none; }

#gate-veil {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-0); z-index: 1000;
}
.gate-message { text-align: center; color: var(--ink-2); }
.gate-message p { margin: 0 0 12px; }
.spinner {
  width: 32px; height: 32px;
  border: 3px solid var(--line);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto 12px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   Layout
   ============================================================ */
.doc {
  max-width: 1440px;
  margin: 0 auto;
  padding: 24px 32px 96px;
}
@media (max-width: 720px) {
  .doc { padding: 16px 16px 64px; }
}

.doc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.wordmark { display: flex; align-items: center; gap: 12px; }
.wordmark .mark {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.wordmark .name {
  font: 700 18px/1 var(--font-sans);
  color: var(--ink-0);
  letter-spacing: 0.02em;
  text-decoration: none;
}
.wordmark .name em { font-style: normal; color: var(--accent); font-weight: 700; }
.wordmark .tagline {
  color: var(--ink-2);
  font: 500 12.5px/1 var(--font-sans);
  letter-spacing: var(--ls-meta);
  padding-left: 8px;
  border-left: 1px solid var(--line);
  margin-left: 4px;
}
@media (max-width: 720px) { .wordmark .tagline { display: none; } }

.doc-head-right {
  display: flex; align-items: center; gap: 12px;
  color: var(--ink-2);
  font: 500 12px/1 var(--font-sans);
}
.user-email {
  color: var(--ink-2);
  font: 500 12px/1 var(--font-mono);
  letter-spacing: var(--ls-meta);
}
.sign-out {
  background: transparent;
  color: var(--info);
  border: 1px solid var(--line);
  padding: 5px 10px;
  border-radius: var(--r-chip);
  cursor: pointer;
  font: 600 11px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
}
.sign-out:hover { color: var(--accent-hi); border-color: var(--accent); }

/* Theme toggle */
.theme-toggle {
  display: flex; gap: 4px;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-nav);
  padding: 4px;
}
.theme-toggle button {
  font: 600 10.5px/1 var(--font-sans);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 5px;
  border: 0;
  background: transparent;
  color: var(--ink-2);
  cursor: pointer;
}
.theme-toggle button.active {
  background: var(--bg-2);
  color: var(--ink-0);
  box-shadow: inset 0 -2px 0 var(--accent);
}
.theme-toggle button:hover { color: var(--ink-0); }

/* Page title row */
.page-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin: 0 0 20px;
}
.page-title h1 {
  margin: 0;
  font: 600 24px/1.15 var(--font-sans);
  color: var(--ink-0);
  letter-spacing: -0.005em;
}
.page-title .crumb {
  color: var(--ink-2);
  font: 500 12.5px/1 var(--font-sans);
  letter-spacing: var(--ls-meta);
}
.page-title .crumb a { color: var(--info); }
.page-title .crumb a:hover { color: var(--accent-hi); }

.gen-meta {
  color: var(--ink-2);
  font: 500 12.5px/1.4 var(--font-sans);
  letter-spacing: var(--ls-meta);
  margin: 0 0 16px;
}

/* Footer */
.site-footer {
  border-top: 1px solid var(--line);
  color: var(--ink-3);
  padding: 14px 24px;
  text-align: center;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: var(--ls-meta);
  margin-top: 40px;
}

/* Typography utility (used sparingly) */
.type-eyebrow {
  font: 600 11px/1 var(--font-sans);
  color: var(--ink-2);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
}

/* ============================================================
   Chips
   ============================================================ */
.chips { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }

.chip-track {
  font: 700 13px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--ink-0);
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  padding: 6px 10px;
  border-radius: var(--r-chip);
}

.chip-surface {
  font: 600 11px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  padding: 5px 8px;
  border-radius: var(--r-chip);
  color: var(--ink-0);
}
.chip-surface.turf {
  background: color-mix(in oklab, var(--turf) 55%, var(--bg-0));
  border: 1px solid var(--turf);
}
.chip-surface.dirt {
  background: color-mix(in oklab, var(--dirt) 45%, var(--bg-0));
  border: 1px solid var(--dirt);
}

.chip-cond {
  font: 600 11px/1 var(--font-mono);
  letter-spacing: var(--ls-caps);
  color: var(--ink-1);
  background: var(--bg-2);
  padding: 5px 8px;
  border-radius: var(--r-chip);
  border: 1px solid var(--line);
}

.chip-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  font: 700 13px/1 var(--font-mono);
  border-radius: var(--r-chip);
  color: var(--ink-0);
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  flex-shrink: 0;
  vertical-align: middle;
}
.chip-num.odd {
  background: color-mix(in oklab, var(--info) 18%, var(--bg-1));
  border-color: color-mix(in oklab, var(--info) 35%, var(--line));
}
.chip-num.even {
  background: color-mix(in oklab, var(--neg) 18%, var(--bg-1));
  border-color: color-mix(in oklab, var(--neg) 35%, var(--line));
  color: color-mix(in oklab, var(--neg) 70%, var(--ink-0));
}

.chip-rank {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font: 600 12px/1 var(--font-mono);
  color: var(--ink-2);
  padding: 4px 8px;
  border-radius: var(--r-chip);
  border: 1px solid var(--line);
  min-width: 30px;
  justify-content: center;
}
.chip-rank.star {
  color: var(--accent);
  border-color: color-mix(in oklab, var(--accent) 60%, var(--bg-0));
  background: var(--star-pill-bg);
}

.edge {
  font: 500 12.5px/1 var(--font-mono);
  letter-spacing: 0.02em;
  padding: 4px 8px;
  border-radius: var(--r-chip);
  display: inline-block;
}
.edge.pos  { color: var(--pos); background: var(--pos-tint); }
.edge.neg  { color: var(--neg); background: var(--neg-tint); }
.edge.zero { color: var(--ink-2); background: var(--zero-bg); }

.badge-bet {
  font: 700 10.5px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  padding: 5px 8px;
  border-radius: var(--r-chip);
  border: 1px solid var(--line-strong);
  color: var(--ink-0);
  background: var(--bg-2);
}
.badge-bet.tri { color: #F6D994; border-color: color-mix(in oklab, #F6D994 40%, var(--line)); }
.badge-bet.ex  { color: #BFDFFA; border-color: color-mix(in oklab, #BFDFFA 40%, var(--line)); }
.badge-bet.sup { color: #F3B5A2; border-color: color-mix(in oklab, #F3B5A2 40%, var(--line)); }

/* ============================================================
   Cards
   ============================================================ */
.card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  overflow: hidden;
}
.card + .card { margin-top: 16px; }

.track-header {
  padding: 20px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border-bottom: 1px solid var(--line-strong);
}
.track-header .code {
  font: 700 24px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  color: var(--ink-0);
  border-right: 1px solid var(--line);
  padding-right: 20px;
}
.track-header .full { font: 600 16px/1.2 var(--font-sans); color: var(--ink-0); }
.track-header .full small {
  display: block; margin-top: 4px;
  color: var(--ink-2); font-weight: 400; font-size: 12.5px;
  letter-spacing: var(--ls-meta);
}
.track-header .right {
  margin-left: auto;
  display: flex; align-items: center; gap: 12px;
  color: var(--ink-2);
  font: 500 12.5px/1 var(--font-sans);
  letter-spacing: var(--ls-meta);
}

.race-header {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 14px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-1);
  scroll-margin-top: 80px;
}
.race-header .r-num {
  font: 700 12px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  color: var(--ink-0);
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  padding: 6px 10px;
  border-radius: var(--r-chip);
}
.race-header .r-time { font: 600 14px/1 var(--font-mono); color: var(--ink-0); }
.race-header .r-meta {
  color: var(--ink-2);
  font: 500 12.5px/1 var(--font-sans);
  letter-spacing: var(--ls-meta);
  display: flex; gap: 10px; align-items: center;
  flex-wrap: wrap;
}
.race-header .r-meta .dot {
  width: 3px; height: 3px;
  background: var(--ink-3);
  border-radius: 50%;
  display: inline-block;
}
.race-header .purse {
  margin-left: auto;
  font: 600 13px/1 var(--font-mono);
  color: var(--accent);
}

/* Jump rail */
.jump-rail {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  padding: 8px 24px;
  background: var(--bg-1);
  border-bottom: 1px solid var(--line);
  font: 500 12px/1 var(--font-mono);
}
.jump-rail a {
  color: var(--info);
  text-decoration: none;
  padding: 6px 10px;
}
.jump-rail a:hover { color: var(--accent-hi); }
.jump-rail .sep { color: var(--ink-3); padding: 6px 2px; }
.jump-rail .back { margin-left: auto; color: var(--ink-2); }
.jump-rail .back a { color: var(--ink-2); }
.jump-rail .back a:hover { color: var(--accent-hi); }

.card-bottom-nav {
  padding: 10px 24px;
  background: var(--bg-1);
  border-top: 1px solid var(--line);
  font: 500 12px/1 var(--font-mono);
  color: var(--ink-2);
  text-align: right;
}
.card-bottom-nav a { color: var(--info); text-decoration: none; }
.card-bottom-nav a:hover { color: var(--accent-hi); }

/* Track anchor offset (target :before trick via scroll-margin) */
.track-anchor { scroll-margin-top: 16px; }

/* ============================================================
   Pick table
   ============================================================ */
.pick-table { width: 100%; border-collapse: collapse; }
.pick-table th,
.pick-table td {
  padding: 10px 12px;
  font-size: 13px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  white-space: nowrap;
}
.pick-table thead th {
  background: var(--bg-2);
  color: var(--ink-2);
  font: 600 10.5px/1 var(--font-sans);
  text-transform: uppercase;
  letter-spacing: var(--ls-caps);
  text-align: left;
  border-bottom: 1px solid var(--line-strong);
}
.pick-table td.num {
  font: 500 13px/1 var(--font-mono);
  color: var(--ink-0);
  text-align: right;
  font-feature-settings: "tnum" 1;
}
.pick-table td.horse {
  font: 600 14px/1.2 var(--font-sans);
  color: var(--ink-0);
  min-width: 220px;
  white-space: normal;
}
.pick-table td.horse .chip-num { margin-right: 10px; }
.pick-table td.horse .connections {
  display: block;
  color: var(--ink-2);
  font: 400 12px/1.4 var(--font-sans);
  margin-top: 4px;
}
.pick-table td.horse .thin {
  display: inline-block;
  margin-left: 6px;
  color: var(--ink-3);
  font: 400 11px/1 var(--font-mono);
}
.pick-table tr.star-row td { background: var(--star-tint); }
.pick-table tr.star-row td:first-child { border-left: 2px solid var(--accent); }
.pick-table tr.star-row td.horse strong { color: var(--accent); font-weight: 700; }
.pick-table tr:hover td { background: rgba(255, 255, 255, 0.02); }
:root[data-theme="light"] .pick-table tr:hover td { background: rgba(0, 0, 0, 0.025); }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Wager grid */
.wagers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 16px 24px 20px;
  background: var(--bg-1);
}
@media (max-width: 720px) { .wagers { grid-template-columns: 1fr; } }

.wager {
  background: var(--bg-0);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.wager .top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.wager .ticket {
  font: 500 13px/1.4 var(--font-mono);
  color: var(--ink-0);
  font-feature-settings: "tnum" 1;
}
.wager .bottom {
  display: flex; gap: 20px; align-items: baseline; flex-wrap: wrap;
}
.wager .stake { font: 600 14px/1 var(--font-mono); color: var(--ink-0); }
.wager .kv { display: flex; gap: 6px; align-items: baseline; }
.wager .kv .k {
  color: var(--ink-2);
  font: 500 10.5px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
}
.wager .kv .v { color: var(--ink-0); font: 500 12.5px/1 var(--font-mono); }

/* Exotic table */
.exotic-section { padding: 8px 24px 20px; background: var(--bg-1); }
.exotic-section .type-eyebrow { margin: 12px 0 8px; }

.exotic-table { width: 100%; border-collapse: collapse; }
.exotic-table th,
.exotic-table td {
  padding: 9px 12px;
  font-size: 13px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
}
.exotic-table thead th {
  background: var(--bg-2);
  color: var(--ink-2);
  font: 600 10.5px/1 var(--font-sans);
  text-transform: uppercase;
  letter-spacing: var(--ls-caps);
  text-align: left;
  border-bottom: 1px solid var(--line-strong);
}
.exotic-table td.tkt {
  font: 600 14px/1 var(--font-mono);
  color: var(--ink-0);
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.exotic-table td.horses {
  color: var(--ink-1);
  font: 400 12.5px/1.4 var(--font-sans);
}
.exotic-table td.prob { width: 220px; }
.prob-bar { display: flex; align-items: center; gap: 10px; }
.prob-bar .track {
  flex: 1;
  height: 6px;
  background: var(--bg-2);
  border-radius: 2px;
  overflow: hidden;
}
.prob-bar .fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, color-mix(in oklab, var(--accent) 60%, var(--bg-0)), var(--accent));
}
.prob-bar .pct {
  font: 500 12.5px/1 var(--font-mono);
  color: var(--ink-0);
  min-width: 48px;
  text-align: right;
}
.exotic-table tr.star-row td { background: var(--star-tint); }
.exotic-table tr.star-row td.tkt { color: var(--accent); }
.exotic-table td.cost {
  font: 600 12.5px/1 var(--font-mono);
  color: var(--ink-1);
  text-align: right;
  white-space: nowrap;
}

.race-meta-row {
  padding: 6px 24px 14px;
  color: var(--ink-2);
  font: 500 12px/1 var(--font-mono);
  letter-spacing: var(--ls-meta);
  background: var(--bg-1);
  border-bottom: 1px solid var(--line);
}

/* ============================================================
   Track picker (sticky nav)
   ============================================================ */
.track-picker {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--bg-0);
  border: 1px solid var(--line);
  border-radius: var(--r-nav);
  padding: 8px;
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.track-picker a {
  text-decoration: none;
  font: 700 13px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  color: var(--ink-2);
  padding: 8px 12px;
  border-radius: 4px;
}
.track-picker a:hover { color: var(--ink-0); background: var(--bg-1); }
.track-picker a.active {
  color: var(--ink-0);
  background: var(--bg-2);
  box-shadow: inset 0 -2px 0 var(--accent);
}

/* ============================================================
   Index (landing) table
   ============================================================ */
.index-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  overflow: hidden;
}
.index-table th,
.index-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  text-align: left;
}
.index-table thead th {
  background: var(--bg-2);
  color: var(--ink-2);
  font: 600 10.5px/1 var(--font-sans);
  text-transform: uppercase;
  letter-spacing: var(--ls-caps);
  border-bottom: 1px solid var(--line-strong);
}
.index-table td.date {
  font: 600 14px/1 var(--font-mono);
  color: var(--ink-0);
  width: 180px;
  letter-spacing: 0.02em;
}
.index-table td a {
  color: var(--info);
  font: 500 13px/1 var(--font-sans);
}
.index-table td a:hover { color: var(--accent-hi); }
.index-table tr:last-child td { border-bottom: 0; }

/* ============================================================
   Chaos / skipped note
   ============================================================ */
.chaos-note {
  margin: 24px 0 0;
  padding: 12px 16px;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-left: 3px solid var(--ink-3);
  border-radius: var(--r-card);
  color: var(--ink-2);
  font: 500 12.5px/1.5 var(--font-sans);
}
.chaos-note code {
  font: 500 12px/1 var(--font-mono);
  background: var(--bg-2);
  color: var(--ink-1);
  padding: 2px 6px;
  border-radius: var(--r-chip);
}

/* ============================================================
   Markdown-generated tables inside .main (e.g. the landing index)
   — only styles top-level kramdown tables, never the component
   tables nested inside .card wrappers.
   ============================================================ */
.main > table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  overflow: hidden;
  margin: 4px 0 24px;
}
.main > table th,
.main > table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}
.main > table thead th {
  background: var(--bg-2);
  color: var(--ink-2);
  font: 600 10.5px/1 var(--font-sans);
  text-transform: uppercase;
  letter-spacing: var(--ls-caps);
  border-bottom: 1px solid var(--line-strong);
}
.main > table tbody tr:nth-child(2n) td { background: rgba(255, 255, 255, 0.015); }
:root[data-theme="light"] .main > table tbody tr:nth-child(2n) td { background: rgba(0, 0, 0, 0.02); }
.main > table tbody tr:hover td { background: rgba(200, 162, 74, 0.04); }
.main > table td:first-child {
  font: 600 14px/1 var(--font-mono);
  color: var(--ink-0);
  width: 180px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.main > table td a {
  color: var(--info);
  text-decoration: none;
  font: 500 13px/1 var(--font-sans);
}
.main > table td a:hover { color: var(--accent-hi); }
.main > table tr:last-child td { border-bottom: 0; }

/* ============================================================
   Fallback kramdown-rendered markdown (index.md etc.)
   ============================================================ */
.main h1 { font: 600 24px/1.15 var(--font-sans); color: var(--ink-0); margin-top: 8px; }
.main h2 {
  font: 600 18px/1.2 var(--font-sans);
  color: var(--ink-0);
  border-bottom: 1px solid var(--line);
  padding-bottom: 6px;
  margin-top: 28px;
}
.main h3 { font: 600 15px/1.2 var(--font-sans); color: var(--accent); margin-top: 20px; }
.main p { color: var(--ink-1); }
.main code {
  background: var(--bg-1);
  border: 1px solid var(--line);
  padding: 1px 5px;
  border-radius: 3px;
  font: 500 12.5px/1 var(--font-mono);
}
.main pre {
  background: var(--bg-1);
  border: 1px solid var(--line);
  padding: 12px;
  border-radius: var(--r-card);
  overflow-x: auto;
  font: 500 12.5px/1.45 var(--font-mono);
}
.main pre code { background: transparent; border: 0; padding: 0; }
.main blockquote {
  border-left: 3px solid var(--line-strong);
  padding: 4px 12px;
  color: var(--ink-2);
  margin: 16px 0;
}
.main hr { border: 0; border-top: 1px solid var(--line); margin: 24px 0; }

/* ============================================================
   Login page
   ============================================================ */
.login-body {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh;
  background: linear-gradient(135deg, var(--bg-0) 0%, var(--bg-1) 100%);
}
.login-card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  padding: 40px 48px;
  max-width: 380px; width: 100%;
  text-align: center;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}
.login-card .wordmark {
  justify-content: center;
  margin-bottom: 18px;
}
.login-card h1 {
  margin: 0 0 6px;
  color: var(--ink-0);
  font: 600 22px/1.2 var(--font-sans);
  letter-spacing: -0.005em;
}
.login-sub {
  color: var(--ink-2);
  font: 500 12.5px/1.4 var(--font-sans);
  letter-spacing: var(--ls-meta);
  margin: 0 0 24px;
}
.sign-in-btn {
  width: 100%;
  background: var(--accent);
  color: var(--bg-0);
  border: 0;
  padding: 11px 14px;
  border-radius: var(--r-card);
  font: 700 13px/1 var(--font-sans);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  cursor: pointer;
}
.sign-in-btn:hover { background: var(--accent-hi); }
.login-error {
  color: var(--neg);
  font: 500 12.5px/1.4 var(--font-sans);
  margin-top: 16px;
}

/* ============================================================
   Breakpoints
   ============================================================ */
@media (max-width: 720px) {
  .track-header { padding: 14px 16px; gap: 12px; }
  .track-header .code { font-size: 20px; padding-right: 14px; }
  .race-header, .jump-rail, .exotic-section, .wagers { padding-left: 16px; padding-right: 16px; }
  .pick-table th, .pick-table td { padding: 8px 8px; font-size: 12.5px; }
  .exotic-table th, .exotic-table td { padding: 8px 8px; }
  .main > table { display: block; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}
