:root{--background:#0e0f12;--surface:#1c1e24;--surface-raised:#23252d;--panel:#141820;--border:#343a46;--text:#f8fafc;--muted-text:#a1a1aa;--ice:#e6f6ff;--blue:#e6f6ff;--primary:#0f9f8f;--primary-shadow:rgba(15,159,143,.22);--amber:#f59e0b;--green:#22c55e;--red:#ef4444;--muted:#64748b;--black:#080b10;--radius:8px;--magenta:#d946ef;--yellow:#facc15}*{box-sizing:border-box;margin:0;padding:0}body,html{overflow-x:hidden}body{max-width:100vw;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--background);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--blue);text-decoration:none}.page{max-width:1720px;margin:0 auto;padding:28px}.intro{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.intro h1{margin:0 0 8px;font-size:28px;line-height:1.2}.intro p{margin:0;color:var(--muted-text);font-size:14px;max-width:760px}.toc{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.button,.chip{display:inline-flex;align-items:center;justify-content:center;height:38px;padding:0 16px;border-radius:999px;border:1px solid rgba(230,246,255,.34);background:var(--surface);color:var(--text);font-size:13px;font-weight:650;cursor:pointer;transition:all .15s ease;white-space:nowrap}.button:hover{background:var(--surface-raised);border-color:rgba(230,246,255,.5)}.button.primary{background:var(--primary);color:#fff;border-color:transparent;box-shadow:0 10px 24px var(--primary-shadow)}.button.primary:hover{background:#0d8a7d}.button.secondary{background:rgba(230,246,255,.06);color:var(--ice);border-color:rgba(230,246,255,.18);box-shadow:none;font-weight:650}.button.success{background:var(--green);color:#04140a;border-color:transparent}.button.danger{background:var(--red);color:#1a0202;border-color:transparent}.button.ghost{background:transparent;color:var(--ice)}.button.practice-gradient{background:linear-gradient(90deg,var(--magenta),var(--amber));color:#fff;border-color:transparent;box-shadow:0 10px 24px rgba(217,70,239,.18)}.mockup-grid{display:grid;grid-gap:28px;gap:28px}.mockup-section{display:grid;grid-gap:12px;gap:12px}.section-title{margin:0;font-size:18px;line-height:1.25}.section-note{margin:0;color:var(--muted-text);font-size:13px}.screen{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.28)}.desktop{width:1440px;min-height:860px}.mobile{width:390px;min-height:844px}.tablet{width:900px;min-height:760px}.row{display:flex;gap:12px;align-items:center}.space-between{justify-content:space-between}.stack{display:grid;grid-gap:12px;gap:12px}.two-col{display:grid;grid-template-columns:1fr 380px;grid-gap:24px;gap:24px}.three-col{grid-template-columns:repeat(3,1fr);grid-gap:12px}.five-col,.three-col{display:grid;gap:12px}.five-col{grid-template-columns:repeat(5,1fr);grid-gap:12px}.topbar{height:56px;background:var(--background);border-bottom:1px solid var(--border);display:flex;padding:0 24px;gap:22px}.brand,.topbar{align-items:center}.brand{display:inline-flex;gap:8px;font-size:15px;font-weight:800}.brand-icon{width:24px;height:24px;border-radius:6px;background:url(/icons/icon-192.png) 50%/cover no-repeat;display:grid;place-items:center;box-shadow:0 0 0 1px rgba(255,255,255,.12);overflow:hidden}.brand-icon svg{display:none}.search{width:420px;height:32px;border:1px solid rgba(230,246,255,.24);border-radius:999px;background:var(--surface);color:var(--muted-text);display:flex;align-items:center;padding:0 14px;font-size:13px}.shell{display:grid;grid-template-columns:248px 1fr;min-height:804px;min-width:0}.sidebar{background:linear-gradient(180deg,rgba(230,246,255,.035),transparent 40%),#111217;border-right:1px solid var(--border);padding:20px 16px;display:flex;flex-direction:column;gap:16px}.nav{display:grid;grid-gap:8px;gap:8px}.nav-item{height:42px;display:flex;align-items:center;gap:10px;padding:0 12px 0 10px;border-radius:999px;color:var(--muted-text);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s ease;text-decoration:none}.nav-item:hover{background:rgba(230,246,255,.05)}.nav-item.active{background:rgba(230,246,255,.11);color:var(--ice);font-weight:750}.nav-icon{width:26px;height:26px;border-radius:8px;display:inline-grid;place-items:center;flex:0 0 auto;color:var(--ice);background:rgba(230,246,255,.08);box-shadow:inset 0 0 0 1px rgba(230,246,255,.1)}.nav-item.active .nav-icon{background:var(--primary);color:#fff;box-shadow:0 10px 24px var(--primary-shadow)}.nav-icon svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sidebar-visual{margin-top:auto;min-height:164px;border-radius:18px;border:1px solid rgba(230,246,255,.12);overflow:hidden;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.74)),url(/assets/loading-visual.png) 50% /cover;display:grid;align-content:end;grid-gap:6px;gap:6px;padding:14px;box-shadow:0 18px 48px rgba(0,0,0,.26)}.sidebar-visual strong{font-size:14px;line-height:1.2}.sidebar-visual span{color:var(--muted-text);font-size:12px;font-weight:700;line-height:1.35}.content{padding:28px 32px 34px;min-width:0}.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-head h2{margin:0;font-size:28px;line-height:1.2}.page-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}.panel h3{margin:0 0 16px;font-size:18px;line-height:1.25}.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;min-height:92px}.metric .label,.muted{color:var(--muted-text);font-size:12px}.metric .value{font-size:26px;font-weight:800;margin-top:6px}.metric .delta{font-size:12px;margin-top:6px;font-weight:650}.green{color:var(--green)}.blue{color:var(--blue)}.amber{color:var(--amber)}.red{color:var(--red)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{color:var(--muted-text);font-size:12px;text-align:left;font-weight:750;padding:0 0 10px;border-bottom:1px solid var(--border)}.table td{padding:14px 0;border-bottom:1px solid rgba(52,58,70,.6);color:var(--text)}.table tr:last-child td{border-bottom:0}.table td>*{min-width:0}.status{display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface-raised);color:var(--text);font-size:12px;font-weight:700}.status.ready{color:var(--green);border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.1)}.status.warn{color:var(--amber);border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.1)}.status.fail{color:var(--red)}.filterbar{display:flex;gap:10px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.filterbar .search{width:320px}.filterbar .row{flex:1 1;min-width:0;flex-wrap:wrap}.cards{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:18px;gap:18px}.content-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:184px;padding:18px;position:relative;overflow:hidden}.assignment-card-wrapper.has-song-thumb,.content-card-wrapper.has-song-thumb,.content-card.has-song-thumb{min-height:220px;padding-top:104px}.song-thumb{position:absolute;left:18px;right:18px;top:18px;height:74px;border-radius:6px;object-fit:cover;width:calc(100% - 36px);border:1px solid rgba(230,246,255,.16);box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}.content-card:before{content:"";position:absolute;left:0;right:0;top:0;height:6px}.content-card.exercise:before,.content-card.song:before,.content-card:before{background:var(--primary)}.content-card h3{margin:10px 0 8px;font-size:15px;font-weight:700}.content-card .meta{color:var(--muted-text);font-size:12px;margin-bottom:8px}.card-actions{position:absolute;right:18px;bottom:18px;display:flex;gap:8px}.form-grid{display:grid;grid-gap:12px;gap:12px}.field{display:grid;grid-gap:6px;gap:6px}.field label{color:var(--muted-text);font-size:12px;font-weight:600}.input{min-height:38px;border:1px solid var(--border);background:var(--surface-raised);border-radius:6px;padding:10px 12px;color:var(--text);font-size:13px;outline:none;transition:border-color .15s ease;width:100%}.input:focus{border-color:var(--primary)}.input::placeholder{color:var(--muted-text)}.google-button{height:44px;border-radius:6px;border:1px solid rgba(230,246,255,.26);background:#f8fafc;color:#111217;display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:700;cursor:pointer}.google-button:hover{background:#e2e8f0}.bottom-nav{height:60px;background:var(--background);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(3,1fr);align-items:center;text-align:center;color:var(--muted-text);font-size:12px;font-weight:700;position:-webkit-sticky;position:sticky;bottom:0}.bottom-nav .active{color:var(--ice)}.practice{min-height:100vh;display:grid;grid-template-rows:58px 1fr}.practice,.practice-header{background:var(--background)}.practice-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 24px;border-bottom:1px solid var(--border)}.practice-title{display:flex;align-items:baseline;gap:14px}.practice-title h1{margin:0;font-size:18px}.practice-title span{color:var(--muted-text);font-size:13px}.practice-content{padding:28px 56px 34px;display:grid;grid-gap:24px;gap:24px}.karaoke-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.karaoke-stat{padding:12px;border-radius:8px;background:rgba(8,11,16,.46);border:1px solid rgba(230,246,255,.12)}.karaoke-stat span{display:block;color:var(--muted-text);font-size:12px;font-weight:750}.karaoke-stat strong{display:block;font-size:24px;margin-top:6px}.piano-roll{height:430px;border:1px solid var(--border);border-radius:8px;background:var(--black);overflow:hidden}.results-page{min-height:100vh;display:grid;grid-template-rows:58px 1fr;background:radial-gradient(circle at 50% 12%,rgba(217,70,239,.18),transparent 34%)}.results-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 24px;background:rgba(14,15,18,.92);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.score-ring{width:210px;place-items:center;background:conic-gradient(var(--green) 0 87%,rgba(230,246,255,.13) 87% 100%),radial-gradient(circle,rgba(14,15,18,.98) 0 61%,transparent 62%);box-shadow:0 0 48px rgba(34,197,94,.16);margin:4px 0}.score-ring,.score-ring-inner{aspect-ratio:1;border-radius:50%;display:grid}.score-ring-inner{width:168px;background:#111217;border:1px solid rgba(230,246,255,.14);place-items:center}.score{font-size:84px;line-height:.95;font-weight:950;color:var(--green);text-shadow:0 0 34px rgba(34,197,94,.22)}.phrase-grid{grid-template-columns:repeat(6,1fr)}.phrase,.phrase-grid{display:grid;grid-gap:8px;gap:8px}.phrase{min-height:78px;padding:10px;border-radius:12px;background:rgba(8,11,16,.52);border:1px solid rgba(230,246,255,.1);align-content:space-between}.phrase strong{font-size:20px}.phrase span{color:var(--muted-text);font-size:12px;font-weight:750}.phrase.best{border-color:rgba(250,204,21,.55);box-shadow:inset 0 0 0 1px rgba(250,204,21,.12)}.phrase.weak{border-color:rgba(245,158,11,.55)}.accuracy-bar{height:14px;display:grid;grid-template-columns:55fr 22fr 10fr 8fr 5fr;grid-gap:1px;gap:1px;overflow:hidden;border-radius:999px;background:var(--black)}.accuracy-bar span:first-child{background:var(--green)}.accuracy-bar span:nth-child(2){background:var(--yellow)}.accuracy-bar span:nth-child(3){background:var(--amber)}.accuracy-bar span:nth-child(4){background:var(--red)}.accuracy-bar span:nth-child(5){background:rgba(230,246,255,.22)}.rail{height:6px;border-radius:999px;background:var(--border);overflow:hidden}.fill{height:100%;border-radius:inherit;background:var(--ice)}.fill.magenta{background:var(--magenta)}.fill.green{background:var(--green)}.stem{display:grid;grid-template-columns:58px 1fr 38px;align-items:center;grid-gap:10px;gap:10px;margin:14px 0;font-size:13px}.transport{display:grid;grid-gap:14px;gap:14px}.timeline{height:6px;background:var(--border);border-radius:999px;overflow:hidden;flex:1 1;min-width:500px}.mic-meter{height:92px;display:flex;align-items:flex-end;gap:5px;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--black)}.mic-meter span{flex:1 1;min-width:5px;border-radius:999px 999px 2px 2px;background:#2a2d35}.mic-meter .live{background:var(--green)}.mic-meter .warn{background:var(--amber)}.mic-meter .clip{background:var(--red)}.stat-row{display:grid;grid-template-columns:24px 1fr auto;grid-gap:10px;gap:10px;align-items:center;font-size:14px;font-weight:720}.stat-icon{width:22px;height:22px;place-items:center;background:rgba(230,246,255,.1);color:var(--amber);font-size:12px}.avatar,.stat-icon{border-radius:50%;display:grid}.avatar{width:52px;height:52px;place-items:center;background:linear-gradient(135deg,var(--magenta),var(--amber));color:#fff;font-weight:900}.loading-spinner{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--amber);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.app-shell{display:flex;flex-direction:column;min-height:100vh}.topnav{gap:8px;margin-left:auto}.topbar-actions,.topnav{display:flex;align-items:center}.topbar-actions{gap:10px}.metric-card{cursor:pointer;transition:all .15s ease}.metric-card:hover{border-color:rgba(230,246,255,.3);transform:translateY(-1px)}.data-table-wrapper{width:100%}.empty-state{text-align:center;padding:32px;color:var(--muted-text)}.empty-state p{margin:0}.assignment-card-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:184px;padding:18px;position:relative;overflow:hidden}.assignment-card-wrapper:before{content:"";position:absolute;left:0;right:0;top:0;height:6px;background:var(--primary)}.assignment-card-wrapper.completed:before{background:var(--green)}.assignment-card-wrapper h3{margin:10px 0 8px;font-size:15px;font-weight:700;color:var(--text)}.content-card-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:184px;padding:18px;position:relative;overflow:hidden}.favorite-button{width:28px;height:28px;border:1px solid rgba(230,246,255,.18);border-radius:6px;background:rgba(10,12,16,.72);color:var(--muted-text);cursor:pointer;line-height:1;flex:0 0 auto;display:inline-grid;place-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .15s ease,background .15s ease,color .15s ease}.favorite-button.active{color:#f8c14a;border-color:rgba(248,193,74,.46);background:rgba(72,49,8,.72)}.favorite-button.large{width:34px;height:34px;font-size:18px}.card-favorite{position:absolute;top:16px;right:16px;z-index:2}.assignment-card-wrapper.has-song-thumb .card-favorite,.content-card-wrapper.has-song-thumb .card-favorite{top:24px;right:24px}.le-player{--ps-s2:#182127;--ps-s3:#212C33;--ps-b:rgba(255,255,255,0.07);--ps-t:#F2F5F7;--ps-t-dim:#8B9AA3;--ps-t-mute:#525E66}.le-player,.practice-stage{--mint:#34E5B7;--mint-bright:#4EF0C4;--mint-soft:rgba(52,229,183,0.16);--mint-glow:rgba(52,229,183,0.35);--ps-ink:#07090C;--ps-ink-2:#0B1014}.practice-stage{--ps-s:#10171C;--ps-s2:#182127;--ps-s3:#212C33;--ps-b:rgba(255,255,255,0.07);--ps-b-strong:rgba(255,255,255,0.14);--ps-t:#F2F5F7;--ps-t-dim:#8B9AA3;--ps-t-mute:#525E66;width:100%;height:100dvh;min-height:0;overflow:hidden;background:var(--ps-ink);color:var(--ps-t);display:grid;grid-template-rows:auto 1fr}.practice-empty,.practice-loading{min-height:100vh;display:grid;place-content:center;justify-items:center;grid-gap:14px;gap:14px;color:var(--ps-t-mute);text-align:center;padding:24px;background:var(--ps-ink)}.practice-empty h1{color:var(--ps-t);font-size:28px;margin:0}.practice-empty p{max-width:440px;line-height:1.5}.practice-loading .loading-spinner{width:32px;height:32px;border-radius:50%;border:2px solid var(--ps-s3);border-top-color:var(--mint);animation:spin 1s linear infinite}.practice-top{height:60px;display:flex;align-items:center;gap:12px;padding:0 16px;border-bottom:1px solid var(--ps-b);background:var(--ps-ink-2)}.practice-back-btn{width:36px;height:36px;flex-shrink:0;border-radius:50%;background:var(--ps-s2);border:none;color:var(--ps-t);display:grid;place-items:center;cursor:pointer}.practice-heading{flex:1 1;min-width:0}.practice-heading span{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--ps-t-mute)}.practice-heading h1{margin:0;font-size:16px;font-weight:600;letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.practice-score-chip{display:flex;flex-direction:column;align-items:flex-end;padding:4px 10px;border-radius:10px;background:var(--mint-soft);border:1px solid rgba(52,229,183,.25)}.practice-score-chip span{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--mint)}.practice-score-chip strong{font-size:16px;font-weight:700;color:var(--mint-bright);line-height:1}.practice-done-btn{background:var(--mint);color:#062B22;border:none;font-weight:700;border-radius:10px;padding:10px 16px;font-size:13px;cursor:pointer;flex-shrink:0;font-family:inherit}.practice-done-btn:hover{background:var(--mint-bright)}.practice-done-btn:disabled{opacity:.6;cursor:not-allowed}.practice-main{flex-direction:column}.practice-content-area,.practice-main{min-height:0;display:flex;overflow:hidden;position:relative}.practice-content-area{flex:1 1;flex-direction:column}.practice-view-toggle{position:absolute;top:10px;right:12px;z-index:5;display:inline-flex;padding:3px;background:rgba(16,23,28,.78);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:999px;gap:2px}.view-toggle-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:none;border-radius:999px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit;transition:background .12s}.view-toggle-btn.active{background:var(--mint);color:#062B22}.view-toggle-btn:not(.active){background:transparent;color:var(--ps-t-dim)}.practice-karaoke-block{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 16px 8px;text-align:center;min-height:0;overflow:hidden;width:100%}.karaoke-prev{font-size:13px;color:var(--ps-t-mute);font-weight:500;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.karaoke-current{font-size:clamp(22px,5dvh,38px);font-weight:600;line-height:1.1;letter-spacing:-.02em;display:flex;flex-wrap:wrap;gap:.28em;justify-content:center;width:100%}.karaoke-word{transition:color .18s;color:var(--ps-t)}.karaoke-word.past{color:var(--ps-t-dim)}.karaoke-word.active{color:var(--mint-bright)}.karaoke-next{font-size:14px;color:var(--ps-t-dim);font-weight:500;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.karaoke-loading{width:100%;display:flex;align-items:center}.karaoke-loading-bar{height:22px;border-radius:8px;background:linear-gradient(90deg,var(--ps-s2) 25%,rgba(255,255,255,.07) 50%,var(--ps-s2) 75%);background-size:200% 100%}.karaoke-loading-bar,.lyrics-version-skeleton{animation:lyrics-shimmer 1.4s ease-in-out infinite}.lyrics-version-skeleton{height:28px;border-radius:6px;margin:2px 0;background:linear-gradient(90deg,var(--ps-s2) 25%,rgba(255,255,255,.06) 50%,var(--ps-s2) 75%);background-size:200% 100%}@keyframes lyrics-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.practice-yt-area{flex:1 1;min-height:0;overflow:hidden;background:#05070a}.practice-yt-area .youtube-reference{width:100%;height:100%;min-height:0;border:none}.practice-yt-area .youtube-reference iframe{width:100%;height:100%;border:0;display:block}.youtube-reference{min-height:0;border-radius:8px;overflow:hidden;background:#05070a;border:1px solid rgba(230,246,255,.11)}.youtube-reference iframe{display:block;width:100%;height:100%;min-height:64px;border:0}.practice-canvas-panel{height:116px;min-height:0;overflow:hidden;border-top:1px solid var(--ps-b);background:var(--ps-ink-2)}.practice-piano-canvas{display:block;width:100%;height:100%;cursor:-webkit-grab;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.practice-piano-canvas:active{cursor:-webkit-grabbing;cursor:grabbing}.practice-mic-bar{padding:4px 16px;background:var(--ps-ink-2);border-top:1px solid var(--ps-b);border-bottom:1px solid var(--ps-b);display:flex;align-items:center;gap:8px}.practice-mic-label{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--ps-t-mute);text-transform:uppercase;letter-spacing:.08em;font-weight:600;white-space:nowrap;flex-shrink:0}.practice-mic-segments{flex:1 1;display:flex;gap:2px;height:5px}.practice-mic-seg{flex:1 1;border-radius:2px;background:var(--ps-s3);opacity:.5}.practice-mic-seg.on{background:var(--mint);opacity:1}.practice-mic-seg.peak{background:#E8C46B;opacity:1}.practice-timeline-area{padding:5px 16px 4px;background:var(--ps-ink)}.practice-progress{height:8px;border-radius:999px;background:var(--ps-s2);position:relative;cursor:pointer;touch-action:none;outline:none;overflow:visible}.practice-progress:focus-visible{box-shadow:0 0 0 3px var(--mint-soft)}.progress-loop-range{background:var(--mint-soft);border:1px solid rgba(52,229,183,.35)}.progress-fill,.progress-loop-range{position:absolute;top:0;bottom:0;border-radius:999px}.progress-fill{left:0;background:var(--mint);pointer-events:none}.progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:var(--mint-bright);box-shadow:0 0 0 4px var(--mint-soft);pointer-events:none}.practice-progress .loop-marker{position:absolute;top:-12px;transform:translateX(-50%);font-style:normal;font-size:9px;font-weight:700;color:var(--mint);font-family:monospace;pointer-events:none}.practice-time-row{display:flex;justify-content:space-between;margin-top:6px;font-family:ui-monospace,monospace;font-size:11px;color:var(--ps-t-dim)}.practice-transport{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;align-items:center;padding:2px 16px 6px;grid-gap:8px;gap:8px;background:var(--ps-ink)}.transport-btn{background:transparent;border:none;color:var(--ps-t-dim);display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:4px;font-family:inherit}.transport-btn svg{width:20px;height:20px;fill:currentColor;display:block}.transport-btn span{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ps-t-mute)}.practice-play-btn{width:64px;height:64px;border-radius:50%;background:var(--mint);color:#062B22;border:none;display:grid;place-items:center;cursor:pointer;justify-self:center;box-shadow:0 6px 20px var(--mint-glow),0 0 0 6px var(--mint-soft);font-family:inherit}.practice-play-btn svg{width:26px;height:26px;fill:currentColor;display:block}.practice-play-btn:disabled{opacity:.6;cursor:not-allowed}.practice-chip-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-gap:6px;gap:6px;padding:4px 12px 8px;border-top:1px solid var(--ps-b);background:var(--ps-ink)}.practice-chip{display:inline-flex;align-items:center;gap:6px;padding:9px 10px;border-radius:999px;background:var(--ps-s2);border:1px solid var(--ps-b);color:var(--ps-t);font-size:12px;font-weight:500;cursor:pointer;transition:background .12s;overflow:hidden;font-family:inherit;white-space:nowrap}.practice-chip:hover{background:var(--ps-s3)}.practice-chip.active{background:var(--mint-soft);border-color:rgba(52,229,183,.35)}.practice-chip svg{width:14px;height:14px;flex-shrink:0}.practice-chip .chip-label{color:var(--ps-t-mute);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.practice-chip .chip-val{color:var(--ps-t);font-weight:600;overflow:hidden;text-overflow:ellipsis}.practice-chip.active .chip-val{color:var(--mint-bright)}.practice-bottom-sheet{position:absolute;left:10px;right:10px;bottom:10px;background:var(--ps-s2);border-radius:20px;border:1px solid var(--ps-b-strong);padding:18px 18px 20px;box-shadow:0 12px 40px rgba(0,0,0,.55);z-index:10}.practice-sheet-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.practice-sheet-title{font-size:16px;font-weight:600;margin:0;color:var(--ps-t)}.practice-sheet-close{background:var(--ps-s3);border:none;border-radius:50%;width:28px;height:28px;display:grid;place-items:center;color:var(--ps-t-dim);cursor:pointer}.practice-sheet-option{width:100%;text-align:left;padding:11px 14px;margin-bottom:7px;background:var(--ps-s3);border:1px solid transparent;border-radius:12px;color:var(--ps-t);cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-family:inherit}.practice-sheet-option.selected{background:var(--mint-soft);border-color:rgba(52,229,183,.4)}.practice-sheet-option .opt-title{font-size:13px;font-weight:600}.practice-sheet-option.selected .opt-title{color:var(--mint-bright)}.practice-sheet-option .opt-desc{font-size:11px;color:var(--ps-t-dim);margin-top:2px}.practice-notice{padding:9px 16px;background:rgba(14,16,20,.9);border-top:1px solid rgba(232,196,107,.25);color:#E8C46B;font-size:12px}.practice-debug-panel{margin:0;padding:10px 12px;font-size:10px;font-family:monospace;background:rgba(2,6,23,.9);color:#cbd5e1;overflow:auto;max-height:160px;white-space:pre-wrap;border-top:1px solid var(--ps-b)}@media (min-width:960px){.practice-top{height:64px;padding:0 24px;gap:16px}.practice-heading h1{font-size:18px}.practice-score-chip strong{font-size:20px}.practice-done-btn{padding:12px 22px;font-size:14px}.practice-main{display:grid;grid-template-rows:1fr auto auto auto;grid-template-columns:1fr 300px}.practice-content-area{flex:unset;grid-column:1}.practice-canvas-panel{grid-column:1;height:220px}.practice-timeline-area{grid-column:1;padding:14px 24px 6px}.practice-transport{grid-column:1;padding:8px 24px 20px;gap:20px}.practice-play-btn{width:72px;height:72px}.practice-chip-row,.practice-mic-bar{display:none}.practice-sidebar{grid-column:2;grid-row:1/5;display:flex;flex-direction:column;padding:20px;gap:20px;background:var(--ps-ink-2);border-left:1px solid var(--ps-b);overflow-y:auto}}@media (max-width:959px){.practice-sidebar{display:none}}.practice-sidebar-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ps-t-mute);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.sidebar-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:7px;gap:7px}.sidebar-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:6px;gap:6px}.sidebar-option{padding:10px 8px;border-radius:10px;font-size:12px;font-weight:600;border:1px solid var(--ps-b);background:var(--ps-s2);color:var(--ps-t);cursor:pointer;text-align:center;font-family:inherit}.sidebar-option.active{background:var(--mint-soft);border-color:rgba(52,229,183,.4);color:var(--mint-bright)}.sidebar-transpose{display:flex;align-items:center;gap:8px}.sidebar-stepper{width:34px;height:34px;border-radius:8px;background:var(--ps-s2);border:1px solid var(--ps-b);color:var(--ps-t);font-size:18px;cursor:pointer;display:grid;place-items:center;font-family:inherit}.sidebar-transpose-val{flex:1 1;text-align:center;padding:7px 0;background:var(--ps-s2);border-radius:8px;border:1px solid var(--ps-b);font-size:15px;font-weight:600;color:var(--ps-t)}.sidebar-mic-live{font-size:11px;color:var(--mint);font-weight:600}.sidebar-mic-info{font-size:11px;color:var(--ps-t-dim);margin-top:4px}.practice-toast{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:10px;padding:10px 14px 10px 16px;border-radius:999px;background:rgba(14,16,20,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(232,196,107,.3);color:#E8C46B;font-size:13px;line-height:1.4;max-width:calc(100% - 32px);white-space:normal;z-index:20;box-shadow:0 8px 24px rgba(0,0,0,.5);animation:toast-in .2s ease}.practice-toast-close{background:rgba(255,255,255,.08);border:none;border-radius:50%;width:22px;height:22px;display:grid;place-items:center;color:#E8C46B;cursor:pointer;flex-shrink:0}@keyframes toast-in{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.phrase-score-toast{position:absolute;top:64px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 24px;border-radius:16px;background:rgba(14,16,20,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);text-align:center;z-index:20;box-shadow:0 8px 24px rgba(0,0,0,.5);animation:phrase-toast-in .25s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.phrase-score-toast-label{font-size:11px;font-weight:600;letter-spacing:.5px;color:rgba(161,161,170,.8);text-transform:uppercase}.phrase-score-toast-score{font-size:32px;font-weight:800;line-height:1.1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.phrase-score-toast-best{font-size:12px;font-weight:600;color:#4ade80;margin-top:2px}@keyframes phrase-toast-in{0%{opacity:0;transform:translateX(-50%) scale(.85)}to{opacity:1;transform:translateX(-50%) scale(1)}}.sidebar-kbd{font-family:monospace;font-size:10px;padding:2px 6px;border-radius:4px;background:var(--ps-s3);color:var(--ps-t-dim);border:1px solid var(--ps-b)}.reference-editor{height:100dvh;overflow:hidden;background:radial-gradient(circle at 38% 6%,rgba(15,159,143,.14),transparent 32%),linear-gradient(180deg,#101217,#080a0f);color:#f8fafc;display:grid;grid-template-rows:auto 1fr}.reference-editor-top{height:66px;display:grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:center;grid-gap:14px;gap:14px;padding:0 22px;border-bottom:1px solid rgba(230,246,255,.12);background:rgba(8,10,15,.9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.reference-editor-top span{display:block;color:var(--muted-text);font-size:12px;font-weight:750;text-transform:uppercase}.reference-editor-top h1{margin:2px 0 0;font-size:19px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reference-editor-main{min-height:0;overflow:hidden;display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-gap:12px;gap:12px;padding:12px 16px 14px}.reference-editor-left{min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto auto;grid-gap:8px;gap:8px}.reference-editor-canvas,.reference-editor-panel{min-height:0;border:1px solid rgba(230,246,255,.12);background:rgba(20,24,32,.78);border-radius:8px}.reference-editor-canvas{overflow:hidden}.reference-editor-panel{padding:16px;overflow:auto}.range-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-top:12px}.range-grid label{display:grid;grid-gap:6px;gap:6px;color:#94a3b8;font-size:12px;font-weight:700}.reference-tools{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-top:14px}.reference-toolbar{display:flex;align-items:center;gap:8px;margin-top:12px;margin-bottom:4px}.reference-editor-ops-header{display:flex;align-items:center;justify-content:space-between;margin-top:20px;margin-bottom:6px}.operation-list{display:grid;grid-gap:8px;gap:8px;margin-top:12px}.operation-row{display:grid;grid-template-columns:1fr auto;grid-gap:4px 8px;gap:4px 8px;align-items:center;padding:10px;border-radius:8px;background:rgba(15,23,42,.8)}.operation-row span{color:#94a3b8;font-size:12px}.operation-row button{grid-row:1/span 2;grid-column:2}.auth-main{min-height:100vh;display:grid;grid-template-columns:520px 1fr;background:var(--background)}.auth-section{padding:48px;display:grid;align-content:center;grid-gap:18px;gap:18px;border-right:1px solid rgba(230,246,255,.14);background:rgba(14,15,18,.84);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-aside{display:grid;place-items:center;background:linear-gradient(rgba(8,11,16,.94),rgba(8,11,16,.42)),url(/assets/loading-visual.png) 50% /cover}.mobile-menu-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid rgba(230,246,255,.18);border-radius:var(--radius);color:var(--text);cursor:pointer;flex:0 0 auto}.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:49}.lib-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px}.lib-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;text-align:left;width:100%;transition:transform .12s ease,border-color .15s ease}.lib-card:active{transform:scale(.97)}.lib-card:hover{border-color:rgba(230,246,255,.3)}.lib-card-thumb{position:relative;aspect-ratio:16/9;background:#05070a;overflow:hidden;flex-shrink:0}.lib-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.lib-card-no-thumb{width:100%;height:100%;display:grid;place-items:center;color:rgba(230,246,255,.15);font-size:32px}.lib-badge{position:absolute;top:7px;right:7px;font-size:10px;font-weight:900;letter-spacing:.04em;padding:2px 7px;border-radius:999px;text-transform:uppercase;pointer-events:none}.lib-badge.ready{background:var(--green);color:#021a0a}.lib-badge.processing{background:var(--amber);color:#160900}.lib-badge.failed{background:var(--red);color:#fff}.lib-badge.active{background:var(--primary);color:#fff}.lib-badge.completed{background:var(--green);color:#021a0a}.lib-badge.overdue{background:var(--red);color:#fff}.lib-card-fav{position:absolute;top:6px;left:6px;width:26px;height:26px;border-radius:50%;border:1px solid rgba(230,246,255,.22);background:rgba(10,12,16,.72);color:var(--muted-text);cursor:pointer;display:inline-grid;place-items:center;font-size:13px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:border-color .15s ease,background .15s ease,color .15s ease;z-index:2}.lib-card-fav.active{color:#f8c14a;border-color:rgba(248,193,74,.46);background:rgba(72,49,8,.72)}.lib-card-info{padding:9px 11px 11px;flex:1 1;display:flex;flex-direction:column}.lib-card-title{font-size:13px;font-weight:700;line-height:1.3;margin-bottom:2px;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lib-card-meta{color:var(--muted-text);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:6px}.lib-card-chips{display:flex;gap:4px;flex-wrap:wrap;margin-top:auto}.lib-chip{display:inline-flex;align-items:center;gap:3px;height:20px;padding:0 7px;border-radius:999px;border:1px solid rgba(230,246,255,.13);background:rgba(230,246,255,.05);color:var(--muted-text);font-size:10px;font-weight:750;white-space:nowrap;cursor:pointer;transition:border-color .15s ease,background .15s ease}.lib-chip:hover{background:rgba(230,246,255,.1)}button.lib-chip.karaoke{color:var(--magenta);border-color:rgba(217,70,239,.28);background:rgba(217,70,239,.08)}button.lib-chip.karaoke:hover{background:rgba(217,70,239,.16)}button.lib-chip.stats{color:var(--amber);border-color:rgba(245,158,11,.28);background:rgba(245,158,11,.07)}button.lib-chip.stats:hover{background:rgba(245,158,11,.14)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:40;height:60px;background:rgba(14,15,18,.96);border-top:1px solid var(--border);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);grid-template-columns:repeat(4,1fr);align-items:center}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted-text);font-size:10px;font-weight:750;text-decoration:none;height:100%;transition:color .15s ease}.mobile-bottom-nav a.active{color:var(--primary)}.mobile-bottom-nav a svg{width:20px;height:20px}@media (max-width:900px){.page{padding:16px}.intro{align-items:flex-start;flex-direction:column}.desktop,.tablet{width:100%;min-width:980px}.mockup-section{overflow-x:auto}.lib-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){.practice{grid-template-rows:56px 1fr}.practice-header{padding:0 16px}.header-actions .chip,.practice-title span{display:none}.practice-content{padding:18px 16px;gap:18px}.bottom-grid,.top-grid{grid-template-columns:1fr;gap:18px}.reference-video{display:none}.piano-roll{height:292px}.button,.chip{min-width:64px}.karaoke-stats{grid-template-columns:1fr}.practice-top{height:56px;min-height:0;grid-template-columns:38px minmax(0,1fr) 64px auto;gap:8px;padding:0 10px}.practice-top>:nth-child(4){display:none}.practice-top .button{height:34px;min-width:0;padding:0 12px;font-size:13px}.practice-score{min-width:60px;height:40px}.practice-main{height:calc(100dvh - 56px);padding:0;grid-template-rows:minmax(90px,1fr) auto minmax(0,1.1fr) auto}.practice-lyrics-area{padding:14px 18px}.practice-lyrics-area strong{font-size:clamp(18px,5dvw,28px)}.practice-bottom{padding:8px 12px 14px;gap:5px}.practice-piano-canvas{min-height:0}}@media (max-width:768px){.auth-main{grid-template-columns:1fr}.auth-aside{display:none}.auth-section{padding:32px 24px;border-right:none}.mobile-menu-toggle{display:flex}.sidebar{position:fixed;top:56px;left:0;bottom:0;width:248px;z-index:50;transform:translateX(-100%);transition:transform .22s ease;overflow-y:auto}.sidebar.open{transform:translateX(0)}.sidebar-backdrop{display:block}.shell{grid-template-columns:1fr;min-height:unset}.search{display:none}.topbar{padding:0 14px;gap:8px;overflow:hidden}.topbar-actions .chip{display:none}.topbar-actions{gap:6px;flex-shrink:0}.brand{min-width:0;overflow:hidden;flex-shrink:1}.brand span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-toggle{flex-shrink:0}.content{padding:16px 16px 28px}.page-head{flex-direction:column;align-items:flex-start;gap:12px}.page-head h2{font-size:22px}.page-actions{width:100%;justify-content:flex-start}.page-actions>.row{width:100%;flex-wrap:wrap}.page-actions .button{flex:1 1 150px}.intro h1{font-size:22px}.toc{justify-content:flex-start}.two-col{grid-template-columns:1fr!important}.cards,.five-col,.three-col{grid-template-columns:repeat(2,1fr)!important}.phrase-grid{grid-template-columns:repeat(3,1fr)!important}.filterbar{flex-wrap:wrap;flex-direction:column;align-items:stretch;gap:8px}.filterbar .search{display:flex!important;width:100%!important}.filterbar .row{flex-wrap:nowrap;width:100%;min-width:0;max-width:100%;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.filterbar .chip{flex:0 0 auto;max-width:min(280px,82vw)}.modal-overlay{align-items:start!important;padding:16px!important}.modal,.modal-overlay{overflow-y:auto!important}.modal{width:min(440px,calc(100vw - 32px))!important;max-height:calc(100dvh - 32px)!important;margin:0 auto!important;padding:18px!important}.modal.wide{width:min(720px,calc(100vw - 32px))!important}.modal .row{flex-wrap:wrap}.modal .row .button{flex:1 1 130px}.data-table-wrapper{overflow:visible}.table,.table tbody,.table td,.table th,.table thead,.table tr{display:block}.table thead{display:none}.table tbody{display:grid;grid-gap:10px;gap:10px}.table tr{border:1px solid rgba(230,246,255,.12);border-radius:var(--radius);background:rgba(8,11,16,.24);padding:10px 12px}.table td{display:grid;grid-template-columns:minmax(82px,34%) minmax(0,1fr);align-items:start;grid-gap:12px;gap:12px;padding:8px 0;border-bottom:1px solid rgba(52,58,70,.45);overflow-wrap:anywhere}.table td[data-column=actions],.table th[data-column=actions]{display:none}.table td:last-child{border-bottom:0}.table td:before{content:attr(data-label);color:var(--muted-text);font-size:11px;font-weight:750;line-height:1.35}.table td[data-label=""]{grid-template-columns:1fr}.table td[data-label=""]:before{display:none}.table td .row{flex-wrap:wrap;justify-content:flex-start}.stem{grid-template-columns:42px 1fr 34px}.timeline{min-width:0}.reference-editor-main{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto;overflow-y:auto}.reference-editor-panel{max-height:320px}.mobile-bottom-nav{display:grid}.student-shell .content{padding-bottom:76px}.student-shell .mobile-menu-toggle{display:none}}@media (max-width:480px){.three-col{grid-template-columns:1fr!important}.five-col{grid-template-columns:repeat(2,1fr)!important}.cards{grid-template-columns:1fr!important}.phrase-grid{grid-template-columns:repeat(2,1fr)!important}.content{padding:12px 12px 24px}.auth-section{padding:28px 20px}.topbar{padding:0 12px}.panel{padding:16px}.button,.chip{min-height:40px;white-space:normal;text-align:center}.table td{grid-template-columns:1fr;gap:4px}.score{font-size:60px}.score-ring{width:160px}.score-ring-inner{width:128px}}.onboarding-overlay{position:fixed;inset:0;z-index:200;background:rgba(8,11,16,.82);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:grid;place-items:center;padding:16px}.onboarding-card{width:min(540px,100%);background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:36px 40px 32px;box-shadow:0 32px 80px rgba(0,0,0,.5);display:grid;grid-gap:24px;gap:24px;max-height:calc(100dvh - 32px);overflow-y:auto}.onboarding-dots{display:flex;gap:8px;justify-content:center}.onboarding-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--border);background:transparent;transition:background .2s,border-color .2s}.onboarding-dot.active{background:var(--primary);border-color:var(--primary)}.onboarding-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px}.onboarding-tour-card{display:flex;align-items:flex-start;gap:16px;padding:16px 18px;background:var(--surface-raised);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--radius)}@media (max-width:600px){.onboarding-card{padding:28px 20px 24px;gap:18px}.onboarding-actions{flex-direction:column-reverse}.onboarding-actions .button{width:100%;justify-content:center}}