@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@500;700;800&family=Manrope:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}:root{--bg: #0e0f12;--bg-2: #16181d;--panel: #1c1f25;--panel-2: #23262e;--border: #2a2e37;--text: #e8e9ed;--text-dim: #9aa0ad;--text-muted: #6b7180;--hit: #79b851;--present: #f3c237;--miss: #3a3a3c;--miss-fg: #6b7180;--accent: #f3c237}body[data-theme=light]{--bg: #f5f6f8;--bg-2: #ffffff;--panel: #ffffff;--panel-2: #eef0f3;--border: #d8dbe2;--text: #15171c;--text-dim: #555a66;--text-muted: #8b91a0;--miss: #b8bcc6;--miss-fg: #5a5e6b}body{font-family:Manrope,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased}body[data-theme=dark]{background:radial-gradient(1200px 700px at 20% -10%,rgba(121,184,81,.08),transparent 60%),radial-gradient(900px 600px at 110% 100%,rgba(243,194,55,.06),transparent 60%),var(--bg)}#root{height:100%}.app{height:100%;display:flex;flex-direction:column}.lobby{flex:1;display:grid;place-items:center;padding:24px}.lobby-card{background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:48px 56px 40px;width:min(560px,92vw);text-align:center;box-shadow:0 30px 80px #00000080,inset 0 1px #ffffff08}.lobby-logo{display:flex;justify-content:center;align-items:center;gap:6px;margin-bottom:32px;position:relative}.logo-l{width:44px;height:44px;display:grid;place-items:center;font-family:JetBrains Mono,monospace;font-weight:800;font-size:24px;background:var(--miss);color:var(--text);border-radius:6px;letter-spacing:.02em}.logo-hit{background:var(--hit);color:#fff}.logo-present{background:var(--present);color:#1a1a1a}.logo-versus{position:absolute;right:-8px;top:-8px;background:var(--accent);color:#1a1a1a;font-weight:800;font-size:11px;padding:3px 8px;border-radius:999px;letter-spacing:.08em}.lobby-spinner{position:relative;width:80px;height:80px;margin:0 auto 24px}.pulse-dot{position:absolute;top:50%;left:50%;width:14px;height:14px;background:var(--hit);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 20px var(--hit)}.pulse-ring{position:absolute;top:50%;left:50%;width:14px;height:14px;border:2px solid var(--hit);border-radius:50%;transform:translate(-50%,-50%);animation:pulse 2s ease-out infinite}.pulse-ring-2{animation-delay:1s}@keyframes pulse{0%{width:14px;height:14px;opacity:1}to{width:80px;height:80px;opacity:0}}.lobby-text{font-size:22px;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}.lobby-dots{display:inline-block;width:24px;text-align:left;color:var(--accent)}.lobby-sub{font-size:13px;color:var(--text-muted);margin-bottom:36px;letter-spacing:.02em}.lobby-code{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-bottom:12px}.lobby-code span{color:var(--text-muted);font-size:11px;text-transform:uppercase;font-weight:800}.lobby-code strong{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:18px;letter-spacing:.08em}.lobby-players{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:20px;background:var(--bg);border:1px solid var(--border);border-radius:14px}.lobby-player{display:flex;flex-direction:column;align-items:center;gap:8px}.lobby-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--hit),#4a8a2c);display:grid;place-items:center;font-weight:800;color:#fff;font-size:16px;letter-spacing:.04em}.lobby-avatar-empty{background:var(--panel-2);color:var(--text-muted);border:2px dashed var(--border);animation:blink 1.5s ease-in-out infinite}@keyframes blink{50%{opacity:.4}}.lobby-name{font-weight:600;font-size:14px}.lobby-status{font-size:11px;text-transform:uppercase;letter-spacing:.1em;padding:2px 8px;border-radius:999px}.lobby-ready{background:#79b85126;color:var(--hit)}.lobby-searching{background:#f3c2371f;color:var(--present)}.lobby-vs{font-family:JetBrains Mono,monospace;font-size:24px;color:var(--text-muted);font-weight:700}.match{flex:1;display:flex;flex-direction:column;padding:16px 24px 12px;position:relative;max-height:100vh;overflow:hidden}.match-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:16px}.brand{display:flex;align-items:center;gap:4px;position:relative}.brand-l{width:28px;height:28px;display:grid;place-items:center;font-family:JetBrains Mono,monospace;font-weight:800;font-size:15px;background:var(--miss);color:var(--text);border-radius:4px}.brand-hit{background:var(--hit);color:#fff}.brand-present{background:var(--present);color:#1a1a1a}.brand-mode{margin-left:10px;font-size:11px;font-weight:800;letter-spacing:.12em;background:var(--accent);color:#1a1a1a;padding:4px 8px;border-radius:4px}.match-info{display:flex;gap:8px}.info-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--panel);border:1px solid var(--border);border-radius:999px;font-size:12px;color:var(--text-dim)}.info-chip strong{color:var(--text);font-weight:700}.dot{width:7px;height:7px;border-radius:50%}.dot-live{background:#ef4444;box-shadow:0 0 8px #ef4444;animation:pulse-live 1.5s ease-in-out infinite}@keyframes pulse-live{50%{opacity:.4}}.boards{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;flex:1;align-items:center;justify-items:center;min-height:0;overflow:hidden}.board-col{display:flex;flex-direction:column;align-items:center;gap:10px}.board-label{display:flex;align-items:baseline;gap:10px;font-size:13px}.board-name{font-weight:700;letter-spacing:.02em}.board-meta{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-muted)}.board-divider{display:flex;flex-direction:column;align-items:center;gap:12px;height:100%;padding:30px 0}.divider-line{width:1px;flex:1;background:linear-gradient(to bottom,transparent,var(--border),transparent)}.divider-x{font-family:JetBrains Mono,monospace;font-weight:800;color:var(--text-muted);font-size:14px;padding:6px 10px;background:var(--panel);border:1px solid var(--border);border-radius:999px}.board{display:flex;flex-direction:column;gap:6px}.row{display:flex;gap:6px}.row-shake{animation:shake .45s ease}.tile{width:clamp(32px,min(4.6vw,7vh),58px);height:clamp(32px,min(4.6vw,7vh),58px);perspective:600px;position:relative;border:0;padding:0;background:transparent;color:var(--text);font:inherit}.tile-clickable{cursor:pointer}.tile-clickable:focus-visible{outline:none}.tile-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .5s ease}.tile-reveal .tile-inner{animation:tile-reveal .56s cubic-bezier(.2,.8,.2,1) forwards;animation-delay:var(--delay)}.tile-face{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-family:JetBrains Mono,monospace;font-weight:800;font-size:clamp(18px,2.2vw,26px);border:2px solid var(--border);border-radius:6px;backface-visibility:hidden;background:transparent;color:var(--text);letter-spacing:.02em;text-transform:uppercase}.tile-clickable .tile-front{transition:border-color .15s ease}.tile-clickable:hover .tile-front,.tile-clickable:focus-visible .tile-front{border-color:var(--text-dim)}.tile-cursor .tile-front{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 16px #f3c23759;animation:cursor-pulse 1s ease-in-out infinite}.tile-cursor:after{content:"";position:absolute;left:22%;right:22%;bottom:-5px;height:3px;border-radius:999px;background:var(--accent);pointer-events:none}@keyframes cursor-pulse{50%{box-shadow:0 0 0 1px var(--accent),0 0 22px #f3c2378c}}.tile-back{transform:rotateX(180deg);border-color:transparent;color:#fff}.tile-filled:not(.tile-reveal) .tile-front{border-color:var(--text-muted);animation:pop .16s ease-out}.tile-pop .tile-front{animation:pop .16s ease-out}.tile-hit .tile-back{background:var(--hit);color:#fff}.tile-present .tile-back{background:var(--present);color:#1a1a1a}.tile-miss .tile-back{background:var(--miss);color:#fff;border-color:var(--miss)}body[data-theme=light] .tile-miss .tile-back{color:#fff}@keyframes pop{0%{transform:scale(.85)}50%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes tile-reveal{0%{transform:rotateX(0) scale(1)}45%{transform:rotateX(90deg) scale(1.04)}to{transform:rotateX(180deg) scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.kb{display:flex;flex-direction:column;gap:6px;margin-top:14px;align-items:center;flex-shrink:0}.kb-disabled{opacity:.5;pointer-events:none}.kb-row{display:flex;gap:5px}.kb-key{height:clamp(38px,6.5vh,52px);min-width:32px;padding:0 10px;border:none;border-radius:6px;background:var(--panel-2);color:var(--text);font-family:Manrope,sans-serif;font-weight:700;font-size:14px;cursor:pointer;transition:transform .08s ease,background .15s ease}.kb-key:hover{background:var(--border)}.kb-key:active{transform:scale(.94)}.kb-wide{padding:0 14px;font-size:12px}.kb-hit{background:var(--hit);color:#fff}.kb-present{background:var(--present);color:#1a1a1a}.kb-miss{background:var(--miss);color:var(--miss-fg)}.toast{position:absolute;top:80px;left:50%;transform:translate(-50%);background:var(--text);color:var(--bg);padding:10px 18px;border-radius:6px;font-weight:700;font-size:13px;z-index:50;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}}.waiting-bar{margin-top:12px;text-align:center;font-size:13px;color:var(--text-dim);padding:12px;background:var(--panel);border:1px solid var(--border);border-radius:10px;font-weight:500}.endcard{position:absolute;top:0;right:0;bottom:0;left:0;background:#0e0f12d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:100;padding:24px;animation:fade-in .3s ease}body[data-theme=light] .endcard{background:#f5f6f8d9}@keyframes fade-in{0%{opacity:0}}.endcard-emoji{font-size:64px;animation:bounce-in .5s cubic-bezier(.34,1.56,.64,1)}@keyframes bounce-in{0%{transform:scale(0)}to{transform:scale(1)}}.endcard-title{font-size:36px;font-weight:800;letter-spacing:-.02em}.endcard-win .endcard-title{color:var(--hit)}.endcard-lose .endcard-title{color:#ef4444}.endcard-draw .endcard-title{color:var(--present)}.endcard-sub{font-size:15px;color:var(--text-dim);margin-bottom:12px}.endcard-answer{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:18px}.endcard-answer-label{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted)}.endcard-answer-tiles{display:flex;gap:6px}.endcard-tile{width:48px;height:48px;background:var(--hit);color:#fff;display:grid;place-items:center;font-family:JetBrains Mono,monospace;font-weight:800;font-size:22px;border-radius:6px;animation:drop-in .4s cubic-bezier(.34,1.56,.64,1) backwards}@keyframes drop-in{0%{transform:translateY(-12px) scale(.8);opacity:0}}.endcard-btn{background:var(--accent);color:#1a1a1a;border:none;padding:14px 32px;border-radius:10px;font-family:Manrope,sans-serif;font-weight:800;font-size:15px;cursor:pointer;letter-spacing:0;transition:transform .1s ease,box-shadow .2s ease;box-shadow:0 4px #b8911f,0 8px 20px #f3c2374d}.endcard-btn:hover{transform:translateY(-1px)}.endcard-btn:active{transform:translateY(2px);box-shadow:0 2px #b8911f}.endcard-btn:disabled{cursor:progress;opacity:.7;transform:none}.endcard-actions{display:flex;flex-direction:column;gap:10px;width:min(380px,90vw)}.endcard-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.endcard-btn-primary{background:var(--accent);color:#1a1a1a;box-shadow:0 4px #b8911f,0 8px 20px #f3c2374d}.endcard-btn-secondary{background:var(--panel-2);color:var(--text);box-shadow:0 3px 0 var(--border);font-size:13px;padding:12px 16px}.endcard-btn-secondary:active{box-shadow:none}.endcard-btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border);box-shadow:none;font-size:13px;padding:12px 16px}.endcard-btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.menu,.screen{flex:1;display:grid;place-items:center;padding:24px;overflow-y:auto}.menu-card{width:min(560px,92vw);text-align:center;padding:48px 40px 36px;background:var(--panel);border:1px solid var(--border);border-radius:20px;box-shadow:0 30px 80px #00000080,inset 0 1px #ffffff08}.menu-brand{display:inline-flex;align-items:center;gap:5px;position:relative;margin-bottom:14px}.menu-tagline{color:var(--text-dim);font-size:14px;margin-bottom:32px}.menu-actions{display:flex;flex-direction:column;gap:10px}.menu-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.menu-btn{display:flex;align-items:center;gap:14px;padding:18px;background:var(--bg);border:1px solid var(--border);border-radius:14px;color:var(--text);font-family:inherit;text-align:left;cursor:pointer;transition:transform .1s ease,border-color .15s ease,background .15s ease}.menu-btn:hover{border-color:var(--text-muted);transform:translateY(-1px)}.menu-btn:active{transform:translateY(0)}.menu-btn-primary{background:linear-gradient(135deg,var(--hit),#5e9c3c);border-color:transparent;box-shadow:0 8px 24px #79b85140}.menu-btn-primary:hover{box-shadow:0 12px 30px #79b85159}.menu-btn-primary .menu-btn-sub{color:#fffc}.menu-btn-primary .menu-btn-title{color:#fff}.menu-btn-icon{width:44px;height:44px;display:grid;place-items:center;background:var(--panel-2);border-radius:10px;font-size:22px;flex-shrink:0}.menu-btn-primary .menu-btn-icon{background:#ffffff2e}.menu-btn-body{flex:1;min-width:0}.menu-btn-title{font-weight:700;font-size:15px;margin-bottom:2px}.menu-btn-sub{font-size:12px;color:var(--text-muted)}.menu-btn-arrow{font-size:22px;color:#fff;opacity:.8}.menu-footer{margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}.menu-stats{display:flex;justify-content:center;gap:12px;font-size:12px;color:var(--text-muted)}.menu-stats strong{color:var(--text);font-weight:700}.menu-stat-divider{color:var(--text-muted)}.screen{flex:1;display:grid;place-items:center;padding:24px;position:relative;min-height:0;overflow-y:auto}.back-btn{position:fixed;top:16px;right:16px;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:999px;font-family:inherit;font-weight:600;font-size:13px;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease;z-index:210;box-shadow:0 4px 14px #0000004d}.back-btn:hover{background:var(--panel-2);border-color:var(--text-muted);transform:translateY(-1px)}.screen-card{width:min(560px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:36px 36px 32px;box-shadow:0 30px 80px #00000080}.screen-card-narrow{padding:48px;max-width:420px}.screen-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);font-weight:800;margin-bottom:6px}.screen-title{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}.screen-sub{color:var(--text-dim);font-size:14px;margin-bottom:24px}.code-box{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:22px;text-align:center;margin-bottom:24px;position:relative}.code-label{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-bottom:12px}.code-value{display:flex;justify-content:center;gap:8px;margin-bottom:14px}.code-char{width:44px;height:56px;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;font-family:JetBrains Mono,monospace;font-weight:800;font-size:24px;color:var(--accent)}.code-copy{background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.code-copy:hover{background:var(--border);color:var(--text)}.code-copy-ok{background:var(--hit);color:#fff;border-color:var(--hit)}.room-players{display:flex;flex-direction:column;gap:8px}.room-player{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg);border:1px solid var(--border);border-radius:12px;transition:border-color .2s ease}.room-player-ready{border-color:var(--hit)}.room-player-empty{border-style:dashed}.room-player-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--hit),#4a8a2c);display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px;letter-spacing:.04em;flex-shrink:0}.room-player-avatar-empty{background:var(--panel-2);color:var(--text-muted);border:2px dashed var(--border);animation:blink 1.5s ease-in-out infinite}.room-player-info{flex:1}.room-player-name{font-weight:700;font-size:14px}.room-player-status{font-size:11px;text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.room-status-ready{color:var(--hit)}.room-status-waiting{color:var(--text-muted)}.room-player-check{color:var(--hit);font-weight:800;font-size:18px}.room-starting{margin-top:20px}.room-starting-bar{height:4px;background:var(--panel-2);border-radius:999px;overflow:hidden;margin-bottom:10px}.room-starting-fill{height:100%;background:linear-gradient(90deg,var(--hit),var(--accent));animation:fill-bar 1.8s ease forwards}@keyframes fill-bar{0%{width:0}to{width:100%}}.room-starting-text{text-align:center;font-size:13px;color:var(--text-dim);font-weight:600}.tabs{display:flex;gap:4px;background:var(--bg);padding:4px;border-radius:10px;border:1px solid var(--border);margin-bottom:20px}.tab{flex:1;padding:10px;background:transparent;border:none;color:var(--text-dim);font-family:inherit;font-weight:600;font-size:13px;border-radius:7px;cursor:pointer;transition:all .15s ease}.tab:hover{color:var(--text)}.tab-active{background:var(--panel-2);color:var(--text)}.tab-badge{display:inline-block;margin-left:4px;background:var(--accent);color:#1a1a1a;font-size:10px;padding:1px 6px;border-radius:999px;font-weight:800}.code-input-section{display:flex;flex-direction:column;gap:16px}.code-input-wrap{position:relative}.code-input{width:100%;padding:18px;background:var(--bg);border:2px solid var(--border);border-radius:12px;color:var(--accent);font-family:JetBrains Mono,monospace;font-weight:800;font-size:28px;text-align:center;letter-spacing:.4em;text-transform:uppercase;outline:none;transition:border-color .15s ease}.code-input::placeholder{color:var(--text-muted);letter-spacing:.3em}.code-input:focus{border-color:var(--accent)}.code-input-error{border-color:#ef4444;animation:shake .4s ease}.code-error{color:#ef4444;font-size:12px;margin-top:6px;text-align:center}.primary-btn{background:var(--accent);color:#1a1a1a;border:none;padding:14px;border-radius:12px;font-family:inherit;font-weight:800;font-size:15px;cursor:pointer;letter-spacing:.02em;box-shadow:0 4px #b8911f;transition:transform .1s ease}.primary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px #b8911f}.primary-btn:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #b8911f}.primary-btn:disabled{opacity:.4;cursor:not-allowed}.rooms-list{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto}.room-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;font-family:inherit;text-align:left;color:var(--text);transition:all .12s ease}.room-row:hover{border-color:var(--accent);background:var(--panel-2)}.room-row-avatar{width:36px;height:36px;display:grid;place-items:center;background:var(--panel-2);border-radius:8px;font-size:18px}.room-row-info{flex:1;min-width:0}.room-row-name{font-weight:700;font-size:14px}.room-row-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);margin-top:2px}.room-row-mode{text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--text-dim)}.room-row-code{font-family:JetBrains Mono,monospace}.room-row-ping{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);font-family:JetBrains Mono,monospace}.ping-dot{width:6px;height:6px;border-radius:50%}.ping-good{background:var(--hit)}.ping-mid{background:var(--present)}.ping-bad{background:#ef4444}.room-row-arrow{color:var(--text-muted);font-size:18px}.joining{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.joining-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:6px}@keyframes spin{to{transform:rotate(360deg)}}.joining-title{font-size:18px;font-weight:700}.joining-sub{font-size:13px;color:var(--text-dim)}.joining-sub strong{color:var(--text)}.joining-code{font-family:JetBrains Mono,monospace;font-weight:800;font-size:22px;color:var(--accent);letter-spacing:.2em;margin-top:8px;padding:8px 16px;background:var(--bg);border-radius:8px}.leave-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:6px 12px;border-radius:999px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.leave-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.leave-btn:disabled{cursor:progress;opacity:.65}.leave-icon{font-size:12px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#08090cb8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;place-items:center;z-index:200;padding:18px;animation:fade-in .18s ease}.dialog{width:min(430px,calc(100vw - 32px));background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;text-align:left;box-shadow:0 30px 80px #0009;animation:dialog-in .18s ease}@keyframes dialog-in{0%{opacity:0;transform:translateY(8px) scale(.98)}}.dialog-mark{width:34px;height:34px;display:grid;place-items:center;margin-bottom:14px;border-radius:8px;background:#ef44441f;border:1px solid rgba(239,68,68,.35);color:#ef4444;font-family:JetBrains Mono,monospace;font-weight:900}.dialog-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);font-weight:800;margin-bottom:6px}.dialog-title{font-size:22px;font-weight:800;margin-bottom:8px}.dialog-sub{font-size:13px;line-height:1.55;color:var(--text-dim);margin-bottom:22px}.dialog-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.dialog-btn{padding:12px;border:none;border-radius:8px;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;transition:transform .1s ease}.dialog-btn:active{transform:translateY(1px)}.dialog-btn:disabled{cursor:progress;opacity:.68;transform:none}.dialog-btn-secondary{background:var(--panel-2);color:var(--text)}.dialog-btn-secondary:hover{background:var(--border)}.dialog-btn-danger{background:#ef4444;color:#fff}.dialog-btn-danger:hover{background:#dc2626}.home{flex:1;display:grid;place-items:center;padding:24px;overflow-y:auto}.home-card{width:min(560px,92vw);max-height:calc(100dvh - 48px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;text-align:center;padding:44px 38px 32px;background:var(--panel);border:1px solid var(--border);border-radius:20px;box-shadow:0 30px 80px #00000080,inset 0 1px #ffffff08}.home-brand{display:inline-flex;align-items:center;gap:5px;position:relative;margin-bottom:12px}.home-tagline{color:var(--text-dim);font-size:13px;margin-bottom:28px}.home-form{display:flex;flex-direction:column;gap:10px;text-align:left}.home-label{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);font-weight:800;margin-bottom:2px}.home-input{width:100%;padding:14px 16px;background:var(--bg);border:2px solid var(--border);border-radius:12px;color:var(--text);font-family:inherit;font-weight:600;font-size:16px;outline:none;transition:border-color .15s ease}.home-input::placeholder{color:var(--text-muted)}.home-input:focus{border-color:var(--accent)}.home-input-error{border-color:#ef4444;animation:shake .4s ease}.home-error{color:#ef4444;font-size:12px;margin-top:-4px}.home-btn{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;padding:16px;background:linear-gradient(135deg,var(--hit),#5e9c3c);color:#fff;border:none;border-radius:12px;font-family:inherit;font-weight:800;font-size:15px;letter-spacing:.02em;cursor:pointer;box-shadow:0 8px 24px #79b85140;transition:transform .1s ease,box-shadow .2s ease}.home-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 30px #79b85159}.home-btn:active:not(:disabled){transform:translateY(1px)}.home-btn:disabled{opacity:.4;cursor:not-allowed}.home-btn-icon{font-size:18px}.home-btn-arrow{font-size:18px;opacity:.85}.private-room{display:flex;flex-direction:column;gap:8px;margin-top:4px}.private-join{color:var(--text-muted);font-size:11px;text-align:center;line-height:1.4}.private-code-wrap{display:grid;grid-template-columns:1fr 38px;gap:6px;min-width:0}.private-code-input{width:100%;min-width:0;padding:11px 9px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--accent);font-family:JetBrains Mono,monospace;font-weight:900;text-align:center;letter-spacing:.08em;outline:none}.private-code-input:focus{border-color:var(--accent)}.private-code-submit{border:1px solid var(--border);background:var(--panel-2);color:var(--text);border-radius:10px;font-family:inherit;font-weight:900;cursor:pointer}.private-code-submit:hover:not(:disabled){border-color:var(--text-muted)}.private-code-submit:disabled{opacity:.45;cursor:not-allowed}.private-btn{border:1px solid var(--border);background:var(--panel-2);color:var(--text);border-radius:10px;padding:12px 14px;font-family:inherit;font-weight:800;cursor:pointer}.private-btn:disabled{opacity:.45;cursor:not-allowed}.home-mode-row{display:flex;justify-content:center;gap:6px;margin-top:14px}.home-mode-chip{padding:5px 10px;background:var(--bg);border:1px solid var(--border);border-radius:999px;font-size:11px;color:var(--text-dim)}.home-mode-chip strong{color:var(--text);font-weight:800}.home-divider{display:flex;align-items:center;gap:10px;font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin:14px 0 4px}.home-divider:before,.home-divider:after{content:"";flex:1;height:1px;background:var(--border)}.home-nav-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}.home-nav-btn{display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text-dim);font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;transition:transform .15s ease,border-color .15s ease,color .15s ease}.home-nav-btn:hover:not(:disabled){color:var(--text);border-color:var(--text-muted);transform:translateY(-1px)}.home-nav-btn:disabled{opacity:.45;cursor:not-allowed}.home-nav-btn-strong{background:var(--panel-2);color:var(--text)}.home-nav-icon{font-size:16px}.account-panel{margin-top:8px;padding:14px;background:var(--bg);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:8px;text-align:left}.account-field{display:flex;flex-direction:column;gap:6px}.account-field label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-weight:800}.account-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:3px;background:var(--panel);border:1px solid var(--border);border-radius:9px}.account-tab{border:0;background:transparent;color:var(--text-dim);border-radius:7px;padding:8px;font-family:inherit;font-weight:800;cursor:pointer}.account-tab-active{background:var(--panel-2);color:var(--text)}.account-input{width:100%;padding:11px 12px;background:var(--panel);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:inherit;font-weight:600;outline:none}.account-input:focus{border-color:var(--accent)}.account-btn,.account-ghost{border:0;border-radius:9px;padding:11px 12px;font-family:inherit;font-weight:800;cursor:pointer}.account-btn{background:var(--accent);color:#1a1a1a}.account-btn:disabled{opacity:.45;cursor:not-allowed}.account-ghost{background:var(--panel-2);color:var(--text)}.account-signed{display:flex;align-items:center;gap:12px}.account-signed-body{flex:1;min-width:0}.account-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:linear-gradient(135deg,var(--hit),#4a8a2c);color:#fff;font-size:13px;font-weight:900;letter-spacing:.04em}.account-label{font-size:11px;text-transform:uppercase;color:var(--text-muted);font-weight:800}.account-name{font-weight:800;margin-top:2px}.account-user{color:var(--text-muted);font-size:12px;margin-top:2px}.stats-panel{margin-top:14px;padding:14px;background:var(--bg);border:1px solid var(--border);border-radius:12px;text-align:left}.stats-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.stats-refresh{border:1px solid var(--border);background:var(--panel);color:var(--text-dim);border-radius:8px;padding:6px 9px;font-family:inherit;font-size:11px;font-weight:800;cursor:pointer}.stats-refresh:disabled{opacity:.5;cursor:wait}.ranking-periods{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-bottom:10px}.ranking-period{min-width:0;border:1px solid var(--border);background:var(--panel);color:var(--text-muted);border-radius:8px;padding:7px 4px;font-family:inherit;font-size:11px;font-weight:800;cursor:pointer;letter-spacing:0}.ranking-period-active{border-color:var(--accent);background:#f3c23724;color:var(--accent)}.ranking-list,.history-list{display:flex;flex-direction:column;gap:6px}.ranking-list{max-height:250px;overflow-y:auto;padding-right:2px}.history-list{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.rank-header,.rank-row{display:grid;grid-template-columns:36px 1fr 36px 36px 36px 56px;align-items:center;gap:8px;padding:10px 12px}.rank-header{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:4px}.home-rank-header{margin-top:2px}.rank-row{background:var(--panel);border:1px solid var(--border);border-radius:8px;font-size:13px}.rank-row-top{background:linear-gradient(90deg,rgba(243,194,55,.06),var(--panel))}.rank-pos{font-weight:800;font-family:JetBrains Mono,monospace;text-align:center}.rank-name{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-avatar{width:26px;height:26px;display:grid;place-items:center;background:var(--panel-2);border-radius:50%;font-size:10px;font-weight:800;letter-spacing:.04em;flex-shrink:0}.rank-w{color:var(--hit);font-weight:700;text-align:center;font-family:JetBrains Mono,monospace}.rank-d{color:var(--present);font-weight:700;text-align:center;font-family:JetBrains Mono,monospace}.rank-l{color:#ef4444;font-weight:700;text-align:center;font-family:JetBrains Mono,monospace}.rank-score{font-weight:800;font-family:JetBrains Mono,monospace;text-align:right;color:var(--accent)}.hist-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:8px 0 10px}.hist-stat{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 8px;text-align:center}.hist-stat-num{font-size:20px;font-weight:800;font-family:JetBrains Mono,monospace}.hist-stat-label{font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-top:4px}.hist-stat-win .hist-stat-num{color:var(--hit)}.hist-stat-lose .hist-stat-num{color:#ef4444}.hist-stat-draw .hist-stat-num{color:var(--present)}.hist-stat-points .hist-stat-num{color:var(--accent)}.hist-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--panel);border:1px solid var(--border);border-left-width:3px;border-radius:10px}.hist-row-win{border-left-color:var(--hit)}.hist-row-lose{border-left-color:#ef4444}.hist-row-draw{border-left-color:var(--present)}.hist-badge{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;font-weight:800;font-size:14px;flex-shrink:0}.hist-badge-win{background:#79b85133;color:var(--hit)}.hist-badge-lose{background:#ef44442e;color:#ef4444}.hist-badge-draw{background:#f3c2372e;color:var(--present)}.hist-info{flex:1;min-width:0}.hist-row-top{display:flex;justify-content:space-between;gap:10px;font-size:13px}.hist-opp{color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hist-when{color:var(--text-muted);font-size:11px;font-family:JetBrains Mono,monospace;flex-shrink:0}.hist-row-bottom{display:flex;justify-content:space-between;gap:10px;font-size:11px;color:var(--text-muted);margin-top:4px}.hist-word strong{color:var(--accent);font-family:JetBrains Mono,monospace;letter-spacing:.04em}.hist-attempts{font-family:JetBrains Mono,monospace;flex-shrink:0}.stats-empty{color:var(--text-muted);font-size:12px;padding:8px 0 2px}.home-footer{margin-top:26px;padding-top:18px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.home-stats{display:flex;justify-content:center;align-items:center;font-size:12px;color:var(--text-muted)}.home-stats strong{color:var(--text);font-weight:700}.home-stat-dot{width:7px;height:7px;background:var(--hit);border-radius:50%;margin-right:8px;box-shadow:0 0 8px var(--hit);animation:pulse-live 1.5s ease-in-out infinite}.home-live-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:999px;color:var(--text-dim);font-family:inherit;font-weight:700;font-size:12px;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.home-live-chip:hover{background:#ef444433;border-color:#ef4444;transform:translateY(-1px)}.home-live-chip strong{color:#ef4444;font-size:13px}.home-live-pulse{width:7px;height:7px;border-radius:50%;background:#ef4444;box-shadow:0 0 8px #ef4444;animation:live-pulse 1.2s ease-in-out infinite}.home-live-arrow{color:var(--text-muted);font-size:11px;margin-left:2px;transition:transform .15s ease,color .15s ease}.home-live-chip:hover .home-live-arrow{color:var(--text);transform:translate(2px)}.profile-badge{position:fixed;top:16px;left:16px;z-index:200}.profile-badge-btn{display:flex;align-items:center;gap:8px;min-height:42px;padding:6px 10px 6px 6px;background:#18181be0;border:1px solid var(--border);border-radius:999px;color:var(--text);font-family:inherit;font-weight:700;cursor:pointer;box-shadow:0 12px 30px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:background .15s ease,border-color .15s ease,transform .15s ease}.profile-badge-btn:hover{background:var(--panel-2);border-color:var(--text-muted);transform:translateY(-1px)}.profile-badge-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--hit),#4a8a2c);display:grid;place-items:center;color:#fff;font-size:12px;font-weight:800}.profile-badge-name{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-badge-chev{color:var(--text-muted);font-size:12px;transition:transform .15s ease}.profile-badge-chev-open{transform:rotate(180deg)}.profile-pop{position:absolute;top:52px;left:0;width:min(310px,calc(100vw - 32px));padding:14px;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 70px #00000080}.profile-pop-header{display:flex;align-items:center;gap:12px}.profile-pop-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--hit),#4a8a2c);display:grid;place-items:center;color:#fff;font-size:16px;font-weight:900;flex-shrink:0}.profile-pop-info{flex:1;min-width:0}.profile-pop-name-row{display:flex;align-items:center;gap:6px}.profile-pop-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:800}.profile-pop-edit-btn{width:26px;height:26px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer}.profile-pop-edit-btn:hover{color:var(--accent);border-color:var(--accent)}.profile-pop-email{margin-top:3px;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-pop-edit{display:flex;gap:4px;align-items:center}.profile-pop-input{flex:1;min-width:0;padding:9px 10px;background:var(--bg);border:2px solid var(--border);border-radius:9px;color:var(--text);font-family:inherit;font-weight:700;outline:none}.profile-pop-input:focus{border-color:var(--accent)}.profile-pop-input-error{border-color:#ef4444!important}.profile-pop-save,.profile-pop-cancel{width:30px;height:30px;border:none;border-radius:8px;font-weight:900;cursor:pointer}.profile-pop-save{background:var(--hit);color:#fff}.profile-pop-cancel{background:var(--panel-2);color:var(--text-dim)}.profile-pop-save:disabled,.profile-pop-cancel:disabled{opacity:.6;cursor:wait}.profile-pop-error{color:#ef4444;font-size:11px;margin-top:4px}.profile-pop-divider{height:1px;background:var(--border);margin:14px 0}.profile-pop-action{width:100%;display:flex;align-items:center;gap:8px;padding:11px 12px;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--text-dim);font-family:inherit;font-weight:700;cursor:pointer;text-align:left}.profile-pop-action:hover{background:var(--panel-2)}.profile-pop-action-danger{color:#ef4444;border-color:#ef44444d}.profile-pop-action-danger:hover{background:#ef44441a;border-color:#ef4444}.profile-pop-action-icon{font-size:14px}.home-watch-btn{width:100%;display:flex;align-items:center;gap:12px;padding:14px;margin:10px 0 2px;background:linear-gradient(135deg,#ef44441f,#ef44440a);border:1px solid rgba(239,68,68,.25);border-radius:12px;color:var(--text);font-family:inherit;cursor:pointer;text-align:left;transition:transform .15s ease,border-color .15s ease}.home-watch-btn:hover{border-color:#ef4444;transform:translateY(-1px)}.home-watch-icon{font-size:22px}.home-watch-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.home-watch-title{font-weight:800;font-size:14px}.home-watch-sub{font-size:11px;color:var(--text-muted)}.home-watch-pulse{width:10px;height:10px;background:#ef4444;border-radius:50%;box-shadow:0 0 10px #ef4444;animation:live-pulse 1.2s ease-in-out infinite}.account-entry-btn{width:100%;margin-top:6px}.home-logout{background:transparent;border:none;color:var(--text-muted);font-family:inherit;font-size:11px;cursor:pointer;margin-top:8px;text-decoration:underline;text-decoration-color:var(--border)}.home-logout:hover{color:var(--text-dim)}.auth{flex:1;display:grid;place-items:center;padding:24px;overflow-y:auto}.auth-card{width:min(420px,92vw);text-align:center;padding:36px 32px 28px;background:var(--panel);border:1px solid var(--border);border-radius:20px;box-shadow:0 30px 80px #00000080}.auth-tabs{display:flex;gap:4px;margin:18px 0 22px;background:var(--bg);padding:4px;border-radius:10px;border:1px solid var(--border)}.auth-tab{flex:1;padding:10px;background:transparent;border:none;color:var(--text-dim);font-family:inherit;font-weight:700;font-size:13px;border-radius:7px;cursor:pointer}.auth-tab-active{background:var(--panel-2);color:var(--text)}.auth-form{display:flex;flex-direction:column;gap:14px;text-align:left}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-weight:800}.auth-field input{padding:12px 14px;background:var(--bg);border:2px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:14px;outline:none;transition:border-color .15s}.auth-field input:focus{border-color:var(--accent)}.auth-input-error{border-color:#ef4444!important}.auth-error{color:#ef4444;font-size:11px}.auth-btn{margin-top:4px;padding:14px;background:linear-gradient(135deg,var(--hit),#5e9c3c);color:#fff;border:none;border-radius:10px;font-family:inherit;font-weight:800;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:46px}.auth-btn:hover:not(:disabled){transform:translateY(-1px)}.auth-btn:disabled{opacity:.6;cursor:wait}.auth-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.auth-divider{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.15em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-guest{padding:12px;background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:10px;font-family:inherit;font-weight:600;font-size:13px;cursor:pointer}.auth-guest:hover{color:var(--text);border-color:var(--text-muted)}.auth-note{text-align:center;color:var(--text-muted);font-size:11px;margin-top:4px}.screen-card-wide{max-width:920px;width:min(920px,92vw)}.screen-sub-sep{margin:0 8px;color:var(--text-muted)}.rank-list{display:flex;flex-direction:column;gap:3px;max-height:420px;overflow-y:auto}.rank-row-me{border-color:var(--hit);background:#79b85114}.rank-me-tag{display:inline-block;margin-left:6px;background:var(--hit);color:#fff;padding:1px 6px;border-radius:999px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.hist-list{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto;padding-right:4px}.hist-empty{text-align:center;padding:40px 20px}.hist-empty-icon{font-size:40px;margin-bottom:10px;opacity:.7}.hist-empty-text{font-weight:700;font-size:15px}.hist-empty-sub{color:var(--text-muted);font-size:13px;margin-top:4px}.hist-clear{margin-top:12px;width:100%;padding:10px;background:transparent;border:1px dashed var(--border);color:var(--text-muted);border-radius:8px;font-family:inherit;font-size:12px;cursor:pointer}.hist-clear:hover:not(:disabled){color:#ef4444;border-color:#ef4444}.hist-clear:disabled{opacity:.5;cursor:wait}.hist-row-clickable{cursor:pointer;transition:background .15s ease}.hist-row-clickable:hover{background:var(--panel-2)}.hist-replay-icon{color:var(--text-muted);font-size:14px;padding:0 4px}.hist-row-clickable:hover .hist-replay-icon{color:var(--accent)}.replay{flex:1;display:flex;flex-direction:column;padding:14px 24px;gap:12px;overflow:hidden}.replay-header{display:flex;align-items:center;gap:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.back-btn-static{position:static}.replay-title{flex:1}.replay-eyebrow{font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);font-weight:800}.replay-meta{font-size:14px;color:var(--text-dim);margin-top:2px}.replay-meta strong{color:var(--text)}.replay-sep{margin:0 8px;color:var(--text-muted)}.replay-when{font-family:JetBrains Mono,monospace;font-size:12px}.replay-controls{display:flex;gap:6px;align-items:center}.replay-ctrl{width:36px;height:36px;border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:8px;cursor:pointer;font-size:14px}.replay-ctrl:hover{background:var(--panel-2)}.replay-speed{background:var(--panel);border:1px solid var(--border);color:var(--text);padding:8px;border-radius:8px;font-family:inherit;font-size:12px}.replay-boards{flex:1}.replay-footer{display:flex;align-items:center;gap:16px;padding-top:10px}.replay-progress{flex:1}.replay-progress-track{height:6px;background:var(--panel-2);border-radius:999px;overflow:hidden}.replay-progress-fill{height:100%;background:linear-gradient(90deg,var(--hit),var(--accent));transition:width .4s ease}.replay-progress-label{font-size:11px;color:var(--text-muted);margin-top:4px;font-family:JetBrains Mono,monospace}.replay-answer-row{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.replay-answer-tiles{display:flex;gap:4px}.replay-answer-tile{width:24px;height:24px;display:grid;place-items:center;background:var(--hit);color:#fff;font-family:JetBrains Mono,monospace;font-weight:800;font-size:12px;border-radius:4px}.live-count-dot{display:inline-block;width:8px;height:8px;background:#ef4444;border-radius:50%;margin-right:8px;box-shadow:0 0 8px #ef4444;animation:live-pulse 1.2s ease-in-out infinite}@keyframes live-pulse{50%{opacity:.45;transform:scale(.75)}}.live-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;max-height:470px;overflow-y:auto;padding-right:4px}.live-empty{grid-column:1 / -1}.live-card{display:flex;flex-direction:column;gap:14px;padding:16px;background:var(--bg);border:1px solid var(--border);border-radius:14px;color:var(--text);font-family:inherit;text-align:left;cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.live-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 12px 30px #00000040}.live-card-header{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.live-card-status{display:flex;align-items:center;gap:6px;color:#ef4444}.live-status-dot{width:7px;height:7px;border-radius:50%;background:#ef4444;box-shadow:0 0 8px #ef4444;animation:live-pulse 1.2s ease-in-out infinite}.live-card-viewers{color:var(--text-muted)}.live-card-players{display:flex;flex-direction:column;gap:8px;align-items:stretch}.live-player{display:flex;align-items:center;gap:8px}.live-player-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--hit),#4a8a2c);display:grid;place-items:center;color:#fff;font-size:10px;font-weight:800;flex-shrink:0}.live-player-name{flex:1;font-weight:600;font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-player-pips{display:flex;gap:3px;flex-shrink:0}.live-pip{width:7px;height:7px;border-radius:50%;background:var(--panel-2)}.live-pip-filled{background:var(--text-dim)}.live-pip-win{background:var(--hit)!important;box-shadow:0 0 6px var(--hit)}.live-vs{text-align:center;font-family:JetBrains Mono,monospace;color:var(--text-muted);font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.15em}.live-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:4px;border-top:1px solid var(--border)}.live-card-turn{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:12px}.live-card-watch{color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:10px}@media (max-width: 760px){body{overflow:hidden}.app{min-height:100dvh}.home,.lobby{padding:max(14px,env(safe-area-inset-top)) max(14px,env(safe-area-inset-right)) max(14px,env(safe-area-inset-bottom)) max(14px,env(safe-area-inset-left))}.home-card,.lobby-card{width:100%;border-radius:14px;padding:28px 18px 22px}.logo-l{width:38px;height:38px;font-size:21px}.home-mode-row{flex-wrap:wrap}.home-nav-row{grid-template-columns:1fr}.rank-header,.rank-row{grid-template-columns:28px 1fr 28px 28px 28px 42px;gap:5px;padding:8px;font-size:11px}.rank-avatar{display:none}.hist-stats{grid-template-columns:repeat(2,1fr)}.hist-row-top,.hist-row-bottom{flex-direction:column;gap:2px}.lobby-players{padding:14px;gap:8px}.match{min-height:100dvh;max-height:none;overflow-y:auto;padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.match-header{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:10px;padding-bottom:10px}.brand{justify-content:center}.match-info{flex-wrap:wrap;justify-content:center;gap:6px}.info-chip{min-height:32px;padding:6px 9px;font-size:11px}.leave-btn{min-height:32px;padding:6px 10px}.dialog{padding:20px}.dialog-actions{grid-template-columns:1fr}.boards{grid-template-columns:1fr;gap:8px;align-items:center;overflow:visible}.board-col{gap:6px}.board-divider{display:none}.board-label{width:min(100%,300px);justify-content:space-between}.board,.row{gap:4px}.tile{width:min(13.2vw,42px);height:min(13.2vw,42px)}.tile-face{border-width:1px;border-radius:5px;font-size:19px}.kb{width:100%;gap:5px;margin-top:10px;padding-bottom:env(safe-area-inset-bottom)}.kb-row{width:100%;gap:4px;justify-content:center}.kb-key{flex:1 1 0;min-width:0;max-width:38px;height:44px;padding:0;font-size:13px;border-radius:5px}.kb-wide{flex:1.55 1 0;max-width:62px;font-size:11px}.toast{top:96px;max-width:calc(100vw - 28px);text-align:center}.waiting-bar{margin-top:8px;padding:10px}.endcard{position:fixed;padding:20px}.endcard-title{font-size:28px}.endcard-tile{width:42px;height:42px;font-size:20px}}@media (max-height: 640px){.match{padding:10px 16px 6px}.match-header{padding-bottom:8px;margin-bottom:8px}.board-label{font-size:12px}.row,.board{gap:4px}.kb{margin-top:8px;gap:4px}.kb-row{gap:4px}}@media (max-width: 760px){html,body,#root{height:auto;min-height:100%}body{overflow-x:hidden;overflow-y:auto;min-height:100dvh}.app{height:auto;min-height:100dvh}.home,.lobby,.screen,.auth{min-height:100dvh;place-items:start center;padding:calc(64px + env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));overflow-x:hidden;overflow-y:auto}.home-card,.lobby-card,.screen-card,.auth-card{width:100%;max-width:none;max-height:none;overflow:visible;border-radius:14px;padding:24px 16px 20px}.screen-card-wide,.screen-card-narrow{width:100%;max-width:none;padding:24px 16px 20px}.screen-title{font-size:22px;line-height:1.1}.screen-sub{font-size:13px;margin-bottom:16px}.back-btn{top:max(10px,env(safe-area-inset-top));right:max(10px,env(safe-area-inset-right));padding:7px 11px;font-size:12px}.profile-badge{top:max(10px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left))}.profile-badge-btn{min-height:36px;padding:4px 8px 4px 4px}.profile-badge-avatar{width:28px;height:28px;font-size:11px}.profile-badge-name{max-width:76px}.profile-pop{width:min(310px,calc(100vw - 20px))}.home-footer{flex-direction:column;align-items:stretch}.home-stats,.home-live-chip{justify-content:center}.code-box{padding:16px 10px}.code-value{gap:4px;margin-bottom:12px}.code-char{width:clamp(27px,9vw,38px);height:clamp(40px,12vw,48px);border-radius:6px;font-size:clamp(16px,5vw,20px)}.code-input{font-size:20px;letter-spacing:.32em;padding:14px 10px}.tabs{gap:4px}.tab{padding:8px 6px;font-size:11px}.rank-list,.hist-list{max-height:none;overflow:visible;padding-right:0}.rank-header,.rank-row{grid-template-columns:24px minmax(0,1fr) 24px 24px 24px 36px;gap:4px;padding:8px 6px;font-size:10px}.rank-name>span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-me-tag{display:none}.hist-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.hist-stat-points{grid-column:1 / -1}.hist-row{align-items:flex-start;gap:8px;padding:10px}.hist-row-top,.hist-row-bottom{align-items:flex-start}.hist-when,.hist-attempts{align-self:flex-start}.hist-replay-icon{display:none}.live-grid{max-height:none;overflow:visible}.match{height:auto;min-height:100dvh;max-height:none;overflow-x:hidden;overflow-y:auto;padding:max(8px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left))}.match-header{gap:8px;margin-bottom:8px;padding-bottom:8px}.brand{justify-content:center}.brand-l{width:24px;height:24px;font-size:13px}.brand-mode{margin-left:6px;padding:3px 6px;font-size:9px}.match-info{gap:4px}.info-chip{min-height:28px;padding:4px 7px;font-size:10px}.leave-btn{min-height:28px;padding:4px 8px;font-size:10px}.boards,.replay-boards{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px;flex:0 0 auto;align-items:start;justify-items:stretch;overflow:visible}.board-divider{display:none}.board-col{width:100%;min-width:0;gap:5px}.board-label{width:100%;max-width:166px;justify-content:space-between;gap:4px;font-size:11px}.board-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-meta{font-size:10px;flex-shrink:0}.board{width:100%;align-items:center;gap:3px}.row{justify-content:center;gap:3px}.tile{width:clamp(24px,8vw,32px);height:clamp(24px,8vw,32px)}.tile-face{border-width:1px;border-radius:5px;font-size:clamp(13px,4.4vw,18px)}.tile-cursor:after{bottom:-4px;height:2px}.kb{position:sticky;bottom:0;width:calc(100% + 16px);margin:8px -8px 0;padding:8px 8px env(safe-area-inset-bottom);gap:4px;background:linear-gradient(to top,var(--bg) 78%,rgba(14,15,18,0));z-index:20}.kb-row{width:100%;gap:3px;justify-content:center}.kb-key{height:38px;max-width:34px;border-radius:5px;font-size:12px}.kb-wide{max-width:54px;font-size:10px}.waiting-bar{margin-top:8px;padding:8px;font-size:12px}.toast{top:92px;max-width:calc(100vw - 24px)}.dialog{width:min(360px,calc(100vw - 24px));padding:18px}.endcard{padding:18px;overflow-y:auto}.endcard-title{font-size:26px}.endcard-tile{width:38px;height:38px;font-size:18px}.replay{height:auto;min-height:100dvh;overflow-x:hidden;overflow-y:auto;padding:max(10px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left))}.replay-header{flex-wrap:wrap;align-items:flex-start;gap:8px}.replay-title{min-width:0}.replay-meta{font-size:12px}.replay-controls{width:100%;justify-content:center}.replay-footer{flex-direction:column;align-items:stretch;gap:10px}.replay-answer-row{justify-content:center;flex-wrap:wrap}}@media (max-width: 380px){.boards,.replay-boards{gap:6px}.tile{width:clamp(23px,7.6vw,29px);height:clamp(23px,7.6vw,29px)}.tile-face{font-size:clamp(12px,4vw,16px)}.kb-key{height:36px;font-size:11px}.kb-wide{max-width:50px;font-size:9px}}
