/* Setlist Bingo — 1&Dun. Mobile-first, dark honky-tonk palette. */
:root{
  --bg:#161310; --panel:#211c17; --panel2:#2b241d; --ink:#f3ece0; --muted:#b3a690;
  --line:#3a3128; --gold:#e7b14c; --gold-deep:#c8902a;
  --gray:#3a342c; --yellow:#e7b14c; --green:#4f9e58; --green-deep:#357a3d;
  --special:#d96b2b; --red:#c0492f;
  --radius:14px; --shadow:0 4px 18px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(circle at 50% -10%, #2a231b 0%, var(--bg) 60%);
  color:var(--ink); font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; min-height:100vh; line-height:1.4;
}
a{color:var(--gold)}
.wrap{max-width:520px;margin:0 auto;padding:14px 14px 40px}
.wide{max-width:1400px}

/* header */
.brand{display:flex;align-items:center;gap:12px;padding:6px 2px 12px}
.brand img{width:46px;height:46px;border-radius:10px;object-fit:cover;box-shadow:var(--shadow)}
.brand .pick{width:42px;height:42px;display:grid;place-items:center;font-size:26px}
.brand h1{font-size:1.15rem;margin:0;letter-spacing:.5px}
.brand .sub{color:var(--muted);font-size:.8rem;margin-top:2px}
.handle-tag{margin-left:auto;text-align:right;font-size:.78rem;color:var(--muted)}
.handle-tag b{display:block;color:var(--gold);font-size:.95rem}

/* grid */
.board{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin:10px 0;padding:8px;border:2px solid var(--gold);border-radius:14px;box-shadow:0 0 16px 2px rgba(231,177,76,.6),inset 0 0 12px rgba(231,177,76,.12)}
.pickmini{width:1.15em;height:1.15em;border-radius:3px;object-fit:cover;vertical-align:-0.25em;display:inline-block}
.cell{
  position:relative;aspect-ratio:1/1;border-radius:10px;border:1px solid var(--line);
  background:var(--gray);display:grid;place-items:center;text-align:center;
  padding:3px;font-size:.62rem;font-weight:600;color:#d8cdb9;cursor:default;
  overflow:hidden;line-height:1.08;transition:transform .12s,background .25s,box-shadow .2s;
  user-select:none;-webkit-tap-highlight-color:transparent;
}
.cell span{display:block;max-height:100%;overflow:hidden}
.cell.played{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#2a1c05;cursor:pointer;box-shadow:0 0 0 2px rgba(231,177,76,.35)}
.cell.played:active{transform:scale(.95)}
.cell.green{background:linear-gradient(160deg,var(--green),var(--green-deep));color:#eaffea;border-color:#2f6e37}
.cell.center,.cell.gold{padding:0;background:#234d29;border-color:#2f6e37;overflow:hidden}
.cell.gold{box-shadow:0 0 12px rgba(231,177,76,.85)}            /* a freshly-gifted free pick glows */
.cell .pickimg{width:100%;height:100%;object-fit:cover;display:block}
.cell.blocked{background:#000;border-color:#000;color:#fff;cursor:default}
.cell.blocked .guitar{font-size:1.45rem;line-height:1;filter:saturate(.25) brightness(1.3)}
.cell .tick{position:absolute;top:2px;right:4px;font-size:.7rem}
.cell.pulse{animation:pulse .6s ease}
@keyframes pulse{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}

/* banners + buttons */
.banner{border-radius:var(--radius);padding:14px 16px;margin:12px 0;text-align:center;font-weight:700;box-shadow:var(--shadow)}
.banner.win{background:linear-gradient(160deg,var(--green),var(--green-deep));color:#fff;animation:pop .5s ease}
.banner.blackout{background:linear-gradient(160deg,var(--gold),var(--special));color:#2a1500}
.banner.closed{background:var(--panel);color:var(--muted);font-weight:600}
@keyframes pop{0%{transform:scale(.9);opacity:0}100%{transform:scale(1);opacity:1}}
.btn{display:inline-block;border:none;border-radius:10px;padding:11px 16px;font-size:.95rem;font-weight:700;
  background:var(--gold);color:#2a1c05;cursor:pointer;box-shadow:var(--shadow)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:var(--panel2);color:var(--ink);border:1px solid var(--line)}
.btn.red{background:var(--red);color:#fff}
.btn.green{background:var(--green);color:#fff}
.btn.block{display:block;width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}
.row{display:flex;gap:8px;flex-wrap:wrap}
.row.tight{gap:6px}

/* panels / forms */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin:10px 0;box-shadow:var(--shadow)}
.panel h2{font-size:.95rem;margin:0 0 10px;color:var(--gold);letter-spacing:.5px;text-transform:uppercase}
label{display:block;font-size:.78rem;color:var(--muted);margin:8px 0 3px}
input,textarea,select{width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:9px 10px;font-size:.9rem;font-family:inherit}
textarea{min-height:120px;resize:vertical}
.pill{display:inline-block;background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:.75rem;color:var(--muted)}
.stat{display:inline-flex;flex-direction:column;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:8px 14px;min-width:74px}
.stat b{font-size:1.4rem;color:var(--gold)}
.stat span{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* social row */
.social{display:flex;gap:8px;justify-content:center;margin:14px 0 6px;flex-wrap:wrap}
.social a{flex:1;min-width:90px;text-align:center;text-decoration:none;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:9px 6px;color:var(--ink);font-size:.82rem;font-weight:600}
.social a.tip{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#2a1c05}
.follow-cta{background:var(--panel);border:2px solid #2fa8ff;border-radius:var(--radius);padding:10px 12px 12px;margin:4px 0 12px;box-shadow:0 0 16px 2px rgba(47,168,255,.55)}
.follow-head{text-align:center;font-size:1.08rem;font-weight:800;color:var(--gold);letter-spacing:.3px;margin-bottom:6px}
.follow-cta .social{margin:0}

/* winners feed */
.feed{margin-top:14px}
.feed h2{font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:0 0 6px}
.feed ul{list-style:none;margin:0;padding:0;max-height:150px;overflow-y:auto}
.feed li{padding:6px 8px;border-bottom:1px solid var(--line);font-size:.85rem;display:flex;justify-content:space-between;gap:8px}
.feed li b{color:var(--gold)}
.feed li.blackout b{color:var(--special)}
.changeName{display:block;text-align:center;margin:16px 0 4px;font-size:.78rem;color:var(--muted)}

/* admin live song list */
.songlist{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.song{display:flex;align-items:center;justify-content:space-between;gap:6px;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 10px;font-size:.82rem;cursor:pointer}
.song.on{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#2a1c05;font-weight:700}
.song .x{font-size:.7rem;opacity:.7}

/* wall */
.wallgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.minicard{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:7px;box-shadow:var(--shadow);position:relative}
.minicard .mh{font-size:.7rem;color:var(--gold);font-weight:700;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.minicard.win{border:5px solid #ffe600;box-shadow:0 0 22px 4px rgba(255,221,0,.95)}
.minicard.blackout{border:5px solid #ffd000;box-shadow:0 0 32px 8px rgba(255,200,0,1)}
.mini{display:grid;grid-template-columns:repeat(5,1fr);gap:2px}
.mini div{aspect-ratio:1/1;border-radius:3px;background:var(--gray)}
.mini div.played{background:var(--yellow)}
.mini div.green{background:var(--green)}
.mini div.blocked{background:#0a0a0a}
.minicard .badge{position:absolute;top:-8px;right:-6px;font-size:1.1rem}

/* celebration overlay */
.overlay{position:fixed;inset:0;display:none;place-items:center;background:rgba(0,0,0,.6);z-index:50;animation:fade .3s}
.overlay.show{display:grid}
.overlay .card{background:linear-gradient(160deg,var(--panel2),var(--panel));border:2px solid var(--gold);border-radius:18px;padding:26px 24px;max-width:340px;text-align:center;box-shadow:0 10px 40px rgba(0,0,0,.6);animation:pop .4s}
.overlay .big{font-size:2.6rem;margin-bottom:6px}
.overlay .alertpick{width:96px;height:96px;border-radius:14px;object-fit:cover;box-shadow:0 4px 16px rgba(0,0,0,.5)}
.overlay h3{margin:4px 0;color:var(--gold)}
@keyframes fade{from{opacity:0}to{opacity:1}}
.muted{color:var(--muted)}
.center{text-align:center}
.small{font-size:.78rem}
.spacer{height:8px}
.hidden{display:none!important}
.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:var(--panel2);border:1px solid var(--gold);color:var(--ink);padding:10px 16px;border-radius:10px;font-size:.85rem;box-shadow:var(--shadow);z-index:60;opacity:0;transition:opacity .3s}
.toast.show{opacity:1}
