:root{--bg:#0f172a;--bg-card:#1e293b;--bg-cell:#1e293b;--bg-cell-hover:#334155;--bg-cell-selected:#3b82f6;--bg-cell-highlight:#1e3a5f;--bg-cell-clue:#263548;--bg-conflict:#7f1d1d;--text:#f1f5f9;--text-muted:#94a3b8;--text-clue:#e2e8f0;--text-player:#60a5fa;--border:#334155;--border-thick:#64748b;--accent:#3b82f6;--accent-hover:#2563eb;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;color:var(--text);background:var(--bg);font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);justify-content:center;display:flex}#root{width:100%;max-width:900px;padding:1rem}.board{background:var(--border);border:2px solid var(--border-thick);aspect-ratio:1;-webkit-user-select:none;user-select:none;touch-action:manipulation;border-radius:8px;grid-template-rows:repeat(9,1fr);grid-template-columns:repeat(9,1fr);gap:1px;max-width:500px;margin:0 auto;display:grid;overflow:hidden}.cell{background:var(--bg-cell);cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;font-size:1.4rem;font-weight:600;transition:background .1s;display:flex;position:relative}.cell:hover{background:var(--bg-cell-hover)}.cell.selected{background:var(--bg-cell-selected);color:#fff}.cell.highlighted{background:var(--bg-cell-highlight)}.cell.clue{color:var(--text-clue);background:var(--bg-cell-clue)}.cell.clue.highlighted{background:#2a4a6b}.cell.player-value{color:var(--text-player)}.cell.conflict{background:var(--bg-conflict);color:#fca5a5}.cell.selected.conflict{background:#991b1b}.cell.box-right{border-right:2px solid var(--border-thick)}.cell.box-bottom{border-bottom:2px solid var(--border-thick)}.numpad{grid-template-columns:repeat(5,1fr);gap:.5rem;max-width:500px;margin:1rem auto 0;display:grid}.numpad button{border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:8px;min-height:44px;padding:.75rem;font-size:1.2rem;font-weight:600;transition:background .15s}.numpad button:hover{background:var(--bg-cell-hover)}.numpad button:active{background:var(--accent)}.numpad button.erase{background:#7f1d1d;border-color:#991b1b}.numpad button.erase:hover{background:#991b1b}.timer{font-variant-numeric:tabular-nums;color:var(--text);font-size:1.5rem;font-weight:700}.difficulty-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.difficulty-badge.easy{color:#bbf7d0;background:#166534}.difficulty-badge.medium{color:#fef08a;background:#854d0e}.difficulty-badge.hard{color:#fed7aa;background:#9a3412}.difficulty-badge.expert{color:#fecaca;background:#7f1d1d}.game-actions{gap:.5rem;max-width:500px;margin:.75rem auto 0;display:flex}.game-actions button{border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:8px;flex:1;min-height:44px;padding:.6rem;font-size:.85rem;font-weight:600;transition:background .15s}.game-actions button:hover{background:var(--bg-cell-hover)}.game-actions button:disabled{opacity:.4;cursor:not-allowed}.page{padding:2rem 0}.page h1{text-align:center;margin-bottom:1.5rem;font-size:2rem}.page h2{color:var(--text-muted);margin-bottom:1rem;font-size:1.3rem}.menu{flex-direction:column;align-items:center;gap:1rem;padding:3rem 0;display:flex}.menu h1{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:800}.menu p{color:var(--text-muted);margin-bottom:1rem}.menu-buttons{flex-direction:column;gap:1rem;width:100%;max-width:320px;display:flex}.btn-large{border-radius:12px;padding:1rem 2rem;font-size:1.2rem}.btn{cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;padding:.7rem 1.5rem;font-size:.9rem;font-weight:600;transition:background .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-cell-hover)}.btn-install{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border:none}.btn-install:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.btn-google{color:#333;cursor:pointer;background:#fff;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.7rem 1.5rem;font-weight:600;display:flex}.btn-google:hover{background:#f1f1f1}.nav{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem 0;display:flex}.nav-links{gap:1rem;display:flex}.nav-links a{color:var(--text-muted);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .15s}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-user{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.85rem;display:flex}.leaderboard-tabs{border:1px solid var(--border);border-radius:8px;gap:0;margin-bottom:1.5rem;display:flex;overflow:hidden}.leaderboard-tabs button{background:var(--bg-card);color:var(--text-muted);cursor:pointer;border:none;flex:1;padding:.6rem;font-size:.85rem;font-weight:600;transition:all .15s}.leaderboard-tabs button.active{background:var(--accent);color:#fff}.score-table{border-collapse:collapse;width:100%}.score-table th,.score-table td{text-align:left;border-bottom:1px solid var(--border);padding:.6rem .75rem}.score-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.score-table tr:hover td{background:var(--bg-card)}.rank-1{color:#fbbf24;font-weight:700}.rank-2{color:#d1d5db;font-weight:700}.rank-3{color:#d97706;font-weight:700}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:16px;width:90%;max-width:380px;padding:2rem}.modal h2{color:var(--success);margin-bottom:1rem;font-size:1.5rem}.modal .score-display{color:var(--accent);margin:.5rem 0;font-size:3rem;font-weight:800}.modal .stats{color:var(--text-muted);justify-content:center;gap:1.5rem;margin:1rem 0;font-size:.9rem;display:flex}.modal .stats strong{color:var(--text);font-size:1.1rem;display:block}.modal .actions{gap:.5rem;margin-top:1.5rem;display:flex}.modal .actions button{flex:1}.group-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:.75rem;padding:1rem}.group-card h3{margin-bottom:.25rem;font-size:1rem}.group-card .code{color:var(--accent);font-family:monospace;font-size:.9rem}.group-card .members{color:var(--text-muted);font-size:.8rem}.inline-form{gap:.5rem;margin-bottom:1rem;display:flex}.inline-form input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;flex:1;padding:.6rem .75rem;font-size:.9rem}.inline-form input::placeholder{color:var(--text-muted)}.loading{text-align:center;color:var(--text-muted);padding:3rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.lives{gap:.2rem;font-size:1.1rem;display:flex}.heart.active{color:var(--danger)}.heart.dead{color:var(--border)}.level-badge{background:var(--accent);color:#fff;border-radius:999px;padding:.25rem .6rem;font-size:.8rem;font-weight:700}.game-header{justify-content:space-between;align-items:center;gap:.5rem;max-width:500px;margin:0 auto;padding:.75rem 0;display:flex}.header-left,.header-right{align-items:center;gap:.5rem;display:flex}.total-score{color:var(--accent);font-size:.8rem;font-weight:600}.tutorial-page{max-width:540px;margin:0 auto}.tutorial-step-indicator{justify-content:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.step-dot{background:var(--border);cursor:pointer;border-radius:50%;width:10px;height:10px;transition:all .2s}.step-dot.active{background:var(--accent);transform:scale(1.3)}.step-dot.done{background:var(--success)}.tutorial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;min-height:360px;padding:1.5rem}.tutorial-card h2{color:var(--text);margin-bottom:.75rem;font-size:1.3rem}.tutorial-card p{color:var(--text-muted);margin-bottom:1rem;line-height:1.6}.mini-board{background:var(--border);border:2px solid var(--border-thick);aspect-ratio:1;-webkit-user-select:none;user-select:none;border-radius:6px;grid-template-rows:repeat(9,1fr);grid-template-columns:repeat(9,1fr);gap:1px;max-width:320px;margin:1rem auto;display:grid;overflow:hidden}.mini-cell{background:var(--bg-cell);color:var(--text-muted);justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.mini-cell.filled{color:var(--text-clue)}.mini-cell.highlight{color:var(--accent);background:#1e3a5f}.mini-cell.answer{background:var(--success);color:#fff;font-weight:800}.mini-cell.box-right{border-right:2px solid var(--border-thick)}.mini-cell.box-bottom{border-bottom:2px solid var(--border-thick)}.tutorial-rules-list{flex-direction:column;gap:1rem;margin-top:.5rem;display:flex}.rule-item{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.95rem;line-height:1.4;display:flex}.rule-icon{text-align:center;flex-shrink:0;width:2rem;font-size:1.5rem}.tutorial-nav{justify-content:space-between;gap:.75rem;margin-top:1.5rem;display:flex}.tutorial-nav button:disabled{opacity:.3;cursor:not-allowed}.update-banner{background:var(--bg-card);border-top:2px solid var(--accent);padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom));z-index:200;justify-content:space-between;align-items:center;gap:1rem;font-size:.9rem;font-weight:600;display:flex;position:fixed;bottom:0;left:0;right:0}.update-actions{flex-shrink:0;gap:.5rem;display:flex}.update-actions .btn{padding:.4rem .8rem;font-size:.8rem}.stats-overview{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:12px;flex-direction:column;gap:.25rem;padding:1rem .5rem;display:flex}.stat-card-accent{border-color:var(--accent)}.stat-value{color:var(--text);font-size:1.4rem;font-weight:800}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.difficulty-stats{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.difficulty-stat-row{color:var(--text-muted);gap:1rem;margin-top:.5rem;font-size:.85rem;display:flex}.stats-login-prompt,.stats-empty{text-align:center;color:var(--text-muted);padding:3rem 1rem}.stats-login-prompt p,.stats-empty p{margin-bottom:1rem}.ios-guide-steps{text-align:left;flex-direction:column;gap:1rem;margin-top:1.25rem;display:flex}.ios-step{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.95rem;line-height:1.4;display:flex}.ios-step strong{color:var(--text)}.ios-step-number{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;font-weight:700;display:flex}@media (width<=768px){.page{padding:1rem 0}}@media (width<=540px){.board{max-width:100%}.cell{font-size:1.1rem}.menu h1{font-size:2rem}.game-header{flex-wrap:wrap}.numpad,.game-actions{max-width:100%}.leaderboard-tabs button{padding:.5rem .25rem;font-size:.75rem}.score-table th,.score-table td{padding:.5rem;font-size:.85rem}.nav-links{gap:.5rem}.nav-links a{font-size:.8rem}}@media (width<=480px){.stats-overview{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:1.2rem}.difficulty-stat-row{flex-wrap:wrap;gap:.5rem}}@media (width<=375px){#root{padding:.5rem}.cell{font-size:.9rem}.numpad button{padding:.5rem;font-size:1rem}.game-actions button{padding:.5rem;font-size:.75rem}.game-header{gap:.25rem;padding:.5rem 0}.timer{font-size:1.2rem}.menu h1{font-size:1.6rem}.menu{gap:.75rem;padding:1.5rem 0}.btn-large{padding:.75rem 1.5rem;font-size:1rem}.tutorial-card{min-height:280px;padding:1rem}.modal{padding:1.25rem}.modal .score-display{font-size:2rem}}@media (height<=700px) and (width<=540px){.board{max-width:min(100%,70vw);margin:0 auto}.numpad{margin-top:.5rem}.numpad button{padding:.5rem}.game-header{padding:.25rem 0}.game-actions{margin-top:.5rem}.page{padding:.5rem 0}}@media (height<=500px) and (orientation:landscape){.board{max-width:min(45vh,300px)}.menu{gap:.5rem;padding:1rem 0}}
