.header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);position:sticky;top:0;z-index:100}.header-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:56px;gap:16px}.header-logo{font-size:1.4rem;font-weight:800;letter-spacing:.1em;color:var(--text-primary);text-decoration:none;flex-shrink:0}.logo-accent{color:var(--accent)}.nav{display:flex;gap:4px}.nav a{color:var(--text-secondary);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;padding:8px 12px;border-radius:var(--radius);text-decoration:none;transition:all var(--transition)}.nav a:hover{color:var(--text-primary);background:var(--bg-tertiary)}.nav a.active{color:var(--accent);background:#538d4e1a}.header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.icon-btn{background:none;border:none;font-size:1.2rem;padding:6px;border-radius:var(--radius);cursor:pointer;line-height:1}.icon-btn:hover{background:var(--bg-tertiary)}.user-info{display:flex;align-items:center;gap:10px}.username{font-weight:600;font-size:.85rem;color:var(--text-primary)}.menu-toggle{display:none;background:none;border:none;padding:8px;cursor:pointer}.hamburger{display:block;width:20px;height:2px;background:var(--text-primary);position:relative;transition:all .3s}.hamburger:before,.hamburger:after{content:"";position:absolute;width:20px;height:2px;background:var(--text-primary);transition:all .3s}.hamburger:before{top:-6px}.hamburger:after{top:6px}.hamburger.open{background:transparent}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{top:0;transform:rotate(-45deg)}@media (max-width: 640px){.menu-toggle{display:block}.nav{display:none;position:absolute;top:56px;left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-direction:column;padding:8px;gap:2px}.nav-open{display:flex}.nav a{padding:12px 16px}.username{display:none}}.game-board{display:flex;flex-direction:column;align-items:center;gap:6px;margin:16px 0}.board-row{display:flex;gap:6px}.board-row.row-shake{animation:shake .5s ease}.tile{width:62px;height:62px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;text-transform:uppercase;border:2px solid var(--tile-border);border-radius:4px;-webkit-user-select:none;user-select:none;transition:border-color .1s}.tile-filled{border-color:var(--tile-active-border)}.tile-pop{animation:pop .1s ease}.tile-reveal{animation:flipIn .5s ease forwards}.tile-correct{background:var(--correct);border-color:var(--correct);color:#fff}.tile-present{background:var(--present);border-color:var(--present);color:#fff}.tile-absent{background:var(--absent);border-color:var(--absent);color:#fff}@media (max-width: 480px){.tile{width:52px;height:52px;font-size:1.6rem}}@media (max-width: 360px){.tile{width:46px;height:46px;font-size:1.4rem}.board-row,.game-board{gap:4px}}.keyboard{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0;max-width:520px;margin:0 auto;width:100%}.keyboard-row{display:flex;gap:5px;width:100%;justify-content:center}.key{height:56px;min-width:36px;flex:1;max-width:44px;background:var(--key-bg);color:var(--key-text);border:none;border-radius:6px;font-size:.85rem;font-weight:700;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.key:active{transform:scale(.95)}.key-wide{min-width:60px;max-width:72px;font-size:.7rem;letter-spacing:.05em}.key-correct{background:var(--correct);color:#fff}.key-present{background:var(--present);color:#fff}.key-absent{background:var(--absent);color:var(--text-muted)}.key-disabled{opacity:.7;cursor:default}@media (max-width: 480px){.key{height:50px;min-width:28px;font-size:.75rem}.key-wide{min-width:50px;font-size:.65rem}.keyboard-row{gap:4px}}.home-landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:20px}.landing-title{font-size:3.5rem;font-weight:800;letter-spacing:.15em}.landing-sub{color:var(--text-secondary);font-size:1.1rem;max-width:400px;line-height:1.6}.btn-large{padding:14px 40px;font-size:1rem}.home-container{display:flex;flex-direction:column;align-items:center}.game-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:340px;padding:8px 0}.game-date{font-size:.85rem;color:var(--text-secondary);font-weight:500}.game-error{background:var(--danger);color:#fff;padding:8px 20px;border-radius:var(--radius);font-size:.85rem;font-weight:600;margin-bottom:8px;animation:slideUp .3s ease}.game-result{text-align:center;padding:16px 0;animation:slideUp .4s ease}.result-text{font-size:1.2rem;font-weight:700;margin-bottom:8px}.result-win{color:var(--correct)}.result-lose{color:var(--text-secondary)}.result-score{font-size:1.5rem;font-weight:800;color:var(--accent)}.result-time{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.result-word{color:var(--text-secondary);font-size:.95rem}.result-word strong{color:var(--text-primary);text-transform:uppercase;letter-spacing:.1em}.achievement-toast{display:flex;align-items:center;gap:14px;padding:14px;background:var(--bg-tertiary);border-radius:var(--radius);margin-bottom:8px}.achievement-icon{font-size:2rem}.achievement-name{font-weight:700;font-size:.95rem}.achievement-desc{color:var(--text-secondary);font-size:.8rem;margin-top:2px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.mp-actions{display:flex;gap:12px;margin-bottom:24px}.mp-btn{flex:1;padding:16px;font-size:.95rem}.mp-notice{background:var(--bg-tertiary);color:var(--text-secondary);padding:12px 16px;border-radius:var(--radius);font-size:.85rem;margin-bottom:16px;text-align:center}.mp-error{background:#e74c3c26;color:var(--danger);padding:10px 14px;border-radius:var(--radius);font-size:.85rem;margin-bottom:16px;border:1px solid rgba(231,76,60,.3)}.mp-join-code{margin-bottom:24px}.mp-join-code h3,.mp-rooms h3{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:12px}.mp-rooms{margin-bottom:24px}.mp-empty{color:var(--text-muted);font-size:.9rem;text-align:center;padding:32px 0}.room-list{display:flex;flex-direction:column;gap:8px}.room-card{display:flex;align-items:center;justify-content:space-between;padding:16px}.room-host{font-weight:600;font-size:.95rem}.room-players{color:var(--text-secondary);font-size:.8rem;margin-top:2px}@media (max-width: 480px){.mp-actions{flex-direction:column}}.race-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}.race-sidebar{display:flex;flex-direction:column;gap:16px}.race-room-header{display:flex;align-items:center;justify-content:space-between}.race-room-header h3{font-size:1rem;font-weight:700}.race-waiting{padding:16px;background:var(--bg-tertiary);border-radius:var(--radius)}.race-status-label{font-size:.85rem;color:var(--text-secondary)}.room-code-display{margin-top:8px;font-size:.9rem;color:var(--text-primary);letter-spacing:.1em}.countdown-display{font-size:3rem;font-weight:800;text-align:center;color:var(--accent);animation:pop .5s ease}.race-timer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-tertiary);border-radius:var(--radius)}.timer-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;font-weight:600}.timer-value{font-size:1.2rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.05em}.player-list{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.player-list-title{padding:10px 14px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.player-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-color)}.player-item:last-child{border-bottom:none}.player-self{background:#538d4e14}.player-name{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:6px}.host-badge{font-size:.6rem;background:var(--accent);color:#fff;padding:2px 6px;border-radius:4px;font-weight:700}.player-status{font-size:.8rem}.status-solved{color:var(--correct);font-weight:700}.status-failed{color:var(--danger);font-weight:600}.status-playing{color:var(--text-secondary)}.race-game-area{display:flex;flex-direction:column;align-items:center}.race-pregame{display:flex;align-items:center;justify-content:center;min-height:400px}.countdown-big{font-size:6rem;font-weight:800;color:var(--accent);animation:pop .5s ease}.pregame-text{font-size:1.2rem;color:var(--text-secondary);font-weight:600}.race-personal-result{text-align:center;padding:12px 0;font-size:.95rem;font-weight:600}.race-results{width:100%;max-width:480px;animation:slideUp .4s ease}.results-title{text-align:center;font-size:1.3rem;font-weight:800;margin-bottom:8px}.results-word{text-align:center;color:var(--text-secondary);margin-bottom:20px}.results-word strong{color:var(--text-primary);letter-spacing:.1em}.results-table{display:flex;flex-direction:column;gap:6px}.result-row{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius)}.result-self{border-color:var(--accent);background:#538d4e14}.result-rank{font-size:1.1rem;font-weight:800;width:36px;text-align:center;color:var(--accent)}.result-player{font-weight:600;flex:1}.result-details{text-align:right;display:flex;flex-direction:column;gap:2px}.result-score-val{font-weight:700;color:var(--accent)}.result-meta{font-size:.75rem;color:var(--text-muted)}@media (max-width: 700px){.race-layout{grid-template-columns:1fr}.race-sidebar{order:2}.race-game-area{order:1}}.lb-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-tertiary);border-radius:var(--radius);padding:4px}.lb-tab{flex:1;padding:10px 16px;background:none;color:var(--text-secondary);font-weight:600;font-size:.85rem;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}.lb-tab:hover{color:var(--text-primary)}.lb-tab-active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 4px #0003}.lb-empty{text-align:center;padding:48px 0;color:var(--text-muted);font-size:.95rem}.lb-table{display:flex;flex-direction:column}.lb-header-row{display:flex;padding:8px 14px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.lb-row{display:flex;padding:12px 14px;align-items:center;border-bottom:1px solid var(--border-color);transition:background var(--transition)}.lb-row:hover{background:var(--bg-tertiary)}.lb-row-self{background:#538d4e0f}.lb-col-rank{width:48px;flex-shrink:0}.lb-col-name{flex:1;font-weight:600;font-size:.9rem}.lb-col-score{width:72px;text-align:right;font-weight:700;color:var(--accent);font-size:.95rem}.lb-col-details{width:140px;text-align:right;font-size:.8rem;color:var(--text-secondary)}.lb-detail-sep{margin:0 4px;color:var(--text-muted)}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-weight:700;font-size:.8rem}.rank-1{background:gold;color:#1a1a1b}.rank-2{background:silver;color:#1a1a1b}.rank-3{background:#cd7f32;color:#1a1a1b}@media (max-width: 480px){.lb-col-details{display:none}}.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.profile-avatar{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;flex-shrink:0}.profile-name{font-size:1.2rem;font-weight:700}.profile-joined{font-size:.8rem;color:var(--text-muted);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:32px}.stat-card{text-align:center;padding:18px 12px}.stat-value{font-size:1.6rem;font-weight:800;color:var(--accent)}.stat-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-top:4px}.section-title{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:16px}.achievements-grid{display:flex;flex-direction:column;gap:8px}.achievement-card{display:flex;align-items:center;gap:14px;padding:16px;transition:all var(--transition)}.achievement-locked{opacity:.4}.achievement-unlocked{border-color:var(--accent)}.ach-icon{font-size:2rem;flex-shrink:0}.ach-info{flex:1}.ach-name{font-weight:700;font-size:.95rem}.ach-desc{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.ach-date{font-size:.7rem;color:var(--text-muted);margin-top:4px}.ach-check{color:var(--accent);font-size:1.2rem;font-weight:800;flex-shrink:0}@media (max-width: 480px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.login-container{display:flex;justify-content:center;align-items:flex-start;padding-top:60px}.login-card{max-width:380px;width:100%}.login-title{font-size:1.4rem;font-weight:700;text-align:center;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.form-group input{width:100%}.login-btn{width:100%;margin-top:4px;padding:12px}.login-error{background:#e74c3c26;color:var(--danger);padding:10px 14px;border-radius:var(--radius);font-size:.85rem;font-weight:500;border:1px solid rgba(231,76,60,.3)}.login-toggle{text-align:center;margin-top:20px;font-size:.85rem;color:var(--text-secondary)}.toggle-link{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:.85rem;margin-left:6px}.toggle-link:hover{color:var(--accent-hover)}:root{--bg-primary: #121213;--bg-secondary: #1a1a1b;--bg-tertiary: #2d2d2e;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #6a6a6a;--border-color: #3a3a3c;--correct: #538d4e;--correct-hover: #5fa05a;--present: #b59f3b;--present-hover: #c9b145;--absent: #3a3a3c;--absent-hover: #4a4a4c;--key-bg: #818384;--key-text: #ffffff;--tile-border: #3a3a3c;--tile-active-border: #565758;--accent: #538d4e;--accent-hover: #5fa05a;--danger: #e74c3c;--warning: #f39c12;--success: #538d4e;--modal-bg: rgba(0, 0, 0, .7);--card-bg: #1e1e1f;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--radius: 8px;--radius-lg: 12px;--transition: .2s ease;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--text-primary: #1a1a1b;--text-secondary: #555555;--text-muted: #999999;--border-color: #d3d6da;--absent: #787c7e;--absent-hover: #888c8e;--key-bg: #d3d6da;--key-text: #1a1a1b;--tile-border: #d3d6da;--tile-active-border: #878a8c;--card-bg: #ffffff;--shadow: 0 4px 24px rgba(0, 0, 0, .1);--modal-bg: rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow-x:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all var(--transition)}button:disabled{opacity:.5;cursor:not-allowed}input{font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:10px 14px;border-radius:var(--radius);font-size:.95rem;transition:border-color var(--transition)}input:focus{outline:none;border-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius);font-weight:600;font-size:.9rem;letter-spacing:.02em}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--absent-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn-small{padding:6px 12px;font-size:.8rem}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.container{max-width:600px;margin:0 auto;padding:0 16px;width:100%}.container-wide{max-width:900px;margin:0 auto;padding:0 16px;width:100%}.page{flex:1;padding:24px 0}.page-title{font-size:1.5rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:24px;text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .2s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:32px;max-width:420px;width:100%;box-shadow:var(--shadow);animation:slideUp .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes flipIn{0%{transform:rotateX(0)}50%{transform:rotateX(90deg)}to{transform:rotateX(0)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.toast-container{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:var(--text-primary);color:var(--bg-primary);padding:12px 24px;border-radius:var(--radius);font-weight:600;font-size:.9rem;animation:slideUp .3s ease,fadeIn .3s ease;pointer-events:auto}@media (max-width: 480px){.container{padding:0 8px}.page-title{font-size:1.2rem}.modal-content{padding:24px 20px}}
