:root{--bg: #f4eee7;--panel: #fbf8f4;--ink: #182032;--muted: #6f7a8a;--faint: #98908a;--line: #e6e0d6;--line-strong: #ddd5ca;--accent: #0a5d81;--accent-ink: #003d5b;--accent-soft: #f2faff;--good: #5f8a6c;--warn: #a87a3c;--bad: #b55a6e;--wrong: #c0506a;--missed: #c08a3e;--shadow: 0 1px 2px rgba(24, 32, 50, .04), 0 8px 24px rgba(0, 42, 64, .07);--radius: 14px;--brand: #003d5b;--brand-deep: #002a40;--brand-accent: #0a5d81;--brand-muted: #3c7a99;--tint: #f2faff;--tint-hover: #cce4f7;--on-dark: #f8fdff;--body: #394659;--surface-muted: #fbf5ec;--band: #f1e9db;--good-soft: #ebf4eb;--bad-soft: #ffebef;--warn-soft: #f5ead4;--r-card: 20px;--r-field: 12px;--r-btn: 12px;--r-track: 14px;--r-pill: 11px;--r-alert: 10px;--r-motif: 18px;--shadow-card: 0 1px 2px rgba(24, 32, 50, .04), 0 18px 50px -24px rgba(0, 42, 64, .18);--shadow-soft: 0 1px 2px rgba(24, 32, 50, .04), 0 12px 30px -14px rgba(0, 42, 64, .14);--shadow-btn: inset 0 1px 0 rgba(248, 253, 255, .18), 0 10px 24px -8px rgba(0, 61, 91, .45);--shadow-btn-hover: inset 0 1px 0 rgba(248, 253, 255, .2), 0 14px 30px -10px rgba(0, 42, 64, .5);--shadow-pill: 0 1px 2px rgba(24, 32, 50, .05), 0 4px 10px -4px rgba(0, 42, 64, .16);--shadow-mark: 0 8px 18px -6px rgba(0, 42, 64, .5);--ring: 0 0 0 3px #cce4f7;--grad-card: linear-gradient(135deg, #fbf8f4 0%, #ffffff 58%, #f2faff 140%);--grad-btn: linear-gradient(180deg, #0a5d81 0%, #003d5b 100%);--grad-btn-hover: linear-gradient(180deg, #0a5d81 0%, #002a40 100%);--grad-roundel: radial-gradient(circle at 32% 28%, #0a5d81, #002a40);--grad-top-accent: linear-gradient(90deg, #003d5b, #0a5d81, #3c7a99);--shimmer: linear-gradient( 105deg, transparent 37%, rgba(255, 255, 255, .96) 46%, rgba(204, 228, 247, .98) 50%, rgba(255, 255, 255, .92) 54%, transparent 63% )}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:600;letter-spacing:-.01em;margin:0}button{font-family:inherit;cursor:pointer}.app{min-height:100%;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 28px;background:var(--panel);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:14px}.brand-mark{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:22px;color:var(--on-dark);background:var(--grad-roundel);box-shadow:var(--shadow-mark)}.brand-mark svg{width:22px;height:22px;display:block}.app-header h1{font-size:22px}.promise{margin:2px 0 0;color:var(--muted);font-size:13.5px}.header-tag{font-size:12.5px;color:var(--accent-ink);background:var(--accent-soft);padding:7px 13px;border-radius:999px;font-weight:600;white-space:nowrap}.header-actions{display:flex;align-items:center;gap:10px;min-width:0}.account-chip{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;color:var(--muted);background:#f3f1ea;border:1px solid var(--line);border-radius:999px;padding:7px 11px}.signout-btn{border:1px solid var(--line-strong);background:#fff;color:var(--ink);border-radius:999px;padding:7px 12px;font-size:12.5px;font-weight:600}.signout-btn:hover{border-color:var(--accent);color:var(--accent-ink)}.app-body{flex:1;min-height:0;display:grid;grid-template-columns:340px minmax(0,1fr) 388px;gap:20px;padding:20px 28px 28px}.landing-shell{position:relative;z-index:0;min-height:100%;max-width:1280px;margin-inline:auto;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);column-gap:72px;align-items:center;padding:64px clamp(40px,6vw,96px);background:radial-gradient(1200px 800px at 12% -10%,#f2faff,#f2faff00 55%),radial-gradient(900px 700px at 105% 115%,#fbf5ec,#fbf5ec00 60%),var(--bg)}.landing-shell:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.035;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}.landing-copy{position:relative;z-index:1;max-width:680px}.landing-copy>*{position:relative;z-index:1}.landing-brand{margin-bottom:30px}.brand.landing-brand h1{font-size:19px}.landing-brand .promise{font-size:12.5px}.landing-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-muted)}.landing-eyebrow:before{content:"";width:26px;height:1px;background:var(--brand-muted)}.landing-copy h2{font-size:clamp(44px,6vw,76px);line-height:.98;letter-spacing:-.015em;font-weight:500;max-width:12ch;margin:0 0 22px;color:var(--ink)}.kw{position:relative;color:var(--brand);white-space:nowrap}.kw-underline{position:absolute;left:-1%;right:-1%;bottom:-.16em;width:102%;height:.4em;overflow:visible}.kw-underline path{stroke-dasharray:240;stroke-dashoffset:240;animation:kwdraw .75s ease-out .35s forwards}@keyframes kwdraw{to{stroke-dashoffset:0}}.score-motif{display:block;width:100%;max-width:520px;height:auto;margin:6px 0 26px}.landing-copy>p{max-width:46ch;margin:0;color:var(--body);font-size:18px;line-height:1.6}.hero-rule{height:1px;border:0;background:var(--line);margin:30px 0}.value-props{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}.value-prop{display:flex;flex-direction:column;gap:9px}.vp-icon{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;background:var(--tint);border:1px solid var(--tint-hover);color:var(--brand)}.vp-icon svg{width:18px;height:18px;display:block}.vp-title{font-size:13.5px;font-weight:600;color:var(--ink)}.vp-sub{font-size:12.5px;line-height:1.45;color:var(--muted)}.trust-stat{display:flex;align-items:center;gap:12px;margin-top:26px}.trust-num{font-family:Fraunces,serif;font-size:24px;font-weight:600;color:var(--brand);line-height:1}.trust-divider{width:1px;height:18px;background:var(--line)}.trust-label{font-size:12.5px;color:var(--muted)}.auth-panel{position:relative;z-index:1;width:100%;max-width:440px;justify-self:start;overflow:hidden;padding:30px clamp(24px,3vw,34px);border:1px solid transparent;border-radius:var(--r-card);background-image:var(--grad-card),linear-gradient(150deg,#ddd5ca,#cce4f7);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:var(--shadow-card)}.auth-panel:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--grad-top-accent)}.auth-head{margin-bottom:18px}.auth-eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.auth-head h3{font-family:Fraunces,serif;font-size:22px;font-weight:600;color:var(--ink)}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;background:var(--band);border-radius:var(--r-track);padding:4px;margin-bottom:18px;box-shadow:inset 0 1px 2px #1820320f}.auth-tabs button{border:none;background:transparent;border-radius:var(--r-pill);padding:10px;color:var(--muted);font-weight:600;transition:background .22s ease,color .22s ease}.auth-tabs button.active{background:var(--panel);color:var(--brand);box-shadow:var(--shadow-pill)}.auth-form{display:flex;flex-direction:column;gap:13px}.auth-form label{display:flex;flex-direction:column;gap:7px;color:var(--muted);font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.auth-form input{width:100%;border:1px solid var(--line);border-radius:var(--r-field);padding:13px 14px;color:var(--ink);font:inherit;letter-spacing:normal;text-transform:none;background:var(--surface-muted);transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.auth-form input::placeholder{color:var(--faint)}.auth-form input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:var(--ring)}.auth-alert{border-radius:var(--r-alert);padding:10px 12px;font-size:13px;line-height:1.45}.auth-alert.error{color:var(--bad);background:var(--bad-soft);border:1px solid rgba(181,90,110,.28)}.auth-alert.success{color:var(--good);background:var(--good-soft);border:1px solid rgba(113,139,120,.3)}.auth-submit{border:none;border-radius:var(--r-btn);background:var(--grad-btn);color:var(--on-dark);padding:14px;font-size:15px;font-weight:700;box-shadow:var(--shadow-btn);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.auth-submit:hover:not(:disabled){background:var(--grad-btn-hover);transform:translateY(-1px);box-shadow:var(--shadow-btn-hover)}.auth-submit:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-btn)}.auth-submit:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:var(--shadow-btn)}.auth-divider{display:flex;align-items:center;gap:12px;margin-top:16px;font-size:12px;color:var(--faint)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--line)}.auth-footer{margin-top:14px;text-align:center;font-size:12.5px;color:var(--muted)}.link-btn{background:none;border:none;padding:0;font:inherit;font-weight:600;color:var(--accent);cursor:pointer}.link-btn:hover{color:var(--brand);text-decoration:underline}@media (prefers-reduced-motion: reduce){.kw-underline path{animation:none;stroke-dashoffset:0}.auth-submit{transition:none}.auth-submit:hover:not(:disabled){transform:none}}.auth-loading{min-height:100%;display:grid;place-items:center;gap:12px;align-content:center;color:var(--muted)}.sidebar{display:flex;flex-direction:column;gap:18px;overflow-y:auto;padding-right:2px}.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 16px 18px;box-shadow:var(--shadow)}.step-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}.step-num{width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;font-size:13px;font-weight:700;display:grid;place-items:center}.step-head h2{font-size:16px}.piece-card,.sample-card{display:block;width:100%;text-align:left;background:#fcfbf8;border:1.5px solid var(--line-strong);border-radius:11px;padding:13px 14px;margin-bottom:10px;transition:border-color .15s,background .15s,box-shadow .15s}.piece-card:hover,.sample-card:hover{border-color:#c8c2b4}.piece-card.selected,.sample-card.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px #0a5d811a}.piece-card.uploaded{cursor:default}.piece-card-title{font-weight:600;font-size:14.5px}.piece-card-sub,.sample-card-sub{color:var(--muted);font-size:12.5px;margin-top:2px}.piece-card-badge{margin-top:9px;font-size:11px;font-weight:600;color:var(--accent-ink)}.sample-card-title{font-weight:600;font-size:14px}.ghost-btn{width:100%;background:#fff;border:1.5px dashed var(--line-strong);color:var(--ink);border-radius:10px;padding:10px;font-size:13.5px;font-weight:500;transition:border-color .15s,color .15s}.ghost-btn:hover{border-color:var(--accent);color:var(--accent-ink)}.hint{margin:9px 2px 0;font-size:12px;color:var(--faint);line-height:1.45}.future-row{margin-top:12px;font-size:11.5px;color:var(--faint);border-top:1px dashed var(--line);padding-top:10px}.sub-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);margin:4px 0 9px}.sub-label.audio{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}.audio-row{display:flex;gap:8px;margin-top:9px}.audio-row .ghost-btn{flex:1;font-size:12.5px;padding:9px 6px}.ghost-btn.recording{border-color:var(--bad);border-style:solid;color:var(--bad);background:#d83c410f;animation:pulse 1.3s ease-in-out infinite}.ghost-btn:disabled{opacity:.5;cursor:not-allowed}.hint.error{color:var(--bad)}@keyframes pulse{50%{background:#d83c4129}}.analyzing-progress{width:80%;text-align:center}.analyzing-label{font-size:13.5px;color:var(--muted);margin-bottom:10px}.progress-track{height:6px;border-radius:999px;background:var(--accent-soft);overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .3s ease}.analyze-btn{margin-top:2px;padding:14px;border:none;border-radius:12px;background:var(--grad-btn);color:var(--on-dark);font-size:15px;font-weight:600;box-shadow:var(--shadow-btn);transition:transform .08s,box-shadow .15s,opacity .15s}.analyze-btn:hover:not(:disabled){transform:translateY(-1px)}.analyze-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.score-column{min-width:0;display:flex}.score-panel{flex:1;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;min-width:0}.score-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}.zoom-controls,.playback-controls{display:inline-flex;align-items:center;gap:6px}.zoom-controls button,.pb-btn{border:1px solid var(--line-strong);background:#fff;border-radius:8px;padding:6px 11px;font-size:12.5px;font-weight:500;color:var(--ink);transition:border-color .15s,background .15s,color .15s}.zoom-controls button:hover,.pb-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-ink)}.zoom-pct{font-size:12px;color:var(--muted);min-width:38px;text-align:center}.pb-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pb-btn:disabled{opacity:.45;cursor:not-allowed}.score-legend{display:flex;gap:8px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--line);font-size:12.5px;color:var(--muted);flex-wrap:wrap}.legend-title{font-weight:600;margin-right:2px}.filter-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fcfbf8;border-radius:999px;padding:5px 11px;font-size:12px;color:var(--muted);transition:all .15s}.filter-btn:hover:not(:disabled){border-color:var(--line-strong)}.filter-btn.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink);font-weight:600}.filter-btn:disabled{opacity:.45;cursor:not-allowed}.legend-dot{width:10px;height:10px;border-radius:50%}.dot-wrong{background:var(--wrong)}.dot-missed{background:var(--missed)}.dot-rhythm{border-radius:2px;background:#0a5d8133;border:1.5px dashed var(--accent)}.score-scroll{flex:1;overflow:auto;padding:22px;display:flex;justify-content:center}.score-host-wrap{width:100%;max-width:980px}.score-host-wrap{position:relative;background:#fff}.score-host{width:100%}.score-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.rhythm-band{position:absolute;background:#0a5d8117;border:1.5px dashed rgba(10,93,129,.5);border-radius:7px}.rhythm-band-tag{position:absolute;bottom:-11px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:9.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#fff;background:var(--accent);padding:2px 8px;border-radius:999px}.note-marker{position:absolute;width:22px;height:22px;border-radius:50%;transform:translate(-50%,-50%);box-sizing:border-box}.note-marker.wrong{border:2.5px solid var(--wrong);background:#e5484d1f}.note-marker.missed{border:2.5px dashed var(--missed);background:#e8a33d1f}.note-playing{position:absolute;width:26px;height:26px;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(10,93,129,.34) 0%,rgba(10,93,129,.12) 55%,transparent 72%);box-shadow:0 0 11px 3px #0a5d8180;animation:note-playing-pulse .85s ease-in-out infinite;pointer-events:none;z-index:2}@keyframes note-playing-pulse{0%,to{transform:translate(-50%,-50%) scale(.86);opacity:.78}50%{transform:translate(-50%,-50%) scale(1.12);opacity:1}}@media (prefers-reduced-motion: reduce){.note-playing{animation:none}}.score-error{margin-top:16px;color:var(--bad);font-size:13.5px}.score-loading{margin:auto;color:var(--muted)}.results{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.results-empty{align-items:center;justify-content:center;text-align:center}.results-empty-inner{max-width:240px;color:var(--muted)}.results-empty-mark{font-size:38px;color:var(--line-strong)}.results-empty h3{font-size:17px;margin:8px 0 6px;color:var(--ink)}.results-empty p{font-size:13px;line-height:1.5}.results-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.chip{border-radius:11px;padding:11px 10px;text-align:center;border:1px solid var(--line);background:#fcfbf8}.chip-value{font-family:Fraunces,serif;font-size:21px;font-weight:600;line-height:1}.chip-label{font-size:10.5px;color:var(--muted);margin-top:5px;letter-spacing:.01em}.chip-good{background:#15924f14;border-color:#15924f38}.chip-good .chip-value{color:var(--good)}.chip-warn{background:#b9760a14;border-color:#b9760a38}.chip-warn .chip-value{color:var(--warn)}.chip-bad{background:#d83c4114;border-color:#d83c4138}.chip-bad .chip-value{color:var(--bad)}.results-headline h3{font-size:19px;line-height:1.25}.results-summary{margin:7px 0 0;font-size:12.5px;color:var(--muted);font-weight:500}.results-paragraph{margin:0;font-size:14.5px;line-height:1.6;color:#353b47}.practice-block{background:linear-gradient(180deg,#f7fcff,#eef7fd);border:1px solid rgba(10,93,129,.16);border-radius:12px;padding:15px 16px 16px}.practice-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-ink);margin-bottom:9px}.practice-steps{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:9px}.practice-steps li{font-size:14px;line-height:1.5;color:#353b47}.encouragement{margin:13px 0 0;font-size:13px;font-style:italic;color:var(--muted)}.analyzing{display:flex;flex-direction:column;align-items:center;gap:18px;padding:40px 0;margin:auto}.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--accent-soft);border-top-color:var(--accent);animation:spin .8s linear infinite}.analyzing ul{list-style:none;padding:0;margin:0;text-align:center;display:flex;flex-direction:column;gap:8px}.analyzing li{font-size:13.5px;color:var(--muted)}@keyframes spin{to{transform:rotate(360deg)}}.mode-tabs{display:flex;gap:4px;background:#efece4;border-radius:11px;padding:4px}.mode-tabs button{flex:1;border:none;background:transparent;border-radius:8px;padding:9px;font-size:13px;font-weight:600;color:var(--muted);transition:background .15s,color .15s}.mode-tabs button.active{background:#fff;color:var(--ink);box-shadow:var(--shadow)}.step-num.done{background:var(--good)}.cta-step{background:linear-gradient(180deg,#f7fcff,#ebf5fc);border-color:#0a5d812e}.cta-hint{margin:10px 2px 0;font-size:12px;color:var(--faint);text-align:center}.sub-label.experimental{margin-top:16px;color:var(--warn)}.timeline{border-top:1px solid var(--line);padding:12px 18px 16px}.timeline-label{font-size:11.5px;color:var(--faint);margin-bottom:8px}.timeline-strip{display:flex;gap:5px;flex-wrap:wrap}.tl-cell{flex:1;min-width:40px;border:1px solid var(--line);background:#fcfbf8;border-radius:8px;padding:6px 2px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:transform .08s,box-shadow .15s}.tl-cell:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.tl-mark{font-size:13px;font-weight:700;line-height:1}.tl-num{font-size:10px;color:var(--faint)}.tl-clean{border-color:#15924f4d}.tl-clean .tl-mark{color:var(--good)}.tl-wrong{background:#e5484d14;border-color:#e5484d59}.tl-wrong .tl-mark{color:var(--wrong)}.tl-missed{background:#e8a33d1a;border-color:#e8a33d66}.tl-missed .tl-mark{color:var(--missed)}.tl-rhythm{background:#0a5d8114;border-color:#0a5d8159}.tl-rhythm .tl-mark{color:var(--accent)}.tl-mixed{background:#d83c411a;border-color:#d83c4166}.tl-mixed .tl-mark{color:var(--bad)}.accuracy-row{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--line)}.accuracy-main{display:flex;align-items:baseline;gap:8px}.accuracy-num{font-family:Fraunces,serif;font-size:32px;font-weight:600;color:var(--good)}.accuracy-label{font-size:12.5px;color:var(--muted)}.accuracy-split{display:flex;gap:12px;font-size:12.5px;color:var(--muted);font-weight:600}.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink);margin-bottom:4px}.weakspots{display:flex;flex-direction:column;gap:12px}.weakspot-card{border:1px solid var(--line-strong);border-radius:12px;padding:14px;background:#fff}.weakspot-card.sample{opacity:.65;border-style:dashed}.weakspot-card.clean{background:#15924f0f;border-color:#15924f40}.weakspot-top{display:flex;align-items:center;gap:9px;margin-bottom:8px}.weakspot-rank{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:grid;place-items:center;flex-shrink:0}.weakspot-card.sample .weakspot-rank{width:auto;height:auto;border-radius:6px;padding:2px 6px;background:var(--faint)}.weakspot-range{font-family:Fraunces,serif;font-size:16px;font-weight:600}.conf-badge{margin-left:auto;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:999px}.conf-high{background:#15924f1f;color:var(--good)}.conf-medium{background:#b9760a1f;color:var(--warn)}.conf-low{background:#71778424;color:var(--muted)}.weakspot-problem{font-size:14.5px;font-weight:500;line-height:1.45;color:var(--ink)}.weakspot-evidence{display:flex;flex-wrap:wrap;gap:6px;margin:9px 0}.ev-chip{font-size:11.5px;background:#f3f1ea;color:#4a505c;padding:3px 9px;border-radius:999px;font-weight:500}.weakspot-practice{font-size:13px;line-height:1.5;color:#4a505c}.loop-btn{margin-top:11px;width:100%;border:1px solid var(--accent);background:var(--accent-soft);color:var(--accent-ink);border-radius:9px;padding:8px;font-size:13px;font-weight:600;transition:background .15s}.loop-btn:hover{background:#0a5d8129}.loop-btn.active{background:var(--accent);color:#fff}.teacher-card{background:linear-gradient(135deg,#002a40,#003d5b);color:#eef6fb;border-radius:13px;padding:16px 17px}.teacher-title{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--tint-hover);margin-bottom:8px}.teacher-text{margin:0;font-size:14.5px;line-height:1.6}.preview-head h3{font-size:18px}.preview-list{list-style:none;padding:0;margin:4px 0 6px;display:flex;flex-direction:column;gap:9px}.preview-list li{font-size:13.5px;color:#4a505c}.preview-foot{font-size:12.5px;color:var(--faint);margin:4px 0 0}.results-empty-mark.error{color:var(--bad)}@media (max-width: 1080px){.landing-shell{grid-template-columns:1fr;column-gap:0;row-gap:36px;padding:48px clamp(24px,6vw,56px);justify-items:center}.auth-panel{order:-1;max-width:520px;width:100%;justify-self:center}.landing-copy{order:0;max-width:620px;justify-self:stretch;border-top:1px solid var(--line);padding-top:34px}.landing-copy h2{font-size:clamp(40px,9vw,60px)}.app-body{grid-template-columns:1fr;grid-auto-rows:min-content}.sidebar{overflow:visible}.score-scroll{max-height:60vh}}@media (max-width: 720px){.app-header{align-items:flex-start;flex-direction:column}.header-actions{width:100%}.account-chip{flex:1;max-width:none}.landing-shell{padding:28px 18px;row-gap:28px}.landing-copy h2{font-size:clamp(34px,11vw,44px)}.landing-copy>p{font-size:15.5px}.auth-panel{max-width:100%;padding:24px 20px;border-radius:16px}.value-props{grid-template-columns:1fr;gap:16px}}.header-left{display:flex;align-items:center;gap:16px;min-width:0}.back-btn{flex-shrink:0;border:1px solid var(--line-strong);background:#fff;color:var(--ink);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;transition:border-color .15s,color .15s,background .15s}.back-btn:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.library{flex:1;min-height:0;overflow-y:auto;width:100%;max-width:1180px;margin-inline:auto;padding:40px clamp(24px,5vw,56px) 56px}.library-hero{max-width:720px;margin-bottom:26px}.library-eyebrow{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:10px}.library-hero h2{font-size:clamp(28px,4vw,38px);line-height:1.08}.library-hero p{margin:12px 0 0;color:var(--body);font-size:15.5px;line-height:1.55}.library-filter{display:inline-flex;gap:4px;padding:4px;margin-bottom:24px;background:var(--band);border:1px solid var(--line);border-radius:999px}.library-filter button{border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:600;padding:8px 16px;border-radius:999px;transition:background .15s,color .15s,box-shadow .15s}.library-filter button:hover{color:var(--ink)}.library-filter button.active{background:#fff;color:var(--accent-ink);box-shadow:var(--shadow-pill)}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:20px}.library-state{min-height:220px;display:grid;justify-items:start;align-content:center;gap:10px;color:var(--body)}.library-state h3{font-size:22px}.library-state p{margin:0;color:var(--muted)}.lib-card{display:flex;flex-direction:column;text-align:left;padding:0;overflow:hidden;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--shadow-soft);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.lib-card:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:var(--shadow-card)}.lib-card:focus-visible{outline:none;box-shadow:var(--ring),var(--shadow-card)}.lib-cover{position:relative;height:116px;background:radial-gradient(120% 140% at 85% -20%,color-mix(in srgb,var(--cover) 26%,#fff) 0%,transparent 60%),linear-gradient(135deg,color-mix(in srgb,var(--cover) 16%,#fff),color-mix(in srgb,var(--cover) 7%,#fbf8f4));border-bottom:1px solid var(--line);overflow:hidden}.lib-clef{position:absolute;left:18px;top:-8px;height:118px;color:var(--cover);opacity:.5}.lib-cover-key,.lib-cover-meter{position:absolute;right:14px;font-weight:600;color:color-mix(in srgb,var(--cover) 78%,#182032)}.lib-cover-key{top:14px;font-size:14px}.lib-cover-meter{bottom:14px;font-size:12px;opacity:.8}.lib-card-body{display:flex;flex-direction:column;flex:1;padding:15px 17px 16px}.lib-card-meta{display:flex;align-items:center;gap:9px;margin-bottom:9px}.lib-diff{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:999px}.diff-beginner{color:var(--good);background:var(--good-soft)}.diff-intermediate{color:var(--accent-ink);background:var(--accent-soft)}.diff-advanced{color:var(--bad);background:var(--bad-soft)}.lib-era{font-size:12px;color:var(--faint)}.lib-card-title{font-family:Fraunces,Georgia,serif;font-weight:600;font-size:18px;letter-spacing:-.01em}.lib-card-composer{margin-top:2px;font-size:13px;color:var(--muted)}.lib-card-blurb{margin:10px 0 0;font-size:13px;line-height:1.5;color:var(--body)}.lib-card-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:14px}.lib-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px}.lib-badge.ready{color:var(--good);background:var(--good-soft)}.lib-badge.byo{color:var(--warn);background:var(--warn-soft)}.lib-open{font-size:12.5px;font-weight:600;color:var(--accent);opacity:0;transform:translate(-4px);transition:opacity .16s ease,transform .16s ease}.lib-card:hover .lib-open{opacity:1;transform:translate(0)}.lib-card-byo-tile{align-items:center;justify-content:center;text-align:center;gap:6px;padding:28px 20px;min-height:200px;background:var(--surface-muted);border:1.5px dashed var(--line-strong);box-shadow:none}.lib-card-byo-tile:hover{border-color:var(--accent);transform:translateY(-3px)}.lib-byo-mark{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:var(--accent-ink);background:var(--accent-soft);margin-bottom:6px}.lib-byo-mark svg{width:22px;height:22px}.lib-byo-title{font-family:Fraunces,Georgia,serif;font-weight:600;font-size:16px}.lib-byo-sub{font-size:12.5px;color:var(--muted);max-width:200px;line-height:1.45}.score-empty{margin:auto;max-width:360px;text-align:center;padding:32px;color:var(--muted)}.score-empty-mark{width:56px;height:56px;margin:0 auto 16px;border-radius:50%;display:grid;place-items:center;font-size:26px;color:var(--accent-ink);background:var(--accent-soft)}.score-empty h3{font-size:18px;color:var(--ink)}.score-empty p{margin:8px 0 0;font-size:14px;line-height:1.55}@media (max-width: 560px){.library-grid{grid-template-columns:1fr}.header-left{gap:10px}}
