:root{--ink:#17221d;--text:#4d594f;--muted:#748074;--surface:#fffdf5;--surface-strong:#f3f6ed;--field:#eef2e7;--line:#d8dfd0;--button:#f8faf3;--green:#1e845e;--blue:#365b8a;--red:#9f3434;--display:Charter, "Iowan Old Style", Georgia, serif;--body:Avenir Next, ui-sans-serif, system-ui, sans-serif;--mono:"SFMono-Regular", Consolas, "Liberation Mono", monospace;color:var(--text);font-family:var(--body);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#dfe6db}*{box-sizing:border-box}html{background:#dfe6db;min-width:320px}body{min-width:320px;min-height:100svh;margin:0}#root{min-height:100svh}.app-shell{height:100svh;padding:14px;overflow:hidden}.review-stage{width:min(1580px,100%);height:calc(100svh - 28px);margin:0 auto}.topbar,.summary-strip,.source-panel,.opening-panel,.move-detail,.input-panel,.review-panel{border:1px solid var(--line);background:var(--surface)}.topbar{border-bottom:0;border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;gap:20px;min-height:64px;padding:0 18px;display:flex}.eyebrow{color:var(--muted);text-transform:uppercase;margin:0 0 3px;font-size:13px;font-weight:700}h1,h2{font-family:var(--display);color:var(--ink);margin:0;font-weight:760;line-height:1}h1{font-size:clamp(24px,2.3vw,38px)}h2{font-size:21px}.top-actions,.button-row,.board-controls,.control-row,.url-import-row,.panel-header,.status-line{align-items:center;display:flex}.top-actions,.button-row,.board-controls{gap:10px}.workspace-grid{border:1px solid var(--line);background:var(--surface);border-radius:0 0 8px 8px;grid-template-columns:minmax(520px,1fr) minmax(430px,520px);height:calc(100% - 64px);min-height:0;display:grid;overflow:hidden}.workspace-grid.settings-open{grid-template-columns:minmax(205px,240px) minmax(520px,1fr) minmax(430px,520px)}.input-panel,.review-panel{border-width:0;border-radius:0}.input-panel{border-right:1px solid var(--line);background:var(--surface-strong);flex-direction:column;gap:10px;padding:12px;display:flex}.review-panel{border-left:1px solid var(--line);flex-direction:column;gap:10px;min-width:0;min-height:0;padding:14px;display:flex;overflow:hidden}.workspace-grid:not(.settings-open) .board-panel{border-left:0}.panel-header{color:var(--ink);gap:8px;font-weight:800}.pgn-drawer{border:1px solid var(--line);background:var(--surface);border-radius:8px;overflow:hidden}.pgn-drawer summary{cursor:pointer;justify-content:space-between;align-items:center;gap:8px;min-height:40px;padding:0 10px;list-style:none;display:flex}.pgn-drawer summary::-webkit-details-marker{display:none}.pgn-drawer summary>svg{color:var(--muted);transition:transform .16s}.pgn-drawer[open] summary>svg{transform:rotate(90deg)}textarea{resize:none;border:0;border-top:1px solid var(--line);width:100%;min-height:150px;max-height:220px;color:var(--ink);font:13px/1.5 var(--mono);background:#f9fbf7;border-radius:0;outline:none;padding:12px}textarea:focus,input[type=range]:focus-visible,button:focus-visible{outline-offset:2px;outline:3px solid #365b8a3d}.control-row{color:var(--muted);justify-content:space-between;gap:14px;font-size:14px;font-weight:800}.color-settings{border:1px solid var(--line);background:var(--surface);border-radius:8px;gap:8px;padding:10px;display:grid}.color-settings label{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;font-size:14px;font-weight:850;display:flex}.color-settings input[type=color]{border:1px solid var(--line);background:var(--button);cursor:pointer;border-radius:8px;width:42px;height:30px;padding:2px}.reset-colors{min-height:32px;color:var(--ink);background:var(--button);box-shadow:inset 0 0 0 1px var(--line);border-radius:8px;font-size:13px;font-weight:850}.url-import-row{color:var(--muted);grid-template-columns:1fr;gap:6px;font-size:14px;font-weight:800;display:grid}.url-import-row input{border:1px solid var(--line);width:100%;min-width:0;height:34px;color:var(--ink);font:13px/1 var(--mono);background:#f9fbf7;border-radius:8px;padding:0 10px}input[type=range]{width:120px;accent-color:var(--green)}button{font:inherit;cursor:pointer;border:0}button:disabled{cursor:not-allowed;opacity:.45}.command,.icon-button{min-height:38px;color:var(--ink);background:var(--button);box-shadow:inset 0 0 0 1px var(--line);border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:850;display:inline-flex}.command{padding:0 15px}.icon-button{width:42px}.play-control{color:#fffdf5;background:var(--ink);width:54px}.command.primary{color:#fdfcf5;background:var(--ink);box-shadow:none}.command.active{background:var(--field);box-shadow:inset 0 0 0 2px #1e845e52}.command.danger{color:#fff8f2;background:var(--red);box-shadow:none}.button-row .command{flex:1;min-width:0;padding-inline:10px}.status-block{gap:8px;margin-top:2px;display:grid}.status-line{color:var(--muted);justify-content:space-between;font-size:14px}.status-line strong{color:var(--ink)}.progress-track{background:#dfe6db;border-radius:999px;height:8px;overflow:hidden}.progress-track span{border-radius:inherit;background:linear-gradient(90deg, var(--green), var(--blue));height:100%;transition:width .18s;display:block}.error-text{color:var(--red);margin:4px 0 0;font-size:14px}.board-panel{background:linear-gradient(90deg,#18263614 1px,#0000 1px) 0 0/46px 46px,linear-gradient(#18263614 1px,#0000 1px) 0 0/46px 46px,radial-gradient(circle at 28% 20%,#c65e2e24,#0000 34%),#edf1e9;grid-template-rows:auto minmax(0,1fr) auto auto;place-items:center stretch;min-width:0;min-height:0;padding:14px;display:grid}.sandbox-banner{width:min(100svh - 220px,100%);max-width:640px;min-height:58px;color:var(--ink);box-shadow:inset 0 0 0 1px var(--line);background:#fffdf5db;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;justify-content:space-between;justify-self:center;align-items:center;gap:10px;margin-bottom:6px;padding:7px 7px 7px 12px;font-size:14px;font-weight:850;display:grid}.sandbox-copy{gap:2px;min-width:0;display:grid}.sandbox-copy span,.sandbox-copy strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.sandbox-kicker{color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:900}.sandbox-actions{align-items:center;gap:7px;display:flex}.sandbox-actions .command{white-space:nowrap;min-height:30px;padding-inline:10px}.board-wrap{aspect-ratio:1;justify-self:center;width:min(100svh - 220px,100%);min-width:min(100%,320px);max-width:640px}.player-strip{width:min(100svh - 220px,100%);max-width:640px;min-height:36px;color:var(--ink);grid-template-columns:30px minmax(0,1fr) 68px;justify-self:center;align-items:center;gap:8px;margin:0 0 6px;display:grid}.player-strip.bottom{margin:6px 0 0}.player-strip.active .clock-pill{background:var(--ink);color:#fffdf5}.player-avatar{width:28px;height:28px;box-shadow:inset 0 0 0 1px var(--line);background:#fffdf5d1;border-radius:8px;place-items:center;font-size:18px;display:grid}.player-meta{min-width:0}.player-meta strong{min-width:0;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;align-items:baseline;font-size:14px;line-height:1.1;display:block;overflow:hidden}.player-meta strong span{color:var(--muted);font-weight:800}.player-meta small{color:var(--muted);font-size:12px;font-weight:800;display:none}.clock-pill{min-width:68px;color:var(--ink);box-shadow:inset 0 0 0 1px var(--line);text-align:center;font-variant-numeric:tabular-nums;background:#fffdf5eb;border-radius:8px;padding:5px 7px;font-size:18px;font-weight:900}.board-controls{justify-content:center;margin-top:8px}.segmented{min-width:190px;box-shadow:inset 0 0 0 1px var(--line);background:#ffffffad;border-radius:8px;grid-template-columns:1fr 1fr;padding:4px;display:inline-grid}.segmented button{min-height:34px;color:var(--muted);background:0 0;border-radius:6px;font-weight:850}.segmented button.active{color:#fffaf0;background:var(--green)}.summary-strip{border-radius:8px;flex:none;grid-template-columns:repeat(3,1fr);min-height:44px;display:grid;overflow:hidden}.source-panel{border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px;display:flex}.opening-panel{border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px;display:grid}.opening-panel span,.opening-panel dt{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:850;display:block}.opening-panel strong{color:var(--ink);margin-top:3px;font-size:14px;line-height:1.2;display:block}.opening-panel dl{gap:8px;margin:0;display:flex}.opening-panel dl div{background:var(--field);border-radius:8px;min-width:58px;padding:8px}.opening-panel dd{color:var(--ink);margin:3px 0 0;font-weight:900}.source-panel span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:850;display:block}.source-panel strong{color:var(--ink);margin-top:3px;font-size:14px;display:block}.source-panel a{min-height:34px;color:var(--ink);background:var(--field);white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:0 10px;font-size:13px;font-weight:850;text-decoration:none;display:inline-flex}.summary-strip div{border-right:1px solid var(--line);justify-content:space-between;align-items:center;gap:8px;min-width:0;padding:8px 12px;display:flex}.summary-strip div:last-child{border-right:0}.summary-strip span{color:var(--muted);text-transform:uppercase;white-space:nowrap;font-size:11px;font-weight:850;display:block}.summary-strip strong{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:17px;line-height:1;display:block;overflow:hidden}.move-detail{border-left:6px solid var(--green);border-radius:8px;flex:none;gap:9px;padding:12px;display:grid}.move-detail.empty{min-height:128px;color:var(--muted);align-content:center;place-items:center;font-weight:800}.detail-heading{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.badge{color:#fefdf8;background:var(--green);text-transform:uppercase;border-radius:6px;align-items:center;gap:6px;margin-bottom:7px;padding:5px 8px;font-size:12px;font-weight:900;display:inline-flex}.move-detail.book,.move-detail.brilliant,.move-detail.best,.move-detail.great,.move-detail.excellent{border-left-color:var(--green)}.move-detail.good{border-left-color:#6e8f52}.move-detail.inaccuracy{border-left-color:#b9822b}.move-detail.mistake{border-left-color:#c65e2e}.move-detail.blunder{border-left-color:var(--red)}.badge.book,.move-chip.book i{background:#c1905d}.badge.brilliant,.move-chip.brilliant i{background:#24a7a0}.badge.great,.move-chip.great i{background:#21865f}.badge.good,.move-chip.good i{background:#5f7d4d}.badge.inaccuracy,.move-chip.inaccuracy i{background:#b9822b}.badge.mistake,.move-chip.mistake i{background:#c65e2e}.badge.blunder,.move-chip.blunder i,.move-chip.missed.mate i{background:var(--red)}.move-detail p{color:var(--text);margin:0;font-size:14px;line-height:1.35}.eval-stack{justify-items:end;gap:3px;display:grid}.eval-stack span{color:var(--muted);font-size:13px}.eval-stack strong{color:var(--ink);font-size:21px}.review-actions{grid-template-columns:minmax(0,1fr) minmax(120px,.72fr);gap:10px;display:grid}.best-callout{min-width:0;min-height:38px;color:var(--ink);background:var(--button);box-shadow:inset 0 0 0 1px var(--line);border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-weight:850;display:inline-flex}.move-list{flex:315px;grid-template-rows:auto 1fr;gap:8px;min-height:315px;display:grid;overflow:hidden}.move-table{min-height:0;max-height:none;padding-right:4px;overflow:auto}.move-row{grid-template-columns:34px minmax(0,1fr) minmax(0,1fr);align-items:stretch;gap:7px;margin-bottom:7px;display:grid}.move-number{color:var(--muted);padding-top:10px;font-size:13px;font-weight:900}.move-chip{min-width:0;min-height:38px;color:var(--ink);background:var(--field);text-align:left;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:7px;padding:0 8px 0 10px;display:grid;box-shadow:inset 0 0 0 1px #0000}.move-chip.active{box-shadow:inset 0 0 0 2px var(--blue), 0 4px 12px #365b8a21}.move-chip span{text-overflow:ellipsis;white-space:nowrap;font-weight:850;overflow:hidden}.move-chip i{color:#fffdf6;background:var(--green);text-transform:uppercase;border-radius:5px;padding:3px 5px;font-size:10px;font-style:normal;font-weight:900}.eval-graph{flex:none;gap:7px;display:grid}.eval-graph .eval-chart{border:1px solid var(--line);background:var(--field);border-radius:8px;width:100%;height:86px;display:block;overflow:hidden}.graph-white{fill:#fffdf5f0}.graph-black{fill:#31433729}.graph-zero{stroke:#17221d40;stroke-width:1.5px}.graph-line{fill:none;stroke:#17221db8;stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round}.graph-active-line{stroke:var(--blue);stroke-width:2px}.graph-dot{cursor:pointer;stroke:#fffdf5;stroke-width:2px;fill:var(--green)}.graph-dot.book{fill:#c1905d}.graph-dot.good{fill:#5f7d4d}.graph-dot.inaccuracy{fill:#d29a34}.graph-dot.mistake{fill:#d66a38}.graph-dot.blunder{fill:var(--red)}.graph-dot.active{stroke:var(--ink);stroke-width:2.5px}.muted{color:var(--muted);margin:20px 0}@media (width<=1180px){.app-shell{padding:10px}.workspace-grid{grid-template-columns:300px minmax(360px,1fr);height:auto;min-height:0}.review-panel{border-left:0;border-top:1px solid var(--line);grid-column:1/-1}.move-table{max-height:320px}}@media (width<=760px){.app-shell{height:auto;padding:0;overflow:visible}.review-stage{height:auto}.topbar{border-radius:0;flex-direction:column;align-items:flex-start;padding:18px}.workspace-grid{border-radius:0;flex-direction:column;min-height:auto;display:flex}.input-panel,.review-panel{border:0;border-top:1px solid var(--line)}textarea{min-height:260px}.board-panel{padding:18px}.board-wrap{width:100%}.detail-heading{flex-direction:column}.eval-stack{justify-items:start}.review-actions{grid-template-columns:1fr}}
