:root{color-scheme:light;font-family:Bricolage Grotesque,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#eee1cf;color:#1d1916;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--paper: #fff7e8;--paper-strong: #fffdf6;--paper-soft: #f7eddb;--ink: #1d1916;--muted: #6f6256;--muted-strong: #50463e;--line: #d4c2aa;--line-strong: #b89f82;--charcoal: #241f1a;--green: #25724f;--blue: #235e84;--danger: #9d372b;--sun: #c99124;--coral: #d94f3c;--teal: #087f78;--violet: #6f4bb7;--plum: #552947;--shadow: 0 22px 58px rgba(46, 34, 21, .16);--shadow-soft: 0 12px 30px rgba(46, 34, 21, .1);--texture: url(/brand/print-texture.webp)}*{box-sizing:border-box}html{min-width:320px;background:linear-gradient(180deg,#fffaf0c2,#e8d6beeb),#eee1cf}body{position:relative;margin:0;min-width:320px;min-height:100vh;background:linear-gradient(90deg,rgba(36,31,26,.035) 1px,transparent 1px),var(--texture),#eee1cf;background-size:72px 72px,min(1000px,110vw) auto,auto;background-position:center top,center 18px,center;background-attachment:scroll,fixed,scroll}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#fff7e8e6,#eee1cfd1 58%,#deccb2eb),linear-gradient(90deg,#55294714,#087f780e 46%,#c9912414);mix-blend-mode:normal;z-index:0}button,input{font:inherit;max-width:100%}button{cursor:pointer;line-height:1.15;text-wrap:balance}button:disabled{cursor:not-allowed;opacity:.52}a{color:inherit;text-decoration:none}::selection{background:#d94f3c38}:focus-visible{outline:3px solid rgba(8,127,120,.38);outline-offset:3px}main{position:relative;z-index:1;width:min(1480px,calc(100% - 28px));margin:0 auto;padding:22px 0 34px}.app-header,.app-footer{display:flex;align-items:flex-start;justify-content:space-between;gap:clamp(16px,3vw,34px)}.brand-block{display:grid;gap:10px;min-width:0;max-width:720px}.brand{display:inline-flex;align-items:center;gap:12px;width:fit-content;font-family:Fraunces,Georgia,serif;font-weight:950;font-size:2.55rem;line-height:.92;color:var(--ink)}.brand-mark{position:relative;display:inline-grid;place-items:center;width:52px;height:52px;border-radius:15px;background:linear-gradient(135deg,#1f1a15,#3b2b22),var(--charcoal);box-shadow:0 12px 28px #342b1f2e;isolation:isolate}.brand-mark:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;z-index:-1;border:1px solid rgba(217,79,60,.28);border-radius:18px;transform:rotate(-3deg)}.brand-mark svg{display:block;width:52px;height:52px;border-radius:15px}.brand-mark rect{fill:var(--paper)}.brand-mark path{fill:var(--charcoal)}.brand-mark circle{fill:var(--coral)}.brand-mark path:last-child{fill:none;stroke:var(--teal);stroke-width:4;stroke-linecap:round}.brand-word b{color:var(--coral);font-weight:inherit}.brand-word{display:inline-flex;align-items:baseline}.brand-block p,.dashboard-intro p,.stream-panel p,.system-item span,.app-footer span{margin:0;color:var(--muted);line-height:1.58;overflow-wrap:anywhere}.social-nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.header-actions{display:grid;justify-items:end;gap:10px;min-width:0}.app-nav,.stream-switcher{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:9px;min-width:0}.app-nav button,.stream-switcher button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border:1px solid rgba(36,31,26,.14);border-radius:999px;padding:9px 14px;background:linear-gradient(180deg,#fffdf6eb,#f7eddbd1),var(--texture);background-size:auto,420px auto;color:var(--muted-strong);font-weight:900;box-shadow:0 8px 18px #2e22150f;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease}.app-nav button svg,.stream-switcher button svg{flex:0 0 auto}.app-nav button:hover,.stream-switcher button:hover{transform:translateY(-1px);border-color:#241f1a4d}.app-nav button.active,.stream-switcher button.active{border-color:var(--charcoal);background:linear-gradient(135deg,var(--charcoal),#3a2921),var(--charcoal);color:#fffaf0;box-shadow:0 14px 28px #241f1a2e}.social-nav a,.app-footer a,.ghost-button,.secondary-button,.danger-button,.primary-button,.study-button,.play-button{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:42px;border-radius:8px;border:1px solid rgba(36,31,26,.16);padding:10px 14px;background:linear-gradient(180deg,#fffdf6f5,#f7eddbdb),var(--texture);background-size:auto,520px auto;color:var(--ink);font-weight:800;line-height:1.15;text-align:center;box-shadow:0 8px 18px #2e22150f;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.ghost-button svg,.secondary-button svg,.danger-button svg,.primary-button svg,.study-button svg,.play-button svg{flex:0 0 auto}.social-nav a:hover,.ghost-button:hover,.secondary-button:hover,.danger-button:hover,.primary-button:hover,.study-button:hover,.play-button:hover,.app-footer a:hover{transform:translateY(-1px);border-color:var(--line-strong);box-shadow:0 12px 24px #2e22151a}.dashboard-band{position:relative;overflow:hidden;display:grid;gap:clamp(20px,3vw,34px);margin:28px 0;padding:clamp(20px,3.2vw,42px);border:1px solid rgba(36,31,26,.14);border-radius:8px;background:linear-gradient(180deg,#fffdf6f2,#fff7e8db),var(--texture),var(--paper);background-size:auto,980px auto,auto;background-position:center,right top,center;box-shadow:var(--shadow);animation:pageIn .26s ease both}.dashboard-band:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(90deg,rgba(217,79,60,.09),transparent 28%),linear-gradient(180deg,rgba(85,41,71,.06),transparent 42%),repeating-linear-gradient(90deg,rgba(36,31,26,.035) 0 1px,transparent 1px 42px)}.dashboard-band>*{position:relative;z-index:1}.dashboard-intro{display:grid;max-width:820px;gap:13px}.hero-note{display:flex;align-items:flex-start;gap:10px;max-width:740px;border-left:4px solid var(--plum);border-radius:8px;padding:12px 14px;background:#55294714;color:#3f2238;font-weight:850;line-height:1.45}.hero-note svg{flex:0 0 auto;margin-top:2px}.hero-receipts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-width:900px;padding-top:3px}.hero-receipts span{display:grid;gap:4px;min-height:92px;border:1px solid rgba(36,31,26,.12);border-radius:8px;padding:13px 14px;background:#fffdf69e;box-shadow:var(--shadow-soft)}.hero-receipts strong{font-family:Fraunces,Georgia,serif;font-size:1.85rem;line-height:1}.hero-receipts em{color:var(--muted);font-size:.83rem;font-style:normal;font-weight:850;line-height:1.3}.general-level-card{display:grid;grid-template-columns:minmax(190px,auto) minmax(260px,1fr);align-items:center;gap:16px 20px;max-width:900px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:16px;background:linear-gradient(135deg,#55294717,#f25f4c14),#fffdf6c7;box-shadow:var(--shadow-medium)}.general-level-main{display:flex;align-items:center;gap:13px;min-width:0}.general-level-seal{display:grid;place-items:center;flex:0 0 auto;width:52px;height:52px;border-radius:50%;color:#fff9e8;background:radial-gradient(circle at 28% 25%,#f0b429,var(--plum) 62%,#241f1a);box-shadow:0 14px 28px #55294742}.general-level-main>div{display:grid;gap:2px;min-width:0}.general-level-main span:not(.general-level-seal){color:var(--muted-strong);font-size:.77rem;font-weight:950;line-height:1.2;text-transform:uppercase}.general-level-main strong{font-family:Fraunces,Georgia,serif;font-size:2.6rem;line-height:.95}.general-level-card p{margin:0;color:#402c37;font-weight:760;line-height:1.5}.general-level-bars{display:grid;grid-column:1 / -1;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.general-level-bars span{display:flex;align-items:center;justify-content:space-between;min-height:42px;gap:10px;border:1px solid color-mix(in srgb,var(--stream-color),transparent 72%);border-radius:8px;padding:8px 10px;background:color-mix(in srgb,var(--stream-color),transparent 90%)}.general-level-bars em{flex:0 0 auto;color:color-mix(in srgb,var(--stream-color),#241f1a 24%);font-size:.78rem;font-style:normal;font-weight:950;line-height:1}.general-level-bars strong{min-width:0;color:#241f1a;font-size:.9rem;font-weight:950;line-height:1.1;text-align:right}.eyebrow{display:inline-flex;align-items:center;gap:8px;width:fit-content;max-width:100%;color:var(--muted-strong);font-size:.78rem;font-weight:900;text-transform:uppercase;line-height:1.2}.eyebrow svg{flex:0 0 auto}h1,h2,h3{margin:0;letter-spacing:0}h1{max-width:980px;font-family:Fraunces,Georgia,serif;font-size:4.35rem;line-height:1.02;text-wrap:balance}h2{font-family:Fraunces,Georgia,serif;font-size:2.25rem;line-height:1.08;text-wrap:balance}.stream-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.stream-panel{position:relative;overflow:hidden;display:grid;grid-template-rows:auto 198px minmax(66px,auto) minmax(54px,auto) auto;gap:15px;min-height:396px;border:1px solid rgba(36,31,26,.13);border-top:6px solid var(--stream-color);border-radius:8px;padding:17px;background:linear-gradient(180deg,#fffdf6f0,#fff7e8d6),var(--texture),color-mix(in srgb,var(--stream-color) 8%,var(--paper));background-size:auto,620px auto,auto;background-position:center,center top,center;box-shadow:var(--shadow-soft);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.stream-panel:after{content:"";position:absolute;inset:auto 14px 64px 14px;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--stream-color) 45%,transparent),transparent);opacity:.75}.stream-panel:hover{transform:translateY(-3px);box-shadow:0 22px 44px color-mix(in srgb,var(--stream-color) 16%,rgba(46,34,21,.12))}.stream-panel.active{border-color:color-mix(in srgb,var(--stream-color) 50%,var(--line));box-shadow:0 20px 45px color-mix(in srgb,var(--stream-color) 18%,transparent)}.stream-select{display:flex;align-items:flex-start;gap:12px;width:100%;border:0;padding:0;background:transparent;color:var(--ink);text-align:left}.stream-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 44px;width:44px;height:44px;border-radius:8px;background:linear-gradient(180deg,color-mix(in srgb,var(--stream-color) 20%,white),color-mix(in srgb,var(--stream-color) 10%,white));color:var(--stream-accent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--stream-color) 18%,transparent)}.stream-select strong{display:block;font-size:1.18rem;line-height:1.1}.stream-select small{display:block;color:var(--muted);line-height:1.32;margin-top:3px}.level-ring-wrap{display:grid;place-items:center;gap:10px;align-self:center;min-height:190px}.level-ring{display:grid;place-items:center;align-content:center;width:154px;height:154px;border-radius:50%;background:radial-gradient(circle at center,var(--paper) 0 58%,transparent 59%),conic-gradient(var(--stream-color) var(--ring-progress),rgba(33,31,29,.12) 0);box-shadow:inset 0 0 0 1px #211f1d14}.level-ring span{color:var(--stream-accent);font-size:.76rem;font-weight:950}.level-ring strong{font-family:Fraunces,Georgia,serif;font-size:3rem;line-height:.95}.level-ring em{color:var(--muted);font-size:.72rem;font-style:normal;font-weight:850}.ring-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:7px}.ring-meta span,.mode-list span,.library-stats span,.question-meta span,.answer-pill,.tap-list{display:inline-flex;align-items:center;min-height:30px;border:1px solid rgba(33,31,29,.1);border-radius:999px;padding:6px 10px;background:#fffdf6ad;color:var(--muted-strong);font-size:.78rem;font-weight:800;line-height:1.25;overflow-wrap:anywhere}.mode-list{display:flex;flex-wrap:wrap;gap:6px}.study-button,.primary-button{border-color:var(--charcoal);background:linear-gradient(135deg,var(--charcoal),#3a2921),var(--charcoal);color:#fffaf0}.study-button{width:100%;margin-top:auto;position:relative;z-index:1}.stream-field-note{display:block;color:var(--muted-strong);font-size:.86rem;font-weight:850;line-height:1.42;overflow-wrap:anywhere}.workspace{display:grid;gap:18px;animation:pageIn .24s ease both}.page-view{margin-top:28px}.workspace-head,.study-head,.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:clamp(14px,2vw,24px);min-width:0}.workspace-head>div,.study-head>div,.section-title>div{min-width:0}.library-stats,.question-meta{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.library-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.library-card{position:relative;overflow:hidden;display:grid;align-content:start;gap:13px;min-height:250px;border:1px solid rgba(36,31,26,.13);border-top:6px solid var(--stream-color);border-radius:8px;padding:16px;background:linear-gradient(180deg,#fffdf6eb,#fff7e8d6),var(--texture),#fffaf0e6;background-size:auto,600px auto,auto;box-shadow:var(--shadow-soft)}.library-card>div:first-child{display:flex;align-items:center;gap:10px}.library-card h3{font-family:Fraunces,Georgia,serif;font-size:1.35rem;line-height:1.1}.library-card p{margin:0;color:var(--muted);line-height:1.5}.library-card-note{border-top:1px solid rgba(33,31,29,.09);padding-top:12px;font-size:.9rem}.recipe-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.recipe-strip article{display:grid;gap:8px;border:1px solid rgba(36,31,26,.13);border-radius:8px;padding:16px;background:linear-gradient(180deg,#fffdf6f5,#f7eddbc7),var(--paper-strong);box-shadow:var(--shadow-soft)}.recipe-strip strong{font-size:1.02rem}.recipe-strip span{color:var(--blue);font-weight:900;line-height:1.3}.recipe-strip p{margin:0;color:var(--muted);line-height:1.45}.study-shell{position:relative;overflow:hidden;display:grid;gap:20px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:clamp(16px,2.5vw,26px);background:linear-gradient(180deg,#fffdf6f5,#fff7e8db),var(--texture),#fffdf7;background-size:auto,960px auto,auto;box-shadow:var(--shadow)}.study-shell>*{position:relative;z-index:1}.session-progress-card{display:grid;justify-items:end;gap:4px;min-width:176px;max-width:280px;border:1px solid rgba(33,31,29,.1);border-radius:8px;padding:12px 14px;background:#fffdf6b8;color:var(--muted-strong);text-align:right;box-shadow:var(--shadow-soft)}.session-progress-card strong{font-family:Fraunces,Georgia,serif;font-size:1.55rem;line-height:1;color:var(--ink)}.session-progress-card span,.session-progress-card em{font-size:.78rem;font-weight:900;line-height:1.25}.session-progress-card em{color:var(--muted);font-style:normal}.session-progress-bar{overflow:hidden;height:10px;border-radius:999px;background:#211f1d14;box-shadow:inset 0 0 0 1px #211f1d0a}.session-progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--coral),var(--teal) 58%,var(--plum));transition:width .22s ease}.session-complete-shell{min-height:min(620px,calc(100vh - 180px));align-content:center;gap:22px;padding-block:clamp(24px,5vw,52px);background:linear-gradient(135deg,#fffdf6f5,#f6ebd8eb 52%,#ebf2ece0),var(--texture),#fffdf7}.confetti-field{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.confetti-field span{--x: 0px;--r: 220deg;position:absolute;top:-34px;left:50%;width:8px;height:15px;border-radius:2px;background:var(--coral);opacity:0;transform:translate3d(0,-40px,0) rotate(0);animation:confetti-drop 3.8s cubic-bezier(.24,.62,.36,1) infinite}.confetti-field span:nth-child(2n){height:10px;background:var(--teal)}.confetti-field span:nth-child(3n){width:12px;background:var(--sun)}.confetti-field span:nth-child(4n){background:var(--violet)}.confetti-field span:nth-child(1){left:4%;--x: 24px;--r: 310deg;animation-delay:.05s}.confetti-field span:nth-child(2){left:9%;--x: -14px;--r: 190deg;animation-delay:.42s}.confetti-field span:nth-child(3){left:14%;--x: 36px;--r: 420deg;animation-delay:.16s}.confetti-field span:nth-child(4){left:19%;--x: -28px;--r: 260deg;animation-delay:.74s}.confetti-field span:nth-child(5){left:24%;--x: 20px;--r: 510deg;animation-delay:1.05s}.confetti-field span:nth-child(6){left:30%;--x: -36px;--r: 350deg;animation-delay:.28s}.confetti-field span:nth-child(7){left:36%;--x: 44px;--r: 230deg;animation-delay:.86s}.confetti-field span:nth-child(8){left:41%;--x: -18px;--r: 390deg;animation-delay:1.18s}.confetti-field span:nth-child(9){left:47%;--x: 30px;--r: 540deg;animation-delay:.36s}.confetti-field span:nth-child(10){left:52%;--x: -42px;--r: 280deg;animation-delay:.66s}.confetti-field span:nth-child(11){left:57%;--x: 16px;--r: 460deg;animation-delay:1.32s}.confetti-field span:nth-child(12){left:62%;--x: -26px;--r: 215deg;animation-delay:.12s}.confetti-field span:nth-child(13){left:68%;--x: 38px;--r: 365deg;animation-delay:.58s}.confetti-field span:nth-child(14){left:73%;--x: -20px;--r: 505deg;animation-delay:1.02s}.confetti-field span:nth-child(15){left:78%;--x: 28px;--r: 245deg;animation-delay:.24s}.confetti-field span:nth-child(16){left:84%;--x: -34px;--r: 415deg;animation-delay:.92s}.confetti-field span:nth-child(17){left:89%;--x: 18px;--r: 570deg;animation-delay:1.24s}.confetti-field span:nth-child(18){left:94%;--x: -30px;--r: 330deg;animation-delay:.48s}.confetti-field span:nth-child(n+19){animation-delay:1.55s;animation-duration:4.4s}@keyframes confetti-drop{0%{opacity:0;transform:translate3d(0,-42px,0) rotate(0)}9%{opacity:.95}to{opacity:0;transform:translate3d(var(--x),min(720px,96vh),0) rotate(var(--r))}}.session-complete-hero{display:grid;gap:10px;max-width:760px}.completion-kicker{display:inline-flex;align-items:center;gap:8px;width:fit-content;border:1px solid rgba(37,114,79,.24);border-radius:999px;padding:7px 11px;background:#25724f1f;color:#174d33;font-size:.78rem;font-weight:950;text-transform:uppercase}.session-complete-hero h2{max-width:780px;margin:0;color:var(--ink);font-family:Fraunces,Georgia,serif;font-size:clamp(2rem,5vw,4.5rem);line-height:.98;text-wrap:balance}.session-complete-hero p{max-width:680px;margin:0;color:var(--muted-strong);font-size:clamp(1rem,1.6vw,1.22rem);font-weight:850;line-height:1.42}.completion-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));border-block:1px solid rgba(36,31,26,.13)}.completion-stats span{display:grid;gap:4px;padding:18px 16px;border-inline-end:1px solid rgba(36,31,26,.1)}.completion-stats span:last-child{border-inline-end:0}.completion-stats strong{color:var(--ink);font-family:Fraunces,Georgia,serif;font-size:clamp(1.8rem,4vw,3.2rem);line-height:1}.completion-stats em{color:var(--muted);font-style:normal;font-weight:900}.completion-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.completion-details>div{display:grid;align-content:start;gap:10px;border-inline-start:5px solid var(--blue);padding:14px 16px;background:#fffdf6b8}.completion-details .unlocked-detail{border-inline-start-color:var(--green);background:#25724f1a}.completion-details strong{color:var(--ink);font-size:.9rem;font-weight:950}.completion-details p,.completion-details ul{margin:0;color:var(--muted-strong);font-weight:850;line-height:1.42}.completion-details ul{display:grid;gap:6px;padding-inline-start:18px}.completion-actions{display:flex;flex-wrap:wrap;gap:10px}@media(prefers-reduced-motion:reduce){.confetti-field span{animation:none;opacity:.22;transform:translate3d(0,18px,0) rotate(24deg)}}.practice-view{margin-top:28px}.empty-state{min-height:220px;place-items:center;text-align:center}.question-layout{display:grid;grid-template-columns:minmax(240px,.88fr) minmax(360px,1.12fr);gap:20px;align-items:start;min-width:0}.question-main,.answer-panel{display:grid;align-content:start;gap:16px;min-width:0}.stimulus-label{display:flex;align-items:flex-start;gap:11px;border:1px solid rgba(35,94,132,.16);border-left:4px solid var(--blue);border-radius:8px;padding:12px 14px;background:#235e8412;color:#173d56}.stimulus-label>svg{flex:0 0 auto;margin-top:2px}.stimulus-label span{display:grid;gap:2px}.stimulus-label strong{font-size:.9rem}.stimulus-label em{color:#496a7a;font-size:.82rem;font-style:normal;font-weight:750;line-height:1.42}.notation{overflow-x:auto;min-height:150px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:10px;background:linear-gradient(180deg,#fffffff5,#fffbf3eb),var(--paper-strong);box-shadow:inset 0 0 0 1px #ffffff7a}.play-button{width:fit-content;border-color:var(--blue);background:linear-gradient(135deg,var(--blue),#173d56),var(--blue);color:#fff}.procedural-note{display:flex;gap:11px;align-items:flex-start;border-left:4px solid var(--teal);padding:12px 14px;border-radius:8px;background:#087f7817;color:#214847;line-height:1.48;font-weight:800}.given-card{display:grid;gap:6px;border:1px solid rgba(33,31,29,.1);border-radius:8px;padding:16px;background:linear-gradient(180deg,#fffdf6f0,#f7eddbc7),var(--paper-strong);box-shadow:var(--shadow-soft)}.given-card span{color:var(--muted);font-size:.76rem;font-weight:900;text-transform:uppercase}.given-card strong{font-family:Fraunces,Georgia,serif;font-size:2rem;line-height:1}.rhythm-guide{display:grid;gap:6px;border:1px solid rgba(217,79,60,.18);border-left:4px solid var(--coral);border-radius:8px;padding:12px 14px;background:#d94f3c14;color:#693026;line-height:1.4}.rhythm-guide strong{font-size:.9rem}.rhythm-guide span,.rhythm-guide em{font-size:.82rem;font-style:normal;font-weight:800}.rhythm-guide em{color:#7b544d}.theory-image{margin:0;display:grid;gap:6px}.theory-image img{display:block;width:100%;max-height:360px;object-fit:contain;border:1px solid rgba(36,31,26,.14);border-radius:8px;background:#f3eadb;box-shadow:var(--shadow-soft)}.theory-image-fallback{min-height:260px;border:1px solid var(--line);border-radius:8px;background:#f3eadb;color:var(--muted);display:grid;place-items:center;align-content:center;gap:8px;text-align:center;padding:24px}.theory-image-fallback span{color:var(--ink);font-weight:900}.theory-image-fallback em{max-width:34ch;font-size:.82rem;font-style:normal}.theory-image figcaption{color:var(--muted);font-size:.78rem}.answer-panel{border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:clamp(14px,1.6vw,20px);background:linear-gradient(180deg,#fffdf6e0,#f7eddbc7),var(--paper-soft);overflow:hidden;box-shadow:var(--shadow-soft)}.task-guide{display:grid;gap:12px;border-left:4px solid var(--blue);border-radius:8px;padding:13px 14px;background:#235e8414;color:#173d56}.task-guide-head{display:flex;align-items:flex-start;gap:10px}.task-guide-head>svg{flex:0 0 auto;margin-top:2px}.task-guide-head span{display:grid;gap:3px}.task-guide-head strong{font-size:.98rem}.task-guide-head em{color:#496a7a;font-size:.84rem;font-style:normal;font-weight:750;line-height:1.44}.task-steps{display:grid;gap:7px;margin:0;padding-left:23px;color:#254e70;font-size:.9rem;line-height:1.42}.task-steps li::marker{font-weight:900}.answer-section-title{display:inline-flex;align-items:center;gap:7px;color:#4a4239;font-size:.86rem;font-weight:900}.practice-banner{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.practice-banner{justify-content:space-between;border:1px solid rgba(35,94,132,.16);border-radius:8px;padding:11px 13px;background:#235e8414;color:#173d56;font-weight:850;line-height:1.35}.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.choice,.piano-key{min-height:52px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:10px 12px;background:linear-gradient(180deg,#fff,#fbf3e6),#fff;color:var(--ink);font-weight:850;line-height:1.22;box-shadow:0 8px 16px #2e22150d;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.choice:hover,.piano-key:hover{transform:translateY(-1px);border-color:var(--line-strong)}.choice.selected{border-color:var(--green);background:#25724f24;box-shadow:0 10px 22px #25724f1f}.text-answer{display:grid;gap:8px;font-weight:850}.text-answer input{width:100%;min-height:50px;border:1px solid rgba(36,31,26,.16);border-radius:8px;padding:12px 14px;background:#fffdf7;color:var(--ink);box-shadow:inset 0 1px #ffffffb8}.input-panel,.tap-panel{display:grid;gap:12px;border:1px solid rgba(33,31,29,.12);border-radius:8px;padding:14px;background:linear-gradient(180deg,#fffdf6db,#f7eddbb3),var(--texture),#ffffff94;background-size:auto,520px auto,auto;box-shadow:var(--shadow-soft)}.input-panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;min-width:0}.input-panel-header span{display:inline-flex;align-items:center;gap:8px;font-weight:900;line-height:1.25;min-width:0;overflow-wrap:anywhere}.input-panel-header svg{flex:0 0 auto}.piano{display:grid;grid-template-columns:repeat(6,minmax(42px,1fr));gap:7px}.piano-key{aspect-ratio:1 / 1.08;min-height:54px}.piano-key.sharp{background:#27231f;color:#fffaf0}.note-entry,.rhythm-entry{display:grid;gap:12px;border:1px solid rgba(33,31,29,.1);border-radius:8px;padding:14px;background:linear-gradient(180deg,#fffdf6db,#f7eddbb8),#ffffff9e;min-width:0;box-shadow:var(--shadow-soft)}.note-entry-actions{display:flex;gap:7px}.entry-staff{min-height:92px;overflow:auto;border:1px solid rgba(36,31,26,.14);border-radius:8px;background:#fffdf7}.rhythm-staff{min-height:80px}.entry-staff>span{display:grid;min-height:92px;place-items:center;padding:14px;color:var(--muted);text-align:center;line-height:1.4;font-weight:750}.selected-notes{display:flex;flex-wrap:wrap;gap:7px;min-height:34px}.selected-notes button,.selected-notes span{display:inline-flex;align-items:center;min-height:32px;border:1px solid rgba(35,94,132,.18);border-radius:999px;padding:6px 11px;background:#235e8414;color:#173d56;font-size:.8rem;font-weight:900;line-height:1.2}.selected-notes span{border-color:#211f1d14;background:#fffaf0e6;color:var(--muted)}.mini-note-editor{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:stretch}.editor-octaves{display:grid;gap:6px}.editor-octaves button{min-width:40px;min-height:36px;border:1px solid rgba(33,31,29,.12);border-radius:8px;background:#fffdf7;color:var(--ink);font-weight:950}.editor-octaves button.selected{border-color:var(--blue);background:#235e841f;color:#173d56}.staff-picker{position:relative;display:grid;grid-template-columns:repeat(7,minmax(34px,1fr));align-items:center;min-height:116px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:10px;background:repeating-linear-gradient(0deg,transparent 0,transparent 14px,rgba(33,31,29,.18) 15px,transparent 16px),#fff}.staff-picker button{position:relative;grid-row:var(--staff-row);align-self:center;justify-self:center;width:34px;height:28px;border:1px solid #211f1d;border-radius:50%;background:#211f1d;color:#fffaf0;font-size:.72rem;font-weight:950;box-shadow:0 6px 10px #211f1d29}.duration-toolbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.duration-button{display:grid;gap:5px;min-height:66px;border:1px solid rgba(35,94,132,.14);border-radius:8px;padding:10px;background:linear-gradient(180deg,#fffdf7,#f8efdf),#fffdf7;color:var(--ink);text-align:left;box-shadow:0 8px 16px #2e22150d}.duration-button strong{font-size:1rem;color:#173d56}.duration-button span{color:var(--muted);font-size:.72rem;font-weight:850;line-height:1.2}.duration-button.rest{border-color:#a83d2d29;background:#a83d2d14}.rhythm-sequence button{border-color:#d94f3c3d;background:#d94f3c17;color:#7a1f15}.piano-keyboard{position:relative;min-height:136px;padding-top:2px;max-width:100%;overflow-x:auto}.white-keys{display:grid;grid-template-columns:repeat(var(--white-count),minmax(24px,1fr));gap:2px;height:136px;min-width:430px}.white-key{position:relative;display:flex;align-items:flex-end;justify-content:center;min-width:0;border:1px solid #cfc4b4;border-radius:0 0 6px 6px;padding:0 3px 10px;background:linear-gradient(#fff,#f8f0e3);color:#3a342e;font-size:.74rem;font-weight:900;box-shadow:inset 0 -10px 18px #342b1f12}.white-key:hover{background:linear-gradient(#fff,#efe2ce)}.black-key{position:absolute;top:2px;z-index:2;width:calc(68% / var(--white-count));height:82px;transform:translate(-50%);border:1px solid #16120f;border-radius:0 0 5px 5px;background:linear-gradient(90deg,#171310,#332c26 58%,#0f0d0b);color:#fffaf0;font-size:.65rem;font-weight:900;box-shadow:0 8px 14px #211f1d47}.black-key:hover{background:linear-gradient(90deg,#0d0b09,#4b4036 58%,#0f0d0b)}.tap-panel{grid-template-columns:minmax(120px,1fr) auto}.tap-target{min-height:124px;border:0;border-radius:8px;background:linear-gradient(135deg,#b7362b,var(--coral) 52%,#e07a43),var(--coral);color:#fffaf0;font-size:1.55rem;font-weight:950;box-shadow:inset 0 0 0 1px #fffaf033,0 14px 24px #9d372b33}.icon-button{display:inline-grid;place-items:center;width:44px;min-height:44px;border:1px solid rgba(36,31,26,.16);border-radius:8px;background:linear-gradient(180deg,#fffdf7,#f5ead8),#fffaf0}.tap-list{grid-column:1 / -1;justify-content:flex-start;overflow-wrap:anywhere;border-radius:8px}.pitch-readout{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:60px;border-radius:8px;padding:12px 14px;background:#fffdf7;border:1px solid rgba(36,31,26,.14)}.pitch-readout strong{font-size:1.35rem}.detected-notes{display:grid;gap:6px;min-height:62px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:12px 14px;background:#fffaf0d1}.detected-notes span{color:var(--muted);font-size:.75rem;font-weight:900;text-transform:uppercase}.detected-notes strong{overflow-wrap:anywhere;font-size:1.05rem}.full{width:100%}.danger-button{border-color:var(--danger);background:linear-gradient(135deg,var(--danger),#6f241a),var(--danger);color:#fffaf0}.secondary-button{border-color:var(--blue);background:#235e841a;color:#173d56}.answer-actions{display:grid;grid-template-columns:1fr;gap:10px}.action-hint{color:var(--muted);font-size:.82rem;font-weight:800;line-height:1.42}.grade{display:grid;gap:6px;border-radius:8px;padding:13px 14px;line-height:1.44;border:1px solid transparent}.grade em{color:inherit;font-style:normal;font-weight:850;opacity:.9}.grade.correct{border-color:#25724f38;background:#25724f21;color:#174d33}.grade.hard,.grade.partial1{border-color:#c9912440;background:#c991242b;color:#654506}.grade.partial2,.grade.fail{border-color:#9d372b40;background:#9d372b21;color:#6f241a}.tree-section{position:relative;overflow:hidden;display:grid;gap:18px;margin-top:4px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:clamp(14px,2vw,20px);background:linear-gradient(180deg,#fffdf6eb,#f7eddbd1),var(--texture),#fffaf0d1;background-size:auto,980px auto,auto;box-shadow:0 18px 48px #342b1f1a;animation:pageIn .24s ease both}.section-title span{font-size:1.15rem;font-weight:950;line-height:1.18}.section-title small{color:var(--muted);font-weight:800;line-height:1.38}.tree-summary{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.tree-summary span{display:inline-flex;align-items:center;min-height:30px;border:1px solid rgba(33,31,29,.1);border-radius:999px;padding:6px 11px;background:#fffdf69e;color:var(--muted-strong);font-size:.78rem;font-weight:900;line-height:1.2}.tree-guide{display:flex;flex-wrap:wrap;gap:9px}.tree-guide span{display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(33,31,29,.09);border-radius:999px;padding:8px 11px;background:#fffdf69e;color:var(--muted-strong);font-size:.78rem;font-weight:900;line-height:1.2}.mini-external-dot{width:13px;height:13px;border-radius:50%;background:linear-gradient(135deg,var(--coral),var(--teal) 55%,var(--plum))}.learning-map{position:relative;display:grid;gap:14px;padding:14px 2px 18px}.learning-map-spine{position:absolute;top:34px;bottom:34px;left:33px;width:4px;border-radius:999px;background:linear-gradient(180deg,var(--green),var(--sun) 48%,var(--coral));opacity:.28}.map-row{position:relative;display:grid;grid-template-columns:70px minmax(230px,460px) minmax(210px,1fr);gap:14px;align-items:center;min-width:0;transform:translate(var(--row-offset))}.map-row:before{content:"";position:absolute;left:35px;right:calc(100% - 84px);height:2px;border-radius:999px;background:#211f1d24}.map-row.with-cross:after{content:"";position:absolute;left:min(544px,calc(100% - 260px));right:160px;height:2px;border-radius:999px;background:linear-gradient(90deg,#211f1d21,#211f1d00)}.map-level{position:relative;z-index:2;display:inline-grid;place-items:center;justify-self:start;width:66px;height:66px;border:4px solid #fffaf0;border-radius:50%;background:#7a7066;color:#fffaf0;font-family:Fraunces,Georgia,serif;font-size:1.05rem;font-weight:900;box-shadow:0 14px 26px #342b1f29}.map-card{position:relative;display:grid;gap:8px;width:100%;min-height:124px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:16px;background:repeating-linear-gradient(0deg,rgba(33,31,29,.025),rgba(33,31,29,.025) 1px,transparent 1px,transparent 12px),#fffdf7;color:var(--ink);text-align:left;box-shadow:0 12px 28px #342b1f14;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.map-card:hover{transform:translateY(-2px)}.map-row.selected .map-card{border-color:var(--blue);box-shadow:0 18px 36px #235e8426}.map-state{width:fit-content;border-radius:999px;padding:5px 9px;background:#211f1d14;color:var(--muted-strong);font-size:.72rem;font-weight:950;text-transform:uppercase;line-height:1.1}.map-card strong{font-family:Fraunces,Georgia,serif;font-size:1.18rem;line-height:1.12;text-wrap:balance}.map-card small{color:var(--muted);font-weight:850}.map-meter{overflow:hidden;height:9px;border-radius:999px;background:#211f1d17}.map-meter i{display:block;height:100%;border-radius:inherit;background:var(--stream-color)}.map-merge{position:absolute;right:14px;top:14px;color:var(--blue)}.map-actions{position:relative;z-index:2;display:grid;gap:9px;min-width:0}.map-practice{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:fit-content;min-height:40px;border:1px solid var(--charcoal);border-radius:999px;padding:9px 13px;background:linear-gradient(135deg,var(--charcoal),#3a2921),var(--charcoal);color:#fffaf0;font-weight:950}.map-cross-deps{display:flex;flex-wrap:wrap;gap:7px}.cross-dep{display:inline-flex;align-items:center;gap:7px;border:1px solid color-mix(in srgb,var(--dep-color) 38%,transparent);border-radius:999px;padding:5px 9px 5px 5px;background:color-mix(in srgb,var(--dep-color) 10%,#fffdf7);color:#211f1d;font-size:.76rem;font-weight:950;box-shadow:0 8px 16px #342b1f12}.cross-dep span{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--dep-color);color:#fffaf0;font-size:.64rem}.cross-dep em{font-style:normal}.cross-dep.missing{opacity:.72}.map-row.mastered .map-level,.map-row.mastered .map-state{background:var(--green);color:#fffaf0}.map-row.active .map-level,.map-row.active .map-state{background:var(--blue);color:#fffaf0}.map-row.available .map-level,.map-row.available .map-state{background:var(--teal);color:#fffaf0}.map-row.queued .map-level,.map-row.queued .map-state{background:var(--sun);color:#3d2b05}.map-row.locked{opacity:.7}.map-row.merge .map-card{background:linear-gradient(135deg,#235e841a,#fffdf700 48%),repeating-linear-gradient(0deg,rgba(33,31,29,.025),rgba(33,31,29,.025) 1px,transparent 1px,transparent 12px),#fffdf7}.dag-board.graph-flow{display:grid;gap:14px;overflow-x:auto;padding:8px 2px 18px}.graph-row{display:grid;grid-template-columns:58px minmax(0,1fr);gap:12px;align-items:center}.graph-level{display:grid;place-items:center}.graph-level span{display:inline-grid;place-items:center;width:46px;height:46px;border:2px solid #fffaf0;border-radius:50%;background:#292521;color:#fffaf0;font-size:.82rem;font-weight:950;box-shadow:0 8px 20px #342b1f21}.graph-node-cluster{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start;min-width:0;padding:8px 0}.dag-node{position:relative;width:min(100%,268px);min-width:218px;transform:translate(var(--node-shift));transition:transform .18s ease,opacity .18s ease}.dag-node-button{position:relative;display:grid;gap:5px;width:100%;min-height:106px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:12px 12px 12px 46px;background:repeating-linear-gradient(0deg,rgba(33,31,29,.025),rgba(33,31,29,.025) 1px,transparent 1px,transparent 12px),#fffdf7;color:var(--ink);text-align:left;box-shadow:0 8px 18px #342b1f14}.dag-node-button strong{font-size:.92rem;line-height:1.2}.dag-node-button small,.dag-status{color:var(--muted);font-size:.74rem;font-weight:850}.dag-node-level{position:absolute;left:10px;top:12px;display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:#eee4d5;color:var(--ink);font-size:.78rem;font-weight:950}.dag-node.selected .dag-node-button{border-color:var(--blue);box-shadow:0 14px 30px #235e8429}.dag-node:hover{transform:translate(var(--node-shift)) translateY(-2px)}.dag-node.merge .dag-node-button{border-color:#235e8452;background:linear-gradient(135deg,#235e841c,#fffdf700 45%),#fffdf7}.merge-icon{position:absolute;right:10px;top:12px;color:var(--blue)}.dag-node.mastered .dag-node-level{background:var(--green);color:#fffaf0}.dag-node.active .dag-node-level{background:var(--blue);color:#fffaf0}.dag-node.available .dag-node-level{background:var(--teal);color:#fffaf0}.dag-node.queued .dag-node-level{background:var(--sun);color:#3d2b05}.dag-node.locked{opacity:.72}.dag-node.locked .dag-node-level{background:#7a7066;color:#fffaf0}.node-practice{position:absolute;right:8px;bottom:8px;display:inline-flex;align-items:center;gap:4px;min-height:28px;border:1px solid rgba(33,31,29,.1);border-radius:999px;padding:4px 8px;background:#fffaf0e6;color:#4a4239;font-size:.68rem;font-weight:950;box-shadow:0 6px 12px #342b1f14}.external-dependencies{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}.external-dependency-node{display:inline-flex;align-items:center;gap:5px;border:1px solid color-mix(in srgb,var(--dep-color) 40%,transparent);border-radius:999px;padding:4px 8px 4px 5px;background:color-mix(in srgb,var(--dep-color) 12%,#fffdf7);color:#211f1d;font-size:.7rem;font-weight:950}.external-dependency-node span{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--dep-color);color:#fffaf0;font-size:.62rem}.external-dependency-node em{font-style:normal}.branch-legend{display:grid;grid-template-columns:repeat(var(--lane-count),minmax(0,1fr));gap:10px;padding-left:72px}.branch-legend span{border:1px solid rgba(33,31,29,.1);border-radius:999px;padding:8px 10px;background:#ffffff9e;color:#5b5146;font-size:.78rem;font-weight:950;text-align:center}.tree-board.branch-board{position:relative;display:grid;gap:12px;padding:8px 0}.tree-spine{position:absolute;top:22px;bottom:22px;left:28px;width:4px;border-radius:999px;background:linear-gradient(var(--green),var(--sun) 45%,var(--danger));opacity:.34}.tree-level-row{position:relative;display:grid;grid-template-columns:58px minmax(0,1fr);gap:14px;align-items:stretch}.tree-level-marker{position:sticky;top:12px;z-index:2;align-self:start;justify-self:center;display:grid;place-items:center;width:54px;height:54px;border:3px solid #fffaf0;border-radius:50%;background:#eee4d5;color:var(--ink);box-shadow:0 8px 20px #342b1f24}.tree-level-marker span{font-size:.9rem;font-weight:950}.tree-level-marker svg{position:absolute;right:-5px;bottom:-3px;border-radius:50%;padding:3px;background:var(--blue);color:#fffaf0}.merge-row .tree-level-marker{background:var(--blue);color:#fffaf0}.branch-lanes{display:grid;grid-template-columns:repeat(var(--lane-count),minmax(170px,1fr));gap:10px;align-items:stretch}.branch-empty{min-height:1px}.tree-step{min-width:0}.tree-card{position:relative;display:grid;gap:9px;min-height:174px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:12px;background:#fffdf7;color:var(--ink);text-align:left}.tree-step.selected .tree-card{border-color:var(--blue);box-shadow:0 14px 34px #235e8429}.tree-step.merge .tree-card{background:linear-gradient(135deg,#235e8414,#fffdf700 42%),#fffdf7}.tree-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.tree-card-top strong{font-size:.98rem;line-height:1.2}.tree-card-top em{flex:0 0 auto;border-radius:999px;padding:4px 8px;background:#eee4d5;color:#5b5146;font-size:.72rem;font-style:normal;font-weight:950;text-transform:uppercase}.branch-pill{width:fit-content;border-radius:999px;padding:4px 8px;background:#235e8414;color:#173d56;font-size:.74rem;font-weight:950}.mastery-meter{overflow:hidden;height:8px;border-radius:999px;background:#211f1d17}.mastery-meter span{display:block;height:100%;border-radius:inherit;background:var(--green)}.tree-card-meta,.dependency-row,.inspector-deps div,.inspector-cross div{display:flex;flex-wrap:wrap;gap:6px}.tree-card-meta span,.dependency-row span,.dependency-row button,.inspector-deps span,.inspector-deps button,.inspector-cross button{display:inline-flex;align-items:center;min-height:26px;border:1px solid transparent;border-radius:999px;padding:4px 8px;font-size:.74rem;font-weight:850;line-height:1.2}.tree-card-meta span{border:1px solid rgba(33,31,29,.08);background:#fffaf0e6;color:#62584d}.dep-ok{border:1px solid rgba(31,122,77,.26);background:#1f7a4d1a;color:#174d33}.dep-missing{border:1px solid rgba(168,61,45,.26);background:#a83d2d1c;color:#762a1e}.dep-more{border:1px solid rgba(35,94,132,.2);background:#235e8414;color:#173d56}.cross-link-rail{display:flex;align-items:center;gap:5px;min-height:32px}.cross-link-rail:before{content:"";flex:1 1 auto;height:2px;border-radius:999px;background:linear-gradient(90deg,#235e840d,#235e8466)}.cross-link-circle{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;padding:0;font-size:.66rem;font-weight:950;box-shadow:0 8px 16px #211f1d1a}.locked-reason{display:inline-flex;align-items:center;gap:6px;color:#762a1e;font-size:.78rem;font-weight:850}.tree-step.mastered .tree-level-marker,.tree-step.mastered .tree-card-top em{background:var(--green);color:#fffaf0}.tree-step.active .tree-level-marker,.tree-step.active .tree-card-top em{background:var(--blue);color:#fffaf0}.tree-step.available .tree-level-marker,.tree-step.available .tree-card-top em{background:var(--teal);color:#fffaf0}.tree-step.queued .tree-level-marker,.tree-step.queued .tree-card-top em{background:var(--sun);color:#3d2b05}.tree-step.locked{opacity:.68}.tree-step.locked .tree-level-marker,.tree-step.locked .tree-card-top em{background:#7a7066;color:#fffaf0}.tree-inspector{display:grid;gap:15px;border:1px solid rgba(36,31,26,.14);border-left:6px solid var(--blue);border-radius:8px;padding:16px;background:linear-gradient(180deg,#fffdf6f0,#f7eddbc7),#fffdf7;box-shadow:var(--shadow-soft)}.tree-inspector.mastered{border-left-color:var(--green)}.tree-inspector.available{border-left-color:var(--teal)}.tree-inspector.queued{border-left-color:var(--sun)}.tree-inspector.locked{border-left-color:var(--danger)}.tree-inspector p{margin:9px 0 0;color:var(--muted);line-height:1.52}.inspector-actions{display:flex;flex-wrap:wrap;align-items:center;gap:11px}.inspector-cross{display:grid;gap:8px;border:1px solid rgba(35,94,132,.14);border-radius:8px;padding:13px;background:#235e8412}.inspector-cross button{border-color:#235e8433;background:#fffdf7;color:#173d56;gap:6px}.inspector-cross button span{width:14px;height:14px;border-radius:50%;background:var(--dep-color)}.inspector-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.inspector-grid>div,.inspector-deps{display:grid;gap:8px;border:1px solid rgba(33,31,29,.1);border-radius:8px;padding:13px;background:#fffaf0a8}.inspector-grid svg{color:var(--blue)}.inspector-grid span{color:var(--muted);line-height:1.48;font-size:.9rem}.system-band{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:24px 0}.settings-band{display:grid;gap:14px;margin:0 0 16px}.privacy-policy{display:grid;gap:16px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:clamp(16px,2vw,22px);background:linear-gradient(180deg,#fffdf6f0,#f7eddbcc),var(--texture),var(--paper-strong);background-size:auto,760px auto,auto;box-shadow:var(--shadow-soft)}.privacy-policy-intro{display:grid;gap:10px;max-width:920px}.privacy-policy h3{font-family:Fraunces,Georgia,serif;font-size:1.7rem;line-height:1.1;text-wrap:balance}.privacy-policy p{margin:0;color:var(--muted);font-weight:750;line-height:1.55}.privacy-policy-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.privacy-policy-grid article{display:grid;align-content:start;gap:8px;min-height:156px;border:1px solid rgba(36,31,26,.12);border-radius:8px;padding:14px;background:#fffdf6a8}.privacy-policy-grid strong{color:var(--ink);font-size:1.02rem}.privacy-policy-grid span{color:var(--muted);font-size:.94rem;font-weight:750;line-height:1.48}.settings-card{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:16px;background:linear-gradient(180deg,#fffdf6f0,#f7eddbc7),#fffdf7;box-shadow:var(--shadow-soft)}.settings-card div{display:grid;gap:6px;min-width:0}.settings-card strong{font-size:1.02rem}.settings-card span{color:var(--muted);line-height:1.48}.danger-zone{border-color:#9d372b33;background:linear-gradient(180deg,#fffdf6db,#9d372b14),#9d372b0f}.cheat-zone{border-color:#087f7847;background:linear-gradient(135deg,#25724f21,#c991241f 54%,#d94f3c14),#fffdf7}.cheat-zone.complete{border-color:#235e843d;background:linear-gradient(135deg,#235e841a,#6f4bb714 52%,#087f7814),#fffdf7}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:18px;background:#1d19166b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.confirm-modal{position:relative;display:grid;gap:12px;width:min(560px,100%);border:1px solid rgba(36,31,26,.16);border-radius:8px;padding:clamp(18px,3vw,26px);background:linear-gradient(180deg,#fffdf6fa,#f7eddbeb),var(--texture),#fffdf7;background-size:auto,620px auto,auto;box-shadow:0 28px 72px #1d191647}.confirm-modal.cheat{border-color:#087f7857}.confirm-modal.danger{border-color:#9d372b57}.modal-close{position:absolute;inset-block-start:10px;inset-inline-end:10px;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid rgba(36,31,26,.14);border-radius:8px;background:#fffdf6c2;color:var(--muted-strong)}.modal-kicker{display:inline-flex;align-items:center;gap:8px;width:fit-content;border:1px solid rgba(36,31,26,.14);border-radius:999px;padding:7px 11px;background:#fffdf6b3;color:var(--muted-strong);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:0}.confirm-modal h3{max-width:calc(100% - 34px);margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(1.45rem,3vw,2rem);line-height:1.08;text-wrap:balance}.confirm-modal p{margin:0;color:var(--muted);font-size:1rem;font-weight:760;line-height:1.55}.modal-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:10px;margin-block-start:4px}.system-item{position:relative;overflow:hidden;display:grid;gap:9px;min-height:160px;border:1px solid rgba(36,31,26,.14);border-radius:8px;padding:16px;background:linear-gradient(180deg,#fffdf6db,#f7eddbc2),var(--texture),#fffaf0c7;background-size:auto,560px auto,auto;box-shadow:var(--shadow-soft)}.system-item svg{color:var(--blue)}.system-item strong{font-size:1.05rem}.app-footer{align-items:flex-end;border-top:1px solid rgba(36,31,26,.14);padding-top:20px;color:var(--muted)}.footer-author{display:grid;gap:5px;min-width:0;max-width:620px}.footer-author strong{color:var(--ink);font-size:1.04rem;line-height:1.1}.footer-kicker{color:var(--muted-strong);font-size:.72rem;font-weight:900;letter-spacing:0;line-height:1;text-transform:uppercase}.app-footer .social-nav{align-items:center}.social-nav a{min-width:104px}.social-nav a span{color:var(--ink);line-height:1}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1180px){.brand{font-size:2.2rem}h1{font-size:3.45rem}h2{font-size:2rem}.stream-grid,.system-band,.library-grid,.privacy-policy-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-receipts,.general-level-card,.recipe-strip,.question-layout{grid-template-columns:1fr}.map-row{grid-template-columns:70px minmax(0,1fr);transform:none}.map-actions{grid-column:2}.map-row.with-cross:after{display:none}.branch-legend,.branch-lanes{min-width:680px}.tree-board.branch-board{overflow-x:auto;padding-bottom:10px}}@media(max-width:760px){main{width:min(100% - 18px,1480px);padding-top:12px}.brand{font-size:1.85rem}.brand-mark,.brand-mark svg{width:46px;height:46px}.app-header,.workspace-head,.study-head,.section-title,.app-footer{align-items:stretch;flex-direction:column}.social-nav,.app-nav,.stream-switcher,.library-stats,.tree-summary{justify-content:flex-start}.app-nav button,.stream-switcher button{min-height:40px;padding:8px 11px}.session-progress-card{justify-items:start;text-align:left;max-width:none}.completion-stats,.completion-details{grid-template-columns:1fr}.completion-stats span{border-inline-end:0;border-block-end:1px solid rgba(36,31,26,.1)}.completion-stats span:last-child{border-block-end:0}.header-actions{justify-items:start}.stream-grid,.system-band,.library-grid,.privacy-policy-grid{grid-template-columns:1fr}.general-level-bars{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-card{align-items:stretch;flex-direction:column}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}.stream-panel{min-height:auto;grid-template-rows:auto auto auto auto auto}.choice-grid,.answer-actions{grid-template-columns:1fr}.learning-map{gap:11px}.learning-map-spine{left:25px}.map-row{grid-template-columns:54px minmax(0,1fr);gap:10px}.map-row:before{left:27px;right:calc(100% - 66px)}.map-level{width:52px;height:52px;font-size:.92rem}.map-card{min-height:116px;padding:13px}.map-actions{grid-column:2}.inspector-grid{grid-template-columns:1fr}.tree-card-top{flex-direction:column}.branch-legend,.branch-lanes{min-width:620px}.tree-level-row{grid-template-columns:48px minmax(0,1fr)}.tree-level-marker{width:46px;height:46px}.tree-spine{left:23px}.piano{grid-template-columns:repeat(4,minmax(42px,1fr))}.duration-toolbar{grid-template-columns:repeat(2,minmax(0,1fr))}.tap-panel{grid-template-columns:1fr auto}.tap-target{min-height:96px}.mini-note-editor{grid-template-columns:1fr}.editor-octaves{display:flex}h1{font-size:2.55rem}h2{font-size:1.72rem}}@media(max-width:440px){.general-level-bars{grid-template-columns:1fr}}
