*,: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}.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}.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}.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}}.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}.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}.bingo-wrap{background:linear-gradient(135deg,#1a0533 0%,#2d0a5e 50%,#1a0533 100%);flex-direction:column;gap:1rem;min-height:100dvh;padding:1rem;display:flex}.country-bar{gap:.5rem;display:flex}.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}.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}.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%{opacity:1;transform:scale(1)}to{opacity:.8;transform:scale(1.02)}}.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}.btn-ranking-game{color:gold;cursor:pointer;background:#ffd7001a;border:1px solid #ffd7004d;border-radius:.75rem;width:100%;margin-top:auto;padding:.65rem;font-size:.85rem;font-weight:700}.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}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background:#ffffff0a}to{background:#ffffff1a}}.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}.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}.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}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}
