*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#1a1c20,#2c2f34);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}.menu-btn,.mode-button,.primary,.primary-button,.speaker-button{background:var(--menu-btn-bg);box-shadow:var(--menu-btn-shadow);color:var(--menu-btn-color)}.menu-btn.primary,.primary-button{background:var(--menu-btn-primary-bg)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--menu-btn-bg:#0b1220;--menu-btn-color:#e6eef8;--menu-btn-primary-bg:linear-gradient(180deg,#0f1724,#0b1220);--menu-btn-shadow:0 2px 8px #02061799;--landing-bg:#0f1724;--landing-accent:#3b82f6;--landing-muted:#94a3b8;--landing-text:#e6eef8}.App{background:linear-gradient(135deg,#1a1c20,#2c2f34);display:flex;flex-direction:column;min-height:100vh}.app-layout{display:flex;flex:1 1;height:100vh;overflow:hidden}.error-message{align-items:center;background:#f44;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;justify-content:space-between;left:50%;margin:0;max-width:calc(100% - 2rem);padding:1rem;position:fixed;top:1rem;transform:translateX(-50%);z-index:10000}.error-message button{background:none;border:none;color:#fff;cursor:pointer;font-size:1.5rem;padding:0 .5rem}@media (max-width:768px){.app-layout{flex-direction:column}.gameboard-area{padding:1rem}}.auth-menu-container{position:relative}.auth-avatar-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;height:32px;justify-content:center;transition:transform .2s ease,box-shadow .2s ease;width:32px}.auth-avatar-button:hover{box-shadow:0 2px 8px #667eea66;transform:scale(1.05)}.auth-dropdown{background:#2c2f34fa;border:1px solid #ffffff1a;border-radius:8px;bottom:100%;box-shadow:0 4px 12px #0000004d;left:0;margin-bottom:8px;min-width:120px;padding:.5rem;position:absolute;z-index:1000}.auth-dropdown-name{border-bottom:1px solid #ffffff1a;color:#ffffffb3;font-size:.85rem;margin-bottom:.25rem;overflow:hidden;padding:.25rem .5rem;text-overflow:ellipsis;white-space:nowrap}.auth-dropdown-logout{background:#0000;border:none;border-radius:4px;color:#ff6b6b;cursor:pointer;font-size:.85rem;padding:.4rem .5rem;text-align:left;transition:background .2s ease;width:100%}.auth-dropdown-logout:hover{background:#ff6b6b26}.auth-login-button{min-width:32px}.auth-user-info{align-items:center;background:#ffffff0f;border-radius:10px;display:flex;gap:.75rem;padding:.75rem}.auth-user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.2rem;font-weight:700;height:40px;justify-content:center;width:40px}.auth-user-details{flex:1 1;min-width:0}.auth-user-name{color:#fff;font-size:.95rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-logout-btn{background:#0000;border:none;color:#fff9;cursor:pointer;font-size:.8rem;padding:.25rem 0;transition:color .2s ease}.auth-logout-btn:hover{color:#ff6b6b}.auth-dropdown-item{background:#0000;border:none;border-radius:4px;color:#ffffffb3;cursor:pointer;font-size:.85rem;padding:.4rem .5rem;text-align:left;transition:background .2s ease;width:100%}.auth-dropdown-item:hover{background:#ffffff0f}.auth-dropdown-separator{border-top:1px solid #ffffff1a;margin:.25rem 0}.landing-page{background:linear-gradient(180deg,#071024,#071827);color:#e6eef8;color:var(--landing-text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;min-height:100vh}.landing-container{margin:0 auto;max-width:980px;padding:24px}.landing-header{padding:28px 0}.landing-header h1{font-size:2rem;margin:0}.landing-tagline{color:#94a3b8;color:var(--landing-muted);margin:4px 0 0}.landing-hero{background:#ffffff05;border-radius:12px;margin-top:18px;padding:48px 24px;text-align:center}.landing-hero h2{font-size:1.6rem;margin:0 0 8px}.landing-lead{color:#94a3b8;color:var(--landing-muted);margin:0 auto 18px;max-width:56ch}.landing-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.landing-btn{background:#3b82f6;background:var(--landing-accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:10px 18px;text-decoration:none}.landing-btn:hover{opacity:.9}.landing-features{background:#ffffff03;border-radius:10px;margin-top:24px;padding:18px}.landing-features a{color:#3b82f6;color:var(--landing-accent)}.landing-features a:hover{opacity:.8}.landing-footer{color:#94a3b8;color:var(--landing-muted);padding:28px 0;text-align:center}@media (max-width:480px){.landing-container{padding:16px}.landing-hero{padding:28px}}.gameboard-area{align-items:center;display:flex;flex:1 1;justify-content:center;padding:2rem;position:relative}.blurred-board{filter:blur(8px);opacity:.3;pointer-events:none}.lobby-stage{align-items:center;display:flex;justify-content:center;position:relative}.lobby-overlay{position:absolute;z-index:1}.countdown-overlay,.game-finished,.lobby-waiting{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0000004d;color:#fff;padding:3rem 2rem;text-align:center}.countdown-overlay{flex-direction:column;gap:1rem}.countdown-circle,.countdown-overlay{align-items:center;display:flex;justify-content:center}.countdown-circle{animation:pulse 1s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 8px 32px #667eea80;height:150px;width:150px}.countdown-number{color:#fff;font-size:4rem;font-weight:900;text-shadow:0 4px 8px #0000004d}.countdown-text{color:#fff;font-size:1.5rem;font-weight:600;letter-spacing:2px;margin:0;text-transform:uppercase}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.game-finished h2,.lobby-waiting h2{font-size:2rem;margin-bottom:1rem}.lobby-waiting p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.back-to-menu-btn,.start-game-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:all .3s ease}.back-to-menu-btn:hover,.start-game-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.final-scores{margin:2rem 0}.final-scores h3{font-size:1.5rem;margin-bottom:1rem}.final-score-item{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;font-size:1.1rem;gap:1rem;margin-bottom:.75rem;padding:1rem}.final-score-item .rank{font-size:1.5rem;font-weight:700;min-width:2rem}.final-score-item .name{flex:1 1;font-weight:600}.final-score-item .score{color:gold;font-size:1.3rem;font-weight:700}.post-game-controls{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem;max-width:300px;width:100%}.waiting-for-host{margin-top:1.5rem}.waiting-for-host p{font-size:1.1rem;margin-bottom:1.5rem;opacity:.9}.placeholder-btn{background:#ffffff1a;border:none;border-radius:8px;color:#ffffff80;cursor:not-allowed;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.placeholder-btn:hover{background:#ffffff26}.game-screen{display:flex;flex:1 1;justify-content:center;padding:2rem 1rem}.game-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0000004d;max-width:1400px;padding:2rem;width:100%}.game-content{align-items:flex-start;display:flex;gap:2rem}.game-area{display:flex;flex:1 1;flex-direction:column}.players-sidebar{flex-shrink:0;width:300px}.game-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.lobby-info{display:flex;flex-direction:column;gap:.5rem}.lobby-code{background:#fff3;border-radius:8px;font-size:1.2rem;font-weight:700;padding:.5rem 1rem}.player-name{font-size:.9rem;opacity:.9}.leave-button{background:#f44c;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.leave-button:hover{background:#f44;transform:translateY(-2px)}.game-status{background:#ffffff1a;border-radius:8px;margin-bottom:2rem;padding:1.5rem;text-align:center}.game-status h2{font-size:1.8rem;margin-bottom:.5rem}.game-status p{font-size:1rem;opacity:.9}.winner{color:gold;font-size:1.2rem;font-weight:600}.players-list{margin-bottom:2rem}.players-list h3{font-size:1.3rem;margin-bottom:1rem}.scoreboard{display:flex;flex-direction:column;gap:.75rem}.player-item{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.player-item.current-player{background:#667eea4d;border:2px solid #667eea80}.player-item.winner{background:#ffd70033;border:2px solid #ffd70080}.player-rank{font-size:1.5rem;font-weight:700;min-width:2rem;text-align:center}.player-info{align-items:center;display:flex;flex:1 1;gap:.5rem}.player-display-name{font-size:1.1rem;font-weight:600}.you-badge{background:#667eea80;border-radius:4px;font-size:.8rem;padding:.2rem .5rem}.player-score{font-size:1.2rem;font-weight:700}.game-controls{display:flex;justify-content:center;margin-top:2rem}.fruitbox-container{align-items:center;display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.game-end-controls{display:flex;justify-content:center;margin-top:1rem}.control-button{border:none;border-radius:8px;box-shadow:0 4px 6px #0003;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.start-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.control-button:hover{box-shadow:0 6px 12px #0000004d;transform:translateY(-2px)}.point-controls{display:flex;flex-direction:column;gap:1rem;max-width:400px;width:100%}.point-input-group{display:flex;flex-direction:column;gap:.5rem}.point-input-group label{font-weight:600}.point-input-group input{background:#ffffff1a;border:2px solid #ffffff4d;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem}.point-input-group input:focus{border-color:#fff9;outline:none}.send-button{background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff}.end-button{background:#f44c;color:#fff}.end-button:hover{background:#f44}@media (max-width:1024px){.game-content{flex-direction:column}.players-sidebar{width:100%}}@media (max-width:768px){.game-container{padding:1.5rem}.game-status h2{font-size:1.5rem}.player-rank{font-size:1.2rem;min-width:1.5rem}.player-display-name,.player-score{font-size:1rem}}@media (max-width:480px){.game-screen{padding:1rem .5rem}.game-container{padding:1rem}.game-header{align-items:flex-start;flex-direction:column}.lobby-code{font-size:1rem}.player-item{gap:.5rem;padding:.75rem}.control-button{font-size:.9rem;padding:.875rem 1.5rem}.point-controls{max-width:100%}}.solo-game-screen{flex:1 1;min-height:80vh;padding:2rem 1rem}.fruitgame-container,.solo-game-screen{align-items:center;display:flex;justify-content:center}.fruitbox-wrapper{align-items:center;display:flex;flex-direction:column;gap:1.5rem}.solo-controls{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.game-over-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0000004d;min-width:400px;padding:3rem 2rem;text-align:center}.game-over-container h2{color:#fff;font-size:2.5rem;margin-bottom:1rem}.final-score{color:gold;font-size:1.8rem;font-weight:700;margin-bottom:2rem}.game-over-buttons{display:flex;flex-direction:column;gap:1rem}.solo-game-screen .control-button{border:none;border-radius:8px;box-shadow:0 4px 6px #0003;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.solo-game-screen .control-button:hover{box-shadow:0 6px 12px #0000004d;transform:translateY(-2px)}.solo-game-screen .primary-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.solo-game-screen .back-button{background:#fff3;border:2px solid #ffffff4d;color:#fff}.solo-game-screen .back-button:hover{background:#ffffff4d}.solo-game-screen .end-button{background:#f44c;color:#fff}.solo-game-screen .end-button:hover{background:#f44}@media (max-width:768px){.game-over-container{max-width:400px;min-width:auto;padding:2rem 1.5rem;width:100%}.game-over-container h2{font-size:2rem}.final-score{font-size:1.5rem}.solo-game-screen .control-button{font-size:.9rem;padding:.875rem 1.5rem}}@media (max-width:480px){.solo-game-screen{padding:1rem .5rem}.game-over-container{padding:1.5rem 1rem}.game-over-container h2{font-size:1.5rem}.final-score{font-size:1.3rem}.solo-controls{width:100%}.solo-game-screen .control-button{flex:1 1;min-width:120px}}.left-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2c2f34f2;box-shadow:4px 0 12px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;gap:2rem;height:100vh;min-height:100vh;overflow-y:auto;padding:2rem;width:300px}.menu-top-bar{display:flex;justify-content:flex-start;margin-bottom:.5rem}.menu-header{text-align:center}.menu-header h2{color:#fff;font-size:1.8rem;margin-bottom:.5rem}.menu-header h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.menu-header-row{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.menu-subtitle{color:#fff;font-size:.9rem;opacity:.8}.menu-buttons,.menu-controls{display:flex;flex-direction:column;gap:1rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{color:#ffffffe6;font-size:.9rem;font-weight:600}.control-group input{background:#ffffff1a;border:2px solid #fff3;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem;transition:all .3s ease;width:100%}.control-group input::placeholder{color:#fff6}.control-group input:focus{background:#ffffff26;border-color:#667eea99;outline:none}.input-with-error{position:relative}.input-error-text{color:#fca5a5;font-size:.7rem;left:.25rem;letter-spacing:.01em;position:absolute;top:-.95rem}.back-icon-button{background:#0000;border:none;color:#fff;min-height:1.6rem;min-width:1.6rem;padding:.1rem}.back-icon-button:hover:not(:disabled){background:#0000}.join-lobby-row{display:flex;gap:.5rem;width:100%}.join-lobby-input{flex:1 1;min-width:0;width:100%}.seed-display{background:#ffffff1a;border:2px solid #fff3;border-radius:8px;color:#fff;font-family:Courier New,monospace;font-size:1rem;padding:.75rem;text-align:center}.leaderboard-toggle{background:#00000059;border:1px solid #ffffff1a;border-radius:10px;box-shadow:inset 0 1px 3px #0006;display:flex;gap:0;margin-bottom:.5rem;overflow:hidden;width:100%}.leaderboard-toggle-btn{background:#0000;border:none;color:#ffffff73;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;letter-spacing:.02em;padding:.55rem .5rem;transition:color .15s ease,background .15s ease,box-shadow .15s ease}.leaderboard-toggle-btn:hover:not(.active){background:#ffffff0d;color:#ffffffb3}.leaderboard-toggle-btn.active{background:linear-gradient(180deg,#295499,#264370);box-shadow:0 2px 6px #0206178c;color:#fff}.left-menu-scoreboard{display:flex;flex-direction:column;gap:.5rem}.left-menu-player-list{background:#ffffff05;border:1px solid #ffffff0a;border-radius:8px;max-height:18rem;overflow-y:auto;padding:.5rem}.left-menu-scoreboard .score-item{align-items:center;background:#ffffff1a;border-radius:6px;color:#fff;display:flex;gap:.5rem;padding:.5rem}.left-menu-scoreboard .score-item.current-player{background:#667eea4d;border:2px solid #667eea99}.left-menu-scoreboard .rank{font-size:1rem;font-weight:700;min-width:1.5rem;text-align:center}.left-menu-scoreboard .name{flex:1 1;font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.left-menu-scoreboard .score{color:gold;font-size:.9rem;font-weight:700}.icon-button{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.3rem;justify-content:center;min-height:1.8rem;min-width:1.8rem;padding:.2rem;transition:all .3s ease}.icon-button:hover:not(:disabled){background:#fff3}.icon-button:disabled{cursor:not-allowed;opacity:.5}.menu-btn{align-items:center;background:linear-gradient(180deg,#295499,#264370);border:none;border-radius:10px;box-shadow:0 2px 8px #02061799;box-shadow:var(--menu-btn-shadow,0 2px 8px #02061799);color:#fff;cursor:pointer;display:inline-flex;font-size:14px;gap:.6rem;padding:.9rem 1rem;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.menu-btn:active{transform:translateY(1px)}.menu-btn:focus{outline:3px solid #6366f11f}.menu-btn[disabled]{cursor:not-allowed;opacity:.6}.menu-btn.primary{background:linear-gradient(180deg,#0f1724,#0b1220);background:var(--menu-btn-primary-bg,linear-gradient(180deg,#0f1724 0,#0b1220 100%))}.menu-btn .btn-icon{font-size:18px}.menu-btn .btn-text{font-weight:600}.menu-btn--small{align-items:center;background:#5e6b80;border-radius:8px;color:#fff;display:inline-flex;font-size:18px;height:44px;justify-content:center;padding:0;width:44px}.menu-btn--small .btn-text{display:none}.menu-btn--small .btn-icon{pointer-events:none}.left-menu-footer{display:flex;justify-content:center;margin-top:auto;padding:10px}.footer-controls,.speaker-control{align-items:center;display:flex;gap:8px}.speaker-range{height:6px;width:110px}.start-error{background:#ff44440f;border:1px solid #ff44441f;border-radius:6px;color:#ffd6d6;font-size:.85rem;margin-top:.5rem;padding:.375rem .5rem}.icon-button-small{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;justify-content:center;min-width:2rem;padding:.25rem .5rem;transition:all .3s ease}.icon-button-small:hover{background:#fff3}.seed-display-with-copy{align-items:center;display:flex;gap:.5rem;position:relative}.settings-box{border-top:1px solid #ffffff0f;display:flex;flex-direction:column;gap:.75rem;padding-top:1rem}.setting-row{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.setting-label{color:#ffffffe6;font-weight:600}.setting-select{appearance:none;background:#ffffff1f;border:2px solid #ffffff2e;border-radius:8px;box-shadow:inset 0 1px 0 #ffffff05;color:#fff;min-width:160px;padding:.5rem .75rem}.setting-select:focus{background:#ffffff24;border-color:#667eeab3;outline:none}.setting-select option{background:#fff;color:#111}.setting-select::-webkit-text-fill-color{color:#fff}.volume-row{align-items:center;display:flex;gap:.75rem}.volume-label{color:#fffffff2;font-weight:600;min-width:140px}.volume-range{appearance:none;background:#ffffff1f;border-radius:6px;flex:1 1;height:8px}.volume-range::-webkit-slider-thumb{-webkit-appearance:none;background:#fff;border-radius:50%;box-shadow:0 2px 6px #0006;height:16px;width:16px}.volume-value{color:#ffffffe6;font-weight:600;min-width:44px;text-align:right}.copied-indicator{animation:fadeIn .3s ease;color:#4ade80;font-size:.8rem;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.left-menu-scoreboard .score-item.winner{background:#ffd70033;border:2px solid #ffd70080}.left-menu-scoreboard .score-item.winner .score{color:gold;font-size:1.1rem}.left-menu .post-game-controls{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.left-menu .waiting-for-host{margin-top:1rem}@media (max-width:768px){.left-menu{height:auto;min-height:100vh;width:100%}}.settings-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.settings-modal{background:#1c1e22;border:1px solid #ffffff0f;border-radius:12px;box-shadow:0 12px 40px #000000a6;display:flex;flex-direction:column;height:540px;left:50%;margin:0;max-height:88vh;max-width:calc(100% - 64px);overflow:hidden;padding:1.25rem;position:fixed;top:50%;transform:translate(-50%,-50%);width:760px}.settings-modal-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.settings-modal-body{display:flex;flex:1 1;gap:1rem;min-height:0;overflow:hidden}.settings-headers{display:flex;flex-direction:column;gap:.5rem;min-width:180px}.settings-header{background:#ffffff0a;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:.6rem .75rem;text-align:left}.settings-header.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea40;color:#fff}.settings-content{flex:1 1;min-height:0;overflow-y:auto;padding-left:.5rem}@media (max-width:640px){.settings-modal{border-radius:8px;height:auto;left:50%;max-height:84vh;top:8vh;transform:translateX(-50%);width:calc(100% - 24px)}.settings-headers{flex-direction:row;min-width:120px;overflow-x:auto}}.mode-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.mode-modal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff26;border-radius:20px;box-shadow:0 12px 48px #0006;max-width:600px;padding:3rem 2rem;text-align:center;width:100%}.mode-modal h2{color:#fff;font-size:2.5rem;margin-bottom:.5rem}.modal-subtitle{color:#fff;font-size:1.2rem;margin-bottom:2.5rem;opacity:.9}.mode-button-group{gap:1.5rem}.mode-button,.mode-button-group{display:flex;flex-direction:column}.mode-button{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:16px;cursor:pointer;padding:2rem;transition:all .3s ease}.mode-button:hover{background:#fff3;border-color:#fff6;box-shadow:0 8px 24px #0000004d;transform:translateY(-4px)}.solo-button:hover{background:#667eea4d;border-color:#667eea99}.multiplayer-button:hover{background:#764ba24d;border-color:#764ba299}.mode-icon{font-size:3rem;margin-bottom:1rem}.mode-title{color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.mode-description{color:#fff;font-size:.95rem;opacity:.85}@media (max-width:768px){.mode-modal{padding:2rem 1.5rem}.mode-modal h2{font-size:2rem}.modal-subtitle{font-size:1rem;margin-bottom:2rem}.mode-button{padding:1.5rem}.mode-icon{font-size:2.5rem}.mode-title{font-size:1.3rem}.mode-description{font-size:.85rem}}@media (max-width:480px){.mode-modal{padding:1.5rem 1rem}.mode-modal h2{font-size:1.5rem}.modal-subtitle{font-size:.9rem}.mode-button{padding:1.25rem}.mode-icon{font-size:2rem}.mode-title{font-size:1.1rem}}.sb-container{background:#2c2f34;border-radius:12px;box-sizing:border-box;color:#e0e0e0;font-family:inherit;max-width:100%;padding:24px;-webkit-user-select:none;user-select:none;width:520px}.sb-loading{color:#aaa;font-size:1.2rem;padding:60px 20px;text-align:center}.sb-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.sb-score{font-size:1.3rem;font-weight:700}.sb-word-count{color:#aaa;font-size:.9rem}.sb-timer-bar{align-items:center;background:#393c41;border-radius:8px;display:flex;height:28px;justify-content:center;margin-bottom:16px;overflow:hidden;position:relative}.sb-timer-text{color:#fff;font-size:.95rem;font-weight:700;position:relative;z-index:1}.sb-timer-up{color:#ff3c3c}.sb-timer-fill{background:#d4a017;border-radius:8px;height:100%;left:0;position:absolute;top:0;transition:width .5s}.sb-word-display{align-items:center;border-bottom:2px solid #555;display:flex;height:52px;justify-content:center;margin-bottom:8px;overflow:hidden;padding-bottom:8px;text-align:center}.sb-word-letters{font-size:1.8rem;font-weight:700;letter-spacing:2px;text-transform:uppercase}.sb-center-char{color:#d4a017}.sb-word-placeholder{color:#666;font-size:1.1rem;font-style:italic}.sb-feedback{animation:sb-fade-in .2s ease;border-radius:6px;font-size:1rem;font-weight:600;height:34px;margin-bottom:8px;overflow:hidden;padding:6px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.sb-feedback-hidden{animation:none;visibility:hidden}.sb-feedback-success{color:#4caf50}.sb-feedback-pangram{color:#d4a017;font-size:1.15rem}.sb-feedback-error{color:#ff5252}@keyframes sb-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sb-honeycomb{align-items:center;display:flex;flex-direction:column;margin:20px auto;width:201px}.sb-hex-row{display:flex;justify-content:center;width:100%}.sb-hex-row-pair{justify-content:space-between}.sb-hex-row+.sb-hex-row{margin-top:-30px}.sb-hex{align-items:center;border:none;clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:66px;justify-content:center;text-transform:uppercase;transition:transform .1s,background .15s;width:76px}.sb-hex:hover:not(:disabled){transform:scale(1.08)}.sb-hex:active:not(:disabled){transform:scale(.95)}.sb-hex:disabled{cursor:default;opacity:.5}.sb-hex-outer{background:#4a4d52;color:#e0e0e0}.sb-hex-outer:hover:not(:disabled){background:#5a5d62}.sb-hex-center{background:#d4a017;color:#1a1a1a}.sb-hex-center:hover:not(:disabled){background:#e0b030}.sb-actions{display:flex;gap:12px;justify-content:center;margin:16px 0}.sb-btn{background:#0000;border:2px solid #555;border-radius:24px;color:#e0e0e0;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 22px;transition:background .15s,border-color .15s}.sb-btn:hover:not(:disabled){background:#ffffff14;border-color:#888}.sb-btn:disabled{cursor:default;opacity:.4}.sb-btn-enter{border-color:#d4a017;color:#d4a017}.sb-btn-enter:hover:not(:disabled){background:#d4a01726}.sb-btn-shuffle{font-size:1.3rem;padding:10px 16px}.sb-found-words{border-top:1px solid #444;margin-top:16px;padding-top:12px}.sb-found-header{color:#bbb;font-size:.95rem;font-weight:600;margin-bottom:8px}.sb-found-list{display:flex;flex-wrap:wrap;gap:6px}.sb-found-empty{color:#666;font-size:.9rem;font-style:italic}.sb-found-word{background:#393c41;border-radius:12px;font-size:.85rem;padding:4px 10px;text-transform:capitalize}.sb-pangram{background:#d4a01740;color:#d4a017;font-weight:600}@media (max-width:500px){.sb-container{border-radius:8px;padding:12px}.sb-honeycomb{width:172px}.sb-hex{font-size:1.25rem;height:56px;width:65px}.sb-hex-row+.sb-hex-row{margin-top:-25px}.sb-word-letters{font-size:1.5rem}.sb-btn{font-size:.9rem;padding:8px 16px}}.sb-wrapper{align-items:flex-start;display:flex;gap:0;position:relative}.sb-btn-wordlist{background:#d4a0171a;border:2px solid #d4a017;border-radius:8px;color:#d4a017;cursor:pointer;display:block;font-size:.95rem;font-weight:600;margin-bottom:10px;padding:8px 16px;transition:background .15s;width:100%}.sb-btn-wordlist:hover{background:#d4a01740}.sb-wordlist-panel{background:#2c2f34;border:1px solid #444;border-radius:12px;display:flex;flex-direction:column;flex-shrink:0;margin-left:16px;max-height:600px;overflow:hidden;width:240px}.sb-wordlist-header{align-items:center;border-bottom:1px solid #444;color:#e0e0e0;display:flex;font-size:.9rem;font-weight:700;justify-content:space-between;padding:12px 14px}.sb-wordlist-close{background:none;border:none;border-radius:4px;color:#aaa;cursor:pointer;font-size:1.1rem;padding:2px 6px}.sb-wordlist-close:hover{background:#ffffff1a;color:#fff}.sb-wordlist-body{flex:1 1;overflow-y:auto;padding:8px 0}.sb-wordlist-item{align-items:center;color:#888;display:flex;font-size:.88rem;justify-content:space-between;padding:5px 14px}.sb-wordlist-item.sb-wordlist-found{color:#e0e0e0}.sb-wordlist-item.sb-wordlist-pangram{color:#d4a017;font-weight:600}.sb-wordlist-item.sb-wordlist-pangram.sb-wordlist-found{color:#d4a017}.sb-wordlist-word{text-transform:capitalize}.sb-wordlist-meta{align-items:center;display:flex;font-size:.85rem;gap:6px}.sb-wordlist-badge{color:#d4a017}.sb-wordlist-check{color:#4caf50;font-weight:700}.sb-wordlist-body::-webkit-scrollbar{width:6px}.sb-wordlist-body::-webkit-scrollbar-track{background:#0000}.sb-wordlist-body::-webkit-scrollbar-thumb{background:#555;border-radius:3px}@media (max-width:700px){.sb-wrapper{align-items:center;flex-direction:column}.sb-wordlist-panel{box-shadow:0 8px 32px #00000080;left:50%;margin-left:0;max-height:70vh;max-width:340px;position:fixed;top:50%;transform:translate(-50%,-50%);width:85vw;z-index:1000}}.sb-app{min-height:100vh}.gameboard-area.sb-gameboard-area{overflow-y:auto;padding:2rem}.sb-home-placeholder{color:#e0e0e0;padding:60px 20px;text-align:center}.sb-home-title{color:#d4a017;font-size:2.2rem;font-weight:700;margin-bottom:12px}.sb-home-subtitle{color:#aaa;font-size:1.1rem}.sb-game-screen,.sb-solo-screen{display:flex;justify-content:center;width:100%}.tensai-menu{text-align:center}.tensai-menu h1{color:#e0e0e0}.tensai-play-btn{background:#60b43c;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:20px;padding:10px 40px}.tensai-seed-group{margin-top:20px}.tensai-label{color:#e0e0e0;font-size:18px}.tensai-seed-input{font-family:Consolas,monospace;font-size:16px;margin-left:8px;width:120px}.tensai-zen-group{margin-top:20px}.tensai-zen-checkbox{margin-left:8px}.tensai-score-row{align-items:center;display:flex;justify-content:space-between}.tensai-score-text{color:#e0e0e0;font-size:22px}.tensai-timer-bar{align-items:center;background:#393c41;border-radius:8px;display:flex;height:24px;justify-content:center;margin:16px 0;position:relative}.tensai-timer-text{color:#fff}.tensai-timer-text,.tensai-timer-text--expired{font-size:16px;font-weight:700;position:relative;z-index:1}.tensai-timer-text--expired{color:#ff3c3c}.lobby-screen{align-items:center;display:flex;flex:1 1;justify-content:center;padding:2rem 1rem}.lobby-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0000004d;max-width:500px;min-width:300px;padding:2rem;width:100%}.lobby-container h2{font-size:2rem;margin-bottom:.5rem;text-align:center}.lobby-container>p{margin-bottom:2rem;opacity:.9;text-align:center}.button-group{display:flex;flex-direction:column;gap:1rem}.lobby-screen .primary-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #0003;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.lobby-screen .primary-button:hover{box-shadow:0 6px 12px #0000004d;transform:translateY(-2px)}.lobby-screen .back-button{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:1rem;margin-bottom:1rem;opacity:.8;padding:.5rem;transition:opacity .3s ease}.lobby-screen .back-button:hover{opacity:1}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input{background:#ffffff1a;border:2px solid #ffffff4d;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem;transition:all .3s ease;width:100%}.form-group input::placeholder{color:#ffffff80}.form-group input:focus{background:#ffffff26;border-color:#fff9;outline:none}.lobby-screen form .primary-button{margin-top:1rem;width:100%}@media (max-width:768px){.lobby-container{padding:1.5rem}.lobby-container h2{font-size:1.5rem}}@media (max-width:480px){.lobby-screen{padding:1rem .5rem}.lobby-container{min-width:auto;padding:1.25rem}.lobby-screen .primary-button,.lobby-screen .secondary-button{font-size:.9rem;padding:.875rem 1.5rem}}
/*# sourceMappingURL=main.8414047e.css.map*/