:root {
  --bg: #0e1116;
  --panel: #161b22;
  --panel-2: #1c232d;
  --line: #2a323d;
  --text: #e6edf3;
  --muted: #a9b3bd;
  --accent: #f0883e;
  --accent-2: #58a6ff;
  --good: #3fb950;
  --good-bg: rgba(63, 185, 80, 0.14);
  --bad: #f85149;
  --bad-bg: rgba(248, 81, 73, 0.12);
  --radius: 10px;
  font-synthesis: none;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: ui-sans-serif, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
}

header {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-end;
  justify-content: space-between;
  padding: 48px 28px 16px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #11161d, var(--bg));
}

/* account control — pinned top-right, out of the header's flex flow */
.account { position: absolute; top: 12px; right: 28px;
  display: flex; align-items: center; gap: 10px; font-size: 12px; }
.account .acct-name { color: var(--muted); }
.account .acct-name b { color: var(--text); font-weight: 600; }
.account button { background: var(--panel-2); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px; padding: 6px 12px;
  cursor: pointer; font-size: 12px; font-weight: 600; }
.account button#signin { background: var(--accent); color: #1a1206; border-color: transparent; }
.account button:hover { filter: brightness(1.08); border-color: var(--accent-2); }
@media (max-width: 640px) { .account { right: 14px; } }
.title h1 { margin: 0; font-size: 22px; letter-spacing: -0.01em; display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.title .tagline { font-size: 12px; font-weight: 600; color: var(--accent); letter-spacing: 0.02em; text-transform: none; }
.title .sub { margin: 4px 0 0; color: var(--muted); font-size: 13px; }

.controls { display: flex; gap: 16px; align-items: center; }
.controls label { display: flex; flex-direction: column; gap: 4px; font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
select, input[type="search"] {
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 13px;
  outline: none;
}
select:focus, input:focus { border-color: var(--accent-2); }

.tabs { display: inline-flex; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; padding: 3px; }
.tabs button {
  background: transparent; border: 0; color: var(--muted);
  padding: 7px 14px; border-radius: 6px; cursor: pointer; font-size: 13px; font-weight: 600;
}
.tabs button.active { background: var(--line); color: var(--text); box-shadow: inset 0 -2px 0 var(--accent); }

.bar {
  display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: space-between;
  padding: 14px 28px; border-bottom: 1px solid var(--line);
}
.chips { display: flex; gap: 10px; flex-wrap: wrap; }
.chip { background: var(--panel); border: 1px solid var(--line); border-radius: 999px; padding: 6px 12px; font-size: 12px; color: var(--muted); }
.chip b { color: var(--text); }
.chip.good b { color: var(--good); }
button.chip { cursor: pointer; font: inherit; font-size: 12px; }
.today-chip:hover { border-color: var(--accent-2); }
.today-chip.good { border-color: var(--good); }
#search { min-width: 240px; }
.bar-right { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.unit-label { display: flex; gap: 8px; align-items: center; font-size: 12px; color: var(--muted); white-space: nowrap; }

main { padding: 8px 28px 40px; }

/* front-load trust — the credibility strip above a model's board */
.trust { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px;
  margin: 10px 0 4px; padding: 10px 14px; font-size: 13px;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); }
.trust-badge { font-size: 12px; font-weight: 700; padding: 2px 9px;
  border-radius: 999px; border: 1px solid var(--line); white-space: nowrap; }
.trust-badge.backtested { color: var(--good); border-color: rgba(63,185,80,0.45);
  background: var(--good-bg); }
.trust-badge.live { color: var(--accent-2); border-color: rgba(88,166,255,0.45); }
.trust-badge.reasoned { color: var(--accent); border-color: rgba(240,136,62,0.45); }
.trust-badge.mine { color: var(--accent); border-color: rgba(240,136,62,0.45);
  background: rgba(240,136,62,0.10); }
.trust-val { color: var(--muted); flex: 1 1 240px; min-width: 0; }
.trust-rec { color: var(--text); white-space: nowrap; }
.trust-mini { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--muted); }
.trust-mini.good { color: var(--good); }

/* ledger time rollups — period toggle + by-sport / by-type slices */
.period-bar { display: inline-flex; background: var(--panel-2);
  border: 1px solid var(--line); border-radius: 8px; padding: 3px;
  margin: 4px 0 14px; }
.period-btn { background: transparent; border: 0; color: var(--muted);
  padding: 6px 14px; border-radius: 6px; cursor: pointer; font-size: 13px;
  font-weight: 600; }
.period-btn.active { background: var(--line); color: var(--text); box-shadow: inset 0 -2px 0 var(--accent); }
.ledger-roll .roll-slices { display: grid; gap: 18px; margin-top: 8px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.roll-slice h4 { margin: 0 0 6px; font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--muted); font-weight: 700; }
.roll-row { display: grid; grid-template-columns: 1fr auto auto; gap: 12px;
  align-items: baseline; padding: 4px 0; border-bottom: 1px solid var(--line); }
.roll-row:last-child { border-bottom: 0; }
.roll-name { color: var(--text); }
.roll-u { text-align: right; min-width: 64px; font-variant-numeric: tabular-nums; }
.status { color: var(--muted); padding: 24px 0; }
.status code { background: var(--panel-2); padding: 2px 6px; border-radius: 5px; }

/* group sections (a game, a race, a market) */
.group { margin-top: 22px; }
.group-h { display: flex; flex-wrap: wrap; align-items: baseline; gap: 12px; margin-bottom: 8px; }
.group-h h2 { margin: 0; font-size: 15px; letter-spacing: -0.01em; }
.group-ctx { color: var(--muted); font-size: 12px; }

tbody tr.flagged td { background: rgba(63, 185, 80, 0.06); }
tbody tr.flagged td:first-child { box-shadow: inset 3px 0 0 var(--good); }
.flag-tag { background: var(--good-bg); color: var(--good); border-color: transparent; }
.detail-line { color: var(--muted); font-size: 12px; font-weight: 400; margin-top: 2px; }
.chip.warn { border-color: rgba(240, 136, 62, 0.5); color: var(--accent); }

/* tune tab */
.tune-panel { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; }
.tune-panel .group-h { margin-bottom: 12px; }
.sliders { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 10px 24px; }
.slider { display: grid; grid-template-columns: 110px 1fr 44px; align-items: center; gap: 10px; }
.slider .flabel { font-size: 12px; color: var(--muted); }
.slider .wval { font-variant-numeric: tabular-nums; font-weight: 600; font-size: 12px; text-align: right; }
.slider input[type="range"] { width: 100%; accent-color: var(--accent); }
.slider.off { opacity: 0.45; }
.reset-btn { margin-left: auto; background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 8px; padding: 6px 14px; cursor: pointer; font-size: 12px; font-weight: 600; }
.reset-btn:hover { border-color: var(--accent-2); }
.reset-btn:disabled { opacity: 0.4; cursor: default; }
.preset-bar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.preset-bar .reset-btn { margin-left: 0; }
.preset-bar input[type="text"] { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 8px; padding: 6px 10px; font-size: 12px; min-width: 170px; }
.preset-status { color: var(--muted); font-size: 12px; }
.lost-tag { background: var(--bad-bg); color: var(--bad); border-color: transparent; margin-left: 6px; }

/* Build Your Model */
#build-btn {
  background: linear-gradient(135deg, var(--accent), #d96f23);
  color: #1a1206; border: 0; border-radius: 8px;
  padding: 9px 16px; cursor: pointer; font-size: 13px; font-weight: 700;
}
#build-btn:hover { filter: brightness(1.08); }
#build-btn.active { outline: 2px solid var(--text); }

#upload-btn {
  background: var(--panel); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px;
  padding: 9px 14px; cursor: pointer; font-size: 13px; font-weight: 600;
}
#upload-btn:hover { border-color: var(--accent); filter: brightness(1.05); }

.track-bar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin: 0 0 14px; padding: 10px 14px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 8px;
}
#track-btn {
  background: var(--accent); color: #1a1206; border: 0; border-radius: 7px;
  padding: 7px 13px; cursor: pointer; font-size: 13px; font-weight: 700;
}
#track-btn:hover { filter: brightness(1.08); }
#track-btn:disabled { opacity: .6; cursor: default; }
.track-done { color: var(--good); font-weight: 700; font-size: 13px; }
.track-note { font-size: 12px; color: var(--muted); }
.track-note code { font-size: 11px; }
.track-msg { font-size: 12px; color: var(--bad); }
.settle-in {
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
  border-radius: 6px; padding: 6px 9px; font-size: 12px;
}
#settle-btn {
  background: var(--accent); color: #1a1206; border: 0; border-radius: 7px;
  padding: 7px 13px; cursor: pointer; font-size: 13px; font-weight: 700;
}
#settle-btn:hover { filter: brightness(1.08); }
#settle-btn:disabled { opacity: .6; cursor: default; }
.settle-more { flex-basis: 100%; margin-top: 2px; }
.settle-more summary { font-size: 12px; color: var(--muted); cursor: pointer; }
.settle-grid {
  display: flex; flex-wrap: wrap; gap: 10px 14px; margin: 10px 0 4px;
}
.settle-grid label {
  display: flex; flex-direction: column; gap: 3px; font-size: 11px;
  color: var(--muted); text-transform: uppercase; letter-spacing: 0.03em;
}
.settle-grid .settle-in { text-transform: none; letter-spacing: normal; }

/* place/show markets in the expandable detail row (race model) */
.markets {
  display: flex; flex-wrap: wrap; gap: 8px 16px; align-items: baseline;
  margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--line);
}
.markets .mkt { font-size: 12.5px; }
.markets .mkt b { color: var(--accent); font-weight: 700; }
.mkt-note { font-size: 11px; color: var(--muted); font-style: italic; }
/* a live +EV play (place/show leg or exotic combo) */
.mkt-play { color: var(--good); font-weight: 600; }
tr.mkt-play td { color: var(--good); }

/* exotic combos panel under each race */
.exotics { margin: 4px 0 6px; }
.exotics > summary {
  font-size: 12px; color: var(--muted); cursor: pointer;
  display: flex; gap: 8px; align-items: baseline;
}
.exotic-cols { display: flex; flex-wrap: wrap; gap: 22px; margin-top: 10px; }
.exotic-col h4 {
  margin: 0 0 4px; font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--muted); font-weight: 700;
}
.exotic-tbl { border-collapse: collapse; font-size: 12.5px; }
.exotic-tbl th, .exotic-tbl td { padding: 2px 12px 2px 0; text-align: right; }
.exotic-tbl th.left, .exotic-tbl td.combo { text-align: left; }
.exotic-tbl th { color: var(--muted); font-weight: 600; }
.exotic-tbl .combo { font-variant-numeric: tabular-nums; font-weight: 600; }
.sources { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 12px; margin-top: 4px; }
.source {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 12px 14px; cursor: pointer; transition: border-color 0.12s, opacity 0.12s;
}
.source:hover { border-color: var(--accent-2); }
.source.on { border-color: var(--good); }
.source.off { opacity: 0.62; }
.source.foundation { cursor: default; opacity: 0.55; border-style: dashed; }
.src-h { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; margin-bottom: 4px; }
.src-meta { color: var(--muted); font-size: 11px; margin-top: 6px; }
.src-slider { margin-top: 10px; grid-template-columns: 52px 1fr 40px; }

/* the board lens — view one of your models on the live board */
.lens-bar { display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  margin: 2px 0 14px; padding: 10px 14px; background: var(--panel);
  border: 1px solid var(--line); border-radius: var(--radius); }
.lens-bar .lens-label { font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--muted); }
.lens-bar select { font-size: 13px; }
.lens-note { font-size: 12px; color: var(--text); }
.lens-note.muted { color: var(--muted); }
.lens-note a { color: var(--accent-2); }

/* My Models — the authoring home */
.mm-sport { font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--muted); margin: 18px 0 2px; }
.mm-sport:first-of-type { margin-top: 6px; }
.mm-filter { display: flex; gap: 8px; align-items: center; font-size: 12px;
  color: var(--muted); white-space: nowrap; margin-left: auto; }
.mm-filter select { font-size: 13px; }
.mm-sport .muted { font-size: 11px; }
.mm-grid { margin-top: 8px; }
.mm-card { cursor: default; }
.mm-card:hover { border-color: var(--line); }
.mm-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.mm-actions .reset-btn { margin-left: 0; }
.mm-actions .reset-btn:first-child { border-color: var(--accent); color: var(--accent); }

/* sign-in-then-adopt success banner (ACCOUNTS.md Phase 4) */
.adopt-banner { display: flex; align-items: center; justify-content: space-between;
  gap: 14px; margin: 2px 0 14px; padding: 11px 16px; background: var(--good-bg);
  border: 1px solid rgba(63, 185, 80, 0.45); border-radius: var(--radius);
  color: var(--text); font-size: 13px; font-weight: 600; }
.adopt-banner .reset-btn { margin-left: 0; }

/* publish + copy-link (ACCOUNTS.md Phase 4) */
.mm-share { display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--line); }
.mm-share .reset-btn { margin-left: 0; }
.mm-vis { display: flex; align-items: center; gap: 8px; font-size: 12px;
  color: var(--muted); text-transform: none; letter-spacing: normal; }
.mm-vis select { font-size: 12px; }
.mm-link-msg { font-size: 12px; color: var(--good); }
.w-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.mm-record { margin-top: 10px; font-size: 12px; color: var(--text); }
.w-chip { font-size: 11px; padding: 2px 8px; border-radius: 999px;
  background: var(--panel); border: 1px solid var(--line); color: var(--text); }
.w-chip.up { color: var(--accent); border-color: rgba(240,136,62,0.4); }
.w-chip.down { color: var(--accent-2); border-color: rgba(88,166,255,0.4); }
.w-chip.muted { color: var(--muted); }

/* Today — the cross-sport value home (the front door) */
.today-head { margin: 2px 0 14px; }
.today-head h2 { margin: 0; font-size: 19px; }
.today-head .today-sub { font-size: 13px; font-weight: 400; color: var(--muted);
  margin-left: 8px; }
.today-meta { color: var(--muted); font-size: 12px; margin-top: 4px; }
.today-list { display: flex; flex-direction: column; gap: 8px; }
.today-row {
  display: grid; align-items: center; gap: 14px; width: 100%; text-align: left;
  grid-template-columns: 28px minmax(0, 1fr) auto auto;
  background: var(--panel-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 11px 14px; cursor: pointer;
  color: var(--text); font: inherit; transition: border-color 0.12s;
}
.today-row:hover { border-color: var(--accent-2); }
.today-rank { color: var(--muted); font-size: 13px; font-weight: 700;
  text-align: center; }
.today-main { min-width: 0; }
.today-main .name { display: inline-flex; align-items: center; }
.today-main .detail-line { display: block; white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; }
.today-tags { display: flex; flex-direction: column; gap: 3px; align-items: flex-end;
  font-size: 11px; text-align: right; }
.today-nums { display: flex; gap: 16px; }
.today-num { display: flex; flex-direction: column; align-items: flex-end;
  font-size: 13px; min-width: 46px; }
.today-num i { color: var(--muted); font-size: 11px; font-style: normal;
  text-transform: uppercase; letter-spacing: 0.04em; margin-top: 2px; }

/* inline glossary — hover any Today column label for a plain-language definition */
.today-num i[data-tip] { position: relative; cursor: help;
  border-bottom: 1px dotted var(--muted); }
.today-num i[data-tip]:hover { color: var(--text); }
.today-num i[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute; bottom: calc(100% + 6px); right: 0; z-index: 40;
  width: max-content; max-width: 220px; text-align: left;
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 10px;
  font-size: 11px; font-style: normal; font-weight: 400; line-height: 1.45;
  text-transform: none; letter-spacing: normal;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45); pointer-events: none;
}

/* first-run coach mark on Today (dismissible, remembered in localStorage) */
.coach { display: flex; gap: 16px; align-items: flex-start;
  justify-content: space-between; margin: 2px 0 14px; padding: 12px 16px;
  background: var(--panel); border: 1px solid var(--line);
  border-left: 3px solid var(--accent-2); border-radius: var(--radius); }
.coach-txt { font-size: 13px; color: var(--text); line-height: 1.5;
  max-width: 780px; }
.coach-txt b { color: var(--text); font-weight: 700; }
.coach-x { flex-shrink: 0; background: var(--panel-2); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px; padding: 7px 14px;
  cursor: pointer; font-size: 12px; font-weight: 600; }
.coach-x:hover { border-color: var(--accent-2); }

@media (max-width: 640px) {
  .today-row { grid-template-columns: 22px 1fr; }
  .today-tags, .today-nums { grid-column: 2; flex-direction: row; align-items: center; }
}

/* Discover — the public model gallery (ACCOUNTS.md Phase 4) */
.disc-row { text-decoration: none; grid-template-columns: 28px minmax(0, 1fr) auto; }
.disc-row .today-num.muted { color: var(--muted); }

/* ledger tab */
.ledger-day .day-line { font-size: 14px; font-weight: 600; font-variant-numeric: tabular-nums; }
.led-model { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); margin-top: 8px; overflow: hidden; }
.led-model-h { display: flex; gap: 10px; align-items: baseline; padding: 10px 14px; cursor: pointer; flex-wrap: wrap; }
.led-model-h:hover { background: var(--panel-2); }
.led-line { font-size: 13px; font-variant-numeric: tabular-nums; }
.led-model .table-wrap { padding: 0 14px 12px; }
.led-table { min-width: 520px; }
.pending-row { display: flex; gap: 12px; align-items: center; padding: 9px 14px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); margin-top: 8px; flex-wrap: wrap; }
.pending-row .p-date { color: var(--muted); font-variant-numeric: tabular-nums; }
.led-more { margin-top: 16px; text-align: center; }
.led-more .reset-btn { margin-left: 0; }
.pending-row .pend-btns { margin-left: auto; display: flex; gap: 8px; }
.pending-row .pend-btns .reset-btn { margin-left: 0; }
.pending-row.open { border-bottom-left-radius: 0; border-bottom-right-radius: 0; border-bottom: 0; }
.settle-btn.active { border-color: var(--accent); color: var(--accent); }

/* pending triage: actionable boards grouped first, auto-settling below */
.pend-sub + .pend-sub { margin-top: 22px; }
.pend-sub-h { font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em;
  font-weight: 700; margin: 6px 0 8px; display: flex; align-items: center; gap: 8px; }
.pend-sub-h.needs { color: var(--accent); }
.pend-sub-h.needs::before { content: ""; width: 8px; height: 8px; border-radius: 999px;
  background: var(--accent); flex-shrink: 0; }
.pend-sub-h.auto { color: var(--muted); }
.pend-clear { color: var(--good); font-size: 13px; margin: 6px 0 8px; }
.pend-sub.auto-rows .pending-row { opacity: 0.82; }

/* one primary action per row: Settle is filled; Fetch/plays stay quiet */
.pend-btns .settle-btn { background: var(--accent); color: #1a1206; border-color: transparent; }
.pend-btns .settle-btn:hover { filter: brightness(1.08); border-color: transparent; }
.pend-btns .settle-btn.active { background: var(--panel-2); color: var(--text); border-color: var(--line); }
.pend-btns .fetch-btn { color: var(--muted); }
.pend-btns .fetch-btn:hover { color: var(--text); border-color: var(--accent-2); }

/* click-settle form (P0.5) */
.settle-form { background: var(--panel); border: 1px solid var(--line); border-top: 1px dashed var(--line); border-radius: 0 0 var(--radius) var(--radius); padding: 12px 14px; }
.settle-race { display: flex; gap: 12px; align-items: flex-start; padding: 8px 0; border-bottom: 1px solid #1a2027; flex-wrap: wrap; }
.settle-race:last-of-type { border-bottom: 0; }
.settle-race .flabel { font-size: 12px; color: var(--muted); min-width: 110px; padding-top: 6px; }
.chip-field { display: flex; gap: 8px; flex-wrap: wrap; flex: 1; }
.horse-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 999px; padding: 5px 6px 5px 12px; font-size: 12px; cursor: pointer; user-select: none; }
.horse-chip:hover { border-color: var(--accent-2); }
.horse-chip.win { border-color: var(--good); background: var(--good-bg); font-weight: 700; }
.horse-chip.scr { opacity: 0.45; text-decoration: line-through; cursor: default; }
.scr-btn { background: transparent; border: 0; color: var(--muted); font-size: 11px; cursor: pointer; padding: 0 4px; border-radius: 999px; }
.scr-btn:hover { color: var(--bad); }
.horse-chip.scr .scr-btn { color: var(--bad); }
.payout-in { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 8px; padding: 6px 10px; font-size: 12px; width: 150px; }
.score-in { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 8px; padding: 6px 8px; font-size: 13px; width: 56px; text-align: center; }
.settle-actions { display: flex; gap: 12px; align-items: center; padding-top: 10px; flex-wrap: wrap; }
.settle-actions .reset-btn { margin-left: 0; }

/* bet slip (Bet Slip v1) */
.you-line { color: var(--accent-2); font-size: 12px; font-weight: 600; font-variant-numeric: tabular-nums; }
.pend-plays { background: var(--panel); border: 1px solid var(--line); border-top: 1px dashed var(--line); border-radius: 0 0 var(--radius) var(--radius); padding: 6px 14px 10px; }
.pend-play { display: flex; gap: 12px; align-items: center; padding: 7px 0; border-bottom: 1px solid #1a2027; flex-wrap: wrap; }
.pend-play:last-of-type { border-bottom: 0; }
.pend-play .name { min-width: 160px; }
.pend-play .bet-btn, .pend-play .bet-form, .pend-play .you-line { margin-left: auto; }
.bet-form { display: inline-flex; gap: 6px; align-items: center; font-size: 12px; color: var(--muted); }
.bet-stake { width: 70px; }
.bet-price { width: 80px; }
.bet-stake, .bet-price { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 8px; padding: 6px 8px; font-size: 13px; text-align: center; }
.bet-form .reset-btn { margin-left: 0; }

/* performance tab */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 12px; }
.stat-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px 16px; }
.stat-label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }
.stat-value { font-size: 19px; font-weight: 700; margin-top: 6px; font-variant-numeric: tabular-nums; }
.stat-hint { color: var(--muted); font-size: 12px; margin-top: 4px; line-height: 1.4; }
.perf-note { color: var(--muted); font-size: 13px; line-height: 1.6; max-width: 720px; }

.table-wrap { overflow-x: auto; border-radius: var(--radius); }
table { width: 100%; border-collapse: collapse; min-width: 720px; }
thead th {
  position: sticky; top: 0; background: var(--bg);
  text-align: right; color: var(--muted); font-weight: 600; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.04em;
  padding: 10px 12px; border-bottom: 1px solid var(--line); cursor: pointer; white-space: nowrap;
}
thead th.left { text-align: left; }
thead th:hover { color: var(--text); }
thead th .arrow { color: var(--accent); margin-left: 4px; }

/* plain-language column explainers on hover (sticky th anchors the bubble) */
th[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  z-index: 30;
  width: max-content;
  max-width: 230px;
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 11px;
  font-weight: 400;
  line-height: 1.45;
  text-transform: none;
  letter-spacing: normal;
  text-align: left;
  white-space: normal;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
  pointer-events: none;
}
th.left[data-tip]:hover::after { left: 0; right: auto; }

tbody td { padding: 9px 12px; border-bottom: 1px solid #1a2027; text-align: right; white-space: nowrap; }
tbody td.left { text-align: left; }
tbody tr:hover { background: var(--panel); }
tbody tr.expandable { cursor: pointer; }

.rank { color: var(--muted); font-variant-numeric: tabular-nums; }
.name { font-weight: 600; }
.spot { color: var(--muted); font-weight: 400; font-size: 12px; }
.muted { color: var(--muted); }
.mono { font-variant-numeric: tabular-nums; }
.tag { font-size: 11px; padding: 1px 6px; border-radius: 6px; background: var(--panel-2); color: var(--muted); border: 1px solid var(--line); margin-left: 6px; }

.pill { font-variant-numeric: tabular-nums; font-weight: 700; padding: 3px 8px; border-radius: 6px; border: 1px solid var(--line); }
.odds { font-variant-numeric: tabular-nums; color: var(--accent-2); font-weight: 600; }

/* decision columns (Edge / EV / Kelly) — divided from the inputs that feed them
   so the eye lands on what you'd act on */
th.decision-start, td.decision-start { border-left: 1px solid var(--line); }
.edge-cell { display: inline-flex; flex-direction: column; align-items: flex-end; gap: 3px; }
.edge-bar { width: 54px; height: 4px; border-radius: 2px; background: var(--line);
  overflow: hidden; position: relative; }
.edge-bar i { position: absolute; top: 0; bottom: 0; right: 0; }
.edge-bar i.pos { background: var(--good); }
.edge-bar i.neg { background: var(--bad); }
.ev-pos { color: var(--good); font-weight: 700; }
.ev-neg { color: var(--bad); }
.book { color: var(--muted); font-size: 12px; }

/* factor detail row */
.detail td { background: var(--panel); border-bottom: 1px solid var(--line); padding: 12px 16px; }
.factors { display: flex; gap: 18px; flex-wrap: wrap; }
.factor { display: flex; flex-direction: column; gap: 4px; min-width: 96px; }
.factor .flabel { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.03em; }
.factor .fval { font-variant-numeric: tabular-nums; font-weight: 600; }
.factor .fbar { height: 5px; border-radius: 3px; background: var(--line); overflow: hidden; position: relative; }
.factor .fbar i { position: absolute; top: 0; bottom: 0; }
.meta { color: var(--muted); margin-top: 10px; font-size: 12px; }

footer { color: var(--muted); font-size: 12px; padding: 18px 28px 10px; border-top: 1px solid var(--line); line-height: 1.6; }
#legal { color: var(--muted); font-size: 12px; padding: 0 28px 40px; line-height: 1.6; }
#legal .disclaimer { max-width: 760px; margin: 0; }
#legal .disclaimer strong { color: var(--text); }
#legal .legal-links { margin: 8px 0 0; }
#legal .legal-links a { color: var(--accent-2); text-decoration: none; }
#legal .legal-links a:hover { text-decoration: underline; }

/* ---------- Systems / "angles" ---------- */
.sys-card .mm-actions .reset-btn:first-child { border-color: var(--accent); color: var(--accent); }
.sys-rule-list { display: block; }
.sys-rule-sum { margin: 3px 0; font-size: 12px; line-height: 1.5; }
.sys-results { margin-top: 12px; border-top: 1px solid var(--line); padding-top: 10px; }
.sys-running { font-style: italic; }
.sys-board { margin-bottom: 12px; }
.sys-board h4 { margin: 4px 0 6px; font-size: 13px; color: var(--muted); font-weight: 600; }
.sys-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.sys-table th { text-align: left; color: var(--muted); font-weight: 600; padding: 4px 8px; border-bottom: 1px solid var(--line); }
.sys-table td { padding: 4px 8px; border-bottom: 1px solid var(--line); }
.sys-table td.num, .sys-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.sys-seg-line { margin: 4px 0; font-size: 12px; }
.sys-cov { font-size: 12px; margin-bottom: 6px; }
.sys-overall { font-size: 13px; margin-bottom: 8px; }
.sys-slice { margin-top: 8px; }
.sys-slice h4 { margin: 4px 0; font-size: 12px; color: var(--muted); font-weight: 600; }
.sys-slice-row { font-size: 12px; margin: 3px 0; }

/* editor */
.sys-form { display: flex; flex-direction: column; gap: 12px; max-width: 860px; }
.sys-field-row { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); }

/* hover ⓘ help next to a builder label (reuses the data-tip tooltip idea) */
.sys-info { position: relative; cursor: help; color: var(--muted); font-size: 12px;
  line-height: 1; flex: none; }
.sys-info:hover, .sys-info:focus { color: var(--accent-2); outline: none; }
.sys-info:hover::after, .sys-info:focus::after {
  content: attr(data-tip);
  position: absolute; bottom: calc(100% + 6px); left: 0; z-index: 50;
  width: max-content; max-width: 260px; text-align: left;
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 10px;
  font-size: 11px; font-weight: 400; line-height: 1.45;
  text-transform: none; letter-spacing: normal;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45); pointer-events: none; white-space: normal;
}
.sys-rule-h .sys-info, .sys-cond .sys-info { color: var(--muted); }
.sys-field-row input[type=text], .sys-field-row select { flex: 1; }
.sys-form input[type=text], .sys-form select {
  background: var(--bg); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 6px 10px; font-size: 13px; font-family: inherit;
}
.sys-rules { display: flex; flex-direction: column; gap: 10px; }
.sys-rule { border: 1px solid var(--line); border-radius: var(--radius); padding: 10px 12px; background: var(--bg); }
.sys-rule-h { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; font-size: 12px; color: var(--muted); }
.sys-rule-h label { display: flex; align-items: center; gap: 5px; }
.sys-rule-h .reset-btn { margin-left: auto; }
.sys-cond { display: flex; align-items: center; gap: 8px; margin: 6px 0; flex-wrap: wrap; }
.sys-cond .sys-val { width: 130px; }
.sys-cond .reset-btn { margin-left: 0; padding: 4px 9px; }
.sys-join { min-width: 32px; font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--accent-2); }
.sys-cond-add { margin-left: 0; margin-top: 4px; }
.sys-save-row { display: flex; align-items: center; gap: 12px; }
.sys-save-row .reset-btn { margin-left: 0; }
.sys-save-btn { background: var(--accent); color: #1b1205; border: none; border-radius: 8px; padding: 8px 18px; cursor: pointer; font-size: 13px; font-weight: 700; }
.sys-save-btn:hover { filter: brightness(1.08); }

@media (max-width: 640px) {
  header, .bar, main, footer, #legal { padding-left: 14px; padding-right: 14px; }
  .hide-sm { display: none; }
  .sys-cond { gap: 6px; }
}
