:root{--primary-color:#667eea;--primary-dark:#764ba2;--success-color:#10b981;--error-color:#dc2626;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-600:#4b5563;--gray-700:#374151;--gray-900:#1f2937;--lyrics-font:"Courier New",Courier,monospace;color:var(--gray-900);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{width:100%;height:100%}body{margin:0}h1{font-size:1.5rem;line-height:1.1}button{cursor:pointer;border-radius:.375rem;font-family:inherit;transition:all .2s}button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}#app{flex-direction:column;display:flex}.lyrics-input,.lyrics-display,.chorded-lyrics,textarea.lyrics-input,.form-group textarea.lyrics-input{font-family:var(--lyrics-font)}.edit-song-modal[data-v-752ece15]{z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay[data-v-752ece15]{background-color:#00000080;position:absolute;inset:0}.modal-content[data-v-752ece15]{background-color:#fff;border-radius:.5rem;width:90%;max-width:500px;max-height:90vh;position:relative;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header[data-v-752ece15]{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2[data-v-752ece15]{margin:0;font-size:1.25rem}.close-btn[data-v-752ece15]{cursor:pointer;color:#6b7280;background:0 0;border:none;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1.5rem;display:flex}.close-btn[data-v-752ece15]:hover{color:#000}.song-form[data-v-752ece15]{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.form-group[data-v-752ece15]{flex-direction:column;gap:.5rem;display:flex}.form-row[data-v-752ece15]{grid-template-columns:1fr 1fr;gap:1rem;display:grid}label[data-v-752ece15]{color:#374151;font-size:.875rem;font-weight:500}input[data-v-752ece15],textarea[data-v-752ece15]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem}input[data-v-752ece15]:focus,textarea[data-v-752ece15]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}textarea[data-v-752ece15]{resize:vertical}.lyrics-actions[data-v-752ece15]{justify-content:flex-end;display:flex}.btn-reformat[data-v-752ece15]{color:#374151;cursor:pointer;background-color:#e5e7eb;border:none;border-radius:.375rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;transition:all .2s}.btn-reformat[data-v-752ece15]:hover{background-color:#d1d5db}.links-section[data-v-752ece15]{flex-direction:column;gap:.5rem;display:flex}.link-input[data-v-752ece15]{align-items:center;gap:.5rem;display:flex}.link-input input[data-v-752ece15]{flex:1}.btn-remove-link[data-v-752ece15]{color:#dc2626;cursor:pointer;background-color:#fee2e2;border:none;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.btn-remove-link[data-v-752ece15]:hover{background-color:#fecaca}.btn-add-link[data-v-752ece15]{color:#0284c7;cursor:pointer;text-align:left;background-color:#dbeafe;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-add-link[data-v-752ece15]:hover{background-color:#bfdbfe}.error-message[data-v-752ece15]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;padding:.75rem;font-size:.875rem}.form-actions[data-v-752ece15]{justify-content:flex-end;gap:1rem;margin-top:.5rem;display:flex}button[data-v-752ece15]{cursor:pointer;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-cancel[data-v-752ece15]{color:#374151;background-color:#e5e7eb}.btn-cancel[data-v-752ece15]:hover{background-color:#d1d5db}.btn-submit[data-v-752ece15]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.btn-submit[data-v-752ece15]:hover:not(:disabled){opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-submit[data-v-752ece15]:disabled{opacity:.6;cursor:not-allowed}.songs-list[data-v-c41cc8f2]{width:100%}.loading[data-v-c41cc8f2],.error[data-v-c41cc8f2],.no-songs[data-v-c41cc8f2]{text-align:center;justify-content:center;align-items:center;padding:2rem;display:flex}.error[data-v-c41cc8f2]{color:#dc2626}.song-tiles[data-v-c41cc8f2]{flex-direction:column;padding:.5rem;display:flex}.song-row[data-v-c41cc8f2]{flex-direction:column;display:flex}.song-tile[data-v-c41cc8f2]{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;justify-content:space-between;align-items:center;padding:1rem;transition:all .2s;display:flex}.song-tile.is-dragging[data-v-c41cc8f2]{opacity:.5;cursor:grabbing}.song-tile[data-v-c41cc8f2]:hover{background-color:#f3f4f6;border-color:#d1d5db}.song-content[data-v-c41cc8f2]{cursor:pointer;flex:1}.song-tile h3[data-v-c41cc8f2]{margin:0;font-size:1rem;font-weight:500}.song-meta[data-v-c41cc8f2]{color:#6b7280;margin:.25rem 0 0;font-size:.875rem}.song-actions[data-v-c41cc8f2]{gap:.5rem;margin-left:1rem;display:flex}.drop-indicator[data-v-c41cc8f2]{height:12px;position:relative}.drop-indicator[data-v-c41cc8f2]:before{content:"";border-top:2px solid #0000;position:absolute;top:50%;left:.5rem;right:.5rem;transform:translateY(-50%)}.drop-indicator.is-active[data-v-c41cc8f2]:before{border-top-color:#3b82f6}.drop-indicator.is-active[data-v-c41cc8f2]:after{content:"";background:#3b82f6;border-radius:999px;width:8px;height:8px;position:absolute;top:50%;left:.35rem;transform:translateY(-50%)}.drop-indicator.end[data-v-c41cc8f2]{margin-bottom:.5rem}button[data-v-c41cc8f2]{cursor:pointer;border:none;border-radius:.375rem;padding:.5rem;font-size:1rem;transition:all .2s}.btn-edit[data-v-c41cc8f2]{color:#1e40af;background-color:#dbeafe}.btn-edit[data-v-c41cc8f2]:hover{background-color:#bfdbfe}.btn-delete[data-v-c41cc8f2]{color:#dc2626;background-color:#fee2e2}.btn-delete[data-v-c41cc8f2]:hover{background-color:#fecaca}.delete-confirm-overlay[data-v-c41cc8f2]{z-index:999;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.delete-confirm-dialog[data-v-c41cc8f2]{background-color:#fff;border-radius:.5rem;max-width:400px;padding:2rem;box-shadow:0 10px 40px #0003}.delete-confirm-dialog h3[data-v-c41cc8f2]{margin:0 0 .5rem;font-size:1.25rem}.delete-confirm-dialog p[data-v-c41cc8f2]{color:#6b7280;margin:0 0 1.5rem}.confirm-actions[data-v-c41cc8f2]{justify-content:flex-end;gap:1rem;display:flex}.btn-cancel[data-v-c41cc8f2]{color:#374151;background-color:#e5e7eb;padding:.5rem 1rem}.btn-cancel[data-v-c41cc8f2]:hover{background-color:#d1d5db}.btn-confirm-delete[data-v-c41cc8f2]{color:#fff;background-color:#dc2626;padding:.5rem 1rem}.btn-confirm-delete[data-v-c41cc8f2]:hover{background-color:#991b1b}.music-details[data-v-9f2abca0]{width:100%;padding:1rem}.no-selection[data-v-9f2abca0]{text-align:center;color:#6b7280;justify-content:center;align-items:center;height:100%;display:flex}.details-container[data-v-9f2abca0]{max-width:900px;margin:0 auto}.details-header[data-v-9f2abca0]{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.details-header h2[data-v-9f2abca0]{margin:0;font-size:2rem;font-weight:700}.header-actions[data-v-9f2abca0]{align-items:center;gap:.75rem;display:flex}.edit-actions[data-v-9f2abca0]{gap:.5rem;display:flex}.btn-edit[data-v-9f2abca0],.btn-secondary[data-v-9f2abca0],.btn-primary[data-v-9f2abca0]{cursor:pointer;border:none;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.btn-edit[data-v-9f2abca0]{color:#1e40af;background-color:#dbeafe}.btn-edit[data-v-9f2abca0]:hover{background-color:#bfdbfe}.btn-secondary[data-v-9f2abca0]{color:#374151;background-color:#e5e7eb}.btn-secondary[data-v-9f2abca0]:hover{background-color:#d1d5db}.btn-primary[data-v-9f2abca0]{color:#fff;background-color:#667eea}.btn-primary[data-v-9f2abca0]:hover{background-color:#5568d3}.btn-compact[data-v-9f2abca0]{padding:.4rem .6rem;font-size:1rem;line-height:1}.btn-compact-expand[data-v-9f2abca0]{align-items:center;gap:.45rem;display:inline-flex;overflow:hidden}.btn-compact-label[data-v-9f2abca0]{opacity:0;white-space:nowrap;max-width:0;transition:max-width .2s,opacity .2s;overflow:hidden}.btn-compact-expand:hover .btn-compact-label[data-v-9f2abca0],.btn-compact-expand:focus-visible .btn-compact-label[data-v-9f2abca0]{opacity:1;max-width:160px}.material-symbols-outlined[data-v-9f2abca0]{font-variation-settings:"FILL" 0,"wght" 500,"GRAD" 0,"opsz" 20;font-size:1.1rem;line-height:1}.btn-icon[data-v-9f2abca0]{color:#374151;cursor:pointer;background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.45rem .6rem;font-size:.9rem;line-height:1;transition:background-color .2s,border-color .2s}.btn-icon[data-v-9f2abca0]:hover{background-color:#f3f4f6;border-color:#cbd5f5}.edit-form[data-v-9f2abca0]{flex-direction:column;gap:1rem;padding:1rem 0 0;display:flex}.form-group[data-v-9f2abca0]{flex-direction:column;gap:.5rem;display:flex}.lyrics-actions[data-v-9f2abca0]{justify-content:flex-end;display:flex}.btn-reformat[data-v-9f2abca0]{font-size:.8rem}.form-row[data-v-9f2abca0]{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group label[data-v-9f2abca0]{color:#6b7280;font-size:.875rem;font-weight:500}.form-group input[data-v-9f2abca0],.form-group textarea[data-v-9f2abca0]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem}.form-group input[data-v-9f2abca0]:focus,.form-group textarea[data-v-9f2abca0]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.link-input[data-v-9f2abca0]{align-items:center;gap:.5rem;display:flex}.link-input input[data-v-9f2abca0]{flex:1}.btn-remove-link[data-v-9f2abca0]{color:#dc2626;cursor:pointer;background-color:#fee2e2;border:none;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;transition:background-color .2s}.btn-remove-link[data-v-9f2abca0]:hover{background-color:#fecaca}.btn-add-link[data-v-9f2abca0]{color:#0284c7;cursor:pointer;text-align:left;background-color:#dbeafe;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.btn-add-link[data-v-9f2abca0]:hover{background-color:#bfdbfe}.error-message[data-v-9f2abca0]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;padding:.75rem;font-size:.875rem}.recordings-header[data-v-9f2abca0]{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.recordings-header h3[data-v-9f2abca0]{margin:0}.recordings-subtitle[data-v-9f2abca0]{color:#6b7280;margin:.25rem 0 0;font-size:.875rem}.recording-actions[data-v-9f2abca0]{gap:.35rem;display:flex}.modal-backdrop[data-v-9f2abca0]{z-index:50;background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-card[data-v-9f2abca0]{background:#fff;border-radius:.75rem;flex-direction:column;gap:.75rem;width:100%;max-width:420px;padding:1.5rem;display:flex;box-shadow:0 20px 60px #0f172a40}.modal-card h4[data-v-9f2abca0]{margin:0}.modal-actions[data-v-9f2abca0]{justify-content:flex-end;gap:.75rem;display:flex}.info-section[data-v-9f2abca0]{margin-bottom:1.5rem}.info-row[data-v-9f2abca0]{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.info-item[data-v-9f2abca0]{flex-direction:column;display:flex}.info-item label[data-v-9f2abca0]{color:#6b7280;margin-bottom:.25rem;font-size:.875rem;font-weight:500}.info-item p[data-v-9f2abca0]{margin:0;font-size:1.125rem}.lyrics-section[data-v-9f2abca0]{margin-top:2rem}.chorded-lyrics[data-v-9f2abca0]{font-size:.95rem;line-height:1.25}.chord-line[data-v-9f2abca0]{display:block}.chord-token[data-v-9f2abca0]{color:#374151;background:#f3f4f6;border-radius:.2rem;padding:0;font-weight:700;display:inline;box-shadow:0 0 0 1px #d1d5db}.lyric-line[data-v-9f2abca0]{white-space:pre;line-height:1.25}.text-token[data-v-9f2abca0]{white-space:pre}.section-title[data-v-9f2abca0]{letter-spacing:.04em;text-transform:uppercase;color:#111827;margin:.35rem 0 .2rem;font-weight:600}.lyrics-section h3[data-v-9f2abca0]{margin-bottom:.5rem;font-size:1rem;font-weight:500}.links-section[data-v-9f2abca0]{margin-top:2rem}.links-section h3[data-v-9f2abca0]{margin-bottom:.5rem;font-size:1rem;font-weight:500}.links-list[data-v-9f2abca0]{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.links-list li[data-v-9f2abca0]{margin:0}.links-list a[data-v-9f2abca0]{color:#667eea;word-break:break-all;text-decoration:none;transition:color .2s}.links-list a[data-v-9f2abca0]:hover{color:#764ba2;text-decoration:underline}.lyrics-section p[data-v-9f2abca0]{color:#374151;white-space:pre-wrap;line-height:1.6}.recordings-section[data-v-9f2abca0]{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:1rem}.recordings-header h3[data-v-9f2abca0]{margin-bottom:.75rem;font-size:1rem;font-weight:500}.recordings-upload[data-v-9f2abca0]{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;flex-direction:column;gap:.5rem;padding:.6rem;display:flex}.recordings-upload-row[data-v-9f2abca0]{grid-template-columns:minmax(200px,1.2fr) minmax(160px,1fr) auto auto;align-items:end;gap:.75rem;display:grid}.recordings-inline-actions[data-v-9f2abca0]{justify-content:flex-end;gap:.5rem;display:flex}@media (max-width:720px){.recordings-upload-row[data-v-9f2abca0]{grid-template-columns:1fr}.recordings-inline-actions[data-v-9f2abca0]{justify-content:flex-start}}.recordings-list[data-v-9f2abca0]{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.recording-card[data-v-9f2abca0]{border:1px solid #e5e7eb;border-radius:.5rem;flex-direction:column;gap:.35rem;padding:.75rem;display:flex}.recording-row[data-v-9f2abca0]{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.recording-title[data-v-9f2abca0]{color:#111827;font-size:.95rem;font-weight:600}.recording-audio[data-v-9f2abca0]{flex:260px;min-width:220px}.recording-notes[data-v-9f2abca0]{color:#374151;margin:0 0 .5rem;font-size:.85rem}.recordings-loading[data-v-9f2abca0],.recordings-empty[data-v-9f2abca0]{color:#6b7280;margin-top:.75rem}.settings-container[data-v-bb8df2cd]{background-color:#f9fafb;flex-direction:column;width:100%;height:100%;padding:2rem;display:flex}.settings-content[data-v-bb8df2cd]{width:100%;max-width:600px;margin:0 auto}h2[data-v-bb8df2cd]{color:#1f2937;margin:0 0 1.5rem;font-size:1.5rem;font-weight:700}h3[data-v-bb8df2cd]{color:#374151;margin:0 0 .75rem;font-size:1rem;font-weight:600}.api-url[data-v-bb8df2cd]{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:2rem;padding:1rem}.api-url p[data-v-bb8df2cd]{color:#6b7280;margin:0 0 .5rem;font-size:.875rem}.api-url code[data-v-bb8df2cd]{color:#1f2937;word-break:break-all;background-color:#f3f4f6;border-radius:.375rem;padding:.5rem;font-family:Courier New,monospace;font-size:.875rem;display:block}.api-mode-section[data-v-bb8df2cd]{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:2rem;padding:1.5rem}.button-group[data-v-bb8df2cd]{gap:.75rem;display:flex}.btn[data-v-bb8df2cd]{cursor:pointer;color:#374151;background-color:#fff;border:2px solid #d1d5db;border-radius:.5rem;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:1rem;font-weight:500;transition:all .2s;display:flex}.btn[data-v-bb8df2cd]:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.btn.active[data-v-bb8df2cd]{color:#fff;background-color:#10b981;border-color:#10b981}.btn[data-v-bb8df2cd]:disabled{cursor:not-allowed;opacity:1}.btn-icon[data-v-bb8df2cd]{font-size:1.25rem}.notification[data-v-bb8df2cd]{border-radius:.5rem;align-items:center;gap:.5rem;margin-top:1rem;padding:1rem;animation:.3s slideIn-bb8df2cd;display:flex}.notification.success[data-v-bb8df2cd]{color:#166534;background-color:#dcfce7;border:1px solid #10b981}.notification-enter-active[data-v-bb8df2cd],.notification-leave-active[data-v-bb8df2cd]{transition:all .3s}.notification-enter-from[data-v-bb8df2cd],.notification-leave-to[data-v-bb8df2cd]{opacity:0;transform:translateY(-10px)}@keyframes slideIn-bb8df2cd{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.add-song-modal[data-v-0e6986d5]{z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay[data-v-0e6986d5]{background-color:#00000080;position:absolute;inset:0}.modal-content[data-v-0e6986d5]{background-color:#fff;border-radius:.5rem;width:90%;max-width:500px;max-height:90vh;position:relative;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header[data-v-0e6986d5]{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2[data-v-0e6986d5]{margin:0;font-size:1.25rem}.close-btn[data-v-0e6986d5]{cursor:pointer;color:#6b7280;background:0 0;border:none;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1.5rem;display:flex}.close-btn[data-v-0e6986d5]:hover{color:#000}.song-form[data-v-0e6986d5]{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.form-group[data-v-0e6986d5]{flex-direction:column;gap:.5rem;display:flex}.form-row[data-v-0e6986d5]{grid-template-columns:1fr 1fr;gap:1rem;display:grid}label[data-v-0e6986d5]{color:#374151;font-size:.875rem;font-weight:500}input[data-v-0e6986d5],textarea[data-v-0e6986d5]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem}input[data-v-0e6986d5]:focus,textarea[data-v-0e6986d5]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}textarea[data-v-0e6986d5]{resize:vertical}.lyrics-actions[data-v-0e6986d5]{justify-content:flex-end;display:flex}.btn-reformat[data-v-0e6986d5]{color:#374151;cursor:pointer;background-color:#e5e7eb;border:none;border-radius:.375rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;transition:all .2s}.btn-reformat[data-v-0e6986d5]:hover{background-color:#d1d5db}.links-section[data-v-0e6986d5]{flex-direction:column;gap:.5rem;display:flex}.link-input[data-v-0e6986d5]{align-items:center;gap:.5rem;display:flex}.link-input input[data-v-0e6986d5]{flex:1}.btn-remove-link[data-v-0e6986d5]{color:#dc2626;cursor:pointer;background-color:#fee2e2;border:none;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.btn-remove-link[data-v-0e6986d5]:hover{background-color:#fecaca}.btn-add-link[data-v-0e6986d5]{color:#0284c7;cursor:pointer;text-align:left;background-color:#dbeafe;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-add-link[data-v-0e6986d5]:hover{background-color:#bfdbfe}.error-message[data-v-0e6986d5]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;padding:.75rem;font-size:.875rem}.form-actions[data-v-0e6986d5]{justify-content:flex-end;gap:1rem;margin-top:.5rem;display:flex}button[data-v-0e6986d5]{cursor:pointer;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-cancel[data-v-0e6986d5]{color:#374151;background-color:#e5e7eb}.btn-cancel[data-v-0e6986d5]:hover{background-color:#d1d5db}.btn-submit[data-v-0e6986d5]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.btn-submit[data-v-0e6986d5]:hover:not(:disabled){opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-submit[data-v-0e6986d5]:disabled{opacity:.6;cursor:not-allowed}.rehearsals-list[data-v-84eb13c5]{background-color:#fff;flex-direction:column;flex:1;padding:1rem;display:flex}.loading[data-v-84eb13c5],.error[data-v-84eb13c5],.empty-state[data-v-84eb13c5]{text-align:center;flex:1;justify-content:center;align-items:center;display:flex}.error[data-v-84eb13c5]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;padding:1rem}.empty-state[data-v-84eb13c5]{color:#6b7280;flex-direction:column;gap:1rem}.empty-state p[data-v-84eb13c5]{margin:0;font-size:1rem}.btn-primary[data-v-84eb13c5]{color:#fff;cursor:pointer;background-color:#667eea;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:500;transition:background-color .2s}.btn-primary[data-v-84eb13c5]:hover{background-color:#5568d3}.rehearsals-container[data-v-84eb13c5]{flex-direction:column;gap:1rem;display:flex}.rehearsal-card[data-v-84eb13c5]{cursor:pointer;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;transition:all .2s}.rehearsal-card[data-v-84eb13c5]:hover{background-color:#f3f4f6;border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.rehearsal-header[data-v-84eb13c5]{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.rehearsal-name[data-v-84eb13c5]{color:#1f2937;margin:0;font-size:1rem;font-weight:600}.rehearsal-actions[data-v-84eb13c5]{gap:.5rem;display:flex}.btn-icon[data-v-84eb13c5]{cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:1rem;transition:transform .2s}.btn-icon[data-v-84eb13c5]:hover{transform:scale(1.2)}.btn-icon.edit[data-v-84eb13c5]:hover{color:#667eea}.btn-icon.delete[data-v-84eb13c5]:hover{color:#dc2626}.rehearsal-date[data-v-84eb13c5]{color:#6b7280;margin-bottom:.5rem;font-size:.875rem}.rehearsal-songs-count[data-v-84eb13c5]{color:#9ca3af;font-size:.875rem}.no-songs[data-v-84eb13c5]{color:#d97706}.songs-count[data-v-84eb13c5]{color:#10b981;font-weight:500}.rehearsal-details[data-v-7b04ad1d]{background-color:#fff;flex-direction:column;flex:1;display:flex}.no-rehearsal[data-v-7b04ad1d]{color:#9ca3af;flex:1;justify-content:center;align-items:center;display:flex}.details-container[data-v-7b04ad1d]{flex-direction:column;flex:1;display:flex;overflow-y:auto}.details-header[data-v-7b04ad1d]{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem;display:flex}.header-main h2[data-v-7b04ad1d]{color:#1f2937;margin:0 0 .5rem;font-size:1.5rem}.header-actions[data-v-7b04ad1d]{align-items:center;display:flex}.edit-actions[data-v-7b04ad1d]{gap:.5rem;display:flex}.btn-edit[data-v-7b04ad1d],.btn-secondary[data-v-7b04ad1d],.btn-primary[data-v-7b04ad1d]{cursor:pointer;border:none;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.btn-edit[data-v-7b04ad1d]{color:#1e40af;background-color:#dbeafe}.btn-edit[data-v-7b04ad1d]:hover{background-color:#bfdbfe}.btn-secondary[data-v-7b04ad1d]{color:#374151;background-color:#e5e7eb}.btn-secondary[data-v-7b04ad1d]:hover{background-color:#d1d5db}.btn-primary[data-v-7b04ad1d]{color:#fff;background-color:#667eea}.btn-primary[data-v-7b04ad1d]:hover{background-color:#5568d3}.edit-form[data-v-7b04ad1d]{flex-direction:column;gap:1rem;padding:1rem 1.5rem 0;display:flex}.form-group[data-v-7b04ad1d]{flex-direction:column;gap:.5rem;display:flex}.form-group label[data-v-7b04ad1d]{color:#6b7280;font-size:.875rem;font-weight:500}.form-group input[data-v-7b04ad1d]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-family:inherit;font-size:.875rem}.form-group input[data-v-7b04ad1d]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.rehearsal-date[data-v-7b04ad1d]{color:#6b7280;margin:0;font-size:.875rem}.rehearsal-meta[data-v-7b04ad1d]{color:#6b7280;margin:.25rem 0 0;font-size:.875rem}.songs-section[data-v-7b04ad1d],.add-song-section[data-v-7b04ad1d]{border-bottom:1px solid #e5e7eb;padding:1.5rem}.songs-section h3[data-v-7b04ad1d],.add-song-section h3[data-v-7b04ad1d]{color:#1f2937;margin:0 0 1rem;font-size:1rem}.error-message[data-v-7b04ad1d]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.empty-songs[data-v-7b04ad1d]{text-align:center;color:#9ca3af;padding:1rem}.songs-list[data-v-7b04ad1d]{flex-direction:column;gap:.5rem;display:flex}.song-item[data-v-7b04ad1d]{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem;display:flex}.song-info[data-v-7b04ad1d]{flex:1;align-items:center;gap:.75rem;display:flex}.song-order[data-v-7b04ad1d]{color:#667eea;min-width:1.5rem;font-weight:600}.song-title[data-v-7b04ad1d]{color:#1f2937}.song-practice[data-v-7b04ad1d]{color:#6b7280;font-size:.85rem}.song-actions[data-v-7b04ad1d]{align-items:center;gap:.5rem;display:flex}.practice-input[data-v-7b04ad1d]{border:1px solid #d1d5db;border-radius:.375rem;width:110px;padding:.35rem .5rem;font-size:.85rem}.practice-input[data-v-7b04ad1d]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 2px #667eea26}.btn-save[data-v-7b04ad1d]{cursor:pointer;color:#3730a3;background-color:#e0e7ff;border:none;border-radius:.375rem;padding:.35rem .6rem;font-size:.8rem;font-weight:500;transition:background-color .2s}.btn-save[data-v-7b04ad1d]:hover:not(:disabled){background-color:#c7d2fe}.btn-save[data-v-7b04ad1d]:disabled{opacity:.6;cursor:not-allowed}.btn-remove[data-v-7b04ad1d]{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:1rem;transition:color .2s}.btn-remove[data-v-7b04ad1d]:hover{color:#dc2626}.add-song-form[data-v-7b04ad1d]{gap:.5rem;margin-bottom:.5rem;display:flex}.add-song-form select[data-v-7b04ad1d]{border:1px solid #d1d5db;border-radius:.375rem;flex:1;padding:.5rem;font-family:inherit;font-size:.875rem}.add-song-form input[data-v-7b04ad1d]{border:1px solid #d1d5db;border-radius:.375rem;width:170px;padding:.5rem;font-family:inherit;font-size:.875rem}.add-song-form select[data-v-7b04ad1d]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.add-song-form select[data-v-7b04ad1d]:disabled{cursor:not-allowed;background-color:#f3f4f6}.btn-add[data-v-7b04ad1d]{color:#fff;cursor:pointer;white-space:nowrap;background-color:#10b981;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:500;transition:background-color .2s}.btn-add[data-v-7b04ad1d]:hover:not(:disabled){background-color:#059669}.btn-add[data-v-7b04ad1d]:disabled{cursor:not-allowed;background-color:#d1d5db}.no-available-songs[data-v-7b04ad1d]{color:#9ca3af;margin:0;font-size:.875rem}.modal-overlay[data-v-9e9ea101]{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal[data-v-9e9ea101]{background-color:#fff;border-radius:.5rem;flex-direction:column;width:90%;max-width:500px;max-height:90vh;display:flex;box-shadow:0 10px 25px #0003}.modal-header[data-v-9e9ea101]{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2[data-v-9e9ea101]{color:#1f2937;margin:0;font-size:1.25rem}.close-btn[data-v-9e9ea101]{cursor:pointer;color:#6b7280;background:0 0;border:none;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1.5rem;display:flex}.close-btn[data-v-9e9ea101]:hover{color:#1f2937}.modal-form[data-v-9e9ea101]{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.form-group[data-v-9e9ea101]{flex-direction:column;gap:.5rem;display:flex}.form-group label[data-v-9e9ea101]{color:#374151;font-weight:500}.form-group input[data-v-9e9ea101]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-family:inherit;font-size:1rem}.form-group input[data-v-9e9ea101]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input[data-v-9e9ea101]:disabled{cursor:not-allowed;background-color:#f3f4f6}.error-message[data-v-9e9ea101]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;padding:.5rem;font-size:.875rem}.form-actions[data-v-9e9ea101]{gap:.5rem;margin-top:1rem;display:flex}.btn-primary[data-v-9e9ea101],.btn-secondary[data-v-9e9ea101]{cursor:pointer;border:none;border-radius:.375rem;flex:1;padding:.5rem 1rem;font-weight:500;transition:background-color .2s}.btn-primary[data-v-9e9ea101]{color:#fff;background-color:#667eea}.btn-primary[data-v-9e9ea101]:hover:not(:disabled){background-color:#5568d3}.btn-secondary[data-v-9e9ea101]{color:#374151;background-color:#e5e7eb}.btn-secondary[data-v-9e9ea101]:hover:not(:disabled){background-color:#d1d5db}.btn-primary[data-v-9e9ea101]:disabled,.btn-secondary[data-v-9e9ea101]:disabled{opacity:.6;cursor:not-allowed}.modal-overlay[data-v-6ec18b45]{z-index:50;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content[data-v-6ec18b45]{background-color:#fff;border-radius:.5rem;width:90%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a}.modal-header[data-v-6ec18b45]{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2[data-v-6ec18b45]{color:#1f2937;margin:0;font-size:1.25rem}.btn-close[data-v-6ec18b45]{color:#6b7280;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1.5rem;transition:color .2s;display:flex}.btn-close[data-v-6ec18b45]:hover{color:#1f2937}.modal-form[data-v-6ec18b45]{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.form-group[data-v-6ec18b45]{flex-direction:column;gap:.5rem;display:flex}.form-group label[data-v-6ec18b45]{color:#374151;font-size:.875rem;font-weight:500}.form-group input[data-v-6ec18b45]{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-family:inherit;font-size:.875rem}.form-group input[data-v-6ec18b45]:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input[data-v-6ec18b45]:disabled{cursor:not-allowed;background-color:#f3f4f6}.error-message[data-v-6ec18b45]{color:#dc2626;background-color:#fee2e2;border-radius:.375rem;padding:.75rem;font-size:.875rem}.modal-buttons[data-v-6ec18b45]{justify-content:flex-end;gap:.75rem;display:flex}.btn-cancel[data-v-6ec18b45],.btn-submit[data-v-6ec18b45]{cursor:pointer;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:500;transition:background-color .2s}.btn-cancel[data-v-6ec18b45]{color:#374151;background-color:#e5e7eb}.btn-cancel[data-v-6ec18b45]:hover:not(:disabled){background-color:#d1d5db}.btn-submit[data-v-6ec18b45]{color:#fff;background-color:#667eea}.btn-submit[data-v-6ec18b45]:hover:not(:disabled){background-color:#5568d3}.btn-cancel[data-v-6ec18b45]:disabled,.btn-submit[data-v-6ec18b45]:disabled{opacity:.5;cursor:not-allowed}.app-container[data-v-a072b627]{background-color:#fff;flex-direction:column;min-height:100vh;display:flex}.app-header[data-v-a072b627]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:space-between;align-items:center;padding:1rem;display:flex;box-shadow:0 2px 4px #0000001a}.app-header h1[data-v-a072b627]{margin:0;font-size:1.5rem;font-weight:700}.logout-button[data-v-a072b627]{color:#fff;cursor:pointer;background-color:#fff3;border:1px solid #fff6;border-radius:4px;padding:.5rem 1rem;font-size:.875rem;transition:background-color .2s}.logout-button[data-v-a072b627]:hover{background-color:#ffffff4d}.loading-container[data-v-a072b627]{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;display:flex}.loading-spinner[data-v-a072b627]{border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin-a072b627}@keyframes spin-a072b627{to{transform:rotate(360deg)}}.login-container[data-v-a072b627]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card[data-v-a072b627]{text-align:center;background:#fff;border-radius:12px;max-width:400px;padding:3rem;box-shadow:0 10px 40px #0003}.login-card h1[data-v-a072b627]{color:#333;margin:0 0 1rem;font-size:2rem}.login-card p[data-v-a072b627]{color:#666;margin:0 0 2rem;font-size:1rem}.login-button[data-v-a072b627]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;width:100%;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:transform .2s,box-shadow .2s}.login-button[data-v-a072b627]:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-button[data-v-a072b627]:active{transform:translateY(0)}.authenticated-container[data-v-a072b627]{flex-direction:column;min-height:100vh;display:flex}.app-main[data-v-a072b627]{flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-container[data-v-a072b627]{flex-direction:column;flex:1;display:flex}.page-header[data-v-a072b627]{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1rem}.page-header h2[data-v-a072b627]{margin:0;font-size:1.25rem}.bottom-nav[data-v-a072b627]{background-color:#f3f4f6;border-top:1px solid #e5e7eb;gap:0;padding:0;display:flex;box-shadow:0 -2px 4px #0000000d}.nav-item[data-v-a072b627]{cursor:pointer;color:#6b7280;background-color:#0000;border:none;flex-direction:column;flex:1;align-items:center;gap:.25rem;padding:1rem;font-size:.75rem;transition:all .2s;display:flex}.nav-item[data-v-a072b627]:hover:not(:disabled){background-color:#e5e7eb}.nav-item.active[data-v-a072b627]{color:#1e40af;background-color:#dbeafe}.nav-item[data-v-a072b627]:disabled{opacity:.5;cursor:not-allowed}.nav-icon[data-v-a072b627]{font-size:1.5rem}.nav-label[data-v-a072b627]{text-align:center;font-weight:500}.floating-action-btn[data-v-a072b627]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:2rem;transition:all .2s;display:flex;position:fixed;bottom:80px;right:20px;box-shadow:0 4px 12px #667eea66}.floating-action-btn[data-v-a072b627]:hover{transform:scale(1.1);box-shadow:0 6px 16px #667eea99}.floating-action-btn[data-v-a072b627]:active{transform:scale(.95)}
