/* ============================================================================
   PARLAY ORACLE — "The Almanac of Edges"
   Editorial divination almanac × racing-form odds sheet.
   Parchment + oxblood + antique gold. Fraunces / Newsreader / Spline Sans Mono.
   ========================================================================== */

:root {
  /* night vellum & parchment ink (the Oracle's nocturnal edition) */
  --paper:    #17130b;
  --paper-2:  #1f1a10;
  --paper-3:  #2a2316;
  --ink:      #ece3cd;       /* cream text */
  --ink-soft: #c2b491;
  --faint:    #877a5c;
  --rule:     #4d4029;
  --rule-soft:#3a3020;
  --ink-line: #39301d;       /* unfilled side of the orb */

  /* foil & accents — brightened for legibility on dark */
  --gold:      #c89a46;
  --gold-deep: #e2bb63;      /* used as gold TEXT — must be bright on dark */
  --gold-glow: #e7c46b;
  --oxblood:   #cb5040;
  --oxblood-2: #d96552;
  --verdigris: #5fa08f;

  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --display: "Fraunces", Georgia, serif;
  --mono: "Spline Sans Mono", ui-monospace, Menlo, monospace;

  --maxw: 1280px;
  --shadow: 0 24px 54px -26px rgba(0, 0, 0, .78);
  --shadow-sm: 0 12px 28px -18px rgba(0, 0, 0, .7);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
html { -webkit-text-size-adjust: 100%; color-scheme: dark; } /* genuinely-dark design — declare it so force-dark leaves it alone */

body {
  color: var(--ink);
  background: var(--paper);
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.55;
  font-optical-sizing: auto;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  position: relative;
}

/* warm vignette + faint astrolabe watermark, fixed behind everything */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(125% 85% at 50% -12%, #2a2110 0%, var(--paper) 46%, #0c0905 100%),
    var(--paper);
}
body::after {
  content: "";
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  opacity: .4; mix-blend-mode: screen;
  background-image:
    /* astrolabe: concentric rings + ticks, top-right */
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='520' height='520' viewBox='0 0 520 520'%3E%3Cg fill='none' stroke='%23b07d2a' stroke-width='1' opacity='0.5'%3E%3Ccircle cx='260' cy='260' r='250'/%3E%3Ccircle cx='260' cy='260' r='205'/%3E%3Ccircle cx='260' cy='260' r='150'/%3E%3Ccircle cx='260' cy='260' r='96'/%3E%3Ccircle cx='260' cy='260' r='44'/%3C/g%3E%3Cg stroke='%23b07d2a' stroke-width='1' opacity='0.45'%3E%3Cg transform='translate(260,260)'%3E%3Cline x1='0' y1='-250' x2='0' y2='-205'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(30)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(60)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(90)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(120)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(150)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(180)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(210)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(240)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(270)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(300)'/%3E%3Cline x1='0' y1='-250' x2='0' y2='-205' transform='rotate(330)'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    /* fine grain */
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat, repeat;
  background-position: right -120px top -110px, 0 0;
  background-size: 620px 620px, 160px 160px;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }
em { font-style: italic; }

#app { max-width: var(--maxw); margin: 0 auto; padding: 0 26px 80px; }

/* small-caps label utility look */
.sc { font-variant-caps: all-small-caps; letter-spacing: .14em; }

/* ── MASTHEAD ──────────────────────────────────────────────────────────── */
.masthead { padding-top: 22px; margin-bottom: 22px; }
.mast-band {
  display: flex; justify-content: space-between; align-items: baseline;
  font-variant-caps: all-small-caps; letter-spacing: .12em;
  font-size: 12.5px; color: var(--gold-deep);
  padding-bottom: 8px; border-bottom: 1px solid var(--ink);
}
.mast-band span:last-child { font-style: italic; color: var(--ink-soft); letter-spacing: .04em; font-variant-caps: normal; }
.mast-name {
  display: flex; align-items: center; justify-content: center; gap: 26px;
  border-bottom: 3px double var(--ink); padding: 14px 0 16px;
}
.nameplate {
  font-family: var(--display); font-weight: 900;
  font-variation-settings: "opsz" 144, "SOFT" 0, "WONK" 1;
  font-size: clamp(2.6rem, 1.2rem + 6vw, 5.6rem);
  line-height: .9; margin: 0; letter-spacing: -.01em;
  text-align: center; color: var(--ink);
}
.nameplate em { font-style: italic; color: var(--oxblood); font-variation-settings: "opsz" 144, "WONK" 1; }
.mast-name .orn { font-size: clamp(1rem, .6rem + 1.6vw, 1.8rem); color: var(--gold); }
.mast-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding-top: 9px; flex-wrap: wrap;
}

.statusbar {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--mono); font-size: 12px; color: var(--ink-soft);
  font-variant-caps: all-small-caps; letter-spacing: .06em;
}
.pulse { width: 7px; height: 7px; border-radius: 50%; background: var(--oxblood); display: inline-block; }
.pulse.ok { animation: beat 2.6s infinite; }
.pulse.updating { background: var(--gold); animation: beat 1s infinite; }
.pulse.err { background: var(--oxblood); }
@keyframes beat { 0% { box-shadow: 0 0 0 0 rgba(154, 43, 30, .5); } 70% { box-shadow: 0 0 0 7px rgba(154, 43, 30, 0); } 100% { box-shadow: 0 0 0 0 rgba(154, 43, 30, 0); } }
.refresh { font-family: var(--mono); font-size: 11px; color: var(--gold-deep); border: 1px solid var(--rule); padding: 2px 9px; border-radius: 2px; font-variant-caps: all-small-caps; letter-spacing: .08em; }
.refresh:hover { border-color: var(--gold); color: var(--oxblood); }

.view-toggle {
  font-family: var(--display); font-weight: 600; font-size: 15px; font-style: italic;
  color: var(--ink); border: 1px solid var(--ink); padding: 6px 18px; border-radius: 2px;
  background: var(--paper); transition: .18s;
}
.view-toggle:hover { background: var(--ink); color: var(--paper); }
.view-toggle.active { background: var(--oxblood); color: var(--paper); border-color: var(--oxblood); }

/* ── SECTION TABS (editions) ───────────────────────────────────────────── */
.tabs { display: flex; gap: 0; margin-bottom: 18px; border-bottom: 1px solid var(--rule); flex-wrap: wrap; }
.tab {
  display: inline-flex; align-items: center; gap: 8px;
  font-variant-caps: all-small-caps; letter-spacing: .1em; font-size: 16px; font-weight: 500;
  color: var(--faint); padding: 9px 18px; border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: .15s;
}
.tab:hover { color: var(--ink); }
.tab.active { color: var(--oxblood); border-bottom-color: var(--oxblood); }
.tab .count { font-family: var(--mono); font-size: 11px; color: var(--gold-deep); }

/* ── THE WIRE (news ticker) ────────────────────────────────────────────── */
.news { display: flex; align-items: stretch; gap: 0; margin-bottom: 22px; border: 1px solid var(--ink); background: var(--paper-2); overflow: hidden; }
.news-label {
  display: flex; align-items: center; white-space: nowrap;
  font-family: var(--display); font-weight: 700; font-style: italic; font-size: 14px;
  color: var(--paper); background: var(--ink); padding: 8px 16px; letter-spacing: .03em;
}
.ticker { overflow: hidden; flex: 1; display: flex; align-items: center; padding: 0 14px; }
.ticker-track { display: inline-flex; gap: 16px; align-items: center; white-space: nowrap; animation: scroll 64s linear infinite; }
.ticker:hover .ticker-track { animation-play-state: paused; }
.news-item { font-size: 14px; color: var(--ink-soft); font-style: italic; }
.news-item:hover { color: var(--oxblood); }
.news .dot { color: var(--gold); }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── LAYOUT ────────────────────────────────────────────────────────────── */
.layout { display: grid; grid-template-columns: 1fr 332px; gap: 26px; align-items: start; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 20px; }
.empty {
  padding: 70px 24px; text-align: center; color: var(--ink-soft);
  border: 1px solid var(--rule); background: var(--paper-2);
  font-style: italic; font-size: 17px;
}
.empty small { display: block; margin-top: 8px; color: var(--faint); font-style: normal; font-size: 13px; }

/* ── GAME CARD (almanac entry) ─────────────────────────────────────────── */
.card {
  background: var(--paper-2); border: 1px solid var(--ink); padding: 16px 16px 14px;
  box-shadow: var(--shadow-sm); position: relative;
  animation: rise .5s both;
}
.card::before { content: ""; position: absolute; left: 6px; right: 6px; top: 5px; height: 1px; background: var(--rule); }
.grid .card:nth-child(2) { animation-delay: .04s; }
.grid .card:nth-child(3) { animation-delay: .08s; }
.grid .card:nth-child(4) { animation-delay: .12s; }
.grid .card:nth-child(n+5) { animation-delay: .16s; }
@keyframes rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.chip { font-family: var(--mono); font-size: 10.5px; font-variant-caps: all-small-caps; letter-spacing: .08em; padding: 2px 7px; }
.chip.pre { color: var(--ink-soft); border: 1px solid var(--rule); }
.chip.live { color: var(--paper); background: var(--oxblood); animation: blink 1.7s infinite; }
.chip.final { color: var(--faint); border: 1px dashed var(--rule); }
@keyframes blink { 50% { opacity: .6; } }
.venue { font-size: 11.5px; color: var(--faint); font-style: italic; }

.teams { display: flex; flex-direction: column; gap: 8px; }
.team { display: grid; grid-template-columns: 38px 1fr auto; align-items: center; gap: 12px; }
.logo { border-radius: 50%; object-fit: contain; background: #ece3cd; padding: 3px; box-shadow: inset 0 0 0 1px var(--gold), 0 1px 5px rgba(0, 0, 0, .55); } /* team marks sit on a gold-rimmed cream coin */
.logo-fallback { display: inline-flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 10px; font-weight: 700; color: var(--paper); border-radius: 50%; }
.tinfo { display: flex; flex-direction: column; line-height: 1.2; overflow: hidden; }
.tinfo b { font-family: var(--display); font-weight: 600; font-size: 17px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tinfo small { color: var(--faint); font-family: var(--mono); font-size: 11px; }
.twin { font-family: var(--mono); font-weight: 500; font-size: 14px; color: var(--ink-soft); }
.team.home .twin { color: var(--gold-deep); }

/* oracle orb — the signature element: a gold reading of the favored side */
.orb-wrap { display: flex; flex-direction: column; align-items: center; gap: 6px; margin: 14px 0 10px; }
.orb {
  --p: 50;
  width: 82px; height: 82px; border-radius: 50%;
  background: conic-gradient(from 180deg, var(--gold) calc(var(--p) * 1%), var(--ink-line) 0);
  display: grid; place-items: center; position: relative;
  box-shadow: inset 0 0 0 7px var(--paper-2), 0 0 0 1px var(--ink), 0 8px 18px -10px rgba(140, 94, 27, .6);
}
.orb::after { content: ""; position: absolute; inset: 13px; border-radius: 50%; box-shadow: inset 0 0 0 1px var(--rule); }
.orb-val { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 90, "WONK" 1; font-size: 23px; line-height: 1; color: var(--ink); z-index: 1; }
.orb-val i { font-style: normal; font-size: 12px; color: var(--gold-deep); }
.orb-cap { font-variant-caps: all-small-caps; letter-spacing: .1em; font-size: 12px; color: var(--ink-soft); }
.orb-cap b { color: var(--oxblood); font-weight: 600; }

.score { display: block; font-family: var(--mono); font-weight: 600; font-size: 19px; text-align: center; margin: 4px 0 10px; }

.breakdown {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: baseline;
  font-family: var(--mono); font-size: 11px; color: var(--faint);
  font-variant-caps: all-small-caps; letter-spacing: .05em;
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  padding: 7px 0; margin-bottom: 11px;
}
.breakdown .blend { color: var(--gold-deep); margin-left: auto; font-weight: 600; }
.breakdown .book { color: var(--verdigris); }

/* ── LEGS (ledger rows) ────────────────────────────────────────────────── */
.legs { display: flex; flex-direction: column; }
.leg {
  display: flex; align-items: center; gap: 10px; width: 100%; text-align: left;
  padding: 9px 4px; border-bottom: 1px dotted var(--rule); transition: .12s;
}
.leg:last-child { border-bottom: 0; }
.leg:hover { background: var(--paper-3); padding-left: 8px; }
.leg.added { background: rgba(176, 125, 42, .12); box-shadow: inset 3px 0 0 var(--gold); }
.leg.known { cursor: default; opacity: .92; }
.leg.known:hover { background: none; padding-left: 4px; }
.leg-label { font-size: 14px; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.leg-prob { font-family: var(--mono); font-size: 13px; font-weight: 600; }
.leg-price { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); }
.leg-add { font-family: var(--display); font-weight: 700; font-size: 16px; color: var(--gold-deep); width: 16px; text-align: center; }
.leg.added .leg-add { color: var(--oxblood); }

.tag {
  font-family: var(--mono); font-size: 8.5px; font-weight: 600; letter-spacing: .1em;
  padding: 2px 5px; border-radius: 1px; text-transform: uppercase; white-space: nowrap;
}
.tag-model  { color: var(--gold-deep); border: 1px solid var(--gold); }
.tag-market { color: var(--verdigris); border: 1px solid var(--verdigris); }
.tag-known  { color: var(--faint); border: 1px dashed var(--rule); }

.edge { font-family: var(--mono); font-size: 11px; font-weight: 700; }
.edge.pos { color: var(--gold-deep); }
.edge.neg { color: var(--oxblood); }

/* ── THE TICKET (parlay slip) ──────────────────────────────────────────── */
.slip {
  position: sticky; top: 16px; background: var(--paper); border: 1px solid var(--ink);
  box-shadow: var(--shadow); padding: 0;
}
.slip::before {
  content: ""; display: block; height: 9px;
  background:
    radial-gradient(circle at 6px 9px, transparent 4px, var(--paper) 4px) 0 0 / 14px 9px repeat-x,
    var(--ink);
}
.slip h2 {
  font-family: var(--display); font-weight: 700; font-size: 21px; font-style: italic;
  margin: 0; padding: 14px 16px 6px; text-align: center; letter-spacing: -.01em;
  border-bottom: 1px solid var(--rule);
}
.slip > :not(.slip-sum):not(h2) { padding-left: 16px; padding-right: 16px; }
.slip-empty { color: var(--ink-soft); font-size: 14px; line-height: 1.65; font-style: italic; padding: 14px 16px 4px; }
.slip-legs { list-style: none; margin: 12px 0; padding: 0 16px; display: flex; flex-direction: column; }
.slip-legs li { display: grid; grid-template-columns: auto auto 1fr auto auto; align-items: center; gap: 8px; padding: 8px 0; border-bottom: 1px dotted var(--rule); font-size: 13px; }
.sl-game { font-family: var(--mono); font-size: 10.5px; color: var(--faint); }
.sl-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sl-price { font-family: var(--mono); color: var(--ink-soft); }
.sl-x { color: var(--faint); font-size: 12px; }
.sl-x:hover { color: var(--oxblood); }

.slip-sum { margin: 4px 16px 0; padding: 12px 0; border-top: 2px solid var(--ink); }
.srow { display: flex; justify-content: space-between; align-items: baseline; font-size: 13.5px; padding: 4px 0; color: var(--ink-soft); }
.srow span { font-variant-caps: all-small-caps; letter-spacing: .05em; }
.srow b { font-family: var(--mono); color: var(--ink); font-weight: 600; }
.srow.ev.pos b { color: var(--gold-deep); }
.srow.ev.neg b { color: var(--oxblood); }
.srow.stake { border-top: 1px dotted var(--rule); margin-top: 6px; padding-top: 9px; }
.srow.stake b { font-size: 15px; }
.verdict {
  text-align: center; font-family: var(--display); font-style: italic; font-weight: 700;
  font-size: 14px; letter-spacing: .02em; padding: 9px; margin: 10px 0; border: 1px solid;
}
.verdict.pos { color: var(--gold-deep); border-color: var(--gold); background: rgba(176, 125, 42, .1); }
.verdict.neg { color: var(--oxblood); border-color: var(--oxblood); background: rgba(154, 43, 30, .07); }
.clear-slip { display: block; width: calc(100% - 32px); margin: 0 16px 14px; border: 1px solid var(--rule); padding: 7px; color: var(--ink-soft); font-family: var(--mono); font-size: 11px; font-variant-caps: all-small-caps; letter-spacing: .08em; }
.clear-slip:hover { color: var(--oxblood); border-color: var(--oxblood); }
.disclaimer { font-size: 11px; color: var(--faint); line-height: 1.55; font-style: italic; padding: 0 16px 16px; }

/* ── THE LEDGER (accuracy) ─────────────────────────────────────────────── */
.acc { display: flex; flex-direction: column; gap: 22px; }
.acc-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 0; border: 1px solid var(--ink); background: var(--paper-2); }
.metric { padding: 18px 20px; border-right: 1px solid var(--rule); display: flex; flex-direction: column; gap: 5px; }
.metric:last-child { border-right: 0; }
.metric .m-label { font-variant-caps: all-small-caps; letter-spacing: .12em; font-size: 12.5px; color: var(--ink-soft); }
.metric .m-val { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 144, "WONK" 1; font-size: 42px; line-height: .95; color: var(--ink); }
.metric .m-sub { font-family: var(--mono); font-size: 11px; color: var(--faint); }
.metric.pos .m-val { color: var(--gold-deep); }
.metric.neg .m-val { color: var(--oxblood); }

.acc-block { border: 1px solid var(--rule); background: var(--paper-2); padding: 16px 20px; }
.acc-block h3 { font-family: var(--display); font-weight: 600; font-style: italic; font-size: 18px; margin: 0 0 12px; }
.acc-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.acc-table th { text-align: left; font-variant-caps: all-small-caps; letter-spacing: .08em; font-weight: 600; font-size: 12.5px; color: var(--gold-deep); padding: 6px 8px; border-bottom: 1.5px solid var(--ink); }
.acc-table td { padding: 9px 8px; border-bottom: 1px dotted var(--rule); font-family: var(--mono); font-size: 13px; }
.acc-table tr:last-child td { border-bottom: 0; }
.acc-table td:first-child { font-family: var(--serif); }

.acc-sports { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; }
.acc-sport { border: 1px solid var(--rule); padding: 13px; display: flex; flex-direction: column; gap: 3px; background: var(--paper); }
.acc-sport span { font-variant-caps: all-small-caps; letter-spacing: .06em; font-size: 14px; }
.acc-sport b { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 90; font-size: 26px; }
.acc-sport small { font-family: var(--mono); font-size: 11px; color: var(--faint); }

.acc-recent { list-style: none; margin: 0; padding: 0; }
.acc-recent li { display: grid; grid-template-columns: auto 1fr auto auto auto; align-items: center; gap: 12px; padding: 9px 2px; border-bottom: 1px dotted var(--rule); font-size: 13.5px; }
.acc-recent li:last-child { border-bottom: 0; }
.acc-recent .rs { font-family: var(--display); font-weight: 900; }
.acc-recent .hit .rs { color: var(--gold-deep); }
.acc-recent .miss .rs { color: var(--oxblood); }
.acc-recent .rg { font-weight: 500; }
.acc-recent .rp { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); }
.acc-recent .rw { font-family: var(--mono); font-size: 12px; color: var(--faint); }
.acc-recent .rmode { font-family: var(--mono); font-size: 8.5px; font-variant-caps: all-small-caps; letter-spacing: .06em; color: var(--verdigris); border: 1px solid var(--verdigris); padding: 1px 4px; }

/* ── TODAY'S THREE (Definite / Maybe / Crazy) ──────────────────────────── */
.three { margin-bottom: 24px; }
.three-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; border-bottom: 1px solid var(--ink); padding-bottom: 7px; margin-bottom: 14px; }
.three-head h2 { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 90, "WONK" 1; font-size: 24px; margin: 0; }
.three-sub { font-family: var(--mono); font-size: 11.5px; font-variant-caps: all-small-caps; letter-spacing: .06em; color: var(--gold-deep); }
.three-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(225px, 1fr)); gap: 16px; }
.three-card { border: 1px solid var(--rule); background: linear-gradient(180deg, var(--paper-2), var(--paper)); padding: 15px 14px 14px; display: flex; flex-direction: column; box-shadow: var(--shadow-sm); }
.three-card.def { border-top: 3px solid var(--gold); }
.three-card.maybe { border-top: 3px solid var(--verdigris); }
.three-card.crazy { border-top: 3px solid var(--oxblood); }
.tc-head { display: flex; flex-direction: column; gap: 1px; margin-bottom: 11px; }
.tier-name { font-family: var(--display); font-weight: 700; font-style: italic; font-size: 20px; }
.three-card.def .tier-name { color: var(--gold-deep); }
.three-card.maybe .tier-name { color: var(--verdigris); }
.three-card.crazy .tier-name { color: var(--oxblood); }
.tier-tag { font-size: 11.5px; color: var(--faint); font-style: italic; }
.tier-payout { font-family: var(--display); font-size: 15px; color: var(--ink-soft); display: flex; align-items: baseline; gap: 6px; }
.tier-payout .arr { color: var(--faint); }
.tier-payout b { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 90, "WONK" 1; font-size: 30px; color: var(--ink); line-height: 1; }
.three-card.def .tier-payout b { color: var(--gold-deep); }
.three-card.crazy .tier-payout b { color: var(--oxblood); }
.tier-meta { display: flex; align-items: baseline; gap: 10px; font-family: var(--mono); font-size: 12px; margin: 7px 0 10px; padding-bottom: 9px; border-bottom: 1px dotted var(--rule); }
.tier-odds { font-weight: 600; color: var(--ink); }
.tier-chance { color: var(--faint); margin-left: auto; }
.tier-legs { list-style: none; margin: 0 0 10px; padding: 0; display: flex; flex-direction: column; gap: 4px; max-height: 176px; overflow: auto; }
.tier-legs li { display: flex; align-items: baseline; gap: 7px; font-size: 12.5px; }
.tl-label { white-space: nowrap; }
.tl-game { font-family: var(--mono); font-size: 10px; color: var(--faint); }
.tl-odds { font-family: var(--mono); font-size: 11px; color: var(--ink-soft); margin-left: auto; }
.tier-cap { font-size: 11.5px; color: var(--faint); font-style: italic; margin: 0 0 12px; line-height: 1.45; }
.tier-load { margin-top: auto; font-family: var(--display); font-style: italic; font-weight: 600; font-size: 13.5px; padding: 9px; border: 1px solid var(--ink); color: var(--ink); background: var(--paper); transition: .15s; }
.three-card.def .tier-load:hover { background: var(--gold); border-color: var(--gold); color: #1a1206; }
.three-card.maybe .tier-load:hover { background: var(--verdigris); border-color: var(--verdigris); color: #07140f; }
.three-card.crazy .tier-load:hover { background: var(--oxblood); border-color: var(--oxblood); color: var(--paper); }

.howto { margin-top: 16px; border: 1px solid var(--rule); background: var(--paper-2); padding: 0 16px; }
.howto summary { cursor: pointer; padding: 13px 0; font-family: var(--display); font-style: italic; font-weight: 600; font-size: 14.5px; color: var(--gold-deep); list-style: none; }
.howto summary::-webkit-details-marker { display: none; }
.howto[open] summary { border-bottom: 1px dotted var(--rule); }
.howto ol { margin: 14px 0; padding-left: 22px; }
.howto li { font-size: 13.5px; margin-bottom: 8px; line-height: 1.5; }
.howto-note { font-size: 12.5px; color: var(--ink-soft); font-style: italic; line-height: 1.55; }
.howto-rg { font-size: 12.5px; color: var(--faint); line-height: 1.55; border-top: 1px dotted var(--rule); padding: 11px 0 15px; margin-top: 10px; }
.howto-rg b { color: var(--oxblood); }

/* ── ACCOUNTS: header control ──────────────────────────────────────────── */
.mast-controls { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.acct { display: inline-flex; align-items: stretch; }
.acct-name { font-family: var(--display); font-style: italic; font-weight: 600; font-size: 15px; color: var(--gold-deep); border: 1px solid var(--rule); border-right: 0; padding: 6px 13px; }
.acct-name:hover, .acct-name.active { color: var(--ink); background: var(--paper-3); }
.acct-out { color: var(--faint); border: 1px solid var(--rule); padding: 6px 11px; font-size: 14px; }
.acct-out:hover { color: var(--oxblood); border-color: var(--oxblood); }
.acct-in { font-family: var(--display); font-style: italic; font-weight: 600; font-size: 15px; color: var(--ink); border: 1px solid var(--gold); padding: 6px 15px; }
.acct-in:hover { background: var(--gold); color: #1a1206; }

/* ── ACCOUNTS: the Register modal ──────────────────────────────────────── */
.modal-scrim { position: fixed; inset: 0; z-index: 60; background: rgba(8, 6, 3, .74); backdrop-filter: blur(3px); display: grid; place-items: center; padding: 20px; animation: fade .2s; }
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
.modal { position: relative; width: min(420px, 100%); background: var(--paper-2); border: 1px solid var(--gold); box-shadow: var(--shadow); padding: 30px 28px 26px; text-align: center; }
.modal-x { position: absolute; top: 9px; right: 12px; color: var(--faint); font-size: 15px; }
.modal-x:hover { color: var(--oxblood); }
.modal-orn { color: var(--gold); font-size: 20px; margin-bottom: 2px; }
.modal h2 { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 90, "WONK" 1; font-size: 28px; margin: 0 0 8px; }
.modal-sub { color: var(--ink-soft); font-size: 13.5px; line-height: 1.6; font-style: italic; margin: 0 0 18px; }
.modal-input { width: 100%; background: var(--paper); border: 1px solid var(--rule); color: var(--ink); font-family: var(--serif); font-size: 16px; padding: 11px 13px; margin-bottom: 12px; }
.modal-input:focus { outline: none; border-color: var(--gold); }
.modal-err { color: var(--oxblood); font-size: 13px; font-style: italic; margin: 0 0 12px; }
.modal-actions { display: flex; flex-direction: column; gap: 9px; }
.modal-btn { font-family: var(--display); font-style: italic; font-weight: 600; font-size: 15px; padding: 11px; border: 1px solid var(--ink); color: var(--ink); background: var(--paper); transition: .15s; }
.modal-btn:hover { background: var(--ink); color: var(--paper); }
.modal-btn.primary { background: var(--gold); border-color: var(--gold); color: #1a1206; }
.modal-btn.primary:hover { background: var(--gold-glow); }
.modal-btn:disabled { opacity: .5; cursor: default; }
.social { display: flex; flex-direction: column; gap: 10px; align-items: center; margin-bottom: 2px; }
.gbtn { display: flex; justify-content: center; min-height: 40px; width: 100%; }
.gbtn > div { margin: 0 auto; }
.fb-btn { width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 9px; background: #1877f2; color: #fff; border: 0; font-family: var(--serif); font-weight: 600; font-size: 15px; padding: 11px; border-radius: 4px; transition: .15s; }
.fb-btn:hover { background: #166fe0; }
.fb-btn .fb-i { font-family: Georgia, "Times New Roman", serif; font-weight: 800; font-size: 18px; line-height: 1; }
.fb-btn:disabled { opacity: .55; cursor: default; }
.or-div { display: flex; align-items: center; gap: 10px; color: var(--faint); font-size: 11.5px; font-variant-caps: all-small-caps; letter-spacing: .08em; margin: 15px 0 13px; }
.or-div::before, .or-div::after { content: ""; flex: 1; height: 1px; background: var(--rule); }

/* ── ACCOUNTS: save ticket + register ──────────────────────────────────── */
.save-ticket { display: block; width: calc(100% - 32px); margin: 12px 16px 6px; font-family: var(--display); font-style: italic; font-weight: 600; font-size: 14px; padding: 10px; border: 1px solid var(--gold); color: var(--gold-deep); background: rgba(176, 125, 42, .09); }
.save-ticket:hover { background: var(--gold); color: #1a1206; }
.save-ticket.ghost { border-style: dashed; border-color: var(--rule); color: var(--ink-soft); background: none; }
.save-ticket.ghost:hover { border-color: var(--gold); color: var(--gold-deep); }
.ticket-flash { text-align: center; font-style: italic; font-size: 13px; color: var(--gold-deep); margin: 10px 16px 0; }

.tix { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.tix-item { border: 1px solid var(--rule); background: var(--paper); }
.tix-head { display: flex; align-items: center; gap: 12px; padding: 10px 13px; border-bottom: 1px dotted var(--rule); }
.tix-meta { font-family: var(--mono); font-size: 12.5px; color: var(--gold-deep); }
.tix-when { font-family: var(--mono); font-size: 11px; color: var(--faint); margin-left: auto; }
.tix-x { color: var(--faint); font-size: 12px; }
.tix-x:hover { color: var(--oxblood); }
.tix-legs { list-style: none; margin: 0; padding: 9px 13px; display: flex; flex-direction: column; gap: 5px; }
.tix-legs li { font-size: 13.5px; display: flex; align-items: baseline; gap: 8px; }
.tix-game { font-family: var(--mono); font-size: 11px; color: var(--faint); }
.tix-odds { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); margin-left: auto; }

/* ── PRO / AUTO-PILOT ──────────────────────────────────────────────────── */
.nav-pill { font-family: var(--display); font-style: italic; font-weight: 600; font-size: 15px; color: var(--gold-deep); border: 1px solid var(--gold); padding: 6px 14px; background: rgba(176, 125, 42, .08); }
.nav-pill:hover, .nav-pill.active { background: var(--gold); color: #1a1206; }
.gopro-pill { font-family: var(--display); font-style: italic; font-weight: 700; font-size: 13.5px; color: #1a1206; background: var(--gold); border: 1px solid var(--gold); padding: 6px 12px; }
.gopro-pill:hover { background: var(--gold-glow); }
.pro-badge { font-family: var(--mono); font-size: 9px; font-weight: 700; letter-spacing: .08em; color: #1a1206; background: var(--gold); padding: 1px 5px; border-radius: 2px; margin-left: 7px; vertical-align: middle; }

.upsell { text-align: center; max-width: 560px; margin: 0 auto; padding: 36px 20px; border: 1px solid var(--rule); background: var(--paper-2); }
.upsell .orn { color: var(--gold); font-size: 26px; }
.upsell h2 { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 144, "WONK" 1; font-size: 40px; margin: 6px 0 10px; }
.upsell-sub { color: var(--ink-soft); font-size: 15px; line-height: 1.6; font-style: italic; margin: 0 0 18px; }
.perks { list-style: none; margin: 0 auto 22px; padding: 0; max-width: 430px; text-align: left; display: flex; flex-direction: column; gap: 9px; }
.perks li { font-size: 14.5px; color: var(--ink); }
.gopro-btn { font-family: var(--display); font-style: italic; font-weight: 700; font-size: 17px; color: #1a1206; background: var(--gold); border: 1px solid var(--gold); padding: 13px 30px; box-shadow: 0 12px 28px -12px var(--gold); }
.gopro-btn:hover { background: var(--gold-glow); }

.ap-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; border-bottom: 1px solid var(--ink); padding-bottom: 7px; margin-bottom: 16px; }
.ap-head h2 { font-family: var(--display); font-weight: 900; font-variation-settings: "opsz" 90, "WONK" 1; font-size: 24px; margin: 0; color: var(--gold-deep); }
.ap-parlay { border-left: 3px solid var(--gold); }
.ap-auto { font-family: var(--mono); font-size: 9px; font-variant-caps: all-small-caps; letter-spacing: .08em; color: #1a1206; background: var(--gold); padding: 2px 6px; border-radius: 2px; margin-left: 8px; }
.ap-actions { display: flex; gap: 10px; align-items: center; margin-top: 12px; flex-wrap: wrap; }
.ap-actions .tier-load { margin: 0; flex: 1; min-width: 160px; }
.dk-link { font-family: var(--display); font-style: italic; font-weight: 600; font-size: 13.5px; color: #07140f; background: #59c947; border: 1px solid #59c947; padding: 9px 16px; }
.dk-link:hover { background: #6bd95a; }
.ev-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.ev-list li { display: grid; grid-template-columns: auto 1fr auto auto auto; align-items: baseline; gap: 12px; padding: 9px 2px; border-bottom: 1px dotted var(--rule); font-size: 13.5px; }
.ev-list li:last-child { border-bottom: 0; }
.ev-label { font-weight: 500; }
.ev-prob { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); }

/* ── RESPONSIVE ────────────────────────────────────────────────────────── */
@media (max-width: 940px) {
  .layout { grid-template-columns: 1fr; }
  .slip { position: static; order: -1; }
  .mast-foot { justify-content: center; }
}
@media (max-width: 520px) {
  #app { padding: 0 14px 56px; }
  .grid { grid-template-columns: 1fr; }
  .mast-band { font-size: 10px; }
  .mast-band span:last-child { display: none; }
  .acc-cards { grid-template-columns: 1fr 1fr; }
  .metric { border-bottom: 1px solid var(--rule); }
}
@media (prefers-reduced-motion: reduce) {
  .ticker-track, .pulse, .chip.live, .card { animation: none !important; }
}

/* ── soccer model lab ─────────────────────────────────────────────── */
.soccer-lab .lab-head { text-align: center; padding: 8px 18px 4px; }
.soccer-lab .lab-head .orn { font-size: 26px; opacity: .9; }
.soccer-lab .lab-head h2 { font-family: var(--serif); font-size: clamp(26px, 5vw, 40px); margin: 2px 0 8px; }
.soccer-lab .lab-sub { max-width: 56ch; margin: 0 auto; color: var(--ink-soft); font-size: 14.5px; line-height: 1.6; }
.soccer-lab .lab-sub a { color: var(--gold-deep); text-decoration: underline dotted; }
.soccer-lab .lab-why p { color: var(--ink-soft); font-size: 14px; line-height: 1.62; margin: 4px 0 0; }
.soccer-lab td.pos, .soccer-lab .pos { color: var(--gold-deep); }
.soccer-lab td.neg, .soccer-lab .neg { color: var(--oxblood); }
.soccer-lab td.muted, .soccer-lab .muted { color: var(--faint); font-style: italic; }
.soccer-lab .ev-list .kelly { font-family: var(--mono); font-size: 11.5px; color: var(--ink-soft); margin-left: auto; }
.soccer-lab .micro { font-size: 11.5px; color: var(--faint); font-style: italic; margin: 8px 0 0; }
.soccer-lab code { font-family: var(--mono); font-size: .92em; color: var(--gold-deep); }

/* ── admin register ───────────────────────────────────────────────── */
.admin-deck .muted { color: var(--faint); font-style: italic; }
.admin-deck td.pos, .admin-deck .pos { color: var(--gold-deep); }
.day-bars { list-style: none; margin: 6px 0 0; padding: 0; display: grid; gap: 6px; }
.day-bars li { display: grid; grid-template-columns: 92px 1fr 32px; align-items: center; gap: 10px; font-family: var(--mono); font-size: 12.5px; }
.day-bars .db-d { color: var(--ink-soft); }
.day-bars .db-bar { height: 9px; background: var(--paper-3); border-radius: 5px; overflow: hidden; }
.day-bars .db-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-glow)); }
.day-bars .db-n { text-align: right; color: var(--gold-deep); }

/* ── top bar + slide-out drawer + numbered Today's Three ─────────────── */
.topbar { position: sticky; top: 0; z-index: 60; display: flex; align-items: center; gap: 12px;
  padding: 9px 16px; background: rgba(23,19,11,.93); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rule); }
.tb-menu { display: flex; flex-direction: column; gap: 4px; width: 36px; height: 34px;
  align-items: center; justify-content: center; background: transparent;
  border: 1px solid var(--ink-line); border-radius: 9px; cursor: pointer; transition: border-color .15s; }
.tb-menu:hover { border-color: var(--gold); }
.tb-menu span { display: block; width: 18px; height: 2px; background: var(--gold-deep); border-radius: 2px; }
.tb-brand { margin-right: auto; font-family: var(--serif); font-size: 19px; color: var(--ink);
  background: transparent; border: 0; cursor: pointer; padding: 4px 2px; }
.tb-brand em { color: var(--oxblood-2); font-style: italic; }
.tb-right { display: flex; align-items: center; }
.tb-right .acct { gap: 8px; }

.drawer-scrim { position: fixed; inset: 0; z-index: 100; background: rgba(0,0,0,.55);
  backdrop-filter: blur(2px); animation: dr-fade .18s ease; }
@keyframes dr-fade { from { opacity: 0; } to { opacity: 1; } }
.drawer { position: fixed; left: 0; top: 0; bottom: 0; width: min(330px, 87vw);
  background: var(--paper-2); border-right: 1px solid var(--gold); box-shadow: 2px 0 44px rgba(0,0,0,.55);
  display: flex; flex-direction: column; overflow-y: auto; animation: dr-slide .24s cubic-bezier(.16,1,.3,1); }
@keyframes dr-slide { from { transform: translateX(-100%); } to { transform: none; } }
.dr-head { display: flex; align-items: center; gap: 9px; padding: 15px 16px;
  border-bottom: 1px solid var(--rule); font-family: var(--serif); font-size: 18px; color: var(--ink); }
.dr-head .orn { color: var(--gold-deep); }
.dr-x { margin-left: auto; background: transparent; border: 0; color: var(--ink-soft); font-size: 15px; cursor: pointer; }
.dr-nav { padding: 12px; display: flex; flex-direction: column; }
.dr-123 { display: flex; flex-direction: column; gap: 8px; }
.dr-num { display: flex; align-items: center; gap: 12px; text-align: left; padding: 11px 12px;
  background: var(--paper-3); border: 1px solid var(--ink-line); border-radius: 11px; cursor: pointer;
  color: var(--ink); transition: border-color .15s; }
.dr-num:hover { border-color: var(--gold); }
.dr-n { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; flex: 0 0 30px;
  border-radius: 50%; background: linear-gradient(135deg, var(--gold), var(--gold-glow)); color: #17130b;
  font-family: var(--serif); font-weight: 700; font-size: 16px; }
.dr-lab { display: flex; flex-direction: column; font-family: var(--serif); font-size: 15px; line-height: 1.2; }
.dr-lab small { font-family: var(--mono); font-size: 10.5px; color: var(--ink-soft); margin-top: 2px; }
.dr-sect { font-variant-caps: all-small-caps; letter-spacing: .1em; font-size: 12px;
  color: var(--gold-deep); padding: 14px 4px 4px; }
.dr-item { display: block; text-align: left; padding: 10px 12px; background: transparent; border: 0;
  border-radius: 8px; color: var(--ink); font-size: 14.5px; cursor: pointer; }
.dr-item:hover { background: var(--paper-3); }
.dr-item.active { background: var(--paper-3); color: var(--gold-deep); }
.dr-item .pro-badge { margin-left: 6px; }
.dr-sports { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.dr-sport { padding: 8px; background: var(--paper-3); border: 1px solid var(--ink-line); border-radius: 8px;
  color: var(--ink-soft); font-size: 13px; cursor: pointer; }
.dr-sport.active { color: var(--gold-deep); border-color: var(--gold); }
.dr-foot { margin-top: auto; padding: 14px 16px; font-size: 11px; color: var(--faint);
  font-style: italic; border-top: 1px solid var(--rule); }

.three-card .tc-head { display: flex; align-items: center; gap: 11px; }
.tc-num { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; flex: 0 0 30px;
  border-radius: 50%; background: linear-gradient(135deg, var(--gold), var(--gold-glow)); color: #17130b;
  font-family: var(--serif); font-weight: 700; font-size: 16px; }
.tc-titles { display: flex; flex-direction: column; }

/* ============================================================================
   LANDING ELEVATION — orchestrated entrance, struck-coin 1·2·3, almanac plates.
   Additive only. Honors prefers-reduced-motion. #app fades once (persists across
   re-renders); the Three cards cascade once during the boot "entering" window.
   ========================================================================== */
@keyframes appReveal  { from { opacity: 0; transform: translateY(9px);  } to { opacity: 1; transform: none; } }
@keyframes plateRise  { from { opacity: 0; transform: translateY(24px) scale(.985); } to { opacity: 1; transform: none; } }
@keyframes sealStrike { from { opacity: 0; transform: scale(.35) rotate(-28deg); } to { opacity: 1; transform: none; } }

@media (prefers-reduced-motion: no-preference) {
  #app { animation: appReveal .7s cubic-bezier(.16,1,.3,1) both; }
  body.entering .three-grid > .three-card { animation: plateRise .72s cubic-bezier(.16,1,.3,1) both; }
  body.entering .three-grid > .three-card:nth-child(1) { animation-delay: .04s; }
  body.entering .three-grid > .three-card:nth-child(2) { animation-delay: .15s; }
  body.entering .three-grid > .three-card:nth-child(3) { animation-delay: .26s; }
  body.entering .three-grid > .three-card .tc-num { animation: sealStrike .55s cubic-bezier(.34,1.56,.64,1) both; }
  body.entering .three-grid > .three-card:nth-child(1) .tc-num { animation-delay: .30s; }
  body.entering .three-grid > .three-card:nth-child(2) .tc-num { animation-delay: .41s; }
  body.entering .three-grid > .three-card:nth-child(3) .tc-num { animation-delay: .52s; }
}

/* horizon glow + letterpress behind the nameplate */
.mast-name { position: relative; }
.mast-name::before {
  content: ""; position: absolute; inset: -34% -8% -54%; z-index: -1; pointer-events: none;
  background: radial-gradient(58% 92% at 50% 32%, rgba(226,187,99,.14), transparent 70%);
}
.nameplate { text-shadow: 0 1px 0 rgba(0,0,0,.55), 0 0 34px rgba(226,187,99,.07); }

/* Today's Three → almanac plates with depth + hover */
.three-card {
  position: relative; border-radius: 3px;
  background:
    radial-gradient(125% 58% at 50% 0%, rgba(226,187,99,.06), transparent 58%),
    linear-gradient(180deg, var(--paper-2), var(--paper));
  transition: transform .26s cubic-bezier(.16,1,.3,1), box-shadow .26s ease, border-color .26s ease;
}
.three-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.three-card.def:hover   { border-color: var(--gold); }
.three-card.maybe:hover { border-color: var(--verdigris); }
.three-card.crazy:hover { border-color: var(--oxblood); }
.three-card:hover .tier-payout b { text-shadow: 0 0 22px currentColor; }

/* the 1·2·3 as struck, tier-colored coins */
.three-card .tc-num {
  background: radial-gradient(120% 120% at 32% 24%, #f1d68c, var(--gold) 54%, #8c6420);
  color: #1a1206; border: 1px solid rgba(120,86,20,.65);
  box-shadow: inset 0 1px 1.5px rgba(255,243,210,.55), inset 0 -2px 3px rgba(70,46,6,.55), 0 2px 7px rgba(0,0,0,.5);
  transition: transform .26s cubic-bezier(.16,1,.3,1);
}
.three-card.maybe .tc-num { background: radial-gradient(120% 120% at 32% 24%, #aeded0, var(--verdigris) 54%, #2c5a4d); color: #06140f; border-color: rgba(44,90,77,.65); }
.three-card.crazy .tc-num { background: radial-gradient(120% 120% at 32% 24%, #ec9785, var(--oxblood) 54%, #7a2616); color: #fff4ef; border-color: rgba(122,38,22,.7); }
.three-card:hover .tc-num { transform: scale(1.08) rotate(-4deg); }

/* ── ELEVATION, DEEPER SURFACES — carry the plate/coin/hover language app-wide ── */

/* board game-cards: lift + accent on hover, matching the Today's Three plates */
.card { transition: transform .24s cubic-bezier(.16,1,.3,1), box-shadow .24s ease, border-color .24s ease; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--rule); }

/* the oracle orb → a struck coin echoing the 1·2·3 medallions */
.orb { box-shadow: 0 3px 12px rgba(0,0,0,.45), inset 0 1px 2px rgba(255,243,210,.12); }
.card:hover .orb { box-shadow: 0 4px 18px rgba(0,0,0,.5), 0 0 22px rgba(226,187,99,.16), inset 0 1px 2px rgba(255,243,210,.16); }

/* stat panels (Ledger / Soccer Lab / Admin / Auto-Pilot) → plate depth + quiet hover */
.acc-block { border-radius: 3px; transition: border-color .24s ease, box-shadow .24s ease; }
.acc-block:hover { box-shadow: var(--shadow-sm); border-color: var(--rule); }
.acc-cards { border-radius: 3px; }
.metric { transition: background .22s ease; }
.metric:hover { background: radial-gradient(120% 120% at 50% 0%, rgba(226,187,99,.05), transparent 70%); }

/* league cards → lift + gold edge */
.acc-sport { border-radius: 3px; transition: transform .22s cubic-bezier(.16,1,.3,1), border-color .22s ease, box-shadow .22s ease; }
.acc-sport:hover { transform: translateY(-3px); border-color: var(--gold); box-shadow: var(--shadow-sm); }

/* the +EV value rows (Auto-Pilot / Soccer) → slide + glow on hover */
.ev-list li { transition: background .18s ease, padding-left .18s ease; border-radius: 2px; }
.ev-list li:hover { background: rgba(226,187,99,.06); padding-left: 6px; }

/* Pro / Auto-Pilot upsell → luminous plate */
.upsell { border-radius: 3px; position: relative; }
.upsell::before {
  content: ""; position: absolute; inset: -1px; z-index: -1; border-radius: 4px; pointer-events: none;
  background: radial-gradient(72% 110% at 50% -8%, rgba(226,187,99,.13), transparent 62%);
}
.gopro-btn, .gopro-pill { transition: transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s ease, filter .2s ease; }
.gopro-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 22px -8px rgba(226,187,99,.5); filter: brightness(1.06); }

/* ── COMPACTION — tighter cards (feedback: "cards too big") ──────────────── */
/* board game-cards: narrower columns, less padding, smaller orb */
.grid { grid-template-columns: repeat(auto-fill, minmax(286px, 1fr)); gap: 16px; }
.card { padding: 12px 14px 11px; }
.orb { width: 62px; height: 62px;
  box-shadow: inset 0 0 0 6px var(--paper-2), 0 0 0 1px var(--ink), 0 6px 14px -9px rgba(140,94,27,.6); }
.orb::after { inset: 10px; }
.orb-val { font-size: 18px; }
.orb-val i { font-size: 9.5px; }
.orb-wrap { margin: 8px 0 7px; gap: 5px; }
.orb-cap { font-size: 11px; }
.score { font-size: 16px; margin: 3px 0 7px; }
.team { gap: 10px; }
.teams { gap: 6px; }
.tinfo b { font-size: 16px; }

/* Today's Three: tighter plates, a touch smaller payout + coin */
.three-grid { grid-template-columns: repeat(auto-fit, minmax(205px, 1fr)); gap: 14px; }
.three-card { padding: 12px 13px 11px; }
.tier-name { font-size: 18px; }
.tier-payout b { font-size: 25px; }
.tier-legs { max-height: 150px; }
.three-card .tc-num { width: 26px; height: 26px; flex-basis: 26px; font-size: 14px; }
