*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{-webkit-font-smoothing:antialiased;background:#1a0533;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.logo-text{font-family:inherit;font-weight:inherit;font-size:inherit}.logo-v{background:linear-gradient(135deg,#c77dff,#e040fb);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.home{background:linear-gradient(135deg,#1a0533 0%,#2d0a5e 50%,#1a0533 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex;position:relative}.lang-toggle{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:999px;padding:.4rem .85rem;font-size:.85rem;font-weight:700;transition:background .2s;position:absolute;top:1.25rem;right:1.25rem}.lang-toggle:hover{background:#ffffff2e}.home-header{text-align:center;margin-bottom:2rem}.logo{margin-bottom:.5rem;font-size:4rem}.home-header h1{color:#fff;text-shadow:0 0 20px #f0c;margin:0;font-size:2.5rem;font-weight:900}.home-header p{color:#c9a0ff;margin-top:.5rem;font-size:1rem}.home-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff26;border-radius:1.5rem;flex-direction:column;gap:1rem;width:100%;max-width:380px;padding:2rem;display:flex}.input{color:#fff;box-sizing:border-box;background:#ffffff1a;border:2px solid #fff3;border-radius:.75rem;outline:none;width:100%;padding:.85rem 1rem;font-size:1rem;transition:border-color .2s}.input::placeholder{color:#fff6}.input:focus{border-color:#c77dff}.input-code{text-align:center;letter-spacing:.5rem;text-transform:uppercase;font-size:2rem;font-weight:900}.button-group{flex-direction:column;gap:.75rem;display:flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#c77dff,#e040fb);box-shadow:0 4px 20px #c77dff66}.btn-secondary{color:#fff;background:#ffffff1f;border:1px solid #fff3}.error{color:#ff6b9d;text-align:center;margin:0;font-size:.9rem}.btn-link{color:#c9a0ff;cursor:pointer;text-align:center;background:0 0;border:none;padding:0;font-size:.9rem}.home-footer{text-align:center;position:absolute;bottom:1rem;left:0;right:0}.btn-link-footer{color:#ffffff4d;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.75rem}.btn-info{color:#fff9;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:999px;margin-top:.75rem;padding:.35rem .9rem;font-size:.8rem}.info-overlay{z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.info-modal{background:#1e0545;border:1px solid #c77dff4d;border-radius:1.5rem;flex-direction:column;gap:1rem;width:100%;max-width:360px;padding:1.75rem;display:flex}.info-modal h2{color:#fff;text-align:center;margin:0;font-size:1.25rem;font-weight:800}.info-modal ul{flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.info-modal li{color:#ffffffd9;font-size:.88rem;line-height:1.5}.info-pro{color:#c77dff;border-top:1px solid #ffffff1a;margin:0;padding-top:.75rem;font-size:.78rem}.pro-return-banner{border-radius:1rem;align-items:flex-start;gap:.75rem;width:100%;max-width:360px;margin-bottom:.5rem;padding:.85rem 1rem;animation:.4s fadeIn;display:flex}.pro-return-success{background:#00e6761f;border:1px solid #00e67659}.pro-return-cancel{background:#ffffff12;border:1px solid #ffffff26}.pro-return-icon{flex-shrink:0;font-size:1.5rem;line-height:1}.pro-return-banner strong{color:#fff;margin-bottom:.15rem;font-size:.9rem;display:block}.pro-return-banner p{color:#fff9;margin:0;font-size:.78rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.topbar{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1a0533d9;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex;position:sticky;top:0}.topbar-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1px solid #ffffff2e;border-radius:999px;padding:.4rem .9rem;font-size:.85rem;font-weight:600;transition:background .15s}.topbar-btn:hover{background:#ffffff2e}.topbar-lang{margin-left:auto}.topbar-player{pointer-events:none;align-items:center;gap:.4rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.topbar-player-name{color:#ffffffbf;text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-size:.8rem;font-weight:600;overflow:hidden}.topbar-host-badge{color:#1a0533;white-space:nowrap;background:linear-gradient(135deg,gold,#fa0);border-radius:999px;padding:.1rem .45rem;font-size:.65rem;font-weight:700}.topbar-leave-btn{color:#f99;border-color:#ff646466}.topbar-leave-btn:hover{background:#ff646426}.leave-overlay{z-index:100;background:#000000a6;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.leave-modal{text-align:center;background:linear-gradient(135deg,#2d0a5e,#1a0533);border:1px solid #ffffff26;border-radius:1.25rem;width:100%;max-width:360px;padding:1.75rem}.leave-title{color:#fff;margin:0 0 .75rem;font-size:1.2rem;font-weight:800}.leave-info{color:#ffffffb3;margin:0 0 1.5rem;font-size:.9rem;line-height:1.5}.leave-btns{gap:.75rem;display:flex}.btn-leave-cancel{color:#fff;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:.75rem;flex:1;padding:.85rem;font-size:1rem;font-weight:600}.btn-leave-confirm{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f44,#c00);border:none;border-radius:.75rem;flex:1;padding:.85rem;font-size:1rem;font-weight:700}.lobby{color:#fff;background:linear-gradient(135deg,#1a0533 0%,#2d0a5e 50%,#1a0533 100%);flex-direction:column;gap:1.25rem;min-height:100dvh;padding:1.5rem;display:flex}.demo-badge{text-align:center;color:gold;letter-spacing:.1em;background:#ffc80026;border:1px solid #ffc80066;border-radius:.75rem;padding:.4rem;font-size:.85rem;font-weight:700}.grid-selector{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:1.25rem;padding:1.25rem}.grid-options{gap:.75rem;margin-top:.75rem;display:flex}.grid-btn{color:#fff;cursor:pointer;background:#ffffff0f;border:2px solid #ffffff26;border-radius:.75rem;flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:.75rem .5rem;font-size:1rem;font-weight:700;transition:all .15s;display:flex}.grid-btn-active{background:#c77dff33;border-color:#c77dff;box-shadow:0 0 12px #c77dff4d}.grid-btn-locked{opacity:.4;cursor:not-allowed}.grid-btn-sub{opacity:.7;font-size:.65rem;font-weight:400}.grid-info{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:1rem;padding:.75rem 1.25rem}.lobby-top{text-align:center;background:#ffffff14;border:1px solid #ffffff26;border-radius:1.25rem;padding:1.5rem}.lobby-label{color:#c9a0ff;text-transform:uppercase;letter-spacing:.1em;margin:0 0 .5rem;font-size:.85rem}.room-code{letter-spacing:.4em;color:#f0c0ff;text-shadow:0 0 30px #c77dff;font-size:3.5rem;font-weight:900}.lobby-hint{color:#ffffff80;margin:.5rem 0 0;font-size:.85rem}.btn-copy-link{color:#c77dff;cursor:pointer;background:#c77dff1f;border:1px solid #c77dff66;border-radius:.75rem;width:100%;margin-top:.75rem;padding:.6rem 1rem;font-size:.85rem;font-weight:600;transition:background .15s}.btn-copy-link:hover{background:#c77dff38}.section-title{text-transform:uppercase;letter-spacing:.1em;color:#c9a0ff;margin:0 0 .75rem;font-size:.85rem}.players-list{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:1.25rem;padding:1.25rem}.player-row{border-bottom:1px solid #ffffff0f;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.player-row:last-child{border-bottom:none}.player-avatar{background:linear-gradient(135deg,#c77dff,#e040fb);border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.9rem;font-weight:900;display:flex}.player-name{flex:1;font-weight:600}.badge-host{color:#c77dff;background:#c77dff4d;border-radius:999px;padding:.2rem .6rem;font-size:.7rem}.pro-banner{text-align:center;background:linear-gradient(135deg,#ffc80026,#ff960026);border:1px solid #ffc8004d;border-radius:1.25rem;padding:1.25rem}.pro-banner p{margin:0 0 .25rem}.pro-desc{color:#fff9;font-size:.85rem;margin-bottom:1rem!important}.btn{cursor:pointer;border:none;border-radius:.75rem;width:100%;padding:1rem;font-size:1.1rem;font-weight:700;transition:transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-pro{color:#1a0533;background:linear-gradient(135deg,gold,#ff9800)}.btn-start{color:#fff;background:linear-gradient(135deg,#00e676,#00bfa5);padding:1.1rem;font-size:1.2rem;box-shadow:0 4px 20px #00e6764d}.waiting-text{text-align:center;color:#ffffff80;margin-top:auto;font-size:.9rem}.full-warning{text-align:center;color:#ff6b9d;font-size:.85rem}.lobby-locked-banner{text-align:center;color:#f99;background:#ff64641f;border:1px solid #ff64644d;border-radius:.75rem;padding:.5rem .75rem;font-size:.82rem;font-weight:700}.btn-lock-lobby{color:#ffffff80;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff26;border-radius:.75rem;width:100%;padding:.65rem;font-size:.82rem;font-weight:600;transition:background .15s}.btn-lock-lobby:hover{background:#ffffff1a}.btn-lock-lobby-locked{color:#f99;background:#ff64641a;border-color:#ff64644d}.btn-guide{color:#fff9;cursor:pointer;text-align:center;background:#ffffff0d;border:1px solid #ffffff1f;border-radius:.75rem;width:100%;padding:.65rem 1rem;font-size:.85rem;font-weight:600;transition:background .15s}.btn-guide:hover{background:#ffffff1a}.guide-content{flex-direction:column;gap:1rem;display:flex}.guide-section{flex-direction:column;gap:.35rem;display:flex}.guide-heading{color:#c77dff;margin:0;font-size:.9rem;font-weight:700}.guide-list{flex-direction:column;gap:.2rem;margin:0;padding-left:1.25rem;display:flex}.guide-list li{color:#fffc;font-size:.82rem;line-height:1.45}.modal-box-pro{gap:.75rem}.disclaimer-subheading{text-transform:uppercase;letter-spacing:.08em;color:#c9a0ff;margin:.25rem 0 0;font-size:.8rem}.disclaimer-list{flex-direction:column;gap:.25rem;margin:0;padding-left:1.1rem;display:flex}.disclaimer-list-features li{color:gold;font-size:.88rem;font-weight:600}.disclaimer-list-notes li{color:#ffffffa6;font-size:.8rem;line-height:1.45}.modal-accept-btn{color:#1a0533;background:linear-gradient(135deg,gold,#ff9800);margin-top:.5rem;padding:.9rem;font-size:1rem}.disclaimer-coming-soon{color:gold;text-align:center;background:#ffc8001a;border:1px solid #ffc8004d;border-radius:.75rem;margin-top:.5rem;padding:.75rem 1rem;font-size:.85rem;font-weight:600}.btn-ranking{color:gold;background:#ffd7001f;border:1px solid #ffd70040}.lobby-share-row{justify-content:center;gap:.5rem;margin-top:.25rem;display:flex}.btn-qr{color:#c77dff;cursor:pointer;white-space:nowrap;background:#c77dff1f;border:1px solid #c77dff4d;border-radius:.75rem;padding:.6rem 1rem;font-size:.85rem;font-weight:600}.qr-container{background:#ffffff0a;border:1px solid #c77dff33;border-radius:1rem;justify-content:center;margin-top:.75rem;padding:1rem;display:flex}.event-mode-selector{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:1.25rem;padding:1.25rem}.event-mode-options{flex-direction:column;gap:.5rem;margin-top:.75rem;display:flex}.event-mode-btn{color:#ffffffb3;text-align:left;cursor:pointer;background:#ffffff0a;border:1px solid #c77dff33;border-radius:.75rem;padding:.7rem 1rem;font-size:.9rem;transition:all .15s}.event-mode-btn-active{color:#fff;background:#c77dff33;border-color:#c77dff;font-weight:700}.event-mode-info{text-align:center;opacity:.8;padding:.5rem}.demo-code-row{gap:.5rem;display:flex}.demo-code-input{color:#fff;letter-spacing:.05em;background:#ffffff12;border:1px solid #ffffff26;border-radius:.75rem;flex:1;padding:.6rem .9rem;font-size:.85rem}.demo-code-input::placeholder{color:#ffffff59}.demo-code-btn{color:#ffffffb3;cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff26;border-radius:.75rem;padding:.6rem 1rem;font-size:.85rem}.demo-code-msg{text-align:center;padding:.25rem;font-size:.85rem}.demo-code-ok{color:#4caf50}.demo-code-err{color:#ef5350}.char-picker{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:1.25rem;padding:1.25rem}.char-grid{grid-template-columns:repeat(6,1fr);gap:.4rem;margin-top:.75rem;display:grid}.char-option{aspect-ratio:1;cursor:pointer;background:#ffffff0a;border:2px solid #ffffff1f;border-radius:.6rem;padding:0;transition:border-color .15s,box-shadow .15s;position:relative;overflow:hidden}.char-option:not(.char-option-locked):hover{border-color:#c77dff80}.char-option-selected{box-shadow:0 0 10px #c77dff80;border-color:#c77dff!important}.char-option-locked{cursor:not-allowed}.char-option-locked .char-img{filter:blur(10px);transform:scale(1.15)}.char-img{object-fit:cover;width:100%;height:100%;display:block}.char-lock-overlay{background:#0f0328eb;border-radius:.4rem;flex-direction:column;justify-content:center;align-items:center;gap:1px;display:flex;position:absolute;inset:0}.char-lock-overlay-icon{font-size:.75rem}.char-lock-overlay-label{letter-spacing:.06em;color:#ffd700d9;font-size:.48rem;font-weight:800}.char-pro-hint{color:#ffffff73;text-align:center;margin:.6rem 0 0;font-size:.75rem}.player-char-img{object-fit:cover;border-radius:.4rem;flex-shrink:0;width:2rem;height:2rem}.btn-back-to-game{color:#fff;background:linear-gradient(135deg,#c77dff,#e040fb);padding:1rem;font-size:1.1rem;box-shadow:0 4px 20px #c77dff59}.now-performing-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);cursor:pointer;background:#1a0533e0;justify-content:center;align-items:center;transition:opacity .35s;display:flex;position:fixed;inset:0}.np-visible{opacity:1;pointer-events:auto}.np-hidden{opacity:0;pointer-events:none}.np-card{text-align:center;width:90%;max-width:340px;padding:2.5rem 2rem}.np-label{letter-spacing:.12em;text-transform:uppercase;color:#c77dff;margin-bottom:1.25rem;font-size:.85rem;font-weight:600}.np-guest{color:#c77dff99;font-weight:400}.np-flag{filter:drop-shadow(0 0 20px #c77dff80);margin-bottom:.75rem;font-size:5rem;line-height:1}.np-country{color:#fff;margin:0 0 .3rem;font-size:2rem;font-weight:800}.np-artist{color:#fffc;margin:0 0 .2rem;font-size:1.05rem}.np-song{color:#c77dff;margin:0 0 1.25rem;font-size:.95rem;font-style:italic}.np-progress{color:#fff6;letter-spacing:.08em;margin:0 0 1.5rem;font-size:.8rem}.np-tap-hint{color:#ffffff40;margin:0;font-size:1.25rem}.bingo-wrap{background:linear-gradient(135deg,#1a0533 0%,#2d0a5e 50%,#1a0533 100%);flex-direction:column;gap:1rem;min-height:100dvh;padding:1rem;display:flex}.game-room-bar{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:.75rem;align-items:center;gap:.5rem;padding:.45rem .75rem;display:flex}.game-room-label{color:#fff6;text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:.7rem}.game-room-code{letter-spacing:.25em;color:#f0c0ff;flex:1;font-size:1.1rem;font-weight:900}.btn-copy-code{color:#c77dff;cursor:pointer;white-space:nowrap;background:#c77dff1f;border:1px solid #c77dff66;border-radius:.5rem;padding:.3rem .65rem;font-size:.75rem;font-weight:600;transition:background .15s}.btn-copy-code:hover{background:#c77dff38}.btn-settings{color:#ffffffb3;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff26;border-radius:.5rem;flex-shrink:0;padding:.3rem .5rem;font-size:1rem;transition:background .15s}.btn-settings:hover{background:#ffffff1f}.country-wrap{position:relative}.country-bar{gap:.5rem;display:flex}.country-suggestions{z-index:20;background:#2d0a5e;border:1px solid #c77dff80;border-radius:.75rem;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 4px 20px #00000080}.suggestion-item{color:#fff;cursor:pointer;text-align:left;background:0 0;border:none;border-bottom:1px solid #ffffff0f;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;transition:background .1s;display:flex}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item:active{background:#c77dff33}.suggestion-flag{font-size:1.15rem}.suggestion-name{font-size:.9rem;font-weight:600}.country-input{color:#fff;background:#ffffff1a;border:2px solid #fff3;border-radius:.75rem;outline:none;flex:1;padding:.75rem 1rem;font-size:.95rem}.country-input::placeholder{color:#fff6}.country-input:focus{border-color:#c77dff}.country-input-error{border-color:#ff6b6b!important}.country-error{color:#f99;text-align:center;background:#ff6b6b26;border:1px solid #ff6b6b80;border-radius:.6rem;margin-top:-.5rem;padding:.5rem .75rem;font-size:.85rem}.btn-refresh{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#c77dff,#e040fb);border:none;border-radius:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:700}.btn-refresh-locked{color:#ffd700b3!important;cursor:not-allowed!important;background:#ffffff1a!important;border:1px solid #ffd7004d!important;font-size:.78rem!important}.bingo-grid{flex:1;gap:.4rem;display:grid}.bingo-grid-3{grid-template-columns:repeat(3,1fr)}.bingo-grid-4{grid-template-columns:repeat(4,1fr)}.bingo-grid-5{grid-template-columns:repeat(5,1fr)}.bingo-grid-4 .square{font-size:clamp(.55rem,2vw,.75rem)}.bingo-grid-5 .square{border-radius:.6rem;font-size:clamp(.45rem,1.8vw,.65rem)}.bingo-grid.bingo-won .square-marked{animation:.6s infinite alternate pulse}.demo-badge-game{text-align:center;color:gold;letter-spacing:.05em;background:#ffc80026;border:1px solid #ffc80066;border-radius:.75rem;padding:.4rem;font-size:.8rem;font-weight:700}.square{aspect-ratio:1;color:#fff;cursor:pointer;text-align:center;background:#ffffff14;border:2px solid #ffffff26;border-radius:1rem;justify-content:center;align-items:center;padding:.5rem;font-size:clamp(.65rem,2.5vw,.85rem);font-weight:600;line-height:1.2;transition:transform .1s,background .2s;display:flex}.square:active{transform:scale(.93)}.square-marked{border-color:#0000;box-shadow:0 2px 16px #c77dff80;background:linear-gradient(135deg,#c77dff,#e040fb)!important}.square-free{color:gold;background:#ffd70026;border-color:#ffd70066}.square-loading{aspect-ratio:1;background:#ffffff0d;border:2px solid #ffffff14;border-radius:1rem;animation:1.2s infinite alternate shimmer}.bingo-banner{text-align:center;color:gold;text-shadow:0 0 30px gold;padding:1rem;font-size:2rem;font-weight:900;animation:.5s infinite alternate pulse}.winner-toast{text-align:center;color:gold;background:#ffc80026;border:1px solid #ffc8004d;border-radius:1rem;padding:.75rem;font-weight:700}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.demo-toast{text-align:center;color:#80ffaa;background:#50ff7826;border:1px solid #50ff7866;border-radius:.75rem;padding:.6rem 1rem;font-size:.85rem;font-weight:700;animation:.3s fadeIn}.game-nav-row{gap:.5rem;margin-top:auto;display:flex}.btn-ranking-game{color:gold;cursor:pointer;background:#ffd7001a;border:1px solid #ffd7004d;border-radius:.75rem;flex:1;padding:.65rem;font-size:.85rem;font-weight:700}.btn-settings-game{color:#ffffffa6;cursor:pointer;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff26;border-radius:.75rem;padding:.65rem .9rem;font-size:.82rem;font-weight:600;transition:background .15s}.btn-settings-game:hover{background:#ffffff1f}.bingo-scoreboard .section-title{text-transform:uppercase;letter-spacing:.1em;color:#ffffff80;margin:0 0 .25rem;font-size:.75rem;font-weight:700}.bingo-scoreboard{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:1rem;flex-direction:column;gap:.4rem;padding:.75rem;display:flex}.score-row{border-radius:.5rem;align-items:center;gap:.5rem;padding:.3rem .5rem;font-size:.82rem;display:flex}.score-row-me{background:#c77dff26}.score-rank{color:#fff6;min-width:1.5rem;font-size:.72rem}.score-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.score-count{color:#fff9;font-size:.78rem}.score-bingo{color:#1a0533;background:linear-gradient(135deg,gold,#fa0);border-radius:999px;padding:.1rem .45rem;font-size:.65rem;font-weight:700}.score-lines{color:#c77dff;font-size:.7rem;font-weight:700}.room-locked-banner{text-align:center;color:#f99;background:#ff64641f;border:1px solid #ff64644d;border-radius:.6rem;padding:.4rem .75rem;font-size:.8rem;font-weight:700}.btn-lock-room{color:#ffffff8c;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff26;border-radius:.75rem;width:100%;padding:.5rem;font-size:.78rem;font-weight:600;transition:background .15s}.btn-lock-room:hover{background:#ffffff1a}.btn-lock-room-locked{color:#f99;background:#ff64641a;border-color:#ff64644d}.btn-end-game{color:#f99;cursor:pointer;background:#ff50501a;border:1px solid #ff646459;border-radius:.75rem;width:100%;margin-top:.25rem;padding:.6rem;font-size:.9rem;font-weight:600;transition:background .15s}.btn-end-game:hover{background:#ff50502e}.btn-end-game-confirm{color:#fff;background:linear-gradient(135deg,#e53935,#c62828);margin-top:.25rem;padding:.9rem;font-size:1rem}@keyframes shimmer{0%{background:#ffffff0a}to{background:#ffffff1a}}.perf-nav{background:#c77dff1a;border:1px solid #c77dff40;border-radius:1rem;align-items:center;gap:.5rem;margin:0 0 .25rem;padding:.6rem .75rem;display:flex}.perf-nav-btn{color:#c77dff;cursor:pointer;white-space:nowrap;background:#c77dff26;border:1px solid #c77dff4d;border-radius:.6rem;flex-shrink:0;padding:.45rem .75rem;font-size:.85rem;font-weight:600}.perf-nav-btn:disabled{opacity:.3;cursor:default}.perf-nav-next{background:#c77dff40}.perf-nav-info{text-align:center;color:#fff9;flex:1;font-size:.8rem;font-weight:500}.perf-info-bar{background:#c77dff14;border:1px solid #c77dff33;border-radius:1rem;align-items:center;gap:.75rem;padding:.65rem .9rem;display:flex}.perf-info-flag{flex-shrink:0;font-size:2rem;line-height:1}.perf-info-text{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.perf-info-country{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.perf-info-guest{color:#c77dffb3;font-size:.8rem;font-weight:400}.perf-info-artist{color:#ffffffb3;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.perf-info-song{color:#c77dff;white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-style:italic;overflow:hidden}.perf-info-num{color:#ffffff59;letter-spacing:.05em;flex-shrink:0;align-self:flex-start;padding-top:.1rem;font-size:.75rem}.country-readonly{text-align:center;color:#ffffffd9;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:.75rem;padding:.6rem 1rem;font-size:1rem;font-weight:600}.ranking-page{background:linear-gradient(135deg,#1a0533 0%,#2d0a5e 50%,#1a0533 100%);flex-direction:column;min-height:100dvh;display:flex}.ranking-locked-banner{text-align:center;color:#f99;background:#ff646426;border-bottom:1px solid #ff64644d;padding:.5rem;font-size:.85rem;font-weight:700}.ranking-content{flex-direction:column;gap:1.5rem;padding:1rem;display:flex;overflow-y:auto}.ranking-section{flex-direction:column;gap:.6rem;display:flex}.ranking-hint{color:#ffffff73;text-align:center;padding:1rem .5rem;font-size:.85rem}.my-picks-list{flex-direction:column;gap:.35rem;display:flex}.pick-row{background:#ffffff12;border-radius:.75rem;align-items:center;gap:.5rem;padding:.45rem .75rem;display:flex}.pick-num{color:#fff6;flex-shrink:0;width:1.4rem;font-size:.8rem}.pick-flag{flex-shrink:0;font-size:1.25rem}.pick-name{color:#fff;flex:1;font-size:.9rem;font-weight:600}.pick-actions{gap:.2rem;display:flex}.pick-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff2e;border-radius:.4rem;justify-content:center;align-items:center;width:1.9rem;height:1.9rem;padding:0;font-size:.9rem;display:flex}.pick-btn:disabled{opacity:.25;cursor:default}.pick-remove{color:#ff8080;background:#ff505026;border-color:#ff50504d}.btn-save{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c77dff,#e040fb);border:none;border-radius:.75rem;width:100%;padding:.75rem;font-size:.95rem;font-weight:700}.btn-save:disabled{opacity:.45;cursor:default}.btn-lock{color:#f99;cursor:pointer;background:#ff64641f;border:1px solid #ff646459;border-radius:.75rem;width:100%;padding:.65rem;font-size:.85rem;font-weight:700}.btn-unlock{color:#90ee90;cursor:pointer;background:#64c86414;border:1px solid #64c8644d;border-radius:.75rem;width:100%;padding:.65rem;font-size:.85rem;font-weight:700}.max-warn{color:#f99;font-size:.75rem;font-weight:400}.countries-grid{grid-template-columns:repeat(2,1fr);gap:.4rem;display:grid}.country-btn{color:#fff;cursor:pointer;text-align:left;background:#ffffff0f;border:1.5px solid #ffffff1a;border-radius:.75rem;align-items:center;gap:.4rem;padding:.45rem .55rem;transition:background .15s;display:flex;position:relative}.country-btn:active{transform:scale(.96)}.country-selected{border-color:#c77dff;background:#c77dff33!important}.country-disabled{opacity:.35;cursor:default}.country-rank{color:#fff;background:#c77dff;border-radius:999px;justify-content:center;align-items:center;width:1.05rem;height:1.05rem;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:3px;right:5px}.country-flag{flex-shrink:0;font-size:1.15rem}.country-name{font-size:.73rem;font-weight:600;line-height:1.2}.other-player{background:#ffffff0d;border-radius:.75rem;flex-direction:column;gap:.35rem;padding:.6rem .75rem;display:flex}.other-name{color:#c77dff;margin:0;font-size:.85rem;font-weight:700}.other-picks{flex-wrap:wrap;gap:.3rem;display:flex}.other-pick{color:#ffffffa6;background:#ffffff0d;border-radius:.4rem;padding:.15rem .4rem;font-size:.72rem}.section-title{color:#fff9;text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.8rem;font-weight:700}.pick-points{border-radius:999px;margin-right:.25rem;padding:.1rem .45rem;font-size:.75rem;font-weight:700}.pick-points-high{color:#00e676;background:#00e67633}.pick-points-mid{color:#c77dff;background:#c77dff33}.pick-points-low{color:#f99;background:#ff646426}.btn-submit-results{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00e676,#00bfa5);border:none;border-radius:.75rem;width:100%;padding:.85rem;font-size:.95rem;font-weight:700}.btn-submit-results:disabled{opacity:.45;cursor:default}.official-entry-list{flex-direction:column;gap:.3rem;margin-bottom:.5rem;display:flex}.official-entry-row{background:#00e67614;border:1px solid #00e67633;border-radius:.6rem;align-items:center;gap:.5rem;padding:.35rem .65rem;display:flex}.official-entry-pos{color:#fff6;width:1.4rem;font-size:.75rem}.official-entry-flag{font-size:1.1rem}.official-entry-name{color:#fff;flex:1;font-size:.85rem;font-weight:600}.official-entry-remove{color:#ff8080;cursor:pointer;background:#ff505026;border:1px solid #ff50504d;border-radius:.4rem;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;padding:0;font-size:1rem;display:flex}.official-results-ref{background:#ffffff0a;border-radius:.75rem;margin-top:1rem;padding:.75rem}.official-row{border-bottom:1px solid #ffffff0d;align-items:center;gap:.5rem;padding:.25rem 0;display:flex}.official-row:last-child{border-bottom:none}.official-pos{color:#fff6;width:1.6rem;font-size:.78rem}.official-flag{font-size:1.1rem}.official-name{color:#ffffffd9;font-size:.85rem;font-weight:600}.final-scoreboard{flex-direction:column;gap:.4rem;display:flex}.final-row{background:#ffffff0f;border-radius:.75rem;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.6rem .75rem;display:flex}.final-row-me{background:#c77dff26;border:1px solid #c77dff4d}.final-row-first{background:#ffd7001f;border:1px solid #ffd7004d}.final-rank{flex-shrink:0;min-width:2rem;font-size:1rem}.final-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.9rem;font-weight:700;overflow:hidden}.final-scores{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.final-score-pill{white-space:nowrap;border-radius:999px;padding:.1rem .4rem;font-size:.65rem;font-weight:600}.final-score-pred{color:#c77dff;background:#c77dff33}.final-score-bingo{color:gold;background:#ffd7002e}.final-score-total{color:#fff;text-align:right;min-width:2.5rem;font-size:.95rem;font-weight:900}.btn-share{color:#c77dff;background:#c77dff26;border:1px solid #c77dff4d;margin-top:.75rem}.sf-correct-count{text-align:center;color:#c77dff;margin:.25rem 0 .5rem;font-size:.95rem;font-weight:700}.ranking-page-title{color:#fff;text-align:center;margin:0 0 .5rem;padding:0;font-size:1.2rem;font-weight:700}.reveal-overlay{z-index:300;-webkit-backdrop-filter:blur(12px);cursor:pointer;background:#0a021af5;justify-content:center;align-items:center;animation:.4s revealFadeIn;display:flex;position:fixed;inset:0}@keyframes revealFadeIn{0%{opacity:0}to{opacity:1}}.reveal-card{text-align:center;width:90%;max-width:340px;padding:2.5rem 2rem;animation:.5s cubic-bezier(.34,1.56,.64,1) revealCardPop}@keyframes revealCardPop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.reveal-position{letter-spacing:.12em;text-transform:uppercase;color:#c77dff;margin:0 0 1rem;font-size:.9rem;font-weight:700}.reveal-medal{filter:drop-shadow(0 0 24px #ffd70080);margin-bottom:1rem;font-size:5.5rem;line-height:1;animation:.6s cubic-bezier(.34,1.56,.64,1) .3s both revealMedalBounce}.reveal-card-step-2 .reveal-medal{filter:drop-shadow(0 0 40px #ffd700cc)}@keyframes revealMedalBounce{0%{opacity:0;transform:scale(0)rotate(-15deg)}to{opacity:1;transform:scale(1)rotate(0)}}.reveal-name{color:#fff;text-shadow:0 0 20px #c77dff99;margin:0 0 .25rem;font-size:2rem;font-weight:900}.reveal-card-step-2 .reveal-name{color:gold;text-shadow:0 0 30px #ffd700b3}.reveal-me{color:#c77dff;margin-top:.2rem;font-size:1rem;font-weight:600;display:block}.reveal-scores{flex-wrap:wrap;justify-content:center;gap:.5rem;margin:.75rem 0 .5rem;display:flex}.reveal-score-pill{color:#ffffffbf;background:#ffffff1a;border-radius:999px;padding:.3rem .75rem;font-size:.82rem}.reveal-total{color:gold;letter-spacing:.03em;margin:.25rem 0 1.5rem;font-size:2.2rem;font-weight:900}.reveal-tap-hint{color:#ffffff40;letter-spacing:.1em;text-transform:uppercase;margin:0;font-size:.8rem}.next-event-hint{text-align:center;color:#ffffffa6;background:#c77dff14;border:1px solid #c77dff33;border-radius:.75rem;margin-top:.5rem;padding:.65rem 1rem;font-size:.88rem;font-weight:600}.legal-page{background:linear-gradient(135deg,#1a0533 0%,#2d0a5e 50%,#1a0533 100%);flex-direction:column;min-height:100dvh;display:flex}.legal-content{color:#ffffffd9;width:100%;max-width:680px;margin:0 auto;padding:1.25rem 1rem 3rem;font-size:.88rem;line-height:1.65}.legal-content h1{color:#c77dff;margin:1.5rem 0 .5rem;font-size:1.3rem;font-weight:900}.legal-content h1:first-child{margin-top:0}.legal-content h2{color:#fff;margin:1rem 0 .25rem;font-size:.95rem;font-weight:700}.legal-content p{color:#ffffffbf;margin:0 0 .5rem}.legal-content strong{color:#fff}.legal-content hr{border:none;border-top:1px solid #ffffff1a;margin:2rem 0}.legal-date{font-size:.75rem;color:#fff6!important;margin-bottom:1rem!important}.chat-fab{color:#fff;cursor:pointer;z-index:100;background:linear-gradient(135deg,#c77dff,#e040fb);border:none;border-radius:50%;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;font-size:1.4rem;transition:transform .15s;display:flex;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 4px 20px #c77dff80}.chat-fab:active{transform:scale(.92)}.chat-fab-unread{animation:1.5s infinite chatPulse}.chat-badge{color:#fff;background:#f44;border-radius:999px;justify-content:center;align-items:center;min-width:1.1rem;height:1.1rem;padding:0 3px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.chat-panel{z-index:99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#140432f7;border:1px solid #c77dff4d;border-radius:1.25rem;flex-direction:column;width:min(340px,100vw - 2rem);max-height:55dvh;display:flex;position:fixed;bottom:5.5rem;right:1rem;box-shadow:0 8px 40px #00000080}.chat-header{color:#c77dff;border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;padding:.65rem 1rem;font-size:.85rem;font-weight:700;display:flex}.chat-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:.9rem;line-height:1}.chat-messages{flex-direction:column;flex:1;gap:.35rem;padding:.6rem .75rem;display:flex;overflow-y:auto}.chat-empty{color:#ffffff4d;text-align:center;margin:1rem 0;font-size:.8rem}.chat-msg{flex-direction:column;align-self:flex-start;max-width:85%;display:flex}.chat-msg-mine{align-self:flex-end;align-items:flex-end}.chat-sender{color:#c77dff;margin-bottom:.1rem;padding:0 .4rem;font-size:.65rem;font-weight:700}.chat-text{color:#fff;word-break:break-word;background:#ffffff1a;border-radius:1rem;padding:.35rem .65rem;font-size:.82rem;line-height:1.4}.chat-msg-mine .chat-text{background:linear-gradient(135deg,#c77dff59,#e040fb59);border-radius:1rem 1rem .25rem}.chat-msg:not(.chat-msg-mine) .chat-text{border-radius:1rem 1rem 1rem .25rem}.chat-input-row{border-top:1px solid #ffffff14;flex-shrink:0;gap:.4rem;padding:.6rem .75rem;display:flex}.chat-input{color:#fff;background:#ffffff14;border:1px solid #ffffff26;border-radius:.75rem;outline:none;flex:1;padding:.5rem .75rem;font-size:.85rem}.chat-input:focus{border-color:#c77dff}.chat-input::placeholder{color:#ffffff4d}.chat-send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c77dff,#e040fb);border:none;border-radius:.75rem;padding:.5rem .75rem;font-size:.9rem}.chat-send:disabled{opacity:.4;cursor:default}@keyframes chatPulse{0%,to{box-shadow:0 4px 20px #c77dff80}50%{box-shadow:0 4px 30px #c77dffe6}}.reveal-overlay-global{z-index:500;cursor:pointer;background:#050014f5;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0;overflow:hidden}.reveal-spotlight{pointer-events:none;background:radial-gradient(at top,#c77dff2e 0%,#0000 70%);width:120%;height:90%;position:absolute;top:-40%;left:50%;transform:translate(-50%)}.reveal-stage{cursor:default;flex-direction:column;justify-content:flex-end;align-items:center;gap:1rem;width:100%;max-width:480px;min-height:100dvh;padding:1rem 1rem 2.5rem;display:flex;position:relative}.reveal-header{flex-direction:column;align-items:center;gap:.4rem;margin-bottom:.5rem;animation:.7s cubic-bezier(.34,1.56,.64,1) both reveal-drop-in;display:flex}.reveal-header-icon{font-size:2.5rem;line-height:1}.reveal-header-text{color:#f0c0ff;letter-spacing:.04em;text-align:center;text-shadow:0 0 30px #c77dff99;font-size:2rem;font-weight:900}.reveal-header-small .reveal-header-text{font-size:1.2rem}.reveal-header-small .reveal-header-icon{font-size:1.5rem}.reveal-loading-hint{color:#ffffff73;margin-top:.25rem;font-size:.85rem;animation:1.2s ease-in-out infinite pulse}.podium-stage{justify-content:center;align-items:flex-end;gap:.5rem;width:100%;max-width:380px;display:flex;position:relative}.podium-slot{opacity:0;flex-direction:column;align-items:center;transition:transform .7s cubic-bezier(.34,1.46,.64,1),opacity .4s;display:flex;transform:translateY(120%)}.podium-slot-in{opacity:1;transform:translateY(0)}.podium-avatar{background:#ffffff0f;border:2px solid #c77dff4d;border-radius:50%;flex-shrink:0;width:64px;height:64px;margin-bottom:.3rem;position:relative;overflow:hidden}.podium-avatar img{object-fit:cover;width:100%;height:100%}.podium-avatar-1{border-color:gold;width:88px;height:88px;box-shadow:0 0 24px #ffd7008c,0 0 60px #ffd70033}.podium-avatar-2{border-color:silver;box-shadow:0 0 12px #c0c0c066}.podium-avatar-3{border-color:#cd7f32;box-shadow:0 0 12px #cd7f324d}.podium-avatar-me{border-width:3px;border-color:#c77dff!important;box-shadow:0 0 18px #c77dff99!important}.podium-initial{color:#c77dff;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.5rem;font-weight:800;display:flex}.podium-you-tag{color:#fff;white-space:nowrap;background:#c77dff;border-radius:4px;padding:1px 5px;font-size:.5rem;font-weight:800;position:absolute;bottom:-.2rem;left:50%;transform:translate(-50%)}.podium-block{border-radius:.75rem .75rem .25rem .25rem;flex-direction:column;justify-content:flex-start;align-items:center;width:100px;padding:.6rem .5rem .4rem;display:flex}.podium-block-1{background:linear-gradient(#ffd70040 0%,#ffd70014 100%);border:1px solid #ffd70080;width:110px;height:130px;box-shadow:0 0 30px #ffd70033,inset 0 1px #ffd7004d}.podium-block-2{background:linear-gradient(#c0c0c02e 0%,#c0c0c00d 100%);border:1px solid #c0c0c059;height:95px}.podium-block-3{background:linear-gradient(#cd7f3226 0%,#cd7f320a 100%);border:1px solid #cd7f324d;height:65px}.podium-medal{margin-bottom:.1rem;font-size:1.1rem;line-height:1}.podium-block-1 .podium-medal{font-size:1.4rem}.podium-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;text-align:center;max-width:90px;font-size:.7rem;font-weight:700;overflow:hidden}.podium-block-1 .podium-name{color:gold;font-size:.82rem}.podium-total{color:#fff;margin-top:.1rem;font-size:1.1rem;font-weight:900}.podium-block-1 .podium-total{color:gold;text-shadow:0 0 12px #ffd70080;font-size:1.35rem}.podium-breakdown{gap:.3rem;margin-top:.15rem;display:flex}.podium-breakdown span{color:#ffffff80;font-size:.52rem}.podium-block-1 .podium-breakdown span{color:#ffd70099}.confetti-burst{pointer-events:none;width:0;height:0;position:absolute;bottom:100%;left:50%}.confetti-piece{width:var(--s,6px);height:var(--s,6px);background:var(--c,gold);animation:confetti-fly 2s var(--d,0s) ease-out forwards;border-radius:2px;position:absolute}@keyframes confetti-fly{0%{opacity:1;transform:translate(-50%,-50%)scale(1)rotate(0)}70%{opacity:1}to{transform:translate(calc(-50% + var(--tx,0px)), calc(-50% + var(--ty,-80px))) scale(0) rotate(600deg);opacity:0}}.reveal-rest{flex-direction:column;gap:.2rem;width:100%;max-width:320px;animation:.5s .1s both reveal-drop-in;display:flex}.reveal-rest-row{color:#ffffffb3;background:#ffffff0a;border-radius:.5rem;align-items:center;gap:.5rem;padding:.35rem .75rem;font-size:.8rem;display:flex}.reveal-rest-me{color:#c77dff;font-weight:700}.rest-rank{width:2rem}.rest-name{flex:1}.rest-total{font-weight:700}.reveal-actions{flex-direction:column;gap:.5rem;width:100%;max-width:320px;animation:.5s .15s both reveal-drop-in;display:flex}.btn-reveal-scores{color:#fff;cursor:pointer;letter-spacing:.02em;background:linear-gradient(135deg,#c77dff,#e040fb);border:none;border-radius:.9rem;padding:.85rem;font-size:1rem;font-weight:800}.btn-reveal-close{color:#fff6;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:.75rem;padding:.5rem;font-size:.85rem}.reveal-tap-skip{color:#ffffff40;text-align:center;margin-top:.25rem;font-size:.72rem;animation:2s ease-in-out infinite pulse}@keyframes reveal-drop-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-box{background:linear-gradient(160deg,#1e0545,#2d0a5e);border:1px solid #c77dff40;border-radius:1.5rem 1.5rem 0 0;flex-direction:column;gap:1rem;width:100%;max-width:480px;max-height:88dvh;padding:1.5rem 1.5rem 2rem;display:flex;overflow-y:auto}.modal-title{color:#f0c0ff;text-align:center;margin:0;font-size:1.15rem;font-weight:800}.modal-body{color:#fffc;margin:0;font-size:.88rem;line-height:1.55}.modal-close-btn{color:#fff;background:linear-gradient(135deg,#c77dff,#e040fb);margin-top:.5rem}.modal-cancel-btn{text-align:center;color:#fff6;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:.85rem}.btn-link{cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}
