:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0a0f18;--panel:#0d1522eb;--panel-strong:#121f31fa;--ink:#f6fbff;--muted:#9fb3c9;--muted-2:#6f839a;--line:#ffffff1f;--accent:#ffd36a;--accent-2:#73e0ff;--good:#9aff9a;--bad:#ff7f86;--home:#ffd36a2e;--shadow:#00000059}*{box-sizing:border-box}html,body{background:radial-gradient(circle at 20% 20%, #17243a 0, var(--bg) 52%, #05070b 100%);width:100%;min-height:100%;color:var(--ink);margin:0;font-family:ui-rounded,Trebuchet MS,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}button,input{font:inherit}.no-script,.dependency-error{z-index:100;color:var(--ink);background:#08111d;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.dependency-error.hidden{display:none}.dependency-error>div,.no-script{border:1px solid var(--line);background:var(--panel-strong);max-width:720px;box-shadow:0 24px 80px var(--shadow);border-radius:24px;padding:28px}code{color:#fff1bd;background:#ffffff14;border-radius:7px;padding:2px 6px}.app-shell{grid-template:"scene side"minmax(0,1fr)"band band"minmax(280px,44dvh)/minmax(0,1fr) minmax(300px,400px);height:100dvh;display:grid}body[data-layout=side] .app-shell{grid-template:"scene side""scene band"minmax(0,1fr)/minmax(0,1fr) minmax(360px,460px)}.scene-shell{background:linear-gradient(#17243b,#0d1726 48%,#11170f);grid-area:scene;min-width:0;position:relative;overflow:hidden}.scene-mount{position:absolute;inset:0}.scene-mount canvas{width:100%;height:100%;display:block}.scene-topbar{z-index:3;pointer-events:none;justify-content:space-between;align-items:flex-start;gap:12px;display:flex;position:absolute;top:18px;left:18px;right:18px}.scene-topbar>*{pointer-events:auto}.topbar-group{flex-wrap:wrap;gap:8px;display:flex}.camera-caption{border:1px solid var(--line);max-width:min(520px,100% - 36px);color:var(--muted);box-shadow:0 12px 35px var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#080d16bf;border-radius:18px;padding:12px 16px;position:absolute;bottom:18px;left:18px}.side-pane{z-index:5;border-left:1px solid var(--line);background:linear-gradient(#0a111df5,#0a0f18fa);flex-direction:column;grid-area:side;gap:12px;min-height:0;padding:16px 18px;display:flex;position:relative;overflow:auto}.play-band{z-index:5;border-top:1px solid var(--line);background:linear-gradient(#0a111df5,#0a0f18fa);grid-area:band;grid-template-columns:minmax(220px,.85fr) minmax(240px,1fr) minmax(360px,1.7fr);grid-template-areas:"target lesson keyboard";gap:10px;min-height:0;padding:14px 18px 16px;display:grid;position:relative;overflow:auto;box-shadow:0 -22px 60px #00000047}body[data-layout=side] .play-band{border-top:0;border-left:1px solid var(--line);box-shadow:none;grid-template:"target""lesson"minmax(120px,1fr)"keyboard"/1fr}.lesson-header{min-width:0}.target-card{grid-area:target}.lesson-text-card{grid-area:lesson}.keyboard-card{grid-area:keyboard}.lesson-header h1,.lesson-header p,.level-card h2,.level-card p,.modal-card h2,.end-card h2{margin:0}.lesson-header h1{letter-spacing:0;margin-top:3px;font-size:1.65rem}.eyebrow{color:var(--accent);letter-spacing:0;text-transform:uppercase;margin:0 0 5px;font-size:.76rem;font-weight:800}.lesson-focus,.privacy-note,.feedback,.score-stack small,.stats-row small{color:var(--muted)}.lesson-focus{margin:8px 0 0;font-size:.95rem;line-height:1.35}.level-card,.target-card,.lesson-text-card,.keyboard-card,.stats-row{border:1px solid var(--line);background:var(--panel);border-radius:22px;min-width:0;box-shadow:0 14px 42px #0000002e}.level-card{justify-content:space-between;align-items:center;gap:16px;padding:12px 14px;display:flex}.level-label{color:var(--accent-2);letter-spacing:0;text-transform:uppercase;margin-bottom:5px;font-size:.82rem;font-weight:800;display:inline-block}.level-card h2{font-size:1.1rem}.score-stack{text-align:right;min-width:96px}.score-stack span{font-size:1.3rem;font-weight:900;display:block}.score-stack small{margin-top:2px;display:block}.progress-wrap{border:1px solid var(--line);background:#ffffff0f;border-radius:999px;height:12px;overflow:hidden}.progress-bar{border-radius:inherit;background:linear-gradient(90deg,#77e0ff,#ffd36a);width:0%;height:100%;transition:width .16s ease-out}.target-card{grid-template-rows:auto minmax(54px,1fr) auto auto;align-content:center;gap:6px;padding:14px;display:grid}.target-label{color:var(--muted-2);letter-spacing:0;text-transform:uppercase;font-size:.78rem;font-weight:800;display:block}.target-key{color:#fff5c9;background:#ffd36a1f;border:2px solid #ffd36ad9;border-radius:20px;place-items:center;width:min(100%,150px);min-height:58px;margin:0;padding:0 18px;font-size:2.8rem;line-height:1;display:inline-grid;box-shadow:inset 0 -8px #00000029,0 10px 30px #ffd36a1f}.next-chunk{min-width:0;min-height:1.3em;color:var(--accent-2);text-overflow:ellipsis;white-space:nowrap;font-size:1.15rem;font-weight:900;line-height:1.2;display:block;overflow:hidden}.feedback{min-height:1.3em;line-height:1.35;display:block}.feedback.good{color:var(--good)}.feedback.bad{color:var(--bad)}.lesson-text-card{min-height:0;padding:14px 16px;overflow:auto}.lesson-text{letter-spacing:0;overflow-wrap:anywhere;font-size:1.65rem;font-weight:750;line-height:1.65}.lesson-text span{text-align:center;border-radius:7px;min-width:.55em;margin:1px;display:inline-block}.lesson-text .done{color:#cfc;background:#9aff9a29}.lesson-text .current{color:#fff2bd;background:#ffd36a38;outline:2px solid #ffd36ad9;animation:1s ease-in-out infinite pulseCurrent}.lesson-text .upcoming{color:#f6fbffa6}.lesson-text .space-char{color:#73e0ffcc}@keyframes pulseCurrent{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.stats-row{grid-template-columns:repeat(5,minmax(0,1fr));padding:5px 0;display:grid}.stats-row div{text-align:center}.stats-row div+div{border-left:1px solid var(--line)}.stats-row span{font-size:1.15rem;font-weight:900;display:block}.stats-row small{text-transform:uppercase;letter-spacing:0;margin-top:3px;font-size:.76rem;display:block}.keyboard-card{min-height:0;padding:12px 14px;display:flex}.keyboard{flex-direction:column;justify-content:center;gap:6px;width:100%;min-height:0;display:flex}.key-row{justify-content:center;gap:6px;min-width:0;display:flex}.key{color:#f6fbffd1;text-transform:lowercase;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;flex:1 1 0;width:100%;max-width:78px;height:44px;font-size:1.16rem;font-weight:900;transition:transform .11s,background .11s,border-color .11s,color .11s,box-shadow .11s}.key:hover{background:#ffffff1a;transform:translateY(-1px)}.key.home{background:var(--home);border-color:#ffd36a52}.key.bump:after{content:"";background:#ffd36ad9;border-radius:999px;width:13px;height:2px;margin:2px auto 0;display:block}.key.current{color:#e9fbff;background:#73e0ff33;border-color:#73e0fff2;transform:translateY(-2px);box-shadow:0 8px 25px #73e0ff29}.key.space{flex:0 46%;min-width:160px;max-width:560px}.key.hit-press{color:#f1fff1;background:#9aff9a33;border-color:#9aff9af2;box-shadow:0 8px 24px #9aff9a2e}.key.miss-press{color:#ffe6e8;background:#ff7f8633;border-color:#ff7f86f2;box-shadow:0 8px 24px #ff7f8629}.key.missed:not(.current){border-color:#ff7f8673}.privacy-note{margin:4px 0 0;font-size:.84rem;line-height:1.35}.button{border:1px solid var(--line);min-height:42px;color:var(--ink);cursor:pointer;background:#ffffff14;border-radius:999px;justify-content:center;align-items:center;padding:0 15px;font-weight:850;transition:transform .12s,background .12s,border-color .12s;display:inline-flex;box-shadow:0 10px 30px #00000029}.button:hover{background:#ffffff1f;transform:translateY(-1px)}.button:disabled,.key:disabled{cursor:not-allowed;opacity:.5;transform:none}.button[aria-pressed=true]{background:#73e0ff24;border-color:#73e0ff8c}.button.primary{background:linear-gradient(#ffd36a52,#ffb15238);border-color:#ffd36ab3}.button.secondary{background:#73e0ff24;border-color:#73e0ff73}.button.ghost{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#090e17b8}.button.subtle{color:var(--muted)}.button.icon{width:42px;padding:0;font-size:1.5rem}.button.danger{color:#ffd0d3;background:#ff7f861f;border-color:#ff7f8659}.modal,.end-overlay{z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#03070cb8;place-items:center;padding:22px;display:grid;position:fixed;inset:0}.modal.hidden,.end-overlay.hidden{display:none}.modal-card,.end-card{border:1px solid var(--line);background:linear-gradient(#121f31fa,#090f19fa);border-radius:28px;width:min(980px,100%);max-height:min(820px,100vh - 44px);overflow:auto;box-shadow:0 30px 100px #00000075}.modal-card{padding:22px}.modal-header,.modal-footer,.end-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.modal-footer{flex-wrap:wrap;justify-content:flex-end;margin-top:18px}.level-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:18px;display:grid}.level-chapter-divider{border-top:1px solid var(--line);color:var(--accent-2);text-transform:uppercase;letter-spacing:.05em;margin:6px 0;padding:8px 0;font-size:.75rem;font-weight:800}.level-choice{border:1px solid var(--line);min-height:116px;color:var(--ink);text-align:left;cursor:pointer;background:#ffffff0f;border-radius:18px;padding:14px}.level-choice:hover:not(:disabled){background:#73e0ff1a;border-color:#73e0ff8c}.level-choice strong,.level-choice span,.level-choice small{display:block}.level-choice strong{margin-bottom:4px}.level-choice span{color:var(--muted);font-size:.82rem;line-height:1.25}.level-choice small{color:var(--accent);margin-top:8px}.level-choice.current-level{border-color:#ffd36abf}.settings-card{width:min(560px,100%)}.settings-list{flex-direction:column;gap:12px;margin-top:18px;display:flex}.settings-row{border:1px solid var(--line);background:#ffffff0a;border-radius:18px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.settings-label strong{font-size:1.02rem;display:block}.settings-label span{color:var(--muted);margin-top:3px;font-size:.84rem;display:block}.settings-segment{gap:6px;display:inline-flex}.end-card{text-align:center;max-width:660px;padding:30px}.end-card h2{letter-spacing:0;font-size:2.4rem}.end-card p{color:var(--muted);line-height:1.5}.end-stats{flex-wrap:wrap;justify-content:center;gap:10px;margin:18px 0;display:flex}.end-stat{border:1px solid var(--line);background:#ffffff0f;border-radius:16px;min-width:120px;padding:12px}.end-stat strong,.end-stat span{display:block}.end-stat strong{font-size:1.25rem}.end-stat span{color:var(--muted);text-transform:uppercase;letter-spacing:0;margin-top:3px;font-size:.76rem}.end-coach{text-align:left;background:#73e0ff17;border:1px solid #73e0ff47;border-radius:18px;gap:6px;max-width:560px;margin:-2px auto 16px;padding:14px 16px;display:grid}.end-coach strong,.end-coach span{display:block}.end-coach strong{color:var(--ink);font-size:1rem}.end-coach span{color:var(--muted);line-height:1.4}.end-coach.strong{background:#9aff9a1a;border-color:#9aff9a57}.end-coach.focus{background:#ffd36a1a;border-color:#ffd36a57}.end-review{color:var(--muted);margin:4px auto 18px}.end-review strong{color:var(--ink);margin-bottom:8px;display:block}.end-review div{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.end-review span{color:#ffd0d3;background:#ff7f861c;border:1px solid #ff7f8657;border-radius:999px;align-items:center;min-height:34px;padding:0 12px;font-weight:850;display:inline-flex}.hidden{display:none!important}.end-actions{flex-wrap:wrap;justify-content:center}.good-pop{animation:.26s goodPop}.bad-shake{animation:.27s badShake}.is-paused .scene-mount canvas{filter:saturate(.72)brightness(.9)}.reduce-motion *,.reduce-motion :before,.reduce-motion :after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}@keyframes goodPop{50%{transform:scale(1.015)}}@keyframes badShake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}@media (width<=980px){html,body{overflow:auto}.app-shell,body[data-layout=side] .app-shell{grid-template:"scene""side""band"/1fr;height:auto;min-height:100dvh}.scene-shell{min-height:360px}.side-pane{border-left:0;border-top:1px solid var(--line);overflow:visible}.play-band,body[data-layout=side] .play-band{border-left:0;border-top:1px solid var(--line);box-shadow:none;grid-template:"target""lesson""keyboard"/1fr;overflow:visible}.target-card{grid-template-rows:auto auto auto;grid-template-columns:auto minmax(0,1fr);align-items:center}.target-label,.feedback{grid-column:1/-1}.target-key{width:112px}}@media (width<=640px){.scene-topbar{top:12px;left:12px;right:12px}.level-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.level-card,.modal-header{flex-direction:column;align-items:flex-start}.score-stack{text-align:left}.side-pane,.play-band{padding:12px}.stats-row{grid-template-columns:repeat(3,minmax(0,1fr))}.lesson-text{font-size:1.2rem}.key{border-radius:8px;height:40px;font-size:.92rem}.key-row{gap:4px}.keyboard{gap:6px}.target-key{min-height:52px;font-size:2.25rem}.button{min-height:38px;padding:0 12px;font-size:.9rem}.button.icon{width:38px;padding:0;font-size:1.35rem}.end-card{padding:22px}.end-card h2{font-size:2rem}.end-stat{min-width:96px}.key.space{min-width:130px}}@media (width<=440px){.topbar-group{gap:6px}.scene-shell{min-height:330px}.stats-row{grid-template-columns:repeat(2,minmax(0,1fr))}.key{height:36px;padding:0;font-size:.82rem}.key.space{min-width:116px}}.modal{z-index:30}.end-overlay{z-index:20}
