:root{
  --bg:#14110c; --panel:#1f1a12; --line:#3a3120; --ink:#e8e0cf;
  --muted:#9a8f76; --accent:#c8a04a; --good:#6fbf73; --hot:#e0563b;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--accent)}
.wrap{max-width:920px;margin:0 auto;padding:18px}
h1,h2{font-weight:800;letter-spacing:.3px;margin:.2em 0}
.brand{color:var(--accent);text-transform:uppercase}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;margin:14px 0}
.muted{color:var(--muted)}
button{font:inherit;font-weight:700;cursor:pointer;border:0;border-radius:8px;padding:10px 14px;background:var(--accent);color:#1a1407}
button.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
button:disabled{opacity:.4;cursor:not-allowed}
input,select{font:inherit;background:#100d09;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:10px}
label{display:block;margin:8px 0 4px;color:var(--muted);font-size:.85rem}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.pill{display:inline-block;padding:3px 9px;border-radius:999px;background:#2a2316;border:1px solid var(--line);font-size:.78rem}

/* bingo grid */
.grid{display:grid;gap:6px;margin-top:10px}
.cell{position:relative;aspect-ratio:1;border:1px solid var(--line);border-radius:8px;background:#0d0b07;
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.cell img{width:100%;height:100%;object-fit:contain;padding:6px;transition:.2s}
.cell .cap{position:absolute;bottom:0;left:0;right:0;font-size:.6rem;text-align:center;background:rgba(0,0,0,.6);padding:1px 2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cell.free{background:#241d10}
.cell.free::after{content:"FREE";color:var(--accent);font-weight:800}
.cell.marked{box-shadow:inset 0 0 0 3px var(--good)}
.cell.marked img{filter:grayscale(.15) brightness(1.05)}
.cell.marked::before{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(111,191,115,.35),transparent 70%)}
.cell.called-now{box-shadow:inset 0 0 0 3px var(--accent)}

.toast{position:fixed;top:14px;left:50%;transform:translateX(-50%);background:#2a2316;border:1px solid var(--accent);
  padding:10px 16px;border-radius:10px;z-index:50;opacity:0;transition:.3s}
.toast.show{opacity:1}
.win-banner{font-size:clamp(28px,7vw,72px);font-weight:900;color:var(--accent);text-shadow:0 2px 24px rgba(200,160,74,.6)}

/* gm tile picker */
.tilelist{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;max-height:60vh;overflow:auto;margin-top:8px}
.tilebtn{background:#0d0b07;border:1px solid var(--line);border-radius:8px;padding:6px;color:var(--ink);text-align:center}
.tilebtn img{width:100%;height:58px;object-fit:contain}
.tilebtn .n{font-size:.62rem;display:block;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tilebtn.called{outline:2px solid var(--good);opacity:.55}
.tilebtn.cat-location{border-color:#3a4a6a}

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