:root{color:#e8e8e8;background-color:#12181b;font-family:Segoe UI,system-ui,sans-serif;line-height:1.5}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{min-height:100dvh;margin:0;overflow-x:hidden}#root{background-color:#0a1014;min-height:100dvh}input,button{font:inherit}input{color:#fff;background:#1a2428;border:1px solid #ffffff26;border-radius:6px;width:100%;margin-bottom:.75rem;padding:.65rem .85rem}@media (width<=768px){input,select,textarea{font-size:16px}button{touch-action:manipulation}}input:focus{outline:2px solid #02718d}a{color:#1af4fc}.bingo-board-wrap{justify-content:center;align-items:center;width:100%;padding:1rem;display:flex}.bingo-container{aspect-ratio:1;background-color:#161616;border-radius:10px;grid-template-rows:auto repeat(5,1fr);grid-template-columns:repeat(5,1fr);gap:.35rem;width:min(100%,500px);padding:clamp(12px,3vw,30px);display:grid;box-shadow:0 0 80px #0c2d6b,0 0 120px #0c2d6b59}.bingo_title{aspect-ratio:1;color:#fff;-webkit-user-select:none;user-select:none;background-color:#02718d;border:1px solid #02718d;border-radius:5px;justify-content:center;align-items:center;margin:0;font-size:clamp(1.25rem,5vw,2.5rem);font-weight:700;transition:background-color .2s,color .2s;display:flex}.bingo_title.bingo-lit{color:#000;background-color:#00fd00;border-color:#00fd00}.bingo-cell{aspect-ratio:1;color:#000;cursor:default;-webkit-tap-highlight-color:transparent;background-color:#fff;border:none;border-radius:5px;justify-content:center;place-self:center;align-items:center;width:100%;max-width:100%;max-height:100%;margin:0;padding:0;font-size:clamp(1rem,4.5vw,2.5rem);font-weight:700;display:flex;position:relative}.bingo-cell.callable{cursor:pointer}.bingo-cell.empty{background-color:#fff}.bingo-cell.setup-fillable{cursor:pointer}.bingo-cell.setup-fillable:hover,.bingo-cell.callable:hover{background:linear-gradient(90deg,#1af4fc94,#33f7ed)}.bingo-cell.marked{cursor:default;background-color:#ff0}.bingo-cell.line-win{color:#fff;background-color:red}.bingo-num{z-index:1;line-height:1;position:relative}.bingo-cell.marked .bingo-num{color:#000}.bingo-cell.line-win .bingo-num{color:#fff}.bingo-strike{z-index:2;pointer-events:none;border-radius:5px;position:absolute;inset:0}.bingo-strike:before{content:"";background:#000;height:clamp(2px,.4vw,5px);position:absolute;top:50%;left:-15%;right:-15%;transform:translateY(-50%)rotate(-45deg)}.bingo-cell.line-win .bingo-strike:before{background:#fff}@media (width<=768px){.bingo-board-wrap{box-sizing:border-box;isolation:isolate;flex-shrink:0;width:100%;max-width:100%;padding:.25rem 0}.bingo-container{aspect-ratio:1;box-sizing:border-box;grid-template-rows:auto repeat(5,minmax(0,1fr));grid-template-columns:repeat(5,minmax(0,1fr));gap:clamp(2px,.8vw,6px);width:100%;max-width:100%;min-height:0;margin:0 auto;padding:clamp(6px,2vw,12px);overflow:hidden;box-shadow:0 0 40px #0c2d6b,0 0 60px #0c2d6b40}.bingo_title{border-radius:4px;place-self:center;width:100%;max-width:100%;height:auto;min-height:0;max-height:100%;font-size:clamp(.75rem,4.2vw,1.35rem)}.bingo-cell{touch-action:manipulation;aspect-ratio:unset;border-radius:4px;place-self:stretch stretch;width:100%;min-width:0;height:100%;min-height:0;font-size:clamp(.65rem,3.6vw,1.15rem)}.bingo-strike:before{left:-10%;right:-10%}}@media (width<=380px){.bingo-container{gap:2px;padding:5px}.bingo-cell{font-size:clamp(.6rem,3.2vw,.95rem)}.bingo_title{font-size:clamp(.65rem,3.8vw,1rem)}}.app-shell{min-height:100vh;position:relative}.app-content{z-index:1;position:relative}.stars-background{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.stars-background-canvas{position:absolute;inset:0}.stars-background-canvas canvas{display:block;width:100%!important;height:100%!important}.stars-background-vignette{pointer-events:none;background:radial-gradient(at 50% 40%,#0000 0%,#0a101459 55%,#0a1014d9 100%);position:absolute;inset:0}.slick-scroll{scrollbar-width:thin;scrollbar-color:#1af4fc #00000059}.slick-scroll::-webkit-scrollbar{width:6px;height:6px}.slick-scroll::-webkit-scrollbar-track{background:#00000059;border-radius:999px;margin:4px}.slick-scroll::-webkit-scrollbar-thumb{background:linear-gradient(#1af4fc 0%,#02718d 100%);border:1px solid #ffffff1f;border-radius:999px;box-shadow:0 0 8px #1af4fc73}.slick-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(#00fd00 0%,#1af4fc 100%);box-shadow:0 0 12px #00fd0066}.slick-scroll::-webkit-scrollbar-corner{background:0 0}@keyframes page-enter{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.page-transition{will-change:opacity, transform;min-height:100vh;animation:.35s cubic-bezier(.22,1,.36,1) both page-enter}@media (prefers-reduced-motion:reduce){.page-transition{will-change:auto;animation:none}}.page{min-height:100vh;padding:1.5rem}.page.center{justify-content:center;align-items:center;display:flex}.card{-webkit-backdrop-filter:blur(8px);background:#161616e0;border:1px solid #ffffff0f;border-radius:12px;padding:2rem;box-shadow:0 0 80px #0c2d6b66}.hero-card{text-align:center;width:100%;max-width:420px}.hero-card.game-panel,.auth-card.game-panel{border-color:#1af4fc47}.auth-hero-actions{flex-direction:column;gap:.5rem;width:100%;margin-top:.25rem;display:flex}.auth-hero-actions .btn{text-align:center;justify-content:center;align-items:center;width:100%;min-height:48px;text-decoration:none;display:inline-flex}.form-card{width:100%;max-width:380px}.page.auth-page{padding:max(1rem, env(safe-area-inset-top)) 1.25rem max(1.5rem, env(safe-area-inset-bottom));flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;min-height:100dvh;display:flex}.auth-card{flex-shrink:0;width:100%;max-width:400px;margin:0;padding:1.2rem 1.35rem 1.5rem}.auth-card .game-panel-header{margin-bottom:.65rem;padding-bottom:.6rem}.auth-card .game-panel-header .game-panel-title-wrap h2{font-size:1.2rem}.auth-invite-banner{color:#ffffffbf;text-align:center;background:#1af4fc1a;border:1px solid #1af4fc47;border-radius:8px;margin:0 0 .75rem;padding:.55rem .75rem;font-size:.85rem;line-height:1.4}.auth-invite-banner strong{color:#1af4fc;letter-spacing:.1em;font-weight:700}.auth-error{text-align:center;background:#ff50501a;border:1px solid #ff505059;border-radius:6px;padding:.45rem .65rem;margin:0 0 .75rem!important}.auth-form-section{margin-bottom:.85rem!important;padding:.85rem!important}.auth-field{margin:0 0 .75rem;display:block}.auth-field:last-child{margin-bottom:0}.auth-field-label{letter-spacing:.1em;text-transform:uppercase;color:#1af4fce6;margin-bottom:.35rem;font-size:.7rem;font-weight:700;display:block}.auth-input{color:#fff;background:#00000059;border:1px solid #1af4fc38;border-radius:8px;width:100%;padding:.7rem .85rem;transition:border-color .15s,box-shadow .15s;margin-bottom:0!important}.auth-input::placeholder{color:#ffffff47}.auth-input:focus{border-color:#1af4fc;outline:none;box-shadow:0 0 18px #1af4fc38}.auth-submit{width:100%;min-height:48px;margin-top:.15rem}.auth-footer{text-align:center;border-top:1px solid #ffffff14;margin-top:1.15rem;padding-top:1rem}.auth-footer-text{color:#ffffff73;margin:0 0 .65rem;font-size:.85rem}.auth-footer-links{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.auth-footer-btn{text-align:center;flex:1;justify-content:center;align-items:center;min-width:7.5rem;min-height:42px;text-decoration:none;display:inline-flex}.auth-footer-btn--ghost{color:#ffffffb3;border:1px solid #ffffff26}.auth-footer-btn--ghost:hover{color:#1af4fc;background:#1af4fc14;border-color:#1af4fc66}.form-card.game-panel .btn.primary,.hero-card.game-panel .btn-game-action{letter-spacing:.05em;text-transform:uppercase;font-weight:700;box-shadow:0 0 24px #02718d99,0 4px #015566}.hero-card.game-panel .btn-group{flex-direction:column;gap:.5rem;width:100%;display:flex}.hero-card.game-panel .btn-group .btn{text-align:center;width:100%;text-decoration:none}.lobby-card{width:100%;max-width:440px}.page.lobby-page{flex-direction:column;align-items:center;gap:1.25rem;min-height:100dvh;padding:1.5rem 1.25rem 2rem;display:flex}.lobby-page-brand{text-align:center;flex-shrink:0;width:100%;max-width:1100px}.lobby-page-brand .logo{letter-spacing:.12em;background:linear-gradient(135deg,#1af4fc 0%,#02718d 45%,#00fd00 100%);color:#0000;filter:drop-shadow(0 0 24px #1af4fc59);-webkit-background-clip:text;background-clip:text;margin:0 0 .35rem;font-size:clamp(2.25rem,6vw,3.25rem)}.lobby-page-brand .app-brand-link{text-decoration:none;display:inline-block}.lobby-page-brand .app-brand-link:hover .logo{filter:drop-shadow(0 0 32px #1af4fc8c)}.lobby-page-tagline{letter-spacing:.14em;text-transform:uppercase;color:#1af4fcbf;margin:0;font-size:.9rem}.lobby-layout{grid-template-columns:minmax(320px,1.2fr) minmax(300px,400px);align-items:stretch;gap:1.25rem;width:100%;max-width:1100px;display:grid}.lobby-layout .lobby-card,.lobby-layout .lobby-leaderboard-card{max-width:none}.game-panel{border:1px solid #1af4fc38;position:relative;overflow:hidden;box-shadow:0 0 40px #0c2d6b73,inset 0 1px #ffffff0f}.game-panel:before{content:"";opacity:.9;background:linear-gradient(90deg,#02718d,#1af4fc,#02718d);height:3px;position:absolute;top:0;left:0;right:0}.lobby-leaderboard-card.game-panel{border-color:#ffcc0047;flex-direction:column;min-height:0;max-height:calc(100dvh - 3rem);padding:1.1rem 1rem 1rem;display:flex;box-shadow:0 0 50px #ffcc0014,0 0 40px #0c2d6b80,inset 0 1px #ffffff14}.lobby-leaderboard-card.game-panel:before{background:linear-gradient(90deg,#f90,#fc0,#1af4fc,#fc0)}.game-panel--play{border-color:#00fd0033;box-shadow:0 0 45px #00fd000f,0 0 40px #0c2d6b73,inset 0 1px #ffffff0f}.game-panel--play:before{background:linear-gradient(90deg,#02718d,#00fd00,#1af4fc)}.game-panel-header{border-bottom:1px solid #ffffff14;align-items:center;gap:.65rem;margin-bottom:.75rem;padding-bottom:.65rem;display:flex}.game-panel-header--play{flex-wrap:wrap}.game-panel-header--play .lobby-player-stats{margin-left:auto}.game-panel-icon{filter:drop-shadow(0 0 8px #1af4fc80);font-size:1.75rem;line-height:1}.game-panel-title-wrap h2{letter-spacing:.06em;text-transform:uppercase;color:#fff;margin:0;font-size:1.3rem}.game-panel-header--arena .game-panel-title-wrap h2{color:#fc0;text-shadow:0 0 20px #ffcc0059}.game-panel-header--play .game-panel-title-wrap h2{color:#1af4fc;text-shadow:0 0 16px #1af4fc59}.game-panel-sub{color:#888;letter-spacing:.12em;text-transform:uppercase;margin-top:.15rem;font-size:.7rem;display:block}.game-panel-meta{color:#888;margin:0 0 .65rem;font-size:.8rem;line-height:1.4}.badge-player{color:#00fd00;background:#00fd001f;border:1px solid #00fd0059}.game-panel-section{background:#0003;border:1px solid #ffffff0f;border-radius:8px;margin-bottom:.85rem;padding:.85rem}.game-section-label{color:#1af4fc;letter-spacing:.04em;align-items:center;gap:.4rem;margin:0 0 .75rem;font-size:.95rem;display:flex}.game-section-icon{opacity:.9;font-size:1rem}.btn-game-action{letter-spacing:.05em;text-transform:uppercase;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 0 24px #02718d99,0 4px #015566}.btn-game-action:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 28px #1af4fc73,0 4px #015566}.btn-game-action:active:not(:disabled){transform:translateY(2px);box-shadow:0 0 16px #02718d80}.btn-game-secondary{color:#1af4fc;border-color:#1af4fc66}.btn-game-secondary:hover{background:#1af4fc1f;border-color:#1af4fc}.lobby-card .lobby-header-user{margin-bottom:.75rem}.lobby-leaderboard-card-body{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#fc0 #00000059;flex:1;min-height:0;overflow-y:auto}.lobby-leaderboard-card-body::-webkit-scrollbar{width:6px}.lobby-leaderboard-card-body::-webkit-scrollbar-track{background:#00000059;border-radius:999px}.lobby-leaderboard-card-body::-webkit-scrollbar-thumb{background:linear-gradient(#fc0 0%,#f90 100%);border:1px solid #ffffff1a;border-radius:999px;box-shadow:0 0 8px #ffcc0059}.lobby-leaderboard-card-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(#ffe566 0%,#fc0 100%)}.lobby-leaderboard-card .game-table-wrap{border-color:#ffcc0040;margin-top:0;box-shadow:0 0 20px #ffcc0014}.logo{letter-spacing:.08em;color:#02718d;margin:0 0 .5rem;font-size:3rem}.logo.logo-small{letter-spacing:.06em;text-align:center;margin:0 0 1rem;font-size:1.35rem;display:block}.app-brand-link{text-decoration:none}.subtitle{color:#888;margin-bottom:2rem}.btn{color:#fff;cursor:pointer;text-align:center;background:0 0;border:1px solid #ffffff26;border-radius:6px;padding:.6rem 1.4rem;text-decoration:none;transition:background .15s;display:inline-block}.btn:hover{background:#ffffff14}.btn.primary{background:#02718d;border-color:#02718d;width:100%}.btn.primary:hover{background:#038ca8}.btn.ghost{color:#1af4fc;border-color:#0000}.btn.small{padding:.35rem .75rem;font-size:.85rem}.btn-group{flex-direction:column;gap:.75rem;display:flex}.btn-group .btn{width:100%}.error{color:#ff6b6b;font-size:.9rem}.game-toast{color:#e8e8e8;text-align:center;background:#02718d59;border-bottom:1px solid #1af4fc59;margin:0;padding:.65rem 1rem;font-size:.9rem}.error.banner{text-align:center;background:#ff00001a;margin:0;padding:.5rem}.muted{color:#888;text-align:center;margin-top:1rem;font-size:.9rem}.link-back{text-align:center;margin-top:1.5rem;display:block}.lobby-header{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.lobby-header-top{justify-content:space-between;align-items:center;gap:.75rem;width:100%;display:flex}.lobby-header h2{flex:1;margin:0}.lobby-header-top h2{flex:0 auto}.lobby-player-stats{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.lobby-stat-chip{white-space:nowrap;background:#1a2428;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:.2rem;padding:.35rem .55rem;font-size:.85rem;font-weight:700;display:inline-flex;box-shadow:0 0 12px #0c2d6b59}.lobby-stat-played{color:#1af4fc;border-color:#1af4fc59}.lobby-stat-wins{color:#fc0;border-color:#ffcc0059}.lobby-header-user{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.badge{color:#1af4fc;background:#02718d33;border-radius:4px;padding:.25rem .6rem;font-size:.85rem}.lobby-section{margin-bottom:1.5rem}.lobby-section h3{color:#aaa;margin:0 0 .75rem;font-size:1rem}.lobby-section input[type=range]{width:100%;margin:.5rem 0 1rem}.game-page{background:0 0;flex-direction:column;min-height:100dvh;display:flex}.game-header-panel{border-radius:0;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.65rem;margin:0;padding:.65rem 1rem;display:flex}.game-header-panel:before{background:linear-gradient(90deg,#02718d,#1af4fc,#00fd00)}.game-header-room{flex-direction:column;gap:.1rem;min-width:0;display:flex}.game-header-room .game-panel-sub{font-size:.65rem}.room-code-badge{letter-spacing:.12em;color:#1af4fc;font-size:.95rem;font-weight:700}.game-panel--arena{border-color:#ffcc0038;box-shadow:0 0 50px #ffcc000f,0 0 40px #0c2d6b80,inset 0 1px #ffffff14}.game-panel--arena:before{background:linear-gradient(90deg,#f90,#fc0,#1af4fc)}.game-arena{background:0 0;flex-direction:row;flex:1;gap:.75rem;min-height:0;padding:.75rem;display:flex}.game-sidebar-panel{flex-direction:column;flex-shrink:0;gap:.5rem;width:340px;max-height:calc(100dvh - 4.5rem);padding:.85rem;display:flex;overflow:hidden}.game-panel-section--players{flex:1;min-height:0;margin-bottom:0;padding:.5rem;overflow:hidden auto}.game-main-wrap{flex-direction:column;flex:1;min-width:0;display:flex}.game-board-panel{flex-direction:column;flex:1;min-height:0;padding:.85rem;display:flex;overflow-y:auto}.game-board-section{background:#00000040;margin-bottom:0;padding:.5rem}.game-board-panel .turn-bar{background:#00000059;border:1px solid #ffffff14;width:100%;max-width:none;margin:0 0 .5rem}.game-board-panel .setup-bar{width:100%;max-width:none;margin:0 0 .5rem}.game-board-panel .game-footer{text-align:center;width:100%;max-width:none;margin:.5rem 0 0}.game-sidebar-panel .btn-game-action{width:100%;margin-top:.35rem}.game-sidebar-panel .turn-timer-display{width:100%}.room-code{letter-spacing:.1em;font-weight:700}.share-room-wrap{align-items:center;gap:.35rem;display:flex}.share-room-btn{margin:0}.share-room-feedback{color:#1af4fc;white-space:nowrap;font-size:.75rem}.game-header-status{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;margin-left:auto;display:flex}.server-status{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.server-status-item{color:#888;white-space:nowrap;background:#ffffff0a;border-radius:4px;align-items:center;gap:.35rem;padding:.2rem .45rem;font-size:.7rem;display:inline-flex}.server-status-dot{background:#666;border-radius:50%;flex-shrink:0;width:7px;height:7px}.server-status-online .server-status-dot{background:#00fd00;box-shadow:0 0 6px #00fd0099}.server-status-connecting .server-status-dot,.server-status-reconnecting .server-status-dot,.server-status-checking .server-status-dot{background:#fa0;animation:1s ease-in-out infinite server-status-pulse}.server-status-offline .server-status-dot{background:#f44}.server-status-online.server-status-item{color:#b8ffb8}.server-status-offline.server-status-item{color:#faa}@keyframes server-status-pulse{50%{opacity:.4}}.status-badge{text-transform:uppercase;background:#333;border-radius:4px;padding:.25rem .6rem;font-size:.8rem}.status-badge.playing{background:#02718d}.status-badge.finished{color:#00fd00;background:#00fd0033}.status-badge.card-status.not-ready{color:#ff6b6b;background:#ff000026;border:1px solid #ff6b6b}.status-badge.card-status.ready{color:#00fd00;background:#00fd0026;border:1px solid #00fd00}.setup-bar{box-sizing:border-box;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;width:min(100%,500px);min-height:4.25rem;margin-bottom:1rem;transition:border-color .2s,box-shadow .2s;display:flex;box-shadow:0 0 20px #1af4fc14,inset 0 1px #ffffff0f;background:linear-gradient(135deg,#161616f2,#1a2428e6)!important;border:1px solid #1af4fc47!important;border-radius:10px!important;padding:.7rem 1rem!important}.setup-bar--ready{box-shadow:0 0 24px #00fd001a,inset 0 1px #00fd0014;background:linear-gradient(135deg,#00281473,#161616f2)!important;border-color:#00fd0066!important}.setup-bar--loading{box-shadow:inset 0 1px #ffffff0a;border-color:#ffffff1f!important}.setup-bar-main{flex:1;align-items:flex-start;gap:.65rem;min-width:min(100%,12rem);display:flex}.setup-bar-icon{filter:drop-shadow(0 0 6px #1af4fc59);background:#1af4fc1f;border:1px solid #1af4fc40;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.25rem;line-height:1;display:flex}.setup-bar--ready .setup-bar-icon{color:#00fd00;filter:none;background:#00fd001f;border-color:#00fd0059;font-size:1rem;font-weight:800}.setup-bar-text{text-align:left;flex:1;min-width:0}.setup-bar-label{color:#1af4fc;letter-spacing:.02em;margin:0 0 .15rem;font-size:1rem;font-weight:700;line-height:1.25}.setup-bar--ready .setup-bar-label{color:#00fd00;text-shadow:0 0 12px #00fd004d}.setup-bar-hint{color:#ffffff73;margin:0;font-size:.8rem;line-height:1.35}.setup-bar--ready .setup-bar-hint{color:#ffffff61;font-style:italic}.setup-bar-action{white-space:nowrap;flex-shrink:0;border-radius:8px!important;margin:0!important;padding:.55rem 1rem!important;font-size:.85rem!important;box-shadow:0 0 20px #02718d80,0 3px #015566!important}.setup-bar-action:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 28px #1af4fc73,0 3px #015566!important}.sidebar-hint{color:#888;margin:0;padding-top:10px;font-size:.8rem}.lobby-hint{color:#888;margin:-.5rem 0 .75rem;font-size:.8rem}.room-settings{background:#1a2428;border-radius:8px;margin-bottom:.5rem;padding:.75rem}.room-settings label{color:#aaa;margin-bottom:.35rem;font-size:.85rem;display:block}.room-settings input[type=number]{width:100%;margin-bottom:0}.turn-timer-display{color:#1af4fc;text-align:center;cursor:pointer;background:#1a2428;border:1px dashed #1af4fc59;border-radius:8px;width:100%;margin:0;padding:.5rem .65rem;font-size:.9rem;transition:background .15s,border-color .15s;display:block}.turn-timer-display:hover{background:#02718d40;border-color:#1af4fc}.game-panel-section .turn-timer-display{width:100%;margin-bottom:.5rem}.join-room-group{background:#1a2428;border:1px solid #1af4fc59;border-radius:8px;align-items:stretch;width:100%;display:flex;overflow:hidden;box-shadow:0 0 16px #0c2d6b59}.join-room-group:focus-within{border-color:#1af4fc;box-shadow:0 0 20px #1af4fc33}.join-room-input{letter-spacing:.12em;text-transform:uppercase;background:0 0;border:none;border-radius:0;flex:1;min-width:0;font-weight:600;margin:0!important}.join-room-input:focus{box-shadow:none;outline:none}.join-room-btn{letter-spacing:.05em;text-transform:uppercase;border:none;border-left:1px solid #1af4fc59;border-radius:0;flex-shrink:0;min-height:44px;margin:0;padding:.65rem 1.1rem;font-weight:700}.turn-timer-display-static{text-align:center;margin:0}.turn-timer-modal{text-align:center;width:min(92vw,360px);padding:1.5rem 1.25rem 1.25rem}.turn-timer-modal h2{margin:0 0 .5rem;font-size:1.35rem}.turn-timer-modal-hint{color:#888;margin:0 0 1rem;font-size:.9rem;line-height:1.45}.turn-timer-modal-label{text-align:left;color:#aaa;margin-bottom:.35rem;font-size:.85rem;display:block}.turn-timer-modal input{margin-bottom:1.25rem}.turn-timer-modal-actions{flex-direction:column-reverse;gap:.65rem;display:flex}.turn-timer-modal-actions .btn{width:100%;min-height:44px;margin:0}@media (width>=480px){.turn-timer-modal-actions{flex-direction:row}.turn-timer-modal-actions .btn{flex:1}}.ready-tag{border-radius:3px;margin-left:auto;padding:.1rem .4rem;font-size:.7rem}.ready-tag.ready{color:#00fd00;background:#00fd0033}.ready-tag.not-ready{color:#ff6b6b;background:#ff000026}.game-sidebar{flex-direction:column;flex-shrink:0;gap:1rem;width:250px;padding:1rem;display:flex}.game-main{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:0;padding:.5rem;display:flex;overflow-y:auto}.turn-bar{box-sizing:border-box;background:linear-gradient(135deg,#161616f2,#1a2428e6);border:1px solid #ffffff1a;border-radius:10px;grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:center;gap:.2rem 1rem;width:min(100%,500px);min-height:4.25rem;margin-bottom:1rem;padding:.7rem 1rem;transition:border-color .2s,box-shadow .2s;display:grid}.turn-bar.my-turn{background:linear-gradient(135deg,#00281480,#161616f2);border-color:#00fd0073;box-shadow:0 0 24px #00fd001f,inset 0 1px #00fd0014}.turn-label{color:#1af4fc;text-align:left;text-overflow:ellipsis;white-space:nowrap;grid-area:1/1;min-width:0;margin:0;font-size:1rem;font-weight:700;line-height:1.25;overflow:hidden}.turn-label.ready{color:#00fd00;text-shadow:0 0 12px #00fd0059}.turn-timer{color:#fff;font-variant-numeric:tabular-nums;background:#00000059;border:1px solid #ffffff1f;border-radius:8px;grid-area:1/2/-1;place-self:center end;min-width:3.25rem;margin:0;padding:.35rem .65rem;font-size:1.5rem;font-weight:800;line-height:1;box-shadow:inset 0 1px #ffffff0f}.turn-bar.my-turn .turn-timer{color:#00fd00;text-shadow:0 0 10px #00fd0066;border-color:#00fd0059}.turn-hint{color:#ffffff73;text-align:left;grid-area:2/1;min-height:1.2em;margin:0;font-size:.8rem;line-height:1.2}.turn-hint--idle{color:#ffffff52;font-style:italic}.waiting-msg,.bingo-placeholder{color:#888;text-align:center;padding:2rem}.game-footer{text-align:center;color:#fff;flex-direction:column;gap:.35rem;width:min(100%,500px);margin-top:1rem;font-size:.9rem;display:flex}.last-called strong{color:#1af4fc}.called-list{color:#aaa;word-break:break-word;font-size:.8rem}.player-list{margin:0;padding:4px 2px;list-style:none}.player-item-wrap{border-radius:8px;margin-bottom:.35rem;list-style:none;position:relative}.player-item-wrap.has-timer{--ring-width:3px;padding:var(--ring-width);background:conic-gradient(from -90deg, var(--ring-color,#1af4fc) 0deg, var(--ring-color,#1af4fc) var(--ring-deg,360deg), transparent var(--ring-deg,360deg));border-radius:8px}.player-item-wrap.has-timer .player-item{border-radius:calc(8px - var(--ring-width));background:#1a2428;border:none;margin:0}.player-item{background:#1a2428;border:2px solid #0000;border-radius:6px;flex-wrap:wrap;align-items:center;gap:.35rem;padding:.5rem .6rem;font-size:.85rem;display:flex}.player-item.active{border-color:#0000}.player-item.me .player-name{color:#00fd00}.host-tag{background:#02718d;border-radius:3px;padding:.1rem .35rem;font-size:.7rem}.lines-badge{color:#888;margin-left:auto;font-size:.75rem}.player-wins-badge{color:#fc0;white-space:nowrap;flex-shrink:0;margin-left:auto;font-size:.75rem}.modal-overlay{z-index:100;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{text-align:center;max-width:360px}.winner-modal .btn.primary{width:100%;margin-bottom:.75rem}.modal-overlay.modal-overlay-top{z-index:110}.confirm-modal{text-align:center;width:min(92vw,400px);padding:1.75rem 1.5rem 1.5rem}.confirm-modal h2{color:#fff;margin:0 0 .75rem;font-size:1.35rem}.confirm-modal-message{color:#aaa;margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.confirm-modal-warning .confirm-modal-message{color:#fc8}.confirm-modal-actions{flex-direction:column-reverse;gap:.65rem;display:flex}.confirm-modal-actions .btn{width:100%;max-width:none;margin:0;padding:.75rem 1rem;font-size:1rem}.confirm-modal-stay{color:#fff;background:#02718d;border-color:#02718d}.confirm-modal-stay:hover{background:#038ca8}.confirm-modal-leave{color:#f88;background:0 0;border:1px solid #ff646480}.confirm-modal-leave:hover{color:#faa;background:#ff444426;border-color:#f66}@media (width>=480px){.confirm-modal-actions{flex-direction:row}.confirm-modal-actions .btn{flex:1}}.btn-link{color:#888;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:.85rem;text-decoration:underline}.btn-link:hover{color:#1af4fc}.vote-wait-msg{color:#1af4fc;margin:0 0 1rem;font-size:.9rem}.leaderboard-page-header{margin-bottom:.75rem}.leaderboard-page-header h2{flex:1}.leaderboard-intro{text-align:left;margin:0 0 1rem;font-size:.9rem}.leaderboard-empty{text-align:center;padding:1rem 0}.leaderboard-list-card,.leaderboard-detail-card{width:100%;max-width:520px;padding:1.1rem}.leaderboard-detail-card{max-width:560px}.leaderboard-list-card .game-panel-header,.leaderboard-detail-card .game-panel-header{margin-bottom:.5rem}.leaderboard-list-card .game-panel-header .btn,.leaderboard-detail-card .game-panel-header .btn{flex-shrink:0;margin-left:auto}.leaderboard-room-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.leaderboard-room-item{color:inherit;background:#1a2428;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;gap:.25rem;padding:.85rem 1rem;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.leaderboard-room-item:hover{background:#02718d33;border-color:#1af4fc}.leaderboard-room-code{letter-spacing:.08em;color:#1af4fc;font-size:1.05rem;font-weight:700}.leaderboard-room-meta{color:#aaa;font-size:.85rem}.leaderboard-room-top{font-size:.9rem}.leaderboard-room-top strong{color:#00fd00}.leaderboard-room-date{color:#666;font-size:.75rem}.leaderboard-stats-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.25rem;display:flex}.leaderboard-stats-dates{font-size:.8rem}.leaderboard-section{background:#00000040;border:1px solid #ffffff0f;border-radius:8px;margin-bottom:1.25rem;padding:.75rem}.leaderboard-section h3{color:#fc0;letter-spacing:.04em;text-transform:uppercase;margin:0 0 .75rem;font-size:.95rem}.win-bar-chart{background:#1a2428;border-radius:8px;margin-bottom:1rem;padding:.75rem}.win-bar-chart-bars{flex-direction:column;gap:.5rem;display:flex}.win-bar-chart-row{grid-template-columns:minmax(4rem,28%) 1fr;align-items:center;gap:.5rem;display:grid}.win-bar-chart-label{color:#ccc;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;overflow:hidden}.win-bar-chart-track{background:#ffffff0f;border-radius:4px;height:1.5rem;position:relative;overflow:hidden}.win-bar-chart-fill{background:linear-gradient(90deg,#02718d,#1af4fc);border-radius:4px;min-width:2px;height:100%;transition:width .35s}.win-bar-chart-value{color:#fff;text-shadow:0 0 4px #000;font-size:.75rem;font-weight:700;position:absolute;top:50%;right:.35rem;transform:translateY(-50%)}.win-bar-chart-caption{color:#666;text-align:center;margin:.5rem 0 0;font-size:.75rem}.chart-empty{text-align:center;margin:0}.leaderboard-rank-list{margin:0;padding:0;list-style:none}.leaderboard-rank-item{border-bottom:1px solid #ffffff0f;grid-template-columns:auto 1fr auto;align-items:center;gap:.35rem .75rem;padding:.5rem 0;display:grid}.leaderboard-rank-num{color:#02718d;font-size:.9rem;font-weight:700}.leaderboard-rank-name{font-weight:600}.leaderboard-rank-wins{color:#00fd00;font-size:.9rem}.leaderboard-rank-meta{grid-column:2/-1;font-size:.75rem}.leaderboard-game-history{-webkit-overflow-scrolling:touch;flex-direction:column;gap:.65rem;max-height:360px;margin:0;padding:0 .35rem 0 0;list-style:none;display:flex;overflow-y:auto}.leaderboard-game-item{background:#1a2428;border:1px solid #ffffff0f;border-radius:8px;padding:.75rem}.leaderboard-game-head{flex-wrap:wrap;justify-content:space-between;gap:.35rem;margin-bottom:.35rem;display:flex}.leaderboard-game-winner{color:#1af4fc}.leaderboard-game-detail{margin:0 0 .5rem;font-size:.8rem}.leaderboard-game-players{flex-wrap:wrap;gap:.35rem .75rem;margin:0;padding:0;font-size:.85rem;list-style:none;display:flex}.leaderboard-game-players .winner{color:#00fd00;font-weight:600}.lobby-leaderboard-link .btn{width:100%}.leaderboard-global-card{max-width:640px}.leaderboard-global-head h3{margin:0}.leaderboard-champion-banner{color:#fc0;background:linear-gradient(90deg,#ffcc0026,#02718d33);border:1px solid #fc06;border-radius:8px;margin:.5rem 0 0;padding:.5rem .75rem;font-size:.9rem}.leaderboard-champion-banner strong{color:#fff}.leaderboard-global-section{border-bottom:1px solid #ffffff14;margin-bottom:2rem;padding-bottom:1.5rem}.game-table-wrap{-webkit-overflow-scrolling:touch;border:1px solid #1af4fc33;border-radius:10px;margin-top:.75rem;overflow-x:auto;box-shadow:0 0 24px #0c2d6b59}.game-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.9rem}.game-table th.game-table-status,.game-table td.game-table-status{z-index:2;text-align:center;border-left:1px solid #1af4fc2e;min-width:5.25rem;position:sticky;right:0;box-shadow:-8px 0 16px -6px #000000bf}.game-table thead th.game-table-status{z-index:3;background:#035a70}.game-table td.game-table-status{background:#1a2428}.game-table tbody tr:hover td.game-table-status{background:#1e3238}.game-table-row-gold td.game-table-status{background:#2a2618}.game-table-row-silver td.game-table-status{background:#242628}.game-table-row-bronze td.game-table-status{background:#2a2218}.game-table-row-me td.game-table-status{background:#1a2820}.game-table thead{background:linear-gradient(#02718d 0%,#035a70 100%)}.game-table th{text-align:left;color:#fff;white-space:nowrap;letter-spacing:.03em;padding:.65rem .75rem;font-size:.8rem;font-weight:600}.game-table td{background:#1a2428;border-bottom:1px solid #ffffff0f;padding:.6rem .75rem}.game-table tbody tr:last-child td{border-bottom:none}.game-table tbody tr:hover td{background:#02718d40}.game-table-rank{text-align:center;width:3.5rem}.game-table-rank-badge{font-size:1rem;font-weight:700}.game-table-player{min-width:8rem}.game-table-name{font-weight:600}.game-table-you{color:#00fd00;vertical-align:middle;background:#00fd0033;border-radius:3px;margin-left:.4rem;padding:.1rem .35rem;font-size:.7rem}.game-table-wins{color:#fc0;font-weight:700}.game-table-games{color:#1af4fc}.game-table-rate{color:#aaa}.game-table-row-gold td{background:#ffcc001f}.game-table-row-silver td{background:#c0c0c01a}.game-table-row-bronze td{background:#cd7f321f}.game-table-row-champion .game-table-name{color:#fc0}.game-table-row-me td{box-shadow:inset 0 0 0 1px #00fd0073}.game-table-champion-tag{color:#000;text-transform:uppercase;background:linear-gradient(90deg,#fc0,#f90);border-radius:4px;padding:.15rem .45rem;font-size:.7rem;font-weight:700;display:inline-block}.game-table-contender-tag{color:#1af4fc;font-size:.75rem}.game-table-active-tag{color:#888;font-size:.75rem}.game-table-empty{text-align:center;padding:1rem 0}@media (width<=768px){.game-table-wrap{-webkit-overflow-scrolling:touch;border-radius:8px;margin-left:-.15rem;margin-right:-.15rem;overflow-x:auto}.game-table{min-width:32rem;font-size:.78rem}.game-table th,.game-table td{white-space:nowrap;padding:.45rem .5rem}.game-table th{letter-spacing:.02em;font-size:.68rem}.game-table-rank{width:2.5rem}.game-table-rank-badge{font-size:.9rem}.game-table-player{white-space:nowrap;text-overflow:ellipsis;min-width:5.5rem;max-width:7rem;overflow:hidden}.game-table-name{text-overflow:ellipsis;vertical-align:middle;max-width:4.5rem;display:inline-block;overflow:hidden}.game-table-you{margin-left:.25rem;font-size:.62rem}.game-table-champion-tag{padding:.1rem .35rem;font-size:.62rem}.game-table-contender-tag,.game-table-active-tag{font-size:.68rem}.game-table th.game-table-status,.game-table td.game-table-status{min-width:4.75rem;padding-left:.65rem;padding-right:.65rem}.page{padding:max(.75rem, env(safe-area-inset-left)) max(.75rem, env(safe-area-inset-right));padding-top:max(.75rem, env(safe-area-inset-top));padding-bottom:max(1rem, env(safe-area-inset-bottom))}.page.center{padding-top:max(1.25rem, env(safe-area-inset-top));align-items:flex-start}.card{border-radius:10px;padding:1.25rem 1rem}.hero-card,.form-card,.auth-card,.lobby-card,.lobby-leaderboard-card{max-width:100%}.page.auth-page{padding-left:max(.75rem, env(safe-area-inset-left));padding-right:max(.75rem, env(safe-area-inset-right));gap:1rem}.auth-card{max-width:100%;padding:1rem 1rem 1.25rem}.auth-card .game-panel-icon{font-size:1.1rem}.auth-footer-btn,.auth-submit{min-height:44px}.page.lobby-page{padding:max(.75rem, env(safe-area-inset-top)) max(.75rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(.75rem, env(safe-area-inset-left));gap:1rem}.lobby-page-brand .logo{letter-spacing:.08em;font-size:2rem}.lobby-page-tagline{font-size:.75rem}.lobby-layout{grid-template-columns:1fr;max-width:100%}.lobby-layout .lobby-card{order:1}.lobby-layout .lobby-leaderboard-card{order:2}.lobby-leaderboard-card{max-height:none}.logo{font-size:2.25rem}.logo.logo-small{font-size:1.2rem}.subtitle{margin-bottom:1.25rem;font-size:.95rem}.game-panel-header--play{flex-direction:column;align-items:stretch}.game-panel-header--play .lobby-player-stats{justify-content:flex-end;width:100%;margin-left:0}.game-panel-title-wrap h2{font-size:1.15rem}.lobby-stat-chip{padding:.3rem .5rem;font-size:.8rem}.lobby-header-user{justify-content:space-between;gap:.75rem;width:100%}.lobby-header-user .badge{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.lobby-header-user .btn{flex-shrink:0;min-height:44px}.btn,.btn-group .btn{min-height:44px;padding:.7rem 1rem}.btn.small{min-height:36px;padding:.4rem .65rem}.game-page{max-width:100vw;min-height:100vh;overflow:hidden}.game-page .game-panel-header--play,.game-page .game-panel-header--arena{flex-flow:row;align-items:center;gap:.45rem;margin-bottom:.5rem;padding-bottom:.45rem}.game-page .game-panel-icon{filter:drop-shadow(0 0 4px #1af4fc59);flex-shrink:0;font-size:1.1rem}.game-page .game-panel-title-wrap h2{font-size:1rem}.game-page .game-panel-sub{font-size:.62rem}.game-header-panel{padding:max(.5rem, env(safe-area-inset-top)) .65rem .5rem;flex-shrink:0;grid-template-rows:auto auto;grid-template-columns:auto 1fr auto;gap:.35rem .5rem;display:grid}.game-header-panel>.btn.ghost{grid-area:1/1;margin:0;padding-left:.25rem;padding-right:.25rem}.game-header-room{text-align:center;grid-area:1/2;justify-self:center;min-width:0}.game-header-room .room-code-badge{letter-spacing:.06em;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;display:block;overflow:hidden}.game-header-panel .share-room-wrap{grid-area:1/3;justify-self:end;min-width:0}.share-room-feedback{font-size:.7rem}.game-header-status{grid-area:2/1/auto/-1;justify-content:space-between;gap:.35rem;width:100%;margin-left:0}.server-status-label{display:none}.server-status-item{justify-content:center;min-width:28px;padding:.35rem}.status-badge{text-overflow:ellipsis;white-space:nowrap;max-width:50%;padding:.2rem .45rem;font-size:.7rem;overflow:hidden}.game-toast,.error.banner{flex-shrink:0;padding:.5rem .65rem;font-size:.85rem}.game-arena{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;flex:1;gap:.5rem;min-width:0;min-height:0;padding:.5rem;overflow:hidden auto}.game-arena>*{min-width:0;max-width:100%}.game-sidebar-panel{flex-shrink:0;width:100%;max-height:none;padding:.65rem}.game-main-wrap{flex:1;min-height:0}.game-board-panel{min-height:0}.game-sidebar-panel .btn-game-action{min-height:44px}.sidebar-hint{text-align:center;margin:0;font-size:.75rem}.player-list{-webkit-overflow-scrolling:touch;scrollbar-width:thin;flex-flow:row;align-items:stretch;gap:.5rem;width:100%;padding:6px 4px 8px;display:flex;overflow:auto visible}.player-item-wrap{isolation:isolate;flex:none;min-width:132px;max-width:160px;margin-bottom:0}.player-item-wrap.has-timer{margin:2px 0}.player-item{padding:.45rem .5rem;font-size:.8rem}.game-main-wrap,.game-main{flex:1 0 auto;width:100%;min-width:0}.game-board-panel{box-sizing:border-box;z-index:0;flex:1 0 auto;justify-content:flex-start;align-items:stretch;gap:.5rem;width:100%;min-width:0;padding:.65rem;position:relative;overflow:hidden visible}.game-board-panel .bingo-board-wrap,.game-main .bingo-board-wrap{flex:none;order:1}.game-board-panel .turn-bar,.game-board-panel .setup-bar,.game-main .turn-bar,.game-main .setup-bar{flex-shrink:0;order:0}.game-board-panel .game-footer,.game-main .game-footer{flex-shrink:0;order:2}.turn-bar,.setup-bar,.game-footer{width:100%;max-width:none;margin-bottom:.35rem}.turn-bar{column-gap:.65rem;min-height:4rem;margin-bottom:.25rem;padding:.6rem .75rem}.turn-label{font-size:.88rem}.turn-timer{min-width:2.85rem;padding:.3rem .5rem;font-size:1.2rem}.turn-hint{font-size:.75rem}.setup-bar{gap:.6rem;min-height:4rem;padding:.6rem .75rem!important}.setup-bar-main{width:100%}.setup-bar-icon{width:1.75rem;height:1.75rem;font-size:1.05rem}.setup-bar-label{font-size:.88rem}.setup-bar-hint{font-size:.75rem}.setup-bar-action{width:100%;min-height:44px}.game-footer{margin-top:.25rem;font-size:.8rem}.called-list{font-size:.75rem;line-height:1.35}.modal-overlay{padding:max(.75rem, env(safe-area-inset-top)) max(.75rem, env(safe-area-inset-right)) max(.75rem, env(safe-area-inset-bottom)) max(.75rem, env(safe-area-inset-left));align-items:flex-start}.modal,.confirm-modal{border-radius:12px 12px 0 0;width:100%;max-width:none;max-height:90dvh;margin:0;overflow-y:auto}.confirm-modal{padding:1.25rem 1rem max(1rem, env(safe-area-inset-bottom))}.winner-modal .btn.primary{min-height:44px}}@media (width<=380px){.game-header-room .room-code-badge{font-size:.78rem}.player-item-wrap{min-width:118px}.leaderboard-detail-card{max-width:100%}.win-bar-chart-row{grid-template-columns:minmax(3.5rem,32%) 1fr}.leaderboard-game-history{max-height:280px}}
