: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;--rhythm: #7c5cd6;--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{height:100%;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:7px 24px;background:var(--panel);border-bottom:1px solid var(--line)}.header-collapse{width:28px;height:28px;border-radius:8px;border:1px solid var(--line-strong);background:#fff;color:var(--muted);font-size:13px;line-height:1;cursor:pointer;display:grid;place-items:center;flex:none;transition:background .15s,border-color .15s,color .15s}.header-collapse:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink)}.account-menu{position:relative;flex:none}.account-avatar{width:30px;height:30px;border-radius:50%;border:none;background:var(--grad-roundel);color:var(--on-dark);font-size:13px;font-weight:700;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-mark);transition:box-shadow .15s,transform .1s}.account-avatar:hover{box-shadow:var(--shadow-mark),0 0 0 3px var(--accent-soft)}.account-popover{position:absolute;top:calc(100% + 8px);right:0;z-index:40;min-width:230px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 10px 30px #002a402e;padding:12px;display:flex;flex-direction:column;gap:10px}.account-popover-email{font-size:12.5px;color:var(--muted);word-break:break-all;padding-bottom:10px;border-bottom:1px solid var(--line)}.account-popover-signout{border:1px solid var(--line-strong);background:#fff;color:var(--ink);border-radius:8px;padding:7px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.account-popover-signout:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink)}.header-peek{display:flex;align-items:center;gap:12px;width:100%;padding:4px 28px;background:var(--panel);border:none;border-bottom:1px solid var(--line);cursor:pointer;text-align:left;transition:background .15s}.header-peek:hover{background:var(--accent-soft)}.header-peek-title{font-size:12.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-peek-meta{font-size:11.5px;font-weight:600;color:var(--good)}.header-peek-chev{margin-left:auto;font-size:11.5px;font-weight:700;color:var(--accent-ink);letter-spacing:.02em;white-space:nowrap}.brand{display:flex;align-items:center;gap:10px;min-width:0}.brand-mark{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:15px;color:var(--on-dark);background:var(--grad-roundel);box-shadow:var(--shadow-mark);flex:none}.brand-text{display:flex;align-items:baseline;gap:9px;min-width:0}.brand-composer{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.promise{margin:2px 0 0;color:var(--muted);font-size:13.5px}.brand-mark svg{width:22px;height:22px;display:block}.app-header h1{font-size:16px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.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:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--muted);background:#f3f1ea;border:1px solid var(--line);border-radius:999px;padding:5px 10px}.signout-btn{border:1px solid var(--line-strong);background:#fff;color:var(--ink);border-radius:999px;padding:5px 11px;font-size:12px;font-weight:600;flex:none}.signout-btn:hover{border-color:var(--accent);color:var(--accent-ink)}.app-body{flex:1;min-height:0;display:flex;align-items:stretch;gap:20px;padding:12px 28px 20px}.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{width:320px;flex:0 0 320px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding-right:2px;transition:width .22s ease,flex-basis .22s ease}.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:0 2px}.sidebar-head-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.setup-foot{margin:2px 4px 0;font-size:12.5px;line-height:1.5;color:var(--muted)}.setup-foot strong{color:var(--accent-ink)}.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}.score-column{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;gap:10px}.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;min-height:0;overflow:hidden}.score-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 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-keyboard{position:relative;display:flex;justify-content:center;padding:8px 22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fbf8f4,#f1ebe2)}.score-keyboard.collapsed{justify-content:flex-end;padding:5px 16px}.keyboard-toggle{font-size:11px;font-weight:600;color:var(--accent-ink);background:#fbf8f4e6;border:1px solid rgba(10,93,129,.22);border-radius:999px;padding:3px 10px;cursor:pointer;transition:background .15s,border-color .15s}.keyboard-toggle:hover{background:var(--tint-hover);border-color:var(--accent)}.score-keyboard.open .keyboard-toggle{position:absolute;top:6px;right:14px;z-index:3}.piano-keyboard{position:relative;width:100%;max-width:980px;height:92px;-webkit-user-select:none;user-select:none;border-radius:4px 4px 6px 6px;background:#1a1d22;padding-top:4px;box-shadow:0 2px 5px #1820322e,inset 0 3px #7d2b32}.pk-key{position:absolute;top:4px;box-sizing:border-box;transition:background 50ms linear,box-shadow 50ms linear}.pk-key.white{height:calc(100% - 4px);background:linear-gradient(180deg,#fff,#f4f1ec 92%,#e7e2d8);border:1px solid #b9b2a6;border-radius:0 0 4px 4px;box-shadow:inset 0 -3px 4px #0000000f;z-index:1}.pk-key.black{height:60%;background:linear-gradient(180deg,#43484f,#23272d 55%,#16191e);border:1px solid #0c0e11;border-radius:0 0 3px 3px;box-shadow:0 2px 3px #00000073,inset 0 -2px 2px #ffffff14;z-index:2}.pk-key.white.active{background:linear-gradient(180deg,#4aa8d6 0%,var(--accent) 100%);border-color:var(--accent-ink);box-shadow:inset 0 -3px 5px #0000001f,0 0 12px 1px #0a5d8199}.pk-key.black.active{background:linear-gradient(180deg,#5cc1ef,#2f9ed0 60%,#1c84b6);border-color:var(--accent-ink);box-shadow:0 2px 3px #0006,0 0 12px 1px #2f9ed0bf}.score-scroll{flex:1;min-height:0;overflow:auto;padding:22px;display:flex;justify-content:center}.score-host-wrap{width:100%;max-width:980px;position:relative;background:#fff}.score-host{width:100%}.score-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.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}.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}.results-empty-mark.error{color:var(--bad)}.sidebar.rail{width:64px;flex:0 0 64px;align-items:center;gap:16px;padding:14px 8px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:visible}.rail-expand,.rail-collapse{width:28px;height:28px;border-radius:8px;border:1px solid var(--line-strong);background:#fff;color:var(--accent-ink);font-size:15px;font-weight:700;cursor:pointer;display:grid;place-items:center;transition:background .15s,border-color .15s}.rail-expand:hover,.rail-collapse:hover{background:var(--accent-soft);border-color:var(--accent)}.rail-steps{display:flex;flex-direction:column;gap:16px;align-items:center}.rail-step{display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;cursor:pointer;padding:0}.rail-step-label{font-size:9.5px;font-weight:600;color:var(--muted)}.rail-step:hover .step-num{box-shadow:0 0 0 3px var(--accent-soft)}.cta-find{font-size:15px;font-weight:700;color:#fff;background:linear-gradient(180deg,#0a6f9c,#084d6e);border:1px solid var(--accent-ink);border-radius:12px;padding:12px 20px;box-shadow:0 2px 7px #0a5d8142;cursor:pointer;transition:transform .12s,box-shadow .12s,background .15s,opacity .15s}.cta-find.header-cta{padding:7px 14px;font-size:13px;border-radius:10px;flex:none}.cta-find:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px 14px #0a5d8157}.cta-find:disabled{opacity:.5;cursor:not-allowed;background:var(--band);color:var(--muted);border-color:var(--line-strong);box-shadow:none}.cta-find.reanalyze{background:#fff;color:var(--accent-ink);box-shadow:none}.cta-result-chip{flex:none;white-space:nowrap;font-size:13px;font-weight:600;color:var(--good);background:var(--good-soft);border:1px solid rgba(95,138,108,.3);padding:6px 12px;border-radius:999px}.results-drawer{flex:none;transition:width .22s ease}.results-drawer.open{width:384px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.results-drawer.closed{width:42px;display:flex}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px 11px;border-bottom:1px solid var(--line);flex:none}.drawer-title{font-size:15px;font-weight:700;color:var(--ink)}.drawer-close{font-size:19px;line-height:1;color:var(--muted);background:none;border:none;cursor:pointer;padding:2px 9px;border-radius:8px}.drawer-close:hover{background:var(--band);color:var(--ink)}.drawer-body{flex:1;overflow-y:auto;padding:18px 16px 22px;display:flex;flex-direction:column;gap:16px}.drawer-tab{width:42px;flex:1;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;color:var(--accent-ink);transition:background .15s,border-color .15s}.drawer-tab:hover{background:var(--accent-soft);border-color:var(--accent)}.drawer-tab-text{writing-mode:vertical-rl;transform:rotate(180deg);font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.drawer-tab-chev{font-size:17px;font-weight:700}.drawer-tab-badge{background:var(--accent);color:#fff;border-radius:999px;min-width:20px;height:20px;padding:0 5px;display:grid;place-items:center;font-size:11px;font-weight:700}.results-preview{color:var(--muted)}.preview-head-title{font-size:16px;color:var(--ink);margin:0 0 8px}.preview-sub{font-size:13px;line-height:1.55;margin:0 0 16px}.legend-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.legend-list li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink)}.lg-dot{width:12px;height:12px;border-radius:50%;flex:none}.lg-dot.wrong{background:var(--wrong)}.lg-dot.missed{background:var(--missed)}.lg-dot.rhythm{background:var(--rhythm)}.weakspot-jump-btn{display:flex;align-items:center;gap:9px;width:100%;margin-bottom:8px;padding:2px;background:none;border:none;border-radius:8px;cursor:pointer;text-align:left;color:inherit}.weakspot-jump-btn:hover .weakspot-range{text-decoration:underline;text-decoration-color:var(--accent)}.weakspot-jump-btn:hover .weakspot-jump{transform:translate(2px)}.weakspot-jump-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.weakspot-jump{color:var(--accent);font-size:15px;font-weight:700;transition:transform .12s}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.heat-cell{position:absolute;border-radius:6px;pointer-events:none}.heat-wrong{background:var(--wrong)}.heat-missed{background:var(--missed)}.heat-rhythm{background:var(--rhythm)}.focus-band{position:absolute;border-radius:8px;pointer-events:none;border:2.5px solid var(--accent);background:#0a5d811a;box-shadow:0 0 0 4px #0a5d811f;animation:focus-flash 1.9s ease-out 1;z-index:3}@keyframes focus-flash{0%{background:#0a5d8147;box-shadow:0 0 0 8px #0a5d8133}70%{background:#0a5d811a}to{background:#0a5d8100;box-shadow:0 0 0 4px #0a5d8100}}.dot-rhythm{background:#7c5cd633;border:1.5px dashed var(--rhythm)}@media (prefers-reduced-motion: reduce){.focus-band{animation:none}.cta-find:hover:not(:disabled),.weakspot-card.clickable:hover{transform:none}}@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{flex-direction:column}.sidebar,.sidebar.rail{width:100%;flex:none;overflow:visible}.sidebar.rail{flex-direction:row;justify-content:flex-start}.sidebar.rail .rail-steps{flex-direction:row}.results-drawer.open,.results-drawer.closed{width:100%}.drawer-tab{flex-direction:row;width:100%;min-height:0;height:auto;padding:10px 14px}.drawer-tab-text{writing-mode:horizontal-tb;transform:none}.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:12px;min-width:0}.back-btn{flex-shrink:0;border:1px solid var(--line-strong);background:#fff;color:var(--ink);border-radius:999px;padding:6px 12px;font-size:12.5px;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}}.muted{color:var(--muted)}.score-library .dot{color:var(--faint)}.browse-scores-btn{border:1px solid var(--line-strong);background:var(--tint);color:var(--brand);border-radius:var(--r-btn);padding:8px 14px;font-weight:600;cursor:pointer}.browse-scores-btn:hover{background:var(--tint-hover)}.score-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:18px 28px 6px;max-width:1080px;margin:0 auto;width:100%}.score-search{flex:1 1 320px;min-width:220px;padding:12px 16px;border:1px solid var(--line-strong);border-radius:var(--r-field);background:var(--surface-muted);color:var(--ink);font-size:15px}.score-search:focus{outline:2px solid var(--accent);outline-offset:1px}.score-tier-filter{display:inline-flex;gap:6px;flex-wrap:wrap}.tier-chip{border:1px solid var(--line-strong);background:var(--panel);color:var(--body);border-radius:var(--r-pill);padding:8px 14px;cursor:pointer;font-size:14px}.tier-chip.active{background:var(--brand);color:var(--on-dark);border-color:var(--brand)}.score-results-meta{max-width:1080px;margin:8px auto 0;padding:0 28px;width:100%;color:var(--muted);font-size:14px}.score-error{max-width:1080px;margin:12px auto;padding:12px 16px;width:calc(100% - 56px);background:var(--bad-soft);color:var(--bad);border-radius:var(--r-alert)}.score-empty-state{max-width:1080px;margin:32px auto;padding:0 28px;text-align:center}.score-results{list-style:none;margin:12px auto 0;padding:0 28px 28px;max-width:1080px;width:100%;display:grid;gap:12px}.score-row{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-card);padding:16px 20px;box-shadow:var(--shadow-soft)}.score-row-main{min-width:0}.score-row-main h3{margin:0 0 2px;font-size:17px;color:var(--ink)}.score-row-composer{margin:0 0 8px;color:var(--muted);font-size:14px}.score-row-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.badge{font-size:12px;font-weight:600;padding:3px 9px;border-radius:var(--r-pill);color:var(--on-dark)}.badge.tier-beginner{background:var(--good)}.badge.tier-intermediate{background:var(--brand-muted)}.badge.tier-advanced{background:var(--warn)}.chip{font-size:12px;padding:3px 9px;border-radius:var(--r-pill);background:var(--band);color:var(--body)}.chip.subtle{background:transparent;border:1px solid var(--line-strong);color:var(--muted)}.score-row-provenance{margin:8px 0 0;font-size:12px}.score-open-btn{flex:0 0 auto;border:1px solid var(--brand);background:var(--brand);color:var(--on-dark);border-radius:var(--r-btn);padding:10px 18px;font-weight:600;cursor:pointer}.score-open-btn:hover{background:var(--brand-deep)}.score-load-more{text-align:center;padding:0 28px 40px}.score-load-more button{border:1px solid var(--line-strong);background:var(--panel);color:var(--brand);border-radius:var(--r-btn);padding:10px 22px;font-weight:600;cursor:pointer}.score-load-more button:disabled{opacity:.6;cursor:default}.score-viewer{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.score-viewer-bar{display:flex;align-items:center;gap:16px;padding:12px 24px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}.score-viewer-meta{flex:1 1 auto;min-width:0}.score-viewer-meta h2{margin:0;font-size:18px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.score-viewer-meta p{margin:2px 0 0;color:var(--muted);font-size:13px}.score-viewer-actions{display:inline-flex;align-items:center;gap:6px}.score-viewer-actions button{border:1px solid var(--line-strong);background:var(--panel);color:var(--body);border-radius:var(--r-btn);padding:8px 12px;cursor:pointer;font-weight:600}.score-viewer-actions button:hover{background:var(--tint)}.zoom-readout{font-size:13px;color:var(--muted);min-width:42px;text-align:center}.score-viewer-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:80px 20px;color:var(--muted)}.score-viewer-state.error{color:var(--bad)}.score-viewer-canvas{flex:1 1 auto;padding:20px 28px 60px;background:#fff;margin:18px auto;max-width:1000px;width:calc(100% - 56px);border-radius:var(--r-card);box-shadow:var(--shadow-soft)}@media (max-width: 720px){.score-row{flex-direction:column;align-items:flex-start}.score-open-btn{align-self:stretch}}
