@font-face{font-family:DM Sans Variable;font-style:normal;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-ext-wght-normal-BOFOeGcA.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans Variable;font-style:normal;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-wght-normal-Xz1IZZA0.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Variable;font-style:italic;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-ext-wght-italic-DUE6_iCb.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans Variable;font-style:italic;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-wght-italic-Cz4n9dED.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/outfit-latin-ext-wght-normal-DdQaqQDo.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/outfit-latin-wght-normal-Bc-8i84L.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--font-body: "DM Sans Variable", "DM Sans", system-ui, -apple-system, sans-serif;--font-display: "Outfit Variable", "Outfit", system-ui, -apple-system, sans-serif;--font-mono: "Courier New", Courier, monospace}*{box-sizing:border-box;margin:0;padding:0;font-family:var(--font-body)}.route-fallback{display:flex;align-items:center;justify-content:center;min-height:50vh;width:100%}.route-fallback__spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#fbbf24;border-radius:50%;animation:route-fallback-spin .9s linear infinite}@keyframes route-fallback-spin{to{transform:rotate(360deg)}}body{font-family:var(--font-body);background:linear-gradient(135deg,#1f0022,#430c4b,#1f0022);background-attachment:fixed;background-repeat:no-repeat;background-size:cover;min-height:100%;color:#fff}html{height:100%}.container{max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:3rem}.logo{padding:0 48px;font-family:var(--font-display);font-size:3.2rem;font-weight:700;margin-bottom:.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1px;position:relative;overflow:visible}.tagline{font-size:1.2rem;opacity:.9;margin-bottom:2rem}.stats{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem}.stat{text-align:center}.stat-number{font-size:2.2rem;font-weight:900;color:#fbbf24;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1px}.stat-label{font-size:.9rem;opacity:.8}.games-section{margin-top:3rem}.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:3rem}.game-card{display:flex;flex-direction:column;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;border:2px solid rgba(255,255,255,.3);transition:all .3s ease;position:relative;overflow:hidden;border-color:#b6870d}.game-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#38003c99,#04f5ff1a);z-index:-1}.game-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0000004d;border-color:#fbbf24}.game-card{background:linear-gradient(135deg,#4c1d95,#553c9a);color:#fff}.game-card:hover{background:linear-gradient(135deg,#553c9a,#6b21a8);box-shadow:0 20px 40px #553c9a66;transform:translateY(-5px)}.game-icon{font-size:3rem;margin-bottom:1.25rem}.game-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin-bottom:.75rem;letter-spacing:.3px;color:#ecf0f1}.game-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.9rem;margin-top:auto}.hamburger-game-stats{padding:0 2px 0 0;display:flex;justify-content:space-between}.player-count{font-size:.8rem;color:#f39c12;margin-bottom:.15em}.game-help-btn{position:absolute;top:1.25rem;right:1.25rem;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;font-size:1.25rem;color:#fbbf24;text-decoration:none;background:transparent;opacity:.75;transition:background-color .18s ease,opacity .18s ease,color .18s ease}.game-help-btn:hover,.game-help-btn:focus-visible{opacity:1;color:#fde68a;background:#ffffff1a;outline:none}.play-buttons{display:flex;gap:1rem}.btn{flex:1;padding:.75rem 1.5rem;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem;letter-spacing:.3px;font-family:var(--font-body)}.btn-primary{background:linear-gradient(45deg,#059669,#1e40af);color:#fff;border:2px solid #fbbf24}.btn-primary:hover{background:linear-gradient(45deg,#047857,#1e3a8a);transform:translateY(-2px)}.btn-ready{background:linear-gradient(45deg,#2ecc71,#27ae60);color:#fff;border:2px solid #2ecc71;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-ready:hover{background:linear-gradient(45deg,#27ae60,#229954);transform:translateY(-2px)}.btn-not-ready{background:linear-gradient(45deg,#6c757d,#495057);color:#fff;border:2px solid #6c757d;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-not-ready:hover{background:linear-gradient(45deg,#495057,#343a40);transform:translateY(-2px)}.ready-icon{font-size:1rem;color:#fff}.btn-secondary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#1f2937;border:1px solid #fbbf24}.btn-secondary:hover{background:linear-gradient(135deg,#d97706,#f59e0b);transform:translateY(-2px);box-shadow:0 8px 16px #fbbf244d}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000}.modal-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#1e40af,#059669);padding:2rem;border-radius:20px;border:2px solid #fbbf24;max-width:500px;width:90%}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-title{font-size:1.5rem;font-weight:700;margin-bottom:12px}.close-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;opacity:.7}.close-btn:hover{opacity:1}.lobby-options{display:flex;flex-direction:column;gap:1rem}.option-group{display:flex;justify-content:space-between;align-items:center}.option-label{font-weight:600}.option-input{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.5rem;color:#fff;width:120px}.option-input::placeholder{color:#fff9}.matchmaking-status{text-align:center;padding:2rem}.time-in-queue{margin:1rem 0;font-size:1rem;color:#bdc3c7;font-weight:500}.time-display{color:#fbbf24;font-weight:700;font-size:1.1rem}.spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.3);border-top:3px solid #fbbf24;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.cancel-btn{background:#ef4444;color:#fff;border:none;padding:.75rem 2rem;border-radius:12px;font-weight:600;cursor:pointer;margin-top:1rem}.cancel-btn:hover{background:#dc2626}.lobby-container{margin:0 auto;padding:2rem}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1rem;max-width:480px;margin:3rem auto 0;padding:2.5rem 2rem;border-radius:24px;background:#1f00228c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.12);box-shadow:0 20px 50px #00000059;animation:stateFadeIn .4s ease}@keyframes stateFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.loading-state h2{font-size:1.6rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.loading-state p{opacity:.8}.loading-spinner{font-size:2.5rem;animation:spinnerBounce 1.1s ease-in-out infinite}@keyframes spinnerBounce{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(180deg)}}.error-state{border-color:#ef444473;box-shadow:0 20px 50px #00000059,0 0 30px #ef444426}.error-state__icon{display:flex;align-items:center;justify-content:center;width:84px;height:84px;border-radius:50%;font-size:2.4rem;color:#fca5a5;background:radial-gradient(circle at 50% 40%,#ef444459,#ef444414);border:2px solid rgba(239,68,68,.5);animation:errorPulse 2s ease-in-out infinite}@keyframes errorPulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 12px #ef444400}}.error-state__title{font-size:1.7rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:.5px}.error-state__message{font-size:1.05rem;line-height:1.6;color:#ffffffd9;max-width:380px}.error-state__btn{flex:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.75rem;padding:.85rem 2rem}.lobby-header{text-align:center;margin-bottom:2rem}.lobby-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1px}.lobby-id-section{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.lobby-id-label{font-size:1.1rem;color:#bdc3c7;font-weight:600}.lobby-id-container{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.3);cursor:pointer}.lobby-id{font-family:var(--font-mono);font-size:1.2rem;font-weight:700;color:#fbbf24;letter-spacing:2px}.copy-btn{background:transparent;border:none;color:#fbbf24;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.copy-btn:hover{background:#fbbf2433;transform:scale(1.1)}.lobby-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.lobby-content--link-up{display:flex;flex-direction:column;gap:2rem}.lobby-content--link-up .players-section,.lobby-content--link-up .game-settings-section{width:100%}.players-section,.game-settings-section{background:linear-gradient(135deg,#553c9a,#6b21a8);border-radius:20px;padding:1.5rem;border:2px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.section-title{display:flex;gap:.75rem;align-items:center;font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin-bottom:1rem;color:#ecf0f1;margin-bottom:2rem;letter-spacing:.5px;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.settings-icon{color:#fbbf24}.players-list{display:flex;flex-direction:column;gap:.75rem}.player-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:12px;transition:all .2s ease}.player-item.ready{background:#2ecc7133;border:1px solid rgba(46,204,113,.5)}.player-item.not-ready{background:#e74c3c33;border:1px solid rgba(231,76,60,.5)}.player-item.empty-slot{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);opacity:.6}.player-info{display:flex;align-items:center;gap:.75rem}.player-icon{color:#bdc3c7;font-size:1.1rem}.player-name{color:#ecf0f1;font-weight:500;display:flex;align-items:center;gap:.5rem}.host-badge{background:#fbbf24;color:#1f2937;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase}.player-status{font-size:.9rem;font-weight:600}.ready-status{color:#2ecc71}.not-ready-status{color:#e74c3c}.waiting-status{color:#95a5a6}.host-status{color:#fbbf24;font-weight:600}.settings-grid{display:flex;flex-direction:column;gap:1rem}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffff1a;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.setting-item label{color:#bdc3c7;font-weight:500}.setting-value{color:#fbbf24;font-weight:700;font-family:var(--font-mono)}.setting-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.5rem;color:#ecf0f1;font-size:.8rem;font-weight:500;min-width:120px;cursor:pointer;transition:all .2s ease}.setting-select:focus{outline:none;border-color:#fbbf24;box-shadow:0 0 0 2px #fbbf2433}.setting-select:disabled{opacity:.5;cursor:not-allowed;background:#ffffff0d}.setting-select option{background:#2c3e50;color:#ecf0f1;padding:.5rem}.header-image{width:64px;margin-bottom:12px}.lobby-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.lobby-actions .btn{display:flex;align-items:center;justify-content:center;gap:.5rem}.start-icon{flex-shrink:0}.btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}@media(max-width:768px){.container{padding:1rem}.games-grid{grid-template-columns:1fr}.stats{flex-direction:column;gap:1rem}.logo{font-size:2rem}.lobby-container{padding:1rem}.lobby-content{grid-template-columns:1fr;gap:1.5rem}.lobby-actions{flex-direction:column}.lobby-actions .btn{width:100%}.lobby-id-section{flex-direction:column;gap:.5rem}}.matchmaking-screen{display:flex;justify-content:center;align-items:center;min-height:60vh}.matchmaking-card{background:linear-gradient(135deg,#1e40af,#059669);padding:2.5rem;border-radius:20px;border:2px solid #fbbf24;max-width:420px;width:100%;text-align:center}.matchmaking-title{font-size:1.6rem;font-weight:700;margin-bottom:.5rem}.matchmaking-game-label{color:#bdc3c7;margin-bottom:.25rem}.match-found-card{animation:matchFoundPop .4s ease-out}@keyframes matchFoundPop{0%{transform:scale(.85);opacity:0}60%{transform:scale(1.03)}to{transform:scale(1);opacity:1}}.match-found-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.match-found-title{font-size:1.8rem;font-weight:800;color:#fbbf24;text-shadow:0 0 20px rgba(251,191,36,.4);animation:matchPulse 1.5s ease-in-out infinite}@keyframes matchPulse{0%,to{text-shadow:0 0 20px rgba(251,191,36,.4)}50%{text-shadow:0 0 30px rgba(251,191,36,.7)}}.match-found-opponent{display:flex;flex-direction:column;align-items:center;gap:.5rem}.opponent-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#553c9a,#6b21a8);border:3px solid #fbbf24;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:#fff}.opponent-name{font-size:1.1rem;font-weight:600;color:#ecf0f1}.accept-countdown-container{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center}.countdown-ring{position:absolute;width:100%;height:100%}.countdown-ring-bg{stroke:#ffffff26}.countdown-ring-progress{stroke:#fbbf24;transition:stroke-dashoffset 1s linear}.countdown-number{font-size:2rem;font-weight:800;color:#fbbf24;z-index:1}.match-found-actions{display:flex;gap:1rem;width:100%}.btn-accept{flex:2;padding:.85rem 1.5rem;background:linear-gradient(45deg,#059669,#10b981);color:#fff;border:2px solid #34d399;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:var(--font-body)}.btn-accept:hover{background:linear-gradient(45deg,#047857,#059669);transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-decline{flex:1;padding:.85rem 1rem;background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.4);border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:var(--font-body)}.btn-decline:hover{background:#ef444459;color:#fff}.waiting-opponent-text{color:#bdc3c7;font-size:1rem;animation:waitingDots 1.5s steps(3) infinite}.game-starting-card{animation:matchFoundPop .3s ease-out}.game-starting-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.game-starting-title{font-size:2rem;font-weight:800;color:#fbbf24}.game-starting-game{font-size:1.1rem;color:#ecf0f1}.game-starting-pulse{width:16px;height:16px;border-radius:50%;background:#fbbf24;animation:startPulse .8s ease-in-out infinite}@keyframes startPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.4}}.matchmaking-notification{position:fixed;top:1rem;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#1e40af,#059669);border:1px solid #fbbf24;border-radius:12px;padding:.75rem 1.5rem;color:#fff;font-weight:600;font-size:.95rem;z-index:2000;cursor:pointer;animation:notifSlideIn .3s ease-out;max-width:90%;text-align:center}@keyframes notifSlideIn{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.matchmaking-error{text-align:center;padding:2rem;color:#fca5a5}.matchmaking-error p{margin-bottom:1rem;font-size:1.1rem}.mm-disconnect-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:3000;animation:overlayFadeIn .3s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.mm-disconnect-card{background:linear-gradient(135deg,#4c1d95,#1e40af);border:2px solid #fbbf24;border-radius:20px;padding:2.5rem;max-width:400px;width:90%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;animation:matchFoundPop .3s ease-out}.mm-disconnect-icon{width:56px;height:56px;border-radius:50%;background:#ef444440;border:2px solid #ef4444;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:800;color:#ef4444}.mm-disconnect-title{font-size:1.4rem;font-weight:700;color:#fbbf24}.mm-disconnect-message{color:#bdc3c7;font-size:1rem}.mm-disconnect-countdown{color:#fbbf24;font-weight:600;font-size:.95rem}.mm-disconnect-actions{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.mm-disconnect-actions .btn{width:100%}.btn-danger{background:linear-gradient(45deg,#ef4444,#dc2626);color:#fff;border:1px solid #ef4444}.btn-danger:hover{background:linear-gradient(45deg,#dc2626,#b91c1c);transform:translateY(-2px)}@media(max-width:768px){.matchmaking-card{padding:1.5rem;margin:0 1rem}.match-found-actions{flex-direction:column}.btn-accept,.btn-decline{flex:unset;width:100%}}.football-icon{display:inline-block;position:relative;font-size:inherit;animation:tiki-taka-movement 10s linear infinite}@keyframes tiki-taka-movement{0%,80%{transform:translate(0) rotate(0)}83%{transform:translate(15px,-15px) rotate(60deg)}86%{transform:translate(-25px,-25px) rotate(120deg)}89%{transform:translate(15px,-35px) rotate(180deg)}93%{transform:translate(-30px,-10px) rotate(240deg)}97%{transform:translate(25px,10px) rotate(300deg)}to{transform:translate(0) rotate(360deg)}}:root{--site-header-height: 84px}.site-header{position:fixed;top:0;left:0;right:0;height:84px;background:linear-gradient(135deg,#1f0022f2,#430c4bf2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);z-index:1000;display:flex;align-items:center}.header-content{display:flex;align-items:center;width:100%;padding:0 16px}.game-sticky-hud-sentinel{height:1px;margin-bottom:-1px;width:100%;pointer-events:none;visibility:hidden}.game-sticky-hud{position:sticky;top:var(--site-header-height);z-index:900;border-radius:12px;isolation:isolate}.game-sticky-hud:before{content:"";position:absolute;inset:-6px -10px;border-radius:inherit;z-index:-1;opacity:0;pointer-events:none;background:linear-gradient(135deg,#1f0022,#430c4b);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 20px #00000059;transition:opacity .18s ease}.game-sticky-hud.is-stuck:before{opacity:1}.football-holdem-sticky-hud{display:flex;flex-direction:column;gap:.3rem}.football-holdem-sticky-hud .football-holdem-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.25rem .55rem;text-align:center}.football-holdem-sticky-hud .football-holdem-title{font-size:1rem;line-height:1.15;font-weight:800}.football-holdem-sticky-hud .football-holdem-phase-hint{margin:0;font-size:.78rem}.football-holdem-sticky-hud .football-holdem-round-info{margin-top:0;gap:.4rem}.football-holdem-sticky-hud .football-holdem-turn-counter{font-size:.82rem}.football-holdem-sticky-hud .football-holdem-tiebreak-badge{font-size:.68rem;padding:.12rem .45rem}.football-holdem-sticky-hud .football-holdem-timer{padding:.12rem .45rem;font-size:.78rem}.football-holdem-timer-slot{display:inline-flex;align-items:center;justify-content:center;min-width:2.75rem;min-height:1.45rem;flex-shrink:0}.football-holdem-sticky-hud .football-holdem-timer-slot{min-height:1.35rem}.football-holdem-sticky-hud .football-holdem-category-banner{padding:.32rem .55rem;gap:.3rem .45rem;border-radius:10px;box-shadow:0 2px 8px #4c1d9540}.football-holdem-sticky-hud .football-holdem-category-label{font-size:.58rem;letter-spacing:.06em}.football-holdem-sticky-hud .football-holdem-category-name{font-size:.92rem}.football-holdem-sticky-hud .football-holdem-category-kind{font-size:.62rem;padding:.1rem .4rem}.football-holdem-sticky-hud .football-holdem-lowball-badge,.football-holdem-sticky-hud .football-holdem-waitandsee-badge{margin-left:0;font-size:.62rem;padding:.1rem .4rem}.football-holdem-sticky-hud .football-holdem-joker-notice,.football-holdem-sticky-hud .football-holdem-scan-hint{font-size:.78rem;margin:0}.football-holdem-sticky-hud .football-holdem-joker-bar{margin-bottom:0;padding:.3rem .45rem;gap:.25rem .4rem;border-radius:10px}.football-holdem-sticky-hud .football-holdem-joker-bar-label{font-size:.62rem;letter-spacing:.08em;margin-right:.1rem}.football-holdem-sticky-hud .football-holdem-joker-btn{padding:.22rem .45rem;font-size:.7rem;gap:.25rem}.football-holdem-sticky-hud .football-holdem-joker-uses{min-width:1rem;height:1rem;font-size:.62rem}.football-holdem-fit{display:flex;flex-direction:column;gap:.25rem}.football-holdem-table-scaler{width:100%;overflow:visible}.football-holdem-page.container{padding:.5rem .75rem 1rem}.football-holdem-page .game-container{padding:.5rem .5rem 0}.header-menu-btn{background:transparent;border:1px solid transparent;border-radius:8px;width:44px;height:44px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .3s ease}.header-menu-btn:hover,.header-menu-btn.open{background:#58187dcc;border-color:#58187d80}.header-menu-btn .menu-icon{font-size:1.2rem;color:#fff;transition:all .3s ease}.header-logo{display:flex;align-items:center;gap:10px;margin-left:20px;cursor:pointer;transition:opacity .2s ease}.header-logo:hover{opacity:.85}.logo-text{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.5px}.header-spacer{flex:1;display:flex;justify-content:flex-end;align-items:center}.main-content{min-height:100vh}.main-content.with-header{padding-top:84px}.menu-overlay{position:fixed;inset:84px 0 0;background:#00000080;z-index:999;opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{to{opacity:1}}.slide-menu{position:fixed;top:84px;left:-400px;width:400px;height:calc(100vh - 60px);background:linear-gradient(135deg,#1f0022,#430c4b,#1f0022);z-index:1001;transition:left .3s ease;box-shadow:4px 0 20px #0000004d;overflow-y:auto}.slide-menu.open{left:0}.slide-menu-content{padding:16px}.games-list{display:flex;flex-direction:column;gap:16px}.menu-game-item{position:relative;background:linear-gradient(135deg,#553c9a,#6b21a8);border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.3);transition:all .2s ease}.menu-game-item .game-details{padding-right:32px}.menu-game-item .game-help-btn{top:10px;right:10px;width:32px;height:32px;font-size:1.05rem}.menu-game-item:hover{background:linear-gradient(135deg,#4c1d95,#553c9a);transform:translateY(-2px);box-shadow:0 4px 12px #553c9a66}.game-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}.game-title-big{display:flex;justify-content:center;align-items:center;margin-bottom:1.5rem;font-family:var(--font-display)}.game-info{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.game-info-ingame-container{display:flex;flex-direction:column;align-items:center;gap:12px}.game-info-top{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;gap:12px}.game-info-bottom{display:flex;justify-content:center;align-items:center;width:100%;gap:1.5rem}.game-icon{font-size:1.5rem;color:#ecf0f1;margin-top:4px}.game-details{flex:1}.game-title{margin:0 0 4px;font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:#ecf0f1}.game-description{margin:0 0 2rem;font-size:.9rem;color:#bdc3c7;line-height:1.4}.players-online{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#2ecc71;font-weight:500}.game-actions{display:flex;gap:8px}.btn-sm{padding:10px 12px;font-size:.8rem;border-radius:6px;flex:1}.confirmation-overlay{position:fixed;inset:0;background:#000000b3;z-index:2000;display:flex;justify-content:center;align-items:center;animation:fadeIn .3s ease}.confirmation-dialog{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:90%;box-shadow:0 10px 30px #0000004d;animation:slideIn .3s ease}.confirmation-dialog h3{margin:0 0 16px;color:#2c3e50;font-size:1.3rem;text-align:center}.confirmation-dialog p{margin:0 0 24px;color:#6c757d;line-height:1.5;text-align:center}.confirmation-buttons{display:flex;gap:12px;justify-content:center}.btn-danger{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s ease}.btn-danger:hover{background:#c82333;transform:translateY(-1px)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:480px){:root{--site-header-height: 56px}.site-header{height:56px}.main-content.with-header{padding-top:56px}.slide-menu{top:56px;width:100vw;left:-100vw;height:calc(100vh - 56px)}.slide-menu.open{left:0}.menu-overlay{top:56px}.header-menu-btn{width:40px;height:40px}.logo-text{font-size:1.1rem}.game-actions{flex-direction:column}.btn-sm{width:100%}.confirmation-buttons{flex-direction:column}.confirmation-buttons .btn{width:100%}}@media(max-width:768px){.slide-menu{width:320px;left:-320px}}.landing-container{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1f0022,#430c4b,#1f0022);background-attachment:fixed;background-repeat:no-repeat;background-size:cover;padding:20px;color:#fff}.landing-content{background:linear-gradient(135deg,#4c1d95,#553c9a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:60px 40px;text-align:center;box-shadow:0 20px 40px #0000004d;max-width:500px;width:100%;border:2px solid rgba(255,255,255,.3);position:relative;overflow:hidden}.landing-content:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#38003c99,#04f5ff1a);z-index:-1}.landing-header{margin-bottom:40px}.landing-logo{font-size:3.2rem;font-weight:700;color:#fff;margin-bottom:15px;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1px;position:relative;overflow:visible}.landing-tagline{font-size:1.2rem;color:#fff;margin:0;font-weight:400;opacity:.9}.landing-form{margin-bottom:40px}.redirect-notice{display:flex;align-items:center;gap:10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 16px;margin-bottom:20px;color:#fff;font-size:.9rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.redirect-icon{font-size:1.1rem}.input-group{margin-bottom:30px}.input-label{display:block;font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:10px;opacity:.9}.username-input{width:100%;padding:15px 20px;font-size:1.1rem;border:2px solid rgba(255,255,255,.3);border-radius:12px;background:#ffffff1a;color:#fff;transition:all .3s ease;box-sizing:border-box;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.username-input:focus{outline:none;border-color:#fbbf24;box-shadow:0 0 0 3px #fbbf2433;transform:translateY(-2px);background:#ffffff26}.username-input::placeholder{color:#fff9;font-style:italic}.play-button{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f0022;border:none;padding:15px 40px;font-size:1.2rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;margin:0 auto;min-width:180px;box-shadow:0 8px 20px #fbbf244d;text-shadow:none;letter-spacing:.5px}.play-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 25px #fbbf2466;background:linear-gradient(135deg,#f59e0b,#d97706)}.play-button:active:not(:disabled){transform:translateY(-1px)}.play-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.play-button.loading{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.realtime-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:50vh;padding:2rem;text-align:center}.realtime-gate .loading-spinner{width:36px;height:36px;border-width:3px;border-top-width:3px}.realtime-gate-message{color:#ffffffbf;font-size:1rem}.play-icon{font-size:1.1rem}.landing-features{display:flex;flex-direction:column;gap:15px}.feature{display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;font-size:1rem;opacity:.9}.feature-icon{font-size:1.2rem}@media(max-width:768px){.landing-container{padding:15px}.landing-content{padding:40px 25px}.landing-logo{font-size:2.5rem}.landing-tagline{font-size:1.1rem}.username-input{padding:12px 15px;font-size:1rem}.play-button{padding:12px 30px;font-size:1.1rem;min-width:160px}.landing-features{gap:12px}.feature{font-size:.9rem}}@media(max-width:480px){.landing-content{padding:30px 20px}.landing-logo{font-size:2rem}.landing-tagline,.input-label{font-size:1rem}.username-input{padding:10px 12px;font-size:.95rem}.play-button{padding:10px 25px;font-size:1rem;min-width:140px}}.join-lobby-section{margin:2rem 0;display:flex;justify-content:center}.join-lobby-compact{display:flex;flex-direction:column;align-items:center;max-width:500px;width:100%}.join-lobby-form{display:flex;gap:12px;width:100%;align-items:center}.lobby-code-input{flex:1;padding:12px 16px;font-size:1rem;border:2px solid rgba(255,255,255,.3);border-radius:12px;background:#ffffff1a;color:#fff;transition:all .3s ease;box-sizing:border-box;text-align:left;font-weight:600;letter-spacing:1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lobby-code-input:focus{outline:none;border-color:#fbbf24;box-shadow:0 0 0 3px #fbbf2433;background:#ffffff26}.lobby-code-input::placeholder{color:#fff9;font-style:italic;letter-spacing:normal;font-weight:400}.lobby-code-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef444433}.error-message{color:#ef4444;font-size:.9rem;margin-top:.5rem;text-align:center;font-weight:500}.join-lobby-button{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f0022;border:none;padding:12px 20px;font-size:1rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:80px;height:48px;text-shadow:none;letter-spacing:.5px;box-shadow:0 4px 12px #fbbf244d;white-space:nowrap}.join-lobby-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2466;background:linear-gradient(135deg,#f59e0b,#d97706)}.join-lobby-button:active:not(:disabled){transform:translateY(-1px)}.join-lobby-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.join-lobby-button.loading{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}@media(max-width:768px){.join-lobby-section{margin:1.5rem 0}.join-lobby-compact{max-width:100%}.join-lobby-form{gap:8px}.lobby-code-input{padding:10px 12px;font-size:.95rem}.join-lobby-button{padding:10px 16px;font-size:.95rem;min-width:70px;height:44px}}.player-item.current-user{background:linear-gradient(135deg,#3b82f61a,#2563eb1a);border:1px solid rgba(59,130,246,.3);box-shadow:0 2px 8px #3b82f626}.player-item.current-user .player-icon.current-user-icon{color:#3b82f6;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.you-icon{color:#3b82f6;font-size:1rem;margin-left:6px;vertical-align:middle}.player-item.current-user.ready{background:linear-gradient(135deg,#22c55e1a,#16a34a1a);border:1px solid rgba(34,197,94,.3);box-shadow:0 2px 8px #22c55e26}.player-item.current-user.ready .player-icon.current-user-icon{color:#22c55e;background:linear-gradient(135deg,#22c55e,#16a34a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.player-item.current-user.ready .you-icon{color:#22c55e}.ttt-draw-section{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:1.25rem;margin-bottom:1rem;padding:0 1rem}.ttt-draw-row{display:flex;align-items:stretch;justify-content:center;gap:.75rem}.ttt-draw-button{min-width:180px;flex:0 1 auto}.ttt-draw-offered-label{display:inline-flex;align-items:center;justify-content:center;cursor:default;pointer-events:none}.ttt-draw-offered-label:hover{transform:none;box-shadow:none}.ttt-draw-response-actions{display:flex;align-items:stretch;gap:.4rem}.ttt-draw-icon-btn{display:inline-flex;align-items:center;justify-content:center;align-self:stretch;aspect-ratio:1;padding:0;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;cursor:pointer;transition:background .15s ease,border-color .15s ease}.ttt-draw-icon-btn:hover:not(:disabled){background:#ffffff29}.ttt-draw-icon-btn:disabled{opacity:.5;cursor:not-allowed}.ttt-draw-accept-btn:hover:not(:disabled){border-color:#22c55e99;color:#22c55e}.ttt-draw-decline-btn:hover:not(:disabled){border-color:#ef444499;color:#ef4444}.ttt-grid-container{display:flex;justify-content:center;align-items:center;padding:1rem 0;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.ttt-grid{display:grid;grid-template-columns:120px repeat(3,120px);grid-template-rows:120px repeat(3,120px);gap:8px;background:#ffffff0d;padding:1rem;border-radius:12px;box-shadow:0 4px 20px #0000004d}.grid-header-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#c9b4b4;border:2px solid rgba(0,0,0,.12);border-radius:8px;padding:.5rem;font-weight:600;text-align:center;gap:4px}.header-image{width:50px;height:50px;object-fit:contain;border-radius:4px}.corner-cell{background:transparent;border:none}.header-type{font-size:.75rem;color:#0000008c;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.header-name{font-size:.9rem;color:#000;font-weight:700}.row-header{grid-column:1}.grid-row{display:contents}.grid-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#2a2a3e,#1f1f3a);border:2px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .3s ease;min-height:110px;position:relative;overflow:hidden}.grid-cell:hover:not(.unavailable):not(.filled){background:linear-gradient(135deg,#3a3a5e,#2f2f5a);border-color:#4a90e280;box-shadow:0 4px 16px #4a90e233;transform:scale(1.02)}.grid-cell.unavailable{background:linear-gradient(135deg,#1a1a1a,#0f0f0f);cursor:not-allowed;opacity:.5}.grid-cell.filled{background:linear-gradient(135deg,#22c55e,#16a34a);cursor:default}.grid-cell.not-your-turn{opacity:.6;cursor:not-allowed!important;background:linear-gradient(135deg,#3a3a4e,#2f2f4a)}.grid-cell.not-your-turn:hover{transform:none;box-shadow:none;border-color:#ffffff1a}.grid-cell.player-one{background:linear-gradient(135deg,#f97316,#ea580c);border-color:#f9731699;box-shadow:0 4px 16px #f973164d,inset 0 0 20px #ffffff1a;cursor:default}.grid-cell.player-two{background:linear-gradient(135deg,#06b6d4,#0891b2);border-color:#06b6d499;box-shadow:0 4px 16px #06b6d44d,inset 0 0 20px #ffffff1a;cursor:default}.grid-cell.player-one:hover,.grid-cell.player-two:hover{transform:none}.empty-cell{font-size:2rem;color:#ffffff4d;font-weight:700}.unavailable-cell{font-size:2rem;color:#fff3}.guessed-player{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:.35rem;width:100%;height:100%}.player-image{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid #ffffff;box-shadow:0 2px 8px #0000004d}.player-placeholder{width:60px;height:60px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#ffffff80;border:3px solid rgba(255,255,255,.3)}.player-name{font-size:.85rem;font-weight:600;color:#fff;text-align:center;margin:0;line-height:1.2;text-shadow:0 2px 4px rgba(0,0,0,.5)}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem;border-radius:16px;max-width:500px;width:90%;box-shadow:0 8px 32px #00000080;border:2px solid rgba(255,255,255,.1)}.modal-content h3{margin:0 0 1rem;color:#fff;font-size:1.5rem}.modal-content p{margin:0 0 1.5rem;color:#fffc;font-size:1rem}.modal-content input{width:100%;padding:12px 16px;font-size:1rem;border:2px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:#fff;margin-bottom:1.5rem;transition:all .3s ease}.modal-content input:focus{outline:none;border-color:#4a90e280;box-shadow:0 0 0 3px #4a90e21a}.modal-content input::placeholder{color:#fff6}.autocomplete-dropdown{position:absolute;top:calc(100% - 1.3rem);left:0;right:0;max-height:200px;overflow-y:auto;background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid rgba(255,255,255,.2);border-radius:8px;box-shadow:0 8px 24px #00000080;z-index:1001;margin-bottom:1rem}.autocomplete-item{padding:12px 16px;cursor:pointer;color:#fff;transition:all .2s ease;border-bottom:1px solid rgba(255,255,255,.05)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:#4a90e233}.autocomplete-dropdown::-webkit-scrollbar{width:8px}.autocomplete-dropdown::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.autocomplete-dropdown::-webkit-scrollbar-thumb{background:#4a90e280;border-radius:4px}.autocomplete-dropdown::-webkit-scrollbar-thumb:hover{background:#4a90e2b3}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.submit-button,.cancel-button{padding:10px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.submit-button{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;box-shadow:0 4px 12px #4a90e24d}.submit-button:hover{background:linear-gradient(135deg,#357abd,#2868a8);box-shadow:0 6px 16px #4a90e266;transform:translateY(-2px)}.cancel-button{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.cancel-button:hover{background:#ffffff26;border-color:#ffffff4d}.scores{display:flex;gap:1.5rem;justify-content:center;align-items:center}.score-item{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff0d;border-radius:8px;font-weight:600;transition:all .3s ease}.score-item.current-turn{transform:scale(1.05);box-shadow:0 0 15px #fff3}.score-item.player-one-score{border:2px solid rgba(249,115,22,.4)}.score-item.player-two-score{border:2px solid rgba(6,182,212,.4)}.score-item.player-one-score.current-turn{background:linear-gradient(135deg,#f9731626,#ea580c26);border-color:#f97316b3;border-width:3px}.score-item.player-two-score.current-turn{background:linear-gradient(135deg,#06b6d426,#0891b226);border-color:#06b6d4b3;border-width:3px}.player-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.player-color-dot.dot-one{background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 0 8px #f9731680}.player-color-dot.dot-two{background:linear-gradient(135deg,#06b6d4,#0891b2);box-shadow:0 0 8px #06b6d480}.timer{font-size:1.5rem;font-weight:700;padding:8px 20px;background:#ffffff1a;border-radius:8px;border:2px solid rgba(255,255,255,.2);color:#fff;min-width:150px;text-align:center}.timer-warning{background:linear-gradient(135deg,#ef44444d,#dc26264d)!important;border-color:#ef444499!important;color:#ef4444!important;animation:timer-pulse .5s ease-in-out infinite}@keyframes timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes pulse-turn{0%,to{box-shadow:0 0 10px #22c55e4d}50%{box-shadow:0 0 20px #22c55e99}}.back-button{margin-top:2rem;padding:12px 32px;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #4a90e24d}.back-button:hover{background:linear-gradient(135deg,#357abd,#2868a8);box-shadow:0 6px 16px #4a90e266;transform:translateY(-2px)}@media(max-width:768px){.ttt-grid{grid-template-columns:100px repeat(3,100px);grid-template-rows:90px repeat(3,100px);gap:6px;padding:.5rem}.grid-cell{min-height:100px}.header-name{font-size:.75rem}.header-type{font-size:.6rem}.header-image{width:40px;height:40px;margin-bottom:0}.player-image,.player-placeholder{width:50px;height:50px}.player-name{font-size:.7rem}}@media(max-width:480px){.ttt-grid-container{justify-content:center;padding:.5rem}.ttt-grid{grid-template-columns:18vw repeat(3,21vw);grid-template-rows:18vw repeat(3,21vw);gap:3px;padding:.25rem}.grid-cell{min-height:unset;aspect-ratio:1}.grid-header-cell{padding:.2rem;gap:2px}.header-name{font-size:.55rem;line-height:1.1;word-break:break-word}.header-type{font-size:.45rem}.header-image{width:8vw;height:8vw;max-width:32px;max-height:32px;margin-bottom:1px}.player-image,.player-placeholder{width:10vw;height:10vw;max-width:40px;max-height:40px;font-size:.9rem}.player-name{font-size:.55rem;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis}.guessed-player{gap:2px}.empty-cell{font-size:1rem}}.toast-container{position:fixed;top:100px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:10px;background:linear-gradient(135deg,#2a2a3e,#1f1f3a);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0006;color:#fff;font-size:.95rem;font-weight:500;min-width:250px;max-width:400px;pointer-events:auto;animation:toast-slide-in .3s ease-out}.toast-leaving{animation:toast-slide-out .3s ease-in forwards}@keyframes toast-slide-in{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(120%);opacity:0}}.toast-icon{font-size:1.2rem;flex-shrink:0}.toast-message{flex:1;line-height:1.4}.toast-error{background:linear-gradient(135deg,#4a2222,#331818);border-color:#ef4444}.toast-success{background:linear-gradient(135deg,#1e4a2e,#153822);border-color:#22c55e}.toast-warning{background:linear-gradient(135deg,#4a3518,#352610);border-color:#f97316}.toast-info{background:linear-gradient(135deg,#1e3355,#152844);border-color:#3b82f6}@media(max-width:480px){.toast-container{top:90px;right:10px;left:10px}.toast{min-width:unset;max-width:unset;width:100%;font-size:.85rem;padding:12px 16px;background:linear-gradient(135deg,#2a2a3e,#1f1f3a)}.toast-error{background:linear-gradient(135deg,#4a2222,#331818)}.toast-success{background:linear-gradient(135deg,#1e4a2e,#153822)}.toast-warning{background:linear-gradient(135deg,#4a3518,#352610)}.toast-info{background:linear-gradient(135deg,#1e3355,#152844)}}.guess-footballer-container{margin:0 auto}.race-scores{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.race-scores .score-item{background:#ffffff1a;padding:8px 16px;border-radius:20px;font-weight:600}.clues-container{display:flex;flex-direction:column;gap:16px;margin:20px 0;padding:20px;background:#0003;border-radius:16px;border:1px solid rgba(255,255,255,.1)}.clues-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.clue-card{background:linear-gradient(135deg,#58187d66,#9333ea4d);border:1px solid rgba(147,51,234,.3);border-radius:12px;padding:12px 20px;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:100px}.clue-card.small{min-width:80px;padding:8px 16px}.clue-card.stat{background:linear-gradient(135deg,#22c55e4d,#16a34a33);border-color:#22c55e66}.clue-label{font-size:.75rem;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.clue-value{font-size:1.1rem;font-weight:600;color:#fff}.clue-value.stat-value{font-size:1.4rem;color:#4ade80}.nationality-clue{display:flex;align-items:center;gap:8px}.nationality-flag{width:28px;height:20px;object-fit:cover;border-radius:3px}.clues-section{margin-top:8px}.clues-section-title{font-size:.9rem;color:#ffffffb3;margin-bottom:12px;text-align:center}.clubs-list{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.club-badge{display:flex;align-items:center;gap:8px;background:#ffffff1a;padding:8px 14px;border-radius:25px;border:1px solid rgba(255,255,255,.15)}.club-logo{width:24px;height:24px;object-fit:contain}.club-name{font-weight:500;font-size:.9rem}.club-years{font-size:.75rem;color:#ffffff80}.trophies-list{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.trophy-badge{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#fbbf244d,#f59e0b33);border:1px solid rgba(251,191,36,.4);padding:6px 12px;border-radius:20px}.trophy-badge.more{background:#ffffff1a;border-color:#fff3;font-size:.8rem;color:#fff9}.trophy-name{font-size:.8rem;font-weight:500}.trophy-year{font-size:.7rem;color:#fff9}.answer-reveal{text-align:center;padding:30px;background:linear-gradient(135deg,#22c55e33,#16a34a1a);border:2px solid rgba(34,197,94,.5);border-radius:16px;margin:20px 0;animation:reveal-pulse .5s ease-out}@keyframes reveal-pulse{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.answer-reveal h3{font-size:1rem;color:#ffffffb3;margin-bottom:8px}.answer-name{font-size:2rem;font-weight:700;color:#4ade80;margin:0}.next-question-hint{font-size:.85rem;color:#ffffff80;margin-top:12px}.guess-input-section{display:flex;gap:12px;margin-top:20px;justify-content:center;align-items:flex-start}.input-wrapper{position:relative;flex:1;max-width:400px}.guess-input{width:100%;padding:14px 20px;font-size:1.1rem;border:2px solid rgba(147,51,234,.4);border-radius:12px;background:#0000004d;color:#fff;outline:none;transition:all .3s ease}.guess-input:focus{border-color:#9333eacc;box-shadow:0 0 20px #9333ea4d}.guess-input::placeholder{color:#fff6}.guess-input:disabled{opacity:.5;cursor:not-allowed}.search-indicator{position:absolute;right:15px;top:50%;transform:translateY(-50%);font-size:.8rem;color:#ffffff80}.submit-guess-button{padding:14px 28px;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#9333ea,#7c3aed);border:none;border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease}.submit-guess-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #9333ea66}.submit-guess-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.guess-input-section .autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#1e1e32fa;border:1px solid rgba(147,51,234,.4);border-radius:12px;margin-top:4px;max-height:300px;overflow-y:auto;z-index:100;box-shadow:0 10px 40px #00000080}.guess-input-section .autocomplete-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s ease;border-bottom:1px solid rgba(255,255,255,.05)}.guess-input-section .autocomplete-item:last-child{border-bottom:none}.guess-input-section .autocomplete-item:hover{background:#9333ea4d}.suggestion-image{width:36px;height:36px;border-radius:50%;object-fit:cover;background:#ffffff1a}.suggestion-info{display:flex;flex-direction:column;gap:2px}.suggestion-name{font-weight:500;color:#fff}.suggestion-nationality{font-size:.8rem;color:#ffffff80}@media(max-width:768px){.clues-row{gap:8px}.clue-card{padding:10px 14px;min-width:80px}.clue-value{font-size:1rem}.clue-value.stat-value{font-size:1.2rem}.club-badge{padding:6px 10px;font-size:.85rem}.guess-input-section{flex-direction:column;align-items:stretch}.input-wrapper{max-width:none}.submit-guess-button{width:100%}.answer-name{font-size:1.5rem}}.game-results-modal-backdrop{position:fixed;inset:0;z-index:1000;display:flex;justify-content:center;align-items:center;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:backdropFadeIn .25s ease}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.game-results-card{position:relative;background:#1e1e28f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:48px 40px;max-width:480px;width:90%;text-align:center;animation:resultsSlideIn .5s cubic-bezier(.16,1,.3,1)}.results-close-btn{position:absolute;top:16px;right:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff9;font-size:1rem;cursor:pointer;transition:background .15s,color .15s}.results-close-btn:hover{background:#ffffff26;color:#fff}@keyframes resultsSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.result-icon{font-size:4rem;margin-bottom:8px;animation:resultsBounce .6s ease .3s both}@keyframes resultsBounce{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.result-title{font-size:2rem;font-weight:800;margin:0 0 8px;background:linear-gradient(135deg,#fff,#ccc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.result-winner{color:#fff9;font-size:1rem;margin:0 0 32px}.result-scoreboard{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.result-score-row{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:transform .2s}.result-score-row.first-place{background:#ffd70014;border-color:#ffd70033}.result-score-row.is-me{border-color:#4caf5066}.result-rank{font-size:1.3rem;min-width:36px;text-align:center}.result-username{flex:1;text-align:left;font-weight:600;font-size:1rem;color:#ffffffe6;display:flex;align-items:center;gap:8px}.you-tag{font-size:.65rem;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:4px;background:#4caf5040;color:#81c784}.result-score{font-weight:700;font-size:1.1rem;color:#fff}.score-label{font-weight:400;font-size:.75rem;color:#ffffff73}@media(max-width:480px){.game-results-card{padding:32px 20px;border-radius:18px}.result-icon{font-size:3rem}.result-title{font-size:1.5rem}.result-score-row{padding:10px 14px}}.initials-clash-container{text-align:center}.letter-selection-phase{margin:2rem 0}.phase-title{font-size:1.5rem;color:#fff;margin-bottom:.5rem}.phase-description{color:#fff9;margin-bottom:1.5rem;font-size:.95rem}.letter-input-area{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.letter-input{width:80px;height:80px;font-size:2.5rem;font-weight:700;text-align:center;text-transform:uppercase;border:3px solid rgba(147,51,234,.5);border-radius:16px;background:#1e1e32cc;color:#fff;caret-color:#9333eacc;outline:none;transition:border-color .2s}.letter-input:focus{border-color:#9333ea;box-shadow:0 0 20px #9333ea4d}.letter-input:disabled{opacity:.6;cursor:not-allowed}.submit-letter-button{padding:16px 28px;font-size:1.1rem;font-weight:600;border:none;border-radius:12px;background:linear-gradient(135deg,#9333ea,#7c3aed);color:#fff;cursor:pointer;transition:all .2s}.submit-letter-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #9333ea66}.submit-letter-button:disabled{opacity:.5;cursor:not-allowed}.random-letter-button{display:flex;align-items:center;justify-content:center;width:56px;height:56px;font-size:1.6rem;line-height:1;border:2px solid rgba(147,51,234,.5);border-radius:12px;background:#1e1e32cc;color:#fff;cursor:pointer;transition:all .2s}.random-letter-button:hover:not(:disabled){transform:translateY(-2px) rotate(-12deg);border-color:#9333ea;box-shadow:0 6px 20px #9333ea66}.random-letter-button:disabled{opacity:.5;cursor:not-allowed}.letter-status{display:flex;justify-content:center;gap:1.5rem}.status-badge{padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:500}.status-badge.waiting{background:#ffffff14;color:#ffffff80}.status-badge.ready{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.initials-display{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1.5rem 0 .5rem}.initial-letter{width:80px;height:80px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#9333ea4d,#7c3aed33);border:2px solid rgba(147,51,234,.5);border-radius:16px}.initial-separator{font-size:1.5rem;color:#fff6;font-weight:600}.valid-count{color:#fff9;font-size:.95rem;margin-bottom:1.5rem}.club-clash-container{text-align:center}.club-selection-phase{margin:2rem 0}.club-input-area{display:flex;align-items:flex-start;justify-content:center;gap:1rem;margin-bottom:1.5rem}.club-search-input{width:100%;max-width:340px;padding:14px 18px;font-size:1.05rem;border:2px solid rgba(147,51,234,.4);border-radius:12px;background:#1e1e32cc;color:#fff;outline:none;transition:border-color .2s}.club-search-input:focus{border-color:#9333ea;box-shadow:0 0 20px #9333ea4d}.club-search-input:disabled{opacity:.6;cursor:not-allowed}.data-coverage-notice{display:flex;align-items:center;gap:10px;max-width:536px;margin:1.25rem auto;padding:10px 16px;border:1px solid rgba(250,204,21,.45);border-radius:12px;background:#facc151f;color:#fde68a;font-size:.9rem;line-height:1.35;text-align:left}.data-coverage-notice__icon{font-size:1.1rem;flex-shrink:0}.data-coverage-notice__text strong{color:#fef3c7;font-weight:700}.data-coverage-notice--compact{max-width:520px;margin-bottom:1rem;padding:8px 14px;font-size:.82rem}@media(max-width:600px){.data-coverage-notice{font-size:.82rem;padding:9px 12px}}.club-selection-phase .input-wrapper{position:relative;width:100%;max-width:340px}.club-selection-phase .autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;margin-bottom:0;max-height:300px;background:#1e1e32fa;border:1px solid rgba(147,51,234,.4);border-radius:12px;box-shadow:0 10px 40px #00000080;z-index:100}.club-selection-phase .autocomplete-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s ease;border-bottom:1px solid rgba(255,255,255,.05)}.club-selection-phase .autocomplete-item:last-child{border-bottom:none}.club-selection-phase .autocomplete-item:hover{background:#9333ea4d}.club-selection-phase .search-indicator{position:absolute;right:15px;top:50%;transform:translateY(-50%)}.club-suggestion-image{width:28px!important;height:28px!important;object-fit:contain;border-radius:4px}.clubs-display{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin:1.5rem 0 .5rem;flex-wrap:wrap}.clubs-display .club-badge{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#9333ea33,#7c3aed1a);border:2px solid rgba(147,51,234,.4);border-radius:16px;min-width:120px}.clubs-display .club-logo{width:56px;height:56px;object-fit:contain}.clubs-display .club-name{font-size:1rem;font-weight:600;color:#fff;text-align:center}.club-separator{font-size:1.5rem;font-weight:700;color:#ffffff80;letter-spacing:2px}@media(max-width:480px){.clubs-display{gap:.75rem}.clubs-display .club-badge{padding:.75rem 1rem;min-width:100px}.clubs-display .club-logo{width:40px;height:40px}.clubs-display .club-name{font-size:.85rem}.club-input-area{flex-direction:column;align-items:stretch}.club-selection-phase .input-wrapper,.club-search-input{max-width:none}.club-input-area .submit-letter-button{width:100%}}.lobby-chat{background:linear-gradient(135deg,#553c9a,#6b21a8);border-radius:20px;padding:1rem 1.25rem;border:2px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;height:320px;margin-bottom:2rem}.lobby-chat .chat-header{display:flex;align-items:center;justify-content:space-between;font-size:1rem;font-weight:600;color:#ecf0f1;margin-bottom:.75rem;letter-spacing:.5px}.lobby-chat .chat-close-btn{background:none;border:none;color:#fff9;font-size:1.1rem;cursor:pointer;padding:2px 6px;border-radius:6px;transition:all .2s}.lobby-chat .chat-close-btn:hover{color:#fff;background:#ffffff1a}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.35rem;padding-right:4px;margin-bottom:.75rem}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.chat-empty{color:#ffffff59;font-size:.85rem;text-align:center;padding:2rem 0}.chat-message{display:flex;flex-direction:column;align-items:flex-start;max-width:85%;animation:chatFadeIn .2s ease}@keyframes chatFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-message.own{align-self:flex-end;align-items:flex-end}.chat-username{font-size:.7rem;font-weight:600;color:#fbbf24;margin-bottom:1px;padding-left:8px}.chat-text{background:#ffffff1a;padding:.35rem .7rem;border-radius:12px;font-size:.85rem;color:#ecf0f1;word-break:break-word;line-height:1.4}.chat-message.own .chat-text{background:#9333ea80}.chat-input-area{display:flex;gap:.5rem}.chat-input-area input{flex:1;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:.5rem .75rem;color:#ecf0f1;font-size:.85rem;outline:none;transition:border-color .2s}.chat-input-area input:focus{border-color:#9333ea99}.chat-input-area input::placeholder{color:#ffffff59}.chat-input-area button{background:linear-gradient(135deg,#9333ea,#7c3aed);border:none;border-radius:12px;padding:.5rem 1rem;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.chat-input-area button:hover:not(:disabled){background:linear-gradient(135deg,#a855f7,#8b5cf6);transform:translateY(-1px)}.chat-input-area button:disabled{opacity:.4;cursor:not-allowed}.chat-collapsible-wrapper{position:fixed;bottom:1.5rem;right:1.5rem;z-index:900}.chat-toggle{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#9333ea,#7c3aed);border:2px solid rgba(255,255,255,.3);color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:all .2s;box-shadow:0 4px 15px #0000004d}.chat-toggle:hover{transform:scale(1.08);box-shadow:0 6px 20px #0006}.chat-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.lobby-chat-overlay{position:absolute;bottom:60px;right:0;width:320px;height:380px;box-shadow:0 8px 32px #0006;animation:chatSlideUp .25s ease}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){.lobby-chat-overlay{width:calc(100vw - 3rem);right:-.75rem}}.daily-puzzle-banner{margin:0 auto 1.5rem;max-width:800px;cursor:pointer;background:linear-gradient(135deg,#430c4be6,#782896e6);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:1rem 1.5rem;transition:transform .2s ease,box-shadow .2s ease}.daily-puzzle-banner:hover{transform:translateY(-2px);box-shadow:0 8px 24px #78289666}.daily-banner-content{display:flex;align-items:center;gap:1rem}.daily-banner-icon{font-size:2rem;color:#f0c040;flex-shrink:0}.daily-banner-text h3{margin:0;font-size:1.1rem;color:#fff}.daily-banner-text p{margin:.25rem 0 0;font-size:.85rem;color:#ffffffb3}.daily-banner-arrow{margin-left:auto;font-size:1.5rem;color:#ffffff80;flex-shrink:0}.daily-puzzle-container{max-width:600px;margin:0 auto;padding:1.5rem 1rem;color:#fff}.daily-puzzle-header{text-align:center;margin-bottom:1.5rem}.daily-puzzle-header h1{font-size:1.6rem;margin:0 0 .25rem}.daily-puzzle-date{color:#ffffff80;font-size:.85rem}.daily-puzzle-loading,.daily-puzzle-error{text-align:center;padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1rem;color:#ffffffb3}.daily-puzzle-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:1.5rem;aspect-ratio:1;max-width:500px;margin-left:auto;margin-right:auto}.daily-puzzle-cell{border-radius:12px;overflow:hidden;position:relative;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);aspect-ratio:1;display:flex;align-items:center;justify-content:center}.daily-puzzle-cell.revealed{border-color:#78289680}.daily-puzzle-cell.hidden{background:#ffffff08}.daily-puzzle-image{width:100%;height:100%;object-fit:cover}.daily-puzzle-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff3;font-size:.8rem}.daily-puzzle-wrong-toast{text-align:center;padding:.5rem 1rem;background:#dc354533;border:1px solid rgba(220,53,69,.4);border-radius:8px;color:#ff6b7a;margin-bottom:1rem;animation:fadeInOut 1.5s ease forwards}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-8px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1}to{opacity:0}}.daily-puzzle-input-section{display:flex;flex-direction:column;gap:1rem}.daily-puzzle-attempts{text-align:center;font-size:.85rem;color:#ffffff80}.daily-puzzle-search-wrapper{display:flex;flex-direction:column;gap:.75rem}.daily-puzzle-search-wrapper .guess-input-wrapper{position:relative;width:100%}.daily-puzzle-search-wrapper .guess-input{width:100%;box-sizing:border-box;padding-right:5.5rem}.daily-puzzle-search-wrapper .search-indicator{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none}.daily-puzzle-search-wrapper .autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;width:100%;margin-top:4px;margin-bottom:0;max-height:220px;border-radius:12px;box-sizing:border-box;z-index:100}.daily-puzzle-search-wrapper .autocomplete-item{display:flex;align-items:center;gap:12px}.daily-puzzle-buttons{display:flex;gap:.5rem}.daily-puzzle-buttons .btn{flex:1}.daily-puzzle-giveup{background:#ffffff0d!important;border:1px solid rgba(255,255,255,.15)!important;color:#fff9!important}.daily-puzzle-giveup:hover{background:#dc354526!important;border-color:#dc354566!important;color:#ff6b7a!important}.daily-puzzle-result{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.daily-puzzle-answer{display:flex;flex-direction:column;align-items:center;gap:.75rem}.daily-puzzle-player-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid rgba(120,40,150,.6)}.daily-puzzle-player-name{font-size:1.4rem;margin:0}.daily-puzzle-success{display:flex;align-items:center;gap:.5rem;color:#4caf50;font-size:1.1rem}.daily-puzzle-success .trophy-icon{color:#f0c040;font-size:1.3rem}.daily-puzzle-gave-up-msg{display:flex;align-items:center;gap:.5rem;color:#ffffff80}.daily-puzzle-stats{display:flex;gap:1.5rem;justify-content:center}.daily-puzzle-stat{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:#fff9}.daily-puzzle-countdown{display:flex;align-items:center;gap:.5rem;color:#fff6;font-size:.9rem;padding:.75rem 1.25rem;background:#ffffff0d;border-radius:10px;border:1px solid rgba(255,255,255,.08)}.admin-container{max-width:900px;margin:0 auto;padding:1.5rem 1rem;color:#fff}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.admin-title{text-align:left;font-size:1.6rem;margin:0}.admin-logout-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff14;color:#ffffffd9;font-size:.9rem;cursor:pointer;transition:background .15s,border-color .15s}.admin-logout-btn:hover{background:#ffffff24;border-color:#ffffff59}.admin-login{text-align:center;padding:3rem 1rem}.admin-login h1{margin:0 0 .5rem}.admin-login p{color:#fff9;margin-bottom:1.5rem}.admin-login-form{display:flex;gap:.5rem;justify-content:center;max-width:400px;margin:0 auto}.admin-input{flex:1;padding:.6rem .9rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff;font-size:.9rem;outline:none;transition:border-color .2s}.admin-input:focus{border-color:#78289699}.admin-error{color:#ff6b7a;font-size:.85rem;margin-top:.75rem}.admin-success{color:#4caf50;font-size:.85rem;margin-top:.75rem}.admin-alert{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#dca01e26;border:1px solid rgba(220,160,30,.4);border-radius:10px;color:#f0c040;margin-bottom:1.5rem;font-size:.9rem}.admin-calendar{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1rem;margin-bottom:1rem}.admin-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.admin-calendar-header h2{margin:0;font-size:1.1rem}.admin-cal-nav{background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.admin-cal-nav:hover{background:#ffffff14}.admin-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.admin-cal-day-header{text-align:center;font-size:.7rem;color:#fff6;padding:.25rem 0;text-transform:uppercase}.admin-cal-cell{aspect-ratio:1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;position:relative;font-size:.85rem}.admin-cal-cell.empty{cursor:default}.admin-cal-cell.has-puzzle{background:#4caf5026;border:1px solid rgba(76,175,80,.3)}.admin-cal-cell.has-puzzle:hover{background:#4caf5040}.admin-cal-cell.no-puzzle{background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.admin-cal-cell.no-puzzle:hover{background:#ffffff14;border-color:#ffffff26}.admin-cal-day{font-weight:500}.admin-cal-dot{width:5px;height:5px;border-radius:50%;background:#4caf50;position:absolute;bottom:4px}.admin-create-btn{display:flex;align-items:center;gap:.4rem;margin-bottom:1.5rem}.admin-form-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.25rem;margin-bottom:1.5rem}.admin-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.admin-form-header h2{margin:0;font-size:1.1rem}.admin-close-btn{background:transparent;border:none;color:#ffffff80;cursor:pointer;font-size:1.1rem;padding:.25rem;transition:color .2s}.admin-close-btn:hover{color:#fff}.admin-form{display:flex;flex-direction:column;gap:1rem}.admin-form-row{display:flex;flex-direction:column;gap:.4rem}.admin-form-row label{font-size:.8rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.admin-selected-player{font-size:.8rem;color:#4caf50}.admin-form-row .guess-input-wrapper{position:relative;width:100%}.admin-form-row .guess-input-wrapper .admin-input{width:100%;box-sizing:border-box;padding-right:5.5rem}.admin-form-row .guess-input-wrapper .search-indicator{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.75rem;color:#ffffff73;pointer-events:none}.admin-form-row .autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;width:100%;margin-top:4px;margin-bottom:0;max-height:220px;border-radius:8px;box-sizing:border-box}.admin-form-row .autocomplete-item{display:flex;align-items:center;gap:12px;padding:10px 12px}.admin-image-slots{display:grid;grid-template-columns:1fr 1fr;gap:8px}.admin-image-slot{display:flex;flex-direction:column;gap:.4rem;align-items:center}.admin-image-label{font-size:.75rem;color:#fff6}.admin-image-preview{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.admin-image-empty{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px dashed rgba(255,255,255,.15);background:#ffffff05;color:#fff3}.admin-file-input{width:100%;font-size:.75rem;color:#ffffff80}.admin-file-input::file-selector-button{padding:.3rem .6rem;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#ffffffb3;cursor:pointer;font-size:.7rem;margin-right:.5rem}.admin-submit-btn{align-self:flex-start}.admin-puzzle-list{margin-top:1.5rem}.admin-puzzle-list h2{font-size:1.1rem;margin:0 0 .75rem}.admin-empty{color:#fff6;text-align:center;padding:2rem}.admin-table{display:flex;flex-direction:column;gap:6px}.admin-table-row{display:flex;align-items:center;gap:1rem;padding:.6rem .8rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;transition:background .15s}.admin-table-row:hover{background:#ffffff0f}.admin-table-date{font-size:.85rem;color:#fff9;min-width:100px}.admin-table-player{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.admin-table-img{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}.admin-table-player span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.admin-table-stats{display:flex;gap:.75rem;font-size:.8rem;color:#fff6}.admin-table-stats span{display:flex;align-items:center;gap:.25rem}.admin-table-actions{display:flex;gap:.3rem}.admin-action-btn{background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffff80;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem;transition:all .15s}.admin-action-btn:hover{background:#ffffff14;color:#fff}.admin-action-danger:hover{background:#dc354526;border-color:#dc354566;color:#ff6b7a}.admin-preview-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.admin-preview-modal{background:linear-gradient(135deg,#1f0022,#2a0a30);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.admin-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.admin-preview-header h2{margin:0;font-size:1.1rem}.admin-preview-info{font-size:.8rem;color:#fff6;margin-bottom:1rem}.preview-grid{max-width:400px;margin:0 auto 1rem}.admin-preview-controls{display:flex;gap:.5rem;justify-content:center}@media(max-width:600px){.admin-table-row{flex-wrap:wrap;gap:.5rem}.admin-table-stats{width:100%;justify-content:flex-start}.admin-table-actions{margin-left:auto}.daily-puzzle-grid{gap:6px}}.link-up-container{margin:0 auto}.link-up-header{margin-bottom:1.25rem}.link-up-title{text-align:center;margin:0 0 1rem;font-size:1.6rem}.link-up-scoreboard{display:flex;align-items:stretch;justify-content:center;gap:.75rem;margin-bottom:.85rem}.link-up-score-card{flex:1;max-width:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.6rem 1rem;border-radius:14px;border:1px solid transparent;background:#ffffff0a;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.link-up-score-team{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.85}.link-up-score-count{font-size:1.7rem;font-weight:800;line-height:1.1}.link-up-score-target{font-size:.95rem;font-weight:600;opacity:.55}.link-up-score-sub{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;opacity:.5}.link-up-score-red{background:#c83c461f;color:#ff8a96}.link-up-score-blue{background:#3c64c81f;color:#8fb4ff}.link-up-score-red.is-active{border-color:#ff6b7ab3;box-shadow:0 0 18px #c83c4659;transform:translateY(-2px)}.link-up-score-blue.is-active{border-color:#6b9fffb3;box-shadow:0 0 18px #3c64c859;transform:translateY(-2px)}.link-up-timer{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:72px;border-radius:14px;background:#0000004d;border:1px solid rgba(255,255,255,.12)}.link-up-timer-value{font-size:1.6rem;font-weight:800;line-height:1}.link-up-timer-unit{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;opacity:.6}.link-up-timer.is-low{border-color:#ff6b7a99;color:#ff6b7a;animation:link-up-pulse 1s ease-in-out infinite}@keyframes link-up-pulse{0%,to{box-shadow:0 0 #ff6b7a00}50%{box-shadow:0 0 16px #ff6b7a80}}.link-up-turn-banner{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-left-width:4px}.link-up-turn-red{border-left-color:#c83c46}.link-up-turn-blue{border-left-color:#3c64c8}.link-up-turn-banner.is-mine{background:#fbbf241a;border-color:#fbbf2466;border-left-color:#fbbf24}.link-up-turn-text{flex:1;font-size:.95rem;color:#ffffffd9}.link-up-turn-text strong{color:#fff}.link-up-turn-indicator{display:flex;align-items:center}.link-up-turn-pulse{width:12px;height:12px;border-radius:50%;background:#fbbf24;box-shadow:0 0 #fbbf2499;animation:link-up-ping 1.4s ease-in-out infinite}@keyframes link-up-ping{0%{box-shadow:0 0 #fbbf2499}70%{box-shadow:0 0 0 8px #fbbf2400}to{box-shadow:0 0 #fbbf2400}}.link-up-turn-dots{display:inline-flex;gap:4px}.link-up-turn-dots span{width:7px;height:7px;border-radius:50%;background:#ffffffb3;animation:link-up-bounce 1.2s ease-in-out infinite}.link-up-turn-dots span:nth-child(2){animation-delay:.18s}.link-up-turn-dots span:nth-child(3){animation-delay:.36s}@keyframes link-up-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.link-up-role-chip{font-size:.72rem;font-weight:700;text-transform:capitalize;padding:.3rem .65rem;border-radius:999px;white-space:nowrap}.link-up-role-red{background:#c83c4640;color:#ff8a96}.link-up-role-blue{background:#3c64c840;color:#8fb4ff}.link-up-clue-bar{display:flex;align-items:center;gap:.65rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.7rem 1rem;margin:1rem 0}.link-up-clue-red{border-color:#c83c4666}.link-up-clue-blue{border-color:#3c64c866}.link-up-clue-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.6}.link-up-clue-word{font-size:1.3rem;font-weight:800;letter-spacing:.01em}.link-up-clue-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 .4rem;border-radius:999px;background:#fbbf24;color:#1f2937;font-weight:800;font-size:.9rem}.link-up-guess-count{margin-left:auto;font-weight:600;font-size:.85rem;color:#ffffffb3}.link-up-board{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:1.5rem}@media(max-width:700px){.link-up-board{grid-template-columns:repeat(4,1fr)}}.link-up-tile{aspect-ratio:1.2;border-radius:8px;padding:.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:default;border:2px solid rgba(255,255,255,.15);background:#ffffff0f;position:relative;transition:transform .15s,border-color .15s;overflow:hidden}.link-up-tile-clickable{cursor:pointer}.link-up-tile-clickable:hover:not(.link-up-tile-selected){border-color:#ffffff59}.link-up-tile-active{justify-content:flex-start;aspect-ratio:auto;min-height:7.5rem}.link-up-tile-hidden{background:#b4a07840;border-color:#b4a07880}.link-up-tile-red,.link-up-tile-revealed.link-up-tile-red{background:#c83c4673;border-color:#c83c46}.link-up-tile-blue,.link-up-tile-revealed.link-up-tile-blue{background:#3c64c873;border-color:#3c64c8}.link-up-tile-neutral,.link-up-tile-revealed.link-up-tile-neutral{background:#a0968273;border-color:#a09682}.link-up-tile-black,.link-up-tile-revealed.link-up-tile-black{background:#1e1e23e6;border-color:#111}.link-up-tile-selected{transform:scale(1.03);border-color:#fff;box-shadow:0 0 12px #ffffff4d}.link-up-tile-name{font-size:.75rem;line-height:1.2;font-weight:600;word-break:break-word}.link-up-vote-dots{display:flex;gap:3px;margin-top:4px}.link-up-vote-dot{width:8px;height:8px;border-radius:50%;background:#fff;opacity:.85}.link-up-tile-actions{display:flex;flex-direction:column;gap:.35rem;width:100%;margin-top:auto;padding-top:.35rem}.link-up-tile-btn{width:100%;padding:.3rem .4rem!important;font-size:.65rem!important;line-height:1.2;white-space:nowrap}.link-up-lead-panel{display:flex;flex-wrap:wrap;gap:.85rem;align-items:flex-end;padding:1rem;margin-bottom:1rem;border-radius:14px;background:#00000038;border:1px solid rgba(255,255,255,.1)}.link-up-lead-fields{display:flex;gap:.85rem;flex:1;min-width:220px}.link-up-field{display:flex;flex-direction:column;gap:.3rem}.link-up-field:first-child{flex:1}.link-up-field-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffffff8c}.link-up-clue-input{width:100%;padding:.65rem .85rem;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#00000059;color:#fff;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.link-up-clue-input::placeholder{color:#ffffff59}.link-up-clue-input:focus{outline:none;border-color:#fbbf2499;box-shadow:0 0 0 3px #fbbf2426}.link-up-stepper{display:inline-flex;align-items:center;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#00000059;overflow:hidden}.link-up-stepper-btn{width:2.4rem;height:2.6rem;border:none;background:#ffffff0f;color:#fff;font-size:1.25rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.link-up-stepper-btn:hover:not(:disabled){background:#fbbf2440}.link-up-stepper-btn:disabled{opacity:.35;cursor:not-allowed}.link-up-stepper-value{min-width:2.4rem;text-align:center;font-size:1.05rem;font-weight:700;color:#fff}.link-up-give-clue-btn{flex:0 0 auto;min-width:140px}.link-up-answerer-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.85rem 1rem;margin-bottom:1rem;border-radius:14px;background:#00000038;border:1px solid rgba(255,255,255,.1)}.link-up-answerer-bar .link-up-hint{margin:0}.link-up-end-turn-btn{flex:0 0 auto;min-width:120px}.link-up-error{color:#ff6b7a;margin-bottom:.5rem}.link-up-hint{color:#ffffff8c;font-size:.9rem}@media(max-width:560px){.link-up-scoreboard{gap:.5rem}.link-up-score-card{padding:.5rem}.link-up-turn-banner{flex-wrap:wrap}.link-up-lead-fields{flex-direction:column;width:100%}.link-up-field-count{align-items:flex-start}.link-up-give-clue-btn{width:100%}}.link-up-lobby-teams{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}@media(max-width:640px){.link-up-lobby-teams{grid-template-columns:1fr}}.link-up-team-column{border-radius:10px;padding:1rem;min-height:120px}.link-up-team-red{background:#c83c461f;border:1px solid rgba(200,60,70,.35)}.link-up-team-blue{background:#3c64c81f;border:1px solid rgba(60,100,200,.35)}.link-up-team-column h3{margin:0 0 .75rem;font-size:1rem}.link-up-drop-slot{margin-bottom:.75rem}.link-up-drop-slot:last-child{margin-bottom:0}.link-up-drop-zone-inner{border:2px dashed rgba(255,255,255,.25);border-radius:8px;padding:.5rem;min-height:56px;transition:border-color .15s,background .15s}.link-up-drop-zone-inner.link-up-drop-lead{border-color:#ffd76473;background:#ffd7640f}.link-up-drop-zone-inner.link-up-drop-team{min-height:88px}.link-up-team-unassigned{background:#ffffff0f;border:1px solid rgba(255,255,255,.2);margin-top:.25rem}.link-up-drop-zone-inner.link-up-drop-unassigned{border-color:#ffffff59;background:#00000026;min-height:88px}.link-up-drop-zone-clickable{cursor:pointer}.link-up-drop-zone-clickable:hover{border-color:#ffffff73;background:#ffffff14}.link-up-drop-zone-inner.link-up-drop-lead.link-up-drop-zone-clickable:hover{border-color:#ffd764a6;background:#ffd7641a}.link-up-drop-zone-clickable:focus-visible{outline:2px solid #fbbf24;outline-offset:2px}.link-up-drop-zone-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#ffffff8c;margin-bottom:.4rem}.link-up-drop-slot:has(.link-up-drop-lead) .link-up-drop-zone-label{color:#ffd764d9}.link-up-drop-zone-content{display:flex;flex-direction:column;gap:.4rem}.link-up-drop-zone-content .link-up-drop-hint{margin:.25rem 0;text-align:center}.link-up-lobby-player{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem;margin-bottom:.5rem;background:#0003;border-radius:6px}.link-up-drop-hint{font-size:.85rem;color:#fff6;font-style:italic}.link-up-roster-warning{color:#ffb347;font-size:.9rem;margin-bottom:.75rem}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.link-up-result-team.link-up-team-red .result-username{color:#ff6b7a}.link-up-result-team.link-up-team-blue .result-username{color:#6b9fff}.language-switcher{position:relative;display:inline-flex;margin-right:12px}.language-switcher__trigger{appearance:none;display:inline-flex;align-items:center;padding:0;background:transparent;border:none;border-radius:3px;cursor:pointer}.language-switcher__flag{display:block;width:30px;height:auto;border-radius:3px;transition:transform .2s ease,box-shadow .2s ease}.language-switcher__trigger:hover .language-switcher__flag,.language-switcher__trigger[aria-expanded=true] .language-switcher__flag{transform:scale(1.06);box-shadow:0 0 0 2px #ffffff73}.language-switcher__menu{position:absolute;top:calc(100% + 8px);right:0;margin:0;padding:6px;list-style:none;min-width:172px;background:linear-gradient(135deg,#1f0022fa,#430c4bfa);border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 12px 30px #00000073;z-index:1100}.language-switcher__option{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:none;border-radius:8px;color:#ffffffd1;font-size:.92rem;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.language-switcher__option:hover{background:#ffffff14;color:#fff}.language-switcher__option.is-active{background:#ffffff1f;color:#fff}.language-switcher__option .language-switcher__flag{width:24px}.language-switcher__name{white-space:nowrap}.landing-language-switcher{position:absolute;top:42px;right:1rem;transform:translateY(-50%);z-index:5}@media(max-width:480px){.landing-language-switcher{top:28px}}.sound-settings{position:relative;display:inline-flex;margin-right:12px}.sound-settings__trigger{appearance:none;display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;border:none;border-radius:3px;color:#ffffffd9;cursor:pointer;transition:color .15s ease,transform .2s ease}.sound-settings__trigger:hover,.sound-settings__trigger[aria-expanded=true]{color:#fff}.sound-settings__icon{display:block;width:20px;height:20px;transition:transform .4s ease}.sound-settings__trigger:hover .sound-settings__icon{transform:rotate(30deg)}.sound-settings__menu{position:absolute;top:calc(100% + 8px);right:0;margin:0;padding:12px;min-width:248px;background:linear-gradient(135deg,#1f0022fa,#430c4bfa);border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 12px 30px #00000073;z-index:1100}.sound-settings__title{margin:0 0 10px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#fff9}.sound-settings__divider{height:1px;margin:8px 0;background:#ffffff1f}.sound-settings__row{display:flex;align-items:center;gap:10px;padding:6px 0}.sound-settings__mute{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:28px;height:28px;padding:0;background:#ffffff14;border:none;border-radius:8px;color:#ffffffd9;cursor:pointer;transition:background .15s ease,color .15s ease}.sound-settings__mute:hover{background:#ffffff29;color:#fff}.sound-settings__mute.is-muted{color:#ff6b6b}.sound-settings__label{flex:1 1 auto;font-size:.9rem;font-weight:600;color:#ffffffd9;white-space:nowrap}.sound-settings__slider{flex:0 0 90px;width:90px;accent-color:#c026d3;cursor:pointer}.sound-settings__slider:disabled{opacity:.4;cursor:not-allowed}.game-status-screen{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:1rem}.game-status-card{width:100%;max-width:440px;padding:2.25rem 1.75rem;text-align:center;background:linear-gradient(135deg,#1f0022f5,#430c4bf5);border:1px solid rgba(255,255,255,.12);border-radius:16px;box-shadow:0 16px 40px #00000073;animation:fadeIn .3s ease}.game-status-title{margin:0 0 .75rem;font-size:1.4rem;font-weight:700;color:#fff}.game-status-message{margin:0 0 1.5rem;font-size:.98rem;line-height:1.5;color:#ffffffbf}.game-status-card .game-status-action{flex:0 0 auto;min-width:180px}.football-holdem-container{display:flex;flex-direction:column;gap:1.25rem}.football-holdem-header{text-align:center}.football-holdem-title{font-size:1.9rem;font-weight:800;background:linear-gradient(135deg,#a78bfa,#f0abfc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0}.football-holdem-phase-hint{color:#cbd5e1;margin:.4rem 0 0}.football-holdem-round-info{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-top:.35rem;flex-wrap:wrap}.football-holdem-turn-counter{font-weight:700;color:#e2e8f0}.football-holdem-tiebreak-badge{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;padding:.2rem .7rem;border-radius:999px;font-size:.8rem;font-weight:700}.football-holdem-timer-slot .football-holdem-timer{display:inline-flex}.football-holdem-timer{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .7rem;border-radius:999px;font-weight:800;font-variant-numeric:tabular-nums;color:#e2e8f0;background:#0f172a8c;border:1px solid rgba(148,163,184,.35);transition:color .2s ease,background .2s ease,border-color .2s ease}.football-holdem-timer-clock{font-size:.95em;line-height:1}.football-holdem-timer.is-low{color:#fff;background:#ef4444d9;border-color:#f87171e6;animation:football-holdem-timer-pulse 1s ease-in-out infinite}@keyframes football-holdem-timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.football-holdem-category-banner{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;padding:.9rem 1.2rem;border-radius:16px;background:linear-gradient(135deg,#7c3aed59,#d946ef40);border:1px solid rgba(167,139,250,.4);box-shadow:0 6px 20px #4c1d9559}.football-holdem-category-label{text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:#c4b5fd}.football-holdem-category-name{font-size:1.5rem;font-weight:800;color:#fff}.football-holdem-category-kind{font-size:.72rem;font-weight:700;padding:.18rem .6rem;border-radius:999px}.football-holdem-kind-total{background:#38bdf833;color:#7dd3fc}.football-holdem-kind-per90{background:#4ade8033;color:#86efac}.football-holdem-scoreboard{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.football-holdem-score-card{display:flex;flex-direction:column;align-items:center;min-width:110px;padding:.6rem .9rem;border-radius:12px;background:#1e293bb3;border:1px solid rgba(148,163,184,.18)}.football-holdem-score-card.is-me{border-color:#a78bfab3;box-shadow:0 0 0 1px #a78bfa4d}.football-holdem-score-card.is-eliminated{opacity:.5}.football-holdem-score-name{font-weight:700;color:#e2e8f0;display:flex;align-items:center;gap:.35rem}.football-holdem-you-tag{font-size:.6rem;background:#7c3aed;color:#fff;padding:.05rem .35rem;border-radius:6px}.football-holdem-score-turns{font-size:1.3rem;font-weight:800;color:#f0abfc}.football-holdem-score-sub{font-size:.75rem;color:#94a3b8}.football-holdem-card{position:relative;width:var(--holdem-card-w, 100px);border:none;padding:0;border-radius:10px;cursor:pointer;background:linear-gradient(160deg,#1e293b,#0f172a);border:1px solid rgba(148,163,184,.2);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;overflow:hidden}.football-holdem-card:not(:disabled):hover{transform:translateY(-6px);box-shadow:0 10px 24px #00000073}.football-holdem-card:disabled{cursor:default}.football-holdem-card-selected{border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa,0 10px 24px #7c3aed80;transform:translateY(-8px)}.football-holdem-card-discarding{border-color:#ef4444;box-shadow:0 0 0 2px #ef4444}.football-holdem-card-face{display:flex;flex-direction:column;align-items:center;padding:.4rem .35rem .45rem;gap:.2rem}.football-holdem-card-photo{width:var(--holdem-card-photo, 46px);height:var(--holdem-card-photo, 46px);border-radius:50%;overflow:hidden;background:radial-gradient(circle at 50% 30%,#475569,#1e293b);display:flex;align-items:center;justify-content:center}.football-holdem-card-photo img{width:100%;height:100%;object-fit:cover}.football-holdem-card-noimg{font-size:1.35rem;font-weight:800;color:#cbd5e1}.football-holdem-card-name{font-weight:700;font-size:.72rem;color:#f1f5f9;text-align:center;line-height:1.1;min-height:1.65em;display:flex;align-items:center}.football-holdem-card-meta{font-size:.72rem;color:#94a3b8;text-align:center}.football-holdem-card-highlight{margin-top:0;display:flex;flex-direction:column;align-items:center;width:100%;padding:.3rem .35rem;border-radius:8px;background:#7c3aed33}.football-holdem-card-highlight-slot{width:100%;min-height:0;display:flex;align-items:center;justify-content:center}.football-holdem-table-center .football-holdem-card-highlight-slot,.football-holdem-play-slot-card .football-holdem-card-highlight-slot{min-height:2.35rem}.football-holdem-card-highlight-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:#c4b5fd}.football-holdem-card-highlight-value{font-size:1.15rem;font-weight:800;color:#fff}.football-holdem-table-center .football-holdem-card-highlight-value{font-size:.95rem}.football-holdem-card-footer-stats{display:flex;gap:.6rem;margin-top:.2rem}.football-holdem-card-stat{display:flex;flex-direction:column;align-items:center}.football-holdem-card-stat-label{font-size:.6rem;color:#94a3b8}.football-holdem-card-stat-value{font-size:.95rem;font-weight:700;color:#e2e8f0}.football-holdem-card-redraw-flag{display:block;text-align:center;font-size:.7rem;font-weight:700;padding:.25rem;background:#0f172acc;color:#cbd5e1}.football-holdem-card-discarding .football-holdem-card-redraw-flag{background:#ef4444;color:#fff}.football-holdem-card-back{display:block;width:var(--holdem-card-back-w, 34px);height:var(--holdem-card-back-h, 48px);border-radius:6px;background:repeating-linear-gradient(45deg,rgba(255,255,255,.08) 0 6px,transparent 6px 12px),linear-gradient(160deg,#7c3aed,#4c1d95);border:2px solid rgba(255,255,255,.25);box-shadow:0 4px 10px #0006}.football-holdem-card-back-lg{width:var(--holdem-card-back-lg-w, 64px);height:var(--holdem-card-back-lg-h, 88px);border-radius:10px}.football-holdem-deck-stack{position:relative;display:flex;justify-content:center}.football-holdem-deck-stack .football-holdem-card-back:nth-child(2){position:absolute;left:4px;top:4px}.football-holdem-deck-stack .football-holdem-card-back:nth-child(3){position:absolute;left:8px;top:8px}.football-holdem-hand{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}.football-holdem-hand-fan{flex-wrap:nowrap;gap:0;align-items:flex-end;justify-content:center;padding:var(--holdem-fan-pad-top, 10px) 0 var(--holdem-fan-pad-bottom, 16px);min-height:calc(var(--holdem-hand-fan-min-height, 120px) + var(--holdem-fan-pad-top, 8px) + var(--holdem-fan-pad-bottom, 14px));max-width:100%}.football-holdem-hand-fan .football-holdem-card{transform-origin:bottom center;transform:translateY(var(--fan-y, 0px)) rotate(var(--fan-rotate, 0deg));margin:0 var(--holdem-fan-overlap, -16px);transition:transform .18s ease,box-shadow .18s ease}.football-holdem-hand-fan .football-holdem-card:not(:disabled):hover{transform:translateY(var(--fan-y, 0px)) rotate(0) scale(1.14);z-index:50;box-shadow:0 16px 32px #0000008c}.football-holdem-hand-fan .football-holdem-card-selected,.football-holdem-hand-fan .football-holdem-card-selected:not(:disabled):hover{transform:translateY(-14px) rotate(0);z-index:45}.football-holdem-hand-fan .football-holdem-card-discarding{transform:translateY(calc(var(--fan-y, 0px) - 18px)) rotate(var(--fan-rotate, 0deg));z-index:30}.football-holdem-table{min-height:170px;display:flex;align-items:center;justify-content:center;padding:.8rem;border-radius:16px;background:#0f172a80;border:1px dashed rgba(148,163,184,.25)}.football-holdem-played-row,.football-holdem-reveal-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;flex-shrink:0;min-height:var(--holdem-play-slot-height);align-items:flex-end}.football-holdem-played{display:flex;flex-direction:column;align-items:center;gap:0}.football-holdem-play-slot{width:var(--holdem-card-w);min-height:var(--holdem-play-slot-height);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.3rem;flex-shrink:0}.football-holdem-play-slot-card{width:100%;height:var(--holdem-play-slot-card-height);display:flex;align-items:center;justify-content:center;flex-shrink:0}.football-holdem-played-empty{width:var(--holdem-card-w);height:var(--holdem-play-slot-card-height);border-radius:10px;border:2px dashed rgba(148,163,184,.3);display:flex;align-items:center;justify-content:center;text-align:center;font-size:.7rem;color:#64748b;padding:.35rem}.football-holdem-played .football-holdem-card-face{width:100%;max-width:var(--holdem-card-w);background:linear-gradient(160deg,#1e293b,#0f172a);border-radius:10px;box-sizing:border-box}.football-holdem-played-owner{font-size:.78rem;font-weight:600;color:#cbd5e1}.football-holdem-played.is-revealed{animation:football-holdem-flip-in .4s ease}@keyframes football-holdem-flip-in{0%{transform:rotateY(90deg);opacity:0}to{transform:rotateY(0);opacity:1}}.football-holdem-played.is-winner .football-holdem-card-face{box-shadow:0 0 0 2px #4ade80,0 8px 22px #4ade8073;border-radius:12px}.football-holdem-poker-table{position:relative;display:flex;flex-direction:column;align-items:center;gap:.85rem;padding:1.35rem 2rem 1.15rem;border-radius:46%/34%;--holdem-card-w: clamp(100px, 11vw, 120px);--holdem-card-photo: calc(var(--holdem-card-w) * .48);--holdem-play-slot-height: calc(var(--holdem-card-w) * 2.05);--holdem-play-slot-card-height: calc(var(--holdem-card-w) * 1.82);--holdem-table-center-banner-reserve: 2.85rem;--holdem-table-center-note-reserve: 1.35rem;--holdem-table-center-height: calc( 1.3rem + var(--holdem-table-center-banner-reserve) + var(--holdem-table-center-note-reserve) + var(--holdem-play-slot-height) );--holdem-card-back-w: 34px;--holdem-card-back-h: 48px;--holdem-fan-overlap: calc(var(--holdem-card-w) * -.19);--holdem-fan-pad-top: 8px;--holdem-fan-pad-bottom: 14px;--holdem-hand-fan-min-height: calc(var(--holdem-card-w) * 1.28);--holdem-seat-me-min-height: calc( var(--holdem-hand-fan-min-height) + var(--holdem-fan-pad-top) + var(--holdem-fan-pad-bottom) + 2.75rem + .5rem );--holdem-table-min-height: calc( 4.5rem + var(--holdem-table-center-height) + var(--holdem-seat-me-min-height) + 2rem );background:radial-gradient(ellipse at 50% 42%,#1f7a4d,#15663f 45%,#0e4a2d);border:12px solid #3b2417;box-shadow:inset 0 0 60px #0000008c,inset 0 0 0 3px #00000040,0 18px 40px #00000073;transform:scale(var(--holdem-table-scale, 1));transform-origin:top center;width:100%;max-width:900px;margin:0 auto;min-height:var(--holdem-table-min-height);scroll-margin-top:calc(var(--site-header-height) + var(--holdem-hud-height, 0px));--holdem-rail-inset: clamp(2.75rem, 13vw, 5.5rem)}.football-holdem-poker-table:before{content:"";position:absolute;inset:var(--holdem-rail-inset);border:1px solid rgba(255,255,255,.07);border-radius:inherit;pointer-events:none}.football-holdem-table-center .football-holdem-card{width:var(--holdem-card-w)}.football-holdem-table-center .football-holdem-card-photo{width:var(--holdem-card-photo);height:var(--holdem-card-photo)}.football-holdem-table-center .football-holdem-card-name{font-size:.72rem;min-height:1.65em}.football-holdem-table-center .football-holdem-card-face{padding:.4rem .35rem .45rem}.football-holdem-seats-top{display:flex;justify-content:center;align-items:flex-start;gap:2.5rem;flex-wrap:wrap;width:100%}.football-holdem-seat{display:flex;flex-direction:column;align-items:center;gap:.45rem}.football-holdem-seat-opponent{min-width:88px;transition:opacity .2s ease,transform .2s ease}.football-holdem-seat-opponent.is-eliminated{opacity:.45}.football-holdem-seat-opponent.is-winner{transform:translateY(-4px)}.football-holdem-seat-info{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.3rem .7rem;border-radius:10px;background:#0818108c;border:1px solid rgba(255,255,255,.12)}.football-holdem-seat-opponent.is-winner .football-holdem-seat-info{border-color:#4ade80;box-shadow:0 0 0 1px #4ade80,0 0 18px #4ade8073}.football-holdem-seat-name{font-weight:700;color:#f1f5f9;font-size:.9rem}.football-holdem-seat-turns{font-size:.78rem;font-weight:700;color:#fcd34d}.football-holdem-seat-score{display:inline-flex;align-items:baseline;gap:.3rem}.football-holdem-seat-score-value{font-size:1.15rem;font-weight:800;color:#fcd34d;line-height:1}.football-holdem-seat-score-label{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8}.football-holdem-score-turns .football-holdem-seat-score-value{font-size:1.5rem;color:#f0abfc}.football-holdem-seat-me-info{flex-direction:row;align-items:center;gap:.6rem;margin:0 auto .5rem;background:#7c3aed47;border-color:#a78bfa99}.football-holdem-seat-place{font-size:.72rem;color:#cbd5e1}.football-holdem-seat-fan{display:flex;justify-content:center;height:32px;padding-left:10px}.football-holdem-seat-card{width:22px;height:32px;border-radius:4px;border-width:1px;margin-left:-11px;box-shadow:0 2px 5px #00000073}.football-holdem-seat-played{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.12rem .5rem;border-radius:999px;background:#08181099;color:#94a3b8}.football-holdem-seat-played.is-played{background:#4ade80;color:#0e4a2d}.football-holdem-table-center{height:var(--holdem-table-center-height);min-height:var(--holdem-table-center-height);max-height:var(--holdem-table-center-height);width:min(94%,560px);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;box-sizing:border-box;overflow:hidden}.football-holdem-table-center-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;flex:1;min-height:0;gap:.35rem}.football-holdem-table-center-meta{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;width:100%;min-height:calc(var(--holdem-table-center-banner-reserve) + var(--holdem-table-center-note-reserve));flex-shrink:0}.football-holdem-joker-response-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;width:100%;min-height:var(--holdem-play-slot-height)}.football-holdem-seat-me{width:100%;min-height:var(--holdem-seat-me-min-height, 200px)}.football-holdem-seat-me .football-holdem-hand{margin-bottom:.5rem}.football-holdem-redraw-actions,.football-holdem-play-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-height:2.75rem;justify-content:center}.football-holdem-play-actions .football-holdem-play-btn:disabled,.football-holdem-play-actions .football-holdem-play-btn.is-submit-disabled{opacity:.42;cursor:not-allowed;transform:none;filter:grayscale(.55) brightness(.85);box-shadow:none;pointer-events:none}.football-holdem-play-actions .football-holdem-play-btn:disabled:hover,.football-holdem-play-actions .football-holdem-play-btn.is-submit-disabled:hover{transform:none;background:linear-gradient(45deg,#059669,#1e40af)}.football-holdem-redraw-count{color:#cbd5e1;margin:0}.football-holdem-hint{color:#94a3b8;font-style:italic;margin:0}.football-holdem-waiting{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#cbd5e1;padding:1.5rem}.football-holdem-eliminated-note{text-align:center;color:#94a3b8;padding:1rem}.football-holdem-error{text-align:center;color:#fca5a5;font-weight:600}.football-holdem-joker-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem .75rem;margin-bottom:.75rem;padding:.65rem .85rem;border-radius:12px;background:#0f172a8c;border:1px solid rgba(148,163,184,.15)}.football-holdem-joker-bar-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;margin-right:.25rem}.football-holdem-joker-btn{position:relative;display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem;border-radius:999px;border:1px solid rgba(167,139,250,.35);background:#7c3aed26;color:#e9d5ff;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease}.football-holdem-joker-btn:not(:disabled):hover{background:#7c3aed47;border-color:#a78bfa8c}.football-holdem-joker-btn:disabled{opacity:.4;cursor:not-allowed}.football-holdem-joker-btn.is-active{background:#7c3aed66;border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa59}.football-holdem-joker-uses{display:inline-flex;align-items:center;justify-content:center;min-width:1.15rem;height:1.15rem;padding:0 .25rem;border-radius:999px;background:#00000059;font-size:.7rem;font-weight:700}.football-holdem-joker-notice,.football-holdem-scan-hint{text-align:center;color:#c4b5fd;font-size:.9rem;margin:0 0 .65rem}.football-holdem-scan-result{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem;padding:.55rem .85rem;border-radius:10px;background:#22c55e1f;border:1px solid rgba(34,197,94,.35);color:#bbf7d0;font-weight:600}.football-holdem-scan-dismiss{border:none;background:transparent;color:inherit;font-size:1.2rem;line-height:1;cursor:pointer;opacity:.75}.football-holdem-lowball-badge,.football-holdem-waitandsee-badge{margin-left:.5rem;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.football-holdem-lowball-badge{background:#fbbf2433;border:1px solid rgba(251,191,36,.45);color:#fde68a}.football-holdem-waitandsee-badge{background:#60a5fa2e;border:1px solid rgba(96,165,250,.45);color:#bfdbfe}.football-holdem-played.is-opponent-revealed{animation:football-holdem-flip-in .35s ease}.football-holdem-card-scan-target:not(:disabled){box-shadow:0 0 0 2px #22c55e8c}.football-holdem-card-scanned{box-shadow:0 0 0 2px #22c55ea6}.football-holdem-card-scanned .football-holdem-card-highlight{background:#22c55e26}.football-holdem-joker-reveal-banner{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem;margin:0;padding:.45rem .75rem;border-radius:10px;background:#7c3aed33;color:#e9d5ff;font-size:.85rem;font-weight:600}.football-holdem-joker-reveal-note{text-align:center;color:#fde68a;font-size:.85rem;margin:0}.settings-note{grid-column:1 / -1;color:#94a3b8;margin:0;font-style:italic}@media(max-width:640px){.football-holdem-poker-table{border-radius:48%/40%;padding:1.1rem 1rem 1rem;gap:.65rem;border-width:10px;--holdem-card-w: clamp(92px, 24vw, 110px);--holdem-rail-inset: clamp(2.5rem, 16vw, 5rem)}}@media(min-width:768px){.football-holdem-poker-table{border-radius:42%/28%;padding:1.5rem 2.75rem 1.25rem;gap:1rem;--holdem-card-w: clamp(108px, 10vw, 120px)}.football-holdem-table-center{width:min(88%,580px)}}@media(max-height:700px){.football-holdem-sticky-hud .football-holdem-title{font-size:.92rem}.football-holdem-sticky-hud .football-holdem-category-name{font-size:.85rem}.football-holdem-title{font-size:1.45rem}.football-holdem-category-banner{padding:.55rem .85rem;gap:.5rem}.football-holdem-category-name{font-size:1.2rem}.football-holdem-joker-bar{margin-bottom:.35rem;padding:.45rem .6rem;gap:.4rem .55rem}.football-holdem-poker-table{padding:1rem .95rem .9rem;gap:.6rem;border-width:9px}}
