/* ============================================================
   SUPERCARD — styles
   ============================================================ */

/* Self-hosted fonts (latin) — no third-party request, fully edge-cacheable.
   Oswald ships as a single variable woff2 covering weights 400–700. */
@font-face {
  font-family: "Anton";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/anton-latin-400.woff2") format("woff2");
}
@font-face {
  font-family: "Oswald";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("fonts/oswald-latin-var.woff2") format("woff2");
}

:root {
  --bg: #0f111a;
  --bg2: #161924;
  --panel: #1b1e2b;
  --panel2: #252938;
  --ink: #f5f6fa;
  --muted: #b6bccd;
  --gold: #f5c542;
  --gold2: #ffe08a;
  --red: #e23b50;
  --crimson: #b01e34;
  --green: #2fd17a;
  --blue: #5cb3ff;
  --line: rgba(255, 255, 255, 0.1);
  --line-strong: rgba(255, 255, 255, 0.18);
  --shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Oswald", "Arial Narrow", sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

.spotlights { display: none; }

.screen { display: none; position: relative; z-index: 1; min-height: 100vh; }
.screen.active { display: block; animation: screenIn .3s ease both; }

@keyframes screenIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.confetti-canvas { position: fixed; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 60; }

button { font-family: inherit; cursor: pointer; }

/* ---------------- TITLE ---------------- */
.title-wrap {
  max-width: 560px;
  margin: 0 auto;
  padding: 7vh 22px 60px;
  text-align: center;
}
.kicker {
  letter-spacing: 0.5em;
  font-size: 13px;
  color: var(--gold);
  margin: 0 0 6px;
  text-transform: uppercase;
}
.logo {
  font-family: "Anton", sans-serif;
  font-size: clamp(64px, 16vw, 120px);
  line-height: 0.86;
  margin: 0;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
}
.logo span { display: block; color: transparent; -webkit-text-stroke: 2px var(--gold); }
.tagline { color: var(--muted); font-size: 18px; margin: 10px 0 26px; letter-spacing: 0.04em; }

.difficulty-row { display: flex; gap: 10px; margin: 22px 0 10px; }
.diff-btn {
  flex: 1;
  background: var(--panel);
  border: 1px solid var(--line);
  color: var(--muted);
  padding: 12px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.12em;
  transition: border-color .15s, color .15s, background .15s;
}
.diff-btn:hover:not(.active) { border-color: var(--line-strong); color: var(--ink); }
.diff-btn.active { background: var(--crimson); color: #fff; border-color: var(--red); }
.diff-desc { color: var(--muted); font-size: 14px; min-height: 38px; margin: 6px 0 18px; line-height: 1.4; }

.btn-primary {
  display: block;
  width: 100%;
  border: none;
  border-radius: 12px;
  padding: 17px;
  font-family: "Anton", sans-serif;
  font-size: 22px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1a1206;
  background: var(--gold);
  transition: transform .1s, background .15s, opacity .15s;
}
.btn-primary:hover:not(:disabled) { transform: translateY(-2px); background: var(--gold2); }
.btn-primary:active:not(:disabled) { transform: translateY(0); }
.btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }

.record-line { color: var(--muted); font-size: 14px; margin: 18px 0 2px; }
.record-line strong { color: var(--gold2); }
.best-line { color: var(--blue); font-size: 13px; margin: 2px 0; }

.how-to {
  margin-top: 26px;
  text-align: left;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 4px 16px;
}
.how-to summary { cursor: pointer; padding: 12px 0; font-weight: 600; letter-spacing: 0.06em; color: var(--gold2); }
.how-to-body { color: var(--muted); font-size: 14px; line-height: 1.55; padding-bottom: 12px; }
.how-to-body strong { color: var(--ink); }
.how-to-body ul { padding-left: 18px; margin: 8px 0 0; }
.how-to-body li { margin: 5px 0; }

.legal-notice {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.5;
  opacity: 0.7;
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
  padding: 22px 18px 28px;
}

.legal-notice a {
  color: var(--gold);
  text-decoration: none;
}

.legal-notice a:hover {
  text-decoration: underline;
}

/* ---------------- DRAFT ---------------- */
.draft-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  background: var(--bg2);
  position: sticky;
  top: 0;
  z-index: 10;
  flex-wrap: wrap;
}
.draft-logo { font-family: "Anton", sans-serif; font-size: 24px; letter-spacing: 1px; color: var(--gold); }
.draft-logo span { -webkit-text-stroke: 1px var(--gold); color: transparent; }
.draft-meta { display: block; color: var(--muted); font-size: 12px; letter-spacing: 0.06em; margin-top: 2px; }
.draft-progress { display: flex; align-items: center; gap: 12px; }
.progress-bar { width: 180px; height: 8px; background: var(--panel2); border-radius: 99px; overflow: hidden; }
.progress-fill { height: 100%; width: 0; background: var(--gold); transition: width .35s; }
#progress-text { color: var(--muted); font-size: 13px; white-space: nowrap; }

.draft-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 22px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 22px;
  align-items: start;
}

/* slot banner */
.slot-banner {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-left: 4px solid var(--gold);
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.slot-banner-num { color: var(--gold); letter-spacing: 0.25em; font-size: 12px; font-weight: 600; }
.slot-banner-name { font-family: "Anton", sans-serif; font-size: 30px; margin: 4px 0 6px; letter-spacing: 0.5px; }
.slot-banner-desc { color: var(--muted); font-size: 14px; margin: 0; max-width: 52ch; line-height: 1.45; }

/* per-match promotion + decade — two tappable cards with re-draw buttons */
.slot-booking { flex-basis: 100%; }
.booking-cards { display: flex; align-items: stretch; gap: 10px; }
.bcard {
  flex: 1; min-width: 0;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 13px 15px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.bcard-label { color: var(--muted); letter-spacing: 0.2em; font-size: 10px; }
.bcard-value { font-family: "Anton", sans-serif; font-size: 20px; color: var(--gold2); line-height: 1.05; }
.bcard-x { align-self: center; color: var(--muted); font-size: 18px; flex: none; }
.booking-skips { display: flex; gap: 10px; margin-top: 10px; }
.redraw {
  flex: 1; min-width: 0;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: transparent; border: 1px solid var(--line); color: var(--muted);
  padding: 11px 12px; border-radius: 10px; font-size: 13px; letter-spacing: 0.03em;
  transition: border-color .15s, color .15s;
}
.redraw:hover:not(:disabled) { border-color: var(--gold); color: var(--gold); }
.redraw:disabled { opacity: 0.32; cursor: not-allowed; }
.redraw em {
  font-style: normal; min-width: 18px; height: 18px; line-height: 18px; padding: 0 5px;
  text-align: center; background: var(--gold); color: #1a1206; border-radius: 99px;
  font-size: 11px; font-weight: 700; flex: none;
}
.sb-flavor { color: var(--muted); font-size: 13px; font-style: italic; line-height: 1.4; margin: 12px 0 0; }

.card-empty { color: var(--muted); font-size: 13px; line-height: 1.5; margin: 0 0 14px; }

/* two-competitor matchup strip */
.slot-matchup { flex-basis: 100%; display: flex; align-items: stretch; gap: 10px; margin-top: 2px; }
.mu-chip {
  flex: 1; min-width: 0; text-align: center; padding: 13px 12px; border-radius: 12px;
  border: 1px solid var(--line); background: var(--panel2); font-size: 15px; color: var(--ink);
  display: flex; align-items: center; justify-content: center; gap: 4px; min-height: 48px;
}
.mu-chip.empty { color: var(--muted); border-style: dashed; }
.mu-chip.empty.active { border-color: var(--gold); color: var(--gold2); box-shadow: 0 0 0 1px var(--gold) inset; }
.mu-chip.filled { cursor: pointer; font-weight: 600; }
.mu-chip.filled em { font-style: normal; color: var(--muted); font-size: 12px; }
.mu-chip.filled:hover { border-color: var(--red); }
.mu-vs { font-family: "Anton", sans-serif; color: var(--gold); font-size: 15px; letter-spacing: 0.08em; align-self: center; flex: none; }

.pool-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; gap: 12px; flex-wrap: wrap; }
.pool-count { color: var(--ink); font-size: 13px; letter-spacing: 0.05em; }
.pool-hint { color: var(--muted); font-size: 12px; }

.pool-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}
.talent {
  text-align: left;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 13px 14px;
  color: var(--ink);
  transition: transform .1s, border-color .15s, background .15s;
}
.talent:hover { transform: translateY(-3px); border-color: var(--gold); background: var(--panel2); }
.talent-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 12px; }
.talent-name { font-weight: 600; font-size: 17px; }
.talent-arch { font-size: 10px; color: var(--muted); letter-spacing: 0.04em; padding: 3px 7px; border: 1px solid var(--line); border-radius: 99px; white-space: nowrap; }
.talent-arch.aff { color: #1a1206; background: var(--gold2); border-color: var(--gold2); font-weight: 700; }
.talent-foot { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.talent-fitlabel { font-size: 11px; color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }
.talent-stars { color: var(--gold); font-size: 18px; letter-spacing: 1px; }

/* card column */
.card-col {
  position: sticky;
  top: 88px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.card-title { font-family: "Anton", sans-serif; letter-spacing: 0.1em; font-size: 18px; margin: 0 0 14px; color: var(--gold2); }

/* ---- Hot Crowd meter (live momentum while booking) ---- */
.heat-meter {
  --heat-color: var(--muted);
  background: var(--panel2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 13px;
  margin-bottom: 16px;
  transition: box-shadow .4s;
}
.heat-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 9px; }
.heat-label { font-size: 10px; letter-spacing: 0.18em; color: var(--muted); }
.heat-tier {
  font-family: "Anton", sans-serif; font-size: 15px; letter-spacing: 0.06em;
  color: var(--heat-color); transition: color .35s;
}
.heat-track { height: 9px; background: var(--bg2); border-radius: 99px; overflow: hidden; }
.heat-fill {
  height: 100%; width: 50%; border-radius: 99px;
  background: var(--heat-color);
  transition: width .55s cubic-bezier(.2,.8,.2,1), background .4s;
}
.heat-foot { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; margin-top: 8px; min-height: 15px; }
.heat-mult { font-variant-numeric: tabular-nums; font-size: 14px; font-weight: 600; color: var(--heat-color); }
.heat-reaction { font-size: 11px; letter-spacing: 0.02em; opacity: 0; }
.heat-reaction.show { animation: heatPop 1.5s ease both; }
.heat-reaction.up { color: var(--green); }
.heat-reaction.down { color: var(--red); }
@keyframes heatPop {
  0% { opacity: 0; transform: translateY(4px); }
  14% { opacity: 1; transform: none; }
  72% { opacity: 1; }
  100% { opacity: 0; }
}
/* tier colours — drive both the fill and the labels via --heat-color */
.heat-meter.cold     { --heat-color: #6db0ff; }
.heat-meter.cool     { --heat-color: #9ab8cf; }
.heat-meter.warm     { --heat-color: var(--gold2); }
.heat-meter.hot      { --heat-color: var(--gold); }
.heat-meter.fire     { --heat-color: #ff7a3c; }
.heat-meter.electric { --heat-color: #ffd24a; box-shadow: 0 0 0 1px rgba(245,197,66,0.45), 0 0 24px rgba(245,197,66,0.22); }
.heat-meter.fire .heat-fill     { background: linear-gradient(90deg, var(--gold), #ff7a3c); }
.heat-meter.electric .heat-fill { background: linear-gradient(90deg, var(--gold), #ff7a3c, var(--gold2)); }
.heat-meter.electric .heat-tier { animation: heatFlicker 1.1s ease-in-out infinite; }
@keyframes heatFlicker { 0%, 100% { opacity: 1; } 50% { opacity: 0.7; } }
.card-slots { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.cslot {
  background: var(--panel2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 9px 11px;
  color: var(--ink);
}
.cslot.active { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold) inset; }
.cslot-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 6px; min-height: 14px; }
.cslot-num { font-size: 10px; letter-spacing: 0.15em; color: var(--muted); }
.cslot-stars { color: var(--gold); font-size: 13px; }
.cslot-bout { display: flex; flex-direction: column; gap: 4px; }
.cslot-vs { font-size: 9px; letter-spacing: 0.2em; color: var(--muted); text-align: center; }
.cside { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.cside-name { font-weight: 600; font-size: 14px; }
.cside-x {
  width: 22px; height: 22px; line-height: 20px; text-align: center; flex: none;
  background: transparent; border: 1px solid var(--line); border-radius: 6px;
  color: var(--muted); font-size: 11px; padding: 0;
}
.cside-x:hover { color: var(--red); border-color: var(--red); }
button.cside.empty {
  width: 100%; text-align: left; color: var(--muted); font-size: 12px;
  background: transparent; border: 1px dashed var(--line); border-radius: 8px; padding: 8px 10px;
}
button.cside.empty:hover { border-color: var(--gold); color: var(--gold); }
.cslot-buys { color: var(--green); font-size: 12px; font-variant-numeric: tabular-nums; text-align: right; margin-top: 6px; }

.card-total { display: flex; justify-content: space-between; align-items: baseline; border-top: 1px solid var(--line); padding-top: 13px; margin-bottom: 14px; }
.card-total span { color: var(--muted); font-size: 13px; letter-spacing: 0.08em; }
.card-total strong { font-family: "Anton", sans-serif; font-size: 26px; color: var(--gold2); font-variant-numeric: tabular-nums; }
/* buys stay secret until the show is booked */
.card-total strong.hidden-buys { font-family: "Oswald", sans-serif; font-size: 13px; font-weight: 600; color: var(--muted); font-style: italic; letter-spacing: 0.04em; }
.btn-book { margin-bottom: 8px; }
.btn-ghost {
  width: 100%; background: transparent; border: 1px solid var(--line);
  color: var(--muted); padding: 10px; border-radius: 10px; font-size: 13px; letter-spacing: 0.06em;
}
.btn-ghost:hover { color: var(--ink); border-color: var(--line-strong); }

/* ---------------- RESULT ---------------- */
.result-wrap { max-width: 640px; margin: 0 auto; padding: 6vh 22px 60px; text-align: center; position: relative; }
.result-flash { display: none; }
.result-kicker { letter-spacing: 0.3em; font-size: 14px; color: var(--gold); margin: 0 0 6px; }
.result-verdict { font-family: "Anton", sans-serif; font-size: clamp(34px, 8vw, 56px); margin: 0 0 18px; line-height: 1; animation: verdictPop .5s cubic-bezier(.18,.9,.32,1.4) both; }
@keyframes verdictPop { 0% { opacity: 0; transform: scale(.7); } 60% { transform: scale(1.06); } 100% { opacity: 1; transform: scale(1); } }
.result-verdict.legendary, .result-verdict.win { color: var(--gold2); }
.result-verdict.near { color: var(--blue); }
.result-verdict.loss { color: var(--red); }

.result-buys { margin: 8px 0 20px; }
.result-buys-num { display: block; font-family: "Anton", sans-serif; font-size: clamp(52px, 14vw, 92px); line-height: 1; color: #fff; font-variant-numeric: tabular-nums; }
.result-buys-label { letter-spacing: 0.35em; font-size: 12px; color: var(--muted); }

.result-vs-record {
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
  padding: 16px 18px; margin: 0 0 22px; text-align: left;
}
.rvr-row { display: flex; justify-content: space-between; padding: 4px 0; color: var(--muted); font-size: 14px; }
.rvr-row strong { color: var(--ink); font-variant-numeric: tabular-nums; }
.rvr-row.rvr-heat { border-top: 1px dashed var(--line); margin-top: 4px; padding-top: 8px; }
.rvr-row.rvr-heat.up strong { color: var(--green); }
.rvr-row.rvr-heat.down strong { color: var(--red); }
.rvr-bar { height: 10px; background: var(--bg2); border-radius: 99px; overflow: hidden; margin: 10px 0 8px; }
.rvr-fill { height: 100%; background: var(--crimson); transition: width .8s ease; }
.rvr-fill.beat { background: var(--gold); }
.rvr-delta { font-size: 13px; text-align: right; }
.rvr-delta.up { color: var(--green); }
.rvr-delta.down { color: var(--red); }

.result-matches { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 26px; }
.rmatch { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 12px 14px; text-align: left; animation: riseIn .5s ease both; }
@keyframes riseIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.rmatch-top { display: flex; justify-content: space-between; align-items: center; }
.rmatch-slot { font-size: 10px; letter-spacing: 0.18em; color: var(--muted); }
.rmatch-stars { color: var(--gold); font-size: 14px; }
.rmatch-stars small { color: var(--muted); font-size: 10px; }
.rmatch-name { font-weight: 600; font-size: 14px; margin: 4px 0 8px; }
.rmatch-bottom { display: flex; justify-content: space-between; align-items: baseline; gap: 6px; flex-wrap: wrap; border-top: 1px solid var(--line); padding-top: 7px; }
.rmatch-wrestler { font-size: 14px; color: var(--gold2); }
.rmatch-wrestler small { color: var(--muted); font-size: 11px; margin: 0 2px; }
.rmatch-buys { font-size: 12px; color: var(--green); font-variant-numeric: tabular-nums; }
.rmatch-finish { font-size: 12px; color: var(--muted); margin-top: 7px; line-height: 1.4; }
.rmatch-finish .rmatch-winner { color: var(--gold2); font-weight: 600; }
.rmatch-finish.upset .rmatch-winner { color: var(--red); }
.rmatch-finish.team { font-style: italic; }
.rmatch-badge { display: inline-block; margin-left: 6px; padding: 1px 7px; border-radius: 999px;
  font-size: 10px; letter-spacing: 0.06em; background: rgba(255,255,255,0.06); color: var(--gold); vertical-align: middle; }
.rmatch-finish.upset .rmatch-badge { background: rgba(226,59,80,0.16); color: var(--red); }

.result-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.result-actions .btn-primary { flex: 2 1 100%; }
.result-actions .btn-ghost { flex: 1; }

/* X / Twitter share — subtle brand tint so it reads as "post this out" */
.btn-share-x { display: inline-flex; align-items: center; justify-content: center; gap: 7px; }
.btn-share-x::before {
  content: "𝕏"; font-size: 14px; line-height: 1; font-weight: 700; color: var(--ink);
}
.btn-share-x:hover { border-color: var(--gold); color: var(--ink); }

/* Standing call-to-action under the buttons — the link that carries the game on */
.share-cta { margin: 14px 0 0; font-size: 13px; color: var(--muted); letter-spacing: 0.03em; }
.share-cta a { color: var(--gold2); text-decoration: none; border-bottom: 1px solid rgba(255,224,138,0.4); }
.share-cta a:hover { border-bottom-color: var(--gold2); }

/* ---------------- match-set overlay + match roll-in ---------------- */
/* fresh match slides in when we auto-advance after a bout is booked */
.slot-banner.rolling, .pool-list.rolling { animation: rollIn .5s cubic-bezier(.2,.7,.2,1) both; }
@keyframes rollIn { from { opacity: 0; transform: translateX(46px); } to { opacity: 1; transform: none; } }

/* full-screen "BOOKED" slam shown the moment both competitors are picked */
.match-set {
  position: fixed; inset: 0; z-index: 80;
  display: flex; align-items: center; justify-content: center;
  padding: 24px; pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(10,10,18,0.72), rgba(10,10,18,0.93));
  animation: msBg 1.15s ease both;
}
@keyframes msBg { 0% { opacity: 0; } 12% { opacity: 1; } 76% { opacity: 1; } 100% { opacity: 0; } }
.ms-card {
  text-align: center; max-width: 560px;
  padding: 26px 40px;
  background: var(--panel); border: 1px solid var(--line); border-top: 4px solid var(--gold);
  border-radius: 16px; box-shadow: 0 30px 80px rgba(0,0,0,0.6);
  animation: msSlam 1.15s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes msSlam {
  0%   { opacity: 0; transform: scale(1.7) rotate(-5deg); filter: blur(5px); }
  18%  { opacity: 1; transform: scale(1) rotate(0); filter: blur(0); }
  74%  { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(.92) translateY(-12px); }
}
.ms-stamp {
  display: inline-block; font-family: "Anton", sans-serif; letter-spacing: 0.18em;
  color: #1a1206; background: var(--gold2); padding: 5px 16px; border-radius: 7px; font-size: 15px;
}
.match-set.final .ms-stamp { background: var(--red); color: #fff; }
.ms-slot { display: block; color: var(--gold); letter-spacing: 0.25em; font-size: 12px; margin-top: 16px; }
.ms-bout { display: flex; align-items: center; justify-content: center; gap: 16px; margin: 10px 0 14px; flex-wrap: wrap; }
.ms-name { font-family: "Anton", sans-serif; font-size: clamp(22px, 6vw, 32px); }
.ms-vs { font-family: "Anton", sans-serif; color: var(--gold); font-size: 16px; letter-spacing: 0.08em; }
.ms-heat { display: block; margin: 0 0 6px; font-size: 13px; font-weight: 600; letter-spacing: 0.02em; }
.ms-heat.up { color: var(--green); }
.ms-heat.down { color: var(--red); }
.ms-next { color: var(--muted); font-size: 13px; font-style: italic; }

/* ---------------- responsive ---------------- */
@media (prefers-reduced-motion: reduce) {
  *, .screen.active { animation: none !important; transition: none !important; }
}

@media (max-width: 880px) {
  .draft-layout { grid-template-columns: 1fr; }
  .card-col { position: static; }
  .draft-progress { width: 100%; }
  .progress-bar { flex: 1; }
  .result-matches { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .title-wrap { padding: 5vh 16px 48px; }
  .tagline { font-size: 16px; }
  .difficulty-row { gap: 8px; }

  /* compact, non-wrapping header */
  .draft-header { padding: 11px 16px; gap: 10px; }
  .draft-logo { font-size: 21px; }
  .draft-meta { font-size: 11px; }
  .draft-progress { gap: 10px; }
  #progress-text { font-size: 12px; }

  .draft-layout { padding: 14px; gap: 14px; }

  /* slot banner stacks into a clean vertical card on phones */
  .slot-banner { flex-direction: column; padding: 16px; gap: 14px; margin-bottom: 14px; }
  .slot-banner-name { font-size: 23px; }
  .slot-banner-desc { font-size: 13px; }

  /* booking + matchup full width, comfy tap targets */
  .bcard-value { font-size: 18px; }
  .redraw { padding: 12px 10px; font-size: 12px; }
  .mu-chip { font-size: 14px; }

  .pool-list { grid-template-columns: 1fr; gap: 10px; }
  .talent { padding: 14px 16px; }
  .talent-head { margin-bottom: 10px; }

  .card-col { padding: 16px; }

  .result-wrap { padding: 5vh 16px 48px; }
  .result-actions { flex-direction: column; }
  .result-actions .btn-primary,
  .result-actions .btn-ghost { flex: none; width: 100%; }
}

/* very narrow phones — keep the two booking cards legible */
@media (max-width: 360px) {
  .booking-cards { gap: 7px; }
  .bcard { padding: 11px 12px; }
  .bcard-value { font-size: 16px; }
  .bcard-x { font-size: 14px; }
  .redraw span { font-size: 11px; }
}
