:root{--mahogany:#4a2f26;--mahogany-deep:#2c1a15;--mahogany-shadow:#1a0f0c;--tan-panel:#c4a882;--tan-deep:#a38562;--honey:#c9a66b;--honey-light:#e8d4b8;--gold:#d4a524;--gold-bright:#e8c94a;--gold-dim:#8a6a18;--ivory:#f7f2e8;--key-white:#faf8f3;--key-black:#3d2a22;--ebony:#1c1410;--panel:#231612f0;--text:#f5ebe0;--muted:#b5a090;--success:#7fd99a;--felt-red:#b50508;--felt-red-deep:#6f0305;--wood-face:#5c3d22;--wood-dark:#2e1d10;--metal-light:#f2f4f6;--metal-mid:#9a9ea3;--metal-dark:#4a4d52;--font:"Segoe UI", system-ui, sans-serif}*,:before,:after{box-sizing:border-box}html,body{background:radial-gradient(ellipse 90% 70% at 50% 35%, #5a3d32 0%, transparent 55%), radial-gradient(ellipse 140% 100% at 50% 100%, #0d0806 0%, var(--mahogany-shadow) 42%, #1a100c 100%);min-height:100%;color:var(--text);font-family:var(--font);margin:0}#app{flex-direction:column;min-height:100vh;display:flex}.shell{flex:1;grid-template-columns:1fr min(380px,100%);gap:0;width:100%;max-width:1400px;margin:0 auto;display:grid}@media (width<=900px){.shell{grid-template-columns:1fr}.drawer{border-top:1px solid #c9a22740;border-left:none;max-height:48vh}}.stage-wrap{flex-direction:column;align-items:center;padding:1rem 1.25rem 2.5rem;display:flex}.sound-strip{background:linear-gradient(#00000047,#0000001f);border:1px solid #c9a22752;border-radius:8px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem 1.5rem;width:100%;max-width:920px;margin-top:.85rem;padding:.65rem .95rem .8rem;display:flex;box-shadow:0 4px 14px #00000040}.sound-strip__metro{color:var(--honey-light);font:inherit;cursor:pointer;background:#0000004d;border:1px solid #fff3;border-radius:6px;flex:none;padding:.45rem .85rem;font-size:.8rem;font-weight:600;transition:background .15s,border-color .15s}.sound-strip__metro:hover{background:#ffffff14}.sound-strip__metro.is-on{border-color:var(--gold);color:#fff;background:#c9a22733}.sound-strip__item{flex:220px;grid-template-columns:min-content 1fr min-content;align-items:center;gap:.5rem .65rem;max-width:360px;display:grid}.sound-strip__label{letter-spacing:.02em;color:var(--honey-light);white-space:nowrap;font-size:.84rem;font-weight:600}.sound-strip input[type=range]{width:100%;min-width:0;accent-color:var(--gold)}.sound-strip__value{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;min-width:2.75rem;font-size:.8rem}.instrument-stack{width:100%;max-width:920px}.instrument-frame{background:repeating-linear-gradient(92deg, #0000000a 0px, #0000000a 1px, transparent 1px, transparent 5px), repeating-linear-gradient(0deg, #ffffff05 0px, transparent 1px, transparent 3px), linear-gradient(168deg, #7a5230 0%, var(--wood-face) 28%, var(--wood-dark) 72%, #1a1008 100%);border:1px solid #281c12e6;border-radius:10px;padding:8px 10px 0;overflow:hidden;box-shadow:0 5px #00000073,0 22px 44px #0000008c,inset 0 2px #ffffff12,inset 0 -3px 8px #00000040}.top-bar{justify-content:space-between;align-items:center;width:100%;max-width:920px;margin-bottom:.75rem;display:flex}.logo{letter-spacing:.04em;color:var(--honey-light);font-size:1.1rem;font-weight:600}.hint{color:var(--muted);font-size:.8rem}.keybed-divider{background:linear-gradient(90deg,#1a1008,#3d2818 20%,#5a3d22 50%,#3d2818 80%,#1a1008);border-radius:6px 6px 0 0;height:4px;margin:0;box-shadow:inset 0 1px #ffffff0f}.keyboard-deck{background:repeating-linear-gradient(90deg,#0000000f 0,#0000 2px 4px),linear-gradient(#2a1a10 0%,#3d2618 30%,#322014 100%);border-top:1px solid #00000080;border-radius:6px 6px 8px 8px;padding:0 0 12px;box-shadow:inset 0 4px 12px #00000073}.keys-felt{background:linear-gradient(180deg, #e01018 0%, var(--felt-red) 35%, var(--felt-red-deep) 100%);border-radius:1px;height:7px;margin:0 12px 10px;box-shadow:inset 0 1px #ffffff40,inset 0 -2px 4px #00000059,0 2px 4px #0006}.keys-bed{perspective:1200px;transform-style:preserve-3d;background:linear-gradient(#1f1510 0%,#2d1e16 40%,#241810 100%);border:1px solid #0000008c;border-radius:4px;margin:0 8px;padding:10px 8px 16px;box-shadow:inset 0 2px 6px #00000080,inset 0 -1px #ffffff0a}.keys-bed .keys-rows{transform-origin:top;transform:rotateX(5deg)}.keys-rows.keys-rows--piano{-webkit-overflow-scrolling:touch;padding-bottom:4px;overflow:auto visible}.piano-row{flex-flow:row;justify-content:center;align-items:flex-end;gap:0;min-width:min(100%,52rem);padding:0 2px 2px;display:flex}.piano-row .key-cap.white{flex:1 1 0;width:auto;min-width:1.15rem;max-width:2.1rem}.piano-row .key-cap.black{flex:0 0 1rem;width:1rem;min-width:1rem;margin-left:-.5rem;margin-right:-.5rem}.keys-label{color:#e8dac6e0;text-shadow:0 1px 2px #0009;margin:0;padding:10px 14px 8px;font-size:.72rem}.keys-label kbd{color:#ffffffe6;background:#00000059;border:1px solid #ffffff1f;border-radius:4px;padding:.1em .35em;font-size:.68rem}.keys-rows{flex-direction:column;gap:.5rem;display:flex}.key-cap{cursor:pointer;-webkit-user-select:none;user-select:none;border:none;font-family:inherit;transition:transform 70ms,box-shadow 70ms;position:relative}html.reduce-motion .key-cap{transition:none}.key-cap__face{pointer-events:none;flex-direction:column;justify-content:flex-end;align-items:center;gap:.12rem;width:100%;min-height:100%;display:flex}.key-cap.white{color:#1a1410;background:linear-gradient(#fff 0%,#f7f5f0 35%,#ebe6dc 70%,#ddd8ce 100%);border:1px solid #c4bfb6;border-bottom:2px solid #9a948a;border-radius:3px 3px 10px 10px;width:1.95rem;min-width:1.95rem;height:3.75rem;padding:.35rem .2rem .45rem;box-shadow:inset 0 2px #fffffff2,inset 0 -4px 8px #0000000f,0 5px #1a120c,0 8px 14px #0006}.key-cap.black{z-index:2;color:#f0ebe3;background:linear-gradient(#2e2e2e 0%,#121212 55%,#050505 100%);border:1px solid #000;border-bottom-width:2px;border-radius:2px 2px 6px 6px;width:1.28rem;min-width:1.28rem;height:2.45rem;margin-left:-.42rem;margin-right:-.42rem;padding:.25rem .12rem .35rem;transform:translateY(-12px);box-shadow:inset 0 -2px 4px #ffffff0f,inset 0 2px 3px #ffffff0a,0 4px #0a0a0a,0 7px 12px #000000a6}.key-cap .letter{font-size:.72rem;font-weight:800;line-height:1;display:block}.key-cap .dual{opacity:.88;text-overflow:ellipsis;max-width:100%;font-size:.52rem;line-height:1.05;overflow:hidden}.key-cap.white:active,.key-cap.white.pressed,.key-cap.white.active-teach{transform:translateY(6px);box-shadow:inset 0 4px 10px #0000001f,0 2px #1a120c,0 4px 8px #00000059}.key-cap.black:active,.key-cap.black.pressed,.key-cap.black.active-teach{transform:translateY(-4px);box-shadow:inset 0 3px 8px #00000080,0 2px #0a0a0a,0 4px 8px #00000080}.key-cap.active-teach{outline-offset:2px;z-index:3;outline:2px solid #e8c040}.key-cap.match-ok{outline-color:var(--success)}@media (width<=540px){.key-cap.white{width:1.55rem;min-width:1.55rem;height:3.25rem;font-size:.55rem}.key-cap.black{width:1.05rem;min-width:1.05rem;height:2.1rem;margin-left:-.32rem;margin-right:-.32rem;transform:translateY(-10px)}.piano-row .key-cap.white{min-width:.95rem;max-width:1.65rem;height:3.1rem;padding:.28rem .1rem .35rem}.piano-row .key-cap.black{flex-basis:.88rem;width:.88rem;min-width:.88rem;height:1.95rem;margin-left:-.44rem;margin-right:-.44rem;transform:translateY(-9px)}.piano-row .key-cap.black:active,.piano-row .key-cap.black.pressed,.piano-row .key-cap.black.active-teach,.key-cap.black:active,.key-cap.black.pressed,.key-cap.black.active-teach{transform:translateY(-2px)}.key-cap .letter{font-size:.62rem}.piano-row .key-cap .letter{font-size:.55rem}.key-cap .dual{font-size:.45rem}.piano-row .key-cap .dual{font-size:.38rem}}.drawer{background:var(--panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-left:1px solid #c9a22733;padding:1rem 1.1rem 1.5rem;overflow-y:auto}.drawer h2{color:var(--honey-light);margin:0 0 .75rem;font-size:1rem}.song-list{max-height:200px;margin:0 0 1rem;padding:0;list-style:none;overflow-y:auto}.song-list button{text-align:left;width:100%;color:var(--text);cursor:pointer;font:inherit;background:#ffffff0a;border:1px solid #0000;border-radius:6px;margin-bottom:.25rem;padding:.5rem .6rem;font-size:.88rem}.song-list button:hover{background:#ffffff14}.song-list button.selected{border-color:var(--gold);background:#c9a2271f}.lesson-meta{color:var(--muted);margin-bottom:.75rem;font-size:.8rem}.mode-row,.transport{flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem;display:flex}.mode-row button,.transport button,.ctl-row button{color:var(--text);cursor:pointer;font:inherit;background:#00000040;border:1px solid #c9a22759;border-radius:6px;padding:.4rem .65rem;font-size:.8rem}.mode-row button.active,.transport button.primary{border-color:var(--gold);background:#c9a22740}.ctl-row{grid-template-columns:1fr 1fr;gap:.5rem .75rem;margin-bottom:.75rem;font-size:.78rem;display:grid}.ctl-row label{color:var(--muted);flex-direction:column;gap:.2rem;display:flex}.ctl-label-row{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.ctl-val{font-variant-numeric:tabular-nums;color:var(--honey-light);text-align:right;flex-shrink:0;min-width:3.25rem;font-size:.82rem;font-weight:600}.ctl-row input[type=range]{width:100%}.timeline{background:#00000059;border-radius:3px;height:6px;margin:.5rem 0;overflow:hidden}.timeline-bar{background:linear-gradient(90deg, var(--gold-dim), var(--gold));width:0%;height:100%;transition:width 50ms linear}.feedback{min-height:1.25rem;color:var(--success);margin-top:.35rem;font-size:.85rem}.next-hint{color:var(--honey-light);margin-top:.25rem;font-size:.85rem}.drawer-toggle{display:none}@media (width<=900px){.drawer-toggle{border:1px solid var(--gold);background:var(--panel);color:var(--text);font:inherit;border-radius:8px;margin:.5rem auto;padding:.5rem 1rem;display:block}.drawer.collapsed-mobile{display:none}}.start-overlay{z-index:100;background:#0f0a08e0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.start-overlay.hidden{display:none}.start-card{text-align:center;background:linear-gradient(160deg, var(--mahogany), var(--mahogany-deep));border:1px solid #c9a22766;border-radius:16px;max-width:360px;padding:2rem 2.5rem}.start-card h1{color:var(--honey-light);margin:0 0 .5rem;font-size:1.5rem}.start-card p{color:var(--muted);margin-bottom:1.25rem;font-size:.9rem}.start-card .start-status{min-height:1.25rem;color:var(--honey-light);margin-bottom:.75rem;font-size:.82rem}.start-card button{cursor:pointer;background:linear-gradient(180deg, #e8c840, var(--gold));color:var(--mahogany-deep);border:none;border-radius:999px;padding:.75rem 2rem;font-size:1rem;font-weight:600}.presets{margin-top:.75rem}.presets select{width:100%;color:var(--text);font:inherit;background:#0000004d;border:1px solid #ffffff26;border-radius:6px;padding:.4rem}.lesson-group{background:radial-gradient(circle at 0 0,#ffffff0a,#0000 55%),#00000040;border:1px solid #c9a22740;border-radius:8px;margin-bottom:.6rem;padding:.35rem .55rem .55rem}.lesson-group>summary{cursor:pointer;color:var(--honey-light);align-items:center;gap:.35rem;margin-bottom:.35rem;font-size:.8rem;font-weight:600;list-style:none;display:flex}.lesson-group>summary:before{content:"▾";opacity:.75;transform-origin:50%;font-size:.7rem;transition:transform .12s}.lesson-group[open]>summary:before{transform:rotate(0)}.lesson-group:not([open])>summary:before{transform:rotate(-90deg)}.lesson-group[open]{padding-bottom:.65rem}.site-footer{color:var(--muted);z-index:40;background:#0000002e;border-top:1px solid #c9a22726;justify-content:center;align-items:center;gap:1.25rem;margin-top:auto;padding:1rem 1.5rem;font-size:.82rem;display:flex;position:sticky;bottom:0}.site-footer a{color:var(--honey-light);text-decoration:none;transition:color .15s}.site-footer a:hover{color:var(--gold-bright)}.gh-link{align-items:center;gap:.35rem;display:inline-flex}.gh-link svg{flex-shrink:0}.seo-faq{max-width:920px;color:var(--muted);margin:.5rem auto .75rem;padding:0 1.1rem;font-size:.82rem}.seo-faq h2{color:var(--honey-light);margin:0 0 .35rem;font-size:.9rem}.seo-faq details{background:#0000002e;border:1px solid #c9a2272e;border-radius:10px;margin-bottom:.35rem;padding:.35rem .65rem}.seo-faq summary{cursor:pointer;color:var(--honey-light);font-weight:650;list-style:none}.seo-faq summary::-webkit-details-marker{display:none}.seo-faq p{color:var(--muted);margin:.35rem 0 0;line-height:1.35}
