:root{--parchment: #f4ecdb;--parchment-2: #ece1c8;--parchment-3: #e3d4b3;--walnut: #8b5e3c;--walnut-deep: #6c4528;--walnut-soft: #b08866;--ink: #1f1714;--ink-soft: #4a3b32;--ink-mute: #8a786a;--felt: #5c8f6f;--felt-deep: #3f6b51;--felt-soft: #d3e2d6;--brass: #c99746;--brass-light: #e7c47e;--brass-deep: #9e7029;--burgundy: #9c3f3f;--cobalt: #2f6fcf;--violet: #6f56b3;--sq-light: #f3e2c1;--sq-dark: #b07946;--role-attacker: var(--cobalt);--role-attacker-fill: #a9c9ff;--role-attacker-fg: #173b78;--role-defender: #4f8264;--role-defender-fill: #9ec5ad;--role-defender-fg: #234734;--role-target: var(--burgundy);--role-target-fill: #df9a9a;--role-target-fg: #581818;--role-support: #7a9c87;--role-support-fill: #c4d8cb;--role-support-fg: #2d4438;--role-blocker: var(--violet);--role-blocker-fill: #c7bdf2;--role-blocker-fg: #33225f;--r-sm: 10px;--r-md: 14px;--r-lg: 22px;--r-xl: 30px;--shadow-1: 0 1px 0 rgba(108, 69, 40, .06), 0 6px 14px -8px rgba(108, 69, 40, .18);--shadow-2: 0 1px 0 rgba(108, 69, 40, .08), 0 14px 28px -16px rgba(108, 69, 40, .28);--serif: ui-serif, Georgia, Cambria, "Times New Roman", serif;--sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;--mono: ui-monospace, "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;--muted: var(--ink-mute);--soft: var(--parchment);--paper: #ffffff;--line: var(--walnut-soft);--line-strong: var(--walnut);--sage: var(--walnut);--sage-dark: var(--ink-soft);--amber: var(--brass);--amber-soft: var(--brass-light);--charcoal: var(--ink);--charcoal-2: var(--walnut-deep);--danger: var(--burgundy);--shadow: var(--shadow-2);--surface-soft: var(--parchment-2);--feedback-bg: var(--parchment-2);--success-bg: var(--parchment-3);--success-line: var(--walnut);--rail-item: var(--parchment);--rail-muted: var(--walnut-soft);--rail-sub: var(--walnut-soft);--rail-heading: var(--ink-mute);--board-frame: var(--walnut-deep);--board-light: var(--sq-light);--board-dark: var(--sq-dark);--board-coords: var(--ink-mute);--piece-light-bg: #fffaf0;--piece-light-text: var(--ink);--piece-light-border: rgba(30, 24, 20, .62);--piece-light-glow: rgba(255, 248, 222, .5);--piece-dark-bg: var(--ink);--piece-dark-text: #f3ead8;--piece-dark-border: rgba(255, 245, 226, .64);--piece-dark-glow: rgba(255, 226, 180, .24);--piece-edge-shadow: rgba(10, 8, 6, .32);--focus-ring: rgba(201, 151, 70, .78);--last-move: rgba(231, 196, 126, .42);--control-shadow: 0 1px 0 rgba(255, 255, 255, .9);font-family:var(--sans);color:var(--ink);background:var(--parchment);font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell[data-theme=dark]{--parchment: #1a1612;--parchment-2: #221c17;--parchment-3: #2d251e;--walnut: #a87a55;--walnut-deep: #6f4e34;--walnut-soft: #5a4232;--ink: #f0e6d4;--ink-soft: #d8cbb9;--ink-mute: #c6b9a7;--felt: #6f8c76;--felt-deep: #5d7865;--felt-soft: #2d3a31;--brass: #d2a25a;--brass-light: #e7c47e;--brass-deep: #8c6730;--burgundy: #c66a6a;--cobalt: #7fb0ff;--violet: #a895e6;--sq-light: #c2a675;--sq-dark: #5b3d24;--role-attacker: var(--cobalt);--role-attacker-fill: #203f73;--role-attacker-fg: #d5e6ff;--role-defender: #7eb38f;--role-defender-fill: #2f4a3a;--role-defender-fg: #cfe5d6;--role-target: var(--burgundy);--role-target-fill: #5b2727;--role-target-fg: #f4c8c8;--role-support: #94b9a3;--role-support-fill: #344739;--role-support-fg: #cddccf;--role-blocker: var(--violet);--role-blocker-fill: #403168;--role-blocker-fg: #e5ddff;--shadow-1: 0 1px 0 rgba(0, 0, 0, .18), 0 6px 14px -8px rgba(0, 0, 0, .5);--shadow-2: 0 1px 0 rgba(0, 0, 0, .22), 0 14px 28px -16px rgba(0, 0, 0, .6);--muted: var(--ink-mute);--soft: var(--parchment);--paper: var(--parchment-2);--line: var(--walnut-soft);--line-strong: var(--walnut);--sage: var(--walnut);--sage-dark: var(--ink-soft);--amber: var(--brass);--amber-soft: var(--brass-light);--charcoal: var(--parchment);--charcoal-2: var(--walnut-deep);--danger: var(--burgundy);--shadow: var(--shadow-2);--surface-soft: var(--parchment-2);--feedback-bg: var(--parchment-2);--success-bg: var(--parchment-3);--success-line: var(--walnut);--rail-item: var(--parchment);--rail-muted: var(--walnut-soft);--rail-sub: var(--walnut-soft);--rail-heading: var(--ink-mute);--board-frame: #100b07;--board-light: var(--sq-light);--board-dark: var(--sq-dark);--board-coords: var(--ink-mute);--piece-light-bg: #efe3ce;--piece-light-text: var(--ink);--piece-light-border: rgba(30, 24, 20, .7);--piece-light-glow: rgba(255, 245, 220, .46);--piece-dark-bg: #14100c;--piece-dark-text: #f4ead6;--piece-dark-border: rgba(255, 247, 230, .68);--piece-dark-glow: rgba(255, 226, 180, .28);--piece-edge-shadow: rgba(0, 0, 0, .48);--last-move: rgba(210, 162, 90, .28);--control-shadow: 0 1px 0 rgba(255, 255, 255, .04)}.ref{display:inline;padding:.05em .35em;border:0;border-radius:6px;font-weight:600;cursor:pointer;background:var(--parchment-2);color:var(--ink);transition:outline-color .12s ease,transform .12s ease;outline:2px solid transparent}.ref[data-role=attacker]{background:var(--role-attacker-fill);color:var(--role-attacker-fg)}.ref[data-role=defender]{background:var(--role-defender-fill);color:var(--role-defender-fg)}.ref[data-role=target]{background:var(--role-target-fill);color:var(--role-target-fg)}.ref[data-role=support]{background:var(--role-support-fill);color:var(--role-support-fg)}.ref[data-role=blocker]{background:var(--role-blocker-fill);color:var(--role-blocker-fg)}.ref:focus-visible,.ref[data-flash=true]{outline-color:currentColor;transform:translateY(-1px)}.board-square[data-mark]{position:relative}.board-square[data-mark]:after{content:"";position:absolute;inset:0;border-radius:0;pointer-events:none;mix-blend-mode:multiply;opacity:.58}.board-square[data-mark=attacker]:after{background:var(--role-attacker-fill);box-shadow:inset 0 0 0 3px var(--role-attacker);mix-blend-mode:normal;opacity:.5}.board-square[data-mark=defender]:after{background:var(--role-defender-fill);box-shadow:inset 0 0 0 3px var(--role-defender)}.board-square[data-mark=target]:after{background:var(--role-target-fill);box-shadow:inset 0 0 0 3px var(--role-target)}.board-square[data-mark=support]:after{background:var(--role-support-fill);box-shadow:inset 0 0 0 3px var(--role-support)}.board-square[data-mark=blocker]:after{background:var(--role-blocker-fill);box-shadow:inset 0 0 0 3px var(--role-blocker)}.board-square[data-flash=true]:after{opacity:.82;animation:ref-square-flash .9s ease}@keyframes ref-square-flash{0%,to{transform:scale(1)}45%{transform:scale(.88)}}@media(prefers-reduced-motion:reduce){.ref,.board-square[data-flash=true]:after{animation:none;transition:none}}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}button{font:inherit;touch-action:manipulation}.app-shell{height:100dvh;min-height:100vh;display:grid;grid-template-columns:1fr;overflow:hidden;color:var(--ink);background:var(--parchment)}.auth-gate-shell{min-height:100dvh;display:grid;place-items:center;padding:24px;color:var(--ink);background:radial-gradient(circle at 20% 12%,color-mix(in srgb,var(--board-light) 28%,transparent),transparent 34%),var(--parchment)}.auth-gate-page{width:min(640px,100%)}.auth-gate-card{display:grid;gap:22px;padding:24px;border:1px solid var(--parchment-3);border-radius:var(--r-lg);background:color-mix(in srgb,var(--parchment-2) 94%,transparent);box-shadow:var(--shadow-2)}.auth-gate-copy{display:grid;gap:10px}.auth-gate-kicker{color:var(--felt);font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.auth-gate-copy h1{margin:0;color:var(--ink);font-family:var(--serif);font-size:clamp(2.2rem,8vw,4.2rem);line-height:.95;letter-spacing:0}.auth-gate-copy p{margin:0;max-width:48ch;color:var(--ink-soft);font-family:var(--sans);font-size:15px;line-height:1.55}.app-shell-frame{display:grid;grid-template-rows:auto minmax(0,1fr) auto;height:100dvh;min-height:100vh;overflow:hidden;max-width:720px;width:100%;margin:0 auto}.app-main{padding:16px 18px 96px;overflow-y:auto}.app-main[data-mode=lessons],.app-main[data-mode=play],.app-main[data-mode=review]{min-height:0;overflow:hidden;padding:10px 12px}@media(min-width:900px){.app-shell{grid-template-columns:84px minmax(0,1fr)}.app-shell-frame{grid-template-rows:auto minmax(0,1fr);max-width:960px}.app-main{padding:24px 32px 32px}.app-main[data-mode=lessons],.app-main[data-mode=play],.app-main[data-mode=review]{padding:20px 24px}}.top-bar{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--parchment-3);background:var(--parchment)}.top-bar-lead,.top-bar-trail{display:flex;align-items:center;justify-content:center}.top-bar-title-cluster{display:flex;flex-direction:column;align-items:center;min-width:0}.top-bar-eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:2px}.top-bar-title{font-family:var(--serif);font-size:19px;font-weight:600;margin:0;color:var(--ink);letter-spacing:.005em;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.top-bar-icon-btn{width:40px;height:40px;display:grid;place-items:center;border:none;background:transparent;color:var(--ink-soft);border-radius:var(--r-md);cursor:pointer;transition:background .12s ease}.top-bar-icon-btn:hover,.top-bar-icon-btn:focus-visible{background:var(--parchment-2);color:var(--ink);outline:none}.bottom-tab-bar{position:sticky;bottom:0;display:grid;grid-template-columns:repeat(5,1fr);padding:6px 6px max(6px,env(safe-area-inset-bottom));background:#f4ecdbdb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--parchment-3);z-index:5}.app-shell[data-theme=dark] .bottom-tab-bar{background:#1a1612eb;border-top-color:var(--walnut-soft)}.bottom-tab{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px 6px;border:none;background:transparent;color:var(--ink-mute);cursor:pointer;position:relative;border-radius:var(--r-md)}.bottom-tab[data-active=true]{color:var(--ink)}.bottom-tab[data-active=true]:before{content:"";position:absolute;top:0;left:22%;right:22%;height:3px;border-radius:0 0 3px 3px;background:var(--brass)}.bottom-tab-icon-wrap{position:relative;display:grid;place-items:center}.bottom-tab-badge{position:absolute;top:-6px;right:-10px;min-width:18px;height:18px;padding:0 5px;display:grid;place-items:center;background:var(--burgundy);color:#fff;font-size:10px;font-weight:700;border-radius:9px;font-family:var(--sans)}.bottom-tab-label{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.02em}@media(max-width:700px)and (max-height:760px),(max-width:700px)and (min-aspect-ratio:9 / 18){.app-shell-frame:has(.app-main:is([data-mode=lessons],[data-mode=play],[data-mode=review])){grid-template-rows:minmax(0,1fr) auto}.app-shell-frame:has(.app-main:is([data-mode=lessons],[data-mode=play],[data-mode=review]))>.top-bar{display:none}}@media(max-height:560px){.app-shell-frame:has(.app-main:is([data-mode=lessons],[data-mode=play],[data-mode=review])){grid-template-rows:minmax(0,1fr) auto}.app-shell-frame:has(.app-main:is([data-mode=lessons],[data-mode=play],[data-mode=review]))>.top-bar{display:none}}@media(min-width:900px){.bottom-tab-bar{display:none}}.tablet-rail{display:none}@media(min-width:900px){.tablet-rail{display:flex;flex-direction:column;align-items:center;gap:14px;padding:16px 8px;border-right:1px solid var(--parchment-3);background:var(--parchment-2)}}.tablet-rail-brand{width:44px;height:44px;display:grid;place-items:center;border-radius:var(--r-md);background:var(--ink);color:var(--parchment);font-size:22px;margin-bottom:6px}.tablet-rail-tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;width:100%;border:none;background:transparent;color:var(--ink-mute);cursor:pointer;border-radius:var(--r-md);position:relative}.tablet-rail-tab[data-active=true]{color:var(--ink);background:var(--parchment)}.tablet-rail-tab[data-active=true]:before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:3px;border-radius:0 3px 3px 0;background:var(--brass)}.tablet-rail-icon-wrap{position:relative;display:grid;place-items:center}.tablet-rail-badge{position:absolute;top:-6px;right:-10px;min-width:18px;height:18px;padding:0 5px;display:grid;place-items:center;background:var(--burgundy);color:#fff;font-size:10px;font-weight:700;border-radius:9px;font-family:var(--sans)}.tablet-rail-label{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.02em}.streak-toast{position:fixed;top:max(14px,env(safe-area-inset-top));left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;width:min(360px,calc(100vw - 32px));max-width:calc(100vw - 32px);padding:12px 14px;border-radius:var(--r-lg);border:1px solid var(--brass-deep);background:linear-gradient(180deg,var(--brass-light),var(--brass));color:#2b1e09;box-shadow:var(--shadow-2);z-index:50;font-family:var(--sans);animation:streak-toast-slide-in .22s ease-out}.streak-toast-text{display:flex;flex-direction:column;align-items:flex-start;min-width:0;line-height:1.2}.streak-toast-count{font-family:var(--serif);font-weight:600;font-size:15px}.streak-toast-caption{font-size:11px;opacity:.78;margin-top:2px;overflow-wrap:anywhere}.streak-toast-dismiss{display:grid;place-items:center;width:28px;height:28px;border:none;background:transparent;color:inherit;opacity:.7;cursor:pointer;border-radius:50%}.streak-toast-dismiss:hover,.streak-toast-dismiss:focus-visible{background:#0000001f;opacity:1;outline:none}@keyframes streak-toast-slide-in{0%{opacity:0;transform:translate(-50%,-16px)}to{opacity:1;transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.streak-toast{animation:none}}.app-shell[data-board-theme=walnut]{--board-frame: #442a1e;--board-light: #ead8b6;--board-dark: #9b6943;--board-coords: #836b59;--last-move: rgba(255, 221, 144, .42);--focus-ring: rgba(68, 42, 30, .72);--piece-light-glow: rgba(255, 239, 196, .55);--piece-dark-glow: rgba(52, 28, 18, .66)}.app-shell[data-board-theme=slate]{--board-frame: #1f2d34;--board-light: #d5dde1;--board-dark: #607889;--board-coords: #6f828d;--last-move: rgba(226, 238, 245, .38);--focus-ring: rgba(227, 170, 85, .74);--piece-light-glow: rgba(247, 252, 255, .5);--piece-dark-glow: rgba(19, 30, 37, .66)}.app-shell[data-board-theme=blue]{--board-frame: #22384f;--board-light: #dbe8f7;--board-dark: #668db5;--board-coords: #6f8297;--last-move: rgba(255, 232, 183, .4);--focus-ring: rgba(216, 154, 61, .76);--piece-light-glow: rgba(245, 250, 255, .52);--piece-dark-glow: rgba(18, 34, 54, .66)}.app-shell[data-theme=dark][data-board-theme=walnut]{--board-frame: #160e0a;--board-light: #b99a69;--board-dark: #684124;--board-coords: #8f745b}.app-shell[data-theme=dark][data-board-theme=slate]{--board-frame: #0c1317;--board-light: #9aa9af;--board-dark: #3f5868;--board-coords: #7d9098}.app-shell[data-theme=dark][data-board-theme=blue]{--board-frame: #0f1a26;--board-light: #9fb8d2;--board-dark: #315981;--board-coords: #7f97ad}.board-wrap{--board-coordinate-gutter: 14px;--board-frame-width: 10px;--board-label-font-size: 11px;width:min(66vh,100%,690px);min-width:320px}.board-coordinate-row,.board-middle{display:grid;grid-template-columns:var(--board-coordinate-gutter) minmax(0,1fr) var(--board-coordinate-gutter);gap:2px}.board-middle{align-items:stretch}.board-grid{position:relative;width:100%;aspect-ratio:1;display:grid;grid-template-columns:repeat(8,1fr);border:var(--board-frame-width) solid var(--board-frame);border-radius:8px;overflow:hidden;box-shadow:0 16px 30px #12191738;background:var(--board-frame)}.board-arrows{position:absolute;z-index:3;inset:var(--board-frame-width);overflow:visible;pointer-events:none}.board-arrow{fill:none;stroke:var(--role-attacker);stroke-linecap:round;stroke-linejoin:round;stroke-width:3px;filter:drop-shadow(0 1px 1px rgba(18,25,23,.3))}.board-arrow-head{fill:var(--role-attacker)}.rank-files{width:calc(100% - 8px);margin:0 auto;display:grid;grid-template-columns:repeat(8,1fr);color:var(--board-coords);font-size:var(--board-label-font-size);font-weight:800;text-align:center;text-transform:uppercase}.rank-labels{display:grid;grid-template-rows:repeat(8,1fr);align-self:stretch;min-width:var(--board-coordinate-gutter);padding:var(--board-frame-width) 0;color:var(--board-coords);font-size:var(--board-label-font-size);font-weight:800;text-align:center;box-sizing:border-box}.rank-labels span{display:grid;place-items:center}.files-top{margin-bottom:1px}.files-bottom{margin-top:1px}.board-square{position:relative;display:grid;place-items:center;width:100%;aspect-ratio:1;border:0;padding:0;cursor:pointer;color:inherit;touch-action:manipulation}.board-square[data-interactive=true]{touch-action:none}.board-square.light{background:var(--board-light)}.board-square.dark{background:var(--board-dark)}.board-square.selected{outline:4px solid rgba(216,154,61,.95);outline-offset:-4px}.board-square.focus:before,.board-square.last:before{content:"";position:absolute;inset:9%;border-radius:8px;pointer-events:none}.board-square.focus:before{border:3px solid var(--focus-ring)}.board-square.last:before{background:var(--last-move)}.board-square.move-from:after{content:"";position:absolute;z-index:2;inset:17%;border-radius:8px;border:2px solid var(--role-attacker);opacity:0;pointer-events:none;animation:board-move-source .24s ease-out}.piece{position:relative;z-index:1;width:clamp(34px,78%,72px);height:clamp(34px,78%,72px);display:grid;place-items:center;filter:drop-shadow(0 1px 0 var(--piece-edge-shadow)) drop-shadow(0 0 7px var(--piece-glow)) drop-shadow(0 5px 6px rgba(12,18,16,.26));pointer-events:none;user-select:none}.board-square.arrow-source .piece{z-index:4}.board-square.move-to .piece{z-index:5;animation:board-piece-arrive .24s cubic-bezier(.16,.84,.28,1)}.piece-svg{width:100%;height:100%;display:block;overflow:visible;pointer-events:none}.piece-svg path,.piece-svg rect,.piece-svg circle{fill:currentColor;stroke:var(--piece-stroke);stroke-linecap:round;stroke-linejoin:round;stroke-width:2.4}.white-piece{color:var(--piece-light-bg);--piece-stroke: var(--piece-light-border);--piece-detail: var(--piece-light-text);--piece-glow: var(--piece-light-glow)}.black-piece{color:var(--piece-dark-bg);--piece-stroke: var(--piece-dark-border);--piece-detail: var(--piece-dark-text);--piece-glow: var(--piece-dark-glow)}.piece-svg .piece-cut{fill:none;stroke:var(--piece-detail);stroke-width:3}.piece-svg .piece-eye{fill:var(--piece-detail);stroke:none}.legal-dot{position:absolute;z-index:2;width:24%;height:24%;border-radius:50%;background:#191f1cbd;box-shadow:0 0 0 2px #fff4d5eb,0 0 0 4px #191f1c52,0 2px 7px #1219175c,inset 0 0 0 1px #ffffff52}@keyframes board-piece-arrive{0%{transform:translate(calc(var(--move-x, 0) * 128%),calc(var(--move-y, 0) * 128%)) scale(.94)}76%{transform:translate(0) scale(1.06)}to{transform:translate(0) scale(1)}}@keyframes board-move-source{0%{opacity:.55;transform:scale(.92)}to{opacity:0;transform:scale(1.35)}}@media(prefers-reduced-motion:reduce){.board-square.move-from:after,.board-square.move-to .piece{animation:none}}.coming-soon-stub{background:var(--parchment-2);border:1px solid var(--parchment-3);border-radius:var(--r-lg);padding:32px 24px;margin-top:24px;text-align:center;box-shadow:var(--shadow-1)}.coming-soon-eyebrow{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);margin:0 0 8px}.coming-soon-title{font-family:var(--serif);font-size:28px;font-weight:600;margin:0 0 12px;color:var(--ink)}.coming-soon-summary{font-family:var(--sans);font-size:14px;line-height:1.55;color:var(--ink-soft);margin:0 auto;max-width:36ch}.theme-choice-group{display:flex;flex-direction:column;gap:9px;margin:0;padding:12px 16px 14px;border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2)}.theme-choice-group legend{padding:0 6px;color:var(--ink);font-family:var(--sans);font-size:13px;font-weight:600}.theme-choice-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.theme-choice{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 10px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--parchment);color:var(--ink-soft);font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer}.theme-choice[data-active=true]{border-color:var(--brass);background:var(--brass-soft);color:var(--ink)}.board-swatch{display:block;width:100%;height:100%;border-radius:6px;background:linear-gradient(135deg,var(--swatch-light) 0 50%,var(--swatch-dark) 50% 100%);border:1px solid rgba(0,0,0,.18)}.progress-bar{height:6px;margin-top:10px;overflow:hidden;border-radius:999px;background:#ffffff1f}.progress-bar span{height:100%;border-radius:inherit;background:var(--amber)}.sync-pill{min-height:40px;max-width:210px;display:grid;align-content:center;padding:5px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);box-shadow:var(--control-shadow)}.sync-pill span,.sync-pill strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sync-pill span{color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase}.sync-pill strong{color:var(--sage-dark);font-size:12px;line-height:1.2}.sync-pill.saving strong{color:var(--amber)}.sync-pill.local strong,.sync-pill.error strong{color:var(--danger)}.segmented{display:inline-flex;min-height:40px;padding:3px;border:1px solid var(--line);border-radius:8px;background:var(--paper);box-shadow:var(--control-shadow)}.segmented button,.ghost-button,.primary-button,.text-button,.more-puzzles,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:7px;border:1px solid transparent;cursor:pointer;font-size:13px;font-weight:800;letter-spacing:0;white-space:nowrap}.segmented button{min-height:32px;padding:0 12px;color:var(--muted);background:transparent}.segmented button.active{color:var(--paper);background:var(--sage-dark)}.segmented button:disabled{opacity:.42;cursor:not-allowed}.ghost-button{min-height:40px;padding:0 13px;background:var(--paper);border-color:var(--line);color:var(--ink)}.theme-button{min-width:122px}.board-theme-picker{position:relative;min-height:40px;display:inline-flex;align-items:center;gap:5px;padding:3px 6px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--muted);box-shadow:var(--control-shadow)}.board-theme-picker legend{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.board-theme-picker button{width:31px;height:31px;display:grid;place-items:center;padding:0;border:1px solid transparent;border-radius:7px;background:transparent;cursor:pointer}.board-theme-picker button.active{border-color:var(--sage);background:var(--surface-soft)}.board-swatch{width:19px;height:19px;overflow:hidden;border:1px solid rgba(20,28,25,.22);border-radius:4px}.primary-button{min-height:42px;padding:0 16px;background:var(--sage-dark);color:var(--paper);box-shadow:0 8px 18px #2f5b4633}.text-button{min-height:28px;padding:0 7px;color:var(--sage-dark);background:transparent}.text-button:disabled{opacity:.45;cursor:not-allowed}.icon-button{width:38px;height:38px;background:var(--paper);border-color:var(--line);color:var(--ink)}.icon-button:disabled,.ghost-button:disabled{opacity:.45;cursor:not-allowed}.coach-card{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:stretch;gap:12px;padding:14px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--parchment-2);box-shadow:var(--shadow-1)}.coach-card-rail{display:grid;align-content:start;justify-items:center;gap:8px}.coach-card-avatar{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:var(--felt);color:var(--parchment);font-family:var(--serif);font-weight:700}.coach-card-rail-actions{display:grid;justify-items:center}.coach-card-rail-actions .speech-card.compact .speech-toggle-button{width:34px;min-width:34px;height:34px;min-height:34px;padding:0;border-radius:9px}.coach-card-rail-actions .speech-card.compact .speech-toggle-label{display:none}.coach-card-body{min-width:0;height:100%;display:flex;flex-direction:column;gap:9px}.coach-card-meta{display:flex;align-items:baseline;gap:7px;flex-wrap:wrap}.coach-card-meta strong{color:var(--ink);font-family:var(--serif);font-size:16px}.coach-card-meta span{color:var(--ink-mute);font-size:12px;font-weight:750}.coach-card-copy{position:relative;color:var(--ink-soft);font-size:14px;line-height:1.5}.coach-card-copy:before{content:"";position:absolute;top:4px;left:-19px;width:12px;height:12px;background:var(--parchment-2);border-left:1px solid var(--line);border-bottom:1px solid var(--line);transform:rotate(45deg)}.coach-card-actions{grid-column:2;display:flex;gap:8px;flex-wrap:wrap}.coach-action-row{min-width:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lesson-flow-actions{display:inline-flex;align-items:center;gap:6px;min-inline-size:0;margin:0;padding-left:8px;border:0;border-left:1px solid var(--line)}.lesson-flow-button{min-width:92px;padding:0 10px}.lesson-flow-button[data-nav-action=continue],.lesson-flow-button[data-nav-action=try-again]{color:var(--paper);background:var(--sage-dark)}.main-board-panel>.coach-card{width:min(100%,640px)}.game-panel>.coach-card{width:min(100%,640px)}.coach-card-note{display:block;margin-top:6px;color:var(--sage-dark);font-size:12px;font-weight:800;line-height:1.35}.narration-view{margin:0}.extras-drawer{min-width:0;max-height:100%;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--paper);box-shadow:var(--shadow)}.extras-drawer>summary{min-height:44px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 12px;color:var(--ink);cursor:pointer;list-style:none}.extras-drawer>summary::-webkit-details-marker{display:none}.extras-drawer>summary:after{content:"+";flex:0 0 auto;width:22px;height:22px;display:grid;place-items:center;border:1px solid var(--line);border-radius:50%;color:var(--sage-dark);font-weight:900}.extras-drawer[open]>summary:after{content:"-"}.extras-drawer summary span,.extras-drawer summary strong{display:block}.extras-drawer summary span{color:var(--muted);font-size:11px;font-weight:900;line-height:1.2;text-transform:uppercase}.extras-drawer summary strong{margin-top:2px;overflow:hidden;font-size:14px;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.extras-drawer-body{display:grid;gap:12px;max-height:min(52dvh,520px);overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;padding:12px;border-top:1px solid var(--line)}.lesson-extras .coach-panel,.play-extras .tutor-panel{box-shadow:none}.lesson-sheet-backdrop{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-end;justify-content:center;padding:18px}.lesson-sheet-scrim{position:absolute;inset:0;border:0;background:#1f171457;cursor:default}.lesson-settings-sheet{position:relative;z-index:1;width:min(100%,560px);max-height:min(82vh,720px);display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding:18px;border:1px solid var(--walnut-soft);border-radius:var(--r-xl) var(--r-xl) var(--r-md) var(--r-md);background:var(--parchment);box-shadow:var(--shadow-2)}.lesson-sheet-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.lesson-sheet-header span{color:var(--ink-mute);font-size:11px;font-weight:850;text-transform:uppercase}.lesson-sheet-header h2{margin:3px 0 0;color:var(--ink);font-family:var(--serif);font-size:22px;line-height:1.1}.lesson-sheet-section{padding:12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--parchment-2)}.lesson-sheet-row{width:100%;display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:10px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--ink);cursor:pointer;text-align:left}.lesson-sheet-row span{color:var(--ink-soft)}.lesson-sheet-row strong{color:var(--ink);font-size:13px}.lesson-sheet-row.danger{padding:12px;border:1px solid rgba(156,63,63,.35);background:#9c3f3f14}.game-feedback-section legend{display:inline-flex;align-items:center;gap:7px;padding:0 4px;color:var(--ink);font-size:13px;font-weight:850}.game-feedback-section{margin:0}@media(min-width:900px){.lesson-sheet-backdrop{align-items:center}}.feedback-card{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.feedback-level-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;min-inline-size:0;margin:0;padding:0;border:0}.feedback-level-list button{min-width:0;min-height:62px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);text-align:left;cursor:pointer}.feedback-level-list button.active{border-color:var(--sage);background:var(--success-bg)}.feedback-level-list span,.feedback-level-list small{display:block;min-width:0}.feedback-level-list span{font-size:13px;font-weight:850;line-height:1.2}.feedback-level-list small{margin-top:4px;color:var(--muted);font-size:11px;line-height:1.25}.focus-card{padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.focus-card strong{display:block;margin-top:10px;color:var(--ink);font-size:14px;line-height:1.25}.focus-card ul{display:grid;gap:7px;margin:10px 0 0;padding-left:18px;color:var(--muted);font-size:13px;line-height:1.35}.speech-card{display:grid;gap:10px;margin-top:12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.speech-card.compact{margin:0;padding:0;border:0;background:transparent}.speech-card.compact .text-button{min-height:30px;border:1px solid var(--line);border-radius:999px;background:var(--parchment)}.speech-card.compact.active .speech-toggle-button{border-color:var(--sage);background:var(--success-bg)}.narration-tutor{display:block;margin-top:8px;color:var(--muted);font-size:12px;font-weight:800}.narration-switch{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}.narration-switch button{min-height:32px;border:1px solid var(--line);border-radius:7px;background:var(--paper);color:var(--muted);cursor:pointer;font-size:12px;font-weight:850}.narration-switch button.active,.narration-switch button:hover{border-color:var(--sage);color:var(--sage-dark);background:var(--success-bg)}.speech-card.active{border-color:var(--sage)}.speech-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.speech-controls{display:grid;gap:9px}.speech-controls label{display:grid;gap:5px}.speech-controls span{color:var(--muted);font-size:11px;font-weight:850;text-transform:uppercase}.speech-controls select{width:100%;min-height:34px;padding:0 9px;border:1px solid var(--line);border-radius:7px;background:var(--paper);color:var(--ink);font:inherit;font-size:13px;font-weight:750}.speech-controls input[type=range]{width:100%;accent-color:var(--sage-dark)}.speech-controls .speech-option{display:flex;align-items:center;gap:8px}.speech-option input{width:16px;height:16px;accent-color:var(--sage-dark)}.speech-option span{text-transform:none}.speech-status{display:block}.speech-status.ready{color:var(--sage-dark);font-weight:850}.speech-status.checking{color:var(--amber)}.speech-status.unavailable{color:var(--danger)}.speech-card .text-button:disabled,.speech-controls select:disabled,.speech-controls input:disabled{opacity:.45;cursor:not-allowed}@media(max-width:700px){.lesson-flow-actions{width:100%;padding-top:4px;padding-left:0;border-top:1px solid var(--line);border-left:0}.lesson-flow-button{flex:1 1 0;min-width:0}}.lesson-rail{color:var(--rail-item);padding:24px 18px;display:flex;flex-direction:column;gap:26px;min-height:100vh;border-right:1px solid rgba(255,255,255,.08)}.brand-block{display:flex;align-items:center;gap:14px;min-width:0}.brand-mark{width:44px;height:44px;display:grid;place-items:center;border-radius:8px;background:#eef7ef;color:var(--charcoal);font-size:29px;box-shadow:inset 0 -4px #2f5b4624}.app-shell[data-theme=dark] .brand-mark{background:#dfe9df;color:#0b100f}.brand-block h1{margin:0;font-size:22px;line-height:1.05;letter-spacing:0}.brand-block p{margin:4px 0 0;color:var(--rail-muted);font-size:12px;line-height:1.35}.progress-summary{padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0d}.progress-summary span,.progress-summary strong{display:block}.progress-summary span{color:var(--rail-heading);font-size:11px;font-weight:850;text-transform:uppercase}.progress-summary strong{margin-top:5px;color:var(--rail-item);font-size:13px}.lesson-rail-tools{display:grid;gap:9px}.lesson-search{min-height:38px;display:flex;align-items:center;gap:8px;padding:0 11px;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--rail-muted);background:#ffffff0f}.lesson-search input{width:100%;min-width:0;border:0;outline:0;color:var(--rail-item);background:transparent;font:inherit;font-size:12px}.lesson-search input::placeholder{color:var(--rail-sub)}.lesson-level-filter{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.lesson-level-filter button{min-height:32px;padding:0 8px;border:1px solid rgba(255,255,255,.11);border-radius:7px;color:var(--rail-muted);background:#ffffff0a;cursor:pointer;font-size:11px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-level-filter button.active,.lesson-level-filter button:hover{color:#102018;background:var(--amber);border-color:var(--amber)}.lesson-nav{display:flex;flex-direction:column;gap:20px;overflow:auto;padding-right:4px;overscroll-behavior:contain;scrollbar-width:thin}.rail-heading{color:var(--rail-heading);font-size:11px;text-transform:uppercase;letter-spacing:0;font-weight:800;margin:0 0 8px 6px}.lesson-button{width:100%;min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 10px 10px 12px;color:var(--rail-item);background:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;text-align:left}.lesson-button:hover,.lesson-button.active{background:#ffffff12;border-color:#ffffff1c}.lesson-button.active{box-shadow:inset 3px 0 0 var(--amber)}.lesson-button.locked{opacity:.55;cursor:not-allowed}.lesson-button.locked:hover{background:transparent;border-color:transparent}.lesson-button strong,.lesson-button small{display:block}.lesson-button strong{font-size:13px;line-height:1.25;font-weight:750}.lesson-button small{color:var(--rail-sub);margin-top:4px;font-size:11px}.lesson-empty{margin:0;padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--rail-muted);background:#ffffff0a;font-size:12px;line-height:1.4}@media(max-width:860px){.lesson-rail{position:sticky;top:0;z-index:20;min-height:0;max-height:44vh;overflow:auto;background:var(--charcoal);padding:12px;gap:12px;border-right:0;border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 16px 28px #0a100e38;overscroll-behavior:contain}.brand-block{gap:10px}.brand-mark{width:38px;height:38px;font-size:24px}.brand-block h1{font-size:19px}.brand-block p{display:none}.progress-summary{padding:10px}.lesson-nav{display:flex;flex-direction:row;gap:12px;overflow-x:auto;overflow-y:hidden;padding:0 0 4px}.lesson-nav section{flex:0 0 min(72vw,260px)}.lesson-button{min-height:54px}.lesson-button strong{font-size:12px}}@media(max-width:560px){.lesson-rail{max-height:40vh}.lesson-nav section{flex-basis:min(82vw,250px)}}.play-layout{display:grid;grid-template-columns:minmax(440px,1fr) 360px;grid-template-rows:minmax(0,1fr);gap:16px;min-height:0}.game-panel{min-height:0}.play-setup-page{height:100%;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-template-rows:minmax(0,1fr) auto;gap:14px;overflow:hidden}.play-setup-panel{min-width:0;display:grid;gap:12px;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.play-setup-page>.coach-card{grid-row:span 2;align-self:start;max-height:100%;overflow:visible}.play-setup-heading span{display:block;color:var(--muted);font-size:11px;font-weight:900;line-height:1.2;text-transform:uppercase}.play-setup-heading h2{margin:2px 0 0;color:var(--ink);font-family:var(--serif);font-size:17px;line-height:1.2}.play-setup-heading p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.compact-game-settings-button{display:none}.play-setup-heading{position:relative}.play-setup-heading .compact-game-settings-button{position:absolute;top:0;right:0;width:36px;height:36px;padding:0}.setup-options-panel{align-content:start;gap:14px}.setup-control-group{display:grid;gap:8px}.setup-control-row{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0;min-inline-size:0;padding:0;border:0;margin:0}.setup-control-row-inner{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;min-width:0}.setup-control-row>.panel-title,.setup-control-row-inner>.panel-title{min-width:0;margin:0}.setup-start-button{width:100%}.side-inline-control{display:grid;grid-template-columns:repeat(3,32px);gap:4px;flex:0 0 auto}.side-chip{width:32px;height:32px;padding:0;border:1px solid var(--line);border-radius:7px;color:var(--ink);cursor:pointer}.side-chip-white{background:var(--piece-light-bg);color:var(--piece-light-text)}.side-chip-black{background:var(--piece-dark-bg);color:var(--piece-dark-text)}.side-chip-random{background:linear-gradient(135deg,var(--piece-light-bg) 0 49%,var(--piece-dark-bg) 51% 100%);color:var(--paper);text-shadow:0 1px 2px rgba(0,0,0,.75),0 0 1px var(--piece-dark-text)}.side-chip.active{border-color:var(--brass-deep);box-shadow:inset 0 0 0 2px var(--brass)}.game-action-row{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:8px;padding:0;margin:0;border:0}.game-action-row .ghost-button{min-height:46px;flex-direction:column;gap:3px;padding:5px 4px;font-size:11px}.game-action-row>button{min-width:0}.game-action-row .game-review-cta{min-height:46px;flex-direction:column;gap:3px;padding:5px 4px;font-size:11px;line-height:1.1;text-align:center;white-space:normal}.concept-proof-banner,.concept-hint-card{width:100%;border:1px solid var(--success-line);border-radius:8px;background:var(--success-bg)}.concept-proof-banner{display:flex;align-items:center;gap:9px;padding:11px 12px;color:var(--sage-dark);font-size:13px;font-weight:850}.concept-hint-card{display:grid;gap:8px;padding:12px}.concept-hint-card span,.concept-hint-card strong{display:block}.concept-hint-card span{color:var(--sage-dark);font-size:11px;font-weight:900;text-transform:uppercase}.concept-hint-card strong{margin-top:3px;color:var(--ink);font-size:14px}.concept-hint-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.4}.concept-hint-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding-top:8px;border-top:1px solid var(--line)}.concept-hint-card .text-button{justify-self:flex-start}.tutor-list{display:grid;gap:10px}.tutor-card{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:68px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);cursor:pointer;text-align:left}.tutor-card.active{border-color:var(--sage);background:var(--success-bg)}.tutor-card strong,.tutor-card small{display:block}.tutor-card strong{font-size:14px}.tutor-card small{margin-top:4px;color:var(--muted);font-size:12px}.tutor-card em{flex:0 0 auto;color:var(--sage-dark);font-style:normal;font-size:12px;font-weight:850}.move-log{padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.move-log ol,.move-log p{margin:12px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.move-log ol{max-height:180px;overflow:auto;padding-left:20px}.move-log li+li{margin-top:4px}.setup-tutor-list{grid-template-columns:repeat(auto-fit,minmax(132px,1fr));min-height:0;overflow:visible}.setup-tutor-list .tutor-card{min-height:58px;align-items:stretch;flex-direction:column;justify-content:center;gap:2px;padding:7px 10px}.setup-tutor-summary{display:grid;gap:1px}.setup-tutor-list .tutor-card em{margin-top:2px}.compact-tutor-blurb{display:none}.difficulty-control-group{position:relative}.difficulty-select-button{display:flex;align-items:center;justify-content:space-between;gap:12px;flex:0 0 min(220px,64%);min-width:0;min-height:42px;padding:6px 9px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);cursor:pointer;text-align:left}.difficulty-select-button span,.difficulty-select-button strong,.difficulty-select-button small{display:block}.difficulty-select-button strong{overflow:hidden;font-size:12px;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.difficulty-select-button small{margin-top:2px;color:var(--muted);font-size:10px;font-weight:800}.difficulty-select-button em{flex:0 0 auto;color:var(--sage-dark);font-size:12px;font-style:normal;font-weight:900}.difficulty-picker-backdrop{position:fixed;inset:0;z-index:80;background:#18231f61;cursor:default}.difficulty-sheet{position:fixed;inset:0;z-index:90;display:flex;flex-direction:column;gap:12px;width:100vw;height:100dvh;min-height:0;padding:14px 18px 16px;background:linear-gradient(180deg,rgba(255,255,255,.26),transparent 34%),var(--parchment);color:var(--ink)}.difficulty-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex:0 0 auto}.difficulty-sheet-header span{color:var(--muted);font-size:11px;font-weight:900;line-height:1.2;text-transform:uppercase}.difficulty-sheet-header h3{margin:2px 0 0;color:var(--ink);font-family:var(--serif);font-size:21px;line-height:1.15}.difficulty-picker{flex:1 1 auto;display:grid;grid-template-columns:minmax(0,1fr);align-content:start;gap:6px;width:100%;min-height:0;overflow:auto;padding:0;margin:0;border:0;background:transparent;min-inline-size:0}.difficulty-picker button{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;min-height:48px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);cursor:pointer;text-align:left}.difficulty-picker button.active{border-color:var(--brass-deep);background:var(--brass-soft);box-shadow:inset 0 0 0 2px #b8860b33}.difficulty-picker strong,.difficulty-picker small,.difficulty-picker em{display:block}.difficulty-picker strong{overflow:hidden;font-size:13px;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.difficulty-picker small{margin-top:2px;color:var(--muted);font-size:11px;font-weight:800}.difficulty-picker em{flex:0 0 auto;color:var(--sage-dark);font-size:11px;font-style:normal;font-weight:900;line-height:1}@media(max-width:640px){.setup-tutor-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.setup-tutor-list .tutor-card{min-height:56px;padding:7px}.difficulty-picker{grid-template-columns:minmax(0,1fr)}}@media(max-width:1180px){.play-setup-page{display:flex;flex-direction:column}.play-setup-page>.coach-card{flex:0 1 auto;grid-row:auto}.play-setup-page .play-setup-panel:first-child{flex:0 0 auto;min-height:0}.setup-options-panel{flex:0 0 auto}}@media(max-width:640px){.play-setup-page{height:auto;max-height:none;min-height:100%;gap:8px;overflow:visible}.play-setup-panel{padding:11px}}@media(max-width:700px)and (max-height:760px),(max-width:700px)and (min-aspect-ratio:9 / 18){.game-action-row .compact-game-settings-button,.play-setup-heading .compact-game-settings-button{display:inline-flex}.play-setup-page>.coach-card{display:none}.compact-tutor-blurb{display:grid;gap:7px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.compact-tutor-blurb strong,.compact-tutor-blurb span{display:block}.compact-tutor-blurb strong{color:var(--ink);font-size:13px;line-height:1.15}.compact-tutor-blurb span{margin-top:2px;color:var(--muted);font-size:11px;font-weight:850;line-height:1.2;text-transform:uppercase}.compact-tutor-blurb p{margin:0;overflow:hidden;color:var(--muted);display:-webkit-box;font-size:12px;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:2}}.review-workspace{min-height:0}.review-mode-tabs{flex:0 0 auto}.review-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.review-summary-stat{min-height:78px;display:grid;align-content:center;gap:5px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--muted)}.review-summary-stat svg{color:var(--sage-dark)}.review-summary-stat span,.review-summary-stat strong{display:block}.review-summary-stat span{font-size:11px;font-weight:850;text-transform:uppercase}.review-summary-stat strong{color:var(--ink);font-size:21px;line-height:1}.review-workspace.practice-active .review-summary-grid,.review-workspace.games-active .review-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.review-workspace.practice-active .review-summary-stat,.review-workspace.games-active .review-summary-stat{min-height:64px;padding:9px}.review-game-list{display:grid;gap:8px}.game-card{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px 10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);font:inherit;text-align:left;cursor:pointer}.game-card:hover{border-color:var(--sage)}.game-card span,.game-card strong,.game-card small{display:block}.game-card strong{font-size:13px}.game-card small{color:var(--muted);font-size:12px;font-weight:750;line-height:1.35}.game-card>small,.game-card-stripe{grid-column:1 / -1}.game-card em{color:var(--sage-dark);font-size:11px;font-style:normal;font-weight:900;text-transform:uppercase}.game-card-stripe{display:grid;grid-template-columns:repeat(auto-fit,minmax(10px,1fr));gap:3px}.game-card-stripe span{height:6px;border-radius:999px;background:var(--line-strong)}.game-card-stripe .proof{background:var(--sage-dark)}.saved-game-review-detail{display:grid;gap:10px}.saved-game-review-detail>.text-button{justify-self:start}.review-focus-row{background:linear-gradient(135deg,rgba(201,170,91,.14),transparent 72%),var(--surface-soft)}.review-practice-callout{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:16px;padding:14px;border:1px solid var(--success-line);border-radius:8px;background:linear-gradient(135deg,rgba(95,139,114,.16),transparent 72%),var(--surface-soft)}.review-practice-callout strong,.review-practice-callout span{display:block}.review-practice-callout strong{color:var(--ink);font-size:14px}.review-practice-callout>div>span{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.review-practice-preview{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.review-practice-preview span{min-height:24px;display:inline-flex;align-items:center;padding:0 8px;border:1px solid var(--line);border-radius:999px;background:var(--paper);color:var(--sage-dark);font-size:11px;font-weight:850}.review-miss-line strong{color:var(--amber)}.review-practice-context{width:100%;display:flex;gap:8px;flex-wrap:wrap}.review-practice-context span{min-height:26px;display:inline-flex;align-items:center;padding:0 9px;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--muted);font-size:12px;font-weight:850}.review-position-note{width:100%;padding:12px;border:1px solid var(--success-line);border-radius:8px;background:var(--success-bg)}.review-position-note strong,.review-position-note span{display:block}.review-position-note strong{color:var(--ink);font-size:13px}.review-position-note span{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.review-practice-feedback{width:100%}.review-refresh-button{width:100%;margin-top:14px}.review-source-list{display:grid;gap:8px;margin-top:14px}.review-source-row{min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--ink);text-align:left;cursor:pointer}.review-source-row.active{border-color:var(--sage);box-shadow:inset 3px 0 0 var(--sage)}.review-source-row strong,.review-source-row small{display:block}.review-source-row small{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.3}.review-source-row em{flex:0 0 auto;color:var(--sage-dark);font-size:12px;font-style:normal;font-weight:900;text-transform:uppercase}.game-review{padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--paper)}.game-review.running{border-color:var(--sage)}.game-review.error{border-color:#9a3f358c}.review-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.review-header strong,.review-header span{display:block}.review-header strong{display:inline-flex;align-items:center;gap:7px;color:var(--ink);font-size:14px}.review-header span{margin-top:4px;color:var(--muted);font-size:12px;font-weight:800}.game-review p{margin:12px 0 0;color:var(--muted);font-size:13px;line-height:1.45}.review-progress-wrap{display:grid;gap:6px;margin-top:10px}.review-progress{width:100%;height:8px;overflow:hidden;border-radius:999px;background:var(--line)}.review-progress span{display:block;height:100%;border-radius:inherit;background:var(--sage);transition:width .18s ease}.review-progress-wrap small{color:var(--muted);font-size:12px;font-weight:800}.move-scrubber{display:grid;gap:8px;margin-top:12px}.move-scrubber-header{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.move-scrubber-header strong{color:var(--ink);font-size:13px}.move-scrubber-header span,.move-scrubber p{color:var(--muted);font-size:12px;font-weight:800;line-height:1.35}.move-scrubber p{margin:0}.move-scrubber-track{display:grid;grid-template-columns:repeat(auto-fit,minmax(58px,1fr));gap:6px}.move-scrubber-step{--review-tone: var(--muted);position:relative;min-width:0;min-height:50px;overflow:hidden;display:grid;gap:2px;justify-items:start;padding:9px 8px 7px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--ink);text-align:left;cursor:pointer}.move-scrubber-step:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--review-tone)}.move-scrubber-step.active{border-color:var(--review-tone);background:var(--paper)}.move-scrubber-step.best,.move-scrubber-step.good{--review-tone: var(--sage-dark)}.move-scrubber-step.inaccuracy{--review-tone: var(--amber)}.move-scrubber-step.mistake,.move-scrubber-step.blunder{--review-tone: var(--danger)}.move-scrubber-step span,.move-scrubber-step strong,.move-scrubber-step small{position:relative;z-index:1;max-width:100%}.move-scrubber-step span{color:var(--muted);font-size:11px;font-weight:900}.move-scrubber-step strong{overflow:hidden;color:var(--ink);font-size:13px;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.move-scrubber-step small{color:var(--review-tone);font-size:10px;font-weight:900;line-height:1.1;text-transform:uppercase}.engine-line{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 8px;border:1px solid var(--line);border-radius:8px;background:var(--paper)}.engine-line code{min-width:0;overflow:hidden;color:var(--ink);font-family:var(--mono);font-size:12px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.engine-line span{flex:0 0 auto;color:var(--sage-dark);font-family:var(--mono);font-size:11px;font-weight:900}.review-list{display:grid;gap:8px;max-height:300px;overflow:auto;margin:12px 0 0;padding:0;list-style:none}.review-row{display:grid;gap:7px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.review-row.best{border-color:var(--success-line);background:var(--success-bg)}.review-row.mistake,.review-row.blunder{border-color:#9a3f3573}.review-row-top,.review-metrics{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.review-row-top span{color:var(--ink);font-size:13px;font-weight:850}.review-row-top strong{color:var(--sage-dark);font-size:12px;text-transform:uppercase;letter-spacing:0}.review-metrics span,.review-row small{color:var(--muted);font-size:12px;line-height:1.35}.review-narrate-button{justify-self:start}.review-recommendations{display:grid;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.review-recommendations>strong{color:var(--ink);font-size:13px}.recommendation-chip{width:100%;display:grid;gap:4px;padding:9px;border:1px solid rgba(201,170,91,.35);border-radius:8px;background:linear-gradient(135deg,rgba(201,170,91,.13),transparent 68%),var(--surface-soft);color:var(--ink);font:inherit;text-align:left}button.recommendation-chip{cursor:pointer}button.recommendation-chip:hover{border-color:var(--amber)}.recommendation-chip span,.recommendation-chip small{display:block}.recommendation-chip span{color:var(--ink);font-size:13px;font-weight:850}.recommendation-chip small{color:var(--muted);font-size:12px;line-height:1.35}.review-practice-save-note{display:block;color:var(--sage-dark);font-size:12px;font-weight:850;line-height:1.35}.review-narration{display:grid;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.review-narration .narration-view{color:var(--ink);font-size:13px;line-height:1.45}.review-board-preview{display:grid;justify-items:center}.review-board-preview .board-wrap{--board-coordinate-gutter: 12px;--board-frame-width: 7px;--board-label-font-size: 10px;width:min(100%,390px);min-width:0}.review-board-preview .board-grid{box-shadow:0 10px 18px #12191729}.review-board-preview .piece{width:clamp(24px,76%,42px);height:clamp(24px,76%,42px)}.review-narration-select{display:grid;gap:5px}.review-narration-select span{color:var(--muted);font-size:11px;font-weight:850;text-transform:uppercase}.review-narration-select select{min-width:0;width:100%;padding:9px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);font:inherit;font-size:13px;font-weight:750}.saved-review-card{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.saved-review-actions,.saved-review-item{display:flex;align-items:center;justify-content:space-between;gap:10px}.saved-review-actions strong,.saved-review-actions span{display:block}.saved-review-actions strong{color:var(--ink);font-size:14px}.saved-review-actions span,.saved-review-empty{color:var(--muted);font-size:12px;font-weight:750}.saved-review-list{display:grid;gap:8px}.saved-review-item{width:100%;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);font:inherit;text-align:left;cursor:pointer}.saved-review-item:hover{border-color:var(--sage)}.saved-review-item span{font-size:13px;font-weight:850}.saved-review-item small{color:var(--muted);font-size:12px;font-weight:750}.saved-review-empty{margin:0;line-height:1.4}@media(max-width:1180px){.review-practice-callout{align-items:stretch;flex-direction:column}.review-practice-callout .primary-button{width:100%}}@media(max-width:560px){.review-summary-grid{grid-template-columns:1fr}.review-mode-tabs{width:100%}.review-mode-tabs button{flex:1 1 0}}.you-page{display:flex;flex-direction:column;gap:22px;padding-top:8px}.you-header h2{font-family:var(--serif);font-size:28px;font-weight:600;margin:0;color:var(--ink)}.you-header{display:flex;align-items:center;gap:14px}.you-avatar{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;background:var(--ink);color:var(--parchment);font-family:var(--serif);font-size:26px;font-weight:600;box-shadow:var(--shadow-1);flex:0 0 auto}.you-header-copy{min-width:0}.you-subtitle{font-family:var(--sans);font-size:13px;color:var(--ink-mute);margin:4px 0 0}.you-section{display:flex;flex-direction:column;gap:10px}.you-section h3{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin:0}.you-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:10px;margin:0}.you-stat-card{min-height:92px;display:flex;flex-direction:column;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2);box-shadow:var(--shadow-1)}.you-stat-card dt{display:flex;align-items:center;gap:7px;color:var(--ink-mute);font-family:var(--sans);font-size:12px;font-weight:700}.you-stat-card dd{margin:0;color:var(--ink);font-family:var(--serif);font-size:28px;font-weight:600;line-height:1}.you-row-button{display:grid;grid-template-columns:24px minmax(0,1fr) auto;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2);color:var(--ink);font-family:var(--sans);font-size:14px;cursor:pointer;text-align:left;transition:background .12s ease}.you-row-button:hover:not(:disabled),.you-row-button:focus-visible:not(:disabled){background:var(--parchment-3);outline:none}.you-row-button:disabled{opacity:.55;cursor:not-allowed}.you-row-label{font-weight:600}.you-row-value{color:var(--ink-mute);font-size:13px}.you-board-picker{border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2);padding:12px 16px 14px;margin:0}.you-board-picker legend{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink);padding:0 6px}.you-board-swatches{display:flex;gap:10px;margin-top:8px}.you-board-swatch{width:44px;height:44px;border:2px solid transparent;border-radius:10px;background:transparent;padding:4px;cursor:pointer}.you-board-swatch.active{border-color:var(--brass)}.you-sound-toggle{width:100%;min-height:44px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:0 12px;border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2);color:var(--ink);cursor:pointer;text-align:left}.you-sound-toggle.active{border-color:var(--sage);background:var(--success-bg)}.you-sound-toggle span{min-width:0;font-size:13px;font-weight:750}.you-sound-toggle strong{color:var(--sage-dark);font-size:12px;font-weight:900}.you-sync-pill{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:var(--r-md);border:1px solid var(--parchment-3);background:var(--parchment-2);font-family:var(--sans);font-size:13px}.you-sync-pill.loading,.you-sync-pill.saving{border-color:var(--brass-light)}.you-sync-pill.saved{border-color:var(--felt)}.you-sync-pill.local,.you-sync-pill.error{border-color:var(--burgundy);color:var(--burgundy)}.you-account-card{display:grid;gap:10px;padding:14px 16px;border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2)}.you-account-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;font-family:var(--sans);font-size:13px}.you-account-summary strong{min-width:0;color:var(--ink);overflow-wrap:anywhere}.account-mode-tabs{width:100%;margin:0}.you-account-field{display:flex;flex-direction:column;gap:7px;color:var(--ink);font-family:var(--sans);font-size:13px;font-weight:700}.you-account-field input{width:100%;min-height:44px;border:1px solid var(--walnut-soft);border-radius:var(--r-md);background:var(--parchment);color:var(--ink);padding:10px 12px;font:inherit}.you-data-tools{display:flex;flex-direction:column;gap:10px}.you-data-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.you-data-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:12px 16px;border:1px solid var(--parchment-3);border-radius:var(--r-md);background:var(--parchment-2);color:var(--ink);font-family:var(--sans);font-size:14px;font-weight:700;cursor:pointer;transition:background .12s ease}.you-data-button:hover:not(:disabled),.you-data-button:focus-visible:not(:disabled){background:var(--parchment-3);outline:none}.you-data-button:disabled{cursor:progress;opacity:.65}.you-data-button.danger{border-color:#9c3f3f59;background:#9c3f3f14;color:var(--burgundy)}.you-data-button.danger:hover:not(:disabled),.you-data-button.danger:focus-visible:not(:disabled){background:#9c3f3f24}.you-data-status{margin:0;font-family:var(--sans);font-size:13px;color:var(--ink-mute)}.you-data-status.ok{color:var(--felt)}.you-data-status.error{color:var(--burgundy)}.you-reset-sheet{gap:16px}.you-reset-copy{margin:0;color:var(--ink-soft);font-family:var(--sans);font-size:14px;line-height:1.5}.you-reset-confirm{display:flex;flex-direction:column;gap:8px;font-family:var(--sans);font-size:13px;font-weight:700;color:var(--ink)}.you-reset-confirm input{width:100%;min-height:44px;border:1px solid var(--walnut-soft);border-radius:var(--r-md);background:var(--parchment-2);color:var(--ink);padding:10px 12px;font:inherit}.you-reset-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.you-goal-sheet{gap:16px}.you-goal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.you-goal-grid label{display:flex;flex-direction:column;gap:8px;color:var(--ink);font-family:var(--sans);font-size:13px;font-weight:700}.you-goal-grid input{width:100%;min-height:44px;border:1px solid var(--walnut-soft);border-radius:var(--r-md);background:var(--parchment-2);color:var(--ink);padding:10px 12px;font:inherit}.you-voice-sheet{gap:16px}.you-voice-tutor{display:flex;flex-direction:column;gap:8px;color:var(--ink);font-family:var(--sans);font-size:13px;font-weight:700}.you-voice-tutor select{width:100%;min-height:44px;border:1px solid var(--walnut-soft);border-radius:var(--r-md);background:var(--parchment-2);color:var(--ink);padding:10px 12px;font:inherit}.you-appearance-sheet{gap:16px}.you-section-stub{border:1px dashed var(--parchment-3);border-radius:var(--r-md);padding:14px 16px;background:transparent;color:var(--ink-soft);font-size:13px}.you-section-stub p{margin:6px 0 0;font-family:var(--sans);line-height:1.55}@media(max-width:599px){.you-page{gap:18px}.you-stat-card{min-height:84px;gap:10px;padding:12px 14px}.you-stat-card dd{font-size:24px}.you-goal-grid{grid-template-columns:1fr}}.workspace{min-width:0;padding:22px;display:flex;flex-direction:column;gap:16px}.workspace-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:2px 0 10px}.workspace-header h2{margin:6px 0 5px;font-size:clamp(25px,3vw,38px);line-height:1.02;letter-spacing:0}.workspace-header p{margin:0;color:var(--muted);font-size:14px;line-height:1.45;max-width:760px}.header-meta{display:flex;align-items:center;gap:9px;color:var(--sage-dark);font-size:12px;font-weight:800}.header-meta span+span:before{content:"";display:inline-block;width:4px;height:4px;margin:0 9px 2px 0;border-radius:50%;background:var(--line-strong)}.header-actions,.demo-actions,.board-toolbar,.puzzle-topline{display:flex;align-items:center}.header-actions{justify-content:flex-end;gap:10px;flex-wrap:wrap}.workspace-header>div:first-child{min-width:min(100%,360px)}.learn-layout{display:grid;grid-template-columns:minmax(440px,1fr) 380px;grid-template-rows:minmax(0,1fr) auto;gap:16px;min-height:0}.dashboard-layout{display:grid;gap:16px}.dashboard-hero,.mastery-panel,.lesson-browser,.stat-tile,.lesson-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.dashboard-hero{min-height:190px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px;background:linear-gradient(135deg,rgba(95,139,114,.14),transparent 48%),var(--paper)}.dashboard-hero span,.browser-toolbar span,.lesson-card span,.stat-tile span{display:block;color:var(--sage-dark);font-size:12px;font-weight:900;text-transform:uppercase}.dashboard-hero h3{max-width:680px;margin:8px 0;color:var(--ink);font-size:clamp(26px,3.2vw,42px);line-height:1.04}.dashboard-hero p{max-width:640px;margin:0;color:var(--muted);font-size:15px;line-height:1.5}.stat-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.stat-tile{min-height:112px;padding:16px}.stat-tile strong{display:block;margin-top:12px;color:var(--ink);font-size:clamp(22px,2.4vw,30px);line-height:1.1}.mastery-panel,.lesson-browser{padding:18px}.mastery-list{display:grid;gap:12px;margin-top:14px}.progression-copy,.empty-proof-copy,.gate-note{margin:12px 0 0;color:var(--muted);font-size:13px;line-height:1.45}.proof-debt-list{display:grid;gap:8px;margin-top:14px}.proof-debt-row{width:100%;min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--ink);cursor:pointer;text-align:left}.proof-debt-row:hover{border-color:var(--sage)}.proof-debt-row strong,.proof-debt-row small{display:block}.proof-debt-row small{margin-top:4px;color:var(--muted);font-size:12px}.proof-debt-row em{flex:0 0 auto;color:var(--sage-dark);font-style:normal;font-size:14px;font-weight:900}.backup-tools{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:16px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.backup-tools strong,.backup-tools span{display:block}.backup-tools strong{color:var(--ink);font-size:13px}.backup-tools span,.backup-message{color:var(--muted);font-size:12px;line-height:1.35}.backup-tools span{margin-top:3px}.backup-actions{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto}.backup-message{display:block;margin-top:9px}.mastery-row{display:grid;grid-template-columns:110px minmax(0,1fr) 46px;gap:12px;align-items:center;color:var(--muted);font-size:13px;font-weight:800}.mastery-row .progress-bar{margin:0;background:var(--surface-soft)}.mastery-row strong{color:var(--ink);text-align:right}.browser-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.browser-toolbar strong{display:block;margin-top:4px;color:var(--ink);font-size:18px}.filter-row{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.filter-row button{min-height:32px;padding:0 10px;border:1px solid var(--line);border-radius:999px;background:var(--paper);color:var(--muted);cursor:pointer;font-size:12px;font-weight:850}.filter-row button.active{border-color:var(--sage);background:var(--success-bg);color:var(--sage-dark)}.lesson-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.lesson-card{min-height:260px;display:flex;flex-direction:column;justify-content:space-between;gap:14px;padding:16px;box-shadow:none}.lesson-card.locked{opacity:.72}.lesson-card h4{margin:8px 0;color:var(--ink);font-size:18px;line-height:1.15}.lesson-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}.lesson-card-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.lesson-card-footer .progress-bar{margin:0;background:var(--surface-soft)}.lesson-card-footer strong{color:var(--sage-dark);font-size:12px}.lesson-proof-line{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px;font-weight:850}.lesson-proof-line strong{color:var(--sage-dark)}.lesson-card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.lesson-card-actions .ghost-button{width:100%}.coach-panel,.tutor-panel{background:var(--paper);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.main-board-panel,.game-panel{min-width:0;display:flex;flex-direction:column;align-items:center;gap:14px}.board-toolbar{width:100%;justify-content:space-between;gap:14px}.board-toolbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.board-toolbar span,.puzzle-topline span{color:var(--muted);font-size:12px;line-height:1.2;font-weight:800;text-transform:uppercase;letter-spacing:0}.board-toolbar strong{display:block;margin-top:4px;color:var(--ink);font-size:17px;line-height:1.25}.demo-actions{width:100%;justify-content:space-between;gap:14px;padding:12px 14px;background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;flex-wrap:wrap}.demo-button-row{display:inline-flex;align-items:center;gap:9px;flex-wrap:wrap}.demo-actions p{margin:0;color:var(--muted);font-size:14px;line-height:1.45;max-width:720px}.demo-actions small{flex-basis:100%;color:var(--sage-dark);font-size:13px;font-weight:800}.stage-map{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.stage-pill{min-height:42px;display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--muted);cursor:pointer;font-size:12px;font-weight:800;text-align:left}.stage-pill span{flex:0 0 auto;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:var(--paper);color:var(--sage-dark);border:1px solid var(--line)}.stage-pill.active{border-color:var(--sage);color:var(--ink)}.stage-pill.complete span{background:var(--sage-dark);color:var(--paper)}.stage-stepper{width:100%;display:grid;grid-template-columns:minmax(0,1fr);align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--line);border-radius:18px;background:var(--surface-soft)}.stage-stepper[data-compact=true]{grid-template-columns:minmax(0,1fr) auto;border-radius:999px}.stage-stepper-label{min-width:0}.stage-stepper-label span{display:block;color:var(--muted);font-size:11px;font-weight:850;line-height:1.2;text-transform:uppercase}.stage-stepper-label strong{display:block;margin-top:2px;overflow:hidden;color:var(--ink);font-family:var(--serif);font-size:16px;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.stage-stepper-label small{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:750;line-height:1.2}.stage-stepper-progress-wrap{display:inline-flex;align-items:center;justify-content:flex-start;gap:10px;min-width:0}.stage-stepper[data-compact=true] .stage-stepper-progress-wrap{justify-content:flex-end}.stage-stepper-progress{width:190px;height:10px;overflow:hidden;border:1px solid var(--walnut-soft);border-radius:999px;background:var(--paper)}.stage-stepper-progress span{height:100%;display:block;border-radius:inherit;background:var(--felt)}.stage-stepper-dots{display:inline-flex;flex-wrap:wrap;justify-content:flex-start;gap:6px;max-width:100%;padding:0;margin:0;list-style:none}.stage-stepper-dot{width:12px;height:12px;border:1px solid var(--walnut-soft);border-radius:50%;background:var(--parchment);cursor:pointer}.stage-stepper-dot[data-complete=true]{background:var(--felt);border-color:var(--felt-deep)}.stage-stepper-dot[data-active=true]{background:var(--brass);border-color:var(--brass-deep);box-shadow:0 0 0 4px #c997462e}.active-surface-kicker{width:100%;min-height:74px;display:grid;grid-template-rows:14px minmax(20px,auto) 14px;align-content:center;gap:5px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.active-surface-kicker span,.active-surface-kicker small{display:block;color:var(--muted);font-size:11px;font-weight:850;line-height:14px;text-transform:uppercase}.active-surface-kicker strong{display:block;overflow:hidden;color:var(--ink);font-family:var(--serif);font-size:17px;line-height:20px;text-overflow:ellipsis;white-space:nowrap}.coach-panel,.tutor-panel{padding:18px;display:flex;flex-direction:column;gap:16px;min-width:0}.panel-title{display:flex;align-items:center;gap:8px;color:var(--ink);font-size:14px;line-height:1.2;font-weight:850}.goal-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.goal-list li{display:grid;grid-template-columns:18px 1fr;gap:8px;color:var(--muted);font-size:13px;line-height:1.35}.goal-list svg{color:var(--sage)}.mini-divider{height:1px;background:var(--line)}.ladder-stats{display:flex;gap:8px;flex-wrap:wrap}.ladder-stats span{min-height:28px;display:inline-flex;align-items:center;gap:6px;padding:0 9px;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--muted);font-size:12px;font-weight:800}.puzzle-board-shell{display:flex;flex-direction:column;gap:10px}.puzzle-topline{justify-content:space-between}.puzzle-feedback{padding:13px;border:1px solid var(--line);border-radius:8px;background:var(--feedback-bg)}.engine-panel{padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.engine-panel.loading{border-color:var(--amber)}.engine-panel.ready{border-color:var(--success-line);background:var(--success-bg)}.engine-panel.error{border-color:var(--danger)}.engine-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.engine-header strong,.engine-header span{display:flex;align-items:center}.engine-header strong{gap:7px;color:var(--ink);font-size:13px;line-height:1.2}.engine-header span{margin-top:4px;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase}.engine-panel p{margin:9px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.engine-analysis{display:grid;gap:9px;margin-top:10px}.engine-analysis .narration-view{color:var(--ink);font-size:13px;line-height:1.45}.engine-board-preview{display:grid;justify-items:center}.engine-details{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}.engine-details span{min-height:26px;display:inline-flex;align-items:center;padding:0 8px;border:1px solid var(--line);border-radius:999px;background:var(--paper);color:var(--sage-dark);font-size:11px;font-weight:850}.puzzle-feedback.correct{border-color:var(--success-line);background:var(--success-bg)}.puzzle-feedback-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.puzzle-feedback-title span{min-height:22px;display:inline-flex;align-items:center;padding:0 7px;border:1px solid var(--line);border-radius:999px;background:var(--paper);color:var(--sage-dark);font-size:11px;font-weight:850;text-transform:uppercase}.puzzle-feedback strong{font-size:13px;line-height:1.2}.puzzle-feedback p,.puzzle-feedback small{display:block;margin:7px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.puzzle-tools{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.up-next-row{grid-column:auto;width:100%;display:flex;flex-direction:column;gap:10px;min-width:0}.up-next-row h3{margin:0;color:var(--ink-mute);font-family:var(--serif);font-size:13px;letter-spacing:.12em;text-transform:uppercase}.up-next-scroll{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:2px}.up-next-card{position:relative;flex:0 0 min(210px,78vw);min-height:82px;display:flex;flex-direction:column;gap:5px;padding:12px 36px 12px 13px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--paper);color:var(--ink);text-align:left;cursor:pointer;scroll-snap-align:start;box-shadow:var(--shadow-1)}.up-next-card[data-active=true]{border-color:var(--brass);box-shadow:inset 3px 0 0 var(--brass),var(--shadow-1)}.up-next-card[data-complete=true]{background:var(--success-bg);border-color:var(--success-line)}.up-next-card span,.up-next-card small{color:var(--muted);font-size:11px;font-weight:850;text-transform:uppercase}.up-next-card strong{color:var(--ink);font-family:var(--serif);font-size:15px;line-height:1.2}.up-next-card svg{position:absolute;top:14px;right:12px;color:var(--brass-deep)}.lesson-extras .up-next-scroll{flex-direction:column;overflow-x:visible}.lesson-extras .up-next-card{width:100%;flex-basis:auto}.puzzle-strip{grid-column:1 / -1;min-width:0;display:grid;grid-template-columns:repeat(5,minmax(120px,1fr)) auto;gap:10px;align-items:stretch}.lesson-extras .puzzle-strip{grid-template-columns:1fr}.puzzle-chip,.more-puzzles{min-height:76px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);text-align:left;cursor:pointer;box-shadow:0 10px 24px #18231f14}.puzzle-chip{padding:12px}.puzzle-chip.active{border-color:var(--sage);box-shadow:inset 0 3px 0 var(--sage),0 10px 24px #18231f14}.puzzle-chip span{display:block;color:var(--sage-dark);font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:0}.puzzle-chip strong{display:block;margin-top:7px;font-size:13px;line-height:1.25}.puzzle-chip small{display:inline-flex;margin-top:9px;color:var(--sage-dark);font-size:11px;font-weight:900;text-transform:uppercase}.more-puzzles{min-width:160px;padding:0 18px;justify-content:center;background:var(--charcoal-2);color:var(--paper)}@media(max-width:1180px){.learn-layout,.play-layout{grid-template-columns:1fr}.stat-grid,.lesson-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.coach-panel,.tutor-panel{display:grid;grid-template-columns:1fr 1fr}.puzzle-board-shell{grid-row:span 2}.puzzle-strip{grid-template-columns:repeat(3,minmax(120px,1fr))}.more-puzzles{min-width:0}}@media(max-width:1020px){.workspace-header{align-items:flex-start;flex-direction:column}.header-actions{width:100%;justify-content:flex-start}.sync-pill{min-width:190px}.board-wrap{width:min(72dvh,100%,680px)}}@media(max-width:860px){.workspace{padding:16px}.header-actions{align-items:stretch}.segmented{flex:1 1 320px}.segmented button{flex:1 1 0}.sync-pill{flex:1 1 170px}.board-theme-picker{flex:0 1 auto}.theme-button,.header-actions>.ghost-button{flex:1 1 160px}.dashboard-hero{min-height:0;padding:18px}.stat-tile{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:14px}.stat-tile strong{margin-top:0;text-align:right}.browser-toolbar{display:grid}.backup-tools{align-items:stretch;flex-direction:column}.backup-actions{width:100%}.backup-actions .ghost-button{flex:1 1 0}.filter-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:3px;scrollbar-width:thin}.filter-row button{flex:0 0 auto}.puzzle-strip{display:flex;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.puzzle-chip,.more-puzzles{flex:0 0 min(62vw,220px)}}@media(max-width:640px){.workspace-header h2{font-size:25px}.workspace-header p{font-size:13px}.header-meta{flex-wrap:wrap}.mastery-panel,.lesson-browser,.stat-tile,.lesson-card{border-radius:7px}.lesson-card{min-height:0}.lesson-card-actions{grid-template-columns:1fr}.board-toolbar{align-items:flex-start;flex-direction:column}.board-toolbar-actions,.board-toolbar .ghost-button{width:100%}.feedback-level-list{grid-template-columns:1fr}.board-wrap{--board-frame-width: 7px;--board-label-font-size: 10px;width:100%}.main-board-panel>.board-wrap,.game-panel>.board-wrap{width:100%;max-width:100%;margin-inline:0}.rank-files{width:calc(100% - 8px)}.stage-map{display:flex;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.stage-pill{flex:0 0 min(62vw,190px)}.demo-button-row,.puzzle-tools{width:100%}.demo-button-row .primary-button,.demo-button-row .ghost-button,.puzzle-tools .text-button{flex:1 1 140px}.engine-header,.puzzle-topline,.concept-hint-row,.tutor-card{align-items:flex-start;flex-direction:column}.concept-hint-row{display:flex}.concept-hint-row .text-button{width:100%}.dashboard-hero{align-items:flex-start;flex-direction:column}.stat-grid,.lesson-card-grid{grid-template-columns:1fr}.board-wrap{width:100%;min-width:0}.coach-panel,.tutor-panel,.puzzle-strip{grid-template-columns:1fr}}@media(max-width:560px){.workspace,.coach-panel,.tutor-panel{padding:12px}.header-actions,.demo-actions{align-items:stretch;flex-direction:column}:where(.sync-pill,.segmented,.board-theme-picker,.ghost-button,.primary-button){width:100%}.segmented button{min-width:0;padding:0 8px}.board-theme-picker{justify-content:center}.stat-tile{align-items:flex-start;flex-direction:column;gap:8px}.stat-tile strong{text-align:left}.main-board-panel,.game-panel{gap:12px}.board-wrap{--board-frame-width: 6px}.piece{width:clamp(26px,76%,48px);height:clamp(26px,76%,48px)}}@media(max-width:640px){.app-main[data-mode=lessons],.app-main[data-mode=play],.app-main[data-mode=review]{padding:6px}.app-main[data-mode=lessons] .learn-layout,.app-main[data-mode=play] .play-layout,.app-main[data-mode=review] .review-practice-layout,.app-main[data-mode=lessons] .main-board-panel,.app-main[data-mode=play] .game-panel,.app-main[data-mode=review] .review-practice-board{gap:8px}.app-main[data-mode=lessons] .main-board-panel>.coach-card,.app-main[data-mode=play] .game-panel>.coach-card,.app-main[data-mode=review] .review-practice-board>.coach-card{min-height:0;height:auto;padding:11px}.app-main[data-mode=play] .game-action-row .ghost-button{min-height:40px}.extras-drawer>summary{min-height:40px;padding:8px 10px}.extras-drawer-body{max-height:48dvh;padding:10px}.active-surface-kicker,.stage-stepper{min-height:62px;grid-template-columns:minmax(0,1fr);padding:8px 10px}.stage-stepper-progress-wrap{justify-content:flex-start}.stage-stepper-progress{width:min(190px,100%)}.active-surface-kicker{grid-template-rows:13px minmax(18px,auto) 13px;gap:4px}.active-surface-kicker span,.active-surface-kicker small{line-height:13px}.active-surface-kicker strong{font-size:16px;line-height:18px}}.app-main[data-mode=lessons] .learn-layout,.app-main[data-mode=play] .play-layout,.app-main[data-mode=review] .review-practice-layout{height:100%;max-height:100%;min-height:0;overflow:hidden}.app-main[data-mode=lessons] .main-board-panel,.app-main[data-mode=play] .game-panel,.app-main[data-mode=review] .review-practice-board{--fit-board-size: clamp(260px, calc(100dvh - 350px) , 680px);--fit-board-min: min(260px, 100%);min-height:0;max-height:100%;overflow:hidden}.app-main[data-mode=lessons] .main-board-panel>.board-wrap,.app-main[data-mode=play] .game-panel>.board-wrap,.app-main[data-mode=review] .review-practice-board>.board-wrap{flex:0 1 auto;width:min(100%,var(--fit-board-size));min-width:var(--fit-board-min)}.app-main[data-mode=lessons] .main-board-panel>.coach-card,.app-main[data-mode=play] .game-panel>.coach-card,.app-main[data-mode=review] .review-practice-board>.coach-card{flex:1 1 0;max-height:100%;overflow:hidden}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-body,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-body,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-card-body{min-height:0}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-copy,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-copy,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-card-copy{min-height:0;overflow:auto}@media(max-width:1180px){.app-main[data-mode=lessons] .learn-layout,.app-main[data-mode=play] .play-layout,.app-main[data-mode=review] .review-practice-layout{display:flex;flex-direction:column}.app-main[data-mode=lessons] .main-board-panel,.app-main[data-mode=play] .game-panel,.app-main[data-mode=review] .review-practice-board{flex:1 1 auto}.app-main[data-mode=lessons] .extras-drawer,.app-main[data-mode=play] .extras-drawer,.app-main[data-mode=review] .review-practice-extras{flex:0 0 auto}}@media(max-width:700px){.app-main[data-mode=lessons],.app-main[data-mode=play],.app-main[data-mode=review]{overflow:hidden;overscroll-behavior:contain}.app-main[data-mode=lessons] .learn-layout,.app-main[data-mode=play] .play-layout,.app-main[data-mode=review] .review-practice-layout{height:100%;max-height:100%;min-height:0;overflow:hidden}.app-main[data-mode=lessons] .learn-layout{overflow:hidden}.app-main[data-mode=lessons] .main-board-panel,.app-main[data-mode=play] .game-panel,.app-main[data-mode=review] .review-practice-board{--fit-board-size: clamp(230px, calc(100dvh - 360px) , 100vw);--fit-board-min: min(230px, 100%);flex:1 1 0;max-height:100%;overflow:hidden}.app-main[data-mode=lessons] .main-board-panel>.coach-card,.app-main[data-mode=play] .game-panel>.coach-card,.app-main[data-mode=review] .review-practice-board>.coach-card{flex:1 1 0;min-height:0;overflow:hidden}}@media(max-width:700px)and (max-height:760px),(max-width:700px)and (min-aspect-ratio:9 / 18),(max-height:560px){.app-main[data-mode=lessons],.app-main[data-mode=play],.app-main[data-mode=review]{overflow:hidden}.app-main[data-mode=lessons] .learn-layout,.app-main[data-mode=play] .play-layout,.app-main[data-mode=review] .review-workspace,.app-main[data-mode=review] .review-practice-layout{height:100%;max-height:100%;min-height:0;overflow:hidden}.app-main[data-mode=lessons] .main-board-panel,.app-main[data-mode=play] .game-panel,.app-main[data-mode=review] .review-practice-board{--fit-board-size: clamp(200px, calc(100dvh - 160px) , 480px);--fit-board-min: 0px;flex:1 1 0;max-height:100%;overflow:hidden}.app-main[data-mode=lessons] .main-board-panel>.coach-card,.app-main[data-mode=play] .game-panel>.coach-card,.app-main[data-mode=review] .review-practice-board>.coach-card{flex:1 1 0;grid-template-rows:minmax(0,1fr) auto;align-items:start;min-height:0;max-height:100%;overflow:hidden;gap:8px 10px;padding:10px}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-body,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-body,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-card-body{align-self:stretch;height:100%;min-height:0;grid-column:2;grid-row:1;gap:4px}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-actions,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-actions,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-card-actions{grid-row:2;grid-column:1 / -1;min-width:0}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-copy,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-copy,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-card-copy{min-height:0;flex:1 1 auto;overflow:auto;font-size:13px;line-height:1.35}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-rail,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-rail{gap:6px}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-card-rail-actions .speech-row,.app-main[data-mode=play] .game-panel>.coach-card .coach-card-rail-actions .speech-row{display:grid;place-items:center}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-action-row,.app-main[data-mode=play] .game-panel>.coach-card .coach-action-row,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-action-row{width:100%;display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;scrollbar-width:none}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-action-row::-webkit-scrollbar,.app-main[data-mode=play] .game-panel>.coach-card .coach-action-row::-webkit-scrollbar,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-action-row::-webkit-scrollbar{display:none}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-action-row>.text-button,.app-main[data-mode=lessons] .main-board-panel>.coach-card .lesson-flow-button,.app-main[data-mode=play] .game-panel>.coach-card .coach-action-row>.text-button,.app-main[data-mode=review] .review-practice-board>.coach-card .coach-action-row>.text-button{min-width:0;min-height:32px;padding:0 8px;font-size:12px}.app-main[data-mode=lessons] .main-board-panel>.coach-card .lesson-flow-actions{flex:2 1 0;min-width:0;padding:0;border:0}.app-main[data-mode=lessons] .main-board-panel>.coach-card .coach-action-row>.text-button,.app-main[data-mode=lessons] .main-board-panel>.coach-card .lesson-flow-button{flex:1 1 0}.app-main[data-mode=lessons] .lesson-extras,.app-main[data-mode=play] .play-extras,.app-main[data-mode=review] .review-practice-extras{display:none}.app-main[data-mode=lessons] .stage-stepper{flex:0 0 auto;min-height:0;padding:7px 10px}.app-main[data-mode=lessons] .stage-stepper-progress-wrap{display:none}.app-main[data-mode=lessons] .stage-stepper-label strong{font-size:15px;line-height:1.1}.app-main[data-mode=lessons] .main-board-panel>.board-wrap,.app-main[data-mode=review] .review-practice-board>.board-wrap{width:min(100%,calc(100dvh - 315px))}.app-main[data-mode=play] .game-panel>.board-wrap{width:min(100%,var(--fit-board-size))}.app-main[data-mode=review] .review-workspace>.mastery-panel{display:none}.app-main[data-mode=review] .saved-game-review-detail,.app-main[data-mode=review] .saved-review-card{align-content:start;min-height:0;max-height:100%;overflow:auto}}@media(max-height:560px)and (min-width:560px){.app-main[data-mode=lessons] .main-board-panel,.app-main[data-mode=play] .game-panel,.app-main[data-mode=review] .review-practice-board{display:grid;grid-template-columns:minmax(180px,auto) minmax(220px,1fr);grid-template-rows:auto minmax(0,1fr);align-items:stretch;justify-content:center;gap:8px 10px}.app-main[data-mode=lessons] .stage-stepper,.app-main[data-mode=play] .game-action-row,.app-main[data-mode=review] .active-surface-kicker{grid-column:1 / -1;grid-row:1;align-self:start}.app-main[data-mode=lessons] .main-board-panel>.board-wrap,.app-main[data-mode=play] .game-panel>.board-wrap,.app-main[data-mode=review] .review-practice-board>.board-wrap{grid-column:1;grid-row:2;align-self:start;justify-self:end;width:min(calc(100dvh - 150px),calc(100vw - 330px),420px);min-width:0}.app-main[data-mode=lessons] .main-board-panel>.coach-card,.app-main[data-mode=play] .game-panel>.coach-card,.app-main[data-mode=review] .review-practice-board>.coach-card{grid-column:2;grid-row:2;align-self:stretch;justify-self:stretch;width:100%;min-width:0}.app-main[data-mode=play] .concept-proof-banner,.app-main[data-mode=play] .concept-hint-card{display:none}}.coach-panel .board-wrap{--board-coordinate-gutter: 12px;--board-frame-width: 7px;--board-label-font-size: 10px;width:100%;min-width:0}.coach-panel .board-grid{box-shadow:0 10px 18px #12191729}.coach-panel .piece{width:clamp(24px,76%,42px);height:clamp(24px,76%,42px)}.engine-board-preview .board-wrap{--board-coordinate-gutter: 12px;--board-frame-width: 7px;--board-label-font-size: 10px;width:min(100%,360px);min-width:0}.engine-board-preview .board-grid{box-shadow:0 10px 18px #12191729}.engine-board-preview .piece{width:clamp(24px,76%,42px);height:clamp(24px,76%,42px)}.today-layout{padding:18px max(16px,env(safe-area-inset-left)) 32px max(16px,env(safe-area-inset-right));display:flex;flex-direction:column;gap:22px;max-width:960px;margin:0 auto}@media(min-width:720px){.today-layout{padding-top:28px;gap:28px}}.today-top-row{display:flex;gap:16px;align-items:stretch;flex-wrap:wrap}.today-streak-ribbon{flex:1 1 240px;display:flex;align-items:center;gap:14px;background:var(--parchment-2);border:1px solid var(--walnut-soft);border-top:3px solid var(--brass);border-radius:var(--r-lg);padding:14px 18px;box-shadow:var(--shadow-1)}.today-streak-flame{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--parchment-3);color:var(--brass-deep)}.today-streak-flame[data-active=true]{background:var(--brass);color:var(--parchment);box-shadow:0 0 0 4px #c997462e}.today-streak-text{display:flex;flex-direction:column;gap:2px}.today-streak-count{font-family:var(--serif);font-size:1.15rem;color:var(--ink)}.today-streak-sub{color:var(--ink-mute);font-size:.8rem}.today-target-ring{flex:1 1 100%;width:100%;display:flex;align-items:center;gap:12px;background:var(--parchment-2);border:1px solid var(--walnut-soft);border-radius:var(--r-lg);padding:12px 16px 12px 12px;box-shadow:var(--shadow-1);min-width:200px}.today-target-disc{border-radius:50%;padding:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .22s ease}.today-target-inner{width:100%;height:100%;border-radius:50%;background:var(--parchment);display:flex;align-items:center;justify-content:center;color:var(--ink);font-family:var(--serif);font-size:.95rem;font-weight:600}.today-target-disc[data-complete=true] .today-target-inner{color:var(--brass-deep);font-size:1.6rem}.today-target-disc[data-active=false] .today-target-inner{color:var(--ink-mute);font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.today-target-empty{display:inline-block}.today-target-caption{color:var(--ink-soft);font-size:.85rem;line-height:1.35}.today-continue-card{display:flex;align-items:center;gap:16px;text-align:left;width:100%;background:var(--ink);color:var(--parchment);border:none;border-radius:var(--r-xl);padding:22px 24px;box-shadow:var(--shadow-2);cursor:pointer;transition:transform .14s ease,box-shadow .14s ease;font-family:var(--sans)}.today-continue-card:hover,.today-continue-card:focus-visible{transform:translateY(-2px);box-shadow:0 1px #6c45281a,0 22px 36px -18px #1f171480;outline:none}.today-continue-card:focus-visible{outline:2px solid var(--brass);outline-offset:4px}.today-continue-card[data-variant=celebration]{background:var(--brass);color:var(--ink)}.today-continue-lead{color:inherit;flex-shrink:0}.today-continue-text{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.today-continue-eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;opacity:.7}.today-continue-title{font-family:var(--serif);font-size:1.4rem;font-weight:600;line-height:1.15}.today-continue-meta{font-size:.85rem;opacity:.78}.today-continue-trail{flex-shrink:0;opacity:.7}.today-section{display:flex;flex-direction:column;gap:12px}.today-section-heading{font-family:var(--serif);font-size:.85rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);display:flex;align-items:center;gap:12px;margin:6px 0 0}.today-section-heading:before,.today-section-heading:after{content:"";flex:1;height:1px;background:var(--walnut-soft)}.today-section-heading:before{max-width:24px}.today-stat-list{display:flex;flex-direction:column}.today-stat-tile{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:8px;padding:12px 0;border-bottom:1px solid var(--walnut-soft)}.today-stat-tile:last-child{border-bottom:none}.today-stat-label{color:var(--ink-soft);font-size:.95rem}.today-stat-value{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--ink);letter-spacing:-.01em}.today-stat-hint{grid-column:1 / -1;color:var(--ink-mute);font-size:.78rem}.today-concept-list{display:flex;flex-direction:column}.today-concept-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:14px;padding:14px 12px;background:transparent;border:none;border-bottom:1px solid var(--walnut-soft);text-align:left;cursor:pointer;border-radius:var(--r-sm);color:var(--ink);font-family:var(--sans);font-size:.95rem}.today-concept-text{display:flex;flex-direction:column;gap:2px;min-width:0}.today-concept-row:last-child{border-bottom:none}.today-concept-row:hover,.today-concept-row:focus-visible{background:var(--parchment-2);outline:none}.today-concept-row:focus-visible{box-shadow:inset 0 0 0 2px var(--brass)}.today-concept-title{font-family:var(--serif);font-weight:600;color:var(--ink)}.today-concept-meta{color:var(--ink-mute);font-size:.82rem}.today-concept-trail{color:var(--brass-deep)}.today-concept-empty{color:var(--ink-mute);font-size:.88rem;font-style:italic;padding:12px 0}.today-library-chips{display:flex;flex-wrap:wrap;gap:8px}.today-chip{border:1px solid var(--walnut-soft);background:var(--parchment-2);color:var(--ink-soft);border-radius:999px;padding:6px 14px;cursor:pointer;font-family:var(--sans);font-size:.85rem;font-weight:500;transition:background .12s ease,color .12s ease,border-color .12s ease}.today-chip:hover,.today-chip:focus-visible{background:var(--parchment-3);outline:none}.today-chip[data-active=true]{background:var(--ink);color:var(--parchment);border-color:var(--ink)}.today-lesson-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:720px){.today-lesson-grid{grid-template-columns:repeat(3,1fr);gap:16px}}@media(min-width:1024px){.today-lesson-grid{grid-template-columns:repeat(4,1fr)}}.today-lesson-card{display:flex;flex-direction:column;gap:8px;background:var(--parchment-2);border:1px solid var(--walnut-soft);border-radius:var(--r-md);padding:14px;cursor:pointer;text-align:left;font-family:var(--sans);color:var(--ink);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.today-lesson-card:hover,.today-lesson-card:focus-visible{transform:translateY(-2px);box-shadow:var(--shadow-1);border-color:var(--brass);outline:none}.today-lesson-card[data-locked=true]{cursor:not-allowed;opacity:.55}.today-lesson-card[data-locked=true]:hover,.today-lesson-card[data-locked=true]:focus-visible{transform:none;box-shadow:none;border-color:var(--walnut-soft)}.today-lesson-eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}.today-lesson-title{font-family:var(--serif);font-size:1.05rem;font-weight:600;line-height:1.2;color:var(--ink)}.today-lesson-progress{position:relative;height:6px;border-radius:3px;background:var(--parchment-3);overflow:hidden}.today-lesson-progress>span{position:absolute;inset:0;background:var(--brass);border-radius:3px}.today-lesson-footer{display:flex;justify-content:space-between;align-items:center;color:var(--ink-mute);font-size:.78rem}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.top-bar-icon-btn,.ref,.today-target-disc,.today-continue-card,.today-chip,.today-concept-row,.today-lesson-card,.review-progress span,.you-row-button,.you-data-button{transition:none}}
