body,.app-container,#player-panel{min-height:100dvh;min-height:100vh}:root{--primary: #6A1B9A;--primary-dark: #4A148C;--primary-light: #9C27B0;--secondary: #E91E63;--success: #4CAF50;--danger: #F44336;--warning: #FF9800;--info: #2196F3;--dark: #212121;--light: #F5F5F5;--card-bg: #FFFFFF;--shadow: 0 4px 6px rgba(0,0,0,.1);--shadow-lg: 0 10px 25px rgba(0,0,0,.15);--border-radius: 16px;--border-radius-sm: 8px;--transition: all .3s ease}*{box-sizing:border-box;margin:0;padding:0}:where(a,button,input,textarea,select,summary,[role=button],[tabindex]:not([tabindex="-1"])):focus-visible{outline:3px solid rgba(106,27,154,.45);outline-offset:3px}:where(.btn,.icon-btn,.leaderboard-tab,.modal-close-btn):focus-visible{box-shadow:0 0 0 4px #6a1b9a38}html,body{height:100%}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:radial-gradient(circle at 10% 20%,rgba(255,213,79,.45),transparent 35%),radial-gradient(circle at 85% 15%,rgba(79,195,247,.42),transparent 40%),radial-gradient(circle at 20% 85%,rgba(244,67,54,.38),transparent 40%),radial-gradient(circle at 90% 75%,rgba(156,39,176,.35),transparent 45%),radial-gradient(circle at 50% 50%,rgba(76,175,80,.25),transparent 60%),linear-gradient(160deg,#0b1f3a,#1b2a55 45%,#283a6e);color:var(--dark);min-height:100dvh;min-height:100vh;padding:0;margin:0;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative}body.modal-open{overflow:hidden}body:before{content:"";position:fixed;inset:-120px;background-image:radial-gradient(circle at 15% 25%,rgba(255,215,0,.12) 0%,transparent 3%),radial-gradient(circle at 25% 60%,rgba(255,105,180,.1) 0%,transparent 3%),radial-gradient(circle at 45% 35%,rgba(135,206,250,.11) 0%,transparent 3%),radial-gradient(circle at 65% 15%,rgba(144,238,144,.1) 0%,transparent 3%),radial-gradient(circle at 75% 75%,rgba(255,165,0,.12) 0%,transparent 3%),radial-gradient(circle at 85% 45%,rgba(238,130,238,.1) 0%,transparent 3%),radial-gradient(circle at 90% 85%,rgba(255,99,71,.11) 0%,transparent 3%),radial-gradient(circle at 10% 80%,rgba(64,224,208,.1) 0%,transparent 3%),radial-gradient(circle at 20% 30%,rgba(255,255,255,.03) 0%,transparent 2%),radial-gradient(circle at 60% 70%,rgba(255,255,255,.03) 0%,transparent 2%),radial-gradient(circle at 80% 10%,rgba(255,255,255,.03) 0%,transparent 2%);background-size:100px 100px;pointer-events:none;z-index:1;will-change:transform;animation:backgroundShift 30s linear infinite}@keyframes backgroundShift{0%{transform:translateZ(0)}to{transform:translate3d(100px,100px,0)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.app-container{min-height:100dvh;min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:2}.app-container:before,.app-container:after{content:none!important;display:none!important}@keyframes colorShift1{0%,to{filter:hue-rotate(0deg)}50%{filter:hue-rotate(40deg)}}@keyframes colorShift2{0%,to{filter:hue-rotate(0deg)}50%{filter:hue-rotate(-30deg)}}.header{background:radial-gradient(circle at 15% 50%,rgba(255,255,255,.25),transparent 45%),radial-gradient(circle at 90% 30%,rgba(255,255,255,.18),transparent 45%),linear-gradient(135deg,#2c3e90,#6b2d91);padding:8px 12px;box-shadow:0 4px 20px #0000004d,0 0 40px #6a1b9a33;position:relative;top:0;z-index:1000;overflow:visible;backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1)}body.player-mode .header{position:relative;top:auto;left:auto;right:auto;width:auto}body.player-mode{--player-panel-top-px: 0px;height:auto;overflow:auto}body.player-mode #player-panel{padding-top:0;height:auto;overflow-y:visible}body.player-mode .player-card{margin-top:0}body.player-mode .app-container{height:100%;min-height:0;overflow:hidden}body.player-mode #player-panel .players-section-compact{display:none!important}@media (max-width: 600px){body.player-mode{--player-panel-top-px: 170px}}.credits-hud{display:flex;align-items:center;gap:10px}.credits-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:linear-gradient(135deg,#ff980038,#ffd54f29);border:1px solid rgba(255,255,255,.22);box-shadow:0 10px 24px #00000029;color:#fff;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.credits-badge.pulse{animation:creditsPulse .7s ease-out}@keyframes creditsPulse{0%{box-shadow:0 10px 24px #00000029,0 0 #ffc10700;transform:translateY(0)}35%{box-shadow:0 10px 24px #00000029,0 0 18px #ffc10773;transform:translateY(-1px) scale(1.02)}to{box-shadow:0 10px 24px #00000029,0 0 #ffc10700;transform:translateY(0) scale(1)}}.cr-icon{width:18px;height:18px;flex:0 0 auto}.cr-coin{color:#ffc107f2}.cr-ticket{color:#4fc3f7f2}.credits-label{font-size:12px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;opacity:.9}.credits-balance{font-size:16px;font-weight:900;font-variant-numeric:tabular-nums;min-width:64px;text-align:right}.credits-suffix{font-size:12px;font-weight:900;opacity:.9}.credits-profile{width:38px;height:38px;display:grid;place-items:center;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;color:#fff;cursor:pointer;transition:background .2s ease}.credits-profile:hover{background:#ffffff2e}.credits-profile:active{background:#ffffff40}.captcha-label-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.captcha-question{display:flex;align-items:center;gap:6px;margin-top:6px;padding:10px 12px;border-radius:var(--border-radius-sm);background:#0000000a;border:1px solid rgba(0,0,0,.12);color:#000000eb;font-weight:700}.queue-image{width:100%;max-width:none;height:180px;object-fit:cover;object-position:50% 30%;display:block;margin:0 auto;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f}.icon-btn-inline{width:38px;height:38px;display:inline-grid;place-items:center;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:#ffffff1a;color:#fff;cursor:pointer;transition:background .2s ease,transform .08s ease}.icon-btn-inline:hover{background:#ffffff2e}.icon-btn-inline:active{transform:translateY(1px);background:#ffffff3d}.field-error{margin-top:8px;padding:10px 12px;border-radius:var(--border-radius-sm);background:#f4433624;border:1px solid rgba(244,67,54,.34);color:#fffffff2;font-weight:650}.form-input.is-invalid{border-color:#f44336bf!important;box-shadow:0 0 0 3px #f4433633!important}.qr-skeleton{width:220px;height:220px;border-radius:16px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(90deg,#ffffff1a,#ffffff2e 45%,#ffffff1a);background-size:220% 100%;animation:shimmer 1.2s ease-in-out infinite}@keyframes shimmer{0%{background-position:0% 0%}to{background-position:220% 0%}}.share-qr{display:grid;place-items:center;gap:10px;margin-top:10px}.share-qr img{width:220px;height:220px;border-radius:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.18)}@media (max-width: 420px){.qr-skeleton,.share-qr img{width:200px;height:200px}}.queue-status-row{display:flex;align-items:center;gap:10px}.queue-status-label{color:#ffffffdb;font-weight:800}.current-queue{display:grid;gap:8px}.queue-badge{display:inline-flex;width:fit-content;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#ffffffeb;font-weight:800;letter-spacing:.2px}.queue-waiting-line{color:#ffffffe0;font-weight:700}.credits-profile .credits-avatar{width:32px;height:32px}.bingo-status:empty{display:none}.bingo-status{font-size:12px;font-weight:700;color:#ffffffe6;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.instructions-list{margin:10px 0 18px;padding-left:20px}.instructions-list li{margin:8px 0;line-height:1.35}.honeypot-field{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}.how-it-works{display:grid;gap:10px;margin:10px 0 18px}.tutorial{margin:10px 0 18px;padding:12px;border-radius:14px;background:#6a1b9a0a;border:1px solid rgba(106,27,154,.16)}.tutorial-header{display:grid;gap:8px}.tutorial-progress-meta{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:12px;color:#000000b8;font-weight:700}.tutorial-progressbar{height:10px;border-radius:999px;background:#00000014;overflow:hidden}.tutorial-progressbar-fill{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,#6a1b9ae6,#00bcd4d9)}.tutorial-body{margin-top:10px}.tutorial-title{margin:8px 0 6px;font-size:16px;font-weight:900;color:var(--dark)}.tutorial-desc{margin:0 0 10px;color:#000000b8;font-size:13px;line-height:1.4}.tutorial-credits-wrap{margin:10px 0}.tutorial-credits-display{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-radius:12px;background:#ffc1071f;border:1px solid rgba(255,193,7,.3)}.tutorial-credits-label{font-weight:900;color:var(--dark);font-size:14px}.tutorial-credits-amount{font-weight:900;color:#ff9800f2;font-size:16px}.tutorial-choices{display:grid;gap:10px;margin:10px 0}.tutorial-challenge{margin:10px 0;padding:10px;border-radius:12px;background:#ffffffb3;border:1px solid rgba(0,0,0,.08)}.tutorial-call-display{margin:10px 0;padding:12px;border-radius:12px;background:#6a1b9a0f;border:1px solid rgba(106,27,154,.2)}.tutorial-last-called{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.tutorial-last-label{font-weight:700;color:#000000b8;font-size:12px}.tutorial-last-number{font-weight:900;font-size:28px;color:var(--primary);min-width:50px;text-align:center;padding:4px 10px;border-radius:8px;background:#fffc}.tutorial-call-history{display:grid;gap:6px}.tutorial-history-label{font-weight:700;color:#000000b8;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.tutorial-call-history-list{display:flex;flex-wrap:wrap;gap:6px}.tutorial-call-number{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:4px 8px;border-radius:8px;background:#ffffffd9;border:1px solid rgba(0,0,0,.1);font-weight:900;font-size:13px;color:#000000d1}.tutorial-demo-title{font-weight:900;margin:6px 0 8px;color:var(--dark)}.tutorial-ticket-wrap{margin:12px 0}.tutorial-ticket-90{display:grid;grid-template-columns:repeat(9,1fr);gap:4px;margin:8px 0 6px;padding:8px;border-radius:12px;background:#ffffffeb;border:2px solid rgba(106,27,154,.2)}.tutorial-cell-90{appearance:none;border:1px solid rgba(0,0,0,.14);background:#fffffff2;border-radius:6px;padding:6px 4px;font-weight:900;font-size:14px;color:var(--dark);min-height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.tutorial-cell-90.blank{background:#00000005;border-color:#0000000f;cursor:default}.tutorial-cell-90.dabbed{border-color:#00bcd499;background:#00bcd42e;color:#006478f2}.tutorial-cell-90.called{animation:tutorial-pulse .6s ease}@keyframes tutorial-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.tutorial-ticket{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0 6px}.tutorial-cell{appearance:none;border:1px solid rgba(0,0,0,.14);background:#ffffffdb;border-radius:12px;padding:12px 10px;font-weight:900;font-size:18px;color:var(--dark);min-height:48px}.tutorial-cell.dabbed{border-color:#00bcd480;background:#00bcd41f}.tutorial-bingo-wrap{margin:12px 0;text-align:center}.tutorial-bingo-wrap .btn{min-width:200px}.tutorial-strict-demo{margin:12px 0;padding:12px;border-radius:12px;background:#ff572214;border:1px solid rgba(255,87,34,.24)}.tutorial-strict-title{font-weight:900;color:#ff5722f2;margin-bottom:8px;font-size:14px}.tutorial-strict-content{font-size:13px;line-height:1.5;color:#000000c7}.tutorial-strict-content .strict-step{margin:6px 0;padding:8px 10px;border-radius:8px;background:#ffffffb3}.tutorial-strict-content .strict-fail{color:#d32f2feb;font-weight:700}.tutorial-strict-content .strict-success{color:#4caf50eb;font-weight:700}.tutorial-hint{color:#000000ad;font-size:12px;line-height:1.35}.tutorial-reward-title{font-weight:900;color:var(--dark);margin:6px 0 4px}.tutorial-reward-desc{color:#000000b8;font-size:13px;line-height:1.4;margin:0 0 10px}.tutorial-controls{margin-top:10px}.instructions-details{margin-top:10px;border-radius:12px;background:#ffffff8c;border:1px solid rgba(0,0,0,.08);padding:10px}.instructions-summary{cursor:pointer;font-weight:900;color:var(--dark)}.hiw-step{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:12px;background:#6a1b9a0a;border:1px solid rgba(106,27,154,.16)}.hiw-icon{width:38px;height:38px;flex-shrink:0;display:grid;place-items:center;border-radius:999px;background:#6a1b9a1f;border:1px solid rgba(106,27,154,.2);font-size:18px}.hiw-title{font-weight:800;color:var(--dark);line-height:1.15}.hiw-desc{margin-top:2px;color:#000000b8;font-size:13px;line-height:1.35}.credits-avatar{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#ffffff2e;overflow:hidden}.credits-avatar.photo{background-size:cover;background-position:center}.credits-username{font-size:12px;font-weight:800;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){#credits-badge,#credits-username{display:none!important}}@media (min-width: 768px){#credits-badge{display:none!important}}.credits-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 12px}.credits-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);color:#ffffffeb;font-size:12px;font-weight:800}@media (max-width: 400px){body.player-mode{--player-panel-top-px: 160px}}@media (min-width: 601px) and (max-width: 1024px) and (orientation: portrait){.screen{padding:18px}.player-card{max-width:720px;padding:16px}}@media (min-width: 601px) and (max-width: 1024px) and (orientation: landscape){.screen{padding:16px}.player-card{max-width:980px;padding:16px}.tickets-container{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:start}.ticket{width:100%}}.header:before,.header:after{content:"";position:absolute;width:60px;height:60px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#f6f6f6 35%,#4fc3f7 36%,#1976d2 70%,#0d47a1);opacity:.2;filter:blur(.2px)}.header:before{right:6%;top:-25px}.header:after{left:4%;top:-30px;width:70px;height:70px;background:radial-gradient(circle at 30% 30%,#fff,#f6f6f6 35%,#ffeb3b 36%,#f57f17 70%,#e65100)}@media (max-width: 600px){.header:before,.header:after{display:none}}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px}.header-banner-wrap{position:relative;width:100%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;padding-right:112px}.bingo-blast-logo{display:flex;align-items:center;gap:12px;padding:8px 0}.blast-text{font-size:36px;font-weight:900;background:linear-gradient(135deg,#ff6b35,#ffd23f,#4ecdc4,#9b59b6,#ff6b35);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 10px rgba(255,107,53,.3),0 4px 20px rgba(255,210,63,.2);letter-spacing:1px;animation:gradientShift 4s ease infinite;font-family:Poppins,sans-serif}.bingo-ball-animated{width:55px;height:55px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#505050,#282828 35%,#1a1a1a 60%,#000);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px #000c,0 4px 10px #f0f6,0 0 20px #00ffff4d,inset -2px -2px 6px #000c,inset 2px 2px 8px #64646466;border:3px solid rgba(255,255,255,.8);animation:ballBounce 2s ease-in-out infinite,ballRotate 4s linear infinite,ballGlowVibrant 2s ease-in-out infinite;position:relative;flex-shrink:0}@keyframes ballBounce{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-8px) rotate(90deg)}50%{transform:translateY(0) rotate(180deg)}75%{transform:translateY(-4px) rotate(270deg)}}@keyframes ballRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ballGlowVibrant{0%,to{box-shadow:0 8px 20px #000c,0 4px 10px #f0f6,0 0 20px #00ffff4d,inset -2px -2px 6px #000c,inset 2px 2px 8px #64646466}50%{box-shadow:0 10px 30px #000000e6,0 6px 15px #f0fc,0 0 40px #0ff9,0 0 60px #ff008066,inset -2px -2px 6px #000c,inset 2px 2px 8px #64646466}}.ball-number-animated{font-size:22px;font-weight:900;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5),0 0 8px rgba(255,255,255,.3);animation:numberPulse 2s ease-in-out infinite}@keyframes numberPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.header-icon-group.overlay-icons{position:fixed;top:8px;right:12px;z-index:1000;display:flex;gap:10px}.header-icon-left.overlay-icons-left{position:fixed;top:10px;left:16px;z-index:1000;display:flex}body.player-mode .header-icon-group.overlay-icons{flex-direction:column;align-items:center}body.player-mode .header-icon-group.overlay-icons .credits-profile,body.player-mode .header-icon-group.overlay-icons #settings-btn.icon-btn{width:44px;height:44px}body.player-mode .header-icon-group.overlay-icons #settings-btn.icon-btn{min-width:44px;min-height:44px;padding:0;margin:0;display:grid;place-items:center}body.player-mode .header-icon-group.overlay-icons .credits-profile{display:grid;place-items:center}body.player-mode .header-icon-group.overlay-icons .credits-profile .credits-avatar{width:36px;height:36px}.header-emoji{font-size:22px;line-height:1;display:block}.sound-icon,.exit-icon{width:101px;height:101px;display:block}.icon-btn{background:#0006;border:2px solid rgba(255,255,255,.3);padding:6px;margin:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.icon-btn:active,.icon-btn:focus{background:#0009;transform:scale(.95)}@media (max-width: 600px){.header{padding:4px 6px}.blast-text{font-size:28px}.bingo-ball-animated{width:45px;height:45px}.ball-number-animated{font-size:18px}.bingo-blast-logo{gap:8px}.header-icon-group.overlay-icons{top:8px;right:8px;gap:6px}.header-icon-left.overlay-icons-left{top:10px;left:12px}.header-banner-wrap{padding-right:104px}.sound-icon,.exit-icon{width:89px;height:89px}.icon-btn{padding:5px}}@media (max-width: 400px){.blast-text{font-size:22px}.bingo-ball-animated{width:38px;height:38px}.ball-number-animated{font-size:15px}.bingo-blast-logo{gap:6px}.sound-icon,.exit-icon{width:82px;height:82px}.icon-btn{padding:4px}.header-banner-wrap{padding-right:96px}}.header-left{display:flex;align-items:center;flex:1 1 auto}.header-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end;position:relative}.header-icon-group{display:flex;align-items:center;gap:6px}.icon-btn{background:none;border:none;padding:4px;margin:0 2px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.icon-btn:active,.icon-btn:focus{background:#00000012}.sound-icon,.exit-icon{width:28px;height:28px;display:block}.header-icon-group.overlay-icons .icon-btn{padding:8px;min-width:44px;min-height:44px}.header-icon-group.overlay-icons .sound-icon,.header-icon-group.overlay-icons .exit-icon{width:34px;height:34px}@media (max-width: 600px){.header-icon-group{gap:2px}.sound-icon,.exit-icon{width:22px;height:22px}.header-icon-group.overlay-icons .icon-btn{padding:8px;min-width:44px;min-height:44px}.header-icon-group.overlay-icons .sound-icon,.header-icon-group.overlay-icons .exit-icon{width:32px;height:32px}}.center-bingo-btn{margin:0 auto;display:flex;align-items:center;justify-content:center}.logo{display:flex;align-items:center;justify-content:center;gap:12px;color:#fff;font-size:24px;font-weight:700;margin:0}.logo-icon{width:45px;height:45px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#1b1b1b;background:radial-gradient(circle at 30% 30%,#fff,#f9f9f9 35%,#f1d36b 36%,#f6b93b 65%,#b07a1e);box-shadow:0 8px 20px #00000073,0 4px 8px #f6b93b80,inset 0 3px 8px #ffffffb3,inset 0 -2px 6px #b07a1e66;animation:spinBall 6s linear infinite,logoGlow 3s ease-in-out infinite;position:relative;overflow:hidden}.logo-icon:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.6) 50%,transparent 70%);animation:shine 3s infinite}@keyframes shine{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}@keyframes logoGlow{0%,to{filter:brightness(1);box-shadow:0 8px 20px #00000073,0 4px 8px #f6b93b80,inset 0 3px 8px #ffffffb3}50%{filter:brightness(1.15);box-shadow:0 8px 25px #00000073,0 4px 12px #f6b93bcc,0 0 20px #f6b93b66,inset 0 3px 8px #ffffffb3}}@keyframes spinBall{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sound-toggle{border:none;background:transparent;color:#fff;padding:4px 6px;border-radius:50%;font-size:18px;cursor:pointer;transition:filter .2s;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.sound-emoji{font-size:20px;transition:filter .2s}.sound-toggle.sound-off .sound-emoji{filter:grayscale(1) brightness(.7)}.header-bingo{width:auto;max-width:none;padding:8px 14px;font-size:13px}.share-toggle-btn{width:44px;height:44px;border-radius:50%;border:2px solid rgba(255,255,255,.6);background:linear-gradient(135deg,#4caf504d,#388e3c4d);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#fff;padding:0;box-shadow:0 4px 12px #4caf5066,0 2px 6px #0003;flex-shrink:0}.share-toggle-btn svg{width:20px;height:20px;fill:currentColor}.share-toggle-btn:hover{transform:translateY(-2px) scale(1.05);background:linear-gradient(135deg,#4caf5080,#388e3c80);box-shadow:0 6px 16px #4caf5080,0 3px 8px #0000004d}.sound-toggle:hover{transform:translateY(-1px);background:#fff3}.sound-toggle.sound-on{border-color:#4caf50b3;background:#4caf5033}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.screen{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:20px;animation:fadeIn .4s ease;min-height:0}#home-screen{position:relative;isolation:isolate;overflow:hidden}#home-screen:before{content:"";position:absolute;inset:-6%;z-index:0;pointer-events:none;background-image:url(/backgroundballs.png?v=20260117b);background-repeat:no-repeat;background-position:center top;background-size:120% auto;filter:blur(1.5px) brightness(.9);transform:translateZ(0);transform-origin:center;opacity:.8}#home-screen:after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 50% 35%,#0000,#00000040 55%,#00000073)}#home-screen>*{position:relative;z-index:1}@media (max-width: 720px){#home-screen{flex-direction:column;justify-content:flex-start;align-items:center;gap:18px}.seo-card{margin-top:0}}@media (min-width: 768px) and (max-width: 1024px){#home-screen{flex-direction:column;justify-content:flex-start;align-items:center;gap:18px;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}.seo-card{margin-top:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hidden{display:none!important}.card,.welcome-card{background:#fffffffa;border-radius:var(--border-radius);box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff80,0 0 40px #6a1b9a26;padding:30px;width:100%;max-width:500px;margin:0 auto;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);position:relative;z-index:10}@media (max-width: 600px){.card,.welcome-card,.header.header-hero,.bingo-hero-logo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}}.welcome-card{max-width:450px;position:relative;overflow:visible}.home-menu-card{overflow:hidden}.home-menu-card{--menu-bg-x: 50%;--menu-bg-y: 50%;--menu-bg-size: 145%;--menu-bg-opacity: .62}.home-menu-bg{position:absolute;inset:-22px;background-image:none;background-repeat:no-repeat;background-position:var(--menu-bg-x) var(--menu-bg-y);background-size:var(--menu-bg-size);opacity:var(--menu-bg-opacity);filter:saturate(1.05) contrast(1.05);pointer-events:none;z-index:0;transition:opacity .3s ease}.home-menu-bg.bg-loaded{background-image:url(/MenuBackground.png?v=20260127a)}.home-menu-card>:not(.home-menu-bg){position:relative;z-index:1}.welcome-card .policy-links{margin-top:24px;padding-top:20px;border-top:2px solid rgba(106,27,154,.1)}.card .policy-links{margin-top:20px;padding-top:15px;border-top:2px solid rgba(106,27,154,.1)}.welcome-card:before,.welcome-card:after{content:"\1f3b2";position:absolute;font-size:30px;opacity:.15;animation:float 4s ease-in-out infinite;z-index:-1}.welcome-card:before{top:-10px;right:-10px;animation-delay:0s}.welcome-card:after{content:"\1f3b0";bottom:-10px;left:-10px;animation-delay:2s}.welcome-header{text-align:center;margin-bottom:32px}.welcome-header h2,.welcome-header h1{color:var(--primary);font-size:28px;margin-bottom:12px;font-weight:700}#home-screen .welcome-header h1,#home-screen .welcome-header .subtitle{color:#000}.seo-card{margin-top:18px;max-width:650px;content-visibility:auto;contain-intrinsic-size:900px}.seo-card p{margin-top:10px;color:#444;line-height:1.55}.seo-steps,.seo-bullets{margin-top:10px;margin-left:18px;color:#444;line-height:1.55}.seo-bullets li,.seo-steps li{margin-top:6px}.seo-faq p{margin-top:10px;color:#444;line-height:1.55}.seo-card a{color:var(--primary);text-decoration:underline}.subtitle{color:#666;font-size:16px;line-height:1.5}.virtual-money-notice{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#4caf5026,#388e3c26);padding:8px 16px;border-radius:20px;margin-top:12px;border:2px solid rgba(76,175,80,.3);box-shadow:0 2px 8px #4caf501a}.notice-icon{font-size:18px}.notice-text{font-size:13px;font-weight:600;color:#388e3c;text-shadow:0 1px 2px rgba(255,255,255,.8)}.virtual-money-notice.guest-progress-notice{background:#00000038;border-color:#ffffff47;box-shadow:0 2px 10px #0000002e}.virtual-money-notice.guest-progress-notice .notice-text{color:#ffffffeb;text-shadow:0 1px 2px rgba(0,0,0,.35)}@media (max-width: 600px){.virtual-money-notice{padding:6px 12px}.notice-text{font-size:12px}}.card-title{color:var(--primary);font-size:24px;font-weight:600;text-align:center;margin-bottom:24px}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:500;color:var(--dark);margin-bottom:8px;font-size:14px}.form-input{width:100%;padding:14px 16px;border:2px solid #E0E0E0;border-radius:var(--border-radius-sm);font-size:16px;font-family:inherit;transition:var(--transition);background:#fff}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6a1b9a1a}.code-input{text-transform:uppercase;text-align:center;font-size:24px;font-weight:600;letter-spacing:4px}.code-input::placeholder{font-size:14px;font-weight:500;letter-spacing:1px}.form-hint{display:block;color:#666;font-size:13px;margin-top:6px}.avatar-selection{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}.avatar-option{width:100%;aspect-ratio:1;border-radius:50%;background:linear-gradient(135deg,#9c27b01a,#6a1b9a1a);border:3px solid #E0E0E0;display:flex;align-items:center;justify-content:center;font-size:32px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.avatar-option:before{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(255,255,255,.3),transparent 60%);opacity:0;transition:opacity .3s ease}.avatar-option:hover:before{opacity:1}.avatar-option:hover{transform:scale(1.1);border-color:var(--primary-light);box-shadow:0 4px 12px #9c27b04d}.avatar-option.selected{border-color:var(--primary);background:linear-gradient(135deg,#9c27b040,#6a1b9a40);box-shadow:0 4px 16px #9c27b066,inset 0 1px 3px #ffffff4d;transform:scale(1.05)}.avatar-option.photo{background-size:cover;background-position:center}.avatar-upload-section{display:flex;justify-content:center;margin-top:10px}.player-avatar-display{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#9c27b033,#6a1b9a33);border:3px solid var(--primary);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 12px #9c27b066,inset 0 1px 3px #fff3;flex-shrink:0}.player-avatar-display.photo{background-size:cover;background-position:center}.player-name-balance{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.player-name-row{display:flex;gap:6px;align-items:center}.balance-header-display{display:flex;align-items:center;gap:4px;flex-shrink:0}@media (max-width: 600px){.balance-header-display{display:none}}.toggle-switch{display:flex;align-items:center;cursor:pointer;user-select:none;padding:12px 0}.toggle-switch input{display:none}.toggle-slider{position:relative;width:56px;height:28px;background:#ccc;border-radius:28px;transition:var(--transition);flex-shrink:0}.toggle-slider:before{content:"";position:absolute;height:22px;width:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:var(--transition);box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(28px)}.toggle-label{margin-left:12px;font-size:14px;font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;font-size:16px;font-weight:600;font-family:inherit;border:none;border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition);text-align:center;text-decoration:none;white-space:nowrap;box-shadow:0 6px #0000002e,0 10px 18px #0000002e}.btn:active{transform:translateY(2px);box-shadow:0 3px #0003,0 6px 12px #0003}.btn-large{width:100%;padding:16px 24px;font-size:18px}.btn-small{padding:8px 16px;font-size:14px}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;position:relative;overflow:hidden;box-shadow:0 4px 15px #6a1b9a66,0 2px 4px #0003,inset 0 1px #fff3}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-primary:hover:before{left:100%}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,#3d0f5c 100%);box-shadow:0 6px 20px #6a1b9a99,0 4px 8px #0000004d,inset 0 1px #fff3;transform:translateY(-2px)}.btn-primary:disabled{background:#ccc;cursor:not-allowed;box-shadow:none}.btn-secondary{background:linear-gradient(135deg,var(--secondary) 0%,#C2185B 100%);color:#fff;position:relative;overflow:hidden;box-shadow:0 4px 15px #e91e6366,0 2px 4px #0003,inset 0 1px #fff3}.btn-secondary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-secondary:hover:before{left:100%}.btn-secondary:hover{background:linear-gradient(135deg,#c2185b,#880e4f);box-shadow:0 6px 20px #e91e6399,0 4px 8px #0000004d,inset 0 1px #fff3;transform:translateY(-2px)}.btn-game-cyan,.btn-game-purple{color:#fff;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--btn-game-a) 0%,var(--btn-game-b) 100%);box-shadow:0 4px 15px var(--btn-game-shadow),0 2px 4px #0003,inset 0 1px #fff3}.btn-game-cyan:before,.btn-game-purple:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);transition:left .5s}.btn-game-cyan:hover:before,.btn-game-purple:hover:before{left:100%}.btn-game-cyan:hover,.btn-game-purple:hover{background:linear-gradient(135deg,var(--btn-game-hover-a) 0%,var(--btn-game-hover-b) 100%);box-shadow:0 6px 20px var(--btn-game-hover-shadow),0 4px 8px #0000004d,inset 0 1px #fff3;transform:translateY(-2px)}.btn-game-cyan:disabled,.btn-game-purple:disabled{background:#ccc;cursor:not-allowed;box-shadow:none}.btn-game-cyan{--btn-game-a: #00b8d4;--btn-game-b: #1565c0;--btn-game-hover-a: #1565c0;--btn-game-hover-b: #0d47a1;--btn-game-shadow: rgba(21, 101, 192, .38);--btn-game-hover-shadow: rgba(21, 101, 192, .58)}.btn-game-purple{--btn-game-a: #8e24aa;--btn-game-b: #5e35b1;--btn-game-hover-a: #5e35b1;--btn-game-hover-b: #311b92;--btn-game-shadow: rgba(94, 53, 177, .38);--btn-game-hover-shadow: rgba(94, 53, 177, .58)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#45a049;box-shadow:0 4px 8px #4caf504d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#d32f2f;box-shadow:0 4px 8px #f443364d}.btn-outline{background:transparent;color:var(--dark);border:2px solid #E0E0E0;box-shadow:none}.btn-outline:hover{background:#f5f5f5;border-color:var(--primary);color:var(--primary)}.btn-icon{font-size:24px}.button-group{display:flex;flex-direction:column;gap:12px;margin-top:24px}.home-menu-buttons{position:relative}.home-menu-card .btn-outline{background:#fff}.room-code-display{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);padding:20px;border-radius:16px;text-align:center;margin-bottom:24px;box-shadow:0 8px 20px #6a1b9a66,0 0 40px #9c27b033,inset 0 1px #fff3;border:2px solid rgba(255,255,255,.2);position:relative;overflow:hidden}.room-code-display:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:shine 3s infinite}.room-code-label{display:block;color:#ffffffe6;font-size:14px;font-weight:500;margin-bottom:8px}.room-code{display:block;color:#fff;font-size:36px;font-weight:700;letter-spacing:6px;font-family:Courier New,monospace}.room-code-small{text-align:center;color:#666;font-size:14px;margin-top:12px}.room-code-small span{font-weight:600;color:var(--primary)}.host-card{max-width:800px!important;padding:20px;margin-top:20px}#host-panel{padding-top:20px}.host-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px}.room-code-display-compact{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);padding:12px 20px;border-radius:var(--border-radius-sm);flex:1}.room-code-compact{display:block;color:#fff;font-size:16px;font-weight:700;letter-spacing:3px;font-family:Courier New,monospace}.bingo-ball-compact{flex-shrink:0}.bingo-ball-small{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,gold,orange);box-shadow:0 4px 8px #ffa50066;display:flex;align-items:center;justify-content:center}.ball-number-small{font-size:28px;font-weight:700;color:var(--dark)}.host-controls-compact{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.host-controls-compact .btn{padding:10px 8px;font-size:14px}.call-board-container-priority{margin-bottom:16px}.call-board-container-priority .call-board{gap:4px;padding:12px}.host-bottom-info{display:grid;grid-template-columns:1fr 1fr;gap:16px}.prizes-compact{display:flex;flex-direction:column;gap:8px}.prize-item{display:flex;align-items:center;gap:8px;padding:8px;background:#f5f5f5;border-radius:8px;font-size:13px}.prize-mini-icon{font-size:20px}.prize-mini-text{flex:1;font-weight:600}.prize-mini-status{font-size:12px;font-weight:600;color:var(--success)}.prize-item.claimed .prize-mini-status{color:var(--danger)}.players-section-compact{display:flex;flex-direction:column;margin-top:16px;background:#fff;padding:12px;border-radius:var(--border-radius-sm);border:2px solid var(--primary)}.section-subtitle{font-size:14px;font-weight:600;color:var(--primary);margin-bottom:8px}.player-list-compact{background:#f5f5f5;border-radius:var(--border-radius-sm);padding:8px;max-height:200px;overflow-y:auto;min-height:50px}.player-list-compact .player-item{padding:8px;margin-bottom:4px;background:#fff;border-radius:4px;border-left:3px solid var(--primary);font-size:13px}.player-list-compact .player-item:last-child{margin-bottom:0}.player-name-text{font-weight:600;color:var(--dark);font-size:14px}.player-details{font-size:12px;color:#666;margin-top:2px}.balance-highlight{color:var(--success);font-weight:700}.game-complete-section{margin-top:20px;padding:20px;background:linear-gradient(135deg,#4caf50,#81c784);border-radius:var(--border-radius-md);text-align:center;animation:slideIn .5s ease}.complete-message h3{color:#fff;font-size:24px;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3);font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.complete-message p{color:#fff;font-size:16px;margin-bottom:20px}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.header-bingo{width:auto;max-width:none;padding:8px 18px;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff2f6b,#ff8a00);color:#fff;border-radius:16px;box-shadow:0 4px 16px #ff2f6b2e;letter-spacing:1px;transition:background .2s,box-shadow .2s}.bingo-btn-text{display:flex;align-items:center;font-size:18px;font-weight:700;gap:6px}.bingo-emoji{font-size:20px;margin-left:2px}.player-info-bar{display:flex;align-items:center;gap:10px;padding:8px 10px;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border-radius:var(--border-radius-sm);margin-bottom:6px;flex-wrap:wrap}.player-info-bar.horizontal{flex-direction:row;justify-content:flex-start;gap:10px}.room-code-small{font-size:13px;color:#0009;font-weight:600;white-space:nowrap}.room-code-small span{font-weight:800;color:var(--primary);letter-spacing:1px}.current-prize-display{background:linear-gradient(135deg,gold,orange);padding:6px 10px;border-radius:8px;text-align:center;margin-bottom:8px;box-shadow:0 2px 8px #ffa5002e;border:1px solid rgba(255,255,255,.18);position:relative;overflow:hidden;animation:prizeGlow 2s ease-in-out infinite}.prize-label-playing.small,.current-prize-text.small{font-size:13px!important;padding:0!important;margin:0!important}.btn-outline{position:relative}.btn-exit-top{position:static;display:block;margin:0 0 10px auto;z-index:10;padding:8px 16px;font-size:15px;border-radius:8px}@media (max-width: 600px){body,.app-container{padding:0!important;margin:0!important;overflow-x:hidden!important;max-width:100vw}.screen{padding:6px!important;min-height:100vh;box-sizing:border-box}.player-card,.card{max-width:100vw!important;width:100vw!important;border-radius:8px!important;margin:0 auto 8px!important;box-sizing:border-box}.player-header{margin-bottom:4px!important}.player-info-bar.horizontal{font-size:12px!important;gap:4px!important;padding:4px 2px!important}.balance-icon,.balance-amount{font-size:15px!important}.room-code-small{font-size:10px!important;margin-left:4px!important}.current-prize-display{font-size:11px!important;padding:2px 4px!important;border-radius:5px!important;margin-bottom:4px!important}.prize-label-playing.small,.current-prize-text.small{font-size:10px!important}.bingo-ball-mini{width:32px!important;height:32px!important;font-size:14px!important}.call-history-row.condensed .history-ball{height:19px!important;min-width:19px!important;font-size:10px!important;margin:0 .5px!important}.tickets-section{margin:6px 0!important}.tickets-header{margin-bottom:4px!important;font-size:13px!important}.tickets-container{gap:6px!important;padding:4px!important;max-height:none!important;overflow-y:auto!important}.ticket{padding:6px!important;border-radius:6px!important;font-size:12px!important;flex-shrink:0!important}.btn,.btn-outline,.btn-primary,.btn-secondary,.btn-success{font-size:13px!important;padding:7px 12px!important;border-radius:7px!important}.btn-exit-top{font-size:12px!important;padding:5px 8px!important;top:2px!important;right:2px!important}.header-content{padding:0 4px!important}.logo{font-size:14px!important;gap:3px!important}.logo-icon{width:22px!important;height:22px!important;font-size:10px!important}.header-bingo{font-size:13px!important;padding:6px 8px!important;border-radius:8px!important}.bingo-btn-text{font-size:13px!important;gap:2px!important}.bingo-emoji{font-size:13px!important}.btn-exit-top{position:relative;z-index:100}.header.fixed-player{position:sticky;top:0;z-index:100}}@media (max-width: 600px){.header-content{flex-direction:row;gap:8px;align-items:center}.header-left{flex:1 1 auto;min-width:0}.logo{font-size:18px;gap:6px}.logo-icon{width:32px;height:32px;font-size:14px}.header-actions{width:auto;justify-content:flex-end;gap:6px}.btn-bingo.header-bingo{font-size:15px;padding:8px 10px;border-radius:10px}.bingo-btn-text{font-size:15px;gap:4px}.bingo-emoji{font-size:16px}.player-info-bar.horizontal{flex-direction:row;gap:6px;font-size:13px;padding:6px 4px}.btn-exit-top{font-size:13px;padding:6px 10px;top:6px;right:6px}.current-prize-display{font-size:12px;padding:4px 6px;border-radius:6px}.prize-label-playing.small,.current-prize-text.small{font-size:11px!important}}@media (max-width: 480px){.header-content{flex-direction:column;gap:10px}.header-actions{width:100%;justify-content:center}.sound-toggle{max-width:140px}.host-header-row{flex-wrap:wrap;gap:10px}.room-code-display-compact{flex:1 1 100%;order:1}.share-toggle-btn{order:2;width:50px;height:50px}.share-toggle-btn svg{width:24px;height:24px}.bingo-ball-compact{order:3}.host-controls-compact{grid-template-columns:repeat(2,1fr)}.host-bottom-info{grid-template-columns:1fr}}@media (max-width: 768px){#host-panel .host-card .host-header-row{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:10px}#host-panel .host-card .room-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0}#host-panel .host-card .room-code-display-compact{flex:1 1 auto;max-width:75%;padding:10px 12px;border-radius:12px}#host-panel .host-card .room-code-label{font-size:12px;line-height:1.1;margin-bottom:2px}#host-panel .host-card .room-code-compact{font-size:14px;letter-spacing:2px}#host-panel .host-card .share-toggle-btn{flex:0 0 auto;width:44px;height:44px;margin:0}#host-panel .host-card .room-code-display-compact,#host-panel .host-card .share-toggle-btn{order:0!important;position:static!important;transform:none!important}}.host-controls{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.control-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.bingo-ball-display{margin:24px 0}.ball-container{display:flex;justify-content:center;align-items:center;padding:20px}.bingo-ball{width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff,#fffacd 15%,gold 35%,orange);box-shadow:0 10px 30px #ffa50080,0 5px 15px #0000004d,inset 0 -5px 15px #00000040,inset 0 3px 8px #fff9,0 0 30px #ffd7004d;display:flex;align-items:center;justify-content:center;animation:bounce .6s ease,ballGlow 2s ease-in-out infinite;position:relative}.bingo-ball:before{content:"";position:absolute;top:15%;left:20%;width:30%;height:30%;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.8),transparent);filter:blur(3px)}@keyframes ballGlow{0%,to{box-shadow:0 10px 30px #ffa50080,0 5px 15px #0000004d,inset 0 -5px 15px #00000040,inset 0 3px 8px #fff9}50%{box-shadow:0 10px 35px #ffa500b3,0 5px 15px #0000004d,inset 0 -5px 15px #00000040,inset 0 3px 8px #fff9,0 0 40px #ffd70080}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.ball-number{font-size:48px;font-weight:700;color:var(--dark);text-shadow:2px 2px 4px rgba(255,255,255,.5)}.call-board-container{margin:24px 0}.section-title{font-size:18px;font-weight:600;color:var(--primary);margin-bottom:16px;text-align:center}.call-board{display:grid;grid-template-columns:repeat(10,1fr);gap:6px;padding:16px;background:#f5f5f5;border-radius:var(--border-radius-sm)}.num-cell{aspect-ratio:1;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--dark);box-shadow:0 2px 6px #0000001a,inset 0 1px #fffc;transition:all .3s ease;user-select:none;border:1px solid rgba(224,224,224,.5);cursor:default}.num-cell:not(.called):hover{transform:scale(1.05);box-shadow:0 4px 10px #00000026,inset 0 1px #fffc}.num-cell.called{background:linear-gradient(135deg,var(--success) 0%,#66BB6A 100%);color:#fff;transform:scale(.95);box-shadow:0 4px 8px #4caf5066;animation:pop .3s ease}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(.95)}}.prizes-display{margin:24px 0}.prize-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.prize-card{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border-radius:12px;padding:16px;text-align:center;box-shadow:0 4px 12px #0000001f,inset 0 1px #ffffff80;transition:all .3s ease;border:2px solid rgba(224,224,224,.5);position:relative;overflow:hidden}.prize-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);transform:translate(-100%);transition:transform .6s}.prize-card:hover:before{transform:translate(100%)}.prize-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000002e,inset 0 1px #ffffff80}.prize-card.claimed{background:linear-gradient(135deg,#66bb6a,#4caf50);color:#fff;border-color:#4caf50;box-shadow:0 4px 15px #4caf5066,0 0 30px #4caf5033,inset 0 1px #ffffff4d;animation:prizeWon .6s ease}@keyframes prizeWon{0%,to{transform:scale(1)}25%{transform:scale(1.1) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}.prize-icon{font-size:32px;margin-bottom:8px}.prize-label{font-size:13px;font-weight:500;margin-bottom:4px}.prize-amount{font-size:20px;font-weight:700;color:var(--primary);margin-bottom:8px}.prize-card.claimed .prize-amount{color:#fff}.prize-status{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--success)}.prize-card.claimed .prize-status{color:#fff}.players-section{margin:24px 0}.player-list{background:#f5f5f5;border-radius:var(--border-radius-sm);padding:16px;max-height:200px;overflow-y:auto}.player-item{padding:12px;background:#fff;border-radius:8px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000000f}.player-item:last-child{margin-bottom:0}.player-name-text{font-weight:600;color:var(--dark)}.player-details{font-size:13px;color:#666}#player-panel{min-height:100dvh;min-height:100vh;padding:0;overflow-y:auto;background:radial-gradient(circle at 20% 20%,rgba(156,39,176,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(33,150,243,.08) 0%,transparent 50%)}.player-card{max-width:600px;width:100%;margin:0 auto;padding:12px;background:transparent;box-shadow:none;border-radius:0}.current-prize-display{background:linear-gradient(135deg,#ff6b35,#ff8c42,#ffd23f);padding:10px 12px;border-radius:12px;text-align:center;margin:10px 0;box-shadow:0 6px 16px #ff6b3559,0 3px 10px #ff8c4240,inset 0 1px 4px #fff6;border:2px solid rgba(255,255,255,.5);position:relative;overflow:hidden;animation:prizeGlow 2s ease-in-out infinite}.current-prize-display:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);animation:shine 4s infinite}.prize-label-playing{font-size:11px;font-weight:600;color:#000c;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;text-shadow:0 1px 2px rgba(255,255,255,.5);position:relative;z-index:1}.prize-label-playing.small{font-size:10px;margin-bottom:3px}.current-prize-text{font-size:18px;font-weight:800;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3),0 0 10px rgba(255,255,255,.5);position:relative;z-index:1;letter-spacing:1px}.current-prize-text.small{font-size:22px}@keyframes prizeGlow{0%,to{box-shadow:0 6px 20px #ffa50066,0 0 30px #ffd70033,inset 0 2px 5px #ffffff4d}50%{box-shadow:0 6px 25px #ffa50099,0 0 40px #ffd70066,inset 0 2px 5px #ffffff4d}}.share-room-card{background:#ffffffeb;padding:14px;border-radius:var(--border-radius-sm);margin-bottom:16px;box-shadow:0 8px 16px #00000014}.share-modal{position:fixed;inset:0;background:#0b102099;display:flex;align-items:center;justify-content:center;z-index:200}.share-modal-content{width:min(420px,92vw);background:#fff;border-radius:16px;padding:16px;box-shadow:0 18px 40px #00000040}.share-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.share-modal-title{font-weight:700;color:#1f2a44}.credits-modal{position:fixed;inset:0;background:#0b102099;display:flex;align-items:center;justify-content:center;z-index:220}.credits-modal-content{width:min(420px,92vw);background:#fff;border-radius:18px;padding:18px;box-shadow:0 18px 44px #00000047;text-align:center}.credits-win-content{position:relative;overflow:hidden}.credits-win-burst{position:absolute;inset:-60%;background:radial-gradient(circle at 30% 30%,#9c27b052,#9c27b000 55%),radial-gradient(circle at 70% 40%,#6a1b9a38,#6a1b9a00 60%),radial-gradient(circle at 50% 70%,#4a148c2e,#4a148c00 55%);transform:scale(.85);animation:creditsBurst 1.3s ease-out infinite;pointer-events:none}@keyframes creditsBurst{0%{transform:scale(.82) rotate(0);opacity:.9}60%{transform:scale(1.02) rotate(4deg);opacity:1}to{transform:scale(1.08) rotate(6deg);opacity:.85}}.credits-win-title{position:relative;font-weight:800;letter-spacing:.6px;color:var(--primary);font-size:26px;margin-top:8px}.credits-win-amount{position:relative;font-weight:800;color:#111827;font-size:40px;margin:10px 0 6px}.credits-win-suffix{font-size:18px;font-weight:800;color:var(--primary-dark)}.credits-win-balance{position:relative;font-weight:700;color:#334155;margin-bottom:14px}.credits-low-title{font-weight:800;color:#111827;font-size:22px;margin-top:4px}.credits-low-message{margin:10px 0 16px;color:#475569;font-weight:600}.resume-countdown{position:fixed;left:50%;top:76px;transform:translate(-50%);background:#111827e6;color:#fff;padding:8px 14px;border-radius:18px;font-weight:700;font-size:14px;z-index:210;box-shadow:0 10px 22px #00000040}.share-title{font-weight:700;font-size:14px;margin-bottom:8px;color:#1f2a44}.share-link-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}.share-link-text{flex:1 1 200px;font-size:12px;color:#3c4a6a;background:#f3f6ff;padding:6px 8px;border-radius:10px;word-break:break-all}.share-fallback{margin-bottom:10px}.share-fallback-actions{display:flex;gap:8px;flex-wrap:wrap}.share-qr{display:flex;justify-content:center}.share-qr img{width:140px;height:140px;border-radius:12px;background:#fff;padding:6px;box-shadow:0 6px 14px #0000001f}.prize-label-playing{font-size:12px;font-weight:600;color:#000000b3;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.current-prize-text{font-size:24px;font-weight:700;color:var(--dark)}.bingo-ball-display-compact{text-align:center;margin:10px 0 12px;padding:12px;background:linear-gradient(135deg,#fffffff2,#e6f0fff2);border-radius:14px;box-shadow:0 6px 16px #2196f333,0 3px 8px #00000014,inset 0 1px #fffc;border:2px solid rgba(33,150,243,.2);display:flex;flex-direction:column;align-items:center;position:relative}.bb-round-mini{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;padding:6px 8px;border-radius:999px;background:#ffffffbf;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 6px #00000014;user-select:none}.bb-round-mini__value{font-size:10px;font-weight:900;color:#000000c7;font-variant-numeric:tabular-nums;white-space:nowrap}.bb-autodab-mini{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:999px;background:#ffffffbf;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 6px #00000014;cursor:pointer;user-select:none}.bb-autodab-mini input{position:absolute;opacity:0;pointer-events:none}.bb-autodab-mini__label{font-size:10px;font-weight:800;color:#000000b8;letter-spacing:.4px;text-transform:uppercase}.bb-autodab-mini__slider{width:34px;height:18px;border-radius:999px;background:#0000002e;position:relative;flex:0 0 auto;transition:background .18s ease}.bb-autodab-mini__slider:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0000002e;transition:transform .18s ease}.bb-autodab-mini input:checked+.bb-autodab-mini__slider{background:#4caf50bf}.bb-autodab-mini input:checked+.bb-autodab-mini__slider:after{transform:translate(16px)}.bb-autodab-mini:focus-within{outline:2px solid rgba(33,150,243,.55);outline-offset:2px}.bb-winneed-ball{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 30%,#fff,#f5f5f5 40%,#e0e0e0);border:2px solid rgba(0,0,0,.12);box-shadow:0 2px 6px #0000001f;margin-left:4px}.bb-winneed-number{font-size:12px;font-weight:900;color:#000000b8;font-variant-numeric:tabular-nums}.bb-winneed-ball.bb-winneed-ball--active{width:56px;height:56px;background:radial-gradient(circle at 30% 30%,#fff,#fff6c2 20%,#ffb300 65%,#ff6f00);border-color:#0000002e;box-shadow:0 0 0 2px #ffb30059,0 0 18px #ffb30059,0 6px 16px #00000029;animation:bbWinNeedPulse 1.15s ease-in-out infinite}.bb-winneed-ball.bb-winneed-ball--active .bb-winneed-number{font-size:20px;color:#111}@keyframes bbWinNeedPulse{0%,to{box-shadow:0 0 0 2px #ffb3004d,0 0 16px #ffb30047,0 6px 16px #00000029}50%{box-shadow:0 0 0 2px #ffb3008c,0 0 26px #ffb3007a,0 6px 16px #00000029}}@media (prefers-reduced-motion: reduce){.bb-winneed-ball.bb-winneed-ball--active{animation:none!important}}.bb-return-lobby-modal{position:fixed;top:94px;left:50%;transform:translate(-50%);z-index:1100;width:min(92vw,420px)}.bb-return-lobby-card{background:#fffffff5;border:2px solid rgba(76,175,80,.25);border-radius:16px;padding:12px 14px;box-shadow:0 12px 28px #00000029}.bb-return-lobby-title{font-weight:900;color:#000000d1;text-transform:uppercase;letter-spacing:.6px;font-size:12px}.bb-return-lobby-subtitle{margin-top:4px;font-weight:700;color:#000000ad;font-size:12px}.bb-return-lobby-actions{display:flex;gap:10px;margin-top:10px;justify-content:flex-end}.balance-ball-row{display:flex;align-items:center;justify-content:space-around;gap:12px;margin-bottom:10px}.balance-display-compact{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:12px;padding:6px 12px;min-width:80px;box-shadow:0 4px 12px #4caf5066,inset 0 1px 3px #fff6;border:2px solid rgba(255,255,255,.3)}.balance-label-mini{font-size:10px;font-weight:700;color:#ffffffe6;text-transform:uppercase;letter-spacing:1px;text-shadow:0 1px 2px rgba(0,0,0,.2)}.balance-value-mobile{font-size:20px;font-weight:900;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3),0 0 8px rgba(255,255,255,.3);margin-top:2px}.balance-value-mobile:before{content:"";font-size:.9em}.ball-section-compact{display:flex;flex-direction:column;align-items:center}.last-number-label{font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.bingo-ball-mini{width:65px;height:65px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffffff 0%,#f0f4ff 35%,var(--info) 36%,#1976d2 70%,#0d47a1 100%);display:inline-flex;align-items:center;justify-content:center;margin:6px auto 10px;box-shadow:0 8px 20px #2196f366,0 4px 10px #00000026,inset -2px -2px 6px #0003,inset 2px 2px 6px #fffc;border:2px solid rgba(255,255,255,.3);animation:ballPulse 2s ease-in-out infinite}@keyframes ballPulse{0%,to{transform:scale(1);box-shadow:0 12px 30px #2196f366,0 6px 15px #00000026,inset -3px -3px 10px #0003,inset 3px 3px 10px #fffc}50%{transform:scale(1.05);box-shadow:0 15px 40px #2196f380,0 8px 20px #0003,inset -3px -3px 10px #0003,inset 3px 3px 10px #fffc}}.ball-number-mini{font-size:30px;font-weight:900;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.4),0 0 8px rgba(255,255,255,.3)}.call-history-row{display:flex;justify-content:center;gap:8px;margin-top:12px;flex-wrap:wrap}.call-history-row.condensed{gap:6px;margin-top:8px}.history-ball{height:29px;min-width:29px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#fff8c4 22%,gold 50%,orange);display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:#111;font-size:12px;box-shadow:0 3px 8px #ffa50059,0 1px 4px #00000026,inset -1px -1px 2px #0003,inset 1px 1px 2px #ffffff80;border:1.5px solid rgba(255,255,255,.3);text-shadow:none;transition:transform .2s ease}.history-ball:hover{transform:scale(1.1)}.history-ball.called{border-color:#00000040}.last-number-label{font-size:14px;font-weight:600;color:#666;margin-bottom:8px}.bingo-ball-mini{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,gold,orange);box-shadow:0 2px 4px #ffa50040;display:inline-flex;align-items:center;justify-content:center;margin:0 auto}.ball-number-mini{font-size:18px;font-weight:700;color:var(--dark)}.bingo-button-section{margin:24px 0;text-align:center}.btn-bingo{width:100%;max-width:300px;padding:24px;background:linear-gradient(135deg,#ff6b35,#f7931e,#ff6b35);background-size:200% 200%;color:#fff;font-size:32px;font-weight:800;border-radius:20px;box-shadow:0 10px 30px #ff6b3580,0 5px 15px #0000004d,inset 0 2px 5px #ffffff4d,0 0 40px #ff6b354d;animation:pulse 2s infinite,gradientShift 3s ease infinite;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;border:4px solid rgba(255,255,255,.4);text-shadow:3px 3px 6px rgba(0,0,0,.4);cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center}.bingo-button-wrapper{display:flex;justify-content:center;margin-top:16px;padding:6px 0}.btn-bingo.inline-bingo{position:relative;width:auto;min-width:180px;padding:14px 36px;font-size:22px;border-radius:40px;box-shadow:0 8px 24px #ff6b3580,0 4px 12px #0000004d,0 0 30px #ff6b354d;animation:bingoPulse 2s ease-in-out infinite}@keyframes bingoPulse{0%,to{transform:scale(1);box-shadow:0 8px 24px #ff6b3580,0 4px 12px #0000004d}50%{transform:scale(1.03);box-shadow:0 10px 30px #ff6b35b3,0 6px 16px #0006}}.btn-bingo.inline-bingo:active{transform:scale(.95)}.btn.game-active{background:linear-gradient(135deg,#ff6b35,#f7931e)!important;color:#fff!important;border:2px solid #FF4500!important;animation:gameActivePulse 1.5s ease-in-out infinite}@keyframes gameActivePulse{0%,to{box-shadow:0 2px 8px #ff6b3566}50%{box-shadow:0 4px 16px #ff6b35b3}}.btn-bingo.floating-bingo{position:fixed;bottom:15px;left:50%;transform:translate(-50%);z-index:1000;width:auto;min-width:150px;padding:12px 28px;font-size:20px;border-radius:40px;box-shadow:0 8px 24px #ff6b3580,0 4px 12px #0000004d,0 0 30px #ff6b354d}.btn-bingo.floating-bingo:active{transform:translate(-50%) scale(.95)}.bingo-btn-text{font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;width:100%;text-align:center}.bingo-emoji{font-size:20px}.btn-bingo-cta{background:linear-gradient(135deg,#ff2f6b,#ff8a00);box-shadow:0 6px #841e0080,0 10px 18px #00000040;letter-spacing:.5px}.btn-bingo-cta:active{box-shadow:0 3px #841e0099,0 6px 12px #0000004d}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.btn-bingo:hover:not(:disabled){transform:scale(1.05);box-shadow:0 14px 35px #ff6b3599,0 7px 20px #00000059}.btn-bingo.floating-bingo:hover:not(:disabled){transform:translate(-50%) scale(1.05)}.btn-bingo:disabled{background:linear-gradient(135deg,#9e9e9e,#757575);cursor:not-allowed;animation:none;box-shadow:0 4px 12px #0003,inset 0 1px 3px #fff3;opacity:.6}@keyframes pulse{0%,to{box-shadow:0 8px 16px #ff6b3566}50%{box-shadow:0 8px 24px #ff6b3599}}.bingo-icon{font-size:48px;display:block;margin-bottom:8px}.bingo-text{display:block;letter-spacing:4px}.bingo-status-text{margin-top:12px;font-size:14px;font-weight:600;color:#666}.bingo-alert{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;padding:20px;border-radius:var(--border-radius);margin-bottom:16px;text-align:center;box-shadow:0 8px 16px #ff6b3566;animation:alertPulse .5s ease}@keyframes alertPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.alert-header{font-size:24px;font-weight:700;margin-bottom:12px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.alert-player{font-size:18px;margin-bottom:16px}.alert-player span{font-weight:700;text-decoration:underline}.alert-claim-details{font-size:15px;font-weight:600;margin-bottom:6px}.alert-claim-status{font-size:14px;margin-bottom:14px}.alert-claim-status.valid{color:#e8f5e9}.alert-claim-status.invalid{color:#ffebee}.alert-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.alert-actions .btn{font-size:16px;padding:12px}.player-header{margin-bottom:10px;margin-top:8px}.player-info-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:linear-gradient(135deg,#fffffff2,#f0f0fff2);border-radius:10px;margin-bottom:0;box-shadow:0 4px 12px #6a1b9a26,0 2px 6px #00000014;border:1.5px solid rgba(106,27,154,.15)}.player-info-bar.horizontal{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:space-between}.player-name-display,.balance-display{display:flex;flex-direction:column;gap:2px}.info-label{font-size:10px;color:#666;font-weight:500}.info-value{font-size:14px;font-weight:600;color:var(--primary)}.balance-display{text-align:right}.balance-icon{font-size:20px}.balance-amount{font-size:18px;font-weight:800;color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);padding:4px 10px;border-radius:12px;border:2px solid #4CAF50;box-shadow:0 2px 6px #4caf504d}.balance-amount:before{content:""}.tickets-section{margin:10px 0 0;padding-bottom:20px}.tickets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:0 4px}.section-title{font-size:20px;font-weight:700;color:#2e7d32;text-shadow:0 2px 4px rgba(0,0,0,.15);margin:0}.tickets-container{display:flex;flex-direction:column;gap:12px;padding:10px;background:linear-gradient(135deg,#e8f5e999,#f3e5f599);border-radius:12px;max-height:none;overflow:visible;box-shadow:0 4px 12px #00000014;border:1.5px solid rgba(139,195,74,.2)}.ticket{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #8BC34A;border-radius:10px;padding:10px;box-shadow:0 6px 16px #0000001f,0 3px 8px #8bc34a33;position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.ticket:active{transform:scale(.98)}.ticket:before{content:"";position:absolute;top:0;left:0;right:0;height:32px;background:linear-gradient(135deg,#8bc34a,#7cb342,#689f38);z-index:0;box-shadow:0 2px 8px #00000026}.ticket h3{position:relative;z-index:1;text-align:center;color:#fff;font-size:12px;font-weight:700;margin:-10px -10px 8px;padding:8px;text-transform:uppercase;letter-spacing:1px;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.ticket-serial{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#00000040;color:#fff;padding:2px 8px;font-size:10px;font-weight:700;letter-spacing:1px;border-radius:999px;z-index:2}.ticket-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:1px;margin-top:2px;background:#000;padding:1px;border-radius:4px}.bb-ticket--nearwin{border-color:#ffb300;box-shadow:0 0 0 2px #ffb30059,0 10px 22px #00000024,0 6px 14px #8bc34a2e;animation:bbNearWinPulse 1.4s ease-in-out infinite}@keyframes bbNearWinPulse{0%,to{box-shadow:0 0 0 2px #ffb3004d,0 10px 22px #00000024,0 6px 14px #8bc34a2e}50%{box-shadow:0 0 0 2px #ffb3008c,0 0 18px #ffb30059,0 10px 22px #00000024}}.bb-ticket__nearwinBanner{margin:0 0 8px;padding:6px 10px;border-radius:10px;background:linear-gradient(135deg,#ff6f00,#ffb300);border:1px solid rgba(0,0,0,.08);color:#fffffff7;text-align:center;font-size:11px;font-weight:900;letter-spacing:.6px;text-transform:uppercase;box-shadow:0 4px 10px #ffb30038}.bb-cell--missing{position:relative;z-index:1;outline:2px solid rgba(255,179,0,.95);outline-offset:-2px;box-shadow:0 0 0 2px #ffb30059,0 0 16px #ffb30059;animation:bbMissingPulse 1.2s ease-in-out infinite}.cell{overflow:hidden}.bb-cell-number{display:inline-block;transform-origin:center;will-change:transform}.bb-cell--missing .bb-cell-number{animation:bbMissingNumberPop 1.2s ease-in-out infinite}@keyframes bbMissingNumberPop{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}@keyframes bbMissingPulse{0%,to{box-shadow:0 0 0 2px #ffb30052,0 0 14px #ffb30047}50%{box-shadow:0 0 0 2px #ffb30099,0 0 22px #ffb30073}}@media (prefers-reduced-motion: reduce){.bb-ticket--nearwin,.bb-cell--missing,.bb-cell--missing .bb-cell-number{animation:none!important}}.cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;border-radius:2px;font-size:20px;font-weight:800;font-variant-numeric:tabular-nums;background:#fff;cursor:pointer;transition:all .2s ease;user-select:none;box-shadow:none}.cell.blank{background:#f3f3f3;box-shadow:none;cursor:default}.cell.called{background:#ffd54f;color:#2c2c2c;animation:highlight .5s ease;position:relative;overflow:hidden;font-weight:800;box-shadow:none}@keyframes highlight{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.cell.dabbed{position:relative}.cell.dabbed:before{content:"";position:absolute;top:50%;left:50%;width:80%;height:80%;transform:translate(-50%,-50%);border-radius:50%;background:linear-gradient(145deg,#f44,#c00);box-shadow:0 4px 8px #0000004d,inset 0 2px 4px #ffffff4d,inset 0 -2px 4px #0003;pointer-events:none;z-index:1;animation:chipPop .18s ease-out}.cell.dabbed:after{content:attr(data-number);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:18px;font-weight:900;line-height:1;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.4),0 -1px 1px rgba(255,255,255,.2);z-index:2;animation:chipPop .18s ease-out}.cell.dabbed.special:before{background:linear-gradient(145deg,gold,#fa0);box-shadow:0 4px 12px #ffd70080,inset 0 2px 4px #fff6,inset 0 -2px 4px #cc99004d,0 0 20px #ffd70066;animation:chipPop .18s ease-out,starGlow 2s ease-in-out infinite}.cell.dabbed.special:after{content:"\2b50";font-size:20px;text-shadow:0 2px 4px rgba(0,0,0,.3);filter:drop-shadow(0 0 4px rgba(255,215,0,.8))}@keyframes chipPop{0%{transform:translate(-50%,-50%) scale(.85);opacity:.8}60%{transform:translate(-50%,-50%) scale(1.05)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes starGlow{0%,to{filter:drop-shadow(0 0 4px rgba(255,215,0,.8))}50%{filter:drop-shadow(0 0 12px rgba(255,215,0,1))}}.claim-section{margin:24px 0}.claim-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.btn-claim{flex-direction:column;padding:16px 8px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff}.btn-claim:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%)}.btn-claim:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.claim-icon{font-size:28px;margin-bottom:4px}.claim-text{font-size:13px;line-height:1.3}.claim-text small{font-size:16px;font-weight:700}.error-message{background:#ffebee;color:var(--danger);padding:12px 16px;border-radius:var(--border-radius-sm);margin:16px 0;font-size:14px;font-weight:500;border-left:4px solid var(--danger)}.success-message{background:#e8f5e9;color:#1b5e20;padding:12px 16px;border-radius:var(--border-radius-sm);margin:16px 0;font-size:14px;font-weight:500;border-left:4px solid #2E7D32}@media (max-width: 600px){body{font-size:14px}.screen{padding:12px}.card,.welcome-card,.player-card,.host-card{padding:16px;max-width:100%}.logo{font-size:18px}.logo-icon{font-size:24px}.welcome-header h2{font-size:22px}.room-code{font-size:24px;letter-spacing:3px}.room-code-compact{font-size:20px;letter-spacing:3px}.bingo-ball{width:80px;height:80px}.ball-number{font-size:36px}.bingo-ball-mini{width:70px;height:70px}.ball-number-mini{font-size:32px}.current-prize-text{font-size:20px}.call-board{gap:3px;padding:8px}.num-cell{font-size:11px;border-radius:4px}.prize-grid{grid-template-columns:1fr}.prize-card{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;text-align:left}.prize-icon{font-size:32px;margin:0}.host-header-row{flex-direction:column}.control-row{grid-template-columns:1fr}.host-controls-compact{grid-template-columns:repeat(2,1fr)}.host-bottom-info{grid-template-columns:1fr}.btn-bingo{font-size:28px;padding:20px}.bingo-icon{font-size:40px}.ticket{min-width:240px}.cell{font-size:18px}.player-info-bar{flex-direction:column;gap:8px;text-align:center}.balance-display{text-align:center}}@media (max-width: 400px){.ticket{min-width:220px}.cell{font-size:17px}.bingo-ball-small{width:60px;height:60px}.ball-number-small{font-size:24px}.current-prize-text{font-size:18px}.btn-bingo{font-size:24px;padding:16px}.tickets-container{grid-template-columns:1fr}}@media (orientation: portrait) and (max-width: 600px){.tickets-container{grid-template-columns:1fr;max-height:none;overflow-y:auto}.ticket{width:100%;flex-shrink:0}.ticket-grid{gap:2px}.cell{font-size:19px}.call-board{grid-template-columns:repeat(9,1fr)}.num-cell{font-size:10px}.player-card{display:flex;flex-direction:column;padding-bottom:80px}.player-header{order:1}.current-prize-display{order:2}.bingo-ball-display-compact{order:3}.tickets-section{order:4;flex:1}.bingo-button-section{order:5}.room-players-section{order:6}#back-to-home-player{position:fixed;bottom:10px;left:10px;right:10px;width:calc(100% - 20px);z-index:100;order:7}}.loading{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);background:var(--dark);color:#fff;padding:16px 24px;border-radius:50px;box-shadow:var(--shadow-lg);font-weight:500;z-index:11001;animation:toastSlideUp .3s ease}.queue-cards{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}.queue-card{border:2px solid rgba(106,27,154,.18);border-radius:16px;padding:8px 12px;background:#ffffffeb}.queue-title{font-weight:700;color:#4a148c;font-size:18px;margin:0 0 4px}.queue-count{margin:4px 0 8px;font-weight:600;color:#333}.public-lobby-footer{margin-top:12px}.public-lobby-footer .current-queue{color:var(--dark);text-align:center}.public-lobby-footer .queue-status-row{justify-content:center;flex-wrap:wrap}.public-lobby-footer .queue-status-label,.public-lobby-footer #current-queue-label,.public-lobby-footer #queue-badge,.public-lobby-footer .queue-waiting-line{color:var(--dark)}.public-lobby-footer #queue-badge,.public-lobby-footer .queue-waiting-line{margin-left:auto;margin-right:auto}.public-lobby-footer #queue-badge.queue-badge{background:#6a1b9a14;border-color:#6a1b9a38}.public-lobby-footer.queued .current-queue{margin-bottom:6px}.public-lobby-footer.queued .button-group{margin-top:8px}.current-queue{font-weight:600;color:#333;margin-bottom:10px;min-height:56px}.policy-links{margin-top:20px;padding-top:15px;border-top:2px solid rgba(106,27,154,.1);text-align:center;font-size:13px}.policy-links a{color:#6a1b9a;text-decoration:none;font-weight:600;transition:all .2s ease}.policy-links a:hover{color:#9c27b0;text-decoration:underline}.ready-countdown{font-weight:800;font-size:20px;text-align:center;margin:6px 0 14px;color:#4a148c}.ready-ticket-row{display:grid;gap:8px;justify-items:center;margin:10px 0 14px}.ready-ticket-meta{font-size:13px;font-weight:800;color:#000000b8}.ready-player-list{display:grid;gap:8px;margin-bottom:14px}.ready-player{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:12px;background:#6a1b9a12}.ready-pill{font-weight:800;font-size:12px;padding:6px 10px;border-radius:999px;background:#f443361f;color:#b71c1c}.ready-pill.on{background:#4caf5029;color:#1b5e20}.ready-btn{position:relative;overflow:hidden;transform:translateZ(0);animation:readyPulse 1.2s ease-in-out infinite}@keyframes readyPulse{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}.fireworks-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden}.firework{position:absolute;width:4px;height:4px;border-radius:50%;animation:firework-fade 1s ease-out forwards}.firework-particle{position:absolute;width:6px;height:6px;border-radius:50%;top:0;left:0;animation:firework-explode 1s ease-out forwards}@keyframes firework-explode{0%{transform:translate(0);opacity:1}to{transform:translate(var(--tx),var(--ty));opacity:0}}@keyframes firework-fade{0%,20%{opacity:1}to{opacity:0}}.player-card{position:relative;overflow:visible}.player-card:before{content:"\1f389";position:absolute;top:-15px;right:10px;font-size:40px;animation:float 3s ease-in-out infinite;z-index:-1}.player-card:after{content:"\1f38a";position:absolute;bottom:-15px;left:10px;font-size:40px;animation:float 3s ease-in-out infinite 1.5s;z-index:-1}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(5deg)}}.balance-icon{animation:pulse-gold 2s ease-in-out infinite;display:inline-block}@keyframes pulse-gold{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}@media (max-width: 600px){body.player-mode{--player-panel-top-px: 170px}.player-card{padding:12px}.player-info-bar.horizontal{font-size:11px;padding:8px 10px;gap:6px}.info-label{font-size:9px}.info-value{font-size:13px}.balance-icon,.balance-amount{font-size:14px}.room-code-small{font-size:9px}.current-prize-display{padding:8px 10px;margin:8px 0;border-radius:10px}.prize-label-playing{font-size:9px;margin-bottom:2px}.current-prize-text{font-size:15px}.current-prize-text.small{font-size:14px}.bingo-ball-display-compact{padding:10px;margin:8px 0 10px;border-radius:10px}.last-number-label{font-size:9px;margin-bottom:6px;letter-spacing:1px}.bingo-ball-mini{width:55px;height:55px;margin:4px auto 8px}.ball-number-mini{font-size:26px}.call-history-row{gap:4px;margin-top:6px}.history-ball{height:25px;min-width:25px;font-size:10px;border-width:1px}.section-title{font-size:14px}.tickets-section{margin:8px 0 0;padding-bottom:20px}.tickets-container{gap:10px;padding:8px}.ticket{padding:8px;border-width:2px;border-radius:8px}.ticket:before{height:26px}.ticket h3{font-size:10px;margin:-8px -8px 6px;padding:6px;letter-spacing:.5px}.cell{font-size:18px;border-width:1px;border-radius:3px}.ticket-grid{gap:1.5px}.btn-bingo.floating-bingo{bottom:10px;min-width:130px;padding:10px 22px;font-size:16px;border-radius:30px}.bingo-btn-text{font-size:16px;gap:4px}.bingo-emoji{font-size:18px}}@media (max-width: 400px){body.player-mode{--player-panel-top-px: 160px}.player-card{padding:6px}.player-info-bar.horizontal{padding:6px 8px;gap:4px}.info-label{font-size:8px}.info-value{font-size:11px}.balance-icon,.balance-amount{font-size:12px}.current-prize-text{font-size:14px}.current-prize-text.small{font-size:12px}.bingo-ball-mini{width:48px;height:48px}.ball-number-mini{font-size:22px}.history-ball{height:21px;min-width:21px;font-size:9px}.cell{font-size:17px}.ticket{padding:6px}.ticket h3{font-size:9px;margin:-6px -6px 5px;padding:5px}.btn-bingo.floating-bingo{bottom:8px;min-width:120px;padding:8px 18px;font-size:14px}.bingo-btn-text{font-size:14px}.bingo-emoji{font-size:16px}}.room-players-section{margin-top:18px;padding:20px 16px 16px;background:linear-gradient(135deg,#fffffff2,#f0f5fff2);border-radius:12px;box-shadow:0 4px 12px #6a1b9a1a,0 2px 6px #0000000d;border:2px solid rgba(106,27,154,.1)}.room-players-section .section-subtitle{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:12px;text-align:center;text-transform:uppercase;letter-spacing:1px}.player-list-view{display:flex;flex-direction:column;gap:10px}.no-players-message{padding:16px;text-align:center;color:#999;font-size:14px;font-style:italic}.player-item-view{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:10px;border:2px solid rgba(106,27,154,.1);box-shadow:0 2px 6px #0000000d;transition:all .2s ease}.player-item-view:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6a1b9a26}.player-item-view.current-player{background:linear-gradient(135deg,#9c27b014,#6a1b9a14);border-color:var(--primary);box-shadow:0 3px 10px #9c27b033,inset 0 1px 3px #ffffff80}.player-item-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#9c27b033,#6a1b9a33);border:2px solid var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 2px 6px #9c27b04d;background-size:cover;background-position:center}.player-item-avatar.photo{background-color:#fff}.player-item-info{flex:1;min-width:0}.player-item-name{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-item-tickets{font-size:12px;color:#666;font-weight:500}.player-item-balance{display:flex;align-items:center;gap:4px;background:linear-gradient(135deg,#4caf5033,#388e3c33);padding:6px 12px;border-radius:20px;flex-shrink:0;border:1.5px solid rgba(76,175,80,.3)}.balance-icon-small{font-size:16px}.balance-text{font-size:14px;font-weight:800;color:#2e7d32}@media (max-width: 600px){.room-players-section{padding:12px;margin-top:12px}.player-item-view{padding:10px;gap:10px}.player-item-avatar{width:36px;height:36px;font-size:20px}.player-item-name{font-size:14px}.player-item-tickets{font-size:11px}.player-item-balance{padding:5px 10px}.balance-text{font-size:13px}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}.modal-overlay.hidden{display:none}.leaderboard-modal-content{background:#fff;border-radius:20px;max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px;border-bottom:2px solid var(--light);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:24px;font-weight:700;color:var(--primary);margin:0}.modal-close-btn{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close-btn:hover{background:var(--light);color:var(--dark)}.leaderboard-body{padding:20px;overflow-y:auto;flex:1}.leaderboard-tabs{display:flex;border-bottom:2px solid var(--light);background:#f8f8f8}.leaderboard-tab{flex:1;padding:12px 20px;background:none;border:none;font-size:15px;font-weight:600;color:#666;cursor:pointer;transition:all .2s ease;border-bottom:3px solid transparent}.leaderboard-tab:hover{color:var(--primary);background:#6a1b9a0d}.leaderboard-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#fff}.leaderboard-view{display:block}.leaderboard-view.hidden{display:none}.my-position-header{background:linear-gradient(135deg,#6a1b9a1a,#9c27b01a);border-radius:12px;padding:16px;margin-bottom:20px;text-align:center}.my-rank-display{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.rank-label{font-size:14px;font-weight:600;color:#666}.rank-number{font-size:28px;font-weight:800;color:var(--primary);text-shadow:0 2px 4px rgba(106,27,154,.2)}.rank-total{font-size:14px;color:#999}.my-position-subtext{margin-top:8px;font-size:13px;color:#666}.my-position-actions{margin-top:12px;display:flex;justify-content:center}.leaderboard-empty{padding:14px;text-align:center;color:#777;background:#6a1b9a0a;border:1px dashed rgba(106,27,154,.22);border-radius:10px}.leaderboard-podium{display:none}.podium-place{display:flex;flex-direction:column;align-items:center;gap:8px;padding:15px;border-radius:12px;background:linear-gradient(135deg,#ffffffe6,#f5f5f5e6);box-shadow:0 4px 12px #0000001a;transition:transform .3s ease;position:relative}.podium-place:hover{transform:translateY(-5px)}.podium-1{order:2;min-width:110px;padding-top:20px}.podium-2{order:1;min-width:100px}.podium-3{order:3;min-width:100px}.podium-medal{width:48px;height:48px;margin-bottom:4px}.medal-icon{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.medal-gold{animation:goldShimmer 2s ease-in-out infinite}.medal-silver{animation:silverSheen 2s ease-in-out infinite}.medal-bronze{animation:bronzeGlow 2s ease-in-out infinite}@keyframes goldShimmer{0%,to{filter:drop-shadow(0 2px 4px rgba(255,215,0,.4)) brightness(1)}50%{filter:drop-shadow(0 2px 8px rgba(255,215,0,.6)) brightness(1.1)}}@keyframes silverSheen{0%,to{filter:drop-shadow(0 2px 4px rgba(192,192,192,.4)) brightness(1)}50%{filter:drop-shadow(0 2px 8px rgba(192,192,192,.6)) brightness(1.15)}}@keyframes bronzeGlow{0%,to{filter:drop-shadow(0 2px 4px rgba(205,127,50,.4)) brightness(1)}50%{filter:drop-shadow(0 2px 8px rgba(205,127,50,.6)) brightness(1.1)}}.podium-avatar{font-size:36px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#6a1b9a26,#9c27b026);border:2px solid var(--primary-light)}.podium-name{font-size:14px;font-weight:700;color:var(--dark);text-align:center;max-width:90px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.podium-balance{font-size:16px;font-weight:800;color:var(--success);text-align:center}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.leaderboard-row{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:10px;border:2px solid rgba(106,27,154,.1);transition:all .2s ease}.leaderboard-row:hover{transform:translate(4px);box-shadow:0 4px 12px #6a1b9a26}.leaderboard-row.current-user{background:linear-gradient(135deg,#9c27b014,#6a1b9a14);border-color:var(--primary);box-shadow:0 3px 10px #9c27b033}.leaderboard-rank{font-size:18px;font-weight:700;color:var(--primary);min-width:42px;text-align:center;display:flex;align-items:center;justify-content:center;flex-shrink:0}.medal-icon-inline{width:28px;height:28px;flex-shrink:0}.medal-icon-inline.gold{filter:drop-shadow(0 2px 4px rgba(255,215,0,.5))}.medal-icon-inline.silver{filter:drop-shadow(0 2px 4px rgba(192,192,192,.5))}.medal-icon-inline.bronze{filter:drop-shadow(0 2px 4px rgba(205,127,50,.5))}.leaderboard-avatar{font-size:28px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#9c27b033,#6a1b9a33);border:2px solid var(--primary-light);flex-shrink:0}.leaderboard-name{flex:1;font-size:15px;font-weight:700;color:var(--dark);display:flex;align-items:center;gap:8px}.you-pill{background:var(--primary);color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:12px;text-transform:uppercase}.leaderboard-balance{font-size:16px;font-weight:800;color:var(--success)}.ad-consent-banner{position:fixed;bottom:0;left:0;width:100%;background:linear-gradient(135deg,#212121fa,#424242fa);color:#fff;padding:20px;box-shadow:0 -4px 12px #0000004d;z-index:9999;animation:slideUpBanner .3s ease}.ad-consent-banner.hidden{display:none}@keyframes slideUpBanner{0%{transform:translateY(100%)}to{transform:translateY(0)}}.consent-content{max-width:800px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.consent-message{flex:1;min-width:200px;font-size:14px;line-height:1.5}.consent-buttons{display:flex;gap:10px}.number-cue{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;user-select:none;padding:14px 20px;min-width:120px;text-align:center;border-radius:var(--border-radius);background:#fffffff2;box-shadow:var(--shadow-lg);color:var(--dark);font-weight:800;font-size:56px;line-height:1}.number-cue.emphasis{outline:3px solid rgba(233,30,99,.35)}.number-cue.hidden{display:none}@media (max-width: 600px){.number-cue{display:none!important}}.enable-spoken-btn{position:fixed;left:50%;bottom:14px;transform:translate(-50%);z-index:9998;border:none;border-radius:999px;padding:12px 18px;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:var(--shadow-lg)}.enable-spoken-btn.hidden{display:none}@keyframes bounceIn{0%{opacity:0;transform:scale(.3) translateY(20px)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1) translateY(0)}}.lobby-ad-container{margin:20px 0;padding:20px;background:#ffffff1a;border-radius:12px;text-align:center}.lobby-ad-container.hidden{display:none}.ad-slot{min-height:90px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:2px dashed rgba(255,255,255,.2);border-radius:8px;color:#ffffff80;font-size:12px}@media (max-width: 600px){.leaderboard-modal-content{max-height:90vh}.leaderboard-podium{padding:10px 5px;gap:5px}.podium-1{min-width:90px}.podium-2,.podium-3{min-width:80px}.podium-medal{width:40px;height:40px}.podium-avatar{font-size:30px;width:50px;height:50px}.podium-name{font-size:12px;max-width:70px}.podium-balance{font-size:14px}.consent-content{flex-direction:column;align-items:stretch}.consent-buttons{width:100%;justify-content:center}}.profile-info{text-align:center;margin:30px 0;padding:20px;background:linear-gradient(135deg,#6a1b9a0d,#9c27b00d);border-radius:12px}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#6a1b9a33,#9c27b033);display:flex;align-items:center;justify-content:center;font-size:48px;margin:0 auto 15px;border:3px solid var(--primary-light);box-shadow:0 4px 12px #6a1b9a4d}.profile-username{font-size:24px;font-weight:800;color:var(--primary);margin-bottom:8px}.profile-balance{font-size:32px;font-weight:900;color:var(--success);text-shadow:0 2px 4px rgba(0,0,0,.1)}.header.header-hero{padding:18px 12px 22px;position:relative;overflow:hidden;border-bottom:2px solid rgba(255,215,0,.3);background:radial-gradient(ellipse 120% 80% at 50% 120%,rgba(255,0,128,.4),transparent 50%),radial-gradient(circle at 20% 20%,rgba(0,212,255,.35),transparent 40%),radial-gradient(circle at 80% 30%,rgba(255,215,0,.3),transparent 35%),radial-gradient(circle at 60% 80%,rgba(138,43,226,.35),transparent 45%),linear-gradient(135deg,#1a0a2e,#16213e,#0f3460 60%,#1a0a2e);box-shadow:0 8px 32px #0006,inset 0 -2px 30px #ff008026,inset 0 2px 30px #00d4ff1a}.header.header-hero:before{content:"";position:absolute;inset:-50%;background:conic-gradient(from 0deg at 50% 50%,#ff008033,#00d4ff26,#ffd70033,#8a2be226,#00ff8826,#ff008033);filter:blur(40px);animation:heroGlowSpin 20s linear infinite;pointer-events:none;z-index:0}.header.header-hero:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 10% 20%,#fff 0px,transparent 1px),radial-gradient(circle at 30% 65%,#fff 0px,transparent 1px),radial-gradient(circle at 50% 10%,#fff 0px,transparent 1px),radial-gradient(circle at 70% 80%,#fff 0px,transparent 1px),radial-gradient(circle at 85% 25%,#fff 0px,transparent 1px),radial-gradient(circle at 95% 60%,#fff 0px,transparent 1px),radial-gradient(circle at 5% 85%,#fff 0px,transparent 1px),radial-gradient(circle at 25% 40%,#fff 0px,transparent 1px),radial-gradient(circle at 60% 50%,#fff 0px,transparent 1px),radial-gradient(circle at 40% 90%,#fff 0px,transparent 1px);background-size:100% 100%;animation:heroTwinkle 3s ease-in-out infinite;pointer-events:none;z-index:0;opacity:.6}@keyframes heroGlowSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes heroTwinkle{0%,to{opacity:.4}50%{opacity:.8}}.header-hero-wrap{position:relative;z-index:1;width:100%;display:flex;align-items:center;justify-content:center;padding:10px;min-height:90px}.header-hero-wrap:before,.header-hero-wrap:after{content:"";position:absolute;border-radius:50%;z-index:0;pointer-events:none;border:3px solid rgba(255,255,255,.5);box-shadow:0 10px 30px #0006,inset 0 -8px 20px #0000004d,inset 0 8px 20px #ffffff4d}.header-hero-wrap:before{width:70px;height:70px;left:5%;top:50%;transform:translateY(-50%);background:radial-gradient(circle at 30% 30%,#ffffffe6,#fff9 20%,#ff0080e6 25%,#db2777 60%,#9d174d);animation:floatBallLeft 4s ease-in-out infinite}.header-hero-wrap:after{width:55px;height:55px;right:8%;top:20%;background:radial-gradient(circle at 30% 30%,#ffffffe6,#fff9 20%,#00d4ffe6 25%,#06b6d4 60%,#0891b2);animation:floatBallRight 5s ease-in-out infinite}@keyframes floatBallLeft{0%,to{transform:translateY(-50%) translate(0) rotate(0)}25%{transform:translateY(-60%) translate(5px) rotate(10deg)}50%{transform:translateY(-50%) translate(10px) rotate(0)}75%{transform:translateY(-40%) translate(5px) rotate(-10deg)}}@keyframes floatBallRight{0%,to{transform:translate(0) translateY(0) rotate(0)}33%{transform:translate(-8px) translateY(-10px) rotate(-15deg)}66%{transform:translate(5px) translateY(5px) rotate(10deg)}}.bingo-hero-logo{position:relative;z-index:2;display:inline-flex;align-items:center;gap:16px;padding:14px 22px;border-radius:24px;background:linear-gradient(135deg,#ffffff26,#ffffff0d);border:2px solid rgba(255,255,255,.25);box-shadow:0 20px 50px #0006,0 0 40px #ff008026,0 0 60px #00d4ff1a,inset 0 1px #fff3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.bingo-ball-hero{width:68px;height:68px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;border:4px solid rgba(255,255,255,.8);background:radial-gradient(circle at 25% 25%,#fff,#fffc 15%,gold 20%,orange,#ff5722 80%,#e64a19);box-shadow:0 0 30px #ffa50099,0 0 60px #ff57224d,0 20px 40px #0006,inset 0 8px 20px #fff6,inset 0 -8px 20px #0000004d;animation:heroBallPulse 2s ease-in-out infinite,heroBallFloat 4s ease-in-out infinite;position:relative;overflow:hidden}.bingo-ball-hero:after{content:"";position:absolute;top:-50%;left:-50%;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.8) 50%,transparent 70%);animation:heroBallShine 3s ease-in-out infinite}@keyframes heroBallPulse{0%,to{box-shadow:0 0 30px #ffa50099,0 0 60px #ff57224d,0 20px 40px #0006,inset 0 8px 20px #fff6,inset 0 -8px 20px #0000004d}50%{box-shadow:0 0 40px #ffa500cc,0 0 80px #ff572280,0 20px 40px #0006,inset 0 8px 20px #fff6,inset 0 -8px 20px #0000004d}}@keyframes heroBallFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.02)}}@keyframes heroBallShine{0%{transform:translate(-100%) translateY(-100%) rotate(45deg);opacity:0}15%{opacity:1}50%{transform:translate(100%) translateY(100%) rotate(45deg);opacity:0}to{transform:translate(100%) translateY(100%) rotate(45deg);opacity:0}}.ball-number-hero{font-weight:900;font-size:26px;color:#1e1e1ef2;text-shadow:0 2px 0 rgba(255,255,255,.8),0 -1px 0 rgba(0,0,0,.2);letter-spacing:1px;position:relative;z-index:1}.brand-stack{display:flex;flex-direction:column;gap:8px;min-width:0}.brand-title{display:flex;align-items:baseline;gap:4px;line-height:1;white-space:nowrap}.brand-word{font-weight:900;font-size:42px;letter-spacing:1px}.brand-bingo{background:linear-gradient(180deg,#ff6ec7,#ff0080 40%,#c06);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 8px rgba(255,0,128,.5));animation:neonPulse 2s ease-in-out infinite}.brand-blast{background:linear-gradient(180deg,gold,#ff8c00 40%,#ff5722);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 8px rgba(255,165,0,.5));animation:neonPulse 2s ease-in-out infinite .3s}@keyframes neonPulse{0%,to{filter:drop-shadow(0 0 8px rgba(255,100,150,.5))}50%{filter:drop-shadow(0 0 15px rgba(255,100,150,.8))}}.brand-suffix{font-weight:900;font-size:18px;letter-spacing:2px;color:#00d4ff;text-shadow:0 0 10px rgba(0,212,255,.8),0 0 20px rgba(0,212,255,.4);padding-left:4px}.brand-tagline{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(90deg,#00d4ff,#ff6ec7,gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:taglineShift 4s ease-in-out infinite}@keyframes taglineShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@media (max-width: 600px){.header.header-hero{padding:14px 10px 18px}.header-hero-wrap{min-height:80px;padding:8px}.header-hero-wrap:before{width:50px;height:50px;left:2%}.header-hero-wrap:after{width:40px;height:40px;right:3%;top:15%}.bingo-hero-logo{padding:12px 16px;border-radius:20px;gap:12px}.bingo-ball-hero{width:54px;height:54px;border-width:3px}.ball-number-hero{font-size:22px}.brand-word{font-size:32px}.brand-suffix{font-size:14px}.brand-tagline{font-size:10px;letter-spacing:1.5px}}@media (max-width: 400px){.header-hero-wrap:before,.header-hero-wrap:after{display:none}.brand-word{font-size:28px}.bingo-ball-hero{width:48px;height:48px}.ball-number-hero{font-size:18px}}@media (max-width: 400px){.bingo-ball-hero{width:46px;height:46px}.brand-word{font-size:26px}.brand-suffix{font-size:14px}.brand-tagline{display:none}}
