:root{--bg: #f4ead2;--bg-2: #fbf5e3;--bg-3: #efe1be;--paper: #ffffff;--ink: #2a2520;--fg: #2a2520;--fg-dim: #7a6b58;--ink-dim: #c8b694;--border: #c8b694;--accent: #6b9347;--accent-2: #4a6a31;--pop: #c44545;--pop-2: #8e2828;--pop-light: #de6c6c;--board-light: #f0d9b5;--board-dark: #b58863;--success: #5b7e3c;--success-bg: #e8f5bd;--warn: #c98a14;--warn-bg: #f5e3b3;--danger: #c44545;--danger-bg: #f4d4d4;--chart-cool: #a2cb8b;--chart-warm: #c44545;--chart-line: #2a2520;--chart-grid: #d6c8a3;--mint-bg: #f4ead2;--mint-hover: #efe1be;--mint: #6b9347;--mint-ink: #4a6a31;--font-pixel: "Pixelify Sans", ui-monospace, "DejaVu Sans Mono", monospace;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "DM Mono", ui-monospace, "Menlo", "Consolas", monospace;font-family:var(--font-body);color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--ink);background-image:radial-gradient(rgba(42,37,32,.04) 1px,transparent 1px),radial-gradient(rgba(42,37,32,.025) 1px,transparent 1px);background-size:6px 6px,13px 13px;background-position:0 0,3px 3px}a{color:var(--pop);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}a:hover{color:var(--pop-2)}button{font-family:var(--font-body);background:var(--bg-2);color:var(--ink);border:2px solid var(--ink);padding:7px 14px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;box-shadow:2px 2px 0 0 var(--ink);transition:transform 80ms ease,box-shadow 80ms ease,background .12s ease}button:hover{background:var(--bg-3)}button:active:not(:disabled){transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink)}button:disabled{background:var(--bg-3);color:var(--fg-dim);border-color:var(--ink-dim);box-shadow:2px 2px 0 0 var(--ink-dim);cursor:not-allowed}button.primary{background:var(--pop);color:var(--paper);border-color:var(--ink)}button.primary:hover{background:var(--pop-light)}button.danger{border-color:var(--danger);color:var(--danger)}button.success{border-color:var(--success);color:var(--success)}input,select{font-family:var(--font-body);background:var(--paper);color:var(--ink);border:2px solid var(--ink);padding:6px 10px;border-radius:4px;font-size:13px;box-shadow:2px 2px 0 0 var(--ink)}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:2px 2px 0 0 var(--accent)}input:disabled,input[readonly]{background:var(--bg-3);color:var(--fg-dim)}label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--fg-dim);font-weight:500}.setup-form>label{font-family:var(--font-pixel);font-size:13px;text-transform:lowercase;color:var(--ink);font-weight:500;letter-spacing:0}.app{max-width:1200px;margin:0 auto;padding:28px 32px 48px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:16px;border-bottom:2px solid var(--ink)}.header h1{margin:0;font-family:var(--font-pixel);font-size:28px;font-weight:600;letter-spacing:0;display:flex;align-items:center;gap:10px}.wm-pop{color:var(--pop)}.header .crumbs{font-size:12px;color:var(--fg-dim);display:flex;align-items:center;gap:16px}.header .crumbs-nav{display:flex;align-items:center;gap:6px}.header .crumbs button{padding:5px 10px;font-size:12px}.header .crumbs button.active-nav{background:var(--pop);color:var(--paper);border-color:var(--ink)}.header .crumbs button.active-nav:hover{background:var(--pop-2)}.settings-screen{max-width:720px}.settings-section{margin-top:24px;padding:16px 20px;background:var(--bg-2);border:1px solid var(--border);border-radius:3px}.settings-section h3{margin:0 0 12px;font-family:var(--font-pixel);font-size:16px;letter-spacing:0}.settings-row{display:flex;align-items:center;gap:16px;padding:6px 0;font-size:13px}.settings-key{flex:0 0 90px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim)}.settings-value{color:var(--ink)}.settings-link-row{display:flex;gap:16px;align-items:flex-start;padding:12px 0;border-top:1px solid var(--border)}.settings-link-row:first-of-type{border-top:none;padding-top:4px}.settings-link-info{flex:1;min-width:0}.settings-link-title{font-family:var(--font-mono);font-size:14px;color:var(--ink);margin-bottom:4px}.settings-link-desc{font-size:12px;color:var(--fg-dim);line-height:1.5}.settings-link-actions{display:flex;gap:8px;flex-shrink:0}.celebration-modal{max-width:460px;text-align:center;padding-top:24px}.celebration-emoji{font-size:52px;line-height:1;margin-bottom:10px}.celebration-title{margin:0 0 6px;font-family:var(--font-pixel);font-size:22px;letter-spacing:0}.celebration-blurb{margin:0 0 16px;font-size:13px;color:var(--fg-dim)}.celebration-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0 18px}.cel-stat{padding:10px 6px;background:var(--bg-2);border:1px solid var(--border);border-radius:3px}.cel-stat-num{font-family:var(--font-pixel);font-size:18px;color:var(--ink);line-height:1.1}.cel-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim);margin-top:2px}.game-stats-screen{max-width:920px}.game-stats-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.game-stats-sub{font-size:12px;color:var(--fg-dim);margin-top:2px;font-family:var(--font-mono)}.game-stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:18px}.eval-compare{margin-bottom:18px}.review-chart-row{grid-column:1 / -1;display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:stretch;margin-top:18px}.review-chart-wrap{min-width:0}.eval-legend{display:flex;flex-direction:column;justify-content:space-evenly;gap:8px;padding:14px 16px;background:var(--bg-2);border:2px solid var(--ink);border-radius:4px;box-shadow:3px 3px 0 0 var(--ink);font-size:11px;font-family:var(--font-mono);color:var(--fg-dim);align-self:stretch;min-width:150px}.eval-legend-row{display:flex;align-items:center;gap:8px}.eval-legend-swatch{display:inline-block;flex-shrink:0;width:18px;height:12px;border-radius:2px}.eval-legend-swatch.swatch-engine{background:var(--fg-dim);height:2px;margin-block:5px}.eval-legend-swatch.swatch-user{position:relative;background:transparent;border-top:1.5px dashed #5d7f33;height:0;margin-block:5px}.eval-legend-swatch.swatch-user:after{content:"";position:absolute;left:50%;top:50%;width:6px;height:6px;margin:-3px 0 0 -3px;background:#5d7f33;border:1px solid var(--paper);border-radius:50%}.eval-legend-swatch.swatch-band{background:#a8c97d;opacity:.7}.eval-legend-swatch.swatch-miss{background:#e8a4a4}.eval-legend-swatch.swatch-scrub{background:transparent;border-left:1.5px dashed var(--ink);width:0;margin-left:8px}.eval-compare-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.eval-transition-toggle{display:flex;gap:4px}.eval-transition-toggle button{padding:3px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.eval-transition-hint{font-size:11px;color:var(--fg-dim);font-family:var(--font-mono)}.stats-section-title{margin:0 0 6px;font-size:13px;text-transform:uppercase;color:var(--fg-dim);letter-spacing:.04em}.eval-compare-stats{display:flex;flex-wrap:wrap;gap:6px 20px;margin:6px 0 10px;font-size:13px;font-family:var(--font-mono);color:var(--ink)}.eval-compare-svg{width:100%;height:auto;background:var(--bg-2);border:1px solid var(--border);border-radius:3px;display:block}.chart-empty{padding:24px;text-align:center;font-size:13px;color:var(--fg-dim);background:var(--bg-2);border:1px solid var(--border);border-radius:3px}.game-stats-table{width:100%;border-collapse:collapse;background:var(--bg-2);border:1px solid var(--border);border-radius:3px;overflow:hidden;font-size:13px}.game-stats-table th,.game-stats-table td{padding:8px 12px;border-bottom:1px solid var(--border);text-align:left}.game-stats-table th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim);background:var(--bg-3)}.game-stats-table tbody tr:last-child td{border-bottom:none}.game-stats-row.exact td{color:var(--success)}.game-stats-row.miss td{color:var(--danger)}.cel-stat-delta{margin-top:4px;font-size:10px;font-family:var(--font-mono);color:var(--fg-dim);letter-spacing:.02em}.cel-stat-delta.better{color:var(--success)}.cel-stat-delta.worse{color:var(--danger)}.cel-stat-delta.neutral{color:var(--fg-dim)}.game-stats-compare-note{font-size:11px;color:var(--fg-dim);font-family:var(--font-mono);margin:-8px 0 18px}.game-stats-bias{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}@media (max-width: 900px){.game-stats-bias{grid-template-columns:1fr}}.game-stats-bias-hint{font-size:12px;color:var(--fg-dim);margin:4px 0 8px;font-style:italic}.confetti-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:1000}.confetti-piece{position:absolute;top:-16px;width:8px;height:12px;animation-name:confetti-fall;animation-timing-function:linear;animation-iteration-count:1;animation-fill-mode:forwards;border-radius:1px}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}.setup-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:600px}.setup-form .full{grid-column:1 / -1}.game-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--bg-2);border:2px solid var(--ink);box-shadow:3px 3px 0 0 var(--ink)}.game-table th,.game-table td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--ink-dim)}.game-table tr:last-child td{border-bottom:none}.game-table th{font-family:var(--font-pixel);font-size:13px;text-transform:lowercase;color:var(--ink);letter-spacing:0;font-weight:500;background:var(--bg-3);border-bottom:2px solid var(--ink)}.game-table tr.clickable{cursor:pointer}.game-table tr.clickable:hover td{background:var(--bg-3)}.game-table tr.no-blunders td{opacity:.55}.game-table td.opening-cell{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--fg-dim)}.row-delete-btn{width:22px;height:22px;padding:0;font-size:11px;line-height:1;border-radius:3px;color:var(--fg-dim)}.row-delete-btn:hover{color:var(--danger)}.status-pill{display:inline-block;padding:2px 8px;border-radius:3px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:2px solid var(--ink)}.status-pill.new{background:var(--bg-3);color:var(--fg-dim)}.status-pill.in_progress{background:var(--warn-bg);color:#6b4a08}.status-pill.done{background:var(--success-bg);color:#2f521b}.action-btn{display:inline-block;width:100px;padding:3px 8px;font-size:11px;font-weight:600;border-radius:3px;text-align:center;white-space:nowrap}.action-btn.todo{background:var(--accent);color:var(--paper);border-color:var(--ink)}.action-btn.todo:hover:not(:disabled){background:var(--accent-2)}.action-btn.todo.alert{background:var(--pop)}.action-btn.todo.alert:hover:not(:disabled){background:var(--pop-light)}.action-btn.done{background:var(--success-bg);color:#2f521b;border-color:var(--ink)}.action-btn.done:hover:not(:disabled){background:#c9e0ad}.action-btn.done.alert{background:#fae0e0;color:var(--pop-2);border-color:var(--ink)}.action-btn.done.alert:hover:not(:disabled){background:#f4c8c8}.review{display:grid;grid-template-columns:minmax(400px,540px) 1fr;gap:28px;align-items:stretch}.board-wrap{width:100%;max-width:520px}.board-shell{border:2px solid var(--ink);border-radius:4px;box-shadow:3px 3px 0 0 var(--ink);overflow:hidden;background:var(--ink);line-height:0}.side-panel{background:var(--bg-2);border:2px solid var(--ink);box-shadow:3px 3px 0 0 var(--ink);border-radius:4px;padding:16px 18px;display:flex;flex-direction:column;gap:14px}.side-panel h3{margin:0;font-family:var(--font-pixel);font-size:16px;text-transform:lowercase;letter-spacing:0;color:var(--ink);font-weight:500}.side-panel .meta{font-size:13px;line-height:1.55}.side-panel .meta .key{color:var(--fg-dim);display:inline-block;width:90px;text-transform:uppercase;font-size:11px;letter-spacing:.05em}.eval-swing{font-family:var(--font-mono);font-size:15px}.eval-swing .before{color:var(--fg-dim)}.eval-swing .after{color:var(--danger);font-weight:700}.pv-line{font-family:var(--font-mono);font-size:14px;line-height:1.65;background:var(--bg-3);padding:10px 12px;border-radius:3px;border:1px solid var(--ink-dim)}.pv-move{cursor:pointer;padding:1px 4px;border-radius:2px}.pv-move.active{background:var(--accent);color:var(--paper)}.pv-move:hover{background:var(--bg)}.controls{display:flex;gap:8px;flex-wrap:wrap}.controls button{flex:1;min-width:80px}.empty-state{color:var(--fg-dim);text-align:center;padding:60px 20px;font-size:14px}.error{color:#6b1f10;background:var(--danger-bg);padding:10px 14px;border:2px solid var(--danger);border-radius:3px;margin:12px 0;font-size:13px}.loading{color:var(--fg-dim);font-style:italic}.kbd{display:inline-block;padding:1px 6px;font-family:var(--font-mono);font-size:11px;background:var(--bg-3);border:1px solid var(--ink);border-radius:2px}.practice-nav{display:flex;gap:8px;align-items:center;margin-top:12px}.practice-nav button{padding:5px 10px;font-size:13px}.practice-nav-info{flex:1;text-align:center;font-family:var(--font-mono);font-size:13px}.practice-hint{margin-top:8px;font-size:12px;color:var(--fg-dim)}.bucket-strip{margin-top:14px;background:var(--bg-2);border:2px solid var(--ink);border-radius:4px;padding:8px 10px;box-shadow:3px 3px 0 0 var(--ink)}.bucket-strip.disabled{opacity:.55}.bucket-strip-legend{display:flex;font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.bucket-strip-row{display:flex;gap:3px}.bucket-btn{flex:1;min-width:0;padding:7px 2px;font-family:var(--font-mono);font-size:12px;background:var(--paper);border:2px solid var(--ink);color:var(--ink);border-radius:3px;box-shadow:1px 1px 0 0 var(--ink)}.bucket-btn:hover:not(:disabled){background:var(--bg-3);transform:translate(-1px,-1px);box-shadow:2px 2px 0 0 var(--ink)}.bucket-btn.selected{background:var(--pop);color:var(--paper);border-color:var(--ink);font-weight:700}.bucket-btn.actual{outline:2px solid var(--success);outline-offset:-2px}.bucket-btn.selected.actual{outline-color:var(--paper)}.practice-guess-list{display:flex;flex-direction:column;gap:5px;max-height:360px;overflow-y:auto;margin-top:4px}.practice-guess-row,.practice-result-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--paper);border:1px solid var(--ink-dim);border-radius:3px;font-size:13px;font-family:var(--font-mono);color:var(--ink);cursor:pointer;text-align:left}.practice-guess-row:hover,.practice-result-row:hover{background:var(--bg-3)}.practice-result-row.exact{border-color:var(--success)}.practice-result-row.close{border-color:var(--warn)}.practice-result-row.miss{border-color:var(--danger)}.bucket-chip{display:inline-block;padding:1px 6px;background:var(--bg-3);border:1px solid var(--ink);border-radius:2px;font-family:var(--font-mono);font-size:12px}.eval-banner{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-3);border:1px solid var(--border);border-radius:3px;font-size:12px;font-family:var(--font-mono)}.eval-banner-pair{display:inline-flex;align-items:center;gap:4px}.eval-banner-key{text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim);font-size:10px}.eval-banner-eval{color:var(--fg-dim)}.eval-banner-sep{color:var(--border)}.eval-banner-muted{color:var(--fg-dim);font-style:italic}.practice-summary{display:flex;flex-wrap:wrap;gap:8px 18px;padding:10px 12px;background:var(--bg-3);border:2px solid var(--ink);border-radius:3px}.stat-row{display:flex;flex-direction:column;min-width:60px}.stat-label{font-size:10px;text-transform:uppercase;color:var(--fg-dim);letter-spacing:.06em;font-weight:600}.stat-value{font-size:16px;font-family:var(--font-pixel)}.stats-screen{display:flex;flex-direction:column;gap:20px}.stats-overall{display:flex;flex-wrap:wrap;gap:14px}.stat-card{flex:1;min-width:160px;background:var(--bg-2);border:2px solid var(--ink);border-radius:4px;padding:14px 16px;box-shadow:3px 3px 0 0 var(--ink)}.stat-card-label{font-size:11px;text-transform:uppercase;color:var(--fg-dim);letter-spacing:.06em;font-weight:700;display:flex;align-items:center;gap:4px}.stat-card-value{font-size:26px;font-family:var(--font-pixel);margin-top:4px;line-height:1;color:var(--pop)}.stat-card-value .unit{font-family:var(--font-body);font-size:11px;color:var(--fg-dim);margin-left:4px;font-weight:500}.stat-card-sub{font-size:11px;color:var(--fg-dim);margin-top:4px}.stats-tabs{display:flex;gap:4px;border-bottom:2px solid var(--ink);margin-bottom:8px}.stats-tabs button{background:transparent;border:2px solid transparent;border-bottom:none;padding:8px 18px;border-radius:6px 6px 0 0;color:var(--fg-dim);font-family:var(--font-pixel);font-size:14px;font-weight:500;margin-bottom:-2px;box-shadow:none;text-transform:lowercase}.stats-tabs button:hover{color:var(--ink)}.stats-tabs button.active{color:var(--ink);background:var(--bg-2);border-color:var(--ink);border-bottom-color:var(--bg-2);font-weight:600}.chart-empty{color:var(--fg-dim);font-size:13px;padding:30px 8px;background:var(--bg-2);border:2px dashed var(--ink-dim);border-radius:4px;text-align:center}.stats-section-blurb{font-size:13px;color:var(--fg-dim);max-width:720px;line-height:1.55}.stats-section-title{margin:0;font-family:var(--font-pixel);font-size:14px;color:var(--ink);letter-spacing:0;text-transform:lowercase;font-weight:500;display:flex;align-items:center;gap:8px}.stats-section-title:before{content:"";display:inline-block;width:8px;height:8px;background:var(--pop);border:1.5px solid var(--ink);box-shadow:1px 1px 0 0 var(--ink)}.chart-wrap{max-width:720px;width:100%}.charts-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;max-width:1200px}.chart-col{display:flex;flex-direction:column;gap:8px;min-width:0}.chart-col>.stats-section-title{margin:0}@media (max-width: 900px){.charts-row{grid-template-columns:1fr}}.trendline,.reviewbars,.eval-compare-svg{width:100%;height:auto;background:var(--bg-2);border:2px solid var(--ink);border-radius:4px;box-shadow:3px 3px 0 0 var(--ink);display:block}.help-tip{display:inline-block;margin-left:4px;width:14px;height:14px;border-radius:50%;background:var(--bg-3);border:1.5px solid var(--ink);font-size:9px;text-align:center;line-height:11px;color:var(--ink);cursor:help;vertical-align:middle;font-family:var(--font-body);text-transform:none;letter-spacing:0;font-weight:700}.help-tip:hover{background:var(--pop);color:var(--paper);border-color:var(--ink)}.row-action-sm{padding:3px 10px;font-size:12px;background:var(--bg-2);border:1.5px solid var(--ink);color:var(--ink);border-radius:3px;box-shadow:1px 1px 0 0 var(--ink)}.row-action-sm:hover:not(:disabled){background:var(--accent);color:var(--paper)}.row-action-sm:disabled{color:var(--fg-dim);background:var(--bg-3);opacity:.7}.eval-compare{margin-top:28px;max-width:980px}.eval-compare-stats{display:flex;flex-wrap:wrap;gap:8px 22px;margin:6px 0 10px;font-size:13px;font-family:var(--font-mono)}.signin-screen{display:flex;justify-content:center;padding:64px 20px 40px}.signin-card{max-width:480px;background:var(--bg-2);border:2px solid var(--ink);border-radius:6px;padding:36px 32px;text-align:center;box-shadow:4px 4px 0 0 var(--ink)}.signin-card .signin-logo{display:flex;justify-content:center;margin-bottom:8px}.signin-card h2{margin:4px 0 12px;font-family:var(--font-pixel);font-size:32px;font-weight:600;letter-spacing:0}.signin-card p{color:var(--fg-dim);font-size:14px;line-height:1.55}.signin-btn{margin-top:16px;padding:10px 24px;font-size:14px;background:var(--accent);border-color:var(--ink)}.signin-btn:hover{background:var(--accent-2)}.signin-fine{margin-top:18px;font-size:12px}.signin-tabs{display:flex;gap:8px;margin-top:18px;justify-content:center}.signin-form{display:flex;flex-direction:column;gap:10px;margin-top:14px;text-align:left}.signin-form label{display:flex;flex-direction:column;gap:4px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim)}.signin-form input{font-size:14px;padding:8px 10px;text-transform:none;letter-spacing:0;color:var(--ink)}.movetable-wrap{margin-top:10px;background:var(--bg-2);border:1px solid var(--border);border-radius:3px;flex:1 1 0;min-height:120px;overflow-y:auto;font-family:var(--font-mono);font-size:13px}.movetable{display:grid;grid-template-columns:38px 1fr 1fr;align-items:stretch}.movetable-row{display:contents}.movetable-row>.movetable-num,.movetable-row>.movetable-cell{border-bottom:1px solid var(--border);min-height:28px}.movetable-num{color:var(--fg-dim);text-align:right;-webkit-user-select:none;user-select:none;background:var(--bg-3);display:flex;align-items:center;justify-content:flex-end;padding:0 8px;border-right:1px solid var(--border)}.movetable-cell{display:flex;align-items:stretch;padding:0}.movetable-cell.black{border-left:1px solid var(--border)}.movetable-cell.empty{color:var(--fg-dim);align-items:center;padding:0 10px}.movetable-ellipsis{padding-left:2px}.movetable-row:has(+.movetable-comment)>.movetable-num,.movetable-row:has(+.movetable-comment)>.movetable-cell{border-bottom:none}.movetable-move{flex:1;display:flex;align-items:center;padding:5px 10px;margin:0;background:transparent;border:none;border-radius:0;box-shadow:none;font-family:inherit;font-size:inherit;font-weight:500;color:var(--ink);cursor:pointer;text-align:left;transition:background 80ms ease,box-shadow 80ms ease}.movetable-san{flex-shrink:0}.movetable-move .guess-chip{margin-left:auto}.movetable-move:hover{background:var(--bg-3)}.movetable-move:active:not(:disabled){transform:none;box-shadow:inset 2px 2px #00000026}.movetable-move.active{background:var(--accent);color:var(--paper);box-shadow:inset 0 0 0 2px var(--ink),2px 2px 0 0 var(--ink);position:relative;z-index:2}.guess-chip{display:inline-flex;align-items:center;gap:2px;padding:1px 5px;background:var(--bg-3);border:1px solid var(--ink-dim);border-radius:2px;font-family:var(--font-mono);font-size:10px;line-height:1.4;color:var(--ink);font-weight:600;font-style:normal;white-space:nowrap}.guess-chip-sep{color:var(--fg-dim);font-weight:400;padding:0 1px}.guess-chip.exact{background:var(--success-bg);border-color:var(--success);color:var(--success)}.guess-chip.close{background:var(--warn-bg);border-color:var(--warn);color:var(--warn)}.guess-chip.miss{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.movetable-move.active .guess-chip{background:var(--paper);border-color:var(--ink)}.movetable-comment{grid-column:1 / -1;padding:7px 12px 7px 14px;background:var(--mint-bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:var(--font-body);font-size:12.5px;color:var(--mint-ink);font-style:italic;font-weight:500;line-height:1.5;white-space:pre-wrap;cursor:text}.movetable-comment:hover{background:var(--mint-hover)}.movetable-comment.editing{cursor:default}.movetable-comment-input{width:100%;margin:0;padding:4px 6px;background:var(--paper);border:1px solid var(--mint);border-radius:2px;font-family:var(--font-body);font-size:12.5px;color:var(--ink);font-style:normal;line-height:1.5;resize:vertical;box-sizing:border-box;box-shadow:none}.movetable-comment-input:focus{outline:2px solid var(--accent);outline-offset:-2px}.movetable-comment-hint{margin-top:4px;font-size:10px;color:var(--mint-ink);opacity:.7;font-style:normal;letter-spacing:.04em}.movetable-sidelines{grid-column:1 / -1;padding:5px 12px 6px 14px;background:var(--mint-bg);border-left:3px solid var(--mint);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:3px}.movetable-sideline{font-style:italic;color:var(--ink);line-height:1.75}.line{display:inline}.line-depth-2,.line-depth-3,.line-depth-4{color:var(--fg-dim);opacity:1}.line-movenum{color:var(--mint-ink);font-weight:700;font-style:normal;margin-right:1px}.line-paren{color:var(--mint);font-weight:700;font-style:normal;margin:0 1px}.line-comment{color:var(--mint-ink);font-style:italic;font-weight:500;opacity:.95}.line-move{display:inline;padding:1px 4px;margin:0;background:transparent;border:none;border-radius:0;box-shadow:none;font-family:inherit;font-size:inherit;font-style:italic;font-weight:600;color:inherit;cursor:pointer;transition:background 80ms ease}.line-move:hover{background:var(--mint-hover)}.line-move:active:not(:disabled){transform:none;box-shadow:inset 1px 1px #00000026}.line-move.active{background:var(--accent);color:var(--paper);font-style:italic;box-shadow:inset 0 0 0 2px var(--ink)}.context-menu{position:fixed;z-index:100;background:var(--paper);border:1px solid var(--ink);border-radius:3px;box-shadow:2px 3px 0 var(--ink-dim);display:flex;flex-direction:column;min-width:180px;padding:4px 0}.context-menu button{text-align:left;background:transparent;border:none;padding:6px 12px;font-family:var(--font-body);font-size:13px;color:var(--ink);cursor:pointer}.context-menu button:hover:not(:disabled){background:var(--bg-3)}.context-menu button:disabled{color:var(--fg-dim);cursor:not-allowed}.annotation-wrap{margin-top:10px}.annotation-label{font-family:var(--font-body);font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim);margin-bottom:4px}.annotation-box{width:100%;padding:8px 10px;background:var(--bg-2);border:1px solid var(--border);border-radius:3px;font-family:var(--font-body);font-size:13px;color:var(--ink);resize:vertical;box-sizing:border-box}.annotation-box:focus{outline:2px solid var(--accent);outline-offset:-2px}.annotation-display{margin-top:10px;padding:8px 10px;background:var(--bg-2);border-left:3px solid var(--pop);border-radius:0 3px 3px 0;font-size:13px;color:var(--ink);white-space:pre-wrap}.library{display:flex;flex-direction:column;gap:16px}.library-header{display:flex;align-items:flex-end;gap:16px;justify-content:space-between;flex-wrap:wrap}.library-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.source-pill{display:inline-block;width:96px;text-align:center;padding:1px 0;font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-radius:2px;border:1px solid var(--ink);background:var(--bg-3);color:var(--ink);box-sizing:border-box}.stage-badge{font-size:11px;padding:1px 6px;border-radius:2px;border:1px solid var(--ink)}.stage-badge.done{background:var(--success-bg);color:var(--success)}.stage-badge.in-progress{background:var(--bg-2);color:var(--ink)}.import-screen{display:flex;flex-direction:column;gap:12px}.import-tabs{display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--border);padding-bottom:6px}.import-tabs .tab{padding:6px 12px;background:transparent;border:1px solid transparent;cursor:pointer}.import-tabs .tab.active{background:var(--accent);color:var(--paper);border-color:var(--ink)}.import-panel{display:flex;flex-direction:column;gap:12px}.import-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.perf-chips{display:flex;flex-wrap:wrap;gap:6px}.perf-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--ink);border-radius:3px;font-size:12px;cursor:pointer;background:var(--bg-3)}.perf-chip.on{background:var(--accent);color:var(--paper)}.pgn-textarea{width:100%;font-family:var(--mono, monospace);font-size:12px;padding:8px;border:1px solid var(--ink);border-radius:3px}.candidate-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}.candidate-list-header{display:flex;align-items:center;gap:12px}.import-result-modal{max-width:420px}.import-result-list{list-style:none;margin:12px 0;padding:0;font-family:var(--font-mono);font-size:13px;color:var(--ink);display:flex;flex-direction:column;gap:6px}.import-result-list li{padding-left:4px}.import-result-list li.error{color:var(--danger)}.game-detail h2{margin-top:0}.stage-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.stage-card{border:1px solid var(--ink);border-radius:4px;padding:16px;background:var(--bg-2);display:flex;flex-direction:column;gap:8px;box-shadow:2px 2px 0 0 var(--ink)}.stage-card h3{margin:0}.stage-card p{margin:0;font-size:13px;color:var(--fg-dim)}.stage-card .note{font-size:12px;padding:6px 8px;background:var(--bg-3);border-left:3px solid var(--accent);color:var(--ink)}.stage-card-status{font-size:13px;color:var(--fg-dim)}.annotate-screen{max-width:520px}.progress-bar{width:100%;height:14px;background:var(--bg-3);border:1px solid var(--ink);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .2s ease}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--paper);border:1px solid var(--ink);box-shadow:4px 4px 0 0 var(--ink);border-radius:4px;padding:18px 20px;max-width:440px;width:calc(100% - 40px);display:flex;flex-direction:column;gap:12px}.modal h3{margin:0}.modal label{display:flex;flex-direction:column;gap:4px;font-size:12px}.modal label .hint{color:var(--fg-dim);font-size:11px}.modal input[type=text],.modal input:not([type]){font-size:14px;padding:6px 8px;border:1px solid var(--ink);border-radius:3px}.dialog-actions{display:flex;gap:8px;justify-content:flex-end}
