.home{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;padding:1rem 2rem 2rem;width:100%;overflow-y:auto}.home-container{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:1.25rem}@media (max-width: 480px){.home{padding:1rem}.home-container{gap:1rem}.home-title{font-size:2.2rem}}.home-nav{width:100%;display:flex;justify-content:space-between;align-items:center}.home-back-link{color:var(--text-dim);text-decoration:none;font-size:.85rem;font-weight:500;transition:color .2s}.home-back-link:hover{color:var(--accent)}.home-share-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:.35rem;border-radius:6px;transition:color .2s,background .2s}.home-share-btn:hover{color:var(--accent);background:#7c5cff1f}.home-title{font-size:3rem;font-weight:800;letter-spacing:-.02em;line-height:1.1;text-align:center}.title-sudoku{color:var(--teal)}.title-feud{color:var(--coral)}.home-subtitle{color:var(--text-dim);font-size:1rem;margin-top:-.75rem}.home-section{width:100%;display:flex;flex-direction:column;gap:.5rem}.home-label{font-size:.85rem;font-weight:600;color:var(--text-dim)}.home-label-center{text-align:center}.home-input{width:100%;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;transition:border-color .2s ease}.home-input:focus{border-color:var(--teal)}.home-input::placeholder{color:var(--text-dim)}.difficulty-buttons{display:flex;gap:.5rem}.difficulty-btn{flex:1;padding:.6rem 1rem;background:var(--surface-hover);border:2px solid transparent;border-radius:10px;color:var(--text-dim);font-size:.9rem;font-weight:600;transition:all .2s ease}.difficulty-btn:hover{background:var(--surface-hover);border-color:var(--border-thick)}.difficulty-btn.active{background:var(--board-bg);border-color:var(--teal);color:var(--teal)}.home-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.home-actions .action-btn{width:100%;padding:1rem;font-size:1.1rem}.toggle-join-btn{width:100%;padding:1rem;background:transparent;color:var(--text-dim);border:1.5px solid rgba(255,255,255,.15);border-radius:10px;font-size:1.1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:all .2s ease}.toggle-join-btn:hover{color:var(--text);border-color:#ffffff4d}.btn-icon{font-size:1em}.join-section{display:flex;flex-direction:column!important;gap:.75rem}.join-input{width:100%}.join-btn{width:100%;padding:.85rem 1rem!important;background:var(--coral)!important;color:#fff!important;border:none!important;border-radius:10px!important;font-size:1rem!important;font-weight:700!important}.join-btn:hover:not(:disabled){filter:brightness(1.1)}.waiting-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem;margin-top:1.5rem}.waiting-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin 1s linear infinite}.waiting-text{font-size:1.25rem;font-weight:600;color:var(--text)}.waiting-label{font-size:.9rem;color:var(--text-dim)}.game-code-display{background:var(--surface);border:2px solid var(--border-thick);border-radius:12px;padding:1rem 2rem}.game-code{font-size:2.5rem;font-weight:800;letter-spacing:.15em;color:var(--teal);font-family:Courier New,monospace}.waiting-actions{display:flex;gap:.5rem;width:100%}.waiting-actions .copy-btn{flex:1}.copy-btn{min-width:140px}.cancel-btn{width:100%;padding:.85rem 1rem!important;background:transparent!important;color:var(--text-dim)!important;border:1px solid var(--border)!important;border-radius:10px!important;font-size:.95rem!important;font-weight:600!important}.cancel-btn:hover{color:var(--text)!important;border-color:var(--border-thick)!important}.cell{display:flex;align-items:center;justify-content:center;position:relative;background:var(--cell-bg);border:1px solid rgba(255,255,255,.08);transition:background-color .15s ease;-webkit-user-select:none;user-select:none}.cell-box-left{border-left:2.5px solid var(--border-thick)}.cell-box-right{border-right:2.5px solid var(--border-thick)}.cell-box-top{border-top:2.5px solid var(--border-thick)}.cell-box-bottom{border-bottom:2.5px solid var(--border-thick)}.cell-empty{cursor:pointer;background:var(--cell-empty)}.cell-empty:hover{background:var(--surface-hover)}.cell-prefilled{background:var(--cell-prefilled)}.cell-player1,.cell-player2{background:var(--cell-bg)}.cell-bonus-double{background:var(--bonus-double-bg)}.cell-bonus-triple{background:var(--bonus-triple-bg)}.cell-bonus-double.cell-player1,.cell-bonus-double.cell-player2{background:color-mix(in srgb,var(--bonus-double-bg) 50%,var(--cell-bg))}.cell-bonus-triple.cell-player1,.cell-bonus-triple.cell-player2{background:color-mix(in srgb,var(--bonus-triple-bg) 50%,var(--cell-bg))}.cell-selected{box-shadow:inset 0 0 0 2.5px var(--teal);background:#4db8a440!important;z-index:1}.cell-value{font-size:clamp(.9rem,3.5vw,1.5rem);font-weight:700;line-height:1}.cell-prefilled .cell-value{color:var(--text-prefilled);font-weight:500}.cell-tile{display:flex;align-items:center;justify-content:center;width:80%;height:80%;border-radius:3px;position:relative;box-shadow:0 2px 0 var(--tile-shadow)}.cell-tile-p1{background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent 50%),var(--tile-bg-p1)}.cell-tile-p2{background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent 50%),var(--tile-bg-p2)}.cell-tile .cell-value{color:var(--tile-text);font-weight:700}.cell-tile-accent{position:absolute;bottom:2px;left:15%;right:15%;height:2px;border-radius:1px}.cell-tile-accent-p1{background:var(--player1)}.cell-tile-accent-p2{background:var(--player2)}.cell-bonus-label{position:absolute;font-size:clamp(.7rem,2.8vw,1.2rem);font-weight:900;color:#fff6;line-height:1;z-index:0}.cell-bonus-label-behind{color:#ffffff26}.cell-bonus-badge{display:none}.board{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);gap:1.5px;background:var(--bg);border:2.5px solid var(--border-thick);width:100%;max-width:500px;aspect-ratio:1;margin:0 auto}.game{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1rem;width:100%;max-width:540px;min-height:100vh;justify-content:center}.score-bar{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;background:var(--surface);border-radius:12px;gap:.5rem}.score-player{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:90px;padding:.5rem;border-radius:8px;transition:transform .2s ease,background-color .2s ease}.score-player1.score-active{background:#4db8a41a;border:1px solid rgba(77,184,164,.3)}.score-player2.score-active{background:#e07b6e1a;border:1px solid rgba(224,123,110,.3)}.score-vs{font-size:.85rem;font-weight:800;color:var(--text-dim);flex-shrink:0}.score-name{font-size:.8rem;font-weight:600;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}.score-you{font-size:.7rem;opacity:.7}.score-value{font-size:1.75rem;font-weight:800;line-height:1;transition:color .3s ease}.score-value-p1{color:var(--player1)}.score-value-p2{color:var(--player2)}.game-status{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.5rem}.game-status-text{font-size:.9rem;font-weight:600;color:var(--text-dim)}.game-status-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.number-pad{display:flex;gap:.4rem;width:100%;max-width:500px}.number-btn{flex:1;aspect-ratio:1;max-height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent 50%),var(--tile-bg);border:none;border-radius:4px;color:var(--tile-text);font-size:1.25rem;font-weight:700;box-shadow:0 2px 0 var(--tile-shadow);transition:all .15s ease}.number-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 0 var(--tile-shadow)}.number-btn:active:not(:disabled){transform:translateY(1px);box-shadow:0 0 0 var(--tile-shadow)}.number-btn-exhausted{opacity:.25;background:var(--surface);color:var(--text-dim);box-shadow:none;text-decoration:line-through}.gameover-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .3s ease-out;padding:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gameover-modal{background:var(--surface);border:1px solid var(--border-thick);border-radius:20px;padding:2.5rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem;min-width:300px;max-width:400px;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.gameover-title{font-size:2rem;font-weight:800}.gameover-winner{font-size:1.1rem;color:var(--text-dim)}.gameover-scores{width:100%;display:flex;flex-direction:row;justify-content:center;gap:1.5rem;padding:1rem;background:#ffffff08;border-radius:12px}.gameover-score-col{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1;padding:1rem;border-radius:10px;background:#ffffff08}.gameover-score-name{font-size:1rem;font-weight:600}.gameover-score-val{font-size:2.25rem;font-weight:800}.gameover-actions{display:flex;gap:.75rem;width:100%;margin-top:.5rem}.gameover-actions .action-btn{flex:1;padding:.85rem 1rem}.game-toolbar{display:flex;justify-content:space-between;width:100%;padding:0 .25rem}.game-toolbar-btn{display:flex;align-items:center;gap:.3rem;background:var(--surface);color:var(--text-dim);font-size:.8rem;font-weight:600;padding:.45rem .75rem;border:1px solid var(--border);border-radius:8px;transition:all .15s ease}.game-toolbar-btn:hover{color:var(--text);border-color:var(--border-thick);background:var(--surface-hover)}.toolbar-icon{font-size:.75rem}.reset-proposal{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:var(--surface);border:1px solid var(--border-thick);border-radius:10px;font-size:.85rem;width:100%}.reset-proposal span{flex:1;color:var(--text)}.reset-proposal .action-btn{padding:.4rem .8rem;font-size:.8rem}.reset-waiting{text-align:center;color:var(--text-dim);font-size:.85rem;padding:.5rem}:root{--bg: #1a1a1f;--board-bg: #1a1a1f;--cell-bg: #2c2c34;--cell-empty: rgba(58, 58, 68, .5);--cell-prefilled: #2c2c34;--player1: #4db8a4;--player2: #e07b6e;--bonus-double-bg: #4a9ebf;--bonus-triple-bg: #d08b3e;--text: rgba(255, 255, 255, .95);--text-dim: rgba(255, 255, 255, .55);--text-prefilled: rgba(255, 255, 255, .72);--border: rgba(255, 255, 255, .15);--border-thick: rgba(255, 255, 255, .35);--selected: #4db8a4;--surface: #2c2c34;--surface-light: #3a3a44;--surface-hover: #3a3a44;--gold: #d4b44e;--coral: #e07b6e;--teal: #4db8a4;--tile-bg: #f2e8d5;--tile-bg-p1: #e8f4f1;--tile-bg-p2: #f4e8e6;--tile-text: #2a2a2a;--tile-shadow: rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}button{cursor:pointer;border:none;outline:none;font-family:inherit;font-size:inherit}button:disabled{cursor:not-allowed;opacity:.4}input{font-family:inherit;font-size:inherit;outline:none}.error-toast{position:fixed;top:1rem;left:50%;transform:translate(-50%);background:var(--coral);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;z-index:1000;cursor:pointer;animation:slideDown .3s ease-out;max-width:90vw}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.action-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem 1.5rem;border-radius:10px;font-size:1rem;font-weight:600;transition:transform .15s ease,background-color .2s ease}.action-btn:hover:not(:disabled){transform:translateY(-1px)}.action-btn:active:not(:disabled){transform:translateY(0)}.action-btn.primary{background:var(--teal);color:#0d0d0d}.action-btn.secondary{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}.action-btn.secondary:hover:not(:disabled){background:var(--surface-hover)}.text-player1{color:var(--player1)}.text-player2{color:var(--player2)}
