*{box-sizing:border-box}:root{--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--radius: 12px;--accent: #6366f1;--accent-hover: #4f46e5;--accent-text: #ffffff;--win: #4ade80;--lose: #f87171}:root[data-theme=light]{--bg: #f3f5fa;--bg-gradient: radial-gradient(1200px 600px at 50% -10%, #e4e9ff 0%, #f3f5fa 60%);--panel: #ffffff;--panel-border: #dde2ee;--text: #1d2433;--text-subtle: #6b7280;--input-bg: #f4f6fb;--shadow: 0 10px 30px rgba(30, 41, 80, .08)}:root[data-theme=dark]{--bg: #0b0e17;--bg-gradient: radial-gradient(1200px 600px at 50% -10%, #1a2240 0%, #0b0e17 60%);--panel: #141927;--panel-border: #262e44;--text: #e6e9f2;--text-subtle: #8b93a7;--input-bg: #0f1422;--shadow: 0 10px 30px rgba(0, 0, 0, .45)}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);background-image:var(--bg-gradient);background-attachment:fixed;color:var(--text);transition:background-color .25s ease,color .25s ease}h1,h2,h3{margin:0}code{background:var(--input-bg);border:1px solid var(--panel-border);border-radius:6px;padding:2px 8px;font-size:.9em;-webkit-user-select:all;user-select:all}.page{min-height:100%;display:flex;flex-direction:column}.btn{font-family:var(--font);font-size:.95rem;font-weight:600;color:var(--text);background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;padding:10px 18px;cursor:pointer;text-decoration:none;text-align:center;transition:transform .08s ease,background .15s ease,border-color .15s ease,opacity .15s ease}.btn:hover:not(:disabled){border-color:var(--accent)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:default}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-text)}.btn.primary:hover:not(:disabled){background:var(--accent-hover)}.btn.big{font-size:1.05rem;padding:14px 24px}.btn.subtle{background:transparent;color:var(--text-subtle)}.btn.small{padding:6px 12px;font-size:.85rem}.btn.key{min-width:110px;font-variant-numeric:tabular-nums}.btn.key.listening{border-color:var(--accent);color:var(--accent)}input[type=text]{font-family:var(--font);font-size:1rem;color:var(--text);background:var(--input-bg);border:1px solid var(--panel-border);border-radius:10px;padding:12px 14px;outline:none;transition:border-color .15s ease;width:100%}input[type=text]:focus{border-color:var(--accent)}input[type=range]{accent-color:var(--accent);flex:1}.home-page{align-items:center;justify-content:center;gap:28px;padding:40px 20px}.home-header{text-align:center;display:flex;flex-direction:column;gap:10px;align-items:center}.home-header h1{font-size:2.6rem;font-weight:800;letter-spacing:-.02em}.tagline{margin:0;color:var(--text-subtle)}.title-blocks{display:flex;gap:6px}.title-block{width:18px;height:18px;border-radius:5px;animation:block-pop 2.4s ease-in-out infinite}@keyframes block-pop{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.home-card{width:min(420px,100%);background:var(--panel);border:1px solid var(--panel-border);border-radius:16px;box-shadow:var(--shadow);padding:28px;display:flex;flex-direction:column;gap:18px}.field{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--text-subtle);font-weight:600}.divider{display:flex;align-items:center;gap:12px;color:var(--text-subtle);font-size:.85rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--panel-border)}.join-row{display:flex;gap:10px}.join-row input{text-transform:uppercase;letter-spacing:.1em}.home-footer{color:var(--text-subtle);font-size:.85rem;text-align:center}.play-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 22px}.brand{font-weight:800;text-decoration:none;color:var(--text);letter-spacing:-.01em}.room-info{display:flex;align-items:center;gap:10px}.room-code{font-weight:700;letter-spacing:.08em}.header-right{display:flex;align-items:center;gap:10px}.conn-dot{width:10px;height:10px;border-radius:50%;background:var(--text-subtle)}.conn-dot.connected{background:var(--win)}.conn-dot.connecting,.conn-dot.reconnecting{background:#facc15;animation:pulse 1s ease-in-out infinite}@keyframes pulse{50%{opacity:.4}}.center-page{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:16px;box-shadow:var(--shadow);padding:28px;display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center;max-width:460px;width:100%}.panel.lobby h2{font-size:1.4rem}.hint{color:var(--text-subtle);font-size:.9rem;margin:0;line-height:1.6}.player-list{list-style:none;margin:0;padding:0;width:100%;display:flex;flex-direction:column;gap:8px}.player-list li{display:flex;justify-content:space-between;background:var(--input-bg);border:1px solid var(--panel-border);border-radius:10px;padding:10px 14px;font-weight:600}.ready{color:var(--text-subtle);font-weight:600}.ready.yes{color:var(--win)}.game-view{flex:1;display:flex;align-items:flex-start;justify-content:center;gap:28px;padding:8px 20px 28px;flex-wrap:wrap}.player-area{display:flex;flex-direction:column;align-items:center;gap:8px}.board-wrap{position:relative}.player-canvas canvas,.opponent-canvas canvas{display:block}.player-meta{display:flex;gap:14px;align-items:baseline}.player-name{font-weight:700}.player-wins{color:var(--text-subtle);font-size:.9rem}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.countdown{font-size:5rem;font-weight:800;color:var(--text);text-shadow:0 4px 24px rgba(0,0,0,.3);animation:countdown-pop .9s ease-out}.countdown.go{color:var(--win)}@keyframes countdown-pop{0%{transform:scale(1.6);opacity:0}20%{transform:scale(1);opacity:1}to{transform:scale(.92);opacity:.9}}.side-panel{display:flex;flex-direction:column;gap:16px;padding-top:36px;width:220px}.opponent-card,.stats-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;box-shadow:var(--shadow);padding:14px}.opponent-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.opponent-board-wrap{position:relative;display:flex;justify-content:center}.opponent-status{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--lose);background:color-mix(in srgb,var(--panel) 60%,transparent);border-radius:8px}.stats-card{display:flex;justify-content:space-around}.stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-value{font-size:1.3rem;font-weight:800;font-variant-numeric:tabular-nums}.stat-label{font-size:.75rem;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.08em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a128c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{background:var(--panel);border:1px solid var(--panel-border);border-radius:16px;box-shadow:var(--shadow);padding:24px;width:min(480px,100%);max-height:86vh;overflow-y:auto;display:flex;flex-direction:column;gap:20px;animation:modal-in .18s ease-out}@keyframes modal-in{0%{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center}.settings-section{display:flex;flex-direction:column;gap:10px}.settings-section h3{font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle)}.settings-section-header{display:flex;justify-content:space-between;align-items:center}.segmented{display:flex;background:var(--input-bg);border:1px solid var(--panel-border);border-radius:10px;padding:4px;gap:4px}.segment{flex:1;border:none;background:transparent;color:var(--text-subtle);font-family:var(--font);font-weight:600;padding:8px;border-radius:7px;cursor:pointer}.segment.active{background:var(--accent);color:var(--accent-text)}.volume-row{display:flex;align-items:center;gap:12px;font-weight:600}.volume-row>span:first-child{width:70px}.volume-value{width:44px;text-align:right;color:var(--text-subtle);font-variant-numeric:tabular-nums}.keymap-grid{display:flex;flex-direction:column;gap:8px}.keymap-row{display:flex;justify-content:space-between;align-items:center;font-weight:600}.result-backdrop{z-index:40}.result-modal{align-items:center;text-align:center;gap:16px;animation:result-in .35s cubic-bezier(.2,.9,.3,1.2)}@keyframes result-in{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.result-title{font-size:2.2rem;font-weight:800}.result-title.win{color:var(--win)}.result-title.lose{color:var(--lose)}.score-line{display:flex;gap:24px;color:var(--text-subtle);font-weight:600}@media(max-width:860px){.side-panel{width:auto;flex-direction:row;align-items:flex-start;padding-top:0}}
