:root{--blue: #0a84ff;--green: #34c759;--red: #ff453a;--orange: #ff9f0a;--yellow: #ffd60a;--purple: #bf5af2;--teal: #40c8e0;--radius-card: 22px;--radius-ctrl: 13px;--radius-pill: 999px;--maxw: 1180px;--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, "Segoe UI", Roboto, sans-serif;--mono: "SF Mono", ui-monospace, "JetBrains Mono", Menlo, monospace}:root,[data-theme=light]{--bg: #f2f2f7;--bg-elevated: #ffffff;--surface: #ffffff;--surface-2: #f7f7fa;--surface-3: #eceef3;--text: #1c1c1e;--text-2: #6b6b70;--text-3: #a0a0a6;--separator: rgba(60, 60, 67, .13);--hairline: rgba(60, 60, 67, .08);--glass: rgba(255, 255, 255, .72);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06), 0 4px 14px rgba(0, 0, 0, .05);--shadow-md: 0 6px 22px rgba(0, 0, 0, .08), 0 2px 6px rgba(0, 0, 0, .05);--shadow-lg: 0 18px 50px rgba(0, 0, 0, .14);--tint-blue: rgba(10, 132, 255, .12)}[data-theme=dark]{--bg: #000000;--bg-elevated: #1c1c1e;--surface: #1c1c1e;--surface-2: #2c2c2e;--surface-3: #3a3a3c;--text: #ffffff;--text-2: #aeaeb4;--text-3: #7c7c82;--separator: rgba(84, 84, 88, .4);--hairline: rgba(84, 84, 88, .26);--glass: rgba(28, 28, 30, .72);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 8px 28px rgba(0, 0, 0, .5);--shadow-lg: 0 20px 56px rgba(0, 0, 0, .6);--tint-blue: rgba(10, 132, 255, .22)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.01em}a{color:var(--blue);text-decoration:none}button{font-family:inherit}:focus-visible{outline:2px solid var(--blue);outline-offset:2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:999px;border:3px solid transparent;background-clip:content-box}.app-shell{min-height:100%;display:flex;flex-direction:column}.app-main{width:100%;max-width:var(--maxw);margin:0 auto;padding:22px clamp(14px,3vw,28px) 80px;flex:1}.section-head{margin:4px 2px 18px}.section-head h2{margin:0;font-size:clamp(24px,3.4vw,34px);font-weight:800;letter-spacing:-.03em}.section-head p{margin:4px 0 0;color:var(--text-2);font-size:15px}.topbar{position:sticky;top:0;z-index:50;background:var(--glass);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--hairline)}.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:10px clamp(14px,3vw,28px);display:flex;align-items:center;gap:16px}.brand{display:flex;align-items:center;gap:11px;cursor:pointer;user-select:none}.brand-logo{width:34px;height:34px;flex:none;display:flex;align-items:center;justify-content:center;font-size:27px;line-height:1}.brand-name{font-weight:800;font-size:19px;letter-spacing:-.03em}.brand-name .dot{color:var(--blue)}.topbar-nav{display:flex;gap:2px;margin:0 auto}.nav-pill{border:0;background:transparent;color:var(--text-2);font-size:14px;font-weight:600;padding:8px 15px;border-radius:var(--radius-pill);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .15s}.nav-pill:hover{color:var(--text);background:var(--surface-3)}.nav-pill.active{color:#fff;background:var(--blue);box-shadow:0 4px 12px var(--tint-blue)}.nav-ico{width:17px;height:17px}.topbar-actions{display:flex;align-items:center;gap:8px;min-width:0}.identity-slot{display:none}.icon-btn{width:38px;height:38px;border-radius:11px;border:0;cursor:pointer;background:var(--surface-2);color:var(--text);display:grid;place-items:center;transition:background .15s}.icon-btn:hover{background:var(--surface-3)}.hamburger{display:none}.identity{display:flex;align-items:center;gap:8px;min-width:0}.segmented{display:inline-flex;background:var(--surface-2);border-radius:10px;padding:3px;gap:2px}.segmented button{border:0;background:transparent;color:var(--text-2);cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;border-radius:8px;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:7px}.plat-ico{width:18px;height:18px;flex:none;border-radius:5px;background-size:contain;background-repeat:no-repeat;background-position:center}.plat-chesscom{background-image:url(/icons/chesscom.png)}.plat-lichess{background-image:url(/icons/lichess-light.svg)}[data-theme=dark] .plat-lichess{background-image:url(/icons/lichess-dark.png);background-color:#ffffff14}.segmented button.active{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm)}.input{border:1px solid var(--separator);background:var(--surface-2);color:var(--text);border-radius:11px;padding:9px 13px;font-size:14px;min-width:0;transition:border .15s}.input:focus{outline:none;border-color:var(--blue)}.topbar-actions .input{flex:0 1 170px;width:170px}.btn{border:0;cursor:pointer;border-radius:var(--radius-ctrl);font-size:14px;font-weight:650;padding:10px 18px;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:transform .06s ease,filter .15s,background .15s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 6px 16px var(--tint-blue)}.btn-primary:hover:not(:disabled){filter:brightness(1.06)}.btn-tinted{background:var(--tint-blue);color:var(--blue)}.btn-ghost{background:var(--surface-2);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface-3)}.btn-sm{padding:7px 13px;font-size:13px;border-radius:10px}.btn-lg{padding:14px 22px;font-size:16px;border-radius:15px;width:100%}.card{background:var(--surface);border-radius:var(--radius-card);box-shadow:var(--shadow-sm);border:1px solid var(--hairline);overflow:hidden}.card-pad{padding:clamp(16px,2.4vw,24px)}.card-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{border:1px solid var(--separator);background:var(--surface-2);color:var(--text);border-radius:var(--radius-pill);padding:8px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.chip:hover:not(.active){background:var(--surface-3)}.chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}.chip:disabled{opacity:.5;cursor:not-allowed}.control-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:9px}.spinner{width:22px;height:22px;border-radius:50%;border:3px solid var(--surface-3);border-top-color:var(--blue);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes indet{0%{margin-left:-35%}to{margin-left:100%}}.progress{display:flex;flex-direction:column;gap:12px}.progress-top{display:flex;align-items:center;gap:12px}.progress-title{flex:1;font-weight:700}.clock{font-variant-numeric:tabular-nums;color:var(--text-2);font-family:var(--mono)}.bar{height:8px;background:var(--surface-3);border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--teal));border-radius:999px;transition:width .25s}.progress-detail{color:var(--text-2);font-size:13px;font-family:var(--mono)}.muted{color:var(--text-2)}.tiny{font-size:12px}.center{text-align:center}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.error-box{background:#ff453a1f;color:var(--red);border-radius:14px;padding:12px 16px;font-size:14px;font-weight:600}.empty-state{text-align:center;padding:48px 20px;color:var(--text-2)}.empty-state .big{font-size:40px}.divider{height:1px;background:var(--separator);border:0;margin:18px 0}.tag{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px}.stack{display:flex;flex-direction:column;gap:14px}.grid-auto{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.kpi{background:var(--surface);border:1px solid var(--hairline);border-radius:18px;padding:16px 18px;box-shadow:var(--shadow-sm)}.kpi-value{font-size:28px;font-weight:800;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.kpi-label{font-size:13px;color:var(--text-2);margin-top:2px}.drawer-backdrop{position:fixed;inset:0;z-index:60;background:#0006;backdrop-filter:blur(4px);animation:fade .2s}.drawer{position:fixed;top:0;right:0;bottom:0;z-index:61;width:min(82vw,320px);background:var(--bg-elevated);box-shadow:var(--shadow-lg);padding:18px;display:flex;flex-direction:column;gap:6px;animation:slideIn .26s cubic-bezier(.32,.72,0,1);border-top-left-radius:22px;border-bottom-left-radius:22px}.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.drawer-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:13px;border:0;background:transparent;color:var(--text);font-size:16px;font-weight:600;cursor:pointer;text-align:left;width:100%}.drawer-item:hover{background:var(--surface-2)}.drawer-item.active{background:var(--tint-blue);color:var(--blue)}@keyframes fade{0%{opacity:0}}@keyframes slideIn{0%{transform:translate(100%)}}.board-wrap{width:100%;max-width:560px}.board-frame{border-radius:16px;overflow:hidden;box-shadow:var(--shadow-md);position:relative}.arrow-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:4}.board-badge{position:absolute;width:12.5%;height:12.5%;pointer-events:none;display:flex;align-items:flex-start;justify-content:flex-end;z-index:5}.board-badge .judge-badge-img{transform:translate(28%,-28%);width:30%;height:auto;min-width:20px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}.board-flex{display:flex;gap:10px;align-items:stretch}.eval-bar{width:16px;border-radius:8px;overflow:hidden;background:#111;display:flex;flex-direction:column-reverse;box-shadow:var(--shadow-sm)}.eval-fill{width:100%;background:#f4f4f5;transition:height .45s cubic-bezier(.32,.72,0,1)}.eval-num{font-family:var(--mono);font-weight:700;text-align:center;font-size:12px;padding:3px 0;color:var(--text-2)}.app-footer{text-align:center;padding:22px 16px 34px;border-top:1px solid var(--hairline);display:flex;flex-direction:column;align-items:center;gap:10px}.built-with{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}.built-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface-2);border:1px solid var(--hairline);padding:4px 10px;border-radius:999px;text-decoration:none}.built-chip:hover{background:var(--surface-3);color:var(--text)}.built-chip img{border-radius:4px}[data-theme=dark] .lichess-mark,[data-theme=dark] .github-mark{filter:invert(1)}.controls-row{display:flex;gap:20px;flex-wrap:wrap;align-items:flex-end}.slider-row{display:flex;align-items:center;gap:12px;margin:12px 0}.settings-h{margin:0 0 14px;font-size:18px}.settings-page{max-width:760px;margin:0 auto}.depth-control{min-width:200px}.depth-row{display:flex;align-items:center;gap:10px}.depth-row input[type=range]{flex:1;min-width:90px}.depth-chip{background:var(--tint-blue);color:var(--blue);white-space:nowrap}.eta{color:var(--text-3);font-weight:500}.color-swatch{display:inline-block;width:14px;height:14px;border-radius:4px;vertical-align:-1px;margin:0 6px;border:1px solid var(--separator)}.color-swatch.white{background:#fff}.color-swatch.black{background:#2b2b2e}.game-list{display:flex;flex-direction:column}.game-row{display:grid;grid-template-columns:12px 22px 1fr auto auto 14px;align-items:center;gap:12px;width:100%;text-align:left;border:0;background:transparent;cursor:pointer;padding:13px 6px;color:var(--text);border-bottom:1px solid var(--hairline);font-size:15px;transition:background .12s}.game-row:last-child{border-bottom:0}.game-row:hover{background:var(--surface-2);border-radius:12px}.dot-result{width:10px;height:10px;border-radius:50%}.dot-result.win{background:var(--green)}.dot-result.loss{background:var(--red)}.dot-result.draw{background:var(--text-3)}.gr-side{font-size:18px}.gr-opp{font-weight:600}.gr-go{color:var(--text-3);font-size:20px;text-align:right}.review-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.review-title{font-size:16px}.sub-tabs{width:fit-content;max-width:100%;overflow:auto}.sub-tabs button{white-space:nowrap}.review-layout,.explore-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:20px;align-items:start}.review-left,.explore-left{display:flex;flex-direction:column;gap:14px}.review-right,.explore-right{display:flex;flex-direction:column;gap:14px;min-width:0}.review-nav,.explore-controls{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap}.explore-controls{justify-content:flex-start}.crash-msg{background:var(--surface-2);border:1px solid var(--hairline);border-radius:10px;padding:10px 12px;font-family:var(--mono);font-size:12px;color:var(--red);white-space:pre-wrap;word-break:break-word;text-align:left;margin:0 0 14px}.game-over-note{font-weight:700;padding:10px 12px;border-radius:10px;background:var(--tint-blue);color:var(--blue);text-align:center}.illegal-note{font-weight:700;padding:12px 14px;border-radius:10px;background:#ff453a1f;color:var(--red);border:1px solid rgba(255,69,58,.3);text-align:center}.blunder-trainer .bt-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.explore-eval-row{display:flex;align-items:center;gap:10px}.depth-tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-2);background:var(--surface-2);border:1px solid var(--hairline);padding:4px 9px;border-radius:999px}.depth-pulse{width:8px;height:8px;border-radius:50%;background:var(--blue)}.depth-pulse.live{animation:depth-pulse 1s ease-in-out infinite}.depth-pulse.done{background:var(--green, #34c759);animation:none}@keyframes depth-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}.eb-wrap{width:100%;max-width:560px;display:flex;flex-direction:column;gap:8px}.eb-palette{display:flex;gap:4px;justify-content:center;background:var(--surface-2);border:1px solid var(--hairline);border-radius:12px;padding:6px}.eb-palette-piece{flex:0 1 56px;aspect-ratio:1;max-width:56px;border:0;background:transparent;border-radius:9px;cursor:grab;padding:3px;touch-action:none}.eb-palette-piece:hover{background:var(--surface-3)}.eb-palette-piece:active{cursor:grabbing}.eb-palette-piece img{width:100%;height:100%;pointer-events:none}.eb-board{position:relative;width:100%;aspect-ratio:1;touch-action:none}.eb-square{position:absolute;width:12.5%;height:12.5%}.eb-piece{position:absolute;width:12.5%;height:12.5%;cursor:grab;touch-action:none;user-select:none;z-index:2}.eb-piece:active{cursor:grabbing}.eb-drag-ghost{position:fixed;transform:translate(-50%,-50%);pointer-events:none;z-index:1000;filter:drop-shadow(0 6px 10px rgba(0,0,0,.35))}.eb-vanish{position:fixed;transform:translate(-50%,-50%);pointer-events:none;z-index:1000;animation:eb-vanish .22s ease forwards}@keyframes eb-vanish{to{transform:translate(-50%,-50%) scale(.2);opacity:0}}.editor{gap:10px}.editor-palette{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;background:var(--surface-2);border:1px solid var(--hairline);border-radius:12px;padding:6px}.editor-piece{width:44px;height:44px;border:2px solid transparent;border-radius:10px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.editor-piece:hover{background:var(--surface-3)}.editor-piece.active{border-color:var(--blue);background:var(--tint-blue)}.editor-board{position:relative;margin:0 auto}.editor-grid{position:absolute;inset:0;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);z-index:6}.editor-cell{border:0;background:transparent;cursor:pointer;padding:0}.editor-cell:hover{box-shadow:inset 0 0 0 9999px #0a84ff29}.editor-cell.pop{animation:editor-pop .2s ease}@keyframes editor-pop{0%{box-shadow:inset 0 0 0 9999px #34c75966}to{box-shadow:inset 0 0 0 9999px #34c75900}}.editor-tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.editor-tools .active-tool{border-color:var(--blue);color:var(--blue)}.review-counter{min-width:62px;text-align:center;font-weight:700}.judge-callout{border-left:4px solid;background:var(--surface);border-radius:12px;padding:11px 14px;font-size:14px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:10px}.judge-callout code,.engine-line code{font-family:var(--mono);background:var(--surface-2);padding:1px 6px;border-radius:6px}.engine-lines{display:flex;flex-direction:column;gap:8px;background:var(--surface);border-radius:16px;padding:12px 14px;box-shadow:var(--shadow-sm);border:1px solid var(--hairline)}.engine-head{display:flex;align-items:center;gap:8px;justify-content:space-between}.cpu-chip{font-size:12px;font-weight:700;color:var(--text-2)}.engine-line{display:flex;gap:10px;align-items:baseline;font-size:13px;padding:4px 6px;border-radius:8px;cursor:default;transition:background .15s ease}.engine-line:hover,.engine-line.hovered{background:var(--surface-2)}.line-rank{width:9px;height:9px;border-radius:50%;flex:none;align-self:center;box-shadow:0 0 0 2px var(--surface)}.eval-tag{font-family:var(--mono);font-weight:700;background:var(--surface-3);color:var(--text);border-radius:6px;padding:2px 7px;flex:none;font-size:12px}.eval-tag.big{font-size:18px;padding:4px 12px}.line-moves{display:flex;flex-wrap:wrap;gap:2px 4px;font-family:var(--mono);color:var(--text-2)}.line-move{border:0;background:transparent;color:var(--text);font:inherit;cursor:pointer;padding:1px 3px;border-radius:5px}.line-move:disabled{cursor:default;color:var(--text-2)}.line-move:not(:disabled):hover{background:var(--tint-blue);color:var(--blue)}.move-strip{display:flex;gap:4px;overflow-x:auto;padding:8px;background:var(--surface);border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--hairline);scrollbar-width:thin}.ms-move{flex:none;border:0;background:var(--surface-2);color:var(--text);font-family:var(--mono);font-size:13px;padding:6px 9px;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.ms-move:hover{background:var(--surface-3)}.ms-move.active{background:var(--blue);color:#fff}.ms-no{opacity:.6}.judge-badge-img{display:inline-block;vertical-align:middle;filter:drop-shadow(0 1px 1px rgba(0,0,0,.18))}.ms-badge{margin-left:1px}.eval-graph{height:110px;position:relative}.review-graph{padding:10px 14px}.report-graph{height:130px;margin-bottom:16px}.report-grid{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:10px 16px;align-items:center}.report-player{display:flex;flex-direction:column;gap:6px;min-width:0}.report-player.right{align-items:flex-end;text-align:right}.report-name{font-weight:700;display:flex;align-items:center;gap:0;min-width:0;max-width:100%}.report-player.right .report-name{justify-content:flex-end}.report-name-text{min-width:0;overflow-wrap:anywhere;word-break:break-word}.report-name .color-swatch{flex:none}.you-tag{font-size:10px;font-weight:800;background:var(--blue);color:#fff;border-radius:5px;padding:1px 6px;margin-left:6px}.report-acc{font-size:36px;font-weight:800;font-variant-numeric:tabular-nums}.report-center{display:flex;align-items:center;gap:8px;justify-content:center;font-weight:600;color:var(--text-2);font-size:14px}.report-num{font-family:var(--mono);font-weight:700;font-size:17px}.report-num.right{text-align:right}.report-judge-cell{display:grid;grid-template-columns:24px 1fr;align-items:center;gap:9px;width:150px;margin:0 auto;transform:translate(32px);text-align:left;font-weight:600;color:var(--text-2);font-size:14px}.report-judge-cell .judge-badge-img{justify-self:center}.report-expand{display:block;width:100%;margin:6px 0 2px;border:0;background:transparent;color:var(--text-2);cursor:pointer;font-size:18px;line-height:1;padding:6px;border-top:1px solid var(--hairline)}.report-expand:hover{color:var(--text);background:var(--surface-2);border-radius:8px}.report-extra{margin-top:8px;padding-top:14px;border-top:1px solid var(--hairline);row-gap:12px}.rating-box{font-family:var(--mono);font-weight:800;font-size:22px;background:var(--surface-2);border:1px solid var(--hairline);border-radius:12px;padding:6px 12px;justify-self:start}.rating-box.right{justify-self:end}.report-phase{display:flex;align-items:center}.report-phase.right{justify-content:flex-end}.review-noengine{display:block;margin:12px auto 0;background:transparent;border:0;color:var(--text-2);font-size:13.5px;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:8px;transition:color .15s,background .15s}.review-noengine:hover{color:var(--blue);background:var(--tint-blue)}.streak-card{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:linear-gradient(135deg,#ff950024,#ff453a1f);border:1px solid var(--hairline);border-radius:18px;padding:14px 18px;box-shadow:var(--shadow-sm)}.streak-flame{display:flex;align-items:center;gap:12px}.streak-emoji{font-size:38px;line-height:1}.streak-count{font-size:30px;font-weight:800;line-height:1;color:#ff8c00}.streak-label{font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--text-2)}.streak-week{display:flex;gap:10px}.streak-day{display:flex;flex-direction:column;align-items:center;gap:5px}.streak-dot{width:22px;height:22px;border-radius:50%;background:var(--surface-3);border:2px solid transparent;display:grid;place-items:center}.streak-day.on .streak-dot{background:#ff8c00;box-shadow:0 0 #ff8c0066}.streak-day.on .streak-dot:after{content:"✓";color:#fff;font-size:12px;font-weight:800}.streak-day.today .streak-dot{border-color:#ff8c00}.streak-dow{font-size:11px;font-weight:700;color:var(--text-2)}.judge-legend{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px;margin-top:12px}.judge-legend-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--surface-2);border:1px solid var(--hairline);border-radius:12px;cursor:pointer;text-align:left;color:var(--text)}.judge-legend-row:hover{background:var(--surface-3)}.judge-legend-name{font-weight:700;flex:1;min-width:0}.judge-legend-edit{opacity:.45;font-size:13px}.toggle{width:50px;height:30px;border-radius:999px;background:var(--surface-3);border:0;position:relative;cursor:pointer;transition:background .2s;padding:0;flex:none}.toggle.on{background:var(--green, #34c759)}.toggle-knob{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s}.toggle.on .toggle-knob{transform:translate(20px)}.puzzle-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.85fr);gap:22px;align-items:start}.puzzle-side{display:flex;flex-direction:column;gap:12px}.puzzle-prompt{font-weight:700;display:flex;align-items:center;gap:8px}.turn-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--text)}.turn-dot[data-color=white]{background:#fff}.turn-dot[data-color=black]{background:#222}.puzzle-status{padding:11px 14px;border-radius:12px;font-weight:600;background:var(--surface-2);border:1px solid var(--hairline)}.puzzle-status.correct{background:#34c75924;color:var(--green);border-color:transparent}.puzzle-status.wrong{background:#ff453a24;color:var(--red);border-color:transparent}.puzzle-status.revealed{background:#ff9f0a24;color:var(--orange);border-color:transparent}.puzzle-status code{font-family:var(--mono)}.puzzle-actions,.puzzle-nav{display:flex;gap:8px;flex-wrap:wrap}.board-wrap.shake{animation:shake .32s cubic-bezier(.36,.07,.19,.97)}@keyframes shake{10%,90%{transform:translate(-2px)}20%,80%{transform:translate(4px)}30%,50%,70%{transform:translate(-7px)}40%,60%{transform:translate(7px)}}.puzzle-nav{justify-content:space-between;margin-top:4px}.puzzle-complete{position:relative;text-align:center;padding:40px 20px 30px;overflow:hidden}.complete-check{display:inline-block}.check-circle{stroke-dasharray:151;stroke-dashoffset:151;animation:draw .5s ease-out forwards}.check-mark{stroke-dasharray:48;stroke-dashoffset:48;animation:draw .35s .45s ease-out forwards}@keyframes draw{to{stroke-dashoffset:0}}.complete-title{font-size:24px;margin:12px 0 4px;animation:pop .4s .5s both}@keyframes pop{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}.confetti{position:absolute;inset:0;pointer-events:none}.confetti span{position:absolute;top:-12px;left:calc(50% + (var(--i) - 12) * 4%);width:9px;height:14px;border-radius:2px;opacity:0;background:hsl(calc(var(--i) * 37),85%,58%);animation:confetti 1.5s calc(var(--i) * 35ms) ease-in forwards}@keyframes confetti{0%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(360px) rotate(540deg)}}.explore-moves{display:flex;flex-wrap:wrap;gap:2px 6px;font-size:14px;line-height:1.7}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px;border-radius:14px;border:2px solid var(--hairline);background:var(--surface-2);cursor:pointer;color:var(--text)}.theme-swatch.active{border-color:var(--blue)}.swatch-board{display:grid;grid-template-columns:1fr 1fr;width:44px;height:44px;border-radius:8px;overflow:hidden}.swatch-board span{display:block}.swatch-pieces{display:flex;align-items:center;justify-content:center;height:44px}.account{position:relative}.account-chip{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;background:var(--surface-2);color:var(--text);border-radius:var(--radius-pill);padding:5px 12px 5px 5px;font-weight:600;font-size:14px}.account-chip:hover{background:var(--surface-3)}.account-avatar{width:28px;height:28px;border-radius:50%;flex:none;display:grid;place-items:center;background:var(--blue);color:#fff;font-weight:800;font-size:13px}.account-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-pop{position:absolute;right:0;top:calc(100% + 8px);z-index:60;min-width:200px;background:var(--bg-elevated);border:1px solid var(--hairline);border-radius:14px;padding:8px;box-shadow:var(--shadow-md)}.menu-backdrop{position:fixed;inset:0;z-index:55}.modal-backdrop{position:fixed;inset:0;z-index:80;background:#00000073;backdrop-filter:blur(3px)}.modal-card{position:fixed;z-index:81;left:50%;top:50%;transform:translate(-50%,-50%);width:min(380px,calc(100vw - 36px));background:var(--bg-elevated);border:1px solid var(--hairline);border-radius:22px;padding:26px 22px 18px;box-shadow:var(--shadow-lg, var(--shadow-md));display:flex;flex-direction:column;gap:8px}.modal-pawn{font-size:40px;text-align:center;line-height:1}.auth-btns{display:flex;flex-direction:column;gap:10px;margin-top:8px}.auth-btn{display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;border-radius:12px;padding:12px 16px;font-size:15px;font-weight:600;border:1px solid var(--separator)}.auth-btn .auth-ico{font-weight:800;width:18px;text-align:center}.auth-btn.google{background:#fff;color:#1f1f22;border-color:#dadce0}.auth-btn.apple{background:#000;color:#fff;border-color:#000}.auth-btn:hover{filter:brightness(.97)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.chart-card{min-width:0}@media (max-width: 860px){.review-layout,.explore-layout,.puzzle-layout{grid-template-columns:1fr}.board-wrap{max-width:460px;margin:0 auto}}@media (max-width: 620px){.game-row{grid-template-columns:10px 20px 1fr auto 12px}.game-row .gr-meta:first-of-type{display:none}.controls-row{gap:14px}.controls-row>button{width:100%}.report-grid{gap:8px 8px}.report-acc{font-size:24px}.report-name{font-size:13px}.report-name-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere}.you-tag{margin-left:4px}.report-center{font-size:12px;gap:5px}.report-num{font-size:15px}.judge-badge-img{width:18px;height:18px}}@media (max-width: 920px){.topbar-nav{display:none}.hamburger{display:grid}.identity-slot{display:none}.brand-name{font-size:18px}.topbar-actions{margin-left:auto}}@media (max-width: 620px){.topbar-inner{gap:10px}.section-head h2{font-size:25px}.settings-gear{display:none}}
