:root{color:#292524;background:#f5f5f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button{font:inherit}.practice-room{min-height:100vh;background:#f5f5f5;color:#292524}.practice-shell{display:grid;gap:18px;width:min(100%,1080px);margin:0 auto;padding:18px 16px max(24px,env(safe-area-inset-bottom))}.file-status,.score-uploader,.part-mapper,.practice-stage,.report-panel{background:#fff;border:1px solid #e7e5e4;border-radius:8px}.file-status{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px}.section-kicker{margin:0 0 6px;color:#777169;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}h1,h2,p{margin:0}h1{color:#0c0a09;font-family:Georgia,Times New Roman,serif;font-size:2.1rem;font-weight:400;line-height:1.08;letter-spacing:0}h2{color:#0c0a09;font-size:1rem;font-weight:650;letter-spacing:0}.status-pill,.tempo-chip,.report-heading span{display:inline-flex;flex:0 0 auto;align-items:center;min-height:30px;border-radius:999px;padding:5px 10px;background:#f0efed;color:#292524;font-size:.78rem;font-weight:700;white-space:nowrap}.status-pill--playable{background:#e7f3ec}.part-mapper,.score-uploader,.practice-stage,.report-panel{padding:16px}.section-heading,.stage-topline{display:flex;align-items:center;justify-content:space-between;gap:10px}.section-heading{justify-content:flex-start;margin-bottom:12px}.upload-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.upload-button,.restore-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;gap:8px;border:1px solid #d6d3d1;border-radius:8px;background:#fff;color:#292524;padding:10px 12px;font:inherit;font-weight:700}.upload-button input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.restore-button:disabled{opacity:.5}.part-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.empty-parts{grid-column:1 / -1;color:#57534e;font-size:.9rem;line-height:1.4}.part-button{display:grid;min-height:62px;gap:4px;border:1px solid #d6d3d1;border-radius:8px;background:transparent;color:#292524;padding:10px;text-align:left}.part-button[data-selected=true]{border-color:#292524;background:#292524;color:#fff}.part-button span{font-weight:700}.part-button small{color:inherit;font-size:.78rem;opacity:.72}.practice-stage{display:grid;gap:16px}.note-strip{display:grid;grid-auto-columns:minmax(78px,1fr);grid-auto-flow:column;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.note-tile{display:grid;min-height:80px;align-content:space-between;border:1px solid #e7e5e4;border-radius:8px;background:#fafafa;padding:10px}.note-tile span{color:#777169;font-size:.72rem}.note-tile strong{color:#0c0a09;font-family:Georgia,Times New Roman,serif;font-size:1.35rem;font-weight:400}.pitch-guide{display:grid;gap:10px;border-block:1px solid #e7e5e4;padding:14px 0;color:#4e4e4e;font-size:.92rem}.pitch-guide-line{display:block;width:100%;height:40px;border-radius:8px;background:linear-gradient(90deg,transparent 0 12%,rgba(41,37,36,.16) 12% 13%,transparent 13% 31%,rgba(41,37,36,.16) 31% 32%,transparent 32% 58%,rgba(41,37,36,.16) 58% 59%,transparent 59%),linear-gradient(180deg,transparent 48%,#292524 48% 52%,transparent 52%),#f0efed}.transport-controls{display:grid;grid-template-columns:1fr;gap:10px}.control-button{display:inline-flex;min-height:48px;align-items:center;justify-content:center;gap:8px;border:1px solid #d6d3d1;border-radius:999px;background:transparent;color:#292524;font-weight:700}.control-button.primary{border-color:#292524;background:#292524;color:#fff}.control-button.primary.is-active{border-color:#0c0a09;background:#0c0a09;box-shadow:0 0 0 3px #29252429;transform:translateY(1px)}.control-button.danger{border-color:#7f1d1d;color:#7f1d1d}.control-button:disabled{cursor:progress;opacity:.58}.error-banner{border:1px solid #f1b6b6;border-radius:8px;background:#fff7f7;color:#7f1d1d;padding:12px 14px;font-weight:650}.empty-report{margin-top:10px;color:#4e4e4e;line-height:1.45}.report-heading{justify-content:space-between}.report-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.report-metrics div{display:grid;min-height:82px;align-content:space-between;border:1px solid #e7e5e4;border-radius:8px;background:#fafafa;padding:12px}.report-metrics span{color:#777169;font-size:.78rem}.report-metrics strong{color:#0c0a09;font-size:1.7rem;font-weight:650}.octave-note{margin:10px 0 0;color:#57534e;font-size:.86rem;line-height:1.4}.note-score-list{display:grid;gap:1px;margin:12px 0 0;padding:0;list-style:none}.note-score-list li{display:flex;align-items:center;justify-content:space-between;min-height:42px;border-top:1px solid #e7e5e4;color:#4e4e4e;font-size:.9rem}.note-score-list strong{color:#292524}@media(min-width:720px){.practice-shell{grid-template-columns:minmax(240px,.72fr) minmax(420px,1.28fr);align-items:start;padding:32px}.file-status,.score-uploader,.practice-stage{grid-column:span 2}.transport-controls{grid-template-columns:repeat(2,minmax(0,1fr))}h1{font-size:2.8rem}}
