:root{--bg: #0e1116;--bg-deep: #0a0d11;--panel: #161b22;--text: #e6edf3;--muted: #8b949e;--accent: #58a6ff;--on-accent: #0e1116;--danger: #f85149;--ok: #3fb950;--border: #30363d;--border-soft: #1f242d;--rate-text: rgba(255, 255, 255, .78)}:root[data-theme=light]{--bg: #fafbfc;--bg-deep: #eef1f4;--panel: #ffffff;--text: #1f2328;--muted: #57606a;--accent: #0969da;--on-accent: #ffffff;--danger: #cf222e;--ok: #1a7f37;--border: #d0d7de;--border-soft: #eaeef2;--rate-text: rgba(255, 255, 255, .92)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}button{background:var(--panel);color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:6px;cursor:pointer;font-size:14px}button:hover{border-color:var(--accent)}button.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent);font-weight:600}button.primary:hover{filter:brightness(1.1)}button:disabled{opacity:.4;cursor:not-allowed}input{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:14px}.app{max-width:1400px;margin:0 auto;padding:clamp(12px,4vw,24px);min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px}.header h1{margin:0;font-size:clamp(18px,4.5vw,22px);font-weight:600}.player-tag{font-size:13px;color:var(--muted)}.menu{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px}.mode-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:20px;cursor:pointer;transition:border-color .15s}.mode-card:hover{border-color:var(--accent)}.mode-card h2{margin:0 0 8px;font-size:16px}.mode-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.config-row{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.config-row label{font-size:13px;color:var(--muted)}select{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:14px}.game-area{display:flex;flex-direction:column;align-items:center;gap:20px}.hud{display:flex;flex-wrap:wrap;gap:8px 20px;font-size:13px;color:var(--muted);justify-content:center}.hud strong{color:var(--text)}.hud>div{white-space:nowrap}.board-wrap{padding:clamp(6px,1.5vw,12px);background:var(--panel);border-radius:8px;border:1px solid var(--border);max-width:100%}.board{display:grid;border:1px solid rgba(0,0,0,.27);-webkit-user-select:none;user-select:none}.square{width:var(--sq, 72px);height:var(--sq, 72px);display:flex;align-items:center;justify-content:center;font-size:calc(var(--sq, 72px) * .72);line-height:1;position:relative;cursor:pointer}.square.marked-correct:after,.square.marked-wrong:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:4px;pointer-events:none}.square.marked-correct:after{box-shadow:inset 0 0 0 3px var(--ok)}.square.marked-wrong:after{box-shadow:inset 0 0 0 3px var(--danger)}.square.hint{background-image:radial-gradient(circle,#14551e47,#14551e47)}.square.target:before{content:"";position:absolute;width:30%;height:30%;background:#14551e6b;border-radius:50%;pointer-events:none}.square.capture:before{content:"";position:absolute;top:4%;right:4%;bottom:4%;left:4%;border-radius:50%;box-shadow:inset 0 0 0 6px #14551e6b;pointer-events:none}.piece-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;line-height:1;z-index:1;pointer-events:auto;background:transparent}.piece-wrap.draggable{cursor:grab}.piece-wrap.draggable:active{cursor:grabbing}.piece{pointer-events:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.palette{display:flex;flex-wrap:wrap;gap:6px;padding:10px;background:var(--panel);border-radius:8px;border:1px solid var(--border);max-width:min(640px,100%);justify-content:center}.palette .slot{width:clamp(36px,9vw,48px);height:clamp(36px,9vw,48px);display:flex;align-items:center;justify-content:center;font-size:clamp(26px,6.5vw,34px);background:var(--bg-deep);border-radius:6px;cursor:grab;border:1px solid transparent;touch-action:none}.palette .slot:hover{border-color:var(--accent)}.palette .slot.dragging{opacity:.4}.palette .slot.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}.actions{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;justify-content:center}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:28px;min-width:320px;max-width:480px}.modal h2{margin:0 0 12px}.modal p{color:var(--muted);margin:0 0 16px;font-size:14px;line-height:1.5}.modal .row{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.result-summary{text-align:center;padding:20px 0}.result-summary .score{font-size:48px;font-weight:700;color:var(--accent)}.result-summary .label{color:var(--muted);font-size:13px}.leaderboard{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px;margin-top:24px}.leaderboard h3{margin:0 0 12px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.leaderboard .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.leaderboard table{width:100%;border-collapse:collapse;font-size:13px;min-width:480px}.leaderboard th,.leaderboard td{text-align:left;padding:6px 8px;border-bottom:1px solid var(--border-soft);white-space:nowrap}.leaderboard th{color:var(--muted);font-weight:500}.leaderboard .rank{color:var(--muted);width:30px}@media (max-width: 520px){.leaderboard table{font-size:12px;min-width:360px}.leaderboard th,.leaderboard td{padding:5px 6px}}.stats-grid{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px;margin-top:24px}.stats-grid h3{margin:0 0 12px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.stats-grid-table-wrap{overflow-x:auto}.stats-grid table{border-collapse:collapse;font-size:12px;width:100%}.stats-grid th,.stats-grid td{padding:8px 10px;text-align:center;border:1px solid var(--border-soft)}.stats-grid thead th{color:var(--muted);font-weight:500;font-size:11px}.stats-grid tbody th.scheme-row{text-align:left;color:var(--text);font-weight:600;background:var(--bg-deep);white-space:nowrap}.stats-grid tbody th.scheme-row{align-items:center}.stats-grid td.empty{background:var(--bg-deep);color:var(--muted)}.stats-grid td .ms{font-weight:600;color:#fff}.stats-grid td .rate{font-size:11px;color:var(--rate-text);margin-top:2px}.scheme-swatch{display:inline-flex;width:22px;height:14px;border-radius:2px;overflow:hidden;flex-shrink:0;vertical-align:middle;margin-right:6px;border:1px solid rgba(128,128,128,.25)}.scheme-swatch span{flex:1}@media (max-width: 520px){.stats-grid th,.stats-grid td{padding:6px}.stats-grid tbody th.scheme-row{font-size:11px}}.stats-callouts{margin-top:12px;font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:4px}.stats-callouts strong{color:var(--text)}.theme-toggle{padding:4px 10px;font-size:12px}.research-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px}.research-tabs button{padding:6px 12px;font-size:13px}.research-tabs button.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.scheme-table-wrap{margin-top:20px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px}.scheme-table-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.scheme-table-n{font-weight:400;text-transform:none;letter-spacing:0;font-size:12px}.scheme-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.scheme-table{border-collapse:collapse;font-size:13px;width:100%;min-width:600px}.scheme-table th{text-align:left;padding:5px 10px;color:var(--muted);font-weight:500;font-size:11px;border-bottom:1px solid var(--border)}.scheme-table td{padding:9px 10px;border-bottom:1px solid var(--border-soft);vertical-align:middle}.scheme-table tbody tr:last-child td{border-bottom:none}.diff-badge{font-size:10px;padding:1px 6px;border-radius:3px;white-space:nowrap;font-weight:500}.diff-easy{background:#3cb43c26;color:var(--ok)}.diff-medium{background:#c8a0002e;color:#c9a00a}.diff-hard{background:#dc78002e;color:#d97706}.diff-extreme{background:#dc32322e;color:var(--danger)}.rt-track{height:5px;background:var(--bg-deep);border-radius:3px;margin-bottom:4px;overflow:hidden;min-width:60px}.rt-fill{height:100%;background:var(--accent);border-radius:3px}.rt-num{font-size:12px;color:var(--text)}.st-acc{font-weight:600;min-width:46px}.st-raw{color:var(--muted)}.acc-hi{color:var(--ok)}.acc-mid{color:#d97706}.acc-lo{color:var(--danger)}.st-n{color:var(--muted);font-size:12px;text-align:right}.session-log{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.session-log-heading{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.session-row{display:flex;gap:10px;align-items:center;padding:7px 0;border-bottom:1px solid var(--border-soft);font-size:13px;flex-wrap:wrap}.session-row:last-child{border-bottom:none}.session-name{font-weight:600;min-width:70px}.session-mode{color:var(--muted);flex:1;font-size:12px}.session-score{color:var(--accent);font-weight:600}.session-rt,.session-err{color:var(--muted);font-size:12px}.session-time{color:var(--muted);font-size:11px;margin-left:auto}.section-heading{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.scheme-scheme-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.scheme-scheme-tabs button{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;font-size:12px}.scheme-scheme-tabs button.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.scheme-scheme-tabs button.active .scheme-swatch{border-color:#ffffff4d}@media (max-width: 520px){.scheme-tab-name{display:none}.scheme-scheme-tabs button{padding:5px 6px}}.raw-data-wrap{margin-top:20px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px}.raw-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-height:420px;overflow-y:auto}.raw-table{border-collapse:collapse;font-size:12px;width:100%;min-width:560px}.raw-table th{text-align:left;padding:5px 10px;color:var(--muted);font-weight:500;font-size:11px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--panel);z-index:1}.raw-table td{padding:7px 10px;border-bottom:1px solid var(--border-soft);vertical-align:middle}.raw-table tbody tr:last-child td{border-bottom:none}.raw-table tbody tr:hover{background:var(--bg-deep)}.raw-date{color:var(--muted);white-space:nowrap}.raw-name{font-weight:600}.raw-score{color:var(--accent);font-weight:600}.raw-muted{color:var(--muted)}.raw-err{color:var(--danger)}.raw-ok{color:var(--ok)}
