:root{--bg: #f2ece3;--surface: rgba(255, 252, 247, .6);--surface-solid: #fffcf7;--border: rgba(255, 255, 255, .3);--border-hover: rgba(90, 183, 195, .4);--text: #2c2520;--text-dim: #8a8078;--accent: #5ab7c3;--accent-hover: #4aa3ae;--danger: #cc4444;--paper: #fffdf8;--glass-shadow: 0 8px 32px rgba(44, 37, 32, .08);--glass-blur: blur(20px);--glass-border: 1px solid rgba(255, 255, 255, .3);color-scheme:light}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#2c252026;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#2c252040}.app{min-height:100vh;display:flex;flex-direction:column;padding:0 24px 56px}.app-header{display:flex;align-items:baseline;gap:16px;padding:20px 0 12px;margin-bottom:16px}.app-title{font-size:1.15rem;font-weight:600;color:var(--text);margin:0;letter-spacing:.02em}.app-subtitle{color:var(--text-dim);font-size:.82rem;margin:0}.app-filename{font-size:.78rem;color:var(--text-dim);background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:3px 12px;border-radius:6px;border:var(--glass-border)}.upload-zone{flex:1;display:flex;align-items:center;justify-content:center;border:2px dashed rgba(44,37,32,.15);border-radius:16px;margin:40px auto;max-width:480px;width:100%;padding:48px;cursor:pointer;transition:border-color .2s,background .2s;background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.upload-zone:hover{border-color:var(--accent);background:#fffcf7cc}.upload-content{text-align:center;color:var(--text-dim)}.upload-content svg{color:var(--accent);margin-bottom:16px}.upload-title{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 4px}.upload-subtitle{font-size:.8rem;margin:0 0 20px}.upload-btn{background:var(--accent);color:#fff;border:none;padding:9px 28px;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;transition:background .2s,box-shadow .2s;box-shadow:0 2px 8px #5ab7c340}.upload-btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #5ab7c359}.upload-hint{font-size:.72rem;color:var(--text-dim);margin:16px 0 0;line-height:1.5;max-width:320px;opacity:.7}.demo-divider{font-size:.8rem;color:var(--text-dim);margin:20px 0 12px;opacity:.5;text-transform:uppercase;letter-spacing:.1em}.demo-btn{background:none;border:1.5px solid rgba(90,183,195,.4);color:var(--accent);padding:10px 24px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.demo-btn:hover:not(:disabled){background:#5ab7c314;border-color:var(--accent)}.demo-btn:disabled{opacity:.6;cursor:not-allowed}.workspace{display:flex;gap:16px;flex:1;min-height:0;overflow:hidden}.thumbnails-panel{width:160px;flex-shrink:0;display:flex;flex-direction:column;background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:12px;overflow:hidden;max-height:70vh;border:var(--glass-border);box-shadow:var(--glass-shadow)}.thumbnails-header{font-size:.7rem;color:var(--text-dim);padding:12px 12px 6px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.thumbnails-list{flex:1;overflow-y:auto;padding:4px 8px 8px;display:flex;flex-direction:column;gap:6px}.thumb-item{position:relative;border:2px solid transparent;border-radius:8px;padding:4px;cursor:grab;transition:border-color .15s,opacity .15s,box-shadow .15s;background:#fffdf8b3}.thumb-item:hover{border-color:#5ab7c34d;box-shadow:0 2px 8px #2c25200f}.thumb-selected{border-color:var(--accent)!important;box-shadow:0 2px 12px #5ab7c333!important}.thumb-deleted{opacity:.3;filter:grayscale(1)}.thumb-img{width:100%;display:block;border-radius:6px}.thumb-placeholder{width:100%;aspect-ratio:.707;background:#2c25200f;border-radius:6px}.thumb-restore-btn{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;border:none;padding:3px 12px;border-radius:6px;font-size:.65rem;font-weight:600;cursor:pointer;opacity:0;transition:opacity .15s;box-shadow:0 2px 8px #5ab7c34d}.thumb-deleted:hover .thumb-restore-btn{opacity:1}.thumb-no-music-overlay{position:absolute;inset:4px 4px 20px;background:#2c252099;border-radius:6px;display:flex;align-items:center;justify-content:center;pointer-events:none}.thumb-no-music-label{font-size:.55rem;font-weight:600;color:#fff;text-align:center;text-transform:uppercase;letter-spacing:.04em;line-height:1.2;padding:3px 6px;background:#2c252080;border-radius:4px}.thumb-label{display:block;text-align:center;font-size:.7rem;color:var(--text-dim);margin-top:2px}.preview-pane{flex:1;display:flex;align-items:center;justify-content:center;background:var(--paper);border-radius:12px;position:relative;overflow:hidden;padding:16px;max-height:70vh;border:var(--glass-border);box-shadow:var(--glass-shadow)}.preview-empty{color:var(--text-dim)}.preview-img{max-width:100%;max-height:calc(70vh - 32px);object-fit:contain;border-radius:4px}.preview-loading{position:absolute;top:12px;right:12px;font-size:.75rem;color:var(--accent);background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:4px 10px;border-radius:6px;border:var(--glass-border)}.preview-warning{position:absolute;bottom:12px;left:50%;transform:translate(-50%);font-size:.75rem;color:var(--accent);background:#5ab7c314;border:1px solid rgba(90,183,195,.2);padding:6px 14px;border-radius:6px;white-space:nowrap}.edit-toolbar{display:flex;align-items:center;justify-content:space-between;background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:10px;padding:8px 16px;margin-bottom:12px;border:var(--glass-border);box-shadow:0 2px 12px #2c25200a}.toolbar-label{font-size:.8rem;color:var(--text-dim)}.toolbar-actions{display:flex;gap:6px}.toolbar-btn{background:#fffdf8b3;color:var(--text);border:1px solid rgba(44,37,32,.1);padding:5px 14px;border-radius:8px;font-size:.78rem;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.toolbar-btn:hover:not(:disabled){border-color:var(--accent);box-shadow:0 2px 8px #5ab7c326}.toolbar-btn:disabled{opacity:.4;cursor:default}.toolbar-btn-delete{color:var(--danger);border-color:#c443}.toolbar-btn-delete:hover:not(:disabled){background:#cc44440f;border-color:var(--danger)}.toolbar-btn-restore{color:var(--accent);border-color:#5ab7c34d}.toolbar-btn-restore:hover{background:#5ab7c30f;border-color:var(--accent)}.action-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:#fffcf7b3;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(255,255,255,.4);box-shadow:0 -4px 24px #2c25200f}.action-bar-spacer{flex:1}.confirm-btn{background:var(--accent);color:#fff;border:none;padding:8px 24px;border-radius:8px;font-weight:600;font-size:.82rem;cursor:pointer;white-space:nowrap;transition:background .2s,box-shadow .2s;box-shadow:0 2px 8px #5ab7c340}.confirm-btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #5ab7c359}.export-badge{font-size:.72rem;font-weight:600;color:var(--accent);background:#5ab7c314;border:1px solid rgba(90,183,195,.2);padding:4px 12px;border-radius:6px;white-space:nowrap}.action-btn{background:#fffdf8cc;color:var(--text);border:1px solid rgba(44,37,32,.1);padding:7px 16px;border-radius:8px;font-size:.78rem;cursor:pointer;white-space:nowrap;transition:border-color .15s,background .15s,box-shadow .15s}.action-btn:hover:not(:disabled){border-color:var(--accent);box-shadow:0 2px 8px #5ab7c326}.action-btn:disabled{opacity:.5;cursor:default}.action-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;box-shadow:0 2px 8px #5ab7c340}.action-btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #5ab7c359}.omr-btn{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.omr-btn:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.reset-btn{background:none;border:none;color:var(--text-dim);font-size:.72rem;cursor:pointer;text-decoration:underline;white-space:nowrap}.reset-btn:hover{color:var(--text)}.omr-spinner{font-size:.75rem;color:var(--accent);white-space:nowrap;animation:omr-pulse 1.5s ease-in-out infinite}@keyframes omr-pulse{0%,to{opacity:1}50%{opacity:.4}}.omr-error{font-size:.75rem;color:var(--danger);background:#cc44440f;border:1px solid rgba(204,68,68,.15);padding:4px 12px;border-radius:6px;white-space:nowrap;max-width:300px;overflow:hidden;text-overflow:ellipsis}.no-backend-msg{font-size:.8rem;color:var(--text-muted);padding:4px 12px;white-space:nowrap}.analysis-summary{font-size:.75rem;color:var(--text-dim);white-space:nowrap}.beat-warning{font-size:.72rem;color:#b08800;background:#b088000f;border:1px solid rgba(176,136,0,.15);padding:4px 12px;border-radius:6px;white-space:nowrap}.score-player{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding-bottom:48px}.score-container{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--paper);border-radius:12px;padding:20px 20px 8px;max-height:calc(100vh - 150px);border:var(--glass-border);box-shadow:var(--glass-shadow)}.score-container svg{cursor:pointer}.score-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:.9rem;padding:48px}.score-error{padding:16px;color:var(--danger);background:#cc44440f;border:1px solid rgba(204,68,68,.15);border-radius:8px;font-size:.85rem}.playback-controls{display:flex;align-items:center;gap:12px;padding:10px 20px;background:#fffcf7b3;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-wrap:wrap;position:fixed;bottom:0;left:0;right:0;z-index:100;border-top:1px solid rgba(255,255,255,.4);box-shadow:0 -4px 24px #2c25200f}.transport-buttons{display:flex;gap:4px}.transport-btn{background:#fffdf8cc;color:var(--text);border:1px solid rgba(44,37,32,.1);padding:7px 16px;border-radius:8px;font-size:.82rem;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.transport-btn:hover:not(:disabled){border-color:var(--accent);box-shadow:0 2px 8px #5ab7c326}.transport-btn:disabled{opacity:.4;cursor:default}.transport-btn-play{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;box-shadow:0 2px 8px #5ab7c340}.transport-btn-play:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #5ab7c359}.tempo-control{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-dim)}.tempo-label{white-space:nowrap;font-weight:500}.tempo-slider{width:100px;accent-color:var(--accent)}.tempo-value{min-width:60px;text-align:right;color:var(--text);font-variant-numeric:tabular-nums}.time-sig-select{background:#fffdf8cc;color:var(--text);border:1px solid rgba(44,37,32,.1);border-radius:6px;padding:4px 8px;font-size:.8rem;font-family:inherit;cursor:pointer;transition:border-color .15s}.time-sig-select:hover{border-color:var(--accent)}.time-sig-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5ab7c326}.time-display{font-size:.8rem;color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:80px}.part-toggles{display:flex;gap:4px;margin-left:auto}.part-btn{width:34px;height:30px;border-radius:8px;border:1px solid rgba(44,37,32,.1);background:#fffdf8cc;color:var(--text);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.part-btn:hover{border-color:var(--accent);box-shadow:0 2px 8px #5ab7c326}.part-btn.active{background:#5ab7c326;color:var(--accent);border-color:#5ab7c34d}.part-btn.muted{background:#cc44441a;color:var(--danger);border-color:#c443}.timesig-confirm{flex:1;display:flex;align-items:center;justify-content:center}.timesig-confirm-card{background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:12px;padding:32px 40px;text-align:center;max-width:380px;width:100%}.timesig-confirm-title{font-size:1.1rem;font-weight:600;color:var(--text);margin:0 0 8px}.timesig-confirm-desc{font-size:.85rem;color:var(--text-dim);margin:0 0 24px;line-height:1.5}.timesig-confirm-select{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:24px;font-size:.85rem;color:var(--text-dim)}.timesig-confirm-select label{font-weight:500}.timesig-confirm-select select{background:#fffdf8cc;color:var(--text);border:1px solid rgba(44,37,32,.1);border-radius:8px;padding:8px 14px;font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .15s}.timesig-confirm-select select:hover{border-color:var(--accent)}.timesig-confirm-select select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5ab7c326}.timesig-confirm-btn{background:var(--accent);color:#fff;border:none;padding:10px 28px;border-radius:8px;font-weight:600;font-size:.88rem;cursor:pointer;transition:background .2s,box-shadow .2s;box-shadow:0 2px 8px #5ab7c340}.timesig-confirm-btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #5ab7c359}
