.settings-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.settings-modal{background:var(--color-surface);border-radius:var(--border-radius-lg);width:90%;max-width:480px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:1.2rem;font-weight:700}.btn-close{width:32px;height:32px;padding:0;background:transparent;border:1px solid transparent;border-radius:50%;color:var(--color-text-muted);font-size:1rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.btn-close:hover{background:var(--color-surface-light);color:var(--color-text);border-color:var(--color-border)}.modal-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:24px}.modal-section{display:flex;flex-direction:column;gap:12px}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:0}.section-header{display:flex;align-items:center;justify-content:space-between}.btn-reset{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:4px 10px;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .15s ease}.btn-reset:hover{color:var(--color-text);border-color:var(--color-text)}.setting-row{display:flex;align-items:center;gap:12px}.setting-row label{font-size:.85rem;min-width:50px}.slider-group{flex:1;display:flex;align-items:center;gap:8px}.slider-group input[type=range]{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--color-border);border-radius:2px;outline:none}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer}.slider-group input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}.slider-value{font-size:.8rem;font-weight:600;min-width:36px;text-align:right;color:var(--color-text-muted)}.toggle-row{display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:12px}.toggle-label{font-size:.85rem}.toggle-track{width:44px;height:24px;background:var(--color-border);border-radius:12px;position:relative;transition:background .2s ease;flex-shrink:0}.toggle-track.active{background:var(--color-primary)}.toggle-track input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease}.toggle-track.active .toggle-thumb{transform:translate(20px)}.scheme-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.scheme-btn{padding:8px 6px;background:var(--color-surface-light);border:2px solid transparent;border-radius:var(--border-radius);color:var(--color-text);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-align:center;line-height:1.2}.scheme-btn:hover{border-color:var(--color-primary)}.scheme-btn.active{border-color:var(--color-primary);background:#e9456026}.bindings-editor{display:flex;flex-direction:column;gap:6px}.binding-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 10px;background:var(--color-surface-light);border-radius:var(--border-radius);transition:background .15s ease}.binding-row.listening{background:#4ecdc41a;box-shadow:0 0 0 1px var(--color-primary)}.action-label{font-size:.8rem;color:var(--color-text-muted);min-width:80px}.key-button{flex:1;max-width:130px;padding:6px 10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text);font-size:.8rem;font-weight:600;text-align:center;cursor:pointer;transition:all .15s ease;min-height:32px}.key-button:hover{border-color:var(--color-text-muted)}.key-button.listening{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.listening-text{font-weight:400;font-size:.75rem}.binding-error{padding:8px 10px;background:#e945601f;border:1px solid rgba(233,69,96,.25);border-radius:var(--border-radius);color:#ff6b6b;font-size:.8rem;text-align:center}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 20px;border-top:1px solid var(--color-border)}.btn-cancel{padding:8px 16px;background:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text);font-size:.85rem;cursor:pointer;transition:all .15s ease}.btn-cancel:hover{border-color:var(--color-text)}.btn-save{padding:8px 20px;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--border-radius);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-save:hover{filter:brightness(1.1)}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:transparent}.modal-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}@media(max-width:480px){.settings-modal{width:95%;max-height:90vh}.modal-header,.modal-body,.modal-footer{padding-left:16px;padding-right:16px}.scheme-selector{grid-template-columns:repeat(2,1fr)}.action-label{min-width:70px;font-size:.75rem}.key-button{max-width:110px}}.home-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.settings-toggle{position:absolute;top:16px;right:16px;width:40px;height:40px;padding:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:10}.settings-toggle:hover{background:var(--color-surface-light);color:var(--color-text);border-color:var(--color-primary)}.settings-toggle svg{width:20px;height:20px}.home-content{width:100%;max-width:440px;padding:32px;display:flex;flex-direction:column;align-items:center;gap:24px}.game-title{font-size:3rem;letter-spacing:.15em;background:linear-gradient(135deg,var(--color-primary),var(--player-lavender));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-subtitle{color:var(--color-text-muted);font-size:.95rem;margin-top:-12px}.menu-buttons{display:flex;flex-direction:column;gap:12px;width:100%}.menu-btn{width:100%;padding:14px 24px;font-size:1rem}.form-container{width:100%}.player-setup{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;color:var(--color-text-muted)}.form-actions{display:flex;gap:12px;margin-top:8px}.form-actions button{flex:1}.error-message{background:#ff6b6b1a;color:var(--color-error);padding:10px 14px;border-radius:var(--border-radius);font-size:.85rem;text-align:center}.home-footer{margin-top:32px;text-align:center;color:var(--color-text-muted);font-size:.8rem;display:flex;flex-direction:column;gap:8px}.footer-links{display:flex;gap:16px;justify-content:center;align-items:center}.version-tag{color:var(--color-text-muted);font-size:.7rem;opacity:.6;font-family:monospace}.built-by{color:var(--color-primary);text-decoration:none;font-weight:600;font-size:.8rem;opacity:.7;transition:opacity .15s ease}.built-by:hover{opacity:1}.peer-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-surface);border-radius:var(--border-radius);border:2px solid transparent;transition:all .15s ease}.peer-card.is-ready{border-color:var(--color-success)}.peer-card.is-local{background:var(--color-surface-light)}.peer-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0}.peer-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.peer-name-row{display:flex;align-items:center;gap:6px}.peer-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.host-badge{background:#ffc10733;color:#ffc107}.you-badge{background:#4ecdc433;color:#4ecdc4}.peer-meta{display:flex;align-items:center;gap:8px;font-size:.8rem}.peer-status{color:var(--color-text-muted)}.peer-status.ready{color:var(--color-success);font-weight:600}.peer-players{color:var(--color-text-muted);opacity:.7}.peer-actions{display:flex;gap:6px;flex-shrink:0}.btn-ready{width:32px;height:32px;padding:0;border-radius:50%;border:2px solid var(--color-border);background:transparent;color:var(--color-text-muted);font-size:1rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.btn-ready:hover{border-color:var(--color-success);color:var(--color-success)}.btn-kick{width:32px;height:32px;padding:0;border-radius:50%;border:2px solid transparent;background:transparent;color:var(--color-text-muted);font-size:1rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.btn-kick:hover{background:var(--color-error);color:#fff}@media(max-width:480px){.peer-card{padding:10px;gap:10px}.peer-avatar{width:36px;height:36px}}.settings-panel{display:flex;flex-direction:column;gap:20px}.panel-section{display:flex;flex-direction:column;gap:12px;background:var(--color-surface);border-radius:var(--border-radius-lg);padding:16px}.panel-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0}.options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.option-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;background:var(--color-surface-light);border:2px solid transparent;border-radius:var(--border-radius);color:var(--color-text);cursor:pointer;transition:all .15s ease;text-align:center}.option-card:hover{border-color:var(--color-primary)}.option-card.selected{border-color:var(--color-primary);background:#e9456026}.option-name{font-weight:600;font-size:.9rem}.option-desc{font-size:.75rem;color:var(--color-text-muted)}@media(max-width:480px){.options-grid{grid-template-columns:repeat(2,1fr);gap:6px}.option-card{padding:10px 6px}.option-name{font-size:.85rem}.option-desc{font-size:.7rem}}.connection-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;font-size:.75rem;font-weight:500;color:var(--color-text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background-color .3s ease}.status-dot.connected{animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.7}}.status-text{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.peer-count{color:var(--color-text);font-weight:600}.connection-status.compact{padding:2px;background:transparent;border:none}.connection-status.compact .status-text{display:none}.connection-status.is-multiplayer .status-dot.disconnected{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-2px)}40%{transform:translate(2px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}.lobby-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow-y:auto}.lobby-content{width:100%;max-width:480px;padding:32px;display:flex;flex-direction:column;gap:24px;animation:slideUp .3s ease-out}.lobby-header{display:flex;align-items:center;gap:16px}.lobby-title{font-size:1.6rem;font-weight:700;margin:0;letter-spacing:.05em}.room-section{display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--color-surface);padding:24px;border-radius:var(--border-radius-lg)}.room-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.room-code{display:flex;gap:6px;cursor:pointer;padding:8px}.room-char{font-size:2.5rem;font-weight:800;font-family:monospace;color:var(--color-primary);letter-spacing:.1em}.btn-copy{background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:6px 16px;border-radius:var(--border-radius);cursor:pointer;font-size:.85rem;transition:all .15s ease}.btn-copy:hover{border-color:var(--color-primary)}.btn-copy.copied{border-color:var(--color-success);color:var(--color-success)}.players-section{display:flex;flex-direction:column;gap:12px}.section-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0}.players-list{display:flex;flex-direction:column;gap:8px}.waiting-notice{text-align:center;color:var(--color-text-muted);font-size:.85rem;padding:16px;background:var(--color-surface);border-radius:var(--border-radius)}.lobby-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.btn-ready-toggle{padding:12px 20px;background:transparent;border:2px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .15s ease}.btn-ready-toggle:hover{border-color:var(--color-success);color:var(--color-success)}.btn-ready-toggle[aria-pressed=true]{border-color:var(--color-success);color:var(--color-success);background:#4caf501a}.btn-start{padding:12px 24px;background:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--border-radius);color:#fff;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .15s ease;letter-spacing:.03em}.btn-start:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-start:disabled{opacity:.5;cursor:not-allowed}.btn-start.all-ready{background:var(--color-success);border-color:var(--color-success);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #4caf5066}50%{box-shadow:0 0 0 8px #4caf5000}}@media(max-width:480px){.lobby-content{padding:20px;gap:20px}.lobby-title{font-size:1.3rem}.room-char{font-size:2rem}.lobby-footer{flex-direction:column}.btn-start,.btn-ready-toggle{width:100%}}.touch-controls{position:fixed;bottom:0;left:0;right:0;padding:12px;padding-bottom:max(12px,env(safe-area-inset-bottom));display:flex;justify-content:space-between;align-items:flex-end;z-index:50;touch-action:none;user-select:none;-webkit-user-select:none;pointer-events:none}.controls-side{pointer-events:auto;display:flex;gap:8px}.left-side{flex-direction:row;align-items:flex-end}.right-side{flex-direction:column;align-items:flex-end}.control-btn{width:72px;height:72px;min-height:72px;padding:0;font-size:2rem;font-weight:700;background:#ffffff1f;border:2px solid rgba(255,255,255,.15);border-radius:50%;color:var(--color-text, #ffffff);display:flex;align-items:center;justify-content:center;transition:all .1s ease;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.btn-icon{display:flex;align-items:center;justify-content:center}.control-btn:active{transform:scale(.92);background:#ffffff40;border-color:var(--color-primary, #4ecdc4)}.left-btn{background:#74b9ff26;border-color:#74b9ff40}.left-btn:active{background:#74b9ff59}.right-btn{background:#74b9ff26;border-color:#74b9ff40}.right-btn:active{background:#74b9ff59}.down-btn{background:#ffab9126;border-color:#ffab9140}.down-btn:active{background:#ffab9159}.rotate-btn{background:#4ecdc426;border-color:#4ecdc440}.rotate-btn:active{background:#4ecdc459}.drop-btn{width:auto;min-width:72px;height:56px;min-height:56px;padding:0 20px;font-size:.8rem;font-weight:700;letter-spacing:.15em;border-radius:28px;background:#e9456033;border-color:#e945604d}.drop-btn:active{background:#e9456066}@media(min-width:400px){.control-btn{width:80px;height:80px;min-height:80px;font-size:2.25rem}.drop-btn{height:60px;min-height:60px;padding:0 24px;font-size:.875rem}}@media(orientation:landscape)and (max-height:500px){.touch-controls{padding:8px 16px}.control-btn{width:56px;height:56px;min-height:56px;font-size:1.5rem}.drop-btn{height:48px;min-height:48px;padding:0 16px;font-size:.75rem}}@media(max-width:360px){.control-btn{width:60px;height:60px;min-height:60px;font-size:1.75rem}.drop-btn{height:52px;min-height:52px;padding:0 16px;font-size:.75rem}}@media(hover:hover)and (pointer:fine){.touch-controls{display:none!important}}.key-binding-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.key-binding-modal{background:var(--color-surface, #1a1a2e);border-radius:var(--border-radius-lg, 12px);padding:24px;min-width:340px;max-width:90vw;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--color-text, #ffffff)}.btn-close{background:none;border:none;color:var(--color-text-muted, #888);font-size:1.5rem;cursor:pointer;padding:0 4px;line-height:1}.btn-close:hover{color:var(--color-text, #ffffff)}.section-label{display:block;font-size:.875rem;color:var(--color-text-muted, #888);margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.scheme-section{margin-bottom:20px}.scheme-list{display:flex;flex-direction:column;gap:6px}.scheme-button{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px;background:var(--color-surface-light, rgba(255, 255, 255, .05));border:1px solid rgba(255,255,255,.1);border-radius:var(--border-radius, 8px);color:var(--color-text, #ffffff);cursor:pointer;transition:all .15s ease}.scheme-button:hover{background:#ffffff1a;border-color:#fff3}.scheme-button.active{background:#4ecdc426;border-color:var(--color-primary, #4ecdc4)}.scheme-name{font-size:.95rem;font-weight:600}.scheme-keys{font-size:.8rem;color:var(--color-text-muted, #888)}.bindings-section{margin-bottom:20px}.bindings-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.binding-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 10px;background:#ffffff08;border-radius:var(--border-radius, 8px);transition:background .15s ease}.binding-row.listening{background:#4ecdc41a;box-shadow:0 0 0 1px var(--color-primary, #4ecdc4)}.action-label{font-size:.875rem;color:var(--color-text, #ffffff);min-width:90px}.key-button{flex:1;max-width:140px;padding:8px 12px;background:var(--color-surface-light, rgba(255, 255, 255, .05));border:1px solid rgba(255,255,255,.15);border-radius:var(--border-radius, 8px);color:var(--color-text, #ffffff);font-size:.875rem;font-weight:600;text-align:center;cursor:pointer;transition:all .15s ease;min-height:36px}.key-button:hover{background:#ffffff1f;border-color:#ffffff40}.key-button.listening{background:var(--color-primary, #4ecdc4);border-color:var(--color-primary, #4ecdc4);color:#fff}.key-display{display:inline-block;min-width:20px}.listening-text{font-weight:400;font-size:.8rem}.btn-reset{width:100%;padding:8px;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:var(--border-radius, 8px);color:var(--color-text-muted, #888);font-size:.8rem;cursor:pointer;transition:all .15s ease}.btn-reset:hover{background:#ffffff0d;color:var(--color-text, #ffffff)}.error-message{padding:10px 12px;background:#e9456026;border:1px solid rgba(233,69,96,.3);border-radius:var(--border-radius, 8px);color:#ff6b6b;font-size:.8rem;margin-bottom:16px;text-align:center}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-actions button{min-width:90px;padding:10px 16px;border-radius:var(--border-radius, 8px);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--color-text, #ffffff)}.btn-secondary:hover{background:#ffffff1a}.btn-primary{background:var(--color-primary, #4ecdc4);border:1px solid var(--color-primary, #4ecdc4);color:#fff}.btn-primary:hover{opacity:.9}.reconnection-overlay{position:absolute;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .3s ease}.reconnection-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 40px;background:var(--color-surface);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);text-align:center;animation:slideUp .3s ease-out;max-width:360px}.reconnection-icon{font-size:3rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.reconnection-title{font-size:1.3rem;font-weight:700;color:var(--color-text);margin:0}.reconnection-message{font-size:.9rem;color:var(--color-text-muted);margin:0;line-height:1.5}.retry-count{font-size:.8rem;color:var(--color-warning, #FF8800);font-weight:600;margin:0}.reconnection-actions{display:flex;gap:10px;margin-top:8px}.reconnection-actions button{padding:10px 20px;font-size:.9rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;transition:all .15s ease}.reconnection-actions .btn-primary{background:var(--color-primary);border:1px solid var(--color-primary);color:#fff}.reconnection-actions .btn-primary:hover:not(:disabled){filter:brightness(1.1)}.reconnection-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.reconnection-actions .btn-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text)}.reconnection-actions .btn-secondary:hover{border-color:var(--color-text)}.reconnection-hint{font-size:.75rem;color:var(--color-text-muted);margin:0;opacity:.7;line-height:1.4}.game-screen{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.game-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--color-surface);flex-shrink:0;min-height:48px;gap:12px}.game-stats{display:flex;gap:24px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-label{font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.stat-value{font-size:1.2rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text)}.game-actions{display:flex;gap:8px}.icon-btn{padding:8px 12px;font-size:1rem;min-height:36px;min-width:36px}.back-btn{padding:8px 16px;font-size:.85rem;min-height:36px}.game-body{flex:1;display:flex;align-items:stretch;min-height:0;overflow:hidden}.game-sidebar{width:120px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;padding:12px 8px;background:var(--color-surface);align-items:center}.sidebar-panel{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:var(--color-surface-light);border-radius:var(--border-radius);width:100%}.panel-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700}.hold-preview,.active-preview{min-height:60px;display:flex;align-items:center;justify-content:center}.next-preview-list{display:flex;flex-direction:column;gap:8px;align-items:center;width:100%}.piece-preview{display:flex;flex-wrap:wrap}.preview-cell{border-radius:2px}.preview-cell.filled{box-shadow:inset 0 -2px #0000004d}.empty-preview{color:var(--color-text-muted);font-size:.9rem;opacity:.4}.game-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-background);position:relative;min-width:0}.game-canvas{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.notifications-overlay{position:absolute;top:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none;z-index:100}.notification{padding:10px 24px;border-radius:var(--border-radius);font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;animation:notif-in .3s ease-out,notif-out .4s ease-in 2s forwards;text-shadow:0 2px 4px rgba(0,0,0,.5)}.notification-success{background:#4ecdc4e6;color:#1a1a2e}.notification-info{background:#74b9ffe6;color:#1a1a2e}.notification-warning{background:#ffe66de6;color:#1a1a2e}.notification-error{background:#ff6b6be6;color:#fff}@keyframes notif-in{0%{opacity:0;transform:translateY(-20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes notif-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}.pause-overlay{position:absolute;inset:0;background:#1a1a2ed9;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200}.pause-content{text-align:center;animation:slideUp .3s ease-out}.pause-content h2{font-size:3rem;font-weight:800;color:var(--color-text);margin-bottom:24px;letter-spacing:.15em;text-shadow:0 4px 8px rgba(0,0,0,.5)}.pause-actions{display:flex;flex-direction:column;gap:12px;align-items:center}.pause-actions button{width:200px;font-size:1rem;padding:12px 24px}@media(max-width:768px){.game-sidebar{display:none}.game-stats{gap:16px}.stat-value{font-size:1rem}}@media(max-width:480px){.game-header{padding:4px 8px}.game-stats{gap:12px}.stat-label{font-size:.55rem}.stat-value{font-size:.9rem}}.gameover-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.gameover-content{width:100%;max-width:440px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:20px}.gameover-title{font-size:2.25rem;letter-spacing:.08em;color:var(--color-primary);margin:0}.high-score-badge{font-size:1rem;font-weight:700;color:var(--color-warning, #f0ad4e);letter-spacing:.05em;animation:pulse-glow 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.6}}.game-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.badge{font-size:.78rem;font-weight:600;padding:4px 10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;white-space:nowrap}.gameover-stats{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 24px;background:var(--color-surface);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.stat-row.score-row{width:100%;display:flex;justify-content:space-between;align-items:baseline;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.stat-label{font-size:.85rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-value.score-value{font-size:2rem;font-weight:800;font-variant-numeric:tabular-nums;color:var(--color-primary)}.stat-grid{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat-cell{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 0}.stat-cell-label{font-size:.72rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.stat-cell-value{font-size:1.2rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text)}.participants-section{width:100%;display:flex;flex-direction:column;gap:10px}.participants-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:0}.participants-list{display:flex;flex-wrap:wrap;gap:8px}.participant-chip{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px}.color-swatch{width:12px;height:12px;border-radius:50%;flex-shrink:0}.participant-name{font-size:.82rem;font-weight:600;color:var(--color-text)}.gameover-actions{display:flex;gap:10px;width:100%;margin-top:4px}.gameover-actions button{flex:1;padding:12px 16px;font-size:.9rem;font-weight:600}.btn-primary{background:var(--color-primary);border:1px solid var(--color-primary);color:#fff;border-radius:var(--border-radius);cursor:pointer;transition:all .15s ease}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--border-radius);cursor:pointer;transition:all .15s ease}.btn-secondary:hover{border-color:var(--color-text)}.btn-ghost{background:transparent;border:1px solid transparent;color:var(--color-text-muted);border-radius:var(--border-radius);cursor:pointer;transition:all .15s ease}.btn-ghost:hover{color:var(--color-text);border-color:var(--color-border)}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-slide-up{animation:slide-up .3s ease-out}@media(max-width:480px){.gameover-content{padding:20px 16px}.gameover-title{font-size:1.8rem}.stat-value.score-value{font-size:1.6rem}.gameover-actions{flex-wrap:wrap}.gameover-actions button{min-width:calc(50% - 5px)}}.highscores-screen{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:var(--color-background)}.highscores-content{width:100%;max-width:560px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:16px;overflow:hidden;flex:1}.highscores-header{display:flex;align-items:center;gap:12px;flex-shrink:0}.highscores-header .btn-back{width:40px;height:40px;min-height:40px;min-width:40px;padding:8px;background:var(--color-surface);border-radius:50%;color:var(--color-text);display:flex;align-items:center;justify-content:center;flex-shrink:0}.highscores-header .btn-back svg{width:100%;height:100%}.highscores-header .btn-clear{width:32px;height:32px;min-height:32px;min-width:32px;padding:4px;background:transparent;border:1px solid var(--color-surface-light);border-radius:50%;color:var(--color-text-muted);font-size:.8rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:auto}.highscores-header .btn-clear:hover{border-color:var(--color-error);color:var(--color-error)}.header-title{display:flex;align-items:center;gap:10px}.header-title .trophy-icon{width:28px;height:28px;color:gold}.header-title h1{font-size:1.4rem;font-weight:700;margin:0}.filter-tabs{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap}.filter-tab{padding:6px 14px;font-size:.8rem;font-weight:600;background:var(--color-surface);color:var(--color-text-muted);border:1px solid transparent;border-radius:20px;cursor:pointer;transition:all .15s ease}.filter-tab:hover{color:var(--color-text);border-color:var(--color-surface-light)}.filter-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;gap:16px}.empty-icon{width:72px;height:72px;color:var(--color-text-muted);opacity:.4}.empty-state h2{font-size:1.25rem;margin:0;color:var(--color-text)}.empty-state p{margin:0;color:var(--color-text-muted);font-size:.9rem}.empty-state .btn-primary{margin-top:8px}.scores-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-bottom:20px}.score-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--color-surface);border-radius:var(--border-radius);border:1px solid transparent;transition:all .2s ease}.score-row.top-three{padding:14px 16px}.score-row.gold{background:linear-gradient(135deg,#ffd7001f,#ffa50014);border-color:#ffd70040}.score-row.silver{background:linear-gradient(135deg,#c0c0c01f,#a0a0a014);border-color:#c0c0c040}.score-row.bronze{background:linear-gradient(135deg,#cd7f321f,#a0522d14);border-color:#cd7f3240}.rank-badge{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rank-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--color-text-muted);background:#ffffff14;border-radius:50%}.medal{width:32px;height:32px}.score-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.score-main{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.player-count{font-size:.7rem;font-weight:600;color:var(--color-text-muted);background:#ffffff14;padding:2px 6px;border-radius:4px}.score-value{font-size:1.15rem;font-weight:700;color:var(--color-primary);font-variant-numeric:tabular-nums}.top-three .score-value{font-size:1.35rem}.score-meta{font-size:.7rem;color:var(--color-text-muted)}.score-footer{display:flex;align-items:center;gap:8px}.difficulty-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border:1px solid;border-radius:10px}.co-op-badge{font-size:.6rem;font-weight:600;color:var(--color-text-muted);background:#a06cd526;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.05em}@media(max-width:400px){.score-main{flex-direction:column;gap:2px}.header-title h1{font-size:1.2rem}}.settings-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow-y:auto}.settings-content{width:100%;max-width:480px;padding:32px;display:flex;flex-direction:column;gap:28px}.settings-header{display:flex;align-items:center;gap:16px}.btn-back{background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:8px 14px;border-radius:var(--border-radius);cursor:pointer;font-size:.9rem;transition:all .15s ease;flex-shrink:0}.btn-back:hover{border-color:var(--color-primary);background:var(--color-surface-light)}.settings-title{font-size:1.8rem;font-weight:700;margin:0;letter-spacing:.05em}.settings-section{display:flex;flex-direction:column;gap:16px;background:var(--color-surface);border-radius:var(--border-radius-lg);padding:20px}.settings-section h2{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0}.setting-row{display:flex;flex-direction:column;gap:8px}.setting-row>label{font-size:.9rem;font-weight:500;color:var(--color-text)}.volume-control{display:flex;align-items:center;gap:10px}.volume-icon{font-size:1.2rem;opacity:.7}.volume-control input[type=range]{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--color-surface-light);border-radius:3px;outline:none}.volume-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-surface)}.volume-control input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-surface)}.volume-value{min-width:36px;text-align:right;font-size:.85rem;color:var(--color-text-muted);font-family:monospace}.difficulty-selector{display:flex;gap:8px}.difficulty-btn{flex:1;padding:10px 12px;background:var(--color-surface-light);border:2px solid transparent;border-radius:var(--border-radius);color:var(--color-text);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.difficulty-btn:hover{border-color:var(--color-primary)}.difficulty-btn.active{border-color:var(--color-primary);background:#e9456026;color:var(--color-primary)}.board-size-selector{display:flex;gap:8px}.size-btn{flex:1;padding:10px 12px;background:var(--color-surface-light);border:2px solid transparent;border-radius:var(--border-radius);color:var(--color-text);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.size-btn:hover{border-color:var(--color-primary)}.size-btn.active{border-color:var(--color-primary);background:#e9456026;color:var(--color-primary)}.about-info{display:flex;flex-direction:column;gap:4px;color:var(--color-text-muted);font-size:.85rem;text-align:center}.about-info p{margin:0}.about-info a{color:var(--color-primary);text-decoration:none}.about-info a:hover{text-decoration:underline}@media(max-width:480px){.settings-content{padding:20px}.settings-title{font-size:1.4rem}}.app{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}:root{--color-background: #1A1A2E;--color-surface: #16213E;--color-surface-light: #1F2B47;--color-primary: #E94560;--color-primary-hover: #FF6B6B;--color-text: #EAEAEA;--color-text-muted: #8B8B8B;--color-success: #4ECDC4;--color-warning: #FFE66D;--color-error: #FF6B6B;--player-coral: #FF6B6B;--player-ocean: #4ECDC4;--player-sunflower: #FFE66D;--player-lavender: #A06CD5;--player-mint: #95E1D3;--player-peach: #FFAB91;--player-sky: #74B9FF;--player-rose: #FD79A8;--cell-size: 24px;--touch-target: 48px;--border-radius: 8px;--border-radius-lg: 16px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation;user-select:none;-webkit-user-select:none}#root{display:flex;flex-direction:column}body{overscroll-behavior:none}button{font-family:inherit;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all .15s ease;min-height:var(--touch-target);padding:12px 24px}button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface-light);color:var(--color-text);border:2px solid var(--color-surface-light)}.btn-secondary:hover:not(:disabled){border-color:var(--color-primary)}input,select{font-family:inherit;font-size:1rem;padding:12px 16px;border:2px solid var(--color-surface-light);border-radius:var(--border-radius);background:var(--color-surface);color:var(--color-text);min-height:var(--touch-target);transition:border-color .15s ease}input:focus,select:focus{outline:none;border-color:var(--color-primary)}input::placeholder{color:var(--color-text-muted)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-up{animation:slideUp .4s ease}
