:root{--paper: #fbf8ee;--panel: #fffdf6;--panel-strong: #f5efe2;--ink: #281715;--muted: #75675f;--line: #ded4c4;--blue: #78c9f2;--blue-deep: #2c86b5;--mint: #c8ead8;--peach: #ffbf91;--lavender: #d8dcff;--rose: #efb2a7;--green: #67b982;--shadow: 0 18px 60px rgba(52, 34, 27, .12);--radius: 22px;--coin-border: rgba(40, 23, 21, .78);--coin-highlight: radial-gradient(circle at 34% 28%, rgba(255, 253, 246, .95) 0 11%, transparent 12%);--coin-blue: var(--coin-highlight), linear-gradient(145deg, #bdeaff, #78c9f2 58%, #5bb4de);--coin-peach: var(--coin-highlight), linear-gradient(145deg, #ffd3b4, #ffb987 58%, #f7a56f);--coin-mint: var(--coin-highlight), linear-gradient(145deg, #d8f5e5, #a6e1bd 58%, #7bcfa0);--coin-lavender: var(--coin-highlight), linear-gradient(145deg, #edf0ff, #c8cff8 58%, #aeb8ef);--coin-rose: var(--coin-highlight), linear-gradient(145deg, #ffd7d0, #efb2a7 58%, #dc9285);--coin-shadow: inset 0 1px 0 rgba(255, 255, 255, .78), 0 2px 0 rgba(40, 23, 21, .84), 0 7px 12px rgba(52, 34, 27, .09);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-out-quint: cubic-bezier(.22, 1, .36, 1);--ease-snap: cubic-bezier(.2, .9, .2, 1)}*{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;overflow:hidden;overflow-x:hidden;background:linear-gradient(#fbf8eee6,#fbf8eef7),url(/assets/learning-atlas.png) center / cover no-repeat,var(--paper);color:var(--ink);font-family:Manrope,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer;color:inherit}button:disabled{cursor:not-allowed;opacity:.58}svg{width:18px;height:18px;stroke-width:2.35;flex:0 0 auto}h1,h2,h3,p{margin-top:0}.app-shell{height:100%;display:grid;grid-template-rows:auto 1fr;padding:18px;gap:14px}.topbar{width:min(1440px,100%);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{border:0;background:transparent;display:inline-flex;align-items:center;gap:10px;font-weight:850;font-size:1rem}.brand-mark{width:24px;height:24px;border-radius:47% 53% 42% 58%/55% 39% 61% 45%;background:var(--ink);box-shadow:7px 1px 0 var(--peach),-5px 8px 0 var(--blue)}.nav-actions,.action-row,.sheet-actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.quiet-pill{display:inline-flex;align-items:center;min-height:32px;padding:0 10px;border:1px solid rgba(40,23,21,.12);border-radius:999px;color:var(--muted);background:#fffdf6b8;font-size:.78rem;font-weight:800}.icon-text-button,.primary-button,.icon-button,.wide-soft-button{border:1.5px solid var(--ink);border-radius:13px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:850;background:#fffdf6b8;padding:0 14px;box-shadow:0 3px #28171533;transform:translateY(0) rotate(0);transition:transform .14s var(--ease-snap),box-shadow .14s var(--ease-snap),background-color .18s var(--ease-out-quart)}.icon-text-button:hover,.primary-button:hover,.icon-button:hover,.wide-soft-button:hover,.chip-row button:hover,.lesson-node:hover,.bite-sequence-grid button:hover{transform:translateY(-2px) rotate(-.35deg)}.icon-text-button:active,.primary-button:active,.icon-button:active,.wide-soft-button:active,.chip-row button:active,.lesson-node:active,.bite-sequence-grid button:active{transform:translateY(2px) scale(.985) rotate(.25deg);box-shadow:0 1px #28171538}.primary-button{background:var(--blue);box-shadow:0 5px #4e91b2;white-space:nowrap}.primary-button.is-loading{opacity:1;background:linear-gradient(90deg,rgba(255,255,255,.18),transparent 38%),var(--coin-blue);cursor:progress}.primary-button.is-loading svg{animation:spin .9s linear infinite}.primary-button.is-loading:hover,.primary-button.is-loading:active{transform:translateY(0) rotate(0);box-shadow:0 5px #4e91b2}.wide-soft-button{width:100%;border-color:#28171547;box-shadow:none;background:#fff9}.icon-button{width:42px;padding:0}.icon-button.mini{min-height:28px;width:28px;border-radius:9px}main{min-height:0;width:min(1440px,100%);margin:0 auto}.home-main{height:100%;display:grid;justify-items:center;align-items:center;overflow-y:auto;overflow-x:hidden;padding:clamp(10px,2vh,24px) 0 clamp(24px,5vh,56px);overscroll-behavior:contain}.home-main.is-generating{align-items:start}.experience-main{height:100%;display:grid;grid-template-rows:auto 1fr;gap:12px}.prompt-home{width:min(820px,100%);display:grid;gap:18px;margin:auto 0}.home-main.is-generating .prompt-home{margin:0}.prompt-box{background:#fffdf6e0;border:1px solid rgba(40,23,21,.1);border-radius:28px;box-shadow:var(--shadow);padding:clamp(20px,4vw,42px);display:grid;gap:14px}.prompt-box h1{margin-bottom:2px;font-family:Fraunces,serif;font-size:clamp(1.8rem,4.2vw,3.7rem);line-height:1.02;letter-spacing:0}.prompt-box .topic-input-wrap{margin-top:6px;min-height:68px;border-radius:22px}.prompt-box input{font-size:1.05rem}.generating-strip{display:grid;grid-template-columns:34px 1fr;gap:12px;align-items:start;border:1px solid rgba(40,23,21,.12);border-radius:20px;padding:13px;background:linear-gradient(135deg,#78c9f229,#c8ead81f),#fffdf6b3;box-shadow:0 12px 28px #34221b14;animation:generation-rise .32s var(--ease-out-quint) both}.spinner-dot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--coin-blue);border:1.5px solid var(--coin-border);box-shadow:var(--coin-shadow)}.spinner-dot svg{animation:spin 1s linear infinite}.generating-strip strong,.generating-strip span{display:block}.generating-strip span{margin-top:3px;color:var(--muted);font-size:.86rem;line-height:1.4}.progress-steps{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:6px}.progress-steps li{position:relative;overflow:hidden;border:1px solid rgba(40,23,21,.12);border-radius:15px;background:#ffffff8c;padding:9px 10px;opacity:.68;display:grid;grid-template-columns:28px minmax(0,1fr) auto;gap:10px;align-items:center;animation:progress-line-in .36s var(--ease-out-quint) both;animation-delay:calc(var(--step) * 55ms)}.progress-steps li.running,.progress-steps li.done{opacity:1}.progress-steps li.done{background:#c8ead87a}.progress-steps li.running{border-color:#2c86b56b;background:linear-gradient(90deg,#78c9f22e,#fffdf69e),#78c9f224;box-shadow:inset 0 0 0 1px #78c9f21f}.progress-steps li:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.58),transparent);transform:translate(-100%);animation:sweep 2.8s ease-in-out infinite;animation-delay:calc(var(--step) * .22s);pointer-events:none}.progress-steps li.waiting:after,.progress-steps li.done:after{display:none}.progress-steps .step-marker{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:#fffdf6cc;border:1px solid rgba(40,23,21,.2);color:var(--muted);box-shadow:inset 0 1px #ffffffdb}.progress-steps li.done .step-marker{background:var(--coin-mint);border:1.5px solid var(--coin-border);color:var(--ink);box-shadow:var(--coin-shadow)}.progress-steps li.running .step-marker{background:var(--coin-blue);border:1.5px solid var(--coin-border);color:var(--ink);box-shadow:var(--coin-shadow)}.progress-steps li.running .step-marker svg{animation:spin 1s linear infinite}.progress-steps b,.progress-steps small,.progress-steps em{position:relative;display:block}.progress-steps b{font-size:.8rem}.progress-steps small{margin-top:3px;color:var(--muted);font-size:.72rem;line-height:1.28}.progress-steps em{justify-self:end;color:var(--muted);font-size:.62rem;font-style:normal;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.progress-steps li.running em{color:#245f79}.progress-steps li.done em{color:#376847}.analysis-checkpoint{margin-top:10px;border:1px solid rgba(40,23,21,.12);border-radius:13px;padding:10px;background:#ffffff9e}.analysis-checkpoint p{margin:5px 0 8px;color:var(--muted);font-size:.82rem;line-height:1.38}.generation-list{background:#fffdf6ad;border:1px solid rgba(40,23,21,.08);border-radius:22px;padding:14px;box-shadow:0 12px 34px #34221b14}.generation-list.empty{text-align:center;color:var(--muted)}.generation-list.empty p{margin:0}.list-heading{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px;color:var(--muted);font-size:.78rem;font-weight:850;text-transform:uppercase;letter-spacing:.07em}.generation-cards{display:grid;gap:8px;max-height:260px;overflow:auto}.generation-card{width:100%;border:1px solid rgba(40,23,21,.12);border-radius:16px;background:#ffffff94;display:grid;grid-template-columns:1fr auto;align-items:center;gap:5px}.generation-card:hover{border-color:#28171557;background:#fffc}.generation-open{border:0;background:transparent;text-align:left;padding:12px;display:grid;gap:5px;color:inherit;text-decoration:none;cursor:pointer}.generation-open>span{width:fit-content;border-radius:999px;padding:4px 8px;background:var(--mint);color:#315642;font-size:.68rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em}.generation-card.generating .generation-open>span{background:var(--lavender);color:#44405f}.generation-card.resume .generation-open>span{background:var(--peach);color:#6f3d21}.generation-card.failed .generation-open>span{background:#ffd8cf;color:#7d342c}.generation-card.new .generation-open>span{background:var(--mint);color:#315642}.generation-card.continue .generation-open>span{background:var(--blue);color:#18485f}.generation-card.finished .generation-open>span{background:#e6e0d6;color:#5b5149}.generation-card strong{font-size:.98rem}.generation-card small{color:var(--muted);line-height:1.35}.delete-record{width:38px;height:38px;margin-right:10px;border:1px solid rgba(40,23,21,.14);border-radius:12px;background:#ffffffad;display:grid;place-items:center;color:inherit;text-decoration:none;cursor:pointer}.delete-record:hover{background:#ffd8cf}.course-header{min-height:0;background:#fffdf6d1;border:1px solid rgba(40,23,21,.1);border-radius:18px;box-shadow:0 10px 34px #34221b14;padding:10px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;animation:block-reveal .42s var(--ease-out-quint) both}.course-header h1{margin-bottom:2px;font-size:clamp(1rem,1.25vw,1.22rem);line-height:1.15;font-weight:850}.course-header p{margin:0;color:var(--muted);font-size:.78rem;line-height:1.25}.course-title-copy{min-width:0}.course-title-actions{display:flex;align-items:center;gap:8px}.composer{min-height:0;background:#fffdf6d4;border:1px solid rgba(40,23,21,.1);border-radius:var(--radius);box-shadow:var(--shadow);display:grid;grid-template-columns:minmax(280px,.74fr) minmax(420px,1fr);gap:24px;align-items:end;padding:28px}.composer.compact{padding:16px;grid-template-columns:minmax(280px,.75fr) minmax(420px,1fr);box-shadow:0 10px 34px #34221b14}.kicker{margin:0 0 8px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;font-weight:850}.composer h1{margin-bottom:8px;font-family:Fraunces,serif;font-size:clamp(1.65rem,2.4vw,3rem);line-height:1;letter-spacing:0}.composer.compact h1{font-family:Manrope,sans-serif;font-size:clamp(1.05rem,1.5vw,1.42rem);line-height:1.15;font-weight:850}.composer p{margin-bottom:0;color:var(--muted);line-height:1.48;font-size:.92rem;max-width:680px}.error-line{margin-top:8px;color:#9b382d!important;font-weight:750}.topic-form{display:grid;gap:10px}.topic-input-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:7px;border:1px solid var(--line);border-radius:18px;background:#ffffff9e}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:12px;background:#ffffffb8;color:var(--ink);padding:11px 12px;outline:none;font-size:.92rem}.topic-input-wrap input{border:0;background:transparent;min-width:0}input:focus,textarea:focus,select:focus{border-color:var(--blue-deep);box-shadow:0 0 0 4px #78c9f238}.chip-row{display:flex;gap:8px;flex-wrap:wrap}.chip-row button{border:0;border-radius:999px;padding:7px 10px;font-size:.78rem;font-weight:850;background:var(--lavender)}.chip-row button:nth-child(2){background:var(--mint)}.chip-row button:nth-child(3){background:var(--peach)}.chip-row button:nth-child(4){background:var(--rose)}.experience{height:100%;min-height:0;overflow:hidden;display:grid;grid-template-columns:minmax(250px,300px) minmax(0,1fr);gap:12px}.course-leftbar,.path-panel,.lesson-lobby,.memory-panel,.sheet,.map-shell,.practice-shell,.player-shell,.assistant-drawer{background:#fffdf6e0;border:1px solid rgba(40,23,21,.1);border-radius:var(--radius);box-shadow:var(--shadow)}.course-leftbar,.course-card{height:calc(100vh - 170px);max-height:620px}.course-leftbar,.path-panel,.memory-panel{min-height:0;overflow:auto;padding:16px}.course-leftbar{animation:block-reveal .46s var(--ease-out-quint) 70ms both}.panel-heading{display:flex;align-items:center;gap:8px;margin-bottom:13px;font-weight:850}.path-section+.path-section{margin-top:18px}.path-section h3{margin-bottom:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem}.lesson-node{width:100%;border:1px solid rgba(40,23,21,.13);background:#ffffff85;border-radius:16px;padding:10px;display:grid;grid-template-columns:34px 1fr;gap:10px;text-align:left;margin-bottom:8px;transform-origin:18px 50%;transition:transform .15s var(--ease-snap),background-color .18s var(--ease-out-quart),outline-color .18s var(--ease-out-quart),box-shadow .15s var(--ease-snap)}.lesson-node>span{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:var(--coin-blue);border:1.5px solid var(--coin-border);box-shadow:var(--coin-shadow);font-size:.78rem;font-weight:850}.lesson-node:nth-of-type(2n)>span{background:var(--coin-lavender)}.lesson-node:nth-of-type(3n)>span{background:var(--coin-mint)}.lesson-node.active>span{background:var(--coin-peach)}.lesson-node.active{outline:3px solid rgba(120,201,242,.62);background:#ffffffd1;animation:select-tick .36s var(--ease-out-quint) both}.lesson-node strong{display:block;font-size:.9rem;line-height:1.22}.lesson-node small{color:var(--muted);font-weight:700}.lesson-lobby{min-height:0;display:flex;flex-direction:column;overflow:hidden}.course-card{position:relative;background:linear-gradient(135deg,#fffdf6f0,#f5efe2bd),var(--panel);animation:block-reveal .5s var(--ease-out-quint) .12s both}.course-card-scroll{flex:1 1 0;min-height:0;overflow:auto;padding:14px 14px 86px;display:grid;gap:12px}.lesson-hero{padding:clamp(18px,2.4vw,26px);border:1px solid rgba(40,23,21,.1);border-radius:22px;background:linear-gradient(135deg,#d8dcff6b,#c8ead84d);animation:card-pop .38s var(--ease-out-quint) .19s both}.lesson-gate{display:grid;align-content:start}.lesson-label{color:var(--muted);font-size:.78rem;font-weight:850;text-transform:uppercase;letter-spacing:.08em}.lesson-hero h2{margin:8px 0 10px;font-size:clamp(1.25rem,1.55vw,1.8rem);line-height:1.12;font-family:Fraunces,serif;letter-spacing:0;max-width:780px}.lesson-hero p{color:#5b4d45;font-size:.96rem;line-height:1.48;max-width:720px}.bite-sequence{min-height:0;padding:2px 4px 12px;animation:block-reveal .38s var(--ease-out-quint) .25s both}.bite-sequence-grid{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(130px,1fr));gap:10px}.bite-sequence-grid button{min-height:118px;border:1px solid rgba(40,23,21,.12);border-radius:18px;background:#ffffff94;padding:12px;text-align:left;display:grid;align-content:start;gap:8px;transform-origin:18px 18px;transition:transform .15s var(--ease-snap),box-shadow .16s var(--ease-snap),border-color .18s var(--ease-out-quart),filter .18s var(--ease-out-quart);animation:bite-card-reveal .42s var(--ease-out-quint) both}.bite-sequence-grid button:nth-child(1){animation-delay:.32s}.bite-sequence-grid button:nth-child(2){animation-delay:.38s}.bite-sequence-grid button:nth-child(3){animation-delay:.44s}.bite-sequence-grid button:nth-child(4){animation-delay:.5s}.bite-sequence-grid button:hover{border-color:#28171547;box-shadow:0 10px 22px #34221b1a;filter:saturate(1.05)}.bite-sequence-grid button:nth-child(1){background:#d8dcff6b}.bite-sequence-grid button:nth-child(2){background:#c8ead86b}.bite-sequence-grid button:nth-child(3){background:#78c9f22e}.bite-sequence-grid button:nth-child(4){background:#ffbf9152}.bite-sequence-grid button>span{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:var(--coin-blue);border:1.5px solid var(--coin-border);box-shadow:var(--coin-shadow);font-weight:850;font-size:.76rem}.bite-sequence-grid button:nth-child(1)>span{background:var(--coin-lavender)}.bite-sequence-grid button:nth-child(2)>span{background:var(--coin-mint)}.bite-sequence-grid button:nth-child(4)>span{background:var(--coin-peach)}.bite-sequence-grid i{color:#4d5d64}.bite-sequence-grid strong{font-size:.92rem}.bite-sequence-grid small,.sequence-note{color:var(--muted);font-size:.8rem;line-height:1.35}.sequence-note{margin-top:14px;max-width:780px}.course-card-cta{position:sticky;bottom:0;z-index:2;flex:0 0 auto;border-top:1px solid rgba(40,23,21,.1);background:#fffdf6f0;box-shadow:0 -18px 32px #34221b14;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;animation:dock-rise .42s var(--ease-out-quint) .56s both}.course-card-cta>span{color:var(--muted);font-size:.78rem;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.course-card-cta .action-row{margin:0}.page-visual{min-width:0}.visual-composition{display:grid;gap:12px}.structured-visual{position:relative;min-height:clamp(300px,40vh,440px);border:1.5px solid rgba(40,23,21,.76);border-radius:28px;overflow:hidden;background:linear-gradient(rgba(40,23,21,.038) 1px,transparent 1px) 0 0 / 42px 42px,linear-gradient(90deg,rgba(40,23,21,.038) 1px,transparent 1px) 0 0 / 42px 42px,linear-gradient(135deg,rgba(120,201,242,.16),transparent 34%),linear-gradient(315deg,rgba(255,191,145,.18),transparent 35%),linear-gradient(180deg,#fffdf6e6,#f5efe2ad);box-shadow:inset 0 1px #ffffffe0,inset 0 0 0 10px #fffdf642,0 18px 44px #34221b1f,0 4px #28171514}.structured-visual:before{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:1px dashed rgba(40,23,21,.12);border-radius:20px;pointer-events:none}.structured-visual:after{content:"";position:absolute;left:22px;top:20px;width:78px;height:9px;border-radius:999px;background:repeating-linear-gradient(90deg,rgba(40,23,21,.18) 0 8px,transparent 8px 14px);opacity:.22;pointer-events:none}.visual-link-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible}.visual-link-layer path{fill:none;stroke:#28171552;stroke-width:.55;stroke-linecap:round;vector-effect:non-scaling-stroke}.visual-link-layer marker path{fill:#28171561;stroke:none}.visual-link-layer text{fill:#6f625a;font-family:Manrope,sans-serif;font-size:3px;font-weight:850;letter-spacing:.02em;paint-order:stroke;stroke:#fffdf6d9;stroke-width:3px;vector-effect:non-scaling-stroke}.visual-equation{position:absolute;left:50%;top:8%;transform:translate(-50%);border:1px solid rgba(40,23,21,.14);border-radius:999px;background:#fffdf6c7;padding:7px 11px;color:#4d5d64;font-size:.78rem;font-weight:850;white-space:nowrap}.visual-node{position:absolute;left:var(--x);top:var(--y);width:clamp(116px,12vw,150px);min-height:66px;border:1.5px solid rgba(40,23,21,.82);border-radius:18px;background:#fffdf6e6;padding:10px;transform:translate(-50%,-50%);box-shadow:0 8px 18px #34221b14;display:grid;grid-template-columns:24px 1fr;align-items:center;gap:9px}.visual-node span{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:var(--coin-blue);border:1.5px solid var(--coin-border);box-shadow:var(--coin-shadow);font-weight:850;font-size:.72rem;margin-bottom:0}.visual-node.primary span,.visual-node.output span{background:var(--coin-peach)}.visual-node.process{background:#d8dcffd6}.visual-node.output{background:#c8ead8db}.visual-node.contrast{background:#efb2a7db}.visual-node.check{background:#78c9f238}.visual-node strong{display:block;margin-bottom:0;font-size:.86rem;line-height:1.08}.visual-note-rail{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.visual-note{display:grid;grid-template-columns:24px 1fr;align-items:start;gap:5px 10px;border-top:1px solid rgba(40,23,21,.13);padding:9px 2px 0}.visual-note span{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;border:1.5px solid var(--coin-border);background:var(--coin-blue);box-shadow:var(--coin-shadow);color:#20100f;font-size:.68rem;font-weight:850;align-self:center}.visual-note:nth-child(2n) span{background:var(--coin-lavender)}.visual-note:nth-child(3n) span{background:var(--coin-mint)}.visual-note strong{align-self:center;font-size:.7rem;line-height:1.1}.content-page .visual-note p,.visual-note p{grid-column:2;margin:0;color:var(--muted);line-height:1.34;font-size:.72rem}.memory-panel{display:flex;flex-direction:column;gap:10px}.knowledge-card{position:relative;border:1px solid rgba(40,23,21,.1);border-radius:16px;background:#ffffff8a;padding:13px}.knowledge-card h3{margin-bottom:7px;font-size:.95rem}.knowledge-card p,.knowledge-card small{color:var(--muted);line-height:1.42;font-size:.84rem}.knowledge-card p{margin-bottom:8px}.provider-note{margin-top:auto;padding-top:10px;color:var(--muted);border-top:1px solid rgba(40,23,21,.1);font-size:.84rem;line-height:1.45}.provider-note strong,.provider-note span{display:block}.tool-plan{border:1px solid rgba(40,23,21,.1);border-radius:16px;background:#78c9f21a;padding:13px}.tool-plan .panel-heading{margin-bottom:8px}.tool-plan p,.tool-plan li{color:var(--muted);font-size:.82rem;line-height:1.38}.tool-plan p{margin-bottom:9px}.tool-plan ul{margin:9px 0 0;padding-left:18px}.tool-tags{display:flex;flex-wrap:wrap;gap:6px}.tool-tags span{border-radius:999px;padding:5px 7px;background:#ffffffb3;color:#4d5d64;font-size:.7rem;font-weight:850}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:24px;background:#2c26207a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.player-shell,.map-shell,.practice-shell{width:min(1160px,calc(100vw - 48px));height:min(820px,100%);display:grid;grid-template-rows:auto 1fr auto;overflow:hidden}.player-top,.player-bottom{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(40,23,21,.1)}.player-bottom{border-top:1px solid rgba(40,23,21,.1);border-bottom:0}.progress-dots{display:flex;gap:8px;align-items:center}.progress-dots span{width:12px;height:12px;border-radius:50%;border:1px solid rgba(40,23,21,.22);background:#fffdf6cc;box-shadow:inset 0 1px #ffffffe6}.progress-dots span.filled{background:var(--coin-blue);border-color:var(--coin-border);box-shadow:inset 0 1px #ffffffc7,0 1px #281715c7,0 4px 8px #34221b14}.player-page{min-height:0;overflow:auto;padding:clamp(18px,3vw,42px)}.hook-page{min-height:100%;display:grid;place-items:center;text-align:center}.hook-page h2{max-width:820px;font-family:Fraunces,serif;font-size:clamp(2rem,4vw,4rem);line-height:1.04;letter-spacing:0}.content-page{min-height:100%;display:grid;grid-template-columns:minmax(280px,.68fr) minmax(420px,1.12fr);align-items:start;align-content:start;gap:clamp(22px,4vw,56px);padding-right:clamp(10px,2vw,28px);padding-top:clamp(6px,1.5vh,18px)}.content-page h2,.cards-page h2,.sheet h2,.map-shell h2{margin-bottom:12px;font-family:Fraunces,serif;font-size:clamp(1.8rem,3vw,3.4rem);line-height:1;letter-spacing:0}.content-page h2{margin-bottom:10px;font-size:clamp(1.45rem,2.15vw,2.55rem);line-height:1.06}.content-page p{color:#51443e;font-size:.96rem;line-height:1.56}.inline-term{border:0;border-bottom:2px solid var(--blue-deep);background:transparent;padding:0 2px;font-weight:850}.term-row{display:flex;gap:8px;flex-wrap:wrap}.term-row button{border:1px solid rgba(40,23,21,.18);border-radius:999px;padding:7px 10px;background:var(--lavender);font-weight:850;font-size:.82rem}.term-popover{position:relative;margin-top:14px;border:1.5px solid var(--ink);border-radius:16px;background:var(--panel);padding:14px;box-shadow:0 14px 28px #34221b24}.term-popover .mini{position:absolute;right:8px;top:8px}.term-popover p{margin:8px 0 12px;font-size:.9rem}.term-popover button:last-child{border:0;background:transparent;color:var(--blue-deep);font-weight:850;padding:0}.cards-page{max-width:1040px;margin:0 auto}.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.sheet-top{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:18px;border-bottom:1px solid rgba(40,23,21,.1)}.sheet-top h2{margin-bottom:0}.map-shell{grid-template-rows:auto 1fr}.map-layout{min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 320px}.mindmap-canvas{position:relative;min-height:0;overflow:hidden;background:linear-gradient(90deg,rgba(120,201,242,.1),transparent 38%),radial-gradient(circle at 18% 50%,rgba(120,201,242,.16),transparent 24%),radial-gradient(circle at 68% 28%,rgba(200,234,216,.22),transparent 28%),#fffdf673}.mindmap-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.mindmap-lines path{fill:none;stroke:#28171542;stroke-width:.5;stroke-linecap:round}.mindmap-node{position:absolute;width:min(240px,30%);min-height:72px;transform:translate(-50%,-50%);border:1.5px solid rgba(40,23,21,.72);border-radius:18px;background:var(--mint);padding:11px 12px;text-align:left;box-shadow:0 5px #2817151f;display:grid;gap:5px}.mindmap-node:nth-of-type(2n){background:var(--lavender)}.mindmap-node:nth-of-type(3n){background:var(--peach)}.mindmap-node.selected{outline:4px solid rgba(120,201,242,.68)}.mindmap-node.locked{opacity:.68}.mindmap-node span{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-size:.62rem;font-weight:850}.mindmap-node strong{line-height:1.18;font-size:.9rem}.mindmap-canvas:before{content:"Left to right learning map";position:absolute;left:18px;top:16px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-size:.66rem;font-weight:850}.concept-detail{border-left:1px solid rgba(40,23,21,.1);padding:22px;display:flex;flex-direction:column;gap:12px;background:#f5efe294}.concept-detail h3{margin-bottom:0;font-size:1.28rem}.concept-detail p{color:var(--muted);line-height:1.5}.practice-shell{background:#fffcf3}.practice-title{font-weight:850;color:var(--muted)}.practice-body{min-height:0;overflow:auto;padding:26px}.practice-stage{min-height:100%;display:grid;grid-template-columns:minmax(260px,.82fr) minmax(360px,1.18fr);gap:clamp(18px,4vw,46px);align-items:center}.practice-visual{border:1.5px solid rgba(40,23,21,.86);border-radius:24px;background:linear-gradient(180deg,#c8ead89e,#fffdf6e6),var(--panel);padding:18px;box-shadow:0 18px 42px #34221b1f}.practice-visual-head{display:flex;align-items:center;gap:8px;margin-bottom:18px;color:var(--muted);font-size:.75rem;font-weight:850;letter-spacing:.07em;text-transform:uppercase}.practice-model{display:grid;gap:14px}.practice-anchor{position:relative;border:1.5px solid var(--ink);border-radius:18px;background:#ffffffb8;padding:14px}.practice-anchor:after{content:"";position:absolute;left:24px;top:calc(100% + 1px);width:2px;height:14px;background:#28171538}.practice-anchor strong,.practice-model-node strong{display:block;line-height:1.2}.practice-anchor small,.practice-model-node small{display:block;margin-top:4px;color:var(--muted);font-size:.78rem;line-height:1.32}.practice-node-stack{display:grid;gap:9px}.practice-model-node{display:grid;grid-template-columns:30px 1fr;gap:10px;align-items:start;border:1px solid rgba(40,23,21,.12);border-radius:16px;background:#ffffff9e;padding:10px}.practice-model-node.primary{background:#d8dcff8a}.practice-model-node>span{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:var(--coin-blue);border:1.5px solid var(--coin-border);box-shadow:var(--coin-shadow);font-weight:850;font-size:.78rem}.practice-model-node:nth-child(2n)>span{background:var(--coin-lavender)}.practice-model-node:nth-child(3n)>span{background:var(--coin-mint)}.practice-model-node.primary>span{background:var(--coin-peach)}.practice-question h2{max-width:820px;font-family:Fraunces,serif;font-size:clamp(1.45rem,2.7vw,3rem);line-height:1.12;letter-spacing:0}.blank{display:inline-block;min-width:clamp(130px,15vw,230px);height:.88em;margin:0 .08em;padding:0 .16em;border-bottom:5px solid var(--blue);color:var(--blue-deep);vertical-align:baseline}.blank.filled{width:auto;height:auto;min-width:0;border-bottom:0;border-radius:999px;background:var(--mint);box-shadow:inset 0 0 0 1.5px #2817152e;padding:.02em .32em .08em}.feedback-box{margin-top:22px;max-width:600px;border-radius:18px;padding:14px 16px;background:var(--mint);border:1px solid rgba(40,23,21,.16)}.feedback-box.wrong{background:#ffd8cf}.feedback-box p{margin:6px 0 0;color:var(--muted)}.practice-options{border-top:1px solid rgba(40,23,21,.1);padding:16px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:10px}.practice-options button:not(.primary-button){border:1.5px solid rgba(40,23,21,.25);border-radius:16px;background:#ffffffa8;min-height:50px;padding:10px;font-weight:850}.practice-options button.selected{outline:3px solid rgba(120,201,242,.58)}.practice-options button.correct{background:var(--mint)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:24;background:#2c262052}.assistant-drawer{position:fixed;z-index:25;left:50%;bottom:18px;transform:translate(-50%);width:min(760px,calc(100% - 24px));overflow:hidden}.assistant-thread{padding:18px;display:grid;gap:10px}.assistant-thread p{margin-bottom:2px;color:var(--muted);line-height:1.45}.assistant-thread button{text-align:left;border:1px solid rgba(40,23,21,.14);border-radius:14px;background:#ffffff9e;padding:11px 12px;font-weight:800}.assistant-input{border-top:1px solid rgba(40,23,21,.1);padding:12px;display:grid;grid-template-columns:1fr auto;gap:8px}.sheet{width:min(720px,100%);padding-bottom:18px}.compact-sheet textarea{width:calc(100% - 36px);margin:18px;resize:vertical}.settings-grid{padding:18px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.settings-grid label{display:grid;gap:7px}.settings-grid label span{color:var(--muted);font-size:.76rem;font-weight:850;text-transform:uppercase;letter-spacing:.07em}.settings-grid .wide{grid-column:1 / -1}.sheet-actions{justify-content:space-between;padding:0 18px}.danger-button{border:1.5px solid #672a24;border-radius:13px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:850;background:#ffd8cf;color:#672a24;padding:0 14px}.confirm-body{padding:18px}.confirm-body p{color:var(--muted);line-height:1.48;margin:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes sweep{0%,35%{transform:translate(-100%)}70%,to{transform:translate(100%)}}@keyframes generation-rise{0%{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes progress-line-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes block-reveal{0%{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes card-pop{0%{opacity:0;transform:translateY(10px) scale(.98) rotate(-.18deg)}72%{opacity:1;transform:translateY(-1px) scale(1.006) rotate(.08deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes bite-card-reveal{0%{opacity:0;transform:translateY(14px) scale(.97) rotate(-.45deg)}72%{opacity:1;transform:translateY(-1px) scale(1.01) rotate(.12deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes dock-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes select-tick{0%{transform:translate(0) rotate(0)}28%{transform:translate(3px) rotate(.55deg)}55%{transform:translate(-2px) rotate(-.35deg)}to{transform:translate(0) rotate(0)}}@media (max-width: 900px){.quiet-pill{display:none}.topbar{width:calc(100% - 48px)}.topic-input-wrap{grid-template-columns:1fr}.prompt-box .primary-button{width:100%}.prompt-box h1{font-size:clamp(1.8rem,7vw,3rem)}}@media (max-width: 1160px){body{overflow:hidden}.quiet-pill{display:none}.nav-actions .icon-text-button{width:42px;padding:0}.nav-actions .icon-text-button span{display:none}.app-shell{min-height:0;height:100%}.composer,.composer.compact{grid-template-columns:1fr}.course-header{grid-template-columns:auto minmax(0,1fr) auto}.lesson-lobby{min-height:0}.bite-sequence-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.practice-stage{grid-template-columns:1fr;align-items:start}}@media (max-width: 760px){body{overflow:auto}.app-shell{padding:12px;min-height:100%;height:auto}.topbar{align-items:flex-start}.quiet-pill{display:none}.composer,.composer.compact{padding:14px;border-radius:18px}.topic-input-wrap{grid-template-columns:1fr}.course-header{grid-template-columns:auto minmax(0,1fr)}.course-title-actions{grid-column:1 / -1;justify-content:flex-start}.primary-button{width:100%}.course-card-cta{align-items:stretch;flex-direction:column}.course-card-cta .primary-button{width:auto}.experience{height:auto;overflow:visible;grid-template-columns:1fr}.course-leftbar,.course-card{height:auto;max-height:none}.course-leftbar,.path-panel,.memory-panel{overflow:visible}.content-page,.map-layout{grid-template-columns:1fr}.structured-visual{min-height:320px}.visual-node{width:min(132px,42vw)}.visual-note-rail{grid-template-columns:1fr}.visual-note{grid-template-columns:24px 1fr}.flow-visual,.flow-visual.compare,.card-grid,.practice-options,.settings-grid,.bite-sequence-grid{grid-template-columns:1fr}.player-shell,.map-shell,.practice-shell{height:100%;border-radius:18px}.overlay{padding:10px}.practice-body{padding:16px}.practice-question h2{font-size:clamp(1.45rem,8vw,2.55rem)}.blank{min-width:130px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.onboarding-overlay{display:flex;align-items:center;justify-content:center}.onboarding-card{background:var(--panel);border:1.5px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);max-width:420px;width:100%;padding:36px 32px 28px;text-align:center}.onboarding-progress{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.onboarding-progress span{width:10px;height:10px;border-radius:50%;background:var(--line);transition:background .3s var(--ease-out-quart)}.onboarding-progress span.filled{background:var(--blue)}.onboarding-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--mint),var(--blue));display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.onboarding-icon svg{width:28px;height:28px;stroke:var(--ink)}.onboarding-card h2{margin-bottom:12px}.onboarding-card p{color:var(--muted);font-size:.95rem;line-height:1.6;margin-bottom:24px}.onboarding-actions{display:flex;gap:12px;justify-content:center}.discuss-fab{position:absolute;bottom:16px;right:16px;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line);background:var(--panel);box-shadow:0 4px 16px #34221b1a;display:flex;align-items:center;justify-content:center;transition:transform .2s var(--ease-out-quart),box-shadow .2s var(--ease-out-quart);z-index:5}.discuss-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #34221b26}.discuss-fab svg{width:20px;height:20px;stroke:var(--blue-deep)}.hook-page,.cards-page,.content-page>div:first-child{position:relative}.flag-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.knowledge-card:hover .flag-btn{opacity:1}.flag-btn svg{width:14px;height:14px;stroke:var(--muted)}.flag-btn:hover svg{stroke:var(--rose)}.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px 12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-card svg{width:22px;height:22px;stroke:var(--blue-deep);margin-bottom:4px}.stat-card strong{font-size:1.5rem;font-weight:800;color:var(--ink)}.stat-card span{font-size:.8rem;color:var(--muted)}.dashboard-reminder{background:linear-gradient(135deg,var(--mint),rgba(200,234,216,.5));border:1px solid rgba(103,185,130,.3);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:10px;margin-bottom:16px;font-weight:650;font-size:.92rem}.dashboard-reminder svg{width:20px;height:20px;stroke:var(--green);flex-shrink:0}
