:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#12202f;--muted:#647184;--paper:#fbfcf8;--panel:#ffffffc7;--panel-strong:#ffffffeb;--line:#20324621;--line-soft:#ffffffad;--blue:#2563eb;--teal:#0f9f8d;--amber:#f59e0b;--rose:#ee5e52;--plum:#7c3aed;--shadow:0 26px 80px #26364d2e;--soft-shadow:0 14px 34px #26364d1c}*{box-sizing:border-box}html{background:linear-gradient(115deg,#2563eb29,#0000 34%),linear-gradient(245deg,#0f9f8d26,#0000 32%),linear-gradient(#f8fbff 0%,#f5fbf7 48%,#fff8ed 100%);min-height:100%;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{min-height:100vh;color:var(--ink);margin:0;overflow-x:hidden}body:before{content:"";z-index:-1;pointer-events:none;background-image:linear-gradient(#12202f0b 1px,#0000 1px),linear-gradient(90deg,#12202f0a 1px,#0000 1px);background-size:72px 72px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000b3,#0000 84%);mask-image:linear-gradient(#000000b3,#0000 84%)}button,input,textarea{font:inherit}button{color:inherit}h1,h2,h3,p{margin-top:0}.topbar{z-index:20;border:1px solid var(--line-soft);width:min(1180px,100% - 28px);height:68px;box-shadow:var(--soft-shadow);-webkit-backdrop-filter:blur(24px)saturate(1.2);backdrop-filter:blur(24px)saturate(1.2);background:#ffffffb8;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;margin:16px auto 0;padding:10px 12px;display:flex;position:sticky;top:16px}.brand-mark,.nav-link,.menu-button,.drawer-head button,.drawer-link,.back-link{cursor:pointer;background:0 0;border:0}.brand-mark{align-items:center;gap:10px;min-width:0;font-weight:900;display:inline-flex}.brand-mark img{border-radius:14px;width:42px;height:42px;box-shadow:0 10px 24px #2563eb2e}.desktop-nav,.top-actions{align-items:center;gap:8px;display:flex}.nav-link{min-height:42px;color:var(--muted);border-radius:13px;align-items:center;gap:8px;padding:0 14px;font-weight:750;transition:background .18s,color .18s,transform .16s;display:inline-flex}.nav-link:hover,.nav-link.is-active{color:var(--ink);background:#ffffffd1;transform:translateY(-1px)}.menu-button{background:#ffffffc7;border-radius:14px;place-items:center;width:44px;height:44px;display:none}.account-pill{border:1px solid var(--line-soft);background:var(--panel-strong);cursor:pointer;border-radius:14px;align-items:center;gap:8px;max-width:220px;min-height:44px;padding:0 12px;font-weight:850;display:inline-flex;box-shadow:0 10px 24px #26364d14}.account-pill span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.mobile-drawer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#12202f3d;padding:16px;display:none;position:fixed;inset:0}.drawer-card{border:1px solid var(--line-soft);width:min(360px,100%);box-shadow:var(--shadow);background:#ffffffdb;border-radius:18px;margin-left:auto;padding:16px}.drawer-head,.drawer-link{justify-content:space-between;align-items:center;gap:12px;display:flex}.drawer-head{margin-bottom:12px}.drawer-head button{background:#fffc;border-radius:12px;place-items:center;width:38px;height:38px;display:grid}.drawer-link{width:100%;min-height:48px;color:var(--muted);border-radius:13px;margin-top:8px;padding:0 12px}.drawer-link span{margin-right:auto}.drawer-link.is-active,.drawer-link:hover{color:var(--ink);background:#ffffffeb}.drawer-auth{border-top:1px solid var(--line);gap:10px;margin-top:14px;padding-top:14px;display:grid}.auth-overlay{z-index:60;-webkit-backdrop-filter:blur(16px)saturate(1.08);backdrop-filter:blur(16px)saturate(1.08);background:#12202f4d;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.auth-card{border:1px solid var(--line-soft);width:min(470px,100%);box-shadow:var(--shadow);background:#ffffffe6;border-radius:20px;padding:26px;position:relative}.auth-card h2{margin-bottom:10px;font-size:clamp(1.8rem,5vw,2.6rem);line-height:1.02}.auth-note,.hero-lead,.workspace-head p,.music-hero p,.requirements-band p{color:var(--muted);line-height:1.6}.auth-close{cursor:pointer;background:#ffffffbf;border:0;border-radius:12px;place-items:center;width:40px;height:40px;display:grid;position:absolute;top:14px;right:14px}.auth-field{margin-bottom:12px}.icon-input{border:1px solid var(--line);background:#ffffffb8;border-radius:14px;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding-left:14px;display:grid}.icon-input svg{color:var(--muted)}.icon-input input{box-shadow:none;background:0 0;border:0;border-radius:0 14px 14px 0}.auth-alert{margin:0 0 14px}.auth-switch{width:100%;min-height:42px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:12px;margin-top:12px;font-weight:850}.home-screen,.workspace{width:min(1180px,100% - 28px);margin:22px auto 64px}.hero-section{border:1px solid var(--line-soft);min-height:calc(100vh - 132px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(30px)saturate(1.18);backdrop-filter:blur(30px)saturate(1.18);background:linear-gradient(145deg,#ffffffd6,#ffffff80),linear-gradient(110deg,#2563eb1a,#f59e0b1a);border-radius:24px;grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr);align-items:center;gap:30px;padding:40px;display:grid;overflow:hidden}.kicker{color:#0b6f74;text-transform:uppercase;align-items:center;gap:8px;margin:0 0 14px;font-size:.82rem;font-weight:900;display:inline-flex}.hero-section h1,.workspace-head h1,.result-hero h1{letter-spacing:0;margin-bottom:18px;font-size:clamp(3rem,8vw,6.8rem);line-height:.9}.workspace-head h1,.result-hero h1{font-size:clamp(2.2rem,6vw,4.8rem)}.hero-lead,.workspace-head p{max-width:720px;font-size:clamp(1rem,2vw,1.2rem)}.hero-actions,.inline-actions{flex-wrap:wrap;gap:12px;margin-top:26px;display:flex}.btn{border:1px solid var(--line-soft);min-height:48px;color:var(--ink);cursor:pointer;background:#ffffffd6;border-radius:14px;justify-content:center;align-items:center;gap:9px;padding:0 18px;font-weight:850;transition:transform .16s,box-shadow .18s,background .18s;display:inline-flex;box-shadow:0 12px 26px #2563eb1c}.btn-primary{color:#fff;background:linear-gradient(135deg,#2563eb,#0f9f8d)}.btn-ghost{color:var(--ink)}.btn:hover{transform:translateY(-2px);box-shadow:0 18px 34px #26364d29}.btn:disabled{cursor:wait;opacity:.68;transform:none}.is-loading svg,.spin{animation:.9s linear infinite spin}.hero-visual{min-height:520px;animation:.7s .12s both floatIn;position:relative}.study-orbit{aspect-ratio:1;background:#ffffff57;border:1px solid #12202f14;border-radius:999px;place-items:center;display:grid;position:absolute;inset:70px 16% auto}.study-orbit img{border-radius:28px;width:min(190px,52%);box-shadow:0 28px 70px #2563eb2e}.orbit-dot{aspect-ratio:1;background:var(--amber);border-radius:999px;width:16px;position:absolute}.dot-a{top:12%;right:18%}.dot-b{background:var(--teal);bottom:18%;left:12%}.dot-c{background:var(--rose);bottom:10%;right:24%}.glass-sheet{border:1px solid var(--line-soft);-webkit-backdrop-filter:blur(24px)saturate(1.18);backdrop-filter:blur(24px)saturate(1.18);background:#ffffffad;border-radius:20px;place-items:center;gap:12px;width:214px;height:250px;font-weight:900;display:grid;position:absolute;box-shadow:0 24px 64px #26364d29}.sheet-a{color:var(--blue);top:42px;left:2%;transform:rotate(-7deg)}.sheet-b{color:var(--rose);top:150px;right:4%;transform:rotate(6deg)}.sheet-c{color:var(--teal);bottom:16px;left:30%;transform:rotate(-1deg)}.feature-strip,.composer-grid,.history-grid,.requirements-grid,.review-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px;display:grid}.flow-card,.glass-panel,.history-card,.requirements-band,.result-hero{border:1px solid var(--line-soft);background:var(--panel);box-shadow:var(--soft-shadow);-webkit-backdrop-filter:blur(22px)saturate(1.12);backdrop-filter:blur(22px)saturate(1.12);border-radius:18px}.flow-card{padding:22px;animation:.52s both riseIn}.flow-card svg{color:var(--blue)}.flow-card:nth-child(2) svg{color:var(--amber)}.flow-card:nth-child(3) svg{color:var(--teal)}.flow-card h2,.history-card h2{margin:12px 0 8px;font-size:1.1rem}.flow-card p,.history-card p,.panel-title p,.question-card p,.review-card p{color:var(--muted);margin-bottom:0;line-height:1.55}.requirements-band{grid-template-columns:minmax(0,.9fr) minmax(360px,1.1fr);align-items:center;gap:22px;margin-top:18px;padding:24px;display:grid}.requirements-band h2{margin-bottom:10px}.requirements-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:0}.requirements-grid span{border:1px solid var(--line);min-height:42px;color:var(--muted);background:#ffffffa3;border-radius:12px;align-items:center;padding:0 12px;font-weight:850;display:inline-flex}.workspace-head{border:1px solid var(--line-soft);box-shadow:var(--soft-shadow);-webkit-backdrop-filter:blur(22px)saturate(1.12);backdrop-filter:blur(22px)saturate(1.12);background:#ffffffa8;border-radius:20px;grid-template-columns:auto 1fr minmax(180px,240px);align-items:start;gap:20px;padding:28px;display:grid}.back-link{min-height:42px;color:var(--muted);background:#ffffffbd;border-radius:13px;align-items:center;gap:8px;padding:0 12px;font-weight:850;display:inline-flex}.progress-card{border:1px solid var(--line-soft);background:#ffffffb3;border-radius:16px;padding:16px}.progress-card span{font-weight:950}.progress-card div,.quiz-progress{background:#12202f1a;border-radius:999px;height:9px;margin-top:12px;overflow:hidden}.progress-card i,.quiz-progress i{border-radius:inherit;background:linear-gradient(90deg, var(--blue), var(--teal), var(--amber));height:100%;transition:width .28s;display:block}.alert{color:#9b2e20;background:#fff1efdb;border:1px solid #ee5e5257;border-radius:14px;margin-top:16px;padding:14px 16px;font-weight:850}.account-nudge{min-height:58px;box-shadow:var(--soft-shadow);color:var(--muted);background:#ffffffa8;border:1px solid #2563eb2e;border-radius:16px;align-items:center;gap:12px;margin-top:16px;padding:12px 14px;font-weight:800;display:flex}.account-nudge svg{color:var(--blue);flex:none}.account-nudge span{flex:1}.account-nudge button{border:1px solid var(--line-soft);cursor:pointer;background:#ffffffd1;border-radius:12px;min-height:38px;font-weight:900}.composer-grid{grid-template-columns:minmax(320px,.88fr) minmax(0,1.12fr);align-items:start}.glass-panel{padding:22px}.panel-title{align-items:flex-start;gap:12px;margin-bottom:18px;display:flex}.panel-title svg{color:var(--blue);flex:none}.panel-title h2{margin-bottom:4px;font-size:1.18rem}.segmented{background:#12202f14;border-radius:14px;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px;padding:5px;display:grid}.segmented button{min-height:40px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:11px;font-weight:850}.segmented button.is-active{color:var(--ink);background:#ffffffe6;box-shadow:0 8px 18px #26364d14}.field{color:var(--muted);gap:8px;margin-bottom:14px;font-weight:850;display:grid}textarea,input{border:1px solid var(--line);width:100%;color:var(--ink);background:#ffffffb8;border-radius:14px;outline:none;box-shadow:inset 0 1px #ffffffdb}textarea{resize:vertical;min-height:240px;padding:16px;line-height:1.55}input{min-height:46px;padding:0 14px}textarea:focus,input:focus{border-color:#2563eb80;box-shadow:0 0 0 4px #2563eb1f}.file-drop{min-height:74px;color:var(--muted);cursor:pointer;background:#ffffff94;border:1px dashed #2563eb6b;border-radius:16px;align-items:center;gap:12px;margin-bottom:14px;padding:16px;font-weight:850;display:flex;position:relative}.file-drop input{opacity:0;cursor:pointer;position:absolute;inset:0}.compact-field{margin-bottom:18px}.output-panel{min-height:560px}.summary-meta,.topic-list,.weak-list{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.summary-meta span,.topic-list span,.weak-list span,.question-count,.history-date{border:1px solid var(--line);min-height:30px;color:var(--muted);background:#ffffffad;border-radius:999px;align-items:center;padding:0 10px;font-size:.82rem;font-weight:850;display:inline-flex}.summary-body{max-height:470px;padding-right:6px;overflow:auto}.summary-body p{color:#273242;background:#ffffff80;border-radius:12px;margin-bottom:10px;padding:10px 12px;line-height:1.58}.summary-section-line{font-weight:900;color:var(--ink)!important;background:#ffffffd6!important}.empty-state,.loading-panel{text-align:center;min-height:310px;color:var(--muted);align-content:center;place-items:center;gap:10px;display:grid}.empty-state svg{color:var(--amber)}.quiz-lock-note{color:#17695e;background:#ebfffab8;border:1px solid #0f9f8d33;border-radius:14px;align-items:flex-start;gap:10px;margin-top:14px;padding:12px;font-weight:800;line-height:1.45;display:flex}.quiz-shell{color:#fff;background:linear-gradient(135deg,#12202ff5,#152a3df0),linear-gradient(120deg,#2563eb3d,#0f9f8d33);place-items:center;min-height:100vh;padding:24px;display:grid}.quiz-window,.quiz-empty{-webkit-backdrop-filter:blur(26px)saturate(1.16);backdrop-filter:blur(26px)saturate(1.16);background:#ffffff14;border:1px solid #ffffff29;border-radius:22px;width:min(980px,100%);box-shadow:0 34px 110px #00000047}.quiz-window{padding:24px}.quiz-empty{text-align:center;align-content:center;place-items:center;gap:14px;min-height:460px;padding:32px;display:grid}.quiz-empty img{border-radius:22px;width:92px}.quiz-empty p{color:#ffffffb8;max-width:480px}.quiz-header{justify-content:space-between;align-items:center;gap:18px;display:flex}.quiz-brand{align-items:center;gap:14px;display:flex}.quiz-brand img{border-radius:16px;width:58px;height:58px}.quiz-brand h1{margin-bottom:0;font-size:clamp(2rem,5vw,4rem);line-height:.95}.quiz-window .kicker{color:#8ee7dd}.timer-pill{color:#fff;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:16px;justify-content:center;align-items:center;gap:10px;min-width:132px;min-height:52px;padding:0 16px;font-size:1.12rem;font-weight:950;display:inline-flex}.timer-pill.is-urgent{color:#ffd1cc;background:#ee5e5233}.quiz-rulebar{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:20px 0;display:grid}.quiz-rulebar span{color:#ffffffc7;background:#ffffff14;border:1px solid #ffffff24;border-radius:14px;align-items:center;min-height:44px;padding:10px 12px;font-weight:800;display:flex}.active-question{background:#ffffff1a;border:1px solid #ffffff24;border-radius:18px;padding:22px}.question-topline{color:#ffffffad;flex-wrap:wrap;justify-content:space-between;gap:8px;margin-bottom:14px;font-weight:850;display:flex}.active-question h2{max-width:860px;font-size:clamp(1.35rem,3vw,2.3rem);line-height:1.18}.answer-grid{gap:10px;margin-top:16px;display:grid}.answer{cursor:pointer;color:var(--ink);background:#ffffff94;border:1px solid #2032461f;border-radius:14px;align-items:flex-start;gap:10px;padding:13px;transition:border-color .16s,background .16s,transform .16s;display:flex}.quiz-window .answer{color:#fff;background:#ffffff1a;border-color:#ffffff24}.answer:hover,.answer.is-selected{background:#ffffffd6;border-color:#2563eb6b;transform:translateY(-1px)}.quiz-window .answer:hover,.quiz-window .answer.is-selected{background:#8ee7dd29;border-color:#8ee7ddb8}.answer input{width:18px;min-height:18px;margin-top:2px}.quiz-footer{justify-content:space-between;gap:12px;margin-top:18px;display:flex}.result-workspace{gap:18px;display:grid}.result-hero{grid-template-columns:180px 1fr;align-items:center;gap:24px;padding:24px;display:grid}.result-hero.is-mastered{background:linear-gradient(145deg,#ffffffe0,#ebfffaad),linear-gradient(120deg,#0f9f8d1f,#f59e0b1f)}.score-ring{aspect-ratio:1;background:radial-gradient(circle, #ffffffeb 58%, transparent 59%), conic-gradient(var(--teal) var(--score), #12202f1f 0);width:168px;box-shadow:var(--soft-shadow);border-radius:999px;place-items:center;display:grid}.score-ring span{font-size:2rem;font-weight:950}.review-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.review-card{box-shadow:var(--soft-shadow);background:#ffffffb8;border:1px solid #ee5e5238;border-radius:16px;padding:18px}.review-card.is-correct{border-color:#0f9f8d3d}.review-head{color:var(--muted);justify-content:space-between;gap:12px;margin-bottom:12px;font-weight:900;display:flex}.review-head span{color:var(--blue)}.review-card h2{font-size:1.1rem}.history-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.history-card{flex-direction:column;justify-content:space-between;gap:18px;min-height:260px;padding:20px;display:flex}.music-hero{border:1px solid var(--line-soft);min-height:calc(100vh - 132px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(28px)saturate(1.18);backdrop-filter:blur(28px)saturate(1.18);background:linear-gradient(145deg,#ffffffd6,#ffffff85),linear-gradient(110deg,#0f9f8d1f,#7c3aed1a);border-radius:24px;grid-template-columns:minmax(340px,.62fr) minmax(520px,1.38fr);align-items:center;gap:34px;padding:38px;display:grid}.music-hero h1{white-space:nowrap;margin-bottom:18px;font-size:clamp(2.8rem,4.2vw,4rem);line-height:1}.music-copy{z-index:2;min-width:0;position:relative}.music-copy p:not(.kicker){color:#40516a;max-width:460px;font-size:1.08rem;font-weight:650}.music-link{width:max-content;margin-top:20px}.music-frame-shell{z-index:1;border:1px solid var(--line-soft);min-width:0;box-shadow:var(--shadow);background:#ffffffc7;border-radius:18px;position:relative;overflow:hidden}.music-frame-toolbar{border-bottom:1px solid var(--line-soft);width:100%;min-height:48px;color:var(--plum);background:#ffffffd1;align-items:center;gap:10px;padding:0 14px;font-weight:950;display:inline-flex}.music-frame{background:#fff;border:0;width:100%;height:min(680px,100vh - 230px);min-height:520px;display:block}@keyframes riseIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes floatIn{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=920px){.desktop-nav{display:none}.menu-button{display:grid}.mobile-drawer.is-open{display:block}.hero-section,.composer-grid,.workspace-head,.result-hero,.music-hero,.requirements-band,.quiz-rulebar{grid-template-columns:1fr}.hero-section{min-height:auto;padding:24px}.hero-visual{min-height:380px}.study-orbit{inset:40px 12% auto}.glass-sheet{width:170px;height:202px}.feature-strip,.history-grid,.review-grid{grid-template-columns:1fr}.progress-card{width:100%}.music-frame{height:62vh;min-height:420px}.music-copy p:not(.kicker){max-width:680px}}@media (width<=560px){.topbar,.home-screen,.workspace{width:min(100% - 18px,1180px)}.brand-mark span{display:none}.topbar{border-radius:16px;height:62px;margin-top:8px;top:8px}.account-pill{max-width:126px;min-height:40px;padding:0 9px}.hero-actions,.inline-actions,.account-nudge,.quiz-footer,.quiz-header{flex-direction:column;align-items:stretch}.btn,.account-nudge button{width:100%}.hero-section h1,.workspace-head h1,.music-hero h1,.result-hero h1{font-size:3rem}.music-link{width:100%}.hero-section,.workspace-head,.glass-panel,.music-hero,.quiz-window,.result-hero,.requirements-band{border-radius:18px;padding:18px}.requirements-grid{grid-template-columns:1fr}.summary-body{max-height:380px}.sheet-a{left:0}.sheet-b{right:0}.sheet-c{left:18%}}
