*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--sans);-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--ink);min-height:100vh}button,input,select{font:inherit;color:inherit}button{cursor:pointer}img,svg{display:block;max-width:100%}:root{--paper: #fef3c7;--paper-soft: #fde68a;--paper-dark: #fcd34d;--ink: #2a1810;--ink-soft: #78350f;--stamp: #dc2626;--stamp-deep: #991b1b;--gold: #d4a017;--gold-soft: #f59e0b;--bg: #1a0e08;--bg-soft: #2a1810;--bg-card: #3a2418;--shadow: 0 8px 24px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 48px rgba(0, 0, 0, .55);--serif: "DM Serif Display", "Playfair Display", Georgia, serif;--sans: "Inter", system-ui, -apple-system, sans-serif;--mono: "SF Mono", Menlo, Consolas, monospace}[data-theme=cyberpunk]{--paper: #0f0f23;--paper-soft: #14142b;--paper-dark: #1f1f3a;--ink: #e0fbfc;--ink-soft: #a5f3fc;--stamp: #ff00ff;--stamp-deep: #c026d3;--gold: #00ffff;--gold-soft: #06b6d4;--bg: #050510;--bg-soft: #0a0a14;--bg-card: #14142b;--shadow: 0 0 24px rgba(0, 255, 255, .25);--shadow-lg: 0 0 48px rgba(255, 0, 255, .35);--serif: "JetBrains Mono", "SF Mono", Menlo, monospace}[data-theme=cyberpunk] .app-title{color:#f0f;text-shadow:0 0 6px #ff00ff,0 0 14px rgba(255,0,255,.6),3px 3px 0 #00ffff}[data-theme=cyberpunk] .controls .btn-ghost{color:#0ff;border-color:#0ff;text-shadow:0 0 4px rgba(0,255,255,.6)}[data-theme=cyberpunk] .controls .btn-ghost:hover{background:#00ffff26}[data-theme=cyberpunk] .controls .btn-stamp{background:#f0f;color:#fff;text-shadow:0 0 6px rgba(255,255,255,.5);box-shadow:0 0 16px #f0f9}[data-theme=cyberpunk] .controls label,[data-theme=cyberpunk] .mic-indicator,[data-theme=cyberpunk] .mic-text,[data-theme=cyberpunk] .last-heard{color:#e0fbfc}[data-theme=cyberpunk] .controls select,[data-theme=cyberpunk] .controls input[type=number]{background:#0a0a14;color:#e0fbfc;border-color:#0ff}[data-theme=cyberpunk] .app-badge{color:#0ff;border-color:#0ff;text-shadow:0 0 4px rgba(0,255,255,.5)}[data-theme=cyberpunk] .app-badge-button:hover{background:#0ff;color:#050510;text-shadow:none}[data-theme=cyberpunk] .help-hint{color:#e0fbfc;opacity:1;text-shadow:0 0 4px rgba(0,255,255,.4)}[data-theme=cyberpunk] .help-hint kbd{background:#00ffff1f;border:1px solid #00ffff;color:#0ff;text-shadow:0 0 4px rgba(0,255,255,.6)}body{background:radial-gradient(circle at 20% 0%,rgba(212,160,23,.08),transparent 50%),radial-gradient(circle at 80% 100%,rgba(220,38,38,.05),transparent 60%),var(--bg)}:root:not([data-theme=cyberpunk]) body:before{content:"";position:fixed;inset:0;background-image:image-set(url(/img/bingo-hall-640.webp) type("image/webp") 1x,url(/img/bingo-hall-1280.webp) type("image/webp") 2x,url(/img/bingo-hall.jpg) type("image/jpeg") 1x);background-size:cover;background-position:center;background-repeat:no-repeat;filter:saturate(.95) contrast(1.05) brightness(1.05);opacity:.7;z-index:-2;pointer-events:none}@media (min-width: 900px){:root:not([data-theme=cyberpunk]) body:before{background-image:image-set(url(/img/bingo-hall-1280.webp) type("image/webp") 1x,url(/img/bingo-hall.jpg) type("image/jpeg") 1x)}}:root:not([data-theme=cyberpunk]) body:after{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at center,#1a0e080d,#1a0e088c 70%,#1a0e08d9),linear-gradient(180deg,#78350f14,#1a0e0840);z-index:-1;pointer-events:none}.app{max-width:1400px;margin:0 auto;padding:32px 24px 80px}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;color:var(--paper);gap:24px;flex-wrap:wrap}.app-title-block{display:flex;flex-direction:column;gap:4px}.app-title{font-family:var(--serif);font-size:clamp(34px,4.5vw,52px);margin:0;letter-spacing:.01em;color:var(--paper);text-shadow:3px 3px 0 var(--stamp),6px 6px 0 var(--ink-soft);line-height:1}.app-subtitle{opacity:.65;font-size:13px;letter-spacing:.02em;font-style:italic}.app-badge{font-family:var(--serif);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:6px 14px;border-radius:999px;white-space:nowrap}.app-badge-button{background:transparent;cursor:pointer;transition:background .15s,color .15s}.app-badge-button:hover{background:var(--gold);color:var(--ink)}.controls{display:flex;gap:14px;flex-wrap:wrap;background:var(--bg-soft);border:1px solid rgba(212,160,23,.4);border-radius:14px;padding:16px 18px;margin-bottom:24px;color:var(--paper);align-items:center;box-shadow:var(--shadow)}.controls-group{display:flex;align-items:center;gap:8px}.controls label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.75;display:flex;align-items:center;gap:8px;white-space:nowrap}.controls select,.controls input[type=number]{background:var(--bg);color:var(--paper);border:1px solid rgba(212,160,23,.5);border-radius:6px;padding:6px 10px;font-size:13px;outline:none}.controls select:focus,.controls input[type=number]:focus{border-color:var(--gold);box-shadow:0 0 0 2px #d4a01733}.controls input[type=number]{width:64px}.controls input[type=checkbox]{accent-color:var(--gold)}.btn{background:var(--gold);color:var(--ink);border:none;border-radius:6px;padding:8px 14px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-family:var(--sans);transition:filter .15s,transform .15s,box-shadow .15s}.btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #d4a01766}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;filter:none}.btn.btn-stamp{background:var(--stamp);color:var(--paper)}.btn.btn-stamp:hover{box-shadow:0 4px 12px #dc262680}.btn-start{padding:12px 22px;font-size:14px;letter-spacing:.1em;box-shadow:0 4px 16px #dc262659;position:relative}.btn-start:before{content:"🎙";margin-right:6px}.btn.btn-ghost{background:transparent;color:var(--paper);border:1px solid rgba(212,160,23,.6)}.btn.btn-ghost:hover{background:#d4a0171f}.cards-grid{display:grid;gap:24px}.cards-grid[data-count="1"]{grid-template-columns:minmax(0,600px);justify-content:center}.cards-grid[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}.cards-grid[data-count="3"]{grid-template-columns:repeat(3,minmax(0,1fr))}.cards-grid[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))}.cards-grid[data-count="5"],.cards-grid[data-count="6"]{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 800px){.cards-grid[data-count="2"],.cards-grid[data-count="3"],.cards-grid[data-count="4"],.cards-grid[data-count="5"],.cards-grid[data-count="6"]{grid-template-columns:minmax(0,1fr)}}.mic-indicator{display:inline-flex;align-items:center;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--paper);opacity:.85;padding:4px 10px;border-radius:999px;background:#0000004d}.mic-dot{width:9px;height:9px;border-radius:50%;background:#555;transition:background .2s}.mic-indicator[data-state=listening] .mic-dot{background:var(--stamp);box-shadow:0 0 8px var(--stamp);animation:breathe 1.6s ease-in-out infinite}.mic-indicator[data-state=error] .mic-dot{background:var(--gold-soft)}.mic-indicator[data-state=loading] .mic-dot{background:var(--gold);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes breathe{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.transcript-row{height:28px;margin:8px 0 16px;display:flex;align-items:center;justify-content:center;overflow:hidden}.last-heard{font-family:var(--mono);font-size:13px;color:var(--paper);opacity:0;max-width:min(900px,90vw);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .4s ease;font-style:italic;text-align:center}.last-heard.show{opacity:.78}.controls-status{display:flex;align-items:center;gap:12px}.cards-slot{position:relative;min-height:200px}.onboard-overlay{position:absolute;inset:-8px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;pointer-events:none;z-index:10;padding-top:40px;background:linear-gradient(180deg,#1a0e088c,#1a0e08d9 60%,#1a0e08f2);backdrop-filter:blur(2px);border-radius:14px;transition:opacity .4s ease}.onboard-overlay.hidden{opacity:0;pointer-events:none}.onboard-arrow{font-size:60px;color:var(--gold);animation:bobUp 1.2s ease-in-out infinite;text-shadow:0 4px 12px rgba(212,160,23,.6)}@keyframes bobUp{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.onboard-text{font-family:var(--serif);color:var(--paper);font-size:clamp(20px,2.4vw,28px);margin-top:8px}.onboard-sub{font-size:13px;color:var(--paper);opacity:.6;font-style:italic;margin-top:4px}.onboard-progress{display:none;flex-direction:column;align-items:center;gap:8px;width:min(420px,80vw);margin-top:24px}.onboard-progress-bar{width:100%;height:10px;background:#d4a0172e;border:1px solid rgba(212,160,23,.45);border-radius:999px;overflow:hidden}.onboard-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--gold),var(--stamp));border-radius:999px;transition:width .25s ease;box-shadow:0 0 12px var(--gold)}.onboard-progress-text{font-family:var(--mono);font-size:12px;color:var(--paper);opacity:.75;text-align:center;word-break:break-all}.onboard-hint{font-size:13px;color:var(--paper);opacity:.85;margin-top:28px;max-width:480px;text-align:center;background:#d4a0171f;border:1px solid rgba(212,160,23,.4);border-radius:8px;padding:12px 16px;line-height:1.5}.toast-area{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:900;display:flex;flex-direction:column;gap:6px;pointer-events:none}.toast{background:var(--bg-soft);color:var(--paper);border:1px solid var(--gold);border-radius:8px;padding:10px 16px;font-size:13px;box-shadow:var(--shadow);animation:toastIn .25s ease,toastOut .4s ease 3.6s forwards;max-width:80vw}@keyframes toastIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastOut{to{transform:translateY(-10px);opacity:0}}.win-overlay{position:fixed;inset:0;background:radial-gradient(circle,#2a1810d9,#000000f2);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease;padding:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.win-banner{font-family:var(--serif);font-size:clamp(70px,14vw,200px);color:var(--gold);text-shadow:6px 6px 0 var(--stamp),12px 12px 0 var(--ink-soft);letter-spacing:.04em;animation:bingoIn .6s cubic-bezier(.34,1.56,.64,1);margin-bottom:16px;line-height:1}@keyframes bingoIn{0%{transform:scale(0) rotate(-15deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.win-winner{font-family:var(--serif);color:var(--paper);font-size:clamp(20px,2.4vw,32px);margin-bottom:6px;letter-spacing:.02em}.win-winner-sep{opacity:.55;font-style:italic}.win-winner-term{color:var(--gold)}.win-subtitle{font-family:var(--serif);color:var(--paper);font-size:clamp(13px,1.4vw,18px);margin-bottom:16px;font-style:italic;letter-spacing:.03em;opacity:.75}.win-thumb{max-width:320px;height:200px;overflow:hidden;margin-bottom:24px;border-radius:12px;position:relative}.win-thumb .card{margin:0 auto;width:320px}.win-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.win-actions .btn{padding:12px 24px;font-size:13px}.win-actions .btn-hero{padding:16px 32px;font-size:15px;letter-spacing:.08em;box-shadow:0 6px 20px #dc262666}.btn-light-ghost{opacity:.55;border-color:#fef3c74d!important}.btn-light-ghost:hover{opacity:1}.dev-mic{position:fixed;bottom:0;left:0;right:0;background:#000000eb;color:var(--paper);padding:10px 14px;display:flex;gap:10px;align-items:center;z-index:800;border-top:1px solid var(--gold)}.dev-mic-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.65;white-space:nowrap}.dev-mic input{flex:1;background:var(--bg);color:var(--paper);border:1px solid rgba(212,160,23,.5);padding:8px 12px;border-radius:6px;outline:none}.dev-mic input:focus{border-color:var(--gold)}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1100;padding:24px;animation:fadeIn .2s ease}.modal{background:var(--paper);color:var(--ink);border-radius:14px;border:4px double var(--gold);max-width:720px;width:100%;max-height:86vh;overflow:auto;padding:24px;font-family:var(--sans);box-shadow:var(--shadow-lg)}.modal h2{font-family:var(--serif);margin:0 0 4px;font-size:28px}.modal-subtitle{font-size:13px;opacity:.7;margin-bottom:16px}.modal table{width:100%;border-collapse:separate;border-spacing:0 6px;font-size:13px}.modal th{text-align:left;font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding-bottom:4px}.modal td{padding:4px 6px}.modal td input{width:100%;padding:6px 8px;border:1px solid rgba(120,53,15,.3);border-radius:5px;background:#fff;font-size:13px}.modal td input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px #d4a01740}.modal-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;position:sticky;bottom:-24px;margin-bottom:-24px;padding:16px 0;background:var(--paper);border-top:1px solid rgba(120,53,15,.15)}.modal .btn-tiny{padding:4px 8px;font-size:11px}.btn.btn-light{background:#78350f1a;color:var(--ink)}.btn.btn-light:hover{background:#78350f33}.help-hint{text-align:center;color:var(--paper);font-size:18px;opacity:.85;margin-top:32px;letter-spacing:.04em}.help-hint kbd{background:#ffffff1f;border:1px solid rgba(255,255,255,.35);padding:3px 8px;border-radius:4px;font-family:var(--mono);font-size:15px;color:var(--paper)}.card{background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.4),transparent 40%),var(--paper);border:4px double var(--gold);border-radius:14px;padding:16px;box-shadow:var(--shadow);position:relative;overflow:hidden;transform:translateZ(0);transition:transform .25s ease,box-shadow .25s ease}.card:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(120,53,15,.06) 1px,transparent 0);background-size:6px 6px;pointer-events:none;opacity:.6}.card.near-win.card-visible{animation:nearWinPulse 1.4s ease-in-out infinite}@keyframes nearWinPulse{0%,to{box-shadow:var(--shadow),0 0 0 0 var(--gold);transform:translateZ(0)}50%{box-shadow:var(--shadow),0 0 0 6px #d4a01773;transform:translate3d(0,-2px,0)}}@media (prefers-reduced-motion: reduce){.card.near-win.card-visible,.card{animation:none!important;transition:none}}.card.frozen{filter:saturate(1.15)}.card.frozen:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,transparent 50%,rgba(220,38,38,.12));pointer-events:none}.card-header{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--serif);color:var(--ink-soft);margin-bottom:10px;position:relative;z-index:1}.card-title{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}.card-pack-label{display:inline-flex;align-items:center;gap:6px}.card-pack-label-text{font-family:var(--sans);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);opacity:.75;white-space:nowrap}.card-pack-select{background:transparent;border:1px solid rgba(120,53,15,.35);border-radius:4px;color:var(--ink);font-family:var(--serif);font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:3px 6px;cursor:pointer;outline:none}.card-pack-select:hover,.card-pack-select:focus{border-color:var(--ink-soft);background:#fef3c799}.card-nickname{font-size:11px;opacity:.85;font-style:italic;font-family:var(--serif)}.bingo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;aspect-ratio:1;position:relative;z-index:1}.bingo-cell{background:linear-gradient(180deg,var(--paper-soft),var(--paper-dark));border:2px solid var(--gold);border-radius:6px;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--sans);color:var(--ink);font-size:clamp(11px,1.3vw,15px);line-height:1.15;padding:4px;font-weight:600;letter-spacing:0;position:relative;transition:transform .15s ease;word-break:break-word;hyphens:auto}.bingo-cell:not(.free){cursor:pointer}.bingo-cell:not(.free):not(.marked):hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.bingo-cell.free{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--ink);font-size:clamp(11px,1.4vw,16px);letter-spacing:.1em}.bingo-cell.free:after{content:"★";position:absolute;top:4px;right:6px;font-size:10px;opacity:.6}.bingo-cell.marked{background:linear-gradient(135deg,var(--stamp),var(--stamp-deep));color:var(--paper);border-color:var(--paper);transform:rotate(-3deg) scale(1.04);box-shadow:0 4px 12px #dc262680;animation:stamp .45s cubic-bezier(.34,1.56,.64,1);z-index:2}@keyframes stamp{0%{transform:rotate(0) scale(.4);opacity:0}60%{transform:rotate(-6deg) scale(1.15);opacity:1}to{transform:rotate(-3deg) scale(1.04);opacity:1}}.bingo-cell.in-win-line{outline:3px solid var(--gold);outline-offset:2px;z-index:3;animation:winPulse .8s ease-out infinite}@keyframes winPulse{0%,to{box-shadow:0 4px 12px #dc262680,0 0 0 0 var(--gold)}50%{box-shadow:0 4px 12px #dc262680,0 0 0 8px #d4a0174d}}.coffee-stain{position:absolute;width:90px;height:90px;border-radius:50%;border:7px solid rgba(120,53,15,.18);pointer-events:none;z-index:0;filter:blur(.5px)}.toast-mark{position:absolute;top:18%;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);padding:5px 10px;border-radius:4px;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;pointer-events:none;animation:toastUp 1.5s ease-out forwards;z-index:5;white-space:nowrap;box-shadow:0 4px 12px #0000004d}.toast-mark:before{content:"heard:";opacity:.6;margin-right:6px}.progress-dots{display:flex;gap:6px;justify-content:center;margin-top:12px;padding:6px 0 0;position:relative;z-index:1}.progress-dot{width:10px;height:10px;border-radius:50%;background:#78350f2e;border:1px solid rgba(120,53,15,.3);transition:all .25s cubic-bezier(.34,1.56,.64,1)}.progress-dot.lit{background:var(--stamp);border-color:var(--stamp);box-shadow:0 0 8px #dc262699;transform:scale(1.15)}.progress-dots[data-progress="4"] .progress-dot.lit{background:var(--gold);border-color:var(--gold);box-shadow:0 0 12px var(--gold);animation:dotPulse .8s ease-in-out infinite}@keyframes dotPulse{0%,to{transform:scale(1.15)}50%{transform:scale(1.35)}}@keyframes toastUp{0%{opacity:0;transform:translate(-50%,10px) scale(.9)}20%{opacity:1;transform:translate(-50%) scale(1)}80%{opacity:1;transform:translate(-50%,-20px) scale(1)}to{opacity:0;transform:translate(-50%,-40px) scale(.95)}}.ashtray{position:fixed;bottom:12px;right:16px;width:220px;height:340px;pointer-events:none;z-index:50;user-select:none;filter:drop-shadow(0 6px 12px rgba(0,0,0,.6));--ember-x: 86px;--ember-y: 34px}.ashtray-svg{position:absolute;bottom:0;left:0;width:220px;height:110px}.ember{animation:emberPulse 1.2s ease-in-out infinite}.ember-core{animation:emberCore 1.2s ease-in-out infinite}.ember-glow{animation:emberGlow 1.2s ease-in-out infinite;filter:blur(2px)}@keyframes emberPulse{0%,to{fill:#ff3d00}50%{fill:#ff8a00}}@keyframes emberCore{0%,to{fill:#ffeb3b;opacity:.95}50%{fill:#fff;opacity:1}}@keyframes emberGlow{0%,to{opacity:.35}50%{opacity:.65}}.smoke{position:absolute;bottom:var(--ember-y);left:var(--ember-x);width:16px;height:16px;margin-left:-8px;margin-bottom:-8px;background:radial-gradient(circle at 50% 50%,#f5f5f5bf,#d2d2d280 35%,#b4b4b433 65%,#96969600 80%);border-radius:50%;filter:blur(3px);opacity:0;animation:smokeRise 6s ease-in infinite;transform-origin:center}.smoke-1{animation-delay:0s;--drift-x: -10px}.smoke-2{animation-delay:1s;--drift-x: 14px}.smoke-3{animation-delay:2s;--drift-x: -6px}.smoke-4{animation-delay:3s;--drift-x: 18px}.smoke-5{animation-delay:4s;--drift-x: -16px}.smoke-6{animation-delay:5s;--drift-x: 8px}@keyframes smokeRise{0%{transform:translate(0) scale(.4);opacity:0}6%{opacity:.85}25%{transform:translate(calc(var(--drift-x) * .3),-60px) scale(1.4);opacity:.7}50%{transform:translate(calc(var(--drift-x) * .7),-130px) scale(2.4);opacity:.5}75%{transform:translate(var(--drift-x),-200px) scale(3.4);opacity:.25}to{transform:translate(calc(var(--drift-x) * 1.3),-270px) scale(4.2);opacity:0}}[data-theme=cyberpunk] .ember{fill:#f0f;filter:drop-shadow(0 0 4px #ff00ff)}[data-theme=cyberpunk] .ember-glow{fill:#0ff}[data-theme=cyberpunk] .smoke{background:radial-gradient(circle at 50% 50%,rgba(0,255,255,.4) 0%,rgba(255,0,255,.2) 50%,transparent 70%)}@media (max-width: 1100px){.ashtray{display:none}}.splash{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 30% 20%,rgba(212,160,23,.25),transparent 55%),radial-gradient(ellipse at 70% 80%,rgba(220,38,38,.25),transparent 55%),linear-gradient(135deg,#1a0e08,#2a1810,#0f0805);overflow:hidden;animation:splashFadeIn .4s ease}.splash.splash-hide{animation:splashFadeOut .55s cubic-bezier(.5,0,.7,.2) forwards}@keyframes splashFadeIn{0%{opacity:0}to{opacity:1}}@keyframes splashFadeOut{to{opacity:0;transform:scale(1.05)}}.splash-balls{position:absolute;inset:0;overflow:hidden;pointer-events:none}.splash-ball{position:absolute;bottom:-120px;left:var(--x);width:var(--size);height:var(--size);border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff9,hsl(var(--hue),75%,55%) 40%,hsl(var(--hue),80%,32%));box-shadow:inset -4px -6px 8px #0000004d,0 4px 12px #0006,0 0 24px hsla(var(--hue),80%,50%,.35);display:flex;align-items:center;justify-content:center;font-family:"DM Serif Display",Georgia,serif;color:#fffffff2;font-size:calc(var(--size) * .42);font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.4);animation:ballRise var(--dur) var(--delay) linear infinite;opacity:0}@keyframes ballRise{0%{transform:translate(0) rotate(0);opacity:0}10%{opacity:.85}50%{transform:translate(calc(var(--size) * .4),-55vh) rotate(180deg)}90%{opacity:.6}to{transform:translate(calc(var(--size) * -.6),-110vh) rotate(360deg);opacity:0}}.splash-card{position:relative;z-index:2;max-width:720px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:22px;animation:splashPop .7s cubic-bezier(.34,1.56,.64,1)}@keyframes splashPop{0%{transform:scale(.85) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.splash-title{font-family:"DM Serif Display",Georgia,serif;font-size:clamp(72px,13vw,168px);line-height:.92;margin:0;color:#fef3c7;letter-spacing:-.01em;text-shadow:4px 4px 0 #dc2626,8px 8px 0 #78350f,12px 12px 24px rgba(0,0,0,.6);animation:titleWobble 6s ease-in-out infinite;transform-origin:50% 80%}@keyframes titleWobble{0%,to{transform:rotate(-1deg)}50%{transform:rotate(1.2deg)}}.splash-subtitle{font-family:"DM Serif Display",Georgia,serif;font-size:clamp(15px,1.8vw,22px);color:#fde68a;font-style:italic;opacity:.85;letter-spacing:.02em}.splash-marquee{width:min(720px,92vw);overflow:hidden;position:relative;padding:12px 0;border-top:1px solid rgba(212,160,23,.4);border-bottom:1px solid rgba(212,160,23,.4);background:#00000040;mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent)}.splash-marquee-inner{display:inline-flex;white-space:nowrap;animation:marqueeScroll 60s linear infinite;gap:0}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.splash-marquee-word{font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#fef3c7;padding:0 8px;text-shadow:0 1px 2px rgba(0,0,0,.5)}.splash-marquee-sep{color:#dc2626;font-weight:900;padding:0 4px;font-size:18px}.splash-play{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fef3c7;border:none;border-radius:999px;padding:18px 40px;font-family:Inter,system-ui,sans-serif;font-size:18px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:14px;box-shadow:0 8px 24px #dc262680,inset 0 -3px #00000040;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;animation:playPulse 2.4s ease-in-out infinite}.splash-play:hover{transform:translateY(-2px) scale(1.03);filter:brightness(1.1);box-shadow:0 12px 32px #dc2626a6,inset 0 -3px #00000040}.splash-play:active{transform:translateY(0) scale(.98)}.splash-play-icon{font-size:18px;display:inline-block;transform:translateY(-1px)}@keyframes playPulse{0%,to{box-shadow:0 8px 24px #dc262680,inset 0 -3px #00000040,0 0 #d4a01799}50%{box-shadow:0 8px 24px #dc262680,inset 0 -3px #00000040,0 0 0 14px #d4a01700}}.splash-tip{font-family:Inter,system-ui,sans-serif;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#fde68a;opacity:.6}[data-theme=cyberpunk]{color-scheme:dark}[data-theme=cyberpunk] body{background:radial-gradient(ellipse at 50% 38%,rgba(255,0,255,.18) 0%,transparent 45%),radial-gradient(ellipse at 50% 50%,rgba(0,255,255,.08) 0%,transparent 60%),linear-gradient(180deg,#0a0118,#1a0033 35%,#2d0040 55%,#4a0050 65%,#0a0014)!important;overflow-x:hidden}[data-theme=cyberpunk] body:before{content:"";position:fixed;left:50%;top:22%;width:360px;height:360px;transform:translate(-50%,-50%);background:radial-gradient(circle,#ff00aa 0%,#ff00aa 38%,transparent 70%);filter:blur(.5px);opacity:.55;z-index:-3;pointer-events:none;border-radius:50%;box-shadow:0 0 80px 20px #f0a6,inset 0 -40px 60px #00ffff40;-webkit-mask-image:linear-gradient(180deg,#000 55%,transparent 75%);mask-image:linear-gradient(180deg,#000 55%,transparent 75%);animation:cpSunPulse 4s ease-in-out infinite}@keyframes cpSunPulse{0%,to{box-shadow:0 0 80px 20px #f0a6,inset 0 -40px 60px #00ffff40}50%{box-shadow:0 0 110px 30px #f0a9,inset 0 -40px 80px #0ff6}}[data-theme=cyberpunk] body:after{content:"";position:fixed;left:0;right:0;bottom:0;height:55vh;background:linear-gradient(180deg,transparent 0%,rgba(10,1,24,.5) 80%,#0a0014 100%),repeating-linear-gradient(90deg,transparent 0,transparent 49px,#ff00ff 49px,#ff00ff 50px),repeating-linear-gradient(0deg,transparent 0,transparent 49px,#00ffff 49px,#00ffff 50px);transform:perspective(420px) rotateX(58deg);transform-origin:50% 0;opacity:.32;z-index:-2;pointer-events:none;animation:cpGridScroll 4s linear infinite}@keyframes cpGridScroll{0%{background-position:0 0,0 0,0 0}to{background-position:0 0,0 0,0 50px}}[data-theme=cyberpunk] .app:before{content:"";position:fixed;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 3px);z-index:1000;pointer-events:none;mix-blend-mode:overlay}[data-theme=cyberpunk] .app:after{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at center,transparent 55%,rgba(0,0,0,.55) 100%);z-index:999;pointer-events:none}[data-theme=cyberpunk] .app-title{font-family:JetBrains Mono,SF Mono,Menlo,monospace!important;letter-spacing:.02em;position:relative;color:#0ff;text-shadow:0 0 4px #00ffff,0 0 12px rgba(0,255,255,.7),2px 2px 0 #ff00ff,-2px 0 0 #ff00ff;animation:cpGlitch 6s steps(1) infinite}@keyframes cpGlitch{0%,92%,to{transform:translate(0);text-shadow:0 0 4px #00ffff,0 0 12px rgba(0,255,255,.7),2px 2px 0 #ff00ff,-2px 0 0 #ff00ff}93%{transform:translate(-2px,1px);text-shadow:3px 0 0 #ff00ff,-3px 0 0 #00ffff}94%{transform:translate(2px,-1px);text-shadow:-4px 0 0 #ff00ff,4px 0 0 #00ffff}95%{transform:translateY(2px);text-shadow:0 3px 0 #ff00ff,0 -3px 0 #00ffff}96%{transform:translate(-1px);text-shadow:2px 2px 0 #ff00ff,-2px 0 0 #00ffff}}[data-theme=cyberpunk] .app-subtitle{color:#0ffc;text-shadow:0 0 6px rgba(0,255,255,.6);font-family:JetBrains Mono,SF Mono,Menlo,monospace!important}[data-theme=cyberpunk] .card{background:linear-gradient(160deg,#0e0a26,#1a0a38)!important;border:1px solid #00ffff;box-shadow:0 0 0 1px #ff00ff59,0 0 24px #00ffff59,inset 0 0 32px #ff00ff26;position:relative}[data-theme=cyberpunk] .card:before{content:"";position:absolute;inset:-2px;border-radius:inherit;background:linear-gradient(135deg,#f0f,#0ff,#f0f);background-size:300% 300%;z-index:-1;filter:blur(8px);opacity:.55;animation:cpBorderShift 6s linear infinite}@keyframes cpBorderShift{0%{background-position:0% 50%}to{background-position:300% 50%}}[data-theme=cyberpunk] .card .cell{background:#00000059;border-color:#00ffff40!important;color:#e0fbfc;text-shadow:0 0 3px rgba(0,255,255,.5);font-family:JetBrains Mono,SF Mono,Menlo,monospace!important}[data-theme=cyberpunk] .card .cell.free{color:#f0f;text-shadow:0 0 8px rgba(255,0,255,.8);background:radial-gradient(circle,rgba(255,0,255,.15),transparent 70%)}[data-theme=cyberpunk] .card .cell.marked,[data-theme=cyberpunk] .card .cell[data-marked=true]{background:radial-gradient(circle,rgba(255,0,255,.55) 0%,rgba(255,0,255,.15) 60%,transparent 100%);color:#fff;text-shadow:0 0 6px #ff00ff,0 0 14px rgba(255,0,255,.8);border-color:#f0f!important;box-shadow:0 0 18px #ff00ffb3,inset 0 0 12px #0ff6;animation:cpStampPulse 1.2s ease-out}@keyframes cpStampPulse{0%{transform:scale(1.18) rotate(-4deg);filter:brightness(2)}60%{transform:scale(.96) rotate(1deg);filter:brightness(1.3)}to{transform:scale(1) rotate(0);filter:brightness(1)}}[data-theme=cyberpunk] .card.near-win{animation:cpNearWin 1.4s ease-in-out infinite}@keyframes cpNearWin{0%,to{box-shadow:0 0 0 1px #ff00ff59,0 0 24px #00ffff59,inset 0 0 32px #ff00ff26}50%{box-shadow:0 0 0 2px #ff00ffe6,0 0 60px #00ffffd9,inset 0 0 48px #ff00ff73}}[data-theme=cyberpunk] .card.winning,[data-theme=cyberpunk] .card .cell.win-cell{background:repeating-linear-gradient(45deg,#f0f 0 8px,#0ff 8px 16px)!important;color:#050510!important;font-weight:900;text-shadow:0 0 4px rgba(255,255,255,.9)!important}[data-theme=cyberpunk] .splash{background:radial-gradient(ellipse at 50% 100%,rgba(255,0,170,.3),transparent 65%),linear-gradient(180deg,#0a0118,#1a0033,#0a0014)}[data-theme=cyberpunk] .splash-card{background:#0a0118d9;border:2px solid #00ffff;box-shadow:0 0 40px #ff00ff80,0 0 80px #00ffff4d,inset 0 0 40px #ff00ff1a;backdrop-filter:blur(4px)}[data-theme=cyberpunk] .splash-title{font-family:JetBrains Mono,SF Mono,Menlo,monospace!important;color:#0ff;text-shadow:0 0 12px #00ffff,0 0 28px rgba(0,255,255,.8),4px 4px 0 #ff00ff,-4px 0 0 rgba(255,0,255,.7);animation:cpGlitch 7s steps(1) infinite;letter-spacing:.04em}[data-theme=cyberpunk] .splash-subtitle{color:#0ffc;font-family:JetBrains Mono,SF Mono,Menlo,monospace!important;text-shadow:0 0 6px rgba(0,255,255,.5)}[data-theme=cyberpunk] .splash-marquee{border-top:1px solid #ff00ff;border-bottom:1px solid #00ffff;background:#00000073;box-shadow:inset 0 0 20px #ff00ff4d,0 0 16px #00ffff40}[data-theme=cyberpunk] .splash-marquee-word{color:#0ff;text-shadow:0 0 8px rgba(0,255,255,.9),0 0 18px rgba(0,255,255,.5);font-family:JetBrains Mono,SF Mono,Menlo,monospace!important}[data-theme=cyberpunk] .splash-marquee-sep{color:#f0f;text-shadow:0 0 6px rgba(255,0,255,.8)}[data-theme=cyberpunk] .splash-play{background:linear-gradient(135deg,#f0f,#0ff)!important;border:2px solid #00ffff;color:#050510!important;font-family:JetBrains Mono,SF Mono,Menlo,monospace!important;letter-spacing:.1em;text-transform:uppercase;font-weight:900;box-shadow:0 0 24px #ff00ffb3,0 0 60px #00ffff80,inset 0 0 16px #ffffff4d;animation:cpPlayPulse 2s ease-in-out infinite}@keyframes cpPlayPulse{0%,to{box-shadow:0 0 24px #ff00ffb3,0 0 60px #00ffff80,inset 0 0 16px #ffffff4d}50%{box-shadow:0 0 40px #f0f,0 0 90px #0ffc,inset 0 0 24px #ffffff80}}[data-theme=cyberpunk] .splash-play:hover{transform:translateY(-2px) scale(1.04);filter:brightness(1.2)}[data-theme=cyberpunk] .splash-tip{color:#00ffffa6;font-family:JetBrains Mono,SF Mono,Menlo,monospace!important}[data-theme=cyberpunk] .splash-ball{filter:drop-shadow(0 0 8px #ff00ff) drop-shadow(0 0 14px rgba(0,255,255,.6)) hue-rotate(180deg) brightness(1.6)}[data-theme=cyberpunk] ::selection{background:#f0f;color:#050510}[data-theme=cyberpunk]{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><g fill='none' stroke='%2300ffff' stroke-width='1.5'><circle cx='12' cy='12' r='6' fill='rgba(255,0,255,0.15)'/><line x1='12' y1='2' x2='12' y2='8'/><line x1='12' y1='16' x2='12' y2='22'/><line x1='2' y1='12' x2='8' y2='12'/><line x1='16' y1='12' x2='22' y2='12'/></g></svg>") 12 12,crosshair}[data-theme=cyberpunk] button,[data-theme=cyberpunk] a,[data-theme=cyberpunk] select,[data-theme=cyberpunk] input,[data-theme=cyberpunk] .cell{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><g fill='%23ff00ff' stroke='%2300ffff' stroke-width='1'><path d='M2 2 L12 14 L7 14 L9 22 L5 22 L3 14 L2 14 Z'/></g></svg>") 4 4,pointer}[data-theme=cyberpunk] .controls{background:#0a011899;border:1px solid rgba(255,0,255,.3);backdrop-filter:blur(6px)}[data-theme=cyberpunk] .btn-stamp{background:linear-gradient(135deg,#f0f,#ff0080)!important;border:1px solid #00ffff!important;color:#fff!important;text-shadow:0 0 4px rgba(255,255,255,.5);font-family:JetBrains Mono,SF Mono,Menlo,monospace!important;letter-spacing:.05em;text-transform:uppercase;box-shadow:0 0 20px #ff00ff80}[data-theme=cyberpunk] .btn-stamp:hover{background:linear-gradient(135deg,#f3f,#f39)!important;box-shadow:0 0 30px #f0fc}[data-theme=cyberpunk] .toast{background:#0a0118eb!important;border:1px solid #00ffff;color:#0ff;box-shadow:0 0 20px #00ffff80;font-family:JetBrains Mono,SF Mono,Menlo,monospace!important}[data-theme=cyberpunk] .ashtray{display:none}[data-theme=cyberpunk] .mic-indicator[data-state=listening] .mic-dot{background:#0ff;box-shadow:0 0 8px #0ff,0 0 16px #00ffffb3}[data-theme=cyberpunk] .mic-indicator[data-state=loading] .mic-dot{background:#f0f;box-shadow:0 0 8px #f0f}@media (prefers-reduced-motion: reduce){[data-theme=cyberpunk] .app-title,[data-theme=cyberpunk] .splash-title,[data-theme=cyberpunk] body:before,[data-theme=cyberpunk] body:after,[data-theme=cyberpunk] .card:before,[data-theme=cyberpunk] .card.near-win,[data-theme=cyberpunk] .splash-play{animation:none!important}}
