:root{--font-display: "Fraunces", "Times New Roman", serif;--font-body: "Manrope", -apple-system, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--pad: 22px;--gap: 18px;--radius-lg: 28px;--radius-md: 18px;--radius-sm: 12px;--sidebar-w: 248px;--sky-1: #fbe9d8;--sky-2: #f6dde6;--sky-3: #e9d9f0;--ground-1: #c8d8b1;--ground-2: #aac49a;--ground-3: #8eb09a;--hill: #b7c6dd;--sun: #ffd7a8;--bloom-a: #f5a99b;--bloom-b: #f6c6dd;--bloom-c: #d6c4ec;--bloom-d: #ffe49a;--particle: rgba(255, 240, 215, .85);--ink: #2e2540;--ink-soft: #5b4f6d;--ink-mute: #8c83a0;--ink-faint: #c4bdd2;--paper: #fbf6ef;--paper-2: #f4ecdf;--line: rgba(46, 37, 64, .08);--line-strong: rgba(46, 37, 64, .16);--glass-bg: rgba(255, 252, 246, .62);--glass-bg-strong: rgba(255, 252, 246, .78);--glass-border: rgba(255, 255, 255, .72);--glass-shadow: 0 24px 60px -28px rgba(89, 64, 122, .35), 0 2px 0 rgba(255, 255, 255, .7) inset;--gold: #d6a35a;--accent: #b48bd6;--accent-2: #5fa7a1;--warm: #e08a6f;--halo: radial-gradient( circle at 50% 50%, rgba(255, 245, 200, .95) 0%, rgba(255, 220, 180, .55) 35%, rgba(255, 220, 180, 0) 75% )}.app[data-palette=day]{--sky-1: #d8ecf8;--sky-2: #e6f1f6;--sky-3: #f0f6ee;--ground-1: #b9d8b3;--ground-2: #94c19c;--ground-3: #6fa389;--hill: #a5bdd6;--sun: #fff3c6;--bloom-a: #f59fb0;--bloom-b: #c8e3f4;--bloom-c: #d8c8f0;--bloom-d: #fde58e;--particle: rgba(255, 255, 240, .95)}.app[data-palette=sunset]{--sky-1: #fbcfae;--sky-2: #f4a9b1;--sky-3: #c89bc8;--ground-1: #a7967e;--ground-2: #7d6f6a;--ground-3: #5b5360;--hill: #957aa3;--sun: #ffb37a;--bloom-a: #f58f7a;--bloom-b: #f7b3c4;--bloom-c: #c198d4;--bloom-d: #ffcf8a;--particle: rgba(255, 220, 180, .95);--paper: #fff3e8;--paper-2: #f7e6d6;--glass-bg: rgba(255, 246, 234, .55)}.app[data-palette=night]{--sky-1: #1e1a3a;--sky-2: #2a2150;--sky-3: #3a2a5e;--ground-1: #2e3257;--ground-2: #232649;--ground-3: #181a36;--hill: #3a3666;--sun: #cbb5ff;--bloom-a: #f5b8c9;--bloom-b: #b8c8ff;--bloom-c: #d8b8ff;--bloom-d: #fff0c0;--particle: rgba(220, 210, 255, .95);--paper: #f7f3ff;--paper-2: #ece4ff;--ink: #221a3a;--glass-bg: rgba(255, 252, 255, .72)}.app[data-density=airy]{--pad: 28px;--gap: 22px;--sidebar-w: 264px}.app[data-density=balanced]{--pad: 22px;--gap: 18px;--sidebar-w: 248px}.app[data-density=compact]{--pad: 16px;--gap: 12px;--sidebar-w: 220px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font-body);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","ss02";overflow:hidden}button{font:inherit;color:inherit}a{color:inherit}.app{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:var(--sidebar-w) 1fr;background:radial-gradient(1200px 800px at 80% -10%,var(--sky-1) 0%,transparent 60%),radial-gradient(900px 700px at -10% 110%,var(--sky-3) 0%,transparent 65%),var(--paper);transition:background .8s ease;overflow:hidden}.sidebar{position:relative;padding:var(--pad);display:flex;flex-direction:column;gap:var(--gap);border-right:1px solid var(--line);background:linear-gradient(180deg,#ffffff73,#ffffff2e);backdrop-filter:blur(20px) saturate(120%);-webkit-backdrop-filter:blur(20px) saturate(120%);z-index:4}.brand{display:flex;align-items:center;gap:12px;padding:4px 6px 18px}.brand-mark{width:38px;height:38px;border-radius:12px;background:radial-gradient(circle at 30% 30%,#fff,transparent 55%),conic-gradient(from 200deg,var(--bloom-c),var(--bloom-a),var(--bloom-d),var(--accent-2),var(--bloom-c));box-shadow:0 8px 24px -8px #b48bd68c,0 0 0 1px #fff9 inset;position:relative}.brand-mark:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:50%;background:radial-gradient(circle,#fff 0%,transparent 70%);opacity:.7}.brand-name{font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:-.02em;font-style:italic;line-height:1}.brand-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-top:4px}.nav{display:flex;flex-direction:column;gap:2px}.nav-section{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);padding:14px 12px 6px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:14px;font-size:14px;font-weight:500;color:var(--ink-soft);cursor:pointer;background:transparent;border:0;text-align:left;width:100%;position:relative;transition:background .22s ease,color .22s ease,transform .22s ease}.nav-item:hover{background:#ffffff8c;color:var(--ink)}.nav-item.active{background:linear-gradient(135deg,#ffffffd9,#ffffff8c);color:var(--ink);box-shadow:0 4px 14px -8px #59407a59,inset 0 0 0 1px #ffffffb3}.nav-item.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:4px;background:linear-gradient(180deg,var(--accent),var(--warm))}.nav-glyph{width:26px;height:26px;flex-shrink:0;display:grid;place-items:center;color:var(--ink-soft)}.nav-item.active .nav-glyph{color:var(--accent)}.nav-meta{margin-left:auto;font-size:11px;color:var(--ink-mute);font-variant-numeric:tabular-nums}.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--warm);box-shadow:0 0 0 3px #e08a6f2e}.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px}.profile{display:flex;align-items:center;gap:12px;padding:10px;border-radius:16px;background:#ffffff8c;border:1px solid rgba(255,255,255,.65)}.profile-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#ffd7c0,#f7b3c4);display:grid;place-items:center;font-family:var(--font-display);font-style:italic;font-size:18px;color:#fff;box-shadow:inset 0 0 0 2px #fff9}.profile-name{font-size:13px;font-weight:600;line-height:1.1}.profile-sub{font-size:11px;color:var(--ink-mute);margin-top:2px}.main{position:relative;display:grid;grid-template-rows:auto 1fr;overflow:hidden;min-height:0}.topbar{display:flex;align-items:center;gap:14px;padding:calc(var(--pad) - 4px) var(--pad) 6px;z-index:3}.greet{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:26px;letter-spacing:-.015em;line-height:1.1;color:var(--ink)}.greet em{font-style:italic;color:var(--accent);font-weight:500}.greet-sub{font-size:12px;color:var(--ink-mute);margin-top:4px;letter-spacing:.02em}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.chip{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:13px;font-weight:500;color:var(--ink);box-shadow:var(--glass-shadow);white-space:nowrap;flex-shrink:0}.chip .val{font-variant-numeric:tabular-nums;font-weight:600}.chip-dot{width:10px;height:10px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff8d0,var(--gold) 70%);box-shadow:0 0 10px var(--gold)}.chip-streak .chip-dot{background:radial-gradient(circle at 30% 30%,#ffc8a8,var(--warm) 70%);box-shadow:0 0 8px var(--warm)}.content{display:grid;grid-template-columns:1.45fr 1fr;gap:var(--gap);padding:8px var(--pad) var(--pad);overflow:hidden;min-height:0}.content.single{grid-template-columns:1fr}.hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(180deg,var(--sky-1) 0%,var(--sky-2) 45%,var(--sky-3) 85%);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);min-height:0}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at 50% 50%,transparent 60%,rgba(46,37,64,.18) 100%)}.rail{display:grid;grid-template-rows:auto auto 1fr;gap:var(--gap);min-height:0;min-width:0}.card{position:relative;border-radius:var(--radius-lg);background:var(--glass-bg);backdrop-filter:blur(18px) saturate(125%);-webkit-backdrop-filter:blur(18px) saturate(125%);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);padding:var(--pad);overflow:hidden}.card-title{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:22px;letter-spacing:-.01em;line-height:1.1;margin:0}.card-kicker{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px;display:flex;align-items:center;gap:8px}.card-kicker:before{content:"";display:inline-block;width:14px;height:1px;background:currentColor}.focus{display:flex;flex-direction:column;gap:14px}.focus-task{font-family:var(--font-display);font-size:28px;line-height:1.15;letter-spacing:-.015em;font-style:italic;font-weight:400}.focus-task strong{background:linear-gradient(120deg,var(--accent) 0%,var(--warm) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;font-weight:500}.focus-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-soft);flex-wrap:wrap}.focus-meta span{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#ffffff8c;border:1px solid var(--line)}.focus-cta{margin-top:6px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:13px 20px;border-radius:999px;background:linear-gradient(135deg,#2e2540,#4a3a66);color:#fff8ec;font-size:13px;font-weight:600;letter-spacing:.01em;border:0;cursor:pointer;box-shadow:0 12px 30px -14px #2e254080,inset 0 1px #ffffff2e;transition:transform .2s ease,box-shadow .2s ease}.btn-primary:hover{transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:999px;background:transparent;border:1px solid var(--line-strong);color:var(--ink);font-size:13px;font-weight:500;cursor:pointer}.btn-ghost:hover{background:#ffffff80}.breath{position:relative;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,var(--bloom-a) 80%);box-shadow:0 0 #f5a99b80;animation:breath 5.5s ease-in-out infinite}@keyframes breath{0%,to{transform:scale(1);box-shadow:0 0 #f5a99b99}50%{transform:scale(1.35);box-shadow:0 0 0 8px #f5a99b00}}.stat-row{display:flex;gap:10px;flex-wrap:wrap}.stat{flex:1;min-width:0;padding:12px 14px;border-radius:16px;background:#ffffff8c;border:1px solid var(--line);display:flex;flex-direction:column;gap:2px}.stat-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}.stat-val{font-family:var(--font-display);font-size:22px;font-style:italic;font-weight:500;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.modules{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;min-height:0;overflow:hidden}.module{position:relative;border-radius:18px;padding:14px;background:#ffffff80;border:1px solid var(--line);cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:96px;overflow:hidden;transition:transform .22s ease,background .22s ease;text-align:left}.module:hover{transform:translateY(-2px);background:#ffffffbf}.module-name{font-family:var(--font-display);font-size:18px;font-style:italic;letter-spacing:-.01em;line-height:1.05}.module-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--ink-mute);margin-top:6px;gap:8px}.module-bar{height:4px;border-radius:4px;background:var(--line);overflow:hidden;margin-top:8px}.module-bar>div{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--warm))}.module-glyph{position:absolute;right:-12px;top:-12px;width:60px;height:60px;opacity:.7;filter:blur(.4px)}.scene-caption{position:absolute;left:24px;bottom:22px;z-index:4;font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--ink-soft);background:#ffffff8c;padding:8px 14px;border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.7);display:inline-flex;align-items:center;gap:8px;pointer-events:none}.scene-caption .dot{width:6px;height:6px;background:var(--accent);border-radius:50%}.scene-hud{position:absolute;top:18px;right:18px;display:flex;flex-direction:column;gap:8px;z-index:4;align-items:flex-end}.hud-pill{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:#ffffff9e;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.7);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hud-pill .val{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:14px;text-transform:none;letter-spacing:-.01em;color:var(--ink)}.scene-toolbar{position:absolute;left:50%;bottom:16px;transform:translate(-50%);display:flex;gap:8px;z-index:4}.scene-toolbar .tool{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:500;color:var(--ink);background:#ffffffb3;border:1px solid rgba(255,255,255,.7);padding:8px 14px;border-radius:999px;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:background .22s ease,transform .22s ease}.scene-toolbar .tool:hover{background:#fff;transform:translateY(-1px)}.scene-toolbar .tool.primary{background:linear-gradient(135deg,var(--accent),var(--warm));color:#fff;border-color:transparent;box-shadow:0 10px 22px -10px #b48bd699}.bubble{position:absolute;left:4%;top:14%;max-width:280px;font-family:var(--font-display);font-style:italic;font-size:15px;line-height:1.3;color:var(--ink);background:#ffffffdb;padding:14px 18px;border-radius:22px 22px 22px 6px;border:1px solid rgba(255,255,255,.85);box-shadow:0 12px 30px -16px #59407a73;z-index:5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.quest-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}.quest{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;background:#ffffff80;border:1px solid var(--line);font-size:13px}.quest-mark{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;flex-shrink:0;color:var(--ink-mute)}.quest.done .quest-mark{background:linear-gradient(135deg,var(--accent),var(--warm));border-color:transparent;color:#fff}.quest.done .quest-text{color:var(--ink-mute);text-decoration:line-through;text-decoration-color:var(--ink-faint)}.quest-text{flex:1;min-width:0}.quest-reward{font-size:11px;color:var(--gold);font-weight:600}.sport{display:flex;align-items:center;gap:14px;padding:14px;border-radius:20px;background:linear-gradient(135deg,#b48bd62e,#f5a99b2e);border:1px solid rgba(255,255,255,.7)}.sport-icon{width:46px;height:46px;border-radius:14px;background:radial-gradient(circle at 30% 30%,#fff,var(--accent-2) 80%);display:grid;place-items:center;color:#fff;box-shadow:0 8px 20px -10px #5fa7a199}.sport-body{flex:1;min-width:0}.sport-title{font-size:14px;font-weight:600}.sport-sub{font-size:12px;color:var(--ink-soft);margin-top:2px}.sport-reward{font-family:var(--font-display);font-style:italic;font-size:16px;color:var(--gold);white-space:nowrap}.rail .card.modules-card{min-height:0;display:flex;flex-direction:column}.modules-scroll{overflow:hidden;min-height:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:6px}.lesson-shell{display:grid;grid-template-columns:1fr 360px;gap:var(--gap);padding:8px var(--pad) var(--pad);overflow:hidden;min-height:0;height:100%}.lesson-shell.single{grid-template-columns:1fr}.lesson-main{display:flex;flex-direction:column;gap:var(--gap);overflow:auto;padding-right:4px}.lesson-side{display:flex;flex-direction:column;gap:var(--gap);overflow:auto}.step-card{border-radius:var(--radius-lg);background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(18px) saturate(125%);backdrop-filter:blur(18px) saturate(125%);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);padding:calc(var(--pad) + 4px)}.step-kind{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:10px}.step-title{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:30px;letter-spacing:-.015em;line-height:1.1;margin:0 0 14px}.step-body{font-size:16px;line-height:1.55;color:var(--ink-soft)}.step-body p{margin:0 0 12px}.step-body strong{color:var(--ink);font-weight:600}.expr{font-family:var(--font-mono);font-size:18px;display:inline-flex;padding:6px 12px;border-radius:10px;background:linear-gradient(135deg,#b48bd62e,#f5a99b29);color:var(--ink)}.explain-steps{display:grid;gap:10px;padding:12px;border-radius:18px;background:#ffffff80;border:1px solid var(--line);margin:12px 0}.explain-steps li{list-style:none;padding-left:0;font-family:var(--font-mono);font-size:14px;color:var(--ink)}.explain-steps li:before{content:"▸";color:var(--accent);margin-right:8px}.practice-problem{display:grid;gap:10px;padding:16px;border-radius:18px;background:#fff9;border:1px solid var(--line);margin-bottom:10px}.practice-problem .q{font-size:15px;color:var(--ink)}.practice-problem .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.practice-input{font-family:var(--font-mono);font-size:18px;padding:10px 14px;border-radius:14px;border:1px solid var(--line-strong);background:#ffffffd9;width:120px;color:var(--ink);transition:border-color .2s ease,box-shadow .2s ease}.practice-input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px #b48bd62e}.practice-input.correct{border-color:var(--accent-2);box-shadow:0 0 0 4px #5fa7a12e}.practice-input.wrong{border-color:var(--warm);box-shadow:0 0 0 4px #e08a6f2e}.practice-hint{font-size:12px;color:var(--ink-mute)}.own-words-area{width:100%;min-height:140px;border-radius:18px;padding:16px;border:1px solid var(--line-strong);background:#ffffffd9;font-family:var(--font-body);font-size:15px;color:var(--ink);resize:vertical}.own-words-area:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px #b48bd62e}.mood-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.mood-btn{padding:10px 16px;border-radius:999px;background:#fff9;border:1px solid var(--line-strong);font-size:14px;cursor:pointer;transition:all .2s ease}.mood-btn:hover{background:#fff;transform:translateY(-1px)}.mood-btn.active{background:linear-gradient(135deg,var(--accent),var(--warm));color:#fff;border-color:transparent}.lesson-progress{display:flex;gap:6px;margin-bottom:14px}.lesson-progress-step{flex:1;height:4px;border-radius:4px;background:var(--line);transition:background .3s ease}.lesson-progress-step.done{background:linear-gradient(90deg,var(--accent),var(--warm))}.lesson-progress-step.current{background:linear-gradient(90deg,var(--accent),var(--warm));opacity:.5}.auth-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:radial-gradient(1200px 800px at 80% -10%,var(--sky-1) 0%,transparent 60%),radial-gradient(900px 700px at -10% 110%,var(--sky-3) 0%,transparent 65%),var(--paper)}.auth-card{width:min(420px,92vw);padding:36px;border-radius:var(--radius-lg);background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(20px) saturate(125%);backdrop-filter:blur(20px) saturate(125%);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);display:flex;flex-direction:column;gap:16px}.auth-title{font-family:var(--font-display);font-style:italic;font-size:32px;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin:0}.auth-sub{font-size:13px;color:var(--ink-mute)}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}.auth-input{padding:12px 14px;border-radius:14px;border:1px solid var(--line-strong);background:#ffffffd9;font:inherit;color:var(--ink)}.auth-input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px #b48bd62e}.auth-error{font-size:12px;color:var(--warm)}.course-page{padding:8px var(--pad) var(--pad);overflow:auto;height:100%;display:flex;flex-direction:column;gap:var(--gap)}.topic-section{display:flex;flex-direction:column;gap:10px}.topic-header{display:flex;align-items:baseline;justify-content:space-between}.topic-title{font-family:var(--font-display);font-style:italic;font-size:24px;font-weight:500;letter-spacing:-.015em;line-height:1.1;margin:0}.topic-summary{font-size:12px;color:var(--ink-mute)}.lesson-tile{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:18px;background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);cursor:pointer;text-align:left;width:100%;transition:transform .22s ease,background .22s ease}.lesson-tile:hover{transform:translateY(-2px);background:var(--glass-bg-strong)}.lesson-tile.locked{opacity:.55;cursor:not-allowed}.lesson-tile.locked:hover{transform:none}.lesson-index{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--bloom-a),var(--bloom-c));display:grid;place-items:center;font-family:var(--font-display);font-style:italic;color:#fff}.lesson-name{font-family:var(--font-display);font-style:italic;font-size:18px;line-height:1.1}.lesson-meta{font-size:11px;color:var(--ink-mute);margin-top:4px}.lesson-arrow{margin-left:auto;color:var(--accent);font-weight:600;font-size:13px}.celebration-card{text-align:center;padding:36px}.celebration-title{font-family:var(--font-display);font-style:italic;font-size:36px;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin:0 0 12px}.celebration-sub{color:var(--ink-soft);margin:0 0 16px;font-size:15px}.celebration-reward{display:inline-flex;align-items:center;gap:8px;padding:14px 22px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--warm));color:#fff;font-family:var(--font-display);font-style:italic;font-size:20px}.module-placeholder{padding:36px;text-align:center;color:var(--ink-mute);font-family:var(--font-display);font-style:italic;font-size:22px}.biome-switcher{display:flex;flex-direction:column;gap:6px;background:#ffffff9e;border:1px solid rgba(255,255,255,.7);border-radius:16px;padding:8px 10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.biome-switcher[data-compact="1"]{padding:6px 8px}.biome-row{display:flex;flex-wrap:wrap;gap:6px}.biome-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;background:#ffffff80;color:var(--ink-soft);font-size:12px;letter-spacing:.04em;padding:5px 11px;border-radius:999px;cursor:pointer;transition:all .18s ease}.biome-chip.thin{font-size:11px;padding:4px 9px;text-transform:lowercase}.biome-chip:hover{background:#ffffffd9;color:var(--ink)}.biome-chip.active{background:linear-gradient(135deg,var(--accent),var(--warm));color:#fff;border-color:transparent;box-shadow:0 6px 14px -8px #b48bd699}.biome-chip.locked{opacity:.42;cursor:not-allowed;text-decoration:line-through}.placement-hud{position:absolute;left:18px;bottom:18px;z-index:5;background:#ffffffd9;border:1px solid rgba(255,255,255,.8);border-radius:18px;padding:12px 16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:6px;max-width:320px}.placement-hud .hud-title{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--ink)}.placement-hud .hud-hint{font-size:12px;color:var(--ink-mute)}.placement-hud .hud-actions{display:flex;gap:8px;margin-top:6px}.garden-screen{position:relative;width:100%;height:100%;min-height:540px}.garden-screen .canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:24px;overflow:hidden}.garden-hud-top{position:absolute;top:18px;left:18px;right:18px;z-index:4;display:flex;justify-content:space-between;gap:12px;pointer-events:none}.garden-hud-top>*{pointer-events:auto}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.shop-card .stage-badge{display:inline-block;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-left:6px}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.static{position:static}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.bottom-bar{display:none}@media (max-width: 820px){.app{grid-template-columns:1fr}.sidebar{display:none}.main{padding-bottom:64px}.content,.lesson-shell,.modules{grid-template-columns:1fr!important}.bottom-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:30;justify-content:space-around;align-items:center;padding:6px 8px env(safe-area-inset-bottom,8px);background:#ffffffc7;backdrop-filter:blur(20px) saturate(120%);-webkit-backdrop-filter:blur(20px) saturate(120%);border-top:1px solid var(--line)}.bottom-bar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;font-size:11px;color:var(--ink-3);text-decoration:none;border-radius:10px}.bottom-bar a.active{color:var(--ink-1);background:#ffffffb3}.bottom-bar .nav-glyph{font-size:18px}}.chess-board-frame{width:100%;height:100%;min-height:280px}.chess-board-fallback{display:grid;place-items:center;gap:8px;height:100%;min-height:280px;padding:16px;text-align:center;color:var(--ink-soft)}.chess-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}@media (max-width: 820px){.chess-layout{grid-template-columns:1fr}}.install-pill{position:fixed;bottom:12px;right:12px;z-index:50;padding:10px 14px;border-radius:999px;background:var(--paper);border:1px solid var(--line);box-shadow:0 12px 36px -16px #00000040;font-size:13px;cursor:pointer}@media (max-width: 820px){.install-pill{bottom:76px}}
