:root{color-scheme:dark;--bg: #131f19;--bg-deep: #0e1712;--panel: #1b2a22;--panel-raised: #22342a;--line: #31463a;--line-soft: #263a2f;--ink: #eae3d0;--ink-dim: #a3ab97;--ink-faint: #6f7a6b;--brass: #d9a441;--brass-bright: #ecc06a;--brass-dim: rgba(217, 164, 65, .16);--good: #86b56d;--bad: #c8654f;--warn: #d0975a;--focus: rgba(236, 192, 106, .72);--blunder: #c8654f;--mistake: #d0975a;--inaccuracy: #b8b06a;--serif: "Cormorant Garamond", Georgia, serif;--sans: "IBM Plex Sans", sans-serif;--mono: "IBM Plex Mono", monospace;--radius: 8px;--radius-sm: 6px;--shadow: 0 8px 26px rgba(0, 0, 0, .32);--shadow-tight: 0 5px 16px rgba(0, 0, 0, .26);--ease-out: cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box}html,body,#root{height:100%}html{scrollbar-gutter:stable}body{margin:0;font-family:var(--sans);font-size:15px;line-height:1.55;color:var(--ink);min-width:320px;background:radial-gradient(1200px 700px at 20% -10%,rgba(217,164,65,.05),transparent 60%),radial-gradient(1000px 800px at 110% 110%,rgba(134,181,109,.04),transparent 55%),var(--bg);background-attachment:fixed}button,input,textarea,select{font:inherit}button,[role=button]{-webkit-tap-highlight-color:transparent}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}#root{position:relative;z-index:1}::selection{background:var(--brass-dim)}.app{width:min(100%,1280px);margin:0 auto;padding:0 max(16px,env(safe-area-inset-left)) 56px max(16px,env(safe-area-inset-right))}.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;flex-wrap:wrap;gap:12px 22px;padding:18px 0 14px;border-bottom:1px solid var(--line-soft);margin-bottom:24px;background:linear-gradient(180deg,#131f19f5,#131f19e0);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-title{font-family:var(--serif);font-weight:700;font-size:28px;line-height:1;letter-spacing:0;margin:0;color:var(--ink);white-space:nowrap}.app-title .knight{color:var(--brass);margin-right:10px}.tabs{display:flex;gap:4px;margin-left:auto;min-width:280px;justify-content:flex-end;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--ink-dim);font-family:var(--sans);font-size:15px;font-weight:500;min-height:40px;padding:8px 14px;cursor:pointer;border-radius:var(--radius);position:relative;white-space:nowrap;transition:color .18s var(--ease-out),background .18s var(--ease-out)}.tab:hover{color:var(--ink);background:#eae3d00a}.tab.active{color:var(--brass-bright);background:var(--brass-dim)}.tab.active:after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:2px;background:var(--brass)}.engine-badge{font-family:var(--mono);font-size:12px;color:var(--ink-faint);white-space:nowrap}.engine-badge.ok{color:var(--good)}.engine-badge.err{color:var(--bad)}.panel{background:linear-gradient(180deg,var(--panel-raised),var(--panel));border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);min-width:0}h2{font-family:var(--serif);font-weight:700;font-size:26px;line-height:1.15;margin:0 0 12px}h3{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.2;margin:0 0 8px;color:var(--brass-bright)}.muted{color:var(--ink-dim)}.faint{color:var(--ink-faint);font-size:13px}.mono{font-family:var(--mono)}.hint{border:1px solid rgba(217,164,65,.35);background:var(--brass-dim);padding:10px 14px;border-radius:var(--radius);font-size:14px;color:var(--ink);overflow-wrap:anywhere}button.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-family:var(--sans);font-size:14px;font-weight:500;line-height:1.2;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel-raised);color:var(--ink);cursor:pointer;transition:border-color .18s var(--ease-out),background .18s var(--ease-out),box-shadow .18s var(--ease-out),transform .12s var(--ease-out)}button.btn:hover:not(:disabled){border-color:var(--brass);box-shadow:var(--shadow-tight)}button.btn:active:not(:disabled){transform:translateY(1px)}button.btn:disabled{opacity:.45;cursor:default;border-color:var(--line);box-shadow:none}button.btn.primary{background:var(--brass);border-color:var(--brass);color:#241a08;font-weight:600}button.btn.primary:hover{background:var(--brass-bright)}button.btn.small{min-height:34px;padding:6px 12px;font-size:13px}button.btn.danger{border-color:#c8654f80;color:var(--bad)}input[type=text],textarea,select{font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--radius);padding:9px 12px;width:100%;min-height:42px;transition:border-color .18s var(--ease-out),box-shadow .18s var(--ease-out),background .18s var(--ease-out)}textarea{resize:vertical;min-height:70px;line-height:1.5}input:focus-visible,textarea:focus-visible,select:focus-visible,button:focus-visible,.tab:focus-visible,.chip:focus-visible,.pass-step:focus-visible,.concept-item:focus-visible{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px #d9a4412e}input::placeholder,textarea::placeholder{color:var(--ink-faint)}label.field{display:block;min-width:min(100%,180px);font-size:13px;color:var(--ink-dim);margin-bottom:14px}label.field>span{display:block;margin-bottom:5px}input[type=range]{accent-color:var(--brass);width:100%;min-height:32px}.row{display:flex;gap:12px;align-items:center;min-width:0}.row>*{min-width:0}.row.wrap{flex-wrap:wrap}.spread{display:flex;justify-content:space-between;align-items:center;gap:12px;min-width:0}.stack{display:flex;flex-direction:column;gap:12px;min-width:0}.play-layout,.review-layout,.drill-layout{display:grid;grid-template-columns:minmax(0,min(500px,42vw)) minmax(0,1fr);gap:24px;align-items:start}.play-layout>.stack:first-child,.review-layout>.stack:first-child,.drill-layout>.stack:first-child{min-width:0}.board-shell{width:min(100%,var(--board-max));max-width:100%;aspect-ratio:1;margin-inline:auto;border-radius:var(--radius)}.board-shell>div{max-width:100%}@media (min-width: 1024px){.play-layout>.stack:first-child,.review-layout>.stack:first-child,.drill-layout>.stack:first-child{position:sticky;top:88px}}.badge{display:inline-block;font-family:var(--mono);font-size:12px;padding:2px 9px;border-radius:20px;border:1px solid var(--line);color:var(--ink-dim);white-space:nowrap;max-width:100%}.badge.blunder{color:var(--blunder);border-color:#c8654f8c}.badge.mistake{color:var(--mistake);border-color:#d0975a8c}.badge.inaccuracy{color:var(--inaccuracy);border-color:#b8b06a8c}.badge.good{color:var(--good);border-color:#86b56d80}.badge.brass{color:var(--brass-bright);border-color:#d9a44180}.chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;min-height:30px;font-size:13px;padding:3px 12px;border-radius:20px;background:var(--brass-dim);border:1px solid rgba(217,164,65,.35);color:var(--brass-bright);cursor:pointer;font-family:var(--sans);line-height:1.25;max-width:100%;overflow-wrap:anywhere;transition:background .18s var(--ease-out),border-color .18s var(--ease-out)}.chip:hover{background:#d9a44147;border-color:#d9a4418c}.coach-chat{display:flex;flex-direction:column;gap:10px;max-height:min(48vh,420px);overflow-y:auto;padding-right:4px}.msg{padding:10px 14px;border-radius:var(--radius);font-size:14px;max-width:min(92%,68ch);white-space:pre-wrap;overflow-wrap:anywhere}.msg.user{align-self:flex-end;background:var(--brass-dim);border:1px solid rgba(217,164,65,.3)}.msg.coach{align-self:flex-start;background:var(--bg-deep);border:1px solid var(--line-soft)}.msg.coach.thinking{color:var(--ink-faint);font-style:italic}.movelist{font-family:var(--mono);font-size:13.5px;line-height:2;max-height:300px;overflow-y:auto;overflow-wrap:anywhere}.movelist .move{padding:1px 6px;border-radius:5px;cursor:pointer}.movelist .move:hover{background:var(--panel-raised)}.movelist .move.current{background:var(--brass-dim);color:var(--brass-bright)}.movelist .move.issue-blunder{color:var(--blunder)}.movelist .move.issue-mistake{color:var(--mistake)}.movelist .move.issue-inaccuracy{color:var(--inaccuracy)}.movelist .num{color:var(--ink-faint);margin-right:2px}.game-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;display:flex;align-items:center;flex-wrap:wrap;gap:14px;padding:12px 16px;border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--panel);color:var(--ink);font-family:var(--sans);text-align:left;cursor:pointer;transition:border-color .18s var(--ease-out),background .18s var(--ease-out),transform .18s var(--ease-out)}.game-item:hover{border-color:var(--brass);background:var(--panel-raised)}.passes{display:flex;gap:0;margin-bottom:18px;border:1px solid var(--line);border-radius:var(--radius);overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.passes::-webkit-scrollbar{display:none}.pass-step{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1 0 0;min-height:42px;display:flex;align-items:center;justify-content:center;text-align:center;padding:9px 6px;font-size:13px;color:var(--ink-faint);background:var(--bg-deep);border:none;border-right:1px solid var(--line-soft);cursor:pointer;white-space:nowrap;transition:color .18s var(--ease-out),background .18s var(--ease-out)}.pass-step:last-child{border-right:none}.pass-step.done{color:var(--good)}.pass-step.active{background:var(--brass-dim);color:var(--brass-bright);font-weight:600}.drill-verdict{font-family:var(--serif);font-size:22px;font-weight:700}.drill-verdict.ok{color:var(--good)}.drill-verdict.fail{color:var(--bad)}.concept-grid{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:24px;align-items:start}.concept-list{display:flex;flex-direction:column;gap:6px;max-height:70vh;overflow-y:auto}.concept-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;min-height:38px;padding:8px 14px;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;background:transparent;color:var(--ink);font-family:var(--sans);font-size:15px;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:8px;transition:border-color .18s var(--ease-out),background .18s var(--ease-out)}.concept-item:hover{border-color:var(--line)}.concept-item.active{background:var(--brass-dim);border-color:#d9a44166;color:var(--brass-bright)}.mastery{font-family:var(--mono);font-size:12px;color:var(--ink-faint);letter-spacing:2px}.mastery .on{color:var(--brass)}.mastery-dot{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;padding:2px 4px;cursor:pointer}.mastery-dot.on{color:var(--brass)}.card-section{margin-bottom:14px}.card-section .label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-bottom:3px}.graph-svg{width:100%;max-height:min(66vh,520px);height:auto;display:block}.graph-svg .edge{stroke:var(--line);stroke-width:1}.graph-svg .node circle{fill:var(--panel-raised);stroke:var(--line);cursor:pointer;transition:stroke .15s}.graph-svg .node:hover circle,.graph-svg .node.active circle{stroke:var(--brass);fill:var(--brass-dim)}.graph-svg .node text{fill:var(--ink-dim);font-family:var(--sans);font-size:11px;pointer-events:none}.graph-svg .node.active text{fill:var(--brass-bright)}.progress{height:6px;border-radius:3px;background:var(--bg-deep);overflow:hidden}.progress>div{height:100%;width:100%;background:var(--brass);transform-origin:left;transition:transform .2s}.evalchart{width:100%;display:block}.evalchart .zero{stroke:var(--ink-faint);stroke-dasharray:3 4;stroke-width:1}.evalchart .curve{fill:none;stroke:var(--brass);stroke-width:1.6}.evalchart .area{fill:#d9a4411f}.evalchart .pt{fill:transparent;cursor:pointer}.evalchart .pt:hover,.evalchart .pt.current{fill:var(--brass-bright)}.evalchart .pt.blunder{fill:var(--blunder)}.evalchart .pt.mistake{fill:var(--mistake)}.mini-review ul{margin:6px 0 10px;padding-left:18px;color:var(--ink-dim);font-size:13.5px}.mini-review li{margin-bottom:2px}.mini-review .label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin:2px 0 0}.mini-review ul.blunder-check{margin-top:4px;border-left:2px solid var(--brass);padding-left:16px;margin-left:2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px;border:2px solid var(--bg)}::-webkit-scrollbar-track{background:transparent}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.tab-content{animation:rise .22s var(--ease-out)}@media (hover: hover) and (pointer: fine){button.btn:hover:not(:disabled),.game-item:hover{transform:translateY(-1px)}}@media (pointer: coarse){.tab,.pass-step,.chip,.concept-item,button.btn{min-height:44px}button.btn.small{min-height:40px;padding:8px 12px}}@media (max-width: 980px){.app-header{top:0}.play-layout,.review-layout,.drill-layout,.concept-grid{grid-template-columns:minmax(0,1fr)}.play-layout>.stack:first-child,.review-layout>.stack:first-child,.drill-layout>.stack:first-child{position:static;width:min(100%,560px)}.concept-list{max-height:360px}}@media (max-width: 680px){body{font-size:14.5px;background-attachment:scroll}.app{padding:0 max(12px,env(safe-area-inset-left)) 44px max(12px,env(safe-area-inset-right))}.app-header{align-items:flex-start;gap:10px;padding:14px 0 12px;margin-bottom:16px}.app-title{font-size:24px}.engine-badge{order:2;width:100%;font-size:11px}.tabs{order:3;width:calc(100% + 24px);min-width:0;margin:0 -12px;padding:0 12px 2px;justify-content:flex-start}.tab{flex:0 0 auto;padding:8px 13px}.panel{padding:14px}h2{font-size:22px}h3{font-size:18px}.play-layout,.review-layout,.drill-layout,.concept-grid{gap:16px}.row:not(.wrap),.spread{flex-wrap:wrap;align-items:flex-start}.row input[type=text]{flex:1 1 180px}button.btn.primary{width:100%}.passes{width:100%;margin-bottom:12px}.pass-step{flex:0 0 auto;min-width:108px}.coach-chat{max-height:50vh}.movelist{max-height:220px}.concept-list{max-height:none}}@media (max-width: 420px){.app{padding-inline:10px}.tabs{width:calc(100% + 20px);margin-inline:-10px;padding-inline:10px}.panel{padding:12px}.app-title{font-size:22px}.game-item{padding:10px 12px}.badge{font-size:11.5px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.hero{display:flex;align-items:center;gap:18px;padding:16px 20px;background:linear-gradient(135deg,var(--panel-raised),var(--panel));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-tight)}.hero-badge{flex:none;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 32% 28%,var(--brass-bright),var(--brass) 62%,#a97c22);box-shadow:0 4px 14px #d9a44159,inset 0 1px 2px #fff6}.hero-badge-num{font-family:var(--serif);font-weight:700;font-size:26px;color:#201607}.hero-main{flex:1;min-width:0}.hero-line{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.hero-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--brass-bright)}.hero-sub{font-size:12px;margin-top:3px}.hero-stats{display:flex;gap:16px;flex:none}.hero-stat{display:flex;flex-direction:column;align-items:center;gap:1px}.hero-stat-val{font-family:var(--mono);font-size:16px;color:var(--ink)}.hero-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint)}.xp-bar{height:8px;margin-top:8px;border-radius:999px;background:var(--bg-deep);border:1px solid var(--line-soft);overflow:hidden}.xp-fill{height:100%;width:100%;border-radius:999px;background:linear-gradient(90deg,var(--brass),var(--brass-bright));transform-origin:left;transition:transform .5s var(--ease-out)}.calibrate-cta{align-items:center;gap:16px;border-color:#d9a44166;background:var(--brass-dim)}.daily{align-items:center;gap:16px}.daily-title{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--ink)}.tree-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,400px);gap:24px;align-items:start}.tree-scroll{overflow-x:auto;max-height:min(72vh,640px);overflow-y:auto}.tree-svg{display:block;min-width:720px}.tree-lane-label{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.04em;opacity:.85}.tree-edge{stroke:var(--line);stroke-width:1.4;stroke-opacity:.55}.tree-node{cursor:pointer}.tree-ring-bg{fill:var(--panel-raised);stroke:var(--line);stroke-width:2}.tree-ring{fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dasharray .5s var(--ease-out)}.tree-core{fill:var(--bg-deep);transition:fill .15s}.tree-node:hover .tree-ring-bg,.tree-node.active .tree-ring-bg{stroke:var(--brass)}.tree-node{outline:none}.tree-node:focus-visible .tree-ring-bg{stroke:var(--brass-bright);stroke-width:3}.tree-level{fill:var(--ink);font-family:var(--mono);font-size:15px;font-weight:600;pointer-events:none}.tree-node.active .tree-level{fill:#201607}.tree-lock{font-size:13px;pointer-events:none}.tree-name{fill:var(--ink-dim);font-family:var(--sans);font-size:11px;pointer-events:none}.tree-node.locked{opacity:.55}.tree-node.locked .tree-ring-bg{stroke-dasharray:3 3}.tree-node.locked .tree-name{opacity:.85}.node-detail{position:sticky;top:88px;max-height:min(78vh,720px);overflow-y:auto}.skill-progress{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:var(--radius);background:var(--bg-deep);border:1px solid var(--line-soft)}.level-pips{display:flex;gap:6px}.level-pips .pip{width:100%;height:5px;border-radius:999px;background:var(--line)}.level-pips .pip.on{background:var(--brass)}.quiz-layout{display:grid;grid-template-columns:minmax(0,min(460px,44vw)) minmax(0,1fr);gap:24px;align-items:start}.quiz-prompt{font-family:var(--serif);font-size:20px;line-height:1.3;margin:0;color:var(--ink)}.choice{-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:left;display:flex;flex-direction:column;gap:4px;width:100%;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel-raised);color:var(--ink);font-family:var(--sans);font-size:15px;cursor:pointer;transition:border-color .15s var(--ease-out),background .15s var(--ease-out)}.choice:hover:not(:disabled){border-color:var(--brass)}.choice:disabled{cursor:default}.choice.correct{border-color:var(--good);background:#86b56d24}.choice.wrong{border-color:var(--bad);background:#c8654f24}.choice-why{font-size:12.5px}.xp-pop{margin-left:12px;font-family:var(--mono);font-size:15px;color:var(--brass-bright)}.levelup{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--brass-bright);animation:levelup-pop .4s var(--ease-out)}@keyframes levelup-pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink-dim)}.quiz-summary{max-width:460px}.summary-grid{display:flex;gap:24px;flex-wrap:wrap}.summary-stat{display:flex;flex-direction:column;gap:2px}.summary-val{font-family:var(--serif);font-size:30px;font-weight:700;color:var(--ink)}.summary-val.brass{color:var(--brass-bright)}.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%);z-index:40;padding:12px 20px;border-radius:999px;background:var(--panel-raised);border:1px solid var(--brass);color:var(--brass-bright);font-family:var(--serif);font-size:17px;font-weight:700;box-shadow:var(--shadow);animation:toast-in .32s var(--ease-out)}@keyframes toast-in{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}@media (max-width: 900px){.tree-grid,.quiz-layout{grid-template-columns:1fr}.tree-scroll{max-height:50vh}.node-detail{position:static;max-height:none;scroll-margin-top:80px}.hero{flex-wrap:wrap}}
