*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.nav-bar{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:#1a1a2e;color:#fff}.nav-bar .nav-title{font-weight:700;margin-right:auto}.nav-bar a{color:#ccc;text-decoration:none;padding:.25rem .5rem;border-radius:4px}.nav-bar a.active{color:#fff;background:#ffffff26}.page{padding:2rem}.page h2{margin-bottom:1rem}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem 2rem;margin-top:1rem;border:2px dashed #888;border-radius:8px;cursor:pointer;transition:border-color .2s,background-color .2s}.upload-dropzone:hover,.upload-dropzone:focus-visible{border-color:#4a90d9;background:#4a90d90d;outline:none}.upload-dropzone.drag-over{border-color:#4a90d9;background:#4a90d91a}.upload-dropzone-text{font-size:1.1rem;color:#333}.upload-dropzone-hint{font-size:.85rem;color:#888}.upload-status{margin-top:1.25rem}.upload-filename{font-weight:600;margin-bottom:.5rem}.upload-progress-container{width:100%;max-width:480px;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.upload-progress-bar{height:100%;background:#4a90d9;border-radius:4px;transition:width .3s ease}.upload-message{margin-top:.5rem;font-size:.95rem}.upload-success{color:#2e7d32}.upload-error{color:#c62828}.upload-reset-btn{margin-top:.75rem;padding:.4rem 1rem;border:1px solid #888;border-radius:4px;background:transparent;cursor:pointer;font-size:.9rem}.upload-reset-btn:hover{background:#f0f0f0}.song-library-toolbar{margin-bottom:1rem}.song-search-input{width:100%;max-width:400px;padding:.5rem .75rem;font-size:.95rem;border:1px solid #ccc;border-radius:6px;outline:none;transition:border-color .2s}.song-search-input:focus{border-color:#4a90d9}.song-library-loading{color:#555;font-style:italic}.song-library-error{color:#c62828}.song-library-empty{color:#777;padding:2rem 0;text-align:center}.song-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.song-list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:6px;transition:background .15s}.song-list-item:hover{background:#f9f9f9}.song-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.song-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-date{font-size:.85rem;color:#888;white-space:nowrap}.song-status{font-size:.8rem;font-weight:600;padding:.15rem .5rem;border-radius:10px;white-space:nowrap}.status-pending{background:#fff3e0;color:#e65100}.status-processing{background:#e3f2fd;color:#1565c0}.status-completed{background:#e8f5e9;color:#2e7d32}.status-failed{background:#ffebee;color:#c62828}.song-actions{display:flex;gap:.5rem;flex-shrink:0}.btn{padding:.35rem .75rem;font-size:.85rem;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#4a90d9;color:#fff}.btn-primary:hover:not(:disabled){background:#3a7bc8}.btn-secondary{background:transparent;border-color:#888;color:#333}.btn-secondary:hover:not(:disabled){background:#f0f0f0}.btn-danger{background:transparent;border-color:#c62828;color:#c62828}.btn-danger:hover:not(:disabled){background:#ffebee}.song-config-form{max-width:480px;display:flex;flex-direction:column;gap:1.25rem;margin-top:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem;border:none;padding:0}.form-group label,.form-group legend{font-weight:600;font-size:.95rem}.form-group input[type=number]{width:100%;max-width:180px;padding:.5rem .75rem;font-size:.95rem;border:1px solid #ccc;border-radius:6px;outline:none;transition:border-color .2s}.form-group input[type=number]:focus{border-color:#4a90d9}.song-text-input{width:100%;max-width:360px;padding:.5rem .75rem;font-size:.95rem;border:1px solid #ccc;border-radius:6px;outline:none;transition:border-color .2s}.song-text-input:focus{border-color:#4a90d9}.form-group input[aria-invalid=true]{border-color:#c62828}.length-inputs{display:flex;gap:1rem}.length-field{display:flex;flex-direction:column;gap:.25rem}.length-field label{font-weight:400;font-size:.85rem;color:#555}.field-error{color:#c62828;font-size:.85rem}.song-config-success{color:#2e7d32;font-size:.95rem}.song-config-error{color:#c62828;font-size:.95rem}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.setlist-create-form{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.setlist-name-input{padding:.5rem .75rem;font-size:.95rem;border:1px solid #ccc;border-radius:6px;outline:none;transition:border-color .2s;width:280px;max-width:100%}.setlist-name-input:focus{border-color:#4a90d9}.setlist-inline-error{color:#c62828;font-size:.85rem;width:100%}.setlist-loading{color:#555;font-style:italic}.setlist-error{color:#c62828;margin-bottom:1rem}.setlist-empty{color:#777;padding:2rem 0;text-align:center}.setlist-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.setlist-card{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.setlist-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem 1rem;background:#fafafa}.setlist-expand-btn{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;font-size:.95rem;padding:.25rem 0;flex:1;text-align:left}.setlist-chevron{display:inline-block;font-size:.7rem;transition:transform .2s}.setlist-chevron.open{transform:rotate(90deg)}.setlist-name{font-weight:600}.setlist-count{color:#888;font-size:.85rem}.setlist-card-body{padding:.75rem 1rem 1rem;border-top:1px solid #e0e0e0}.setlist-empty-songs{color:#888;font-size:.9rem;padding:.5rem 0}.setlist-song-list{list-style:none;display:flex;flex-direction:column;gap:.25rem;padding-left:0;counter-reset:none}.setlist-song-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border:1px solid transparent;border-radius:4px;cursor:grab;transition:background .15s,border-color .15s}.setlist-song-item:hover{background:#f5f5f5}.setlist-song-item.dragging{opacity:.4}.setlist-song-item.drag-over{border-color:#4a90d9;background:#4a90d914}.setlist-song-order{width:1.5rem;text-align:center;font-weight:600;color:#888;font-size:.85rem;flex-shrink:0}.setlist-song-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setlist-add-panel{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed #ddd}.setlist-add-label{font-size:.85rem;font-weight:600;color:#555;margin-bottom:.35rem}.setlist-available-songs{list-style:none;display:flex;flex-direction:column;gap:.25rem}.setlist-available-item{display:flex;align-items:center;justify-content:space-between;padding:.3rem .5rem;border-radius:4px}.setlist-available-item:hover{background:#f5f5f5}.setlist-no-available{color:#888;font-size:.85rem}.btn-sm{padding:.2rem .5rem;font-size:.8rem}.perf-container{display:flex;flex-direction:column;height:100vh;max-height:100vh;background:#000;color:#fff;font-family:Courier New,Courier,monospace;overflow:hidden}.perf-container .perf-loading,.perf-container .perf-error{padding:2rem;font-size:1.25rem;text-align:center}.perf-container .btn-secondary{color:#ccc;border-color:#555}.perf-container .btn-secondary:hover:not(:disabled){background:#222}.perf-toolbar{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#111;flex-shrink:0}.perf-back-btn{font-size:1.1rem}.perf-song-title{font-weight:700;font-size:1rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.perf-line-counter{font-size:.85rem;color:#888;white-space:nowrap}.perf-fs-btn{font-size:1.25rem}.perf-lyrics{flex:1;display:flex;flex-direction:column;justify-content:center;padding:2rem 2.5rem;overflow:hidden}.perf-line{display:flex;flex-direction:column;padding:.25rem 0;transition:opacity .3s ease}.perf-lyric-text{font-size:48pt;line-height:1.3;white-space:pre-wrap;word-break:break-word}.perf-chord-line{font-size:32pt;line-height:1.2;color:#ffd54f;white-space:pre}.perf-section-header{font-size:24pt;line-height:1.4;color:#80cbc4;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.85}.perf-line-current{opacity:1}.perf-line-current .perf-lyric-text{color:#fff;text-shadow:0 0 8px rgba(255,255,255,.3)}.perf-line-upcoming{opacity:.45}.perf-line-past{opacity:.2}.perf-controls{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;background:#111;flex-shrink:0}.perf-play-btn,.perf-pause-btn{min-width:6rem}.perf-stop-btn{min-width:5rem}.perf-no-scroll-hint{font-size:.8rem;color:#888;white-space:nowrap}.perf-container:fullscreen{width:100vw;height:100vh}.perf-container:fullscreen .perf-lyrics{padding:3rem 4rem}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem;text-align:center}.error-boundary h2{font-size:1.5rem;margin-bottom:.75rem;color:#c62828}.error-boundary-message{color:#555;margin-bottom:1.5rem;max-width:480px}.error-boundary-actions{display:flex;gap:.75rem}.toast-container{position:fixed;bottom:1.25rem;right:1.25rem;display:flex;flex-direction:column;gap:.5rem;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-radius:6px;font-size:.9rem;box-shadow:0 2px 8px #0000002e;pointer-events:auto;animation:toast-in .25s ease-out;max-width:360px}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:#e8f5e9;color:#2e7d32;border-left:4px solid #2e7d32}.toast-error{background:#ffebee;color:#c62828;border-left:4px solid #c62828}.toast-info{background:#e3f2fd;color:#1565c0;border-left:4px solid #1565c0}.toast-close{background:none;border:none;cursor:pointer;font-size:.85rem;color:inherit;opacity:.6;padding:0 .25rem;line-height:1}.toast-close:hover{opacity:1}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#555;font-style:italic}.loading-spinner:before{content:"";width:1.25rem;height:1.25rem;border:2px solid #ddd;border-top-color:#4a90d9;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
