:root {
  --bg: #0b0a1a;
  --bg2: #141232;
  --card: #1c1a3d;
  --card2: #24214f;
  --ink: #f4f2ff;
  --muted: #a29ecb;
  --pink: #ff2d95;
  --purple: #8a4bff;
  --cyan: #22e0d6;
  --gold: #ffd23f;
  --green: #2fe08a;
  --border: #2e2a5a;
  --shadow: 0 10px 40px rgba(0, 0, 0, 0.45);
  --radius: 16px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(138, 75, 255, 0.35), transparent),
    radial-gradient(1000px 500px at -10% 110%, rgba(255, 45, 149, 0.28), transparent),
    var(--bg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--cyan); }

.wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 28px 20px 60px;
}

/* ---------- Brand ---------- */
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  font-size: 1.4rem;
  letter-spacing: -0.02em;
}
.brand .logo {
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--pink), var(--purple));
  box-shadow: 0 6px 20px rgba(138, 75, 255, 0.5);
  font-size: 1.3rem;
}
.brand small { color: var(--muted); font-weight: 500; font-size: .72rem; display:block; letter-spacing: .16em; text-transform: uppercase; }

/* ---------- Hero ---------- */
.hero {
  text-align: center;
  padding: 40px 0 10px;
}
.hero h1 {
  font-size: clamp(2.2rem, 6vw, 4rem);
  line-height: 1.02;
  margin: 18px 0 10px;
  letter-spacing: -0.03em;
}
.hero h1 .grad {
  background: linear-gradient(90deg, var(--pink), var(--gold), var(--cyan));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero p.lead { color: var(--muted); font-size: 1.15rem; max-width: 620px; margin: 0 auto 26px; }
.hero-stats { margin-top: 22px; color: var(--muted); font-size: .98rem; }
.hero-stats b { color: var(--cyan); font-weight: 800; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: none; cursor: pointer;
  font-family: inherit; font-weight: 700; font-size: 1rem;
  padding: 14px 26px; border-radius: 999px;
  color: #fff; text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s;
}
.btn:active { transform: translateY(1px) scale(.99); }
.btn-primary { background: linear-gradient(135deg, var(--pink), var(--purple)); box-shadow: 0 8px 24px rgba(255, 45, 149, 0.4); }
.btn-primary:hover { box-shadow: 0 10px 30px rgba(255, 45, 149, 0.6); }
.btn-ghost { background: transparent; border: 2px solid var(--border); color: var(--ink); }
.btn-ghost:hover { border-color: var(--purple); }
.btn-cyan { background: linear-gradient(135deg, var(--cyan), #1aa9c7); box-shadow: 0 8px 24px rgba(34, 224, 214, .3); color:#04202a; }
.btn-gold { background: linear-gradient(135deg, var(--gold), #ff9f1c); color:#3a2400; box-shadow: 0 8px 24px rgba(255,210,63,.35); }
.btn-lg { font-size: 1.15rem; padding: 18px 34px; }
.btn:disabled { opacity: .4; cursor: not-allowed; }
.btn-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---------- Cards / panels ---------- */
.panel {
  background: linear-gradient(180deg, var(--card), var(--bg2));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
}
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 720px) { .grid-2 { grid-template-columns: 1fr; } }

.feature-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 34px; }
@media (max-width: 720px) { .feature-cards { grid-template-columns: 1fr; } }
.feature { text-align: left; }
.feature .ic { font-size: 1.8rem; }
.feature h3 { margin: 10px 0 6px; }
.feature p { color: var(--muted); margin: 0; font-size: .95rem; }

/* ---------- Playlist picker ---------- */
.print-picker-controls { display:flex; gap: 12px; align-items:center; flex-wrap:wrap; margin-bottom: 6px; }
.pl-cat-head { grid-column: 1 / -1; text-transform: uppercase; letter-spacing: .12em; font-size: .74rem;
  font-weight: 800; color: var(--purple); margin: 10px 2px 2px; }
.pl-cat-head:first-child { margin-top: 0; }
.playlists { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.pl {
  text-align: left; cursor: pointer;
  border: 2px solid var(--border); background: var(--card);
  border-radius: 14px; padding: 18px; transition: .12s;
}
.pl:hover { border-color: var(--purple); transform: translateY(-2px); }
.pl.sel { border-color: var(--pink); box-shadow: 0 0 0 3px rgba(255,45,149,.25); }
.pl .emoji { font-size: 1.8rem; }
.pl h3 { margin: 8px 0 2px; }
.pl small { color: var(--muted); }

/* ---------- Section head ---------- */
.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: .72rem; color: var(--purple); font-weight: 700; }
h2.sec { font-size: 1.5rem; margin: 6px 0 18px; }

.field { margin-bottom: 14px; }
.field label { display:block; font-size:.85rem; color: var(--muted); margin-bottom:6px; font-weight:600; }
.field input {
  width: 100%; padding: 14px 16px; font-size: 1.05rem; font-family: inherit;
  border-radius: 12px; border: 2px solid var(--border);
  background: var(--bg2); color: var(--ink); outline: none;
}
.field input:focus { border-color: var(--purple); }

/* ---------- Host console ---------- */
.host-top { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap: wrap; margin-bottom: 20px; }
.code-badge {
  font-family: "SF Mono", ui-monospace, monospace; font-weight: 800;
  font-size: 2rem; letter-spacing: .35em; padding: 8px 8px 8px 20px;
  background: var(--bg2); border: 2px dashed var(--purple); border-radius: 14px;
}
.stat { text-align:center; }
.stat .n { font-size: 2rem; font-weight: 800; }
.stat .l { color: var(--muted); font-size:.8rem; text-transform: uppercase; letter-spacing:.1em; }
.stats-row { display:flex; gap: 26px; }

.now-playing {
  text-align:center; padding: 30px; border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(255,45,149,.18), rgba(138,75,255,.18));
  border: 1px solid var(--border); margin-bottom: 18px; min-height: 150px;
  display:flex; flex-direction:column; justify-content:center;
}
.now-playing .np-label { color: var(--muted); text-transform: uppercase; letter-spacing:.18em; font-size:.75rem; }
.now-playing .np-title { font-size: 2.2rem; font-weight: 800; margin: 8px 0 4px; line-height:1.1; }
.now-playing .np-artist { color: var(--cyan); font-size: 1.15rem; }
.now-playing.empty .np-title { color: var(--muted); font-size: 1.4rem; }

.called-list { display:flex; flex-wrap: wrap; gap: 8px; max-height: 260px; overflow:auto; }
.chip {
  background: var(--card2); border:1px solid var(--border); border-radius: 999px;
  padding: 7px 14px; font-size: .9rem; display:flex; gap:8px; align-items:center;
}
.chip .num { color: var(--muted); font-weight: 700; }
.chip.latest { border-color: var(--pink); background: rgba(255,45,149,.15); }

.pattern-pick { display:flex; gap:8px; flex-wrap: wrap; }
.pattern-pick button {
  background: var(--card2); border:2px solid var(--border); color: var(--ink);
  padding: 8px 14px; border-radius: 10px; cursor:pointer; font-family: inherit; font-weight:600;
}
.pattern-pick button.sel { border-color: var(--cyan); color: var(--cyan); }

/* ---------- Bingo card ---------- */
.bingo {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
  max-width: 520px; margin: 0 auto;
}
.bingo .head {
  aspect-ratio: 1; display:grid; place-items:center; border-radius: 12px;
  font-weight: 900; font-size: 1.6rem; color:#fff;
  background: linear-gradient(135deg, var(--pink), var(--purple));
}
.cell {
  aspect-ratio: 1; border-radius: 12px; cursor: pointer;
  background: var(--card2); border: 1px solid var(--border);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding: 6px; gap: 3px; transition: .1s; user-select:none;
  overflow:hidden;
}
.cell .t { font-size: .74rem; font-weight: 700; line-height: 1.1; }
.cell .a { font-size: .62rem; color: var(--muted); line-height:1; }
.cell.free { background: linear-gradient(135deg, var(--gold), #ff9f1c); color:#3a2400; }
.cell.free .t { font-size: .9rem; }
.cell.marked { background: linear-gradient(135deg, var(--green), #17b978); color:#04241a; transform: scale(.97); }
.cell.marked .a { color: rgba(4,36,26,.7); }
.cell.win { animation: pop .4s ease; box-shadow: 0 0 0 3px var(--gold), 0 0 22px var(--gold); }
@keyframes pop { 0%{transform:scale(1)} 50%{transform:scale(1.08)} 100%{transform:scale(1)} }

/* ---------- Player ---------- */
.player-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; flex-wrap:wrap; gap:10px; }
.pill { background: var(--bg2); border:1px solid var(--border); border-radius:999px; padding:8px 16px; font-weight:600; }
.pill b { color: var(--cyan); }

.toast {
  position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%) translateY(120px);
  background: linear-gradient(135deg, var(--gold), #ff9f1c); color:#3a2400;
  font-weight: 800; padding: 16px 26px; border-radius: 14px; box-shadow: var(--shadow);
  transition: transform .35s cubic-bezier(.2,1.4,.4,1); z-index: 50; max-width: 90vw; text-align:center;
}
.toast.show { transform: translateX(-50%) translateY(0); }

.muted { color: var(--muted); }
.center { text-align:center; }
.mt { margin-top: 18px; }
.hidden { display: none !important; }
.spacer { height: 18px; }
.foot { text-align:center; color: var(--muted); font-size:.85rem; margin-top: 40px; }
.winbanner {
  background: linear-gradient(135deg, var(--gold), #ff9f1c); color:#3a2400;
  padding: 14px 18px; border-radius: 14px; font-weight: 800; text-align:center; margin-bottom: 16px;
}

/* ---------- Print shop ---------- */
.controls-bar {
  display:flex; gap:14px; align-items:flex-end; flex-wrap:wrap;
  background: var(--card); border:1px solid var(--border); border-radius: 14px; padding:16px; margin-bottom: 18px;
}
.controls-bar .field { margin:0; }
.controls-bar .field input, .controls-bar .field select {
  padding: 10px 12px; font-size: 1rem; font-family: inherit; border-radius: 10px;
  border: 2px solid var(--border); background: var(--bg2); color: var(--ink); width: 120px;
}
.deck-meta { color: var(--muted); margin: 8px 2px 16px; }

/* Printed cards render on WHITE so what you see is what prints (ink-friendly). */
.print-area { background: #f4f4f7; border-radius: 14px; padding: 20px; }
.sheet {
  display: grid; grid-template-columns: 1fr; gap: 26px;
  background: #fff; color: #111; padding: 26px; border-radius: 8px; margin: 0 auto 22px;
  max-width: 760px; box-shadow: 0 6px 24px rgba(0,0,0,.15);
}
/* 2-up = two cards side by side on a LANDSCAPE page */
.sheet.two { grid-template-columns: 1fr 1fr; align-items: center; gap: 20px; max-width: 1040px; }
.pcard { border: 3px solid #111; border-radius: 12px; padding: 14px; break-inside: avoid; }
.pcard-head {
  display:flex; align-items:center; gap:10px; border-bottom: 3px solid #111;
  padding-bottom: 10px; margin-bottom: 12px;
}
.pcard-head .pemoji { font-size: 1.5rem; }
.pcard-head .pcard-logo { height: 34px; width: auto; flex: none; }
.pcard-head .ptitle { font-weight: 900; font-size: 1.1rem; letter-spacing:-.01em; }
.pcard-head .pnum { margin-left:auto; font-weight: 900; font-size: 1.2rem; }
.pbingo { display:grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.pbingo .phead {
  aspect-ratio: 2.2 / 1; display:grid; place-items:center; color:#fff; background:#111;
  font-weight: 900; font-size: 1.5rem; border-radius: 6px;
}
.pcell {
  aspect-ratio: 1; border: 2px solid #111; border-radius: 6px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding: 4px; gap: 2px; overflow:hidden;
}
.pcell .pt { font-weight: 800; font-size: .74rem; line-height: 1.08; }
.pcell .pa { font-size: .6rem; color: #555; line-height: 1; }
.pcell.pfree { background: #111; color:#fff; }
.pcell.pfree .pt { font-size: .95rem; }
.pfoot { margin-top: 10px; text-align:center; font-size: .72rem; color:#444; font-weight:600; letter-spacing:.02em; }

@media print {
  body { background: #fff !important; }
  .no-print { display: none !important; }
  .wrap { max-width: none; margin: 0; padding: 0; }
  .print-area { background: #fff; padding: 0; }
  .sheet { box-shadow: none; margin: 0; padding: 10mm; page-break-after: always; border-radius: 0; max-width: none; }
  .sheet:last-child { page-break-after: auto; }
  .pcard { border-color:#000; }
}

/* ---------- Music player ---------- */
/* Top player bar (dark, full-width) */
.player-bar {
  display: grid; grid-template-columns: 84px 1fr; gap: 16px; align-items: center;
  background: linear-gradient(180deg, #060512, #0d0b22);
  border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 16px 20px; margin-bottom: 20px;
}
.pb-art {
  width: 84px; height: 84px; border-radius: 12px; overflow: hidden; background: var(--card2);
  display: grid; place-items: center; position: relative;
}
.pb-art img { width: 100%; height: 100%; object-fit: cover; }
.pb-art .art-fallback { font-size: 2.2rem; opacity: .5; }
.pb-art .eq { position:absolute; bottom:7px; left:7px; display:flex; gap:2px; align-items:flex-end; height:18px; }
.pb-art .eq span { width:3px; background: var(--cyan); border-radius:2px; animation: eqb 0.9s ease-in-out infinite; }
.pb-art .eq span:nth-child(2){ animation-delay:.15s } .pb-art .eq span:nth-child(3){ animation-delay:.3s } .pb-art .eq span:nth-child(4){ animation-delay:.45s }
@keyframes eqb { 0%,100%{height:4px} 50%{height:16px} }
.player-bar.paused .eq { opacity: 0; }

.pb-title { font-size: 1.25rem; font-weight: 800; line-height: 1.1; }
.pb-sub { color: var(--muted); font-size: .85rem; margin-top: 2px; }
.pb-sub b { color: var(--cyan); font-weight: 700; }

.pb-seekrow { display:flex; align-items:center; gap: 12px; margin: 12px 0 10px; }
.pb-seekrow .t { color: var(--muted); font-size: .8rem; font-variant-numeric: tabular-nums; min-width: 34px; }

/* range sliders (seek + volume) */
input[type="range"].rng {
  -webkit-appearance: none; appearance: none; height: 6px; border-radius: 999px;
  background: var(--card2); cursor: pointer; outline: none;
}
input[type="range"].rng.seek { flex: 1; background: linear-gradient(90deg, var(--pink), var(--purple)) no-repeat; background-size: var(--fill, 0%) 100%; background-color: var(--card2); }
input[type="range"].rng::-webkit-slider-thumb {
  -webkit-appearance: none; width: 15px; height: 15px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,.5); cursor: pointer;
}
input[type="range"].rng::-moz-range-thumb { width: 15px; height: 15px; border:none; border-radius: 50%; background:#fff; cursor:pointer; }

.pb-controls { display:flex; align-items:center; gap: 12px; flex-wrap: wrap; }
.tbtn {
  width: 46px; height: 46px; border-radius: 50%; border: 2px solid var(--border);
  background: var(--card2); color: var(--ink); font-size: 1.05rem; cursor: pointer; display:grid; place-items:center;
  transition: .12s; flex: none;
}
.tbtn:hover { border-color: var(--purple); }
.tbtn.play { width: 56px; height: 56px; font-size: 1.35rem; border: none; background: linear-gradient(135deg, var(--pink), var(--purple)); box-shadow: 0 6px 18px rgba(255,45,149,.4); }
.tbtn.sm { width: 40px; height: 40px; font-size: .95rem; }
.tbtn.sel { border-color: var(--cyan); color: var(--cyan); }
.pb-vol { display:flex; align-items:center; gap: 8px; }
.pb-vol .vol-slider { width: 90px; }
.pb-spacer { flex: 1; }
.seg { display:flex; border:2px solid var(--border); border-radius: 10px; overflow:hidden; }
.seg button { background: var(--card2); border:none; color: var(--muted); padding: 8px 12px; cursor:pointer; font-family:inherit; font-weight:700; }
.seg button.sel { background: var(--purple); color:#fff; }

/* Full-width tracklist */
.tracklist-head { display:flex; justify-content:space-between; align-items:center; margin: 4px 2px 10px; flex-wrap:wrap; gap:8px; }
.tracklist-head .pl-label { display:flex; align-items:center; gap:8px; font-weight:800; font-size:1.05rem; }
.tracklist-head .pl-label .note { color: var(--purple); font-size:1.2rem; }
.tracklist-head .count { color: var(--muted); }
.tracklist-head .count b { color: var(--cyan); font-size: 1.05rem; }

.tracklist {
  border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden;
  background: var(--bg2);
}
.track {
  display:flex; align-items:center; gap: 14px; width:100%; text-align:left;
  border: none; border-bottom: 1px solid rgba(255,255,255,.05);
  background: transparent; color: var(--ink); font-family: inherit;
  padding: 13px 18px; cursor: pointer; transition: background .1s;
}
.track:last-child { border-bottom: none; }
.track:hover { background: rgba(255,255,255,.04); }
.track .tnote { color: var(--purple); font-size: 1.1rem; flex:none; width: 18px; }
.track .tname { min-width:0; white-space: nowrap; overflow:hidden; text-overflow: ellipsis; font-size: 1.02rem; }
.track .tname b { font-weight: 700; }
.track .tname .tsep { color: var(--muted); font-weight: 400; }
.track .tname .tartist { color: var(--muted); }
.track .tstatus { margin-left:auto; flex:none; font-size: 1.05rem; }

/* PLAYED — strong filled band so a caller can scan-verify a bingo at a glance */
.track.played { background: rgba(203, 108, 120, .38); }
.track.played:hover { background: rgba(203, 108, 120, .46); }
.track.played .tnote { color: #f7c9d2; }
.track.played .tname, .track.played .tname .tartist, .track.played .tname .tsep { color: #fff; }
.track.played .tstatus { color: #ffd7de; }

/* CURRENT — subtle highlight + speaker icon */
.track.current { background: rgba(255,255,255,.09); box-shadow: inset 3px 0 0 var(--pink); }
.track.current .tstatus { color: var(--pink); }

.status-note { color: var(--muted); font-size: .85rem; margin: 10px 2px 0; }
.util-bar {
  display:flex; align-items:center; gap: 12px; flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(34,224,214,.12), rgba(138,75,255,.12));
  border: 1px solid var(--border); border-radius: 12px; padding: 12px 16px; margin-bottom: 14px;
}
.util-bar .ub-title { font-weight: 700; }

/* Tonight's-shift bar */
.shift-bar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(138,75,255,.14), rgba(34,224,214,.10));
  border: 1px solid var(--purple); border-radius: 14px; padding: 12px 18px; margin-bottom: 18px;
  font-weight: 600;
}
.shift-bar b { color: var(--cyan); }
.picker-item.sel-tonight { border-color: var(--cyan); box-shadow: 0 0 0 2px rgba(34,224,214,.3); }
.picker-item .pcheck { margin-left: auto; flex: none; font-size: 1.05rem; color: var(--cyan); }

/* Resume-game banner */
.resume-banner {
  display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(255,210,63,.14), rgba(255,45,149,.10));
  border: 1px solid var(--gold); border-radius: 14px; padding: 14px 18px; margin-bottom: 18px;
  font-weight: 600;
}
.resume-banner b { color: var(--gold); }

/* Movie-mode caller */
.movie-bar {
  background: linear-gradient(180deg, #0b0a1f, #14122e);
  border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 22px 24px; margin-bottom: 20px; text-align: center;
}
.movie-bar .mb-label { color: var(--muted); text-transform: uppercase; letter-spacing: .1em; font-size: .78rem; font-weight: 700; }
.movie-bar .mb-now { font-size: 2.4rem; font-weight: 900; line-height: 1.05; margin: 10px 0 2px;
  background: linear-gradient(90deg, var(--gold), var(--pink)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.movie-bar .mb-sub { color: var(--cyan); font-weight: 700; font-size: 1.05rem; min-height: 1.2em; }
.movie-bar .mb-actions { display:flex; gap: 12px; align-items:center; justify-content:center; flex-wrap: wrap; margin-top: 16px; }

.brand-logo { height: 40px; width: auto; display:block; }
.brand-logo.on-dark { filter: none; }
.pl-select {
  font-family: inherit; font-weight: 700; font-size: .95rem; color: var(--ink);
  background: var(--bg2); border: 2px solid var(--border); border-radius: 10px;
  padding: 9px 12px; cursor: pointer; max-width: 260px;
}
.pl-select:focus { outline: none; border-color: var(--purple); }
.round-pat { display:flex; align-items:center; gap:8px; font-weight:700; font-size:.9rem; color: var(--muted); }
.round-hint { color: var(--muted); font-size:.82rem; margin: -4px 2px 12px; }
.round-hint b { color: var(--cyan); font-weight:700; }

/* ---------- Playlist picker ---------- */
.picker-search {
  width:100%; padding: 13px 16px; font-size: 1.05rem; font-family: inherit;
  border-radius: 12px; border: 2px solid var(--border); background: var(--bg2); color: var(--ink);
  outline: none; margin-bottom: 14px;
}
.picker-search:focus { border-color: var(--purple); }
.picker-list { max-height: 56vh; overflow: auto; }
.picker-cat { text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; font-weight: 800;
  color: var(--purple); margin: 14px 4px 6px; position: sticky; top: 0; background: var(--card); padding: 4px 0; }
.picker-cat:first-child { margin-top: 0; }
.picker-item {
  display:flex; align-items:center; gap: 12px; width:100%; text-align:left; cursor:pointer;
  border: 1px solid var(--border); background: var(--card2); color: var(--ink); font-family: inherit;
  border-radius: 10px; padding: 11px 14px; margin-bottom: 6px; transition: .1s;
}
.picker-item:hover { border-color: var(--purple); transform: translateX(2px); }
.picker-item.active { border-color: var(--pink); box-shadow: 0 0 0 2px rgba(255,45,149,.3); }
.picker-item .pemo { font-size: 1.3rem; flex:none; }
.picker-item .pnm { font-weight: 700; }
.picker-item .pmeta { color: var(--muted); font-size: .8rem; margin-left:auto; flex:none; }
.picker-empty { color: var(--muted); text-align:center; padding: 24px; }

/* ---------- Winner verification modal ---------- */
.modal-overlay {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(4, 3, 14, .72); backdrop-filter: blur(4px);
  display: grid; place-items: center; padding: 20px;
}
.vmodal {
  width: 100%; max-width: 560px; max-height: 92vh; overflow: auto;
  background: linear-gradient(180deg, var(--card), var(--bg2));
  border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 22px;
}
.vmodal-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom: 16px; }
.vclose {
  width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--border);
  background: var(--card2); color: var(--ink); font-size: 1rem; cursor: pointer; flex:none;
}
.vclose:hover { border-color: var(--pink); }
.vcontrols { display:grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 16px; }
@media (max-width: 480px) { .vcontrols { grid-template-columns: 1fr; } }
.vcontrols select {
  width: 100%; padding: 13px 14px; font-size: 1rem; font-family: inherit;
  border-radius: 12px; border: 2px solid var(--border); background: var(--bg2); color: var(--ink);
}

.vverdict { border-radius: 12px; padding: 14px 16px; font-weight: 800; text-align:center; margin-bottom: 16px; font-size: 1.05rem; }
.vverdict.muted { background: var(--bg2); color: var(--muted); font-weight: 600; }
.vverdict.win { background: linear-gradient(135deg, var(--green), #17b978); color: #04241a; }
.vverdict.nowin { background: rgba(255,45,149,.14); color: var(--ink); border: 1px solid var(--pink); }

.vgrid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.vcell {
  aspect-ratio: 1; border-radius: 10px; background: var(--card2); border: 1px solid var(--border);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding: 4px; gap: 2px; overflow:hidden;
}
.vcell .vt { font-size: .62rem; font-weight: 700; line-height: 1.05; }
.vcell .va { font-size: .52rem; color: var(--muted); line-height: 1; }
.vcell.played { background: linear-gradient(135deg, var(--green), #17b978); color:#04241a; border-color: transparent; }
.vcell.played .va { color: rgba(4,36,26,.7); }
.vcell.win { box-shadow: 0 0 0 3px var(--gold); }
.vlegend { display:flex; gap: 6px; align-items:center; justify-content:center; color: var(--muted); font-size: .8rem; margin-top: 14px; }
.vlegend .dot { width: 12px; height: 12px; border-radius: 4px; display:inline-block; }
.vlegend .dot.played { background: var(--green); }
.vlegend .dot.win { background: var(--gold); }
