/* BingoBongo — shared styles (adapted from the design mockup) */
:root{
  --plum:#2b1b45; --plum-2:#3d2a5e;
  --coral:#ff5d7a; --coral-d:#e8375a;
  --lime:#8ede5a; --lime-d:#5bbd2e;
  --gold:#ffce4a; --sky:#4ec5ff;
  --cream:#fbf6ee; --ink:#241735; --muted:#8a7fa0; --line:#eadff0;
  --shadow:0 10px 30px rgba(43,27,69,.14);
  --radius:20px;
  --font-h:'Fredoka',system-ui,sans-serif;
  --font-b:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--font-b);color:var(--ink);min-height:100vh;
  background:
    radial-gradient(900px 500px at 90% -10%, rgba(255,93,122,.18), transparent 60%),
    radial-gradient(800px 500px at -10% 110%, rgba(78,197,255,.16), transparent 60%),
    var(--cream);
}
h1,h2,h3,h4{font-family:var(--font-h);margin:0;letter-spacing:.2px}
a{color:var(--coral-d)}
.wrap{max-width:1240px;margin:0 auto;padding:20px}

/* logo */
.logo{display:flex;align-items:center;gap:12px}
.logo .ball{
  width:46px;height:46px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-family:var(--font-h);font-weight:700;color:#fff;font-size:20px;
  background:radial-gradient(circle at 32% 28%, #ff8fa4, var(--coral) 55%, var(--coral-d));
  box-shadow:inset 0 -4px 8px rgba(0,0,0,.18), 0 6px 14px rgba(232,55,90,.4);
}
.logo h1{font-size:26px;line-height:1}
.logo .tag{font-size:12px;color:var(--muted);font-weight:600;margin-top:2px;letter-spacing:.3px}

/* buttons */
.btn{font-family:var(--font-h);font-weight:600;font-size:15px;cursor:pointer;border:none;border-radius:14px;padding:12px 18px;color:#fff}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important}
.btn.primary{background:var(--coral);box-shadow:0 5px 0 var(--coral-d)}
.btn.go{background:var(--lime-d);box-shadow:0 5px 0 #489a24}
.btn.warn{background:var(--gold);color:var(--plum);box-shadow:0 5px 0 #d9a922}
.btn.hold{background:var(--sky);color:var(--plum);box-shadow:0 5px 0 #2a9fd6}
.btn.ghost{background:#fff;color:var(--plum);box-shadow:0 0 0 2px var(--line)}
.btn.sm{font-size:13.5px;padding:9px 13px;border-radius:11px}

/* ===== NEW GAME FORM ===== */
.setup-card{max-width:460px;margin:8vh auto 0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}
.setup-card h2{font-size:22px;margin-bottom:4px;color:var(--plum)}
.setup-card p.sub{color:var(--muted);font-size:14px;margin:0 0 18px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:13px;margin-bottom:6px;color:var(--plum)}
.field input[type=text],.field input[type=number],.field select{
  width:100%;border:2px solid var(--line);border-radius:12px;padding:11px 13px;font-family:var(--font-b);font-size:15px;background:#fff;color:var(--ink)
}
.hint{font-size:12.5px;color:var(--muted);margin-top:6px}

/* ===== CALLER (HOST/BOARD) ===== */
.caller-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.code-badge{background:var(--plum);color:#fff;border-radius:14px;padding:8px 16px;font-family:var(--font-h);font-weight:600}
.code-badge b{font-size:22px;letter-spacing:2px;color:var(--gold)}
.status-pill{font-family:var(--font-h);font-weight:600;font-size:13px;padding:6px 13px;border-radius:999px}
.status-pill.running{background:#eafbe2;color:var(--lime-d)}
.status-pill.paused{background:#fff4d6;color:#b78a12}
.status-pill.break{background:#e7f0ff;color:#3f6fd8}
.status-pill.ended{background:#fff0f2;color:var(--coral-d)}
.round-pill{background:#eef4ff;color:#3f6fd8;font-family:var(--font-h);font-weight:600;font-size:13px;padding:6px 13px;border-radius:999px}
.plan-list{margin:6px 0 0;padding-left:20px;color:var(--ink);font-size:13.5px;line-height:1.7}
.plan-list li{font-family:var(--font-h);font-weight:500}
.round-rows{display:flex;flex-direction:column;gap:8px;max-height:44vh;overflow-y:auto}
.round-row{display:flex;align-items:center;gap:8px}
.round-row .rn{font-family:var(--font-h);font-weight:600;font-size:11.5px;color:var(--muted);min-width:56px}
.round-row select,.round-row input{flex:1;min-width:0;margin:0}
.round-row .rm-round{flex:none;border:none;background:var(--line);color:var(--plum);width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:17px;line-height:1}
.play-round{margin-top:4px;font-family:var(--font-h);font-weight:600;font-size:13px;opacity:.95}
.controls{display:flex;gap:9px;flex-wrap:wrap;margin-left:auto;align-items:center}
.controls .ivl{display:flex;align-items:center;gap:6px;background:#fff;border-radius:12px;padding:6px 10px;box-shadow:0 0 0 2px var(--line)}
.controls .ivl input{width:52px;border:none;font-family:var(--font-h);font-weight:600;font-size:16px;text-align:center;color:var(--plum)}
.voice-select{max-width:170px;border:2px solid var(--line);border-radius:11px;padding:8px 10px;font-family:var(--font-b);font-size:13px;background:#fff;color:var(--ink)}
/* fixed control bar at the bottom of the caller page */
.controls-bar{position:fixed;left:0;right:0;bottom:0;margin:0;justify-content:center;background:rgba(255,255,255,.97);box-shadow:0 -6px 22px rgba(43,27,69,.16);padding:12px 16px;z-index:50}
/* bingo claim banner at the top of the caller (stacked list of claims) */
.claim-bar{position:fixed;top:0;left:0;right:0;z-index:60;background:var(--gold);color:var(--plum);padding:10px 16px;box-shadow:0 4px 18px rgba(43,27,69,.25);max-height:62vh;overflow-y:auto}
.claim-bar.won{background:var(--lime)}
.claim-bar b{color:var(--plum)}
.claim-inner{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.claim-head{font-family:var(--font-h);font-weight:700;font-size:15px;text-align:center}
.claim-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;background:rgba(255,255,255,.55);border-radius:12px;padding:8px 12px}
.claim-row .lbl{font-family:var(--font-h);font-weight:600;font-size:14.5px}
.claim-row .acts{display:flex;gap:8px}
/* full-height caller board: fill the viewport, purple board stretches */
.wrap.has-bottom-bar{padding-bottom:92px;min-height:100vh;display:flex;flex-direction:column}
.wrap.has-bottom-bar .caller-grid{flex:1 1 auto;min-height:0;align-items:stretch}
.wrap.has-bottom-bar .side{align-self:start}
.wrap.has-bottom-bar .board{display:flex;flex-direction:column}
/* number tiles grow to fill the full height of the board */
.wrap.has-bottom-bar .board .cols{flex:1 1 auto;grid-auto-rows:1fr;grid-template-columns:clamp(40px,3.5vw,70px) repeat(15,1fr);gap:8px}
.wrap.has-bottom-bar .board .cell{aspect-ratio:auto;font-size:clamp(18px,2vw,40px)}
.wrap.has-bottom-bar .board .rowlabel{font-size:clamp(22px,2.6vw,48px)}
.controls .ivl span{font-size:12px;color:var(--muted);font-weight:600}

.caller-grid{display:grid;grid-template-columns:1fr 300px;gap:18px;align-items:start}
@media(max-width:900px){.caller-grid{grid-template-columns:1fr}}

.board{background:linear-gradient(160deg,var(--plum),var(--plum-2));border-radius:var(--radius);padding:24px;color:#fff;box-shadow:var(--shadow)}
.current{display:flex;align-items:center;gap:22px;margin-bottom:20px;flex-wrap:wrap;min-height:150px}
.big-ball{
  width:150px;height:150px;border-radius:50%;flex:none;display:grid;place-items:center;text-align:center;
  background:radial-gradient(circle at 32% 26%, #ffe08a, var(--gold) 55%, #e9a91f);
  box-shadow:inset 0 -8px 16px rgba(0,0,0,.22), 0 12px 26px rgba(0,0,0,.3);color:var(--plum);
}
.big-ball.empty{background:rgba(255,255,255,.09);box-shadow:none;color:#b8a9d8}
.big-ball .l{font-family:var(--font-h);font-weight:600;font-size:26px;line-height:1}
.big-ball .n{font-family:var(--font-h);font-weight:700;font-size:64px;line-height:.9}
.big-ball.empty .n{font-size:30px}
.current .cap{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:#c9bce8;font-weight:700;margin-bottom:8px}
.recent{display:flex;gap:8px;flex-wrap:wrap}
.recent .mini{min-width:44px;height:44px;padding:0 6px;border-radius:22px;display:grid;place-items:center;font-family:var(--font-h);font-weight:600;font-size:15px;background:rgba(255,255,255,.14)}

.cols{display:grid;grid-template-columns:42px repeat(15,1fr);gap:5px}
.rowlabel{display:grid;place-items:center;font-family:var(--font-h);font-weight:700;color:var(--gold);font-size:22px}
.cell{aspect-ratio:1;border-radius:8px;display:grid;place-items:center;font-size:12.5px;font-weight:600;background:rgba(255,255,255,.08);color:#cdbfea}
.cell.on{background:var(--lime);color:var(--plum);box-shadow:0 3px 0 var(--lime-d)}
.cell.just-called{animation:cellFlash .8s ease}

/* side panel */
.side{display:flex;flex-direction:column;gap:16px}
.panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;text-align:center}
.panel h3{font-size:15px;color:var(--plum);margin-bottom:10px}
#qr{display:flex;justify-content:center}
#qr img,#qr canvas{border-radius:10px}
.join-url{font-size:12px;color:var(--muted);word-break:break-all;margin-top:10px}
.count-big{font-family:var(--font-h);font-weight:700;font-size:40px;color:var(--plum);line-height:1}
.count-lbl{font-size:12.5px;color:var(--muted);font-weight:600}
.pattern-lbl{font-family:var(--font-h);font-weight:600;color:var(--plum)}
.prize-lbl{font-family:var(--font-h);font-weight:700;color:#b78a12;font-size:14px}

/* flash keyframes */
@keyframes ballPop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.14)}100%{transform:scale(1);opacity:1}}
.big-ball.flash{animation:ballPop .55s ease}
@keyframes cellFlash{0%{transform:scale(1)}30%{transform:scale(1.3);box-shadow:0 0 20px rgba(142,222,90,.95),0 3px 0 var(--lime-d)}100%{transform:scale(1)}}

/* ===== PLAYER (PHONE) ===== */
.play-body{max-width:520px;margin:0 auto;padding:0 0 40px}
.play-top{background:linear-gradient(160deg,var(--coral),var(--coral-d));color:#fff;padding:20px 20px 22px;border-radius:0 0 24px 24px;box-shadow:var(--shadow);text-align:center}
.play-top .rm{font-size:12.5px;opacity:.9;font-weight:600}
.play-top h2{font-size:22px;margin-top:3px}
.play-top .pat{margin-top:10px;background:rgba(255,255,255,.2);display:inline-block;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600}
.play-status{margin-top:8px;font-size:12.5px;font-weight:600;opacity:.95}
.play-current{display:flex;flex-direction:column;align-items:center;gap:8px;margin:24px 0}
.play-current .cap{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);font-weight:700}
.play-body .big-ball{width:130px;height:130px}
.play-body .big-ball.empty{background:#efe7f7;color:#b0a4c4;box-shadow:none}
.play-count{text-align:center;color:var(--muted);font-size:13px;font-weight:600;margin-bottom:14px}
.play-sec{padding:0 18px}
.play-label{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);font-weight:700;margin:0 0 10px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips .c{min-width:44px;height:44px;padding:0 8px;border-radius:22px;display:grid;place-items:center;font-family:var(--font-h);font-weight:600;font-size:15px;background:#fff;color:var(--plum);box-shadow:0 3px 8px rgba(43,27,69,.08)}
.chips .c.newest{background:var(--lime);box-shadow:0 3px 0 var(--lime-d);animation:cellFlash .8s ease}
.play-foot{text-align:center;color:var(--muted);font-size:12px;margin-top:26px}

.banner{border-radius:14px;padding:12px 16px;font-weight:600;font-size:14px;text-align:center;margin:14px 18px}
.banner.paused{background:#fff4d6;color:#b78a12}
.banner.break{background:#e7f0ff;color:#3f6fd8}
.banner.ended{background:#fff0f2;color:var(--coral-d)}
.banner.done{background:#eafbe2;color:var(--lime-d)}

.notfound{max-width:420px;margin:12vh auto;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;text-align:center}
.notfound h2{color:var(--plum);font-size:22px;margin-bottom:8px}
.notfound p{color:var(--muted);font-size:14.5px;margin:0}
