:root{--bg:#f8fafc;--bg-card:#fff;--bg-sidebar:#e2e8f0;--text:#1e293b;--text-muted:#64748b;--text-sidebar:#1e293b;--accent:#6366f1;--accent-light:#eef2ff;--border:#e2e8f0;--player-bg:#f1f5f9;--player-text:#1e293b}@media (prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]){--bg:#0f172a;--bg-card:#1e293b;--bg-sidebar:#0a0f1e;--text:#e2e8f0;--text-muted:#94a3b8;--text-sidebar:#e2e8f0;--border:#334155;--accent-light:#1e1b4b;--player-bg:#0a0f1e;--player-text:#f1f5f9}}:root[data-theme=dark]{--bg:#0f172a;--bg-card:#1e293b;--bg-sidebar:#0a0f1e;--text:#e2e8f0;--text-muted:#94a3b8;--text-sidebar:#e2e8f0;--border:#334155;--accent-light:#1e1b4b;--player-bg:#0a0f1e;--player-text:#f1f5f9}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{background:var(--accent);color:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.app-header h1{letter-spacing:-.01em;font-size:1.25rem;font-weight:700}.btn-theme-toggle{cursor:pointer;color:#fff;opacity:.75;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;padding:0;transition:opacity .15s;display:flex}.btn-theme-toggle svg{width:100%;height:100%;display:block}.btn-theme-toggle:hover{opacity:1}.app-body{flex:1;display:flex;overflow:hidden}.song-list{background:var(--bg-sidebar);width:220px;min-width:180px;color:var(--text-sidebar);border-right:1px solid var(--border);flex-shrink:0;padding:.75rem 0;overflow-y:auto}.song-list h2{text-transform:uppercase;letter-spacing:.1em;color:#64748b;padding:0 1rem .5rem;font-size:.7rem}.song-list ul{list-style:none}.song-list li{cursor:pointer;border-left:3px solid #0000;padding:.65rem 1rem;transition:background .12s}.song-list li:hover{background:#0000000f}.song-list li.active{border-left-color:var(--accent);background:#6366f140}.song-title{font-size:.875rem;font-weight:600}.song-artist{color:var(--text-muted);margin-top:.1rem;font-size:.78rem}.song-list-empty{color:#64748b;padding:.5rem 1rem;font-size:.8rem;line-height:1.5}.song-list-empty code{background:#00000014;border-radius:3px;padding:.05rem .25rem;font-size:.75rem}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.player{background:var(--player-bg);color:var(--player-text);flex-direction:column;flex-shrink:0;gap:.6rem;padding:.875rem 1.25rem;display:flex}.player-empty{color:#64748b;justify-content:center;align-items:center;min-height:90px;font-size:.875rem;display:flex}.player-info{align-items:baseline;gap:.75rem;display:flex}.player-song-title{font-size:1rem;font-weight:700}.player-artist{color:#94a3b8;font-size:.8rem}.player-error{color:#f87171;font-size:.8rem}.player-controls{align-items:center;gap:.75rem;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-play{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-size:.9rem;transition:opacity .15s;display:flex}.btn-play svg{width:52%;height:52%;display:block}.btn-play--loading svg{animation:.9s linear infinite spin}.btn-play:disabled{opacity:.45;cursor:not-allowed}.btn-loop{border:1.5px solid var(--accent);width:2.25rem;height:2.25rem;color:var(--accent);cursor:pointer;opacity:.5;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:.45rem;transition:opacity .15s,background .15s;display:flex}.btn-loop svg{width:100%;height:100%;display:block}.btn-loop--active{background:var(--accent);color:#fff;opacity:1}.btn-loop:disabled{opacity:.25;cursor:not-allowed}.seek-area{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.seek-bar{accent-color:var(--accent);cursor:pointer;flex:1;min-width:0}.time{color:#94a3b8;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:2.4rem;font-size:.72rem}.pitch-controls{align-items:center;gap:.4rem;display:flex}.pitch-label{color:var(--player-text);opacity:.6;text-transform:uppercase;letter-spacing:.06em;margin-right:.2rem;font-size:.7rem}.pitch-controls button{border:1px solid var(--border);width:1.6rem;height:1.6rem;color:var(--player-text);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;line-height:1;transition:background .1s;display:flex}.pitch-controls button:hover{background:color-mix(in srgb, var(--player-text) 15%, transparent)}.pitch-value{text-align:center;font-variant-numeric:tabular-nums;min-width:5.5rem;color:var(--player-text);font-size:.8rem}.btn-reset-pitch{opacity:.65;width:auto!important;padding:0 .5rem!important;font-size:.7rem!important}.content-panels{border-top:1px solid var(--border);flex:1;display:flex;overflow:hidden}.lyrics-panel,.notes-panel{flex-direction:column;gap:.75rem;min-width:0;padding:1rem 1.25rem;display:flex;overflow-y:auto}.lyrics-panel{border-right:1px solid var(--border);flex:1}.notes-panel{flex:1;min-width:220px}.notes-panel--collapsed{width:2.75rem;min-width:unset;border-left:1px solid var(--border);flex:none;padding:1rem .5rem;overflow:hidden}.lyrics-panel h3,.notes-panel h3{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);flex-shrink:0;font-size:.7rem;font-weight:600}.lrc-lines{flex-direction:column;gap:.4rem;display:flex}.lrc-line-wrapper{border-radius:4px;flex-direction:column;padding:.2rem 0;display:flex}.lrc-line-wrapper:nth-child(2n){background:color-mix(in srgb, var(--text) 4%, transparent)}.lrc-line-row{align-items:center;gap:.4rem;display:flex}.lrc-line{color:var(--text-muted);border-left:3px solid #0000;flex:1;margin:0;padding-left:.5rem;font-size:.95rem;line-height:1.65;transition:color .2s,font-size .15s,font-weight .15s}.lrc-line.active{color:var(--accent);border-left-color:var(--accent);font-size:1.05rem;font-weight:600}.lrc-line.seekable{cursor:pointer}.lrc-line.seekable:hover{color:var(--text)}.line-note-btn{cursor:pointer;width:1rem;height:1rem;color:var(--text-muted);opacity:.2;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;line-height:1;transition:opacity .15s,background .15s;display:flex}@media (width>=700px){.line-note-btn{width:1.75rem;height:1.75rem}.line-note-btn svg{width:1rem;height:1rem}}.line-note-btn svg{width:100%;height:100%;display:block}.line-note-btn.has-note{opacity:.2}.line-note-btn:hover{opacity:.8;background:var(--accent-light)}.line-note-editor{padding:.25rem .5rem .25rem 1rem}.line-note-textarea{box-sizing:border-box;background:var(--surface);width:100%;color:var(--text);border:1px solid var(--accent);resize:vertical;border-radius:4px;outline:none;padding:.3rem .5rem;font-family:inherit;font-size:.8rem}.line-note-text{color:var(--text-muted);border-left:2px solid var(--border);opacity:.85;margin:.1rem 0 .2rem 1.5rem;padding-left:.5rem;font-size:.78rem;font-style:italic}.txt-lyrics{white-space:pre-wrap;color:var(--text);font-family:inherit;font-size:.95rem;line-height:1.7}.lyrics-empty,.lyrics-loading{color:var(--text-muted);font-size:.875rem}.notes-panel--collapsed .notes-header{flex-direction:column;align-items:center;gap:.5rem}.notes-panel--collapsed h3{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.12em}.btn-notes-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:.15rem .25rem;font-size:.85rem;line-height:1;transition:color .15s,background .15s}.btn-notes-toggle:hover{color:var(--text);background:var(--accent-light)}.notes-collapsed-preview{display:none}.notes-header{flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.notes-actions{gap:.4rem;display:flex}.notes-actions button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:4px;padding:.25rem .6rem;font-size:.75rem;transition:background .12s}.notes-actions button:hover{background:var(--accent-light)}.notes-textarea{resize:none;border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:6px;flex:1;min-height:120px;padding:.75rem;font-family:inherit;font-size:.875rem;line-height:1.6}.notes-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 20%, transparent);outline:none}.notes-hint{color:var(--text-muted);flex-shrink:0;font-size:.72rem}@media (width<=700px){.app{height:auto;min-height:100vh;overflow:auto}.app-body{flex-direction:column;overflow:visible}.song-list{width:100%;min-width:unset;max-height:180px;padding:.5rem 0}.song-list h2{padding:0 .5rem .4rem}.song-list li{padding:.55rem .5rem}.main-content{overflow:visible}.player{padding:.75rem .5rem}.content-panels{flex-direction:column;overflow:visible}.lyrics-panel,.notes-panel{padding:.75rem .5rem}.app-header{padding:.6rem .5rem}.lyrics-panel{border-right:none;border-bottom:1px solid var(--border)}}
