:root{color:#101828;font-synthesis:none;text-rendering:optimizelegibility;background:#fff7ed;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{color:#fff;cursor:pointer;background:#0f766e;border:0;border-radius:8px;padding:.78rem 1rem;font-weight:800}button:hover{filter:brightness(1.05)}button:disabled{cursor:not-allowed;opacity:.55}button.primary{background:#e11d48}button.danger{background:#9f1239}button.ghost{background:#ffffff2e;border:1px solid #ffffff73}button.active,.toolbar button.active,.segmented button.active{color:#111827;background:#facc15}.app-shell{background:linear-gradient(135deg,#fff7ed 0%,#ccfbf1 45%,#fee2e2 100%);min-height:100vh}.topbar{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff7ede6;border-bottom:1px solid #0f766e2e;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem clamp(1rem,4vw,2rem);display:flex;position:sticky;top:0}.topbar nav{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.brand{color:#9f1239;background:0 0;padding-inline:0;font-size:1.2rem}.home-screen,.page,.game-layout{width:min(1180px,100% - 2rem);margin:0 auto;padding:1.5rem 0 3rem}.hero-band{color:#fff;background:linear-gradient(125deg,#e11d48 0%,#f97316 42%,#0f766e 100%);border-radius:0 0 28px 28px;grid-template-columns:1.3fr .7fr;align-items:center;gap:1.5rem;min-height:46vh;padding:clamp(1.25rem,5vw,3rem);display:grid;overflow:hidden}.hero-band h1{margin:0;font-size:clamp(2.4rem,8vw,5.8rem);line-height:.95}.hero-band p{max-width:56ch;font-size:clamp(1rem,2vw,1.35rem)}.eyebrow{text-transform:uppercase;letter-spacing:0;font-size:.82rem;font-weight:900}.hero-ball{aspect-ratio:1;color:#9f1239;background:#facc15;border-radius:50%;justify-self:center;place-items:center;width:min(34vw,260px);font-size:clamp(4rem,14vw,9rem);font-weight:1000;display:grid;box-shadow:0 24px 80px #11182742}.home-actions{grid-template-columns:repeat(5,minmax(0,1fr));gap:.8rem;margin-top:1rem;display:grid}.home-actions button{min-height:5rem;font-size:1.1rem}.ball-stage{text-align:center;justify-items:center;gap:.65rem;padding:1.5rem;display:grid}.current-ball{aspect-ratio:1;color:#fff;text-shadow:0 5px #0000002e;background:linear-gradient(160deg,#facc15 0 54%,#e11d48 55% 100%);border-radius:50%;place-items:center;width:clamp(160px,32vw,300px);font-size:clamp(4.8rem,14vw,10rem);font-weight:1000;display:grid;box-shadow:0 24px 65px #e11d4859}.ball-stage strong{font-size:clamp(1.4rem,4vw,2.3rem)}.mini-balls-strip{justify-content:center;align-items:center;gap:.55rem;min-height:3.2rem;margin-top:-.25rem;display:flex}.mini-ball{aspect-ratio:1;color:#fff;text-shadow:0 2px #0000002e;background:linear-gradient(160deg,#facc15 0 54%,#e11d48 55% 100%);border-radius:50%;place-items:center;width:2.8rem;font-size:1.05rem;font-weight:1000;display:grid;box-shadow:0 8px 22px #e11d4838}.mini-ball-placeholder{color:#475467;border:1px dashed #0f766e59;border-radius:999px;padding:.45rem .9rem;font-weight:800}.tv-mode .mini-ball-placeholder{color:#fff;border-color:#ffffff73}.controls,.toolbar,.segmented,.tv-actions{flex-wrap:wrap;justify-content:center;gap:.65rem;display:flex}.controls{margin-bottom:.5rem;padding-bottom:1.25rem}.controls button{min-width:7rem}.status-strip{flex-wrap:wrap;justify-content:center;gap:.75rem;margin:1rem 0;font-weight:800;display:flex}.status-strip span{background:#ffffffbf;border:1px solid #0f766e2e;border-radius:999px;padding:.55rem .8rem}.content-grid{grid-template-columns:minmax(0,2fr) minmax(260px,.8fr);align-items:start;gap:1rem;display:grid}.content-grid.three{grid-template-columns:minmax(0,1.4fr) minmax(260px,.8fr) minmax(240px,.7fr)}.panel{background:#ffffffdb;border:1px solid #0f766e2e;border-radius:8px;padding:1rem;box-shadow:0 14px 38px #0f172a14}.panel.wide{width:100%}.panel-header{justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1rem;display:flex}.panel h2{margin:0;font-size:1.2rem}.panel-header span{color:#475467;font-weight:700}.number-grid{gap:.35rem;display:grid}.grid-90{grid-template-columns:repeat(10,minmax(0,1fr))}.number-cell{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;place-items:center;min-height:2.2rem;font-weight:900;display:grid}.number-cell.drawn{color:#fff;background:#0f766e;border-color:#0f766e}.history-list{flex-wrap:wrap;gap:.45rem;display:flex}.history-ball{aspect-ratio:1;color:#9f1239;background:#fee2e2;border-radius:50%;place-items:center;width:2.55rem;font-weight:1000;display:grid}.bingo75-board{grid-template-columns:repeat(5,minmax(0,1fr));gap:.45rem;display:grid}.bingo75-column{gap:.3rem;display:grid}.bingo75-column strong{text-align:center;color:#fff;background:#e11d48;border-radius:8px;padding:.5rem}.pattern-preview{grid-template-columns:repeat(5,1fr);gap:.35rem;margin-bottom:1rem;display:grid}.pattern-cell{aspect-ratio:1;background:#e2e8f0;border-radius:6px}.pattern-cell.active{background:#facc15;border:2px solid #9f1239}.segmented{justify-content:flex-start}.segmented button{background:#0f766e;font-size:.9rem}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.settings-grid label{gap:.45rem;font-weight:800;display:grid}.settings-grid input[type=range],.settings-grid select,.toolbar input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:.6rem}.toggle-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;padding:.8rem;display:flex!important}.toggle-row input{width:1.35rem;height:1.35rem}.cards-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem;margin-top:1rem;display:grid}.bingo-card{break-inside:avoid;background:#fff;border:2px solid #0f766e;border-radius:8px;padding:.85rem}.bingo-card strong{margin-bottom:.5rem;display:block}.card90,.card75,.card-letters{gap:.25rem;display:grid}.card90{grid-template-columns:repeat(9,1fr)}.card75,.card-letters{grid-template-columns:repeat(5,1fr)}.card90 span,.card75 span,.card-letters span{background:#f8fafc;border:1px solid #e2e8f0;border-radius:5px;place-items:center;min-height:2rem;font-weight:800;display:grid}.card-letters span{color:#fff;background:#e11d48}.tv-mode{color:#fff;background:radial-gradient(circle at 50% 0,#f97316 0 18%,#0000 19%),linear-gradient(135deg,#111827,#0f766e 48%,#9f1239);place-items:center;gap:1rem;min-height:100vh;padding:1rem;display:grid}.tv-mode .panel{color:#fff;background:#ffffff29;border-color:#ffffff4d;width:min(100%,900px)}.tv-mode .panel-header span{color:#fff}.exit-tv{position:fixed;top:1rem;right:1rem}@media (width<=860px){.hero-band,.content-grid,.content-grid.three,.settings-grid{grid-template-columns:1fr}.home-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-90{grid-template-columns:repeat(6,minmax(0,1fr))}.topbar{flex-direction:column;align-items:flex-start}}@media print{.topbar,.toolbar{display:none}.app-shell{background:#fff}.panel{box-shadow:none;border:0}}.history-panel .history-list{align-content:flex-start;max-height:42vh;overflow-y:auto}.history-panel .history-ball{flex:none}.bingo-card-75{color:#fff;width:min(100%,238px);box-shadow:none;background:#0f766e;border:6px solid #0f766e;border-radius:0;justify-self:center;padding:.45rem .45rem .35rem;position:relative;overflow:hidden}.bingo-card-75 .card-letters{grid-template-columns:repeat(5,1fr);gap:0;margin:0 0 .35rem;display:grid}.bingo-card-75 .card-letters span{color:#fff;background:0 0;border:0;border-radius:0;place-items:center;min-height:2rem;font-size:1.8rem;font-weight:1000;line-height:1;display:grid}.bingo-card-75 .card75{z-index:1;background:#0f766e;border:1px solid #0f766e;grid-template-columns:repeat(5,1fr);gap:1px;display:grid;position:relative}.bingo-card-75 .card75 span{aspect-ratio:1;color:#050505;background:#fff;border:0;border-radius:0;place-items:center;min-height:0;font-size:1.7rem;font-weight:1000;line-height:1;display:grid}.bingo-card-75 .free-cell i{aspect-ratio:1;background:radial-gradient(circle at 34% 28%,#fff 0 12%,#facc15 13% 48%,#e11d48 49% 100%);border-radius:50%;width:62%;display:block;box-shadow:inset 0 -.12rem #00000024}@media print{.bingo-card-75{width:2.5in}}.tv-link-panel{background:#ffffffdb;border:1px solid #0f766e38;border-radius:8px;gap:.55rem;width:min(100%,420px);margin:1rem auto 0;padding:.85rem;display:grid;box-shadow:0 10px 28px #0f172a14}.tv-link-panel div{justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.tv-link-panel strong{font-size:1rem}.tv-link-panel span{color:#475467;font-size:.9rem;font-weight:800}.tv-link-code{color:#fff;letter-spacing:.12em;background:#0f766e;border-radius:8px;place-items:center;min-height:3.1rem;font-size:2rem;line-height:1;display:grid}.tv-link-panel input{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:.65rem;font-weight:900}.tv-link-panel button{width:100%;padding:.65rem .8rem}.side-stack{align-content:start;gap:1rem;display:grid}.linked-tv{align-content:stretch;justify-items:stretch;gap:0;width:100vw;height:100vh;padding:clamp(4.25rem,6vh,5.25rem) clamp(1rem,2vw,2.5rem) clamp(1rem,2vw,2.5rem);overflow:hidden}.linked-tv-layout{grid-template-columns:minmax(340px,40fr) minmax(520px,60fr);align-items:start;gap:clamp(1rem,2vw,2rem);width:100%;height:100%;display:grid}.linked-tv-current{align-content:start;justify-items:center;min-width:0;display:grid}.linked-tv .ball-stage{text-align:center;justify-items:center;gap:clamp(.55rem,1.4vh,1rem);width:min(100%,620px);padding:0}.linked-tv .eyebrow{font-size:clamp(.95rem,1.25vw,1.35rem)}.linked-tv .current-ball{width:clamp(210px,28vw,430px);max-width:min(100%,48vh);font-size:clamp(5.2rem,12vw,11rem);box-shadow:0 20px 58px #e11d4847}.linked-tv .ball-stage strong{max-width:100%;font-size:clamp(2rem,3.4vw,4.2rem);line-height:1.05}.linked-tv .mini-balls-strip{display:none}.linked-tv .mini-ball{width:clamp(4rem,6.2vh,5.6rem);font-size:clamp(1.35rem,2.1vh,2rem)}.linked-tv .panel{width:100%;height:100%;margin:0;padding:clamp(1rem,1.8vw,1.7rem);overflow:hidden}.linked-tv .panel-header h2{font-size:clamp(1.55rem,2vw,2.5rem)}.linked-tv .panel-header span{font-size:clamp(1.15rem,1.45vw,1.8rem)}.linked-tv .history-list{grid-template-columns:repeat(auto-fill,minmax(clamp(2rem,3vh,3.4rem),1fr));align-content:start;gap:clamp(.3rem,.5vw,.6rem);height:calc(100% - clamp(3rem,5vh,4.8rem));max-height:none;padding-right:.2rem;display:grid;overflow-y:auto}.linked-tv .history-ball{justify-self:center;width:100%;max-width:3.4rem;font-size:clamp(1rem,1.4vw,1.5rem)}.tv-code{z-index:2;color:#fff;background:#ffffff24;border:1px solid #ffffff73;border-radius:999px;padding:.45rem .8rem;font-weight:1000;position:fixed;top:1rem;left:1rem}.tv-audio-button{z-index:2;position:fixed;top:1rem;right:1rem}.tv-connection{z-index:2;color:#111827;background:#facc15eb;border-radius:999px;padding:.45rem .8rem;font-weight:1000;position:fixed;top:1rem;left:50%;transform:translate(-50%)}@media (width<=720px){.tv-link-panel{width:100%}.linked-tv{height:auto;min-height:100vh;overflow:auto}.linked-tv-layout{grid-template-columns:1fr;height:auto}.linked-tv .panel{min-height:40vh}}.pwa-page{gap:1rem;display:grid}.pwa-hero{color:#fff;background:linear-gradient(125deg,#e11d48 0%,#f97316 48%,#0f766e 100%);border:0;gap:.8rem;display:grid}.pwa-hero h1{margin:0;font-size:clamp(2.2rem,7vw,5.4rem);line-height:.95}.pwa-hero p{max-width:62ch;margin:0;font-size:clamp(1rem,2vw,1.25rem);font-weight:700}.pwa-actions{flex-wrap:wrap;gap:.65rem;margin-top:.35rem;display:flex}.pwa-status-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.pwa-status-card{align-content:center;gap:.4rem;min-height:7rem;display:grid}.pwa-status-card strong{color:#475467;text-transform:uppercase;font-size:.9rem}.pwa-status-card span{color:#101828;font-size:clamp(1.35rem,3vw,2rem);font-weight:1000}.pwa-note{gap:.35rem;display:grid}.pwa-note p{color:#475467;margin:0;font-weight:700}@media (width<=720px){.pwa-status-grid{grid-template-columns:1fr}}
