.release-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.release-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;max-height:95vh;max-width:700px;overflow-y:auto;width:90%}.form-section{border-top:1px solid #e5e7eb;margin-top:1.5rem;padding-top:1rem}.section-toggle{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.5rem 0;text-align:left;transition:color .2s;width:100%}.section-toggle:hover{color:#2563eb}.section-title{color:#374151;font-size:1.1rem;margin:0 0 .5rem}.section-description{color:#6b7280;font-size:.9rem;line-height:1.4;margin:0 0 1.5rem}.checkbox-container{align-items:flex-start;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all .2s}.checkbox-container:hover{background:#3b82f605;border-color:#3b82f6}.form-checkbox{accent-color:#3b82f6;cursor:pointer;height:18px;margin:2px 0 0;width:18px}.checkbox-label{color:#374151;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.95rem;font-weight:500;gap:.25rem}.checkbox-label .field-hint{color:#6b7280;font-size:.85rem;font-weight:400;margin:0}.simple-form-group{margin-bottom:1rem!important}.simple-checkbox{align-items:flex-start;color:#374151;cursor:pointer;display:flex;font-size:.85rem;gap:.5rem}.simple-checkbox input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:16px;margin:1px 0 0;width:16px}.checkbox-text{flex:1 1}.checkbox-text .field-hint{color:#6b7280;display:block;font-size:.75rem;font-weight:400;margin-top:.25rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.release-modal-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem 2rem}.release-modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.release-modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;padding:.25rem;transition:all .2s;width:2rem}.release-modal-close:hover{background:#e5e7eb;color:#374151}.release-modal-body{padding:2rem}.form-group:last-child{margin-bottom:0}.form-group label{color:#374151;font-weight:600}.field-hint{color:#6b7280;display:block;font-size:.8rem;font-weight:400;margin-top:.25rem}.required-indicator{color:#dc2626;font-weight:600;margin-left:.25rem}.form-input,.form-textarea{border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:.9rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-input:focus,.form-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-textarea{min-height:100px;resize:vertical}.form-input.error,.form-textarea.error{border-color:#dc2626}.field-error{color:#dc2626;display:block;font-size:.8rem;margin-top:.25rem}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.release-modal-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.btn{min-width:100px;padding:.75rem 1.5rem}.btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-secondary:hover:not(:disabled){background:#f3f4f6}.btn-primary{background:#2563eb}.btn-primary:hover:not(:disabled){background:#1d4ed8}@media (max-width:640px){.release-modal{margin:1rem;width:95%}.release-modal-body,.release-modal-footer,.release-modal-header{padding:1rem}.release-modal-footer{flex-direction:column-reverse}.btn{width:100%}}.move-song-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.move-song-modal{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;max-height:85vh;max-width:800px;width:100%}.move-song-header{align-items:center;background:#fafafa;border-bottom:1px solid #eee;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.move-song-header h2{color:#333;font-size:1.25rem;font-weight:600;margin:0}.move-song-header .close-button{background:none;border:none;color:#999;cursor:pointer;font-size:1.75rem;line-height:1;padding:0}.move-song-header .close-button:hover{color:#333}.move-song-content{flex:1 1;overflow-y:auto;padding:1.25rem 1.5rem}.move-song-search-bar{margin-bottom:1rem;position:relative}.move-song-search-bar input{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:.95rem;padding:.75rem 2.5rem .75rem 1rem;width:100%}.move-song-search-bar input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff26;outline:none}.move-song-clear-search{background:#ddd;border:none;border-radius:50%;color:#666;cursor:pointer;font-size:14px;height:22px;line-height:1;position:absolute;right:10px;top:50%;transform:translateY(-50%);width:22px}.move-song-clear-search:hover{background:#ccc}.move-song-count{color:#666;font-size:.85rem;margin-bottom:.75rem}.move-song-empty,.move-song-loading{color:#666;padding:2.5rem 1rem;text-align:center}.move-song-error{background:#f8d7da;border-radius:6px;color:#721c24;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.move-song-table-container{border:1px solid #e1e5e9;border-radius:6px;max-height:350px;overflow-y:auto}.move-song-table{background:#fff;border-collapse:collapse;width:100%}.move-song-table thead{background:#f8f9fa;position:sticky;top:0;z-index:1}.move-song-table th{border-bottom:1px solid #e1e5e9;color:#666;font-size:.8rem;font-weight:600;padding:.75rem;text-align:left}.move-song-table tbody tr{cursor:pointer;transition:background-color .15s ease}.move-song-table tbody tr:hover{background:#f8f9fa}.move-song-table tbody tr.selected{background:#e3f2fd}.move-song-table tbody tr:not(:last-child) td{border-bottom:1px solid #f0f0f0}.move-song-table td{color:#333;font-size:.9rem;padding:.6rem .75rem;vertical-align:middle}.move-song-cover{border-radius:4px;display:block;height:40px;object-fit:cover;width:40px}.move-song-cover.placeholder{align-items:center;background:#f0f0f0;color:#999;display:flex;font-size:1rem;justify-content:center}.move-song-title-cell{color:#333;font-weight:500}.move-song-artist-cell{color:#555}.move-song-pack-cell{color:#888;font-size:.85rem}.move-song-check{color:#007bff;font-size:1.1rem;font-weight:700}.move-song-pagination{align-items:center;border-top:1px solid #eee;display:flex;gap:1rem;justify-content:center;margin-top:1rem;padding-top:.75rem}.move-song-pagination button{background:#fff;border:1px solid #ddd;border-radius:4px;color:#007bff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.move-song-pagination button:disabled{color:#ccc;cursor:not-allowed}.move-song-pagination button:not(:disabled):hover{background:#f0f0f0}.move-song-page-info{color:#666;font-size:.9rem}.move-song-confirmation{background:#f8f9fa;border:1px solid #eee;border-radius:6px;margin-top:1rem;padding:1rem}.move-song-confirmation p{color:#333;font-size:.95rem;margin:.3rem 0}.move-song-warning{color:#856404!important;font-size:.9rem!important}.move-song-footer{background:#fafafa;border-radius:0 0 8px 8px;border-top:1px solid #eee;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.move-song-cancel-btn,.move-song-submit-btn{border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;min-width:100px;padding:.6rem 1.5rem}.move-song-cancel-btn{background:#fff;border:1px solid #ddd;color:#666}.move-song-cancel-btn:hover{background:#f5f5f5;border-color:#ccc}.move-song-submit-btn{background:#007bff;border:1px solid #007bff;color:#fff}.move-song-submit-btn:disabled{cursor:not-allowed;opacity:.5}.move-song-submit-btn:not(:disabled):hover{background:#0056b3;border-color:#0056b3}@media (max-width:600px){.move-song-modal{max-height:95vh;max-width:95vw}.move-song-table-container{max-height:280px}.move-song-table td,.move-song-table th{font-size:.85rem;padding:.5rem}.move-song-cover{height:32px;width:32px}.move-song-pack-cell,.move-song-table th:nth-child(4){display:none}}.swap-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.swap-modal{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;max-height:85vh;max-width:500px;width:100%}.swap-modal-header{align-items:center;background:#fafafa;border-bottom:1px solid #eee;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:1rem 1.25rem}.swap-modal-header h2{color:#333;font-size:1.1rem;margin:0}.swap-close-btn{background:none;border:none;color:#999;cursor:pointer;font-size:1.5rem;line-height:1;padding:0}.swap-close-btn:hover{color:#333}.swap-modal-content{flex:1 1;overflow-y:auto;padding:1.25rem}.swap-empty-text,.swap-loading{color:#666;padding:2rem 0;text-align:center}.swap-error{background:#f8d7da;border-radius:4px;color:#721c24;font-size:.9rem;margin-bottom:1rem;padding:.6rem .75rem}.swap-steps{gap:0;margin-bottom:1.25rem}.swap-step,.swap-steps{align-items:center;display:flex;justify-content:center}.swap-step{background:#e0e0e0;border-radius:50%;color:#666;font-size:.8rem;font-weight:600;height:28px;width:28px}.swap-step.active{background:#007bff;color:#fff}.swap-step-line{background:#e0e0e0;height:3px;width:60px}.swap-step-line.active{background:#007bff}.swap-section-label{color:#666;font-size:.9rem;margin-bottom:.75rem}.swap-current-song-card{align-items:center;background:#f8f9fa;border:1px solid #eee;border-radius:8px;display:flex;gap:.75rem;margin-bottom:1rem;padding:.75rem}.swap-song-cover{border-radius:6px;flex-shrink:0;height:48px;object-fit:cover;width:48px}.swap-song-cover.placeholder{align-items:center;background:#e0e0e0;color:#999;display:flex;font-size:1.2rem;justify-content:center}.swap-song-info{display:flex;flex-direction:column;gap:.15rem}.swap-song-info strong{color:#333;font-size:.95rem}.swap-song-info span{color:#666;font-size:.85rem}.swap-destination-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.swap-destination-option{align-items:center;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;transition:all .15s}.swap-destination-option:hover{background:#f8f9fa;border-color:#007bff}.swap-destination-option.selected{background:#e3f2fd;border-color:#007bff}.swap-destination-option.danger:hover{border-color:#dc3545}.swap-destination-option.danger.selected{background:#f8d7da;border-color:#dc3545}.swap-option-icon{font-size:1.25rem}.swap-option-text{display:flex;flex:1 1;flex-direction:column;gap:.15rem}.swap-option-text strong{color:#333;font-size:.9rem}.swap-option-text span{color:#666;font-size:.8rem}.swap-check{color:#007bff;font-size:1rem;font-weight:700}.swap-destination-option.danger .swap-check{color:#dc3545}.swap-form-group{margin-bottom:1rem}.swap-form-group label{color:#555;display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem}.swap-form-group input,.swap-form-group select{background:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;color:#333;font-size:.9rem;padding:.6rem .75rem;width:100%}.swap-form-group input:focus,.swap-form-group select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff26;outline:none}.swap-delete-warning{background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:.9rem;padding:.75rem}.swap-mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.swap-mode-toggle button{background:#fff;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;flex:1 1;font-size:.9rem;padding:.65rem;transition:all .15s}.swap-mode-toggle button:hover{background:#f8f9fa}.swap-mode-toggle button.active{background:#007bff;border-color:#007bff;color:#fff}.swap-songs-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.swap-song-item{align-items:center;border:1px solid #eee;border-radius:6px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem;transition:all .15s}.swap-song-item:hover{background:#f8f9fa;border-color:#007bff}.swap-song-item.selected{background:#e3f2fd;border-color:#007bff}.swap-song-title{color:#333;font-size:.9rem;font-weight:600}.swap-song-artist{color:#666;font-size:.8rem}.swap-modal-footer{background:#fafafa;border-radius:0 0 8px 8px;border-top:1px solid #eee;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.25rem}.swap-back-btn{background:#fff;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:.9rem;margin-right:auto;padding:.5rem 1rem}.swap-back-btn:hover,.swap-cancel-btn{background:#f0f0f0}.swap-cancel-btn{border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.swap-cancel-btn:hover{background:#e0e0e0}.swap-continue-btn,.swap-submit-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1.25rem}.swap-continue-btn:disabled,.swap-submit-btn:disabled{cursor:not-allowed;opacity:.5}.swap-continue-btn:not(:disabled):hover,.swap-submit-btn:not(:disabled):hover{background:#0056b3}.swap-submit-btn.danger{background:#dc3545}.swap-submit-btn.danger:not(:disabled):hover{background:#c82333}.swap-modal.large{max-width:700px}.swap-new-song-form{margin-top:.5rem}.community-event-banner{background:#fff;border:1px solid #ddd;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin-bottom:1.5rem;overflow:hidden}.community-event-banner.expanded{box-shadow:0 4px 12px #00000014}.event-banner-header{align-items:center;background:#fafafa;cursor:pointer;display:flex;justify-content:space-between;padding:1rem 1.25rem;transition:background .2s ease}.event-banner-header:hover{background:#f0f0f0}.event-banner-title-section{align-items:center;display:flex;gap:.75rem}.event-icon{font-size:1.5rem}.event-theme{color:#333;font-size:1.1rem;font-weight:600;margin:0}.event-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.7rem;font-weight:600;gap:.35rem;padding:.25rem .6rem;text-transform:uppercase}.event-status-badge.active{background:#d4edda;color:#155724}.event-status-badge.ended{background:#fff3cd;color:#856404}.event-banner-stats{align-items:center;display:flex;gap:1.25rem}.event-stat{align-items:center;color:#666;display:flex;font-size:.85rem;gap:.4rem}.event-stat-value{color:#333;font-weight:600}.expand-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#007bff;cursor:pointer;display:flex;font-size:.85rem;gap:.4rem;padding:.4rem .8rem;transition:background .2s ease}.expand-toggle:hover{background:#e3f2fd}.expand-toggle svg{transition:transform .3s ease}.expand-toggle.expanded svg{transform:rotate(180deg)}.event-banner-content{background:#fff;border-top:1px solid #eee;padding:1.25rem}.event-banner-image{aspect-ratio:1100/310;border-radius:6px;margin-bottom:1rem;object-fit:cover;object-position:center;width:100%}.event-description{color:#555;line-height:1.6;margin-bottom:1rem}.event-deadline{align-items:center;background:#fff3cd;border-radius:4px;color:#856404;display:flex;font-size:.85rem;font-weight:500;gap:.5rem;margin-bottom:1rem;padding:.5rem .75rem;width:fit-content}.event-stage-content{background:#f8f9fa;border:1px solid #eee;border-radius:6px;padding:1.25rem}.stage-not-registered{text-align:center}.stage-not-registered h3{color:#333;margin-bottom:.5rem}.stage-not-registered p{color:#666;margin-bottom:1.25rem}.register-button{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.75rem;transition:all .2s ease}.register-button:hover{background:#0056b3}.stage-registered{text-align:center}.registered-badge{align-items:center;background:#d4edda;border-radius:6px;color:#155724;display:inline-flex;font-weight:600;gap:.5rem;margin-bottom:1.25rem;padding:.5rem 1rem}.add-song-section{margin-top:1rem}.add-song-section h4{color:#333;margin-bottom:1rem}.add-song-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.add-song-button{align-items:center;background:#fff;border:1px solid #007bff;border-radius:6px;color:#007bff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.65rem 1.25rem;transition:all .2s ease}.add-song-button:hover{background:#007bff;color:#fff}.unregister-link{color:#999;cursor:pointer;display:inline-block;font-size:.85rem;margin-top:1rem;transition:color .2s ease}.unregister-link:hover{color:#dc3545}.stage-in-progress,.workflow-complete-banner{display:flex;flex-direction:column;gap:1rem}.workflow-complete-banner{align-items:center;animation:slideIn .3s ease-out;background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #28a745;border-radius:12px;padding:1.25rem;text-align:center}.workflow-complete-banner .complete-message{color:#155724;font-size:1.1rem;font-weight:600}.continue-to-submit-button{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;box-shadow:0 4px 12px #28a7454d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s ease}.continue-to-submit-button:hover{box-shadow:0 6px 16px #28a74566;transform:translateY(-2px)}.continue-to-submit-button:active{transform:translateY(0)}.event-song-card-wrapper{background:#fff;border-radius:8px}.event-song-card-wrapper>div{margin:0!important}.community-event-banner .event-song-info{align-items:center;display:flex;gap:.75rem}.community-event-banner .event-song-thumbnail{background:#eee;border-radius:4px;height:50px;object-fit:cover;width:50px}.community-event-banner .event-song-details h4{color:#333;font-size:.95rem;margin:0 0 .15rem}.community-event-banner .event-song-details p{color:#666;font-size:.85rem;margin:0}.community-event-banner .stage-actions{display:flex;gap:.5rem}.community-event-banner .action-button{align-items:center;background:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;display:inline-flex;font-size:.8rem;gap:.4rem;padding:.4rem .75rem;transition:all .2s ease}.community-event-banner .action-button:hover{background:#e0e0e0}.community-event-banner .action-button.danger{border-color:#dc3545;color:#dc3545}.community-event-banner .action-button.danger:hover{background:#dc3545;color:#fff}.stage-completed{text-align:center}.stage-subtitle{color:#666;margin-bottom:1rem}.rv-release-notice{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem;text-align:left}.completed-song-info{background:#f8f9fa;border-radius:6px;color:#333;margin-bottom:1rem;padding:.5rem 1rem}.stage-completed-actions{border-top:1px solid #eee;margin-top:1.5rem;padding-top:1rem}.stage-completed-actions .actions-label{color:#888;font-size:.85rem;margin-bottom:.75rem}.stage-completed-actions .action-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.stage-completed-actions .action-button{background:#fff;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;font-size:.85rem;padding:.4rem .75rem;transition:all .15s}.stage-completed-actions .action-button:hover{background:#f0f0f0}.stage-completed-actions .action-button.secondary{background:#e3f2fd;border-color:#90caf9;color:#1565c0}.stage-completed-actions .action-button.secondary:hover{background:#bbdefb}.stage-completed-actions .action-button.danger{border-color:#f5c6cb;color:#dc3545}.stage-completed-actions .action-button.danger:hover{background:#f8d7da}.completion-message{align-items:center;color:#155724;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-bottom:.75rem}.community-event-banner .submission-form{margin:0 auto;max-width:450px}.community-event-banner .form-group{margin-bottom:.75rem;text-align:left}.community-event-banner .form-group label{color:#555;display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem}.community-event-banner .form-group label.required:after{color:#dc3545;content:" *"}.community-event-banner .form-group input,.community-event-banner .form-group textarea{background:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;color:#333;font-size:.9rem;padding:.6rem .75rem;width:100%}.community-event-banner .form-group input:focus,.community-event-banner .form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff26;outline:none}.community-event-banner .submit-button{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:.5rem 1.25rem;transition:all .2s ease;width:auto}.community-event-banner .submit-button:disabled{cursor:not-allowed;opacity:.5}.community-event-banner .submit-button:not(:disabled):hover{background:#218838}.stage-submitted{text-align:center}.submitted-badge{background:#d4edda;border-radius:6px;color:#155724;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.6rem 1.25rem}.submitted-badge,.submitted-song-card{align-items:center;margin-bottom:1.25rem}.submitted-song-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:1rem;padding:1rem;text-align:left}.submitted-song-cover{border-radius:6px;flex-shrink:0;height:80px;object-fit:cover;width:80px}.submitted-song-cover.placeholder{align-items:center;background:#f0f0f0;display:flex;font-size:2rem;justify-content:center}.submitted-song-details h4{color:#333;font-size:1.1rem;margin:0 0 .25rem}.submitted-song-details p{color:#666;font-size:.95rem;margin:0}.submitted-song-details .album-name{color:#888;font-size:.85rem;font-style:italic}.submission-details{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1.25rem;padding:1rem;text-align:left}.submission-detail-row{border-bottom:1px solid #f0f0f0;display:flex;flex-direction:column;gap:.25rem;padding:.5rem 0}.submission-detail-row:last-child{border-bottom:none}.detail-label{color:#666;font-size:.8rem;font-weight:500}.detail-value{color:#333;font-size:.95rem}.detail-link{color:#007bff;font-size:.9rem;text-decoration:none;word-break:break-all}.detail-link:hover{text-decoration:underline}.detail-empty{color:#999;font-size:.9rem;font-style:italic}.edit-submission-button.primary{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;margin-bottom:1rem;padding:.65rem 1.5rem;transition:all .2s ease}.edit-submission-button.primary:hover{background:#0056b3}.community-event-banner .submission-preview{background:#fff;border:1px solid #eee;border-radius:6px;margin-bottom:1rem;padding:1rem;text-align:left}.community-event-banner .submission-preview p{color:#555;font-size:.9rem;margin:.4rem 0}.community-event-banner .submission-preview a{color:#007bff;text-decoration:none}.community-event-banner .submission-preview a:hover{text-decoration:underline}.community-event-banner .edit-submission-button{align-items:center;background:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;display:inline-flex;font-size:.85rem;gap:.4rem;padding:.4rem .75rem;transition:all .2s ease}.community-event-banner .edit-submission-button:hover{background:#e0e0e0}.community-event-banner .form-actions{display:flex;gap:1rem;justify-content:center;margin-top:.75rem}.event-error-message{background:#dc35451a;border-radius:4px;color:#dc3545;margin-bottom:1rem;padding:.5rem}.inline-form-hint{color:#666;font-size:.8rem;margin:.5rem 0;text-align:left}.inline-add-song-form{background:#fff;border:1px solid #ddd;border-radius:6px;margin-top:1rem;padding:1rem}.inline-add-song-form h4{color:#333;font-size:.95rem;margin:0 0 .75rem}.inline-form-row{display:flex;gap:.75rem;margin-bottom:.75rem}.inline-form-row input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:.9rem;padding:.6rem .75rem}.inline-form-row input:focus{border-color:#007bff;outline:none}.inline-form-actions{display:flex;gap:.5rem;justify-content:flex-end}.inline-form-actions button{border-radius:4px;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s ease}.inline-form-actions .cancel-btn{background:#f0f0f0;border:1px solid #ddd;color:#666}.inline-form-actions .cancel-btn:hover{background:#e0e0e0}.inline-form-actions .submit-btn{background:#007bff;border:none;color:#fff}.inline-form-actions .submit-btn:hover{background:#0056b3}.inline-form-actions .submit-btn:disabled{cursor:not-allowed;opacity:.5}.event-participants{border-top:1px solid #eee;margin-top:1.25rem;padding-top:1rem}.event-participants h4{color:#666;font-size:.8rem;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.participants-list{display:flex;flex-wrap:wrap;gap:.4rem}.participant-badge{align-items:center;background:#f0f0f0;border-radius:999px;color:#555;display:inline-flex;font-size:.75rem;gap:.4rem;padding:.3rem .6rem}.participant-badge.has-song{background:#d4edda;color:#155724}.participant-badge.submitted{background:#d1ecf1;color:#0c5460}.community-event-banner .other-submissions-section{border-top:1px solid #e0e0e0;margin-top:1.5rem;padding-top:1rem}.community-event-banner .other-submissions-toggle{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem;transition:color .2s}.community-event-banner .other-submissions-toggle:hover{color:#333}.community-event-banner .toggle-icon{color:#888;font-size:.75rem}.community-event-banner .toggle-text{font-weight:500}.community-event-banner .other-submissions-content{background:#f9f9f9;border-radius:6px;margin-top:.75rem;padding:.75rem}.community-event-banner .submissions-empty,.community-event-banner .submissions-error,.community-event-banner .submissions-loading{color:#666;font-size:.9rem;padding:1rem;text-align:center}.community-event-banner .submissions-error{color:#d32f2f}.community-event-banner .submissions-list{display:flex;flex-direction:column;gap:.5rem}.community-event-banner .submission-item{align-items:center;background:#fff;border:1px solid #e8e8e8;border-radius:4px;display:flex;gap:.75rem;padding:.5rem .75rem}.community-event-banner .submission-album-cover{border-radius:4px;flex-shrink:0;height:40px;object-fit:cover;width:40px}.community-event-banner .submission-album-cover.placeholder{align-items:center;background:linear-gradient(135deg,#e8e8e8,#d0d0d0);display:flex;font-size:1.2rem;justify-content:center}.community-event-banner .submission-info{align-items:baseline;display:flex;flex:1 1;flex-wrap:wrap;gap:.25rem .5rem}.community-event-banner .submission-title{color:#333;font-weight:600}.community-event-banner .submission-artist{color:#666;font-size:.9rem}.community-event-banner .submission-user{color:#888;font-size:.85rem;font-style:italic}.community-event-banner .submission-status-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.2rem .5rem;text-transform:uppercase}.community-event-banner .submission-status-badge.wip{background:#fff3e0;color:#e65100}.community-event-banner .submission-status-badge.done{background:#e8f5e9;color:#2e7d32}.community-event-banner .submission-status-badge.ready{background:#e3f2fd;color:#1565c0}.community-event-banner .submission-status-badge.planning{background:#f3e5f5;color:#7b1fa2}.community-event-banner .submission-item.current-user{background:#e3f2fd;border:1px solid #90caf9}.community-event-banner .submission-item.registered-only{opacity:.8}.community-event-banner .submission-title.no-song{color:#999;font-style:italic}.community-event-banner .submission-link{background:#e3f2fd;border-radius:4px;color:#1565c0;font-size:.8rem;padding:.25rem .5rem;text-decoration:none;transition:background .2s}.community-event-banner .submission-link:hover{background:#bbdefb}@media (max-width:768px){.event-banner-header{align-items:flex-start;flex-direction:column;gap:.75rem}.event-banner-stats{justify-content:space-between;width:100%}.stage-in-progress{align-items:flex-start}.add-song-buttons,.stage-in-progress{flex-direction:column}.add-song-button{justify-content:center;width:100%}.inline-form-row{flex-direction:column}.community-event-banner .submission-item{flex-wrap:wrap}.community-event-banner .submission-info{width:100%}}.hero-section{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #0000001a;padding:2rem;text-align:center}.hero-content{margin:0 auto;max-width:600px}.hero-title{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px #0003}.brand-highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.hero-subtitle{color:#ffffffe6;font-size:1.1rem;font-weight:300;margin-bottom:1.5rem}.hero-games{margin-bottom:2rem}.games-label{color:#fffc;font-size:.9rem;font-weight:500;margin-bottom:1rem}.game-logos{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.game-logo{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:28px;opacity:.8;transition:opacity .3s ease;width:auto}.game-logo:hover{opacity:1}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-button{font-size:1.1rem;padding:1rem 2rem;text-decoration:none;transition:all .3s}.cta-button.primary{background:linear-gradient(135deg,gold,#ff8c00);color:#333}.cta-button.primary:hover{box-shadow:0 8px 25px #ffd7004d;transform:translateY(-2px)}.cta-button.secondary{background:#0000;border:2px solid #fff;color:#fff}.cta-button.secondary:hover{background:#fff;color:#333;transform:translateY(-2px)}@media (max-width:768px){.hero-section{padding:1.5rem 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.game-logos{gap:1rem}.game-logo{height:24px}}.community-leaderboard{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:1.5rem}.sidebar-area .community-leaderboard{padding:1rem}.sidebar-area .leaderboard-item{gap:.75rem;padding:.5rem .75rem}.sidebar-area .rank{font-size:.9rem;min-width:1.5rem}.sidebar-area .username{font-size:.9rem}.sidebar-area .points{font-size:.8rem}.sidebar-area .join-community-btn{font-size:.9rem;padding:.5rem 1rem}.leaderboard-list{display:flex;flex-direction:column;gap:.5rem}.leaderboard-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:1rem;padding:.75rem 1rem;transition:all .2s ease}.leaderboard-item:hover{background:#e9ecef;transform:translateY(-1px)}.leaderboard-item.top-three{background:linear-gradient(135deg,#ffd7001a,#ff8c001a);border:1px solid #ffd7004d}.leaderboard-item.top-three:hover{background:linear-gradient(135deg,#ffd70033,#ff8c0033)}.leaderboard-item.current-user{background:linear-gradient(135deg,#667eea26,#764ba226)!important;border-left:3px solid #667eea!important;box-shadow:0 2px 6px #667eea33;font-weight:600}.leaderboard-item.current-user.top-three{background:linear-gradient(135deg,#667eea33,#764ba233)!important;border-left:3px solid #667eea!important}.leaderboard-item.current-user:hover{background:linear-gradient(135deg,#667eea40,#764ba240)!important;box-shadow:0 3px 10px #667eea4d}.leaderboard-item.current-user .current-user-name{color:#667eea!important;font-weight:700}.leaderboard-item.current-user .current-user-name:before{content:"👤 ";margin-right:4px}.rank{font-size:1.1rem;font-weight:700;min-width:2rem;text-align:center}.username{color:#333;flex:1 1;font-weight:600}.username.clickable{cursor:pointer;transition:color .2s ease}.username.clickable:hover{color:#667eea;text-decoration:underline}.points{color:#ff8c00;font-size:.9rem;font-weight:700}.section-footer{margin-top:1.5rem;padding-top:1.5rem}.join-community-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.join-community-btn:hover{box-shadow:0 4px 15px #667eea4d;transform:translateY(-2px)}.view-full-leaderboard-btn{background:#0000;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;width:100%}.view-full-leaderboard-btn:hover{background:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff;transform:translateY(-1px)}.sidebar-area .view-full-leaderboard-btn{font-size:.85rem;padding:.4rem .8rem}@media (max-width:768px){.community-leaderboard{padding:1.5rem}.section-title{font-size:1.5rem}.leaderboard-item{gap:.75rem;padding:.5rem .75rem}.rank{font-size:1rem;min-width:1.5rem}.username{font-size:.9rem}.points{font-size:.8rem}}.latest-updates{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:12px;box-shadow:0 4px 16px #0000000d;max-width:100%;padding:.75rem}.latest-updates.compact{max-height:200px;overflow:hidden;transition:max-height .3s ease-out}.latest-updates.compact.content-expanded,.latest-updates.expanded{max-height:none;overflow:visible}.updates-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.toggle-view-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background .2s}.toggle-view-btn:hover{background:#0056b3}.updates-list{display:flex;flex-direction:column;gap:1rem}.update-item{background:#fafafa;border:1px solid #eee;border-radius:8px;padding:.6rem;transition:all .2s ease}.update-item:hover{background:#f5f5f5;border-color:#ddd;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.update-header{flex-wrap:wrap;gap:.5rem;margin-bottom:.4rem}.update-header,.update-meta{align-items:center;display:flex}.update-meta{gap:.75rem}.next-update-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.25rem .5rem;transition:background .2s}.next-update-btn:hover{background:#1e7e34}.compact-updates{max-width:100%}.compact-updates .update-item{margin-bottom:0;min-height:auto;padding:.75rem}.compact-updates .update-item.compact{padding:.6rem}.compact-updates .update-item.compact .update-header{margin-bottom:.5rem}.compact-updates .update-item.compact .update-content{word-wrap:break-word;font-size:.9rem;line-height:1.4;margin:0 0 .5rem;white-space:pre-wrap}.compact-updates .update-item.compact .update-content.truncated{-webkit-line-clamp:3;-webkit-box-orient:vertical;word-wrap:break-word;display:-webkit-box;overflow:hidden;text-overflow:ellipsis;white-space:normal}.compact-updates .update-item.compact .update-footer{margin:0}.update-icon{flex-shrink:0;font-size:1.2rem}.update-title{color:#333;flex:1 1;font-size:1rem;font-weight:600;margin:0;min-width:200px}.update-date{color:#666;flex-shrink:0;font-size:.8rem}.update-content{word-wrap:break-word;color:#555;font-size:.85rem;line-height:1.4;margin:0 0 .4rem;white-space:pre-wrap}.update-content.truncated{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden;text-overflow:ellipsis;white-space:normal}.update-footer{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between}.update-author{color:#666;font-size:.8rem;font-style:italic}.update-type-badge{border-radius:12px;font-size:.8rem;font-weight:500;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.update-type-badge[data-type=announcement]{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1976d2}.update-type-badge[data-type=feature]{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);color:#388e3c}.update-type-badge[data-type=update]{background:linear-gradient(135deg,#fff3e0,#ffcc80);color:#f57c00}.update-type-badge[data-type=bugfix]{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#d32f2f}.expand-toggle-btn{background:#0000;border:none;color:#007bff;cursor:pointer;font-size:.85rem;margin:.25rem 0 .5rem;padding:.25rem 0;text-decoration:underline;transition:color .2s}.expand-toggle-btn:hover{color:#0056b3}@media (max-width:768px){.latest-updates{padding:1.5rem}.section-title{font-size:1.5rem}.update-item{padding:1rem}.update-header{align-items:flex-start;flex-direction:column;gap:.5rem}.update-title{font-size:1.1rem;min-width:0;min-width:auto}.update-footer{align-items:flex-start;flex-direction:column;gap:.5rem}.update-type-badge{align-self:flex-start}}.latest-releases{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;box-sizing:border-box;max-width:100%;overflow:hidden;padding:1.5rem;width:100%}.youtube-embed{margin-top:1.5rem}.youtube-wrapper{box-shadow:0 8px 32px #0000004d}.youtube-wrapper,.youtube-wrapper iframe{border-radius:12px}.releases-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.header-left{display:flex;flex-direction:column;gap:.25rem}.header-right{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:.75rem}.release-count{color:#6c757d;font-size:.8rem;font-weight:400}.section-title{font-size:1.5rem;line-height:1.2}.rhythmverse-link{background:#6c757d;border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.rhythmverse-link:hover{background:#5a6268;color:#fff}.releases-list{display:flex;flex-direction:column;gap:1rem}.pack-release{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 1px 3px #00000014;box-sizing:border-box;margin-bottom:1.25rem;max-width:100%;overflow:hidden;padding:1.25rem;transition:all .2s ease;width:100%}.pack-release:hover{border-color:#e0e0e0;box-shadow:0 1px 3px #00000014}.pack-header{align-items:flex-start;gap:1rem;margin-bottom:1rem;width:100%}.pack-header,.pack-info{background:#0000!important;max-width:100%;overflow:hidden}.pack-info{flex:1 1;min-width:0}.pack-title-section{background-color:initial!important;border:none!important;box-shadow:none!important;margin-bottom:.5rem;padding:0!important}.pack-header .pack-info .pack-title-section .pack-name,.pack-info .pack-title-section .pack-name,.pack-title-section .pack-name,.pack-title-section h3.pack-name{word-wrap:break-word;background:#0000!important;background-color:initial!important;border:none!important;box-shadow:none!important;color:#1a1a1a!important;font-size:1.6rem!important;font-weight:700!important;-webkit-hyphens:auto;hyphens:auto;letter-spacing:-.01em;line-height:1.3!important;margin:0 0 .75rem!important;overflow-wrap:break-word;padding:0!important}.pack-credits{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem;width:100%}.pack-artist{word-wrap:break-word;font-size:.9rem;max-width:100%;overflow-wrap:break-word}.pack-author-highlight{background:#f0f0f0;border-radius:4px;color:#555;flex-shrink:0;font-size:.8rem;font-weight:500;padding:.25rem .6rem;white-space:nowrap}.pack-meta{color:#888;font-size:.85rem;gap:1rem;margin-top:.25rem}.song-count{color:#666}.release-date{color:#888}.pack-songs{gap:.25rem}.song-item{border-radius:4px;padding:.4rem .5rem;transition:background .15s ease}.song-number{min-width:18px}.pack-cover{align-items:center;background:#f0f0f0;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-shrink:0;height:120px;justify-content:center;max-width:120px;min-width:120px;width:120px}.cover-image{display:block}.cover-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.music-icon{color:#fff;font-size:1.5rem}.release-info{flex:1 1;min-width:0}.release-title{color:#333;font-size:1rem;font-weight:600}.release-artist,.release-title{margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.release-artist{color:#666;font-size:.9rem;font-weight:500}.release-album{color:#888;font-size:.8rem;font-style:italic;margin:0 0 .5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.release-pack{margin-bottom:.5rem}.pack-label{color:#999;font-size:.75rem;margin-right:.5rem}.pack-name{background:#007bff1a;border-radius:4px;color:#007bff;font-weight:500;padding:.2rem .5rem}.release-author{color:#666;font-weight:500}.release-genre{border-radius:12px;color:#fff;display:inline-block;font-size:.7rem;font-weight:500;letter-spacing:.5px;margin-bottom:.5rem;padding:.2rem .6rem;text-transform:uppercase}.release-meta{align-items:center;color:#999;display:flex;font-size:.8rem;gap:1rem;margin-top:.5rem}.release-date,.release-duration{white-space:nowrap}.release-actions{flex-shrink:0}.play-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.play-button:hover{box-shadow:0 4px 15px #667eea4d;transform:scale(1.1)}.empty-icon{font-size:3rem;opacity:.5}.empty-state h3{font-weight:600;margin:1rem 0 .5rem}.empty-state p{line-height:1.5}.explore-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.explore-button:hover{box-shadow:0 4px 15px #667eea4d;transform:translateY(-2px)}.explore-button.primary{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.explore-button.primary:hover{background:linear-gradient(135deg,#0056b3,#004085);color:#fff}.explore-button.secondary{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff}.explore-button.secondary:hover{background:linear-gradient(135deg,#5a6268,#495057);color:#fff}.empty-state-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem}.error-state{color:#dc3545;padding:2rem}.retry-button{margin-top:1rem;transition:background .2s}.section-footer{margin-top:1rem;padding-top:1rem}.explore-music-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.explore-music-btn:hover{box-shadow:0 4px 15px #667eea4d;transform:translateY(-2px)}@media (max-width:768px){.latest-releases{padding:1.5rem}.section-title{font-size:1.5rem}.releases-header{align-items:flex-start;flex-direction:column;gap:1rem}.pack-release{padding:1rem}.pack-header{gap:1rem}.pack-cover{height:80px;width:80px}.pack-name{font-size:1.1rem}.pack-credits{align-items:flex-start;flex-direction:column;gap:.5rem}.pack-author-highlight{font-size:.8rem;padding:.3rem .8rem}.pack-songs{gap:.25rem;grid-template-columns:1fr}.song-item{padding:.4rem}.music-icon{font-size:1.2rem}}.release-metadata{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-top:1rem;padding:.75rem}.release-description p{line-height:1.5}.release-actions{margin-top:.75rem}.release-action-btn{border-radius:4px;gap:.4rem}.release-action-btn:hover{opacity:.9}.download-btn{background:#28a745}.download-btn:hover{background:#218838}.youtube-btn{background:#dc3545}.youtube-btn:hover{background:#c82333}.btn-icon{font-size:.9rem}.download-link-icon{align-items:center;background:#28a7451a;border:1px solid #28a74533;border-radius:8px;color:#28a745;display:inline-flex;height:36px;justify-content:center;text-decoration:none;transition:all .2s ease;width:36px}.download-link-icon:hover{background:#28a74526;box-shadow:0 2px 6px #28a74533;color:#218838;transform:translateY(-1px)}.download-link-icon svg{height:20px;width:20px}.releases-navigation{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:12px;display:flex;gap:1rem;justify-content:center;margin:1.5rem 0;padding:1rem}.releases-navigation.round-robin{justify-content:space-between;padding:.75rem 1rem}.nav-btn{background:#fff;border:1px solid #ced4da}.nav-btn:hover:not(:disabled){background:#007bff;border-color:#007bff;color:#fff}.page-indicators{display:flex;gap:.5rem}.page-indicator{align-items:center;background:#fff;border:1px solid #ced4da;border-radius:50%;color:#495057;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;height:2.5rem;justify-content:center;transition:all .2s;width:2.5rem}.page-indicator:hover{background:#e9ecef;border-color:#adb5bd}.page-indicator.active{background:#007bff;border-color:#007bff;color:#fff}.release-indicators{align-items:center;display:flex;flex-direction:column;gap:.5rem}.current-release-info{color:#666;font-size:.85rem;font-weight:500}.release-dots{align-items:center;display:flex;gap:.5rem}.release-dot{background:#ced4da;border:none;border-radius:50%;cursor:pointer;height:10px;padding:0;transition:all .2s ease;width:10px}.release-dot:hover{background:#adb5bd;transform:scale(1.2)}.release-dot.active{background:#007bff;transform:scale(1.3)}.single-release-container{width:100%}.see-all-btn{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;text-decoration:none;transition:all .15s;white-space:nowrap}.see-all-btn:hover{background:#0056b3;color:#fff}@media (max-width:768px){.releases-header{flex-direction:column;gap:1rem}.header-right,.releases-header{align-items:stretch}.releases-navigation{flex-direction:column;gap:1rem}.releases-navigation.round-robin{flex-direction:row;gap:.5rem;justify-content:space-between}.nav-btn{font-size:.8rem;padding:.5rem .75rem}.nav-btn,.page-indicators{justify-content:center}.release-indicators{gap:.25rem}.current-release-info{font-size:.8rem}.release-dots{gap:.25rem}.release-dot{height:8px;width:8px}}.pack-cover-carousel{align-items:center;display:flex;gap:.5rem;position:relative}.cover-arrow{align-items:center;background:#ffffffe6;border:1px solid #e0e0e0;border-radius:50%;color:#333;cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;height:32px;justify-content:center;transition:all .2s ease;width:32px;z-index:2}.cover-arrow:hover{background:#007bff;border-color:#007bff;color:#fff;transform:scale(1.1)}.cover-arrow:active{transform:scale(.95)}.cover-indicators{bottom:-8px;display:flex;gap:.25rem;left:50%;position:absolute;transform:translateX(-50%);z-index:3}.cover-indicator{background:#0000004d;border:none;border-radius:50%;cursor:pointer;height:6px;padding:0;transition:all .2s ease;width:6px}.cover-indicator.active{background:#007bff;height:8px;width:8px}.release-description-section{background:#0000;border:none;border-radius:0;margin:1.5rem 0;padding:0}.release-description-text{word-wrap:break-word;font-size:.95rem;line-height:1.7;white-space:pre-wrap}.read-more-btn{background:#0000;color:#007bff;font-size:.95rem;font-weight:500;padding:.25rem .5rem;transition:color .2s ease}.read-more-btn:hover{color:#0056b3}.pack-songs-section{margin-top:1.5rem}.songs-section-title{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 .75rem}.pack-songs{background:#0000;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:.75rem 0}.song-item{background:#fff;padding:.6rem .75rem;transition:all .15s ease}.song-item:hover{background:#e9ecef}.song-number{color:#888;flex-shrink:0;font-size:.85rem;min-width:24px;text-align:right}.song-album-cover{border:1px solid #e0e0e0;height:48px;width:48px}.song-info{display:flex;flex-direction:column;gap:.25rem}.song-title{font-size:.95rem}.song-artist,.song-title{word-wrap:break-word;overflow-wrap:break-word}.song-artist{font-size:.85rem}.song-download-link-icon{align-items:center;background:#28a7451a;border:1px solid #28a74533;border-radius:6px;color:#28a745;display:inline-flex;flex-shrink:0;height:32px;justify-content:center;margin-left:auto;text-decoration:none;transition:all .2s ease;width:32px}.song-download-link-icon:hover{background:#28a74526;box-shadow:0 2px 4px #28a74533;color:#218838;transform:translateY(-1px)}.song-download-link-icon svg{height:18px;width:18px}.songs-pagination{background:#0000;border-radius:6px;padding:.75rem}.songs-nav-btn{border:1px solid #ced4da;color:#495057;font-weight:500;padding:.5rem .75rem;transition:all .2s}.songs-nav-btn:hover:not(:disabled){background:#007bff;border-color:#007bff}.songs-page-info{font-weight:500}.release-actions{gap:.75rem;margin-top:1rem}.release-action-btn{border:1px solid #0000;font-size:.9rem;gap:.5rem;padding:.6rem 1rem;transition:all .15s}.release-action-btn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.pack-cover-carousel .pack-cover{height:120px;max-width:120px;min-width:120px;position:relative;width:120px}@media (max-width:768px){.pack-title-section .pack-name{font-size:1.4rem!important}.pack-cover,.pack-cover-carousel .pack-cover{height:100px;max-width:100px;min-width:100px;width:100px}.cover-arrow{font-size:1.2rem;height:28px;width:28px}.release-description-section{padding:1rem}.release-description-text{font-size:.9rem}.song-album-cover{height:40px;width:40px}.songs-pagination{flex-direction:column;gap:.5rem}}.edit-release-btn{align-items:center;background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;gap:.25rem;margin-top:.5rem;padding:.375rem .75rem;transition:all .2s ease}.edit-release-btn:hover{background:#5a6fd8;transform:translateY(-1px)}.edit-release-btn:active{transform:translateY(0)}.latest-feature-requests{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:1rem}.feature-requests-widget{background:#0000;border-radius:0;box-shadow:none;overflow:visible}.feature-requests-list{padding:0}.feature-request-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:.75rem;padding:.75rem;transition:background-color .2s ease}.feature-request-item:last-child{border-bottom:none}.feature-request-item:hover{background-color:#f8f9fa}.request-header{align-items:center;gap:.5rem;margin-bottom:0}.status-icon{flex-shrink:0}.request-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#333;display:-webkit-box;font-size:.85rem;font-weight:600;line-height:1.2;margin:0;overflow:hidden;text-overflow:ellipsis}.latest-feature-requests .request-meta{color:#666;display:block;font-size:.75rem;margin:.25rem 0 0;text-align:left}.votes{font-weight:500}.latest-feature-requests .author{color:#888;display:inline-block;margin-right:.5rem}.latest-feature-requests .time{color:#999;display:inline-block}.request-content{flex:1 1;min-width:0;text-align:left}.voting-section{flex-shrink:0}.feature-request-item .voting-section button{font-size:1rem!important;padding:.125rem!important}.feature-request-item .voting-section>div{gap:.25rem!important;min-width:40px!important}.feature-request-item .voting-section>div>div{font-size:.9rem!important;min-width:20px!important}.empty-state,.login-prompt{color:#666;padding:2rem 1rem;text-align:center}.empty-icon,.login-icon{font-size:2rem;margin-bottom:.5rem}.empty-state h3,.login-prompt h3{color:#333;font-size:1.1rem;margin:.5rem 0}.empty-state p,.login-prompt p{color:#666;font-size:.9rem;margin:.5rem 0 1rem}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.login-btn:hover{box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}@media (max-width:768px){.latest-feature-requests .request-meta{align-items:flex-start;flex-direction:column;gap:.25rem;margin-left:0}.section-title{font-size:1.1rem}.feature-request-item{align-items:flex-start;flex-direction:column;gap:.75rem;padding:.75rem}.voting-section{align-self:center}}.tips-and-tricks{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:2rem}.sidebar-area .tips-and-tricks{padding:1rem}.sidebar-area .section-title{margin-bottom:1rem}.sidebar-area .tips-grid{gap:.75rem;grid-template-columns:1fr}.sidebar-area .tip-card{padding:1rem}.sidebar-area .tip-title{font-size:1rem}.sidebar-area .tip-summary{font-size:.85rem}.sidebar-area .join-button{font-size:.9rem;padding:.75rem 1.5rem}.section-title{color:#333;font-size:1.8rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.tip-display{display:flex;justify-content:center}.loading-tip{color:#666;padding:2rem;text-align:center}.tip-card{background:#f8f9fa;border:1px solid #eee;border-radius:12px;cursor:pointer;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.tip-card:hover{background:#f0f0f0;border-color:#ddd;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.tip-card.expanded{background:#fff;border-color:#667eea;box-shadow:0 8px 25px #667eea26}.tip-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1rem}.tip-icon{flex-shrink:0;font-size:2rem;margin-top:.25rem}.tip-title-section{flex:1 1;min-width:0}.tip-title{color:#333;font-size:1.1rem;font-weight:600;line-height:1.3;margin:0 0 .5rem}.tip-category{border-radius:12px;color:#fff;display:inline-block;font-size:.7rem;font-weight:500;letter-spacing:.5px;padding:.2rem .6rem;text-transform:uppercase}.next-tip-button{align-items:center;background:none;border:2px solid #ddd;border-radius:50%;color:#666;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:30px;justify-content:center;transition:all .2s ease;width:30px}.next-tip-button:hover{background:#667eea1a;border-color:#667eea;color:#667eea}.tip-summary{color:#555;font-size:.95rem;line-height:1.5;margin:0 0 1rem}.tip-link-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;margin-top:.5rem;padding:.5rem 1rem;transition:all .2s ease}.tip-link-button:hover{background:#0056b3;transform:translateY(-1px)}.tip-details{animation:fadeIn .3s ease;border-top:1px solid #eee;margin-top:1.5rem;padding-top:1.5rem}.tip-list{flex-direction:column;list-style:none;margin:0;padding:0}.tip-detail,.tip-list{display:flex;gap:.75rem}.tip-detail{align-items:flex-start;color:#666;font-size:.9rem;line-height:1.4}.bullet{color:#667eea;flex-shrink:0;font-size:1.2rem;font-weight:700;margin-top:-.1rem}.section-footer{border-top:1px solid #eee;margin-top:2rem;padding-top:2rem}.tips-note{text-align:center}.tips-note p{color:#666;font-size:1rem;line-height:1.5;margin:0 0 1rem}.join-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;overflow:hidden;padding:1rem 2rem;position:relative;transition:all .3s ease}.join-button:hover{box-shadow:0 8px 25px #667eea4d;transform:translateY(-2px)}.join-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.join-button:hover:before{left:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.tips-and-tricks{padding:1.5rem}.section-title{font-size:1.5rem}.tips-grid{gap:.75rem;grid-template-columns:1fr}.tip-card{padding:1rem}.tip-header{gap:.75rem}.tip-icon{font-size:1.5rem}.tip-title{font-size:1rem}.expand-button{font-size:1rem;height:25px;width:25px}.join-button{font-size:.9rem;padding:.75rem 1.5rem}}@media (max-width:480px){.tip-header{align-items:flex-start;flex-direction:column;gap:.5rem}.tip-title-section{width:100%}.expand-button{align-self:flex-end}}.login-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:0;padding:1.5rem}.login-container{width:100%}.login-header{margin-bottom:1rem;text-align:center}.login-header h2{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:#666;font-size:.9rem;margin:0}.login-form{margin-bottom:0}.form-group{margin-bottom:1rem}.form-group label{font-size:.9rem}.form-group input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.error-message{background:#fee;border:1px solid #fcc;margin-bottom:1rem}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1rem;padding:1rem;transition:all .3s ease;width:100%}.submit-button:hover:not(:disabled){box-shadow:0 4px 15px #667eea4d;transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.form-toggle{color:#666;font-size:.9rem;text-align:center}.form-toggle span{margin-right:.5rem}.toggle-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:600;text-decoration:underline}.toggle-button:hover{color:#764ba2}.forgot-password{margin-bottom:1rem;text-align:center}.forgot-password-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:.85rem;text-decoration:underline;transition:color .2s ease}.forgot-password-link:hover{color:#764ba2}.login-benefits{border-top:1px solid #eee;padding-top:1rem}.login-benefits h3{color:#333;font-size:1rem;font-weight:600;margin-bottom:1rem;text-align:center}.login-benefits ul{list-style:none;margin:0;padding:0}.login-benefits li{align-items:center;color:#555;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 0}@media (max-width:768px){.login-section{margin:0 1rem;padding:1.5rem}.login-header h2{font-size:1.3rem}.form-group input{padding:.6rem}.submit-button{padding:.8rem}}.quick-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:1.5rem}.stats-title{color:#333;font-size:1.3rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.stat-item{align-items:center;background:#f8f9fa;border:1px solid #eee;border-radius:12px;display:flex;gap:.75rem;padding:1rem;transition:all .2s ease}.stat-item:hover{background:#f0f0f0;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{flex-shrink:0;font-size:1.5rem}.stat-content{flex:1 1;min-width:0}.stat-value{font-size:1.4rem;margin-bottom:.25rem}.stat-label{color:#666;font-weight:500}.stats-grid.loading .stat-item{padding:1.2rem}.loading-item{justify-content:center}.loading-placeholder{animation:loading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:4px;height:40px;width:60px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.stats-error{color:#666;font-size:.9rem;padding:1rem;text-align:center}.sidebar-area .quick-stats{padding:1rem}.sidebar-area .stats-title{font-size:1.1rem;margin-bottom:1rem}.sidebar-area .stats-grid{gap:.5rem}.sidebar-area .stat-item{gap:.5rem;padding:.75rem}.sidebar-area .stat-icon{font-size:1.2rem}.sidebar-area .stat-value{font-size:1.1rem}.sidebar-area .stat-label{font-size:.7rem}@media (max-width:768px){.stats-grid{gap:.75rem;grid-template-columns:1fr}.stat-item{padding:.75rem}.stat-icon{font-size:1.3rem}.stat-value{font-size:1.2rem}}@media (max-width:480px){.stats-grid{gap:.5rem}.stat-item{gap:.5rem;padding:.6rem}}.user-dashboard{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;overflow:hidden}.dashboard-header{background:#fff;color:#333;padding:1rem 2rem}.header-content{justify-content:space-between}.header-actions{align-items:center;display:flex;gap:.5rem}.refresh-btn{padding:.5rem;transition:opacity .2s ease,transform .3s ease,background-color .2s}.refresh-btn:hover:not(:disabled){background-color:#0000000d}.collapse-toggle{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:1.2rem;padding:.5rem;transition:background-color .2s}.collapse-toggle:hover{background-color:#0000001a}.dashboard-header h2{font-size:1.3rem;font-weight:700;margin:0}.dashboard-header p{color:#333333b3;font-size:.95rem;margin:0}.suggestions-container{padding:1rem 2rem 1.5rem}.suggestions-list{grid-gap:.75rem;display:grid;gap:.75rem;grid-auto-rows:minmax(auto,1fr);grid-template-columns:1fr 1fr}.suggestion-item{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 1px 3px #0000000d;cursor:pointer;display:flex;gap:.75rem;min-height:90px;overflow:hidden;padding:.6rem;position:relative;transition:all .2s ease}.suggestion-item:hover{background-color:#f8f9fa;border-color:#dee2e6;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.suggestion-album-art{border-radius:6px;box-shadow:0 2px 4px #00000026;flex-shrink:0;height:48px;object-fit:cover;width:48px}.suggestion-content{display:flex;flex:1 1;flex-direction:column;justify-content:flex-start;min-width:0;overflow:hidden}.suggestion-main{display:flex;flex-direction:column;gap:.08rem}.suggestion-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#333;display:-webkit-box;font-size:.9rem;font-weight:600;line-height:1.2;margin:0;overflow:hidden;text-overflow:ellipsis}.suggestion-artist,.suggestion-stats{color:#666;font-size:.75rem;line-height:1.2;margin:0}.suggestion-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.15rem}.suggestion-tag{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:500;margin-bottom:0;margin-right:.25rem;padding:.2rem .4rem;white-space:nowrap}.suggestion-tag-event{animation:pulse-glow 2s ease-in-out infinite;background:linear-gradient(135deg,#ff6b6b,#ee5a24)}@keyframes pulse-glow{0%,to{box-shadow:0 0 4px #ff6b6b66}50%{box-shadow:0 0 8px #ff6b6bb3}}.suggestion-item-event{background:linear-gradient(90deg,#ff6b6b0d,#fff);border-left:3px solid #ff6b6b}.suggestion-item-event:hover{background:linear-gradient(90deg,#ff6b6b1a,#f8f9fa)}.suggestion-parts{color:#666;font-size:.72rem;line-height:1.2;margin:.12rem 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggestion-time{color:#999;font-size:.7rem;margin:0}.suggestion-progress{position:absolute;right:.5rem;top:.5rem}.progress-circle-small{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border-radius:50%;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;font-size:.7rem;font-weight:600;height:32px;justify-content:center;width:32px}.empty-state{padding:1.5rem;width:100%}.empty-state p{margin:0 0 1rem}.cta-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.cta-btn:hover{box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}.dashboard-loading{color:#666;padding:3rem;text-align:center}.dashboard-loading .loading-spinner{animation:spin 1s linear infinite;border:3px solid #f0f0f0;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 1rem;width:40px}.dashboard-error{color:#666;padding:2rem;text-align:center}.retry-btn{background:#667eea;margin-top:.5rem}.retry-btn:hover{background:#5a6fd8}@media (max-width:768px){.dashboard-header,.suggestions-container{padding:1rem 1.5rem}.suggestions-list{gap:.5rem;grid-template-columns:1fr}.suggestion-item{height:110px;padding:.5rem}.suggestion-album-art{height:32px;width:32px}.suggestion-title{font-size:.85rem}.suggestion-tag{font-size:.65rem;padding:.15rem .3rem}.progress-circle-small{font-size:.65rem;height:28px;width:28px}}@media (max-width:480px){.suggestions-list{grid-template-columns:1fr}.suggestion-item{height:100px}}.modal-backdrop{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.collaboration-modal{animation:modalSlideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.5rem 1rem}.modal-header h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#95a5a6;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.close-btn:hover:not(:disabled){background:#f8f9fa;color:#7f8c8d}.close-btn:disabled{cursor:not-allowed;opacity:.5}.song-info-section{margin-bottom:1.5rem;padding:0 1.5rem}.song-details{align-items:flex-start;gap:1rem}.song-thumbnail{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:80px;object-fit:cover;width:80px}.song-thumbnail.placeholder{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#bdc3c7;display:flex;font-size:2rem;justify-content:center}.song-text{flex:1 1}.song-text h3{color:#2c3e50;font-size:1.25rem;font-weight:600;line-height:1.2;margin:0 0 .25rem}.song-text .artist{color:#34495e;font-size:1rem;font-weight:500;margin:0 0 .25rem}.song-text .album{color:#7f8c8d;font-size:.9rem;margin:0 0 .5rem}.song-status{align-items:center;display:flex;font-size:.85rem;gap:.5rem}.status-icon{font-size:1rem}.status-text{color:#3498db;font-weight:500}.owner{color:#95a5a6}.modal-form{padding:0 1.5rem 1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#2c3e50;font-size:.95rem;margin-bottom:.5rem}.required{color:#e74c3c}.optional{color:#95a5a6;font-size:.85rem;font-weight:400}.message-textarea{border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:.95rem;line-height:1.5;min-height:100px;padding:.75rem;resize:vertical;transition:border-color .2s,box-shadow .2s;width:100%}.message-textarea:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.message-textarea:disabled{background:#f8f9fa;cursor:not-allowed;opacity:.7}.char-count{color:#95a5a6;font-size:.8rem;margin-top:.25rem;text-align:right}.parts-help{color:#7f8c8d;font-size:.9rem;margin:0 0 .75rem}.parts-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.part-checkbox{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem;transition:background .2s}.part-checkbox:hover{background:#f8f9fa}.part-checkbox input[type=checkbox]{margin:0}.part-label{color:#2c3e50;font-size:.9rem}.selected-parts{background:#e8f4fd;border:1px solid #bde0ff;border-radius:6px;color:#2980b9;font-size:.9rem;margin-top:.75rem;padding:.75rem}.loading-parts,.no-parts{background:#f8f9fa;border-radius:6px;color:#7f8c8d;font-size:.9rem;padding:1rem;text-align:center}.info-box{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.info-icon{flex-shrink:0;font-size:1.25rem}.info-box strong{color:#856404;display:block;margin-bottom:.25rem}.info-box p{color:#856404;font-size:.9rem;line-height:1.4;margin:0}.error-message{border-radius:6px;font-size:.9rem;gap:.5rem;padding:.75rem}.error-icon{flex-shrink:0;font-size:1rem}.modal-actions{border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.cancel-btn{background:#95a5a6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:background .2s}.cancel-btn:hover:not(:disabled){background:#7f8c8d}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;min-width:120px;padding:.75rem 1.5rem;transition:all .2s}.submit-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.submit-btn:disabled{box-shadow:none;transform:none}.cancel-btn:disabled,.submit-btn:disabled{background:#bdc3c7;cursor:not-allowed}.batch-modal{display:flex;flex-direction:column;max-width:700px;overflow:hidden}.batch-modal .modal-form,.batch-modal .modal-header{flex-shrink:0}.batch-target-info{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:.5rem;padding:0 1.5rem 1rem}.target-label{color:#7f8c8d;font-size:.9rem}.target-username{color:#667eea;cursor:pointer;font-size:1rem;font-weight:600;transition:opacity .2s}.target-username:hover{opacity:.8}.target-display-name{color:#95a5a6;font-size:.9rem}.batch-songs-section{display:flex;flex-direction:column;flex-shrink:1;min-height:0;overflow:hidden;padding:0 1.5rem 1rem}.batch-songs-header{flex-shrink:0;margin-bottom:.75rem}.songs-count{color:#2c3e50;font-size:.95rem;font-weight:600}.batch-songs-list{background:#f8f9fa;border:1px solid #eee;border-radius:8px;flex-shrink:1;max-height:200px}.pack-group{border-bottom:1px solid #eee}.pack-group:last-child{border-bottom:none}.pack-header{align-items:center;background:#e9ecef;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1rem}.pack-icon{font-size:1rem}.pack-name{color:#2c3e50;font-weight:600}.pack-count{color:#6c757d;font-size:.8rem}.pack-songs{padding:.5rem}.batch-song-item{align-items:center;border-radius:6px;display:flex;gap:.75rem;padding:.5rem;transition:background .2s}.batch-song-item:hover{background:#fff}.batch-song-item .song-cover{align-items:center;background:#e9ecef;border-radius:4px;display:flex;flex-shrink:0;height:36px;justify-content:center;overflow:hidden;width:36px}.batch-song-item .song-cover img{height:100%;object-fit:cover;width:100%}.batch-song-item .cover-placeholder{color:#adb5bd;font-size:1rem}.batch-song-item .song-info{flex:1 1;min-width:0}.batch-song-item .song-title{color:#2c3e50;font-size:.875rem;font-weight:500}.batch-song-item .song-artist,.batch-song-item .song-title{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-song-item .song-artist{color:#6c757d;font-size:.8rem}.batch-song-item .song-status{border-radius:4px;flex-shrink:0;font-size:.75rem;padding:.25rem .5rem;white-space:nowrap}.batch-song-item .song-status.status-future-plans{background:#e3f2fd;color:#1976d2}.batch-song-item .song-status.status-in-progress{background:#fff3e0;color:#f57c00}@media (max-width:768px){.modal-backdrop{padding:.5rem}.collaboration-modal{max-height:95vh}.modal-header{padding:1rem 1rem 0}.modal-header h2{font-size:1.25rem}.modal-form,.song-info-section{padding:0 1rem 1rem}.song-details{flex-direction:column;gap:.75rem}.song-thumbnail{height:60px;width:60px}.parts-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.community-wips{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:1rem}.sidebar-area .section-title{font-size:1.3rem;margin-bottom:0}.refresh-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;opacity:.6;padding:.25rem .5rem;transition:opacity .2s ease,transform .3s ease}.refresh-btn:hover:not(:disabled){opacity:1;transform:rotate(180deg)}.refresh-btn:active:not(:disabled){transform:rotate(1turn)}.refresh-btn:disabled{cursor:not-allowed;opacity:.4}.refresh-icon{display:inline-block;font-size:1rem}.wips-widget{background:#0000;border-radius:0;box-shadow:none;overflow:visible}.wips-list{padding:0}.wip-item{border-bottom:1px solid #f0f0f0;padding:.75rem;transition:background-color .2s ease}.wip-item:last-child{border-bottom:none}.wip-item:hover{background-color:#f8f9fa}.wip-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.75rem}.wip-info{flex:1 1;min-width:0}.wip-title{color:#333;font-size:.9rem;font-weight:600;line-height:1.3;margin:0 0 .25rem}.wip-artist,.wip-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wip-artist{color:#666;font-size:.8rem;margin:0}.wip-cover{border-radius:6px;box-shadow:0 1px 3px #0003;flex-shrink:0;height:40px;object-fit:cover;width:40px}.wip-meta{margin-top:.5rem}.wip-progress{align-items:center;display:flex;gap:.5rem}.progress-bar{background:#f3f4f6;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .3s ease}.progress-text{font-size:.75rem;font-weight:600;min-width:2.5rem;text-align:right}.wip-details{align-items:center;color:#888;display:flex;font-size:.75rem;gap:.5rem;justify-content:space-between}.author{font-weight:500}.wip-details-right{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.collaborate-btn{background:#3498db;border-radius:4px;font-size:.7rem;font-weight:500;line-height:1.2;padding:.25rem .5rem;transition:background .2s ease;white-space:nowrap}.collaborate-btn:hover{background:#2980b9}.collaborate-btn:active{transform:translateY(0)}.collaborate-btn.sent{background:#f39c12;color:#fff}.collaborate-btn.sent:hover{background:#e67e22}.collaborate-btn.accepted{background:#27ae60}.collaborate-btn.accepted:hover{background:#229954}.collaborate-btn.declined{background:#95a5a6;cursor:not-allowed}.collaborate-btn:disabled{opacity:.7}.collaborate-btn:disabled:hover{background:#3498db}.status-popup-backdrop{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.status-popup{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-height:80vh;max-width:400px;overflow:auto;width:90%}.status-popup-header{align-items:center;border-bottom:1px solid #e1e5e9;display:flex;justify-content:space-between;padding:1rem 1.5rem}.status-popup-header h4{color:#333;font-size:1rem;font-weight:600;margin:0}.status-popup-header .close-btn{background:none;border:none;border-radius:4px;color:#7f8c8d;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem;transition:color .2s ease}.status-popup-header .close-btn:hover{color:#333}.status-popup-content{padding:1.5rem}.status-popup-content p{color:#333;line-height:1.5;margin:0 0 1rem}.status-popup-content p:last-child{margin-bottom:0}.status-popup-actions{border-top:1px solid #e1e5e9;display:flex;justify-content:flex-end;padding:1rem 1.5rem}.close-popup-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.6rem 1.2rem;transition:background .2s ease}.close-popup-btn:hover{background:#5568d3}.section-footer{padding:.75rem}.empty-state{padding:2rem 1rem}.empty-state h3{color:#333;font-size:1.1rem;margin:.5rem 0}.empty-state p{color:#666;font-size:.9rem}.error-state{color:#666;padding:2rem 1rem}.retry-button{background:#dc3545;border:none;border-radius:6px;font-size:.85rem;margin-top:.5rem;padding:.5rem 1rem}.retry-button:hover{background:#c82333}@media (max-width:768px){.section-title{font-size:1.1rem}.wip-item{padding:.75rem}.wip-header{gap:.5rem}.wip-cover{height:35px;width:35px}.wip-details{align-items:flex-start;flex-direction:column;gap:.25rem}}.intro-section{margin-bottom:0}.intro-widget{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;overflow:hidden;padding:1.5rem;position:relative}.intro-widget:before{background:linear-gradient(135deg,#667eea,#764ba2);content:"";height:3px;left:0;position:absolute;right:0;top:0}.intro-title{color:#333;font-size:1.4rem;font-weight:600;margin:0 0 1rem;text-align:center}.intro-description{color:#555;font-size:1rem;line-height:1.6;margin-bottom:1rem;text-align:center}.feature-highlights{grid-gap:1rem;display:grid;gap:1rem}.feature-item{background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 8px #0000000a;font-size:.9rem;line-height:1.5;padding:1rem 1.25rem;position:relative;transition:transform .2s ease,box-shadow .2s ease}.feature-item:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 3px 3px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.feature-item:hover{box-shadow:0 4px 16px #667eea26;transform:translateY(-2px)}.feature-item strong{color:#333;display:block;font-weight:600;margin-bottom:.25rem}@media (max-width:768px){.intro-widget{padding:1.25rem}.intro-title{font-size:1.1rem}.intro-description{font-size:.9rem}.feature-item{font-size:.85rem;padding:.6rem}}.closest-achievements-widget{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:1rem}.sidebar-area .closest-achievements-widget h3{color:#333;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.closest-achievements-widget .error,.closest-achievements-widget .loading{color:#666;font-size:.9rem;font-style:italic;padding:1rem 0;text-align:center}.closest-achievements-widget .error{color:#dc3545}.no-achievements p{color:#666;font-size:.9rem;font-style:italic;margin:0;text-align:center}.achievements-list{padding:0}.achievement-item{border-bottom:1px solid #f0f0f0;padding:.75rem;transition:background-color .2s ease}.achievement-item:last-child{border-bottom:none}.achievement-item:hover{background-color:#f8f9fa}.achievement-content{width:100%}.achievement-name{color:#333;font-size:.9rem;font-weight:600;margin-bottom:.25rem}.achievement-description{color:#666;font-size:.8rem;line-height:1.3;margin-bottom:.5rem}.progress-text{color:#666}.percentage{color:#007bff;font-weight:600}.points{color:#28a745;font-weight:600}.view-all-link{background:#f8f9fa;border-top:1px solid #e9ecef;padding:1rem;text-align:center}.view-all-link a{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;display:inline-block;font-size:.85rem;font-weight:600;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.view-all-link a:hover{box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}@media (max-width:768px){.closest-achievements-widget{padding:.75rem}.achievement-item{padding:.5rem .75rem}.achievement-name{font-size:.85rem}.achievement-meta{font-size:.75rem;gap:.5rem}}.collaboration-invites{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:2rem;padding:1rem}.sidebar-area .collaboration-invites-widget h2{color:#333;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.section-title{align-items:center;display:flex;gap:.5rem}.invite-count{background:#dc3545;border-radius:10px;color:#fff;font-size:.7rem;font-weight:700;min-width:1.2rem;padding:.2rem .5rem;text-align:center}.collaboration-invites-widget{background:#0000;border-radius:0;box-shadow:none;overflow:visible}.invites-list{padding:0}.invite-item{border-bottom:1px solid #f0f0f0;padding:.75rem;transition:background-color .2s ease}.invite-item:last-child{border-bottom:none}.invite-item:hover{background-color:#f8f9fa}.invite-content{margin-bottom:.75rem}.invite-header{align-items:flex-start;display:flex;gap:.75rem;margin-bottom:.25rem}.invite-artwork{flex-shrink:0}.invite-album-cover{object-fit:cover}.invite-album-cover,.invite-album-cover-placeholder{border-radius:6px;box-shadow:0 1px 4px #0000001a;height:40px;width:40px}.invite-album-cover-placeholder{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#6c757d;display:flex;font-size:1rem;justify-content:center}.invite-song-info{flex:1 1;min-width:0}.invite-song-info .song-title{color:#333;font-size:.9rem;font-weight:600}.invite-song-info .song-artist,.invite-song-info .song-title{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-song-info .song-artist{color:#666;font-size:.75rem}.batch-invite{background:linear-gradient(135deg,#667eea08,#764ba208);border-left:3px solid #667eea}.batch-artwork,.batch-icon-wrapper{height:40px;width:40px}.batch-icon-wrapper{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;box-shadow:0 1px 4px #667eea4d;display:flex;flex-direction:column;justify-content:center}.batch-icon-wrapper .batch-icon{font-size:1rem;line-height:1}.batch-icon-wrapper .batch-count{color:#fff;font-size:.65rem;font-weight:700;margin-top:0}.batch-actions{flex-direction:column;gap:.5rem}.batch-quick-actions{display:flex;gap:.5rem}.see-details-btn{background:#0000;border:1px solid #667eea;border-radius:4px;color:#667eea;cursor:pointer;font-size:.75rem;font-weight:500;padding:.35rem .75rem;text-align:center;transition:all .2s ease}.see-details-btn:hover{background:#667eea;color:#fff}.time{flex-shrink:0;font-size:.75rem}.invite-meta{color:#666;font-size:.8rem;margin:0 0 .25rem}.requester{color:#888}.invite-message{color:#555;font-size:.8rem;font-style:italic;line-height:1.3;margin:.25rem 0 0}.invite-actions{display:flex;gap:.5rem}.accept-btn,.reject-btn{border:none;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:600;min-width:60px;padding:.4rem .8rem;transition:all .2s ease}.accept-btn{background:#28a745;color:#fff}.accept-btn:hover:not(:disabled){background:#218838}.reject-btn{background:#6c757d;color:#fff}.reject-btn:hover:not(:disabled){background:#5a6268}.accept-btn:disabled,.reject-btn:disabled{cursor:not-allowed;opacity:.6}.section-footer{background:#f8f9fa;border-top:1px solid #e9ecef;padding:1rem;text-align:center}.view-all-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:.85rem;font-weight:600;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.view-all-btn:hover{box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}@media (max-width:768px){.invite-header{align-items:flex-start;flex-direction:column}.song-title{margin-bottom:.25rem;margin-right:0}.invite-actions{justify-content:flex-start}.accept-btn,.reject-btn{font-size:.75rem;padding:.35rem .7rem}}.community-event-homepage-banner{align-items:center;background:#fff;border:1px solid #ddd;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 8px #0000000d;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding:1rem 1.25rem;transition:all .2s ease}.community-event-homepage-banner:hover{box-shadow:0 4px 12px #00000014}.event-homepage-info{align-items:center;display:flex;flex:1 1;gap:.75rem}.event-homepage-icon{font-size:1.75rem}.event-homepage-text h3{color:#333;font-size:1rem;font-weight:600;margin:0 0 .2rem}.event-homepage-text p{color:#666;font-size:.85rem;margin:0}.event-homepage-stats{align-items:center;display:flex;gap:1.25rem}.event-homepage-stat{text-align:center}.event-homepage-stat-value{color:#333;display:block;font-size:1.1rem;font-weight:700}.event-homepage-stat-label{color:#888;font-size:.65rem;letter-spacing:.5px;text-transform:uppercase}.event-homepage-cta{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.6rem 1.25rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.event-homepage-cta:hover{background:#0056b3}.event-homepage-deadline{align-items:center;color:#856404;display:flex;font-size:.75rem;font-weight:500;gap:.3rem;margin-top:.2rem}.community-event-homepage-banner.released{background:linear-gradient(135deg,#f8fff9,#fff);border-left-color:#28a745}.released-badge{background:#28a745;border-radius:4px;color:#fff;display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.5px;margin-right:.5rem;padding:.2rem .5rem;vertical-align:middle}.event-homepage-stat.featured .event-homepage-stat-value{color:#28a745;font-size:1.5rem}.event-homepage-stat.featured .event-homepage-stat-label{color:#28a745;font-weight:600}.event-homepage-cta.released{background:#28a745}.event-homepage-cta.released:hover{background:#218838}@media (max-width:768px){.community-event-homepage-banner{flex-direction:column;padding:1rem;text-align:center}.event-homepage-info{flex-direction:column}.event-homepage-cta,.event-homepage-stats{justify-content:center;width:100%}}.home-page{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#333;min-height:100vh}.home-content{grid-gap:2rem;display:grid;gap:2rem;margin:0 auto;max-width:1200px;padding:2rem}.home-content.unauthenticated{grid-template-areas:"main-content sidebar" "main-content sidebar";grid-template-columns:2fr 1fr}.main-content-area{display:flex;flex-direction:column;gap:.75rem;grid-area:main-content}.main-content-area>*{margin:0}.sidebar-area{grid-gap:.75rem;display:grid;gap:.75rem;grid-area:sidebar;max-width:100%;min-width:0;overflow-x:hidden;overflow-y:visible}.sidebar-area>*{word-wrap:break-word;box-sizing:border-box;max-width:100%;min-width:0;overflow-wrap:break-word;width:100%}.sidebar-area section,.sidebar-area>div{overflow:visible!important}.sidebar-area *{box-sizing:border-box;max-width:100%}.home-content.authenticated{grid-template-areas:"full-width full-width" "main-content sidebar" "main-content sidebar";grid-template-columns:2fr 1fr}.full-width-section{grid-area:full-width;width:100%}@media (max-width:1440px){.home-content{max-width:100%;padding:2rem 1.5rem}.sidebar-area{min-width:280px}}@media (max-width:1200px){.home-content.authenticated,.home-content.unauthenticated{gap:1.5rem;grid-template-columns:1.75fr 1fr}.home-content{padding:2rem 1.5rem}}@media (max-width:1023px){.home-content,.home-content.authenticated,.home-content.unauthenticated{grid-template-areas:none;grid-template-columns:1fr}.full-width-section,.main-content-area,.sidebar-area{grid-area:unset}.sidebar-area{min-width:100%}}@media (max-width:768px){.home-content{gap:1.5rem;padding:1.5rem 1rem}.sidebar-area{min-width:100%}}.loading-container{color:#fff;padding:4rem 2rem;text-align:center}.loading-spinner{border:3px solid #ffffff4d;border-top-color:gold;margin:0 auto 1rem}.user-settings-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:800px;padding:20px}.user-settings-header{margin-bottom:30px;text-align:center}.user-settings-header h1{color:#333;font-size:2rem;font-weight:600;margin-bottom:8px}.user-settings-header p{color:#666;font-size:.95rem;margin:0}.user-settings-content{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.settings-tabs{background:#f8f9fa;border-bottom:2px solid #f0f0f0;display:flex}.settings-tab{background:#0000;background-color:initial;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:1rem 2rem;transition:all .2s ease}.settings-tab:hover{background-color:#007bff0d;color:#007bff}.settings-tab.active{background-color:#fff;border-bottom-color:#007bff;color:#007bff;font-weight:600}.settings-section{padding:24px 30px}.settings-section h2{border-bottom:1px solid #e9ecef;color:#333;font-size:1.5rem;font-weight:600;margin-bottom:20px;padding-bottom:8px}.settings-section h3{color:#555;font-size:1.3rem;font-weight:500;margin-bottom:15px}.settings-form{margin-top:20px}.form-group{align-items:flex-start;display:flex;flex-direction:column;margin-bottom:18px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:8px}.form-control{background-color:#fff;border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:16px;height:48px;padding:12px 16px;transition:border-color .2s ease;width:100%}.form-control-small{max-width:300px}.form-control-small,.form-control-small[type=email],.form-control-small[type=select],.form-control-small[type=text]{box-sizing:border-box;width:300px!important}.form-control:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-control:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-text{color:#6c757d;display:block;font-size:14px;margin-top:6px}.form-actions{border-top:1px solid #e9ecef;margin-top:24px;padding-top:20px}.btn{display:inline-block;font-size:16px;padding:12px 24px;position:relative;text-align:center}.btn-primary{background-color:#007bff}.btn-primary:hover:not(:disabled){background-color:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.btn-secondary{background-color:#6c757d}.btn-secondary:hover:not(:disabled){background-color:#545b62;box-shadow:0 4px 8px #6c757d4d;transform:translateY(-1px)}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333;box-shadow:0 4px 8px #dc35454d;transform:translateY(-1px)}.loading{color:#666;font-size:18px;padding:40px;text-align:center}@media (max-width:768px){.user-settings-container{padding:15px}.settings-section{padding:20px}.user-settings-header h1{font-size:2rem}.settings-tab{font-size:.9rem;padding:.75rem 1rem}.btn{margin-bottom:10px;width:100%}}@media (max-width:480px){.user-settings-container{padding:10px}.settings-section{padding:15px}.user-settings-header h1{font-size:1.8rem}.settings-tab{font-size:.85rem;padding:.5rem .75rem}}.admin-page{margin:0 auto;max-width:1400px;padding:20px}.admin-header{margin-bottom:30px}.admin-header h1{color:#333;font-size:28px;margin-bottom:5px}.admin-subtitle{color:#666;font-size:14px}.users-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.users-section h2{color:#333;font-size:20px;font-weight:600;margin-bottom:20px}.users-table-container{overflow-x:auto}.users-table{background:#fff;border:1px solid #e0e0e0;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.users-table thead{background:#f5f5f5;border-bottom:2px solid #e0e0e0}.users-table th{color:#555;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.users-table td{border-top:1px solid #f0f0f0;color:#333;font-size:14px;padding:12px 16px}.users-table tbody tr:hover{background:#f9f9f9}.username-cell{color:#007bff;font-weight:600}.date-cell{color:#777;font-size:12px;white-space:nowrap}.badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.badge-admin{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.badge-user{background:#e9ecef;border:1px solid #dee2e6;color:#495057}.badge-active{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.badge-inactive{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.actions-cell{white-space:nowrap}.actions-cell button{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;margin-right:5px;padding:6px 12px;transition:all .2s}.btn-impersonate{background:#2196f3;color:#fff}.btn-impersonate:hover{background:#1976d2;transform:translateY(-1px)}.btn-toggle-admin{color:#fff}.btn-promote{background:#ffc107}.btn-promote:hover{background:#ffa000;transform:translateY(-1px)}.btn-demote{background:#9e9e9e}.btn-demote:hover{background:#757575;transform:translateY(-1px)}.btn-delete{background:#f44336}.btn-delete:hover{background:#d32f2f;transform:translateY(-1px)}.error-message,.loading{color:#666;font-size:16px;padding:40px;text-align:center}.error-message{color:#dc3545}.admin-page button[type=button]:not(.actions-cell button){background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:10px;padding:10px 20px}.admin-page button[type=button]:not(.actions-cell button):hover{background:#0056b3}@media (max-width:1200px){.users-table{font-size:12px}.users-table td,.users-table th{padding:8px}.actions-cell button{font-size:11px;padding:4px 8px}}.releases-page{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#333;min-height:100vh;padding:2rem 1rem}.youtube-embed{margin-top:1rem}.youtube-embed.compact{margin-top:.75rem}.youtube-wrapper{border-radius:8px;box-shadow:0 4px 16px #0003;height:0;overflow:hidden;padding-bottom:56.25%;position:relative}.youtube-embed.compact .youtube-wrapper{border-radius:6px;box-shadow:0 2px 8px #00000026}.youtube-wrapper iframe{border-radius:8px;height:100%;left:0;position:absolute;top:0;width:100%}.youtube-embed.compact .youtube-wrapper iframe{border-radius:6px}.releases-header{margin-bottom:2rem}.header-content{margin:0 auto;max-width:1200px}.back-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#333;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem;transition:all .2s}.back-btn:hover{background:#f8f9fa;transform:translateX(-2px)}.title-section h1{color:#333;font-size:3rem;font-weight:800;margin:0 0 .5rem}.subtitle{color:#666;font-size:1.2rem;font-weight:300;margin:0 0 1rem}.release-stats{align-items:center;display:flex;gap:1.5rem;margin-top:1rem}.page-info,.total-count{background:#fff;border:1px solid #ddd;border-radius:20px;box-shadow:0 2px 4px #0000001a;color:#333;font-size:.85rem;font-weight:500;padding:.5rem 1rem}.pagination-container{display:flex;justify-content:center;margin:2rem 0}.pagination-container.top{margin-bottom:1.5rem}.pagination-container.bottom{margin-top:2rem}.pagination-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;gap:1rem;padding:1rem 1.5rem}.nav-btn,.pagination-controls{align-items:center;display:flex}.nav-btn{background:#ffffffe6;border:none;border-radius:8px;color:#495057;cursor:pointer;font-size:.9rem;font-weight:500;gap:.5rem;padding:.6rem 1rem;transition:all .2s}.nav-btn:hover:not(:disabled){background:#fff;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.nav-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.page-numbers{gap:.5rem}.page-btn,.page-numbers{align-items:center;display:flex}.page-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;height:2.5rem;justify-content:center;transition:all .2s;width:2.5rem}.page-btn:hover{background:#ffffff4d;transform:scale(1.05)}.page-btn.active{background:#fff;border-color:#fff;color:#667eea}.page-dots{color:#fff9;padding:0 .5rem}.releases-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.releases-grid,.releases-list-view{margin:0 auto;max-width:1200px;padding:0 1rem}.pack-release-list-item{background:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1rem;overflow:hidden;transition:all .2s ease}.pack-release-list-item:hover{border-color:#ddd;box-shadow:0 4px 12px #0000001f}.pack-release-list-item.expanded{border-color:#667eea;box-shadow:0 6px 20px #00000026}.pack-list-row{align-items:center;cursor:pointer;display:flex;gap:1rem;padding:1rem 1.5rem;transition:background-color .2s ease}.pack-list-row:hover{background-color:#f8f9fa}.pack-release-list-item.expanded .pack-list-row{background-color:#f8f9fa;border-bottom:1px solid #e5e5e5}.pack-cover-container{flex-shrink:0;position:relative}.pack-cover-thumbnail{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:60px;object-fit:cover;width:60px}.pack-cover-placeholder{align-items:center;background:#f5f5f5;border-radius:8px;color:#999;display:flex;font-size:1.2rem;height:60px;justify-content:center;width:60px}.cover-count{background:#667eea;border-radius:12px;color:#fff;font-size:.7rem;font-weight:600;min-width:20px;padding:2px 6px;position:absolute;right:-6px;text-align:center;top:-6px}.pack-basic-info{flex:1 1;min-width:0}.pack-title{color:#1a1a1a;font-size:1.1rem;font-weight:700;line-height:1.3;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pack-subtitle{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.pack-author{font-weight:500;transition:color .2s ease}.pack-author:hover{color:#667eea}.separator{color:#ccc}.pack-meta-info{align-items:center;display:flex;flex-shrink:0;gap:1rem}.release-date{color:#666;font-size:.85rem;font-weight:500}.expand-indicator{color:#667eea;font-size:.9rem;font-weight:700;transition:transform .2s ease}.pack-release-list-item.expanded .expand-indicator{transform:rotate(90deg)}.pack-expanded-content{background:#fafafa;padding:0 1.5rem 1.5rem}.pack-actions-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.download-btn:hover{box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.edit-btn{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff}.edit-btn:hover{background:linear-gradient(135deg,#5a6268,#495057);box-shadow:0 4px 8px #6c757d4d;transform:translateY(-1px)}.release-description{background:#fff;border:1px solid #e5e5e5;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.release-description-text{color:#555;font-size:.9rem;line-height:1.5}.read-more-btn{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;margin-left:.5rem;text-decoration:underline}.expanded-covers{margin-bottom:1.5rem}.expanded-covers h5{color:#333;font-size:1rem;font-weight:600;margin:0 0 .75rem}.covers-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));max-width:500px}.album-cover-grid-item{aspect-ratio:1;border-radius:6px;box-shadow:0 2px 4px #0000001a;object-fit:cover;width:100%}.songs-section{margin-bottom:1.5rem}.songs-section h5{color:#333;font-size:1rem;font-weight:600;margin:0 0 .75rem}.songs-list{background:#fff;border:1px solid #e5e5e5;border-radius:8px;overflow:hidden}.song-item{border-bottom:1px solid #f0f0f0;gap:.75rem;padding:.75rem 1rem;transition:all .2s ease}.song-item:last-child{border-bottom:none}.song-item:hover{background-color:#f8f9fa;transform:translateX(2px)}.song-number{font-weight:600;min-width:1.5rem}.song-album-cover{border-radius:4px;box-shadow:0 2px 4px #0000001a;flex-shrink:0;height:40px;object-fit:cover;width:40px}.song-info{min-width:0}.song-title{font-size:.9rem;margin-bottom:.2rem}.song-artist{font-size:.8rem;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.songs-pagination{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:1rem;justify-content:center;margin-top:1rem;padding:1rem}.songs-nav-btn{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s ease}.songs-nav-btn:hover:not(:disabled){background:#667eea;border-color:#667eea;color:#fff}.songs-nav-btn:disabled{cursor:not-allowed;opacity:.5}.songs-page-info{color:#666;font-size:.85rem}.youtube-section{margin-bottom:1rem}.youtube-section h5{color:#333;font-size:1rem;font-weight:600;margin:0 0 .75rem}.pack-release-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 12px #00000026;color:#333;height:auto;overflow:hidden;transition:all .2s;width:100%}.pack-release-card:hover{box-shadow:0 6px 16px #0003;transform:translateY(-2px)}.pack-cover{background:#f5f5f5;height:150px;overflow:hidden;width:100%}.cover-image{height:100%;object-fit:cover;width:100%}.cover-placeholder{align-items:center;background:#f5f5f5;color:#999;display:flex;font-size:2rem;height:100%;justify-content:center;width:100%}.cover-carousel{height:100%;position:relative;width:100%}.carousel-btn{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;opacity:0;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s;width:32px;z-index:2}.cover-carousel:hover .carousel-btn{opacity:1}.carousel-btn:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.carousel-btn.prev-btn{left:8px}.carousel-btn.next-btn{right:8px}.carousel-dots{bottom:8px;display:flex;gap:6px;left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:opacity .2s;z-index:2}.cover-carousel:hover .carousel-dots{opacity:1}.carousel-dots .dot{background:#ffffff80;border:none;border-radius:50%;cursor:pointer;height:8px;transition:all .2s;width:8px}.carousel-dots .dot.active{background:#fff;transform:scale(1.2)}.carousel-dots .dot:hover{background:#fffc}.pack-details{padding:1rem}.pack-title-section{background:#0000!important;border:none;margin-bottom:1rem;padding:0}.pack-title-section .pack-name{word-wrap:break-word;background:#0000!important;border:none!important;color:#1a1a1a!important;font-size:1.3rem!important;font-weight:700!important;-webkit-hyphens:auto;hyphens:auto;letter-spacing:-.01em;line-height:1.3!important;margin:0 0 .5rem!important;overflow-wrap:break-word;padding:0!important}.pack-credits{margin-bottom:.75rem}.pack-artist{color:#666;font-size:.95rem;font-weight:500;margin-bottom:.25rem}.pack-author{background:#f0f0f0;border-radius:10px;color:#888;display:inline-block;font-size:.8rem;padding:.2rem .5rem}.pack-meta{align-items:center;border-bottom:1px solid #eee;color:#666;display:flex;font-size:.8rem;justify-content:space-between;padding-bottom:.5rem}.pack-meta,.songs-list{margin-bottom:.75rem}.song-item{padding:.3rem 0}.song-number{color:#999;font-size:.8rem;font-weight:500;min-width:1.2rem}.song-title{color:#555;flex:1 1;font-weight:400}.song-download-link{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border-radius:6px;box-shadow:0 2px 4px #28a74533;color:#fff;display:inline-flex;flex-shrink:0;font-size:.85rem;font-weight:600;gap:.5rem;margin-left:auto;padding:.5rem .75rem;text-decoration:none;transition:all .2s}.song-download-link:hover{background:linear-gradient(135deg,#218838,#1a9870);box-shadow:0 4px 8px #28a7454d;color:#fff;transform:translateY(-1px)}.song-download-link .download-icon{font-size:1rem}.song-download-link .download-text{white-space:nowrap}.release-metadata{border-top:1px solid #eee;margin-top:.75rem;padding-top:.75rem}.release-description{margin-bottom:.75rem}.release-description p{color:#555;font-size:.85rem;font-style:italic;line-height:1.4;margin:0}.release-actions{display:flex;flex-wrap:wrap;gap:.5rem}.release-action-btn{align-items:center;border-radius:6px;display:inline-flex;flex:1 1;font-size:.8rem;font-weight:500;gap:.3rem;justify-content:center;min-width:100px;padding:.4rem .75rem;text-decoration:none;transition:all .2s}.download-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.download-btn:hover{background:linear-gradient(135deg,#218838,#1a9870);color:#fff;transform:translateY(-2px)}.youtube-btn{background:linear-gradient(135deg,#dc3545,#e74c3c);color:#fff}.youtube-btn:hover{background:linear-gradient(135deg,#c82333,#d62c1a);color:#fff;transform:translateY(-2px)}.btn-icon{font-size:1rem}.empty-state{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;grid-column:1/-1;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.empty-state h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:#fffc;margin-bottom:2rem}.cta-button{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.cta-button:hover{background:linear-gradient(135deg,#0056b3,#004085);transform:translateY(-2px)}.error-state{margin:0 auto;max-width:600px;padding:4rem 2rem;text-align:center}.error-state p{color:#ffffffe6;font-size:1.1rem;margin-bottom:2rem}.retry-button{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .2s}.retry-button:hover{background:#ffffff4d}@media (max-width:768px){.releases-page{padding:1rem .5rem}.title-section h1{font-size:2.2rem}.subtitle{font-size:1rem}.release-stats{align-items:flex-start;flex-direction:column;gap:.75rem}.releases-list-view{padding:0 .5rem}.pack-list-row{gap:.75rem;padding:.75rem 1rem}.pack-cover-placeholder,.pack-cover-thumbnail{height:50px;width:50px}.pack-title{font-size:1rem!important}.pack-subtitle{flex-wrap:wrap;font-size:.85rem}.pack-meta-info{align-items:flex-end;flex-direction:column;gap:.5rem}.release-date{font-size:.8rem}.pack-expanded-content{padding:0 1rem 1rem}.pack-actions-row{flex-direction:column;gap:.5rem}.action-btn{justify-content:center;width:100%}.covers-grid{gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.song-item{gap:.5rem;padding:.5rem .75rem}.song-album-cover{height:32px;width:32px}.song-title{font-size:.85rem}.song-artist{font-size:.75rem}.songs-pagination{flex-direction:column;gap:.75rem;padding:.75rem}.pagination-controls{flex-direction:column;gap:1rem;padding:1rem}.page-numbers{order:-1}}.releases-page .pack-release{display:flex;flex-direction:column;height:100%;padding:1rem}.releases-page .pack-header{gap:.75rem;margin-bottom:.75rem}.releases-page .pack-title-section .pack-name{font-size:1.3rem!important;margin:0 0 .5rem!important}.releases-page .pack-cover,.releases-page .pack-cover-carousel .pack-cover{height:100px;max-width:100px;min-width:100px;width:100px}.releases-page .pack-songs-section{display:flex;flex:1 1;flex-direction:column;margin-top:1rem}.releases-page .pack-songs{gap:.4rem;max-height:300px;overflow-y:auto;padding:.5rem 0}.releases-page .songs-section-title{font-size:1rem;margin:0 0 .5rem}.releases-page .release-description-section{margin:.75rem 0}.artist-connection-inline{animation:expandIn .3s ease-out;background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;display:flex;flex-direction:column;margin-bottom:.75rem;margin-top:.75rem;max-width:100%;overflow:hidden;width:100%}@keyframes expandIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.artist-connection-header{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-shrink:0;justify-content:space-between;padding:1rem 1.5rem}.header-content{align-items:center;display:flex;gap:1rem}.artist-image{border:3px solid #ffffff4d;border-radius:50%;flex-shrink:0;height:60px;width:60px}.header-text h3{font-size:1.25rem;font-weight:700;margin:0 0 .25rem}.header-text p{font-size:.95rem;margin:0;opacity:.9}.header-text .username-link{color:#fff;cursor:pointer;font-weight:600;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.header-text .username-link:hover{text-decoration-style:solid}.close-button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.25rem;height:32px;justify-content:center;line-height:1;padding:0;transition:background .2s ease;width:32px}.close-button:hover{background:#ffffff4d}.artist-connection-content{background:#f8f9fa;flex:1 1;padding:1rem 1.5rem}.error-state,.loading-state{align-items:center;color:#666;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.error-state button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.5rem 1rem}.stats-summary{display:flex;gap:.75rem;margin-bottom:1rem}.stat-item{background:#fff;border-left:4px solid #0000;border-radius:8px;box-shadow:0 1px 3px #00000014;flex:1 1;padding:.75rem;text-align:center}.stat-item.shared{border-left-color:#fbbf24}.stat-item.yours{border-left-color:#667eea}.stat-item.theirs{border-left-color:#10b981}.stat-value{color:#1f2937;display:block;font-size:1.5rem;font-weight:700}.stat-label{color:#6b7280;display:block;font-size:.8rem;letter-spacing:.5px;margin-top:.25rem;text-transform:uppercase}.tabs{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;gap:.5rem;margin-bottom:.75rem;padding:.375rem}.tab{border-radius:6px;color:#6b7280;flex:1 1;font-size:.85rem;padding:.5rem .75rem}.tab:hover{background:#f3f4f6;color:#374151}.tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.songs-comparison{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;padding:.75rem}.shared-songs-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.column h4{border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:.8rem;letter-spacing:.5px;margin:0 0 .5rem;padding-bottom:.375rem;text-transform:uppercase}.column.yours h4{border-bottom-color:#667eea}.column.theirs h4{border-bottom-color:#10b981}.column.theirs .column-header-with-action{border-bottom:2px solid #10b981;margin-bottom:.5rem;padding-bottom:.375rem}.column.theirs .column-header-with-action h4{border-bottom:none;margin-bottom:0;padding-bottom:0}.single-column{max-width:100%}.two-column-layout{width:100%}.songs-list{display:flex;flex-direction:column;gap:.5rem}.songs-list-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.released-summary{background:#f0f0f0;border-radius:6px;color:#6b7280;font-size:.85rem;font-style:italic;margin-bottom:.75rem;padding:.75rem;text-align:center}.song-item{background:#f9fafb;border-radius:6px;gap:.5rem;justify-content:space-between;min-width:0;overflow:hidden;padding:.5rem .625rem;transition:background .2s ease}.song-item:hover{background:#f3f4f6}.song-item.shared{background:linear-gradient(135deg,#fbbf241a,#fbbf240d);border:1px solid #fbbf244d}.song-item-main{align-items:center;display:flex;flex:1 1;gap:.5rem;min-width:0;overflow:hidden}.song-cover{border-radius:4px;flex-shrink:0;height:32px;object-fit:cover;width:32px}.song-details,.song-title-container{display:block;overflow:hidden;text-align:left}.song-title-container{min-width:0}.song-title{color:#1f2937;display:block;font-size:.85rem;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.shared-badge{flex-shrink:0;font-size:.85rem}.song-album{color:#9ca3af;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-album,.song-owner{display:block;font-size:.7rem;margin-top:.125rem;text-align:left}.song-owner{color:#667eea;cursor:pointer;font-weight:500}.song-owner:hover{text-decoration:underline}.song-status{background:#e5e7eb;border-radius:4px;color:#4b5563;margin-left:.5rem;padding:.15rem .5rem}.collab-btn,.song-status{flex-shrink:0;font-size:.7rem;white-space:nowrap}.collab-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:.3rem .6rem;transition:all .2s ease}.collab-btn:hover:not(:disabled){box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.collab-btn:disabled{cursor:not-allowed;opacity:.7}.collab-btn.sent{background:#fbbf24;color:#1f2937}.collab-btn.accepted{background:#10b981}.collab-btn.declined{background:#ef4444}.empty-state{color:#6b7280;padding:2rem}.empty-state p{margin:.5rem 0}.empty-state .hint{font-size:.85rem;opacity:.8}.column-header-with-action{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.column-header-with-action h4{border-bottom:none;color:#6b7280;font-size:.8rem;letter-spacing:.5px;margin:0;padding-bottom:0;text-transform:uppercase}.select-all-row{display:flex;justify-content:flex-end;margin-bottom:.5rem}.select-all-btn{background:#0000;border:1px solid #667eea;border-radius:4px;color:#667eea;cursor:pointer;font-size:.7rem;font-weight:500;padding:.25rem .5rem;transition:all .2s ease;white-space:nowrap}.select-all-btn:hover{background:#667eea;color:#fff}.artist-selection-bar{align-items:center;animation:slideDown .2s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem;padding:.75rem 1rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.artist-selection-bar .selection-info{align-items:center;color:#fff;display:flex;gap:.75rem}.artist-selection-bar .selection-count{font-size:.9rem;font-weight:600}.artist-selection-bar .clear-selection-btn{background:#fff3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:background .2s ease}.artist-selection-bar .clear-selection-btn:hover{background:#ffffff4d}.artist-selection-bar .send-batch-btn{background:#fff;border:none;border-radius:6px;color:#667eea;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.artist-selection-bar .send-batch-btn:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.song-checkbox{align-items:center;display:flex;flex-shrink:0}.song-checkbox input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.song-checkbox input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.song-item.selected{background:linear-gradient(135deg,#667eea26,#764ba21a);border:1px solid #667eea4d}@media (max-width:640px){.artist-connection-inline{border-radius:8px}.artist-connection-header{padding:.75rem 1rem}.artist-image{height:48px;width:48px}.header-text h3{font-size:1.1rem}.stats-summary{flex-direction:column;gap:.5rem}.stat-item{align-items:center;display:flex;justify-content:space-between;text-align:left}.stat-value{font-size:1.25rem}.tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab{flex:none;white-space:nowrap}.shared-songs-grid,.songs-list-grid{grid-template-columns:1fr}.artist-selection-bar{align-items:stretch;flex-direction:column;gap:.5rem}.artist-selection-bar .selection-info{justify-content:space-between}.artist-selection-bar .send-batch-btn{text-align:center;width:100%}}.smart-discovery{background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a;margin-bottom:2rem;overflow:hidden}.smart-discovery-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem}.smart-discovery-header h3{font-size:1.25rem;font-weight:600;margin:0}.smart-discovery-content{background:#fff;display:flex;flex-direction:column;gap:2rem;padding:1.5rem}.smart-discovery-empty,.smart-discovery-error,.smart-discovery-loading{color:#666;padding:1rem;text-align:center}.smart-discovery-empty p{color:#666;margin:.5rem 0}.shared-section h4{color:#333;font-size:1rem;font-weight:600;margin:0 0 .75rem}.shared-items{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.shared-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;flex-direction:column;gap:.75rem;padding:1rem;transition:box-shadow .2s ease}.shared-item:hover{box-shadow:0 2px 8px #0000001a}.shared-artist-card{cursor:pointer;position:relative;transition:all .2s ease}.shared-artist-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.shared-artist-card:active{transform:translateY(0)}.view-details-icon{color:#667eea;flex-shrink:0;font-size:1.25rem;opacity:0;transition:opacity .2s ease,transform .2s ease}.shared-artist-card:hover .view-details-icon{opacity:1;transform:translateX(2px)}.artist-card-wrapper{display:flex;flex-direction:column;min-width:0}.expanded-artist-detail{margin-top:.75rem;max-width:100%;min-width:0;overflow:hidden;width:100%}.expanded-artist-detail .artist-connection-inline{box-sizing:border-box;max-width:100%;overflow:hidden;width:100%}.expanded-artist-detail .artist-connection-inline *{box-sizing:border-box;max-width:100%}.expanded-artist-detail .song-item,.expanded-artist-detail .song-item-main{max-width:100%}.expanded-artist-detail .collab-btn{flex-shrink:0}.shared-item-content{align-items:flex-start;display:flex;gap:.75rem}.shared-song-cover{object-fit:cover}.shared-song-cover,.shared-song-cover.placeholder{border:1px solid #dee2e6;border-radius:6px;flex-shrink:0;height:50px;width:50px}.shared-song-cover.placeholder{align-items:center;background:#e9ecef;color:#6c757d;display:flex;font-size:1.5rem;justify-content:center}.shared-item-info{flex:1 1;min-width:0}.shared-artist,.shared-song{color:#333;font-size:.95rem;line-height:1.4;margin-bottom:.25rem}.shared-artist strong,.shared-song strong{font-weight:600}.song-status-badge{font-weight:400}.shared-user,.song-status-badge{color:#666;font-size:.85rem}.username-link{font-weight:500;transition:opacity .2s ease}.username-link:hover{text-decoration:underline}.song-count{color:#888;font-size:.85rem;font-weight:400;margin-left:.5rem}.artist-breakdown{color:#666;display:flex;flex-wrap:wrap;font-size:.85rem;gap:.5rem}.breakdown-item{display:inline}.breakdown-item:not(:last-child):after{color:#ccc;content:"•";margin-left:.5rem}.collaborate-btn{align-self:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.collaborate-btn:hover:not(:disabled){box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.collaborate-btn:active:not(:disabled){transform:translateY(0)}.collaborate-btn:disabled{cursor:not-allowed;opacity:.6}.collaborate-btn.sent{background:#ffc107;color:#333}.collaborate-btn.accepted{background:#28a745;color:#fff}.collaborate-btn.declined{background:#dc3545;color:#fff}.expand-button{background:#0000;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:.25rem;padding:.75rem;text-align:center;transition:all .2s ease}.expand-button:hover{background:#667eea;color:#fff}.shared-more{color:#667eea;cursor:pointer;font-size:.85rem;font-style:italic;padding:.5rem;text-align:center}.shared-more:hover{text-decoration:underline}@media (max-width:768px){.smart-discovery-content,.smart-discovery-header{padding:1rem}.smart-discovery-content{gap:1.5rem}.shared-items{grid-template-columns:1fr}.shared-song-cover{height:40px;width:40px}}.section-header{margin-bottom:1rem;min-height:40px}.section-title-group{gap:.5rem;min-height:40px}.section-title{font-size:1.2rem}.section-count{background-color:#6c757d;border-radius:12px;font-size:.8rem;font-weight:500;padding:.2rem .6rem}.artist-image-container{align-items:center;display:flex;flex-shrink:0;margin-right:8px}.artist-image{object-fit:cover}.artist-image,.artist-image-placeholder{border:1px solid #e1e5e9;border-radius:4px;height:32px;width:32px}.artist-image-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:14px;justify-content:center}.artist-details{display:flex;flex-direction:column;justify-content:center;line-height:1}.artist-info{flex:1 1}.artist-header{align-items:center;border:1px solid #e1e5e9;border-radius:4px;display:flex;height:auto;justify-content:space-between;margin-bottom:2px;min-height:0;padding:4px 8px}.artist-name{color:#495057;font-size:.9rem;line-height:1;padding:0}.song-count{font-size:.75rem;line-height:1;margin:1px 0 0;padding:0}.collapse-icon{align-items:center;display:flex;font-size:8px;height:12px;justify-content:center;margin-right:4px;width:12px}.song-album{color:#6c757d;font-size:.8rem;font-weight:400;line-height:1.2;margin-top:2px}.song-title{font-weight:500;line-height:1.3;margin:0}.song-meta{margin-top:4px}.search-container{align-items:center;display:flex;margin-right:1rem;position:relative}.search-input{border:1px solid #ccc;border-radius:20px;box-sizing:border-box;font-size:.9rem;height:40px;outline:none;padding:.5rem 1rem;transition:border-color .2s ease,box-shadow .2s ease;width:250px}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.search-input::placeholder{color:#999;font-style:italic}.clear-search{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:1.2rem;height:24px;justify-content:center;position:absolute;right:8px;transition:background-color .2s ease,color .2s ease;width:24px}.clear-search:hover{background-color:#f0f0f0;color:#666}.profile-section .group-toggle,.profile-section .section-controls .group-toggle{align-items:center;background:#fff!important;border:1px solid #ccc!important;border-radius:20px!important;box-sizing:border-box!important;cursor:pointer;display:inline-flex!important;font-size:.9rem!important;gap:.5rem;height:40px!important;justify-content:center;line-height:1;margin-bottom:0!important;overflow:visible!important;padding:.5rem 1rem!important;transition:all .2s ease;white-space:nowrap}.profile-section .group-toggle:hover,.profile-section .section-controls .group-toggle:hover{background-color:#f8f9ff!important;border-color:#007bff!important}.profile-section .group-toggle.active,.profile-section .section-controls .group-toggle.active{background-color:#007bff!important;border-color:#007bff!important;color:#fff!important}.toggle-icon{font-size:.9rem}@media (max-width:768px){.search-input{font-size:.8rem;padding:.4rem .8rem;width:200px}.section-controls{align-items:stretch;flex-direction:column;gap:.5rem}.search-container{margin-bottom:.5rem;margin-right:0}}@media (max-width:480px){.search-input{width:180px}}.no-search-results{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#6c757d;padding:2rem;text-align:center}.no-search-results p{margin:.5rem 0}.no-search-results p:first-child{color:#495057;font-weight:600}.sortable-header:hover{background-color:#e9ecef!important}.sort-indicator{color:#007bff;font-size:.9em;font-weight:700;margin-left:.25rem}.users-grouped-view{display:flex;flex-direction:column;gap:1rem}.user-group-item{background:#fff;border:1px solid #e1e5e9;border-radius:8px;overflow:hidden}.user-header{background:#f8f9fa;cursor:pointer;padding:1rem;transition:background-color .2s ease}.user-header:hover{background:#e9ecef}.user-info{align-items:center;display:flex;gap:.75rem}.user-image-container{align-items:center;display:flex;flex-shrink:0;margin-right:8px}.user-image{object-fit:cover}.user-image,.user-image-placeholder{border:1px solid #e1e5e9;border-radius:50%;height:32px;width:32px}.user-image-placeholder{align-items:center;background:#e9ecef;color:#6c757d;display:flex;font-size:1rem;justify-content:center}.user-details{align-items:center;display:flex;flex:1 1;gap:.5rem}.user-name{color:#667eea;font-size:1rem;font-weight:600;margin:0}.user-name:hover{text-decoration:underline}.user-songs{background:#fff;padding:0}.user-songs table{border-radius:0;margin:0}.grouping-controls{align-items:center;display:flex;gap:.5rem}.group-select-wrapper,.sort-select-wrapper{align-items:center;display:flex;gap:.375rem}.group-select-label,.sort-select-label{color:#6c757d;font-size:.8125rem;font-weight:500;-webkit-user-select:none;user-select:none;white-space:nowrap}.group-select,.sort-select{background:#fff;border:1px solid #dee2e6;border-radius:6px;box-sizing:border-box;color:#495057;cursor:pointer;font-size:.8125rem;font-weight:500;height:32px;min-width:90px;padding:.375rem .625rem;transition:all .2s ease}.group-select:hover,.sort-select:hover{background:#f8f9fa;border-color:#adb5bd}.group-select:focus,.sort-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.hide-my-songs-checkbox{align-items:center;color:#495057;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.5rem;padding:.375rem .75rem;-webkit-user-select:none;user-select:none;white-space:nowrap}.hide-my-songs-checkbox input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:16px;width:16px}.hide-my-songs-checkbox:hover{color:#333}.sortable-header{cursor:pointer;padding-right:1.5rem!important;position:relative;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.sortable-header:hover{background-color:#f8f9fa}.sort-indicator{color:#6c757d;display:inline-block;font-size:.75rem;font-weight:400;margin-left:.5rem;opacity:.6}.sortable-header:hover .sort-indicator{color:#667eea;opacity:1}.selection-bar{align-items:center;animation:slideIn .2s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;display:flex;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.selection-info{align-items:center;display:flex;gap:.5rem}.selection-count{font-size:.9375rem;font-weight:600}.selection-owner{font-size:.875rem;opacity:.9}.selection-actions{align-items:center;display:flex;gap:.5rem}.clear-selection-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.375rem .75rem;transition:all .2s ease}.clear-selection-btn:hover{background:#ffffff4d;border-color:#ffffff80}.batch-request-btn{background:#fff;border:none;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#667eea;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.batch-request-btn:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.batch-request-btn:disabled{cursor:not-allowed;opacity:.5}.public-song-row.selected{background-color:#e3f2fd!important}.public-song-row.selected:hover{background-color:#bbdefb!important}.community-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:2rem 0}.community-container{margin:0 auto;max-width:1200px;padding:0 1rem}.page-header h1{color:#2c3e50}.page-header p{color:#7f8c8d}.results-section{min-height:400px}.error-message{align-items:center;background:#ffe6e6;border:1px solid #ffb3b3;border-radius:8px;color:#d63031;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.error-icon{font-size:1.2rem}.retry-btn{background:#d63031;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;margin-left:auto;padding:.5rem 1rem;transition:background .2s}.retry-btn:hover{background:#b71c1c}.no-results{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:3rem 1rem;text-align:center}.no-results-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.no-results h3{color:#2c3e50;font-size:1.5rem;margin:0 0 .5rem}.no-results p{color:#7f8c8d;font-size:1rem;margin:0}.results-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:0 .5rem}.results-count{color:#7f8c8d;font-size:.95rem;font-weight:500}.songs-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:2rem}.load-more-section{display:flex;justify-content:center;padding:2rem 0}.load-more-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;min-width:150px;padding:.75rem 2rem;transition:all .2s}.load-more-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.load-more-btn:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.loading-section{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:3rem}.loading-section p{color:#7f8c8d;font-size:1rem;margin-top:1rem}@media (max-width:768px){.community-page{padding:1rem 0}.community-container{padding:0 .5rem}.page-header h1{font-size:2rem}.page-header p{font-size:1rem}.songs-grid{gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.results-header{align-items:flex-start}.error-message,.results-header{flex-direction:column;gap:.5rem}.error-message{text-align:center}.retry-btn{align-self:center;margin-left:0}}@media (max-width:480px){.songs-grid{grid-template-columns:1fr}}.collaboration-requests-page{margin:0 auto;max-width:1200px;padding:2rem}.page-header{margin-bottom:2rem;text-align:center}.page-header h1{color:#333;font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.page-header p{color:#666;font-size:1.1rem;margin:0}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}.tabs-container{margin-bottom:2rem}.tabs{border-bottom:2px solid #e9ecef;display:flex;gap:0}.tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:1rem;font-weight:500;padding:1rem 2rem;position:relative;transition:all .2s ease}.tab:hover{background:#f8f9fa;color:#667eea}.tab.active{background:#f8f9ff;border-bottom-color:#667eea;color:#667eea}.count-badge{background:#dc3545;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:700;margin-left:.5rem;min-width:1.5rem;padding:.2rem .5rem;text-align:center}.section{margin-bottom:3rem}.section h2{border-left:4px solid #667eea;color:#333;font-size:1.5rem;font-weight:600;margin:0 0 1rem;padding-left:1rem}.requests-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.request-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1.5rem;transition:all .2s ease}.request-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.request-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1rem}.album-cover,.album-cover-placeholder{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:60px;width:60px}.album-cover-placeholder{font-size:1.5rem}.song-info{flex:1 1}.song-title{color:#333;font-size:1.2rem;margin:0 0 .25rem}.song-artist{color:#666;font-size:.9rem;margin:0 0 .5rem}.song-status{background:#e9ecef;border-radius:6px;color:#495057;display:inline-block;font-size:.75rem;font-weight:500;max-width:fit-content;padding:.2rem .6rem;width:auto}.request-meta{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem;margin-left:auto}.status-badge{border-radius:6px;padding:.3rem .8rem}.status-pending{background:#fff3cd;color:#856404}.status-accepted{background:#d1edff;color:#004085}.status-rejected{background:#f8d7da;color:#721c24}.time{color:#999;font-size:.8rem}.request-content{margin-bottom:1rem}.request-user{color:#333;font-size:.95rem;margin:0 0 .75rem}.assigned-parts,.owner-response,.request-message,.requested-parts{background:#f8f9fa;border-radius:6px;font-size:.9rem;line-height:1.4;margin:.5rem 0;padding:.75rem}.request-message{background:#e3f2fd;border-left:3px solid #2196f3}.owner-response{background:#e8f5e8;border-left:3px solid #4caf50}.assigned-parts,.requested-parts{background:#fff3e0;border-left:3px solid #ff9800}.current-song-status{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;flex-wrap:wrap;font-size:.9rem;gap:.5rem;line-height:1.4;margin:.5rem 0;padding:.75rem}.song-status-badge{border-radius:6px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-left:.5rem;padding:.3rem .8rem;text-transform:uppercase}.song-status-badge.status-future-plans{background:#e1f5fe;color:#01579b}.song-status-badge.status-in-progress{background:#fff3e0;color:#e65100}.song-status-badge.status-released{background:#e8f5e8;color:#2e7d32}.request-actions{border-top:1px solid #e9ecef;display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem}.btn{border-radius:6px;font-size:.9rem;font-weight:500;min-height:40px;padding:.6rem 1.2rem;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary:hover:not(:disabled){background:#5a6fd8}.btn-accept{background:#28a745;color:#fff;flex:1 1}.btn-accept:hover:not(:disabled){background:#218838}.btn-reject{background:#dc3545;color:#fff;flex:1 1}.btn-reject:hover:not(:disabled){background:#c82333}.btn-reopen{background:#ffc107;color:#212529;flex:1 1}.btn-reopen:hover:not(:disabled){background:#e0a800}.btn-delete{background:#dc3545;color:#fff;font-size:.8rem;min-height:auto;padding:.4rem .8rem}.btn-delete:hover:not(:disabled){background:#c82333}.empty-state{background:#f8f9fa;border:1px dashed #dee2e6;border-radius:12px;color:#666;padding:3rem 2rem;text-align:center}.empty-state p{font-size:1rem;font-weight:500;margin:0 0 .5rem}.empty-state-subtext{color:#999;font-size:.9rem}.batch-card{border-left:4px solid #667eea}.batch-info{align-items:center;display:flex;flex:1 1;gap:.75rem}.batch-icon{font-size:2rem;opacity:.7}.batch-details{flex:1 1}.batch-title{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.batch-packs{color:#666;font-size:.85rem;margin:0}.song-status-tag{background:#e9ecef;border-radius:6px;color:#495057;display:inline-block;font-size:.75rem;font-weight:500;padding:.2rem .6rem}.username-link{color:#667eea;cursor:pointer;font-weight:700;transition:opacity .2s}.username-link:hover{opacity:.8}.pack-permissions-granted{align-items:center;background:#d4edda;border-left:3px solid #28a745;border-radius:6px;color:#155724;display:flex;font-size:.9rem;gap:.5rem;margin-top:.5rem;padding:.75rem}.permission-icon{font-size:1rem}.batch-songs-preview{margin-top:1rem}.expand-btn{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.expand-btn:hover{background:#e9ecef;border-color:#dee2e6}.batch-songs-list{border:1px solid #e9ecef;border-radius:6px;margin-top:.75rem;max-height:300px;overflow-y:auto}.batch-song-row{align-items:center;background:#fff;border-bottom:1px solid #f0f0f0;display:flex;gap:.75rem;padding:.75rem;transition:background .2s}.batch-song-row:last-child{border-bottom:none}.batch-song-row:hover{background:#f8f9fa}.batch-song-row .song-thumb{align-items:center;background:#e9ecef;border-radius:4px;display:flex;flex-shrink:0;height:36px;justify-content:center;overflow:hidden;width:36px}.batch-song-row .song-thumb img{height:100%;object-fit:cover;width:100%}.batch-song-row .song-thumb span{color:#adb5bd;font-size:1rem}.batch-song-row .song-details{flex:1 1;min-width:0}.batch-song-row .title{color:#2c3e50;font-size:.875rem;font-weight:500}.batch-song-row .artist,.batch-song-row .title{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-song-row .artist{color:#6c757d;font-size:.8rem}.batch-song-row .status-tag{border-radius:4px;flex-shrink:0;font-size:.7rem;padding:.2rem .5rem;white-space:nowrap}.batch-song-row .status-tag.status-future-plans{background:#e3f2fd;color:#1976d2}.batch-song-row .status-tag.status-in-progress{background:#fff3e0;color:#f57c00}.decision-select{background:#fff;border:1px solid #ced4da;border-radius:4px;cursor:pointer;flex-shrink:0;font-size:.8rem;padding:.375rem .5rem}.decision-select:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.item-status{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:24px;justify-content:center;width:24px}.item-status.approved{background:#d4edda;color:#155724}.item-status.rejected{background:#f8d7da;color:#721c24}.pack-permissions-option{background:#fff8e1;border:1px solid #ffe082;border-radius:8px;margin-top:1rem;padding:1rem}.permission-checkbox{align-items:flex-start;cursor:pointer;display:flex;gap:.75rem}.permission-checkbox input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;margin-top:2px;width:18px}.checkbox-text{color:#333;font-size:.9rem;font-weight:500}.permission-help{color:#856404;display:block;font-size:.8rem;font-weight:400;margin-top:.25rem}.btn-selective{background:#667eea;color:#fff;flex:1 1}.btn-selective:hover:not(:disabled){background:#5a6fd8}.status-partial{background:#ffe8cc;color:#945000}.status-cancelled{background:#e9ecef;color:#6c757d}@media (max-width:768px){.collaboration-requests-page{padding:1rem}.page-header h1{font-size:2rem}.tabs{flex-direction:column}.tab{border-right:none}.tab,.tab.active{border-bottom:1px solid #e9ecef}.tab.active{border-left:3px solid #667eea}.requests-grid{grid-template-columns:1fr}.request-header{align-items:flex-start;flex-direction:column}.request-meta{align-items:center;flex-direction:row;gap:1rem;justify-content:space-between;width:100%}.request-actions{flex-direction:column}}.profile-page{background:#f8f9fa;color:#333;min-height:100vh}.profile-container{margin:0 auto;max-width:1000px;padding:2rem}.profile-header{background:#fff;border:1px solid #e9ecef;border-radius:16px;box-shadow:0 2px 12px #00000014;margin-bottom:2rem;padding:2rem}.profile-header-content{align-items:flex-start;display:flex;gap:2rem}.profile-avatar{flex-shrink:0;height:100px;position:relative;width:100px}.profile-avatar img{object-fit:cover}.profile-avatar img,.profile-avatar-fallback{border:2px solid #e9ecef;border-radius:12px;height:100%;width:100%}.profile-avatar-fallback{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:2.5rem;font-weight:700;justify-content:center}.profile-info{flex:1 1}.profile-username{color:#212529;font-size:2rem;font-weight:700;margin:0 0 .5rem}.profile-display-name{color:#6c757d;font-size:1.25rem;font-weight:500;margin:0 0 1rem}.profile-details{margin-bottom:1.5rem}.detail-row{align-items:flex-start;border-bottom:1px solid #f1f3f4;display:flex;gap:1rem;padding:.75rem 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#6c757d;flex-shrink:0;font-size:.875rem;font-weight:600;min-width:140px}.detail-value{color:#212529;font-size:.875rem;font-weight:500;line-height:1.4;word-break:break-word}.website-link{color:#667eea;text-decoration:none;transition:color .2s}.website-link:hover{color:#495057;text-decoration:underline}.discord-link{border-radius:4px;color:#5865f2;font-weight:600;padding:2px 4px;text-decoration:none;transition:all .2s}.discord-link:hover{background-color:#5865f21a;color:#4752c4;text-decoration:none}.edit-profile-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.edit-profile-btn:hover{background:#5a67d8;transform:translateY(-1px)}.profile-content{grid-gap:2rem;display:grid;gap:2rem}.profile-section{background:#fff;border:1px solid #e9ecef;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow:hidden}.section-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem 2rem}.section-title{color:#212529;font-size:1.25rem;font-weight:600;margin:0}.section-count{background:#667eea;border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.section-content{padding:0}.achievements-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));padding:1.5rem}.achievement-item{align-items:center;background:#f8f9fa;border-left:4px solid;border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .2s}.achievement-item:hover{background:#e9ecef;transform:translateY(-2px)}.achievement-icon{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-shrink:0;font-size:2rem;height:3rem;justify-content:center;width:3rem}.achievement-info{flex:1 1}.achievement-info h4{color:#212529;font-size:1rem;font-weight:600;margin:0 0 .25rem}.achievement-info p{color:#6c757d;font-size:.875rem;margin:0 0 .5rem}.achievement-meta{align-items:center;display:flex;font-size:.75rem;font-weight:600;gap:.75rem}.rarity{border-radius:4px;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.rarity.legendary{background:#ff6b3533;color:#ff6b35}.rarity.epic{background:#9d4edd33;color:#9d4edd}.rarity.rare{background:#2196f333;color:#2196f3}.rarity.uncommon{background:#4caf5033;color:#4caf50}.rarity.common{background:#75757533;color:#757575}.points{color:#667eea}.packs-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));padding:1.5rem}.pack-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;transition:all .2s}.pack-item:hover{background:#fff;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.pack-item h4{color:#212529;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.pack-meta{color:#6c757d}.pack-description,.pack-meta{font-size:.875rem;margin:0 0 1rem}.pack-description{color:#495057;line-height:1.4}.pack-links{display:flex;flex-wrap:wrap;gap:.5rem}.songs-section{padding:0}.section-title-group{align-items:center;display:flex;gap:.75rem}.section-controls{align-items:center;display:flex;gap:.5rem}.group-toggle{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:.75rem;gap:.3rem;padding:.3rem .6rem;transition:all .2s ease}.group-toggle.active{background:#667eea;border-color:#667eea;color:#fff}.group-toggle:hover{background:#f8f9fa;border-color:#dee2e6}.group-toggle.active:hover{background:#5a67d8}.toggle-icon{font-size:.7rem}.artists-grouped-view{padding:1.5rem}.artist-group{background:#fff;border:1px solid #e9ecef;border-radius:12px;margin-bottom:1.5rem;overflow:hidden}.artist-group:last-child{margin-bottom:0}.artist-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;cursor:pointer;padding:1rem 1.5rem;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.artist-header:hover{background:#e9ecef}.artist-info{align-items:center;display:flex;gap:.75rem}.collapse-icon{color:#6c757d;font-size:.875rem;font-weight:700;text-align:center;transition:transform .2s ease;width:1rem}.artist-name{color:#212529;font-size:1.125rem;font-weight:600;margin:0}.song-count{color:#6c757d;font-size:.875rem;font-weight:500}.artist-songs{background:#fff;padding:1rem}.song-item{align-items:center;border:1px solid #0000;border-radius:8px;display:flex;gap:1rem;padding:.75rem;transition:background-color .2s ease}.song-item:hover{background:#f8f9fa;border-color:#e9ecef}.song-artwork{flex-shrink:0;height:48px;position:relative;width:48px}.album-cover{object-fit:cover}.album-cover,.album-cover-placeholder{border:1px solid #e9ecef;border-radius:6px;height:100%;width:100%}.album-cover-placeholder{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#6c757d;display:flex;font-size:1.25rem;justify-content:center}.song-details{align-items:center;display:flex;flex:1 1;justify-content:space-between;min-width:0}.song-title-block{display:flex;flex:1 1;flex-direction:column;min-width:0}.song-item .song-title{color:#212529;font-size:1rem;font-weight:600;line-height:1.3;margin:0 0 .25rem}.song-meta{align-items:center;color:#6c757d;display:flex;flex-wrap:wrap;font-size:.875rem;gap:.5rem}.album-name{font-weight:500}.pack-name{color:#666;font-size:.8rem;font-style:italic}.song-item .status-badge{font-size:.75rem;margin-left:.5rem;padding:.2rem .6rem}.artist-songs .pack-name{margin-left:auto}.songs-table-wrapper{overflow-x:auto}.songs-table{border-collapse:collapse;width:100%}.songs-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#495057;font-size:.875rem;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.songs-table td{border-bottom:1px solid #e9ecef;color:#495057;font-size:.875rem;padding:.75rem 1rem}.songs-table tr:hover{background:#f8f9fa}.songs-table tr:last-child td{border-bottom:none}.artwork-col{padding:.5rem!important;width:60px}.table-artwork{align-items:center;display:flex;justify-content:center}.table-album-cover{object-fit:cover}.table-album-cover,.table-album-cover-placeholder{border-radius:6px;box-shadow:0 1px 4px #0000001a;height:40px;width:40px}.table-album-cover-placeholder{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#6c757d;display:flex;font-size:1rem;justify-content:center}.song-title{color:#212529!important;font-weight:600}.status-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase;white-space:nowrap}.status-badge.released{background:#4caf5033;color:#4caf50}.status-badge.in-progress{background:#ffc10733;color:#ffc107}.status-badge.future-plans{background:#2196f333;color:#2196f3}.pagination-wrapper{border-top:1px solid #e9ecef;display:flex;justify-content:center;padding:1rem 1.5rem}.pagination{align-items:center;display:flex;gap:.5rem}.pagination button{background:#fff;border:1px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.pagination button:hover:not(:disabled){background:#f8f9fa;border-color:#dee2e6}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination button.active{background:#667eea;border-color:#667eea;color:#fff}.pagination-info{color:#6c757d;font-size:.875rem;margin:0 1rem}.profile-empty{color:#6c757d;padding:3rem 2rem;text-align:center}.profile-empty h3{color:#495057;margin:0 0 .5rem}.profile-error{background:#fff;border:1px solid #e9ecef;border-radius:16px;padding:3rem 2rem;text-align:center}.profile-error h2{color:#dc3545;margin:0 0 1rem}.profile-error p{color:#6c757d;margin:0 0 2rem}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;justify-content:center;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a67d8;transform:translateY(-1px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268;transform:translateY(-1px)}.btn-sm{font-size:.75rem;padding:.375rem .75rem}@media (max-width:768px){.profile-container{padding:1rem}.profile-header{padding:1.5rem}.profile-header-content{flex-direction:column;gap:1.5rem;text-align:center}.profile-avatar{align-self:center;height:80px;width:80px}.profile-username{font-size:1.75rem}.detail-row{flex-direction:column;gap:.5rem;padding:1rem 0}.detail-label{font-size:.8rem;min-width:auto}.detail-value{font-size:.9rem}.section-controls{align-items:flex-end;flex-direction:column;gap:.5rem}.group-toggle{font-size:.7rem;gap:.2rem;padding:.25rem .5rem}.artists-grouped-view{padding:1rem}.artist-header{padding:.75rem 1rem}.artist-name{font-size:1rem}.song-count{font-size:.75rem}.song-item{gap:.75rem;padding:.5rem}.song-artwork{height:40px;width:40px}.song-item .song-title{font-size:.9rem}.song-meta{font-size:.75rem}.achievements-grid,.packs-grid{grid-template-columns:1fr;padding:1rem}.section-header{padding:1rem 1.5rem}.section-title{font-size:1.125rem}.songs-table td,.songs-table th{font-size:.75rem;padding:.5rem}.artwork-col{padding:.3rem!important;width:50px}.table-album-cover,.table-album-cover-placeholder{font-size:.8rem;height:32px;width:32px}}.community-events-page{margin:0 auto;max-width:1200px;padding:2rem}.community-events-header{margin-bottom:2rem}.community-events-header h1{align-items:center;color:#333;display:flex;font-size:2rem;gap:.75rem;margin:0 0 .5rem}.community-events-header p{color:#666;margin:0}.active-event-alert{background:#fff;border:1px solid #ddd;border-left:4px solid #e94560;border-radius:8px;box-shadow:0 2px 8px #0000000d;flex-wrap:wrap;justify-content:space-between;margin-bottom:2rem;padding:1rem 1.25rem}.active-event-alert,.active-event-alert-content{align-items:center;display:flex;gap:1rem}.active-event-alert-icon{font-size:1.5rem}.active-event-alert-text h3{color:#e94560;font-size:1rem;margin:0 0 .25rem}.active-event-alert-text p{color:#666;font-size:.875rem;margin:0}.active-event-alert-cta{align-items:center;background:#e94560;border:none;border-radius:6px;color:#fff;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;text-decoration:none;transition:all .2s ease}.active-event-alert-cta:hover{background:#d63384}.events-list{display:flex;flex-direction:column;gap:1.5rem}.events-section{margin-bottom:2rem}.events-section h2{border-bottom:1px solid #eee;color:#555;font-size:.875rem;letter-spacing:.5px;margin:0 0 1rem;padding-bottom:.5rem;text-transform:uppercase}.event-card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #0000000d;overflow:hidden;transition:all .2s ease}.event-card:hover{border-color:#007bff;box-shadow:0 4px 12px #00000014}.event-card-banner{background:#f0f0f0;height:150px;object-fit:cover;width:100%}.event-card-content{padding:1.25rem}.event-card-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.event-card-title{flex:1 1}.event-card-title h3{color:#333;font-size:1.25rem;margin:0 0 .25rem}.event-card-theme{color:#e94560;font-size:.875rem;font-weight:500}.event-card-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.35rem;padding:.25rem .75rem;text-transform:uppercase}.event-card-status.active{background:#d4edda;color:#155724}.event-card-status.ended{background:#fff3cd;color:#856404}.event-card-status.revealed{background:#d1ecf1;color:#0c5460}.event-card-description{color:#555;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.event-card-meta{border-top:1px solid #eee;display:flex;flex-wrap:wrap;gap:1.5rem;padding-top:1rem}.event-card-meta-item{align-items:center;color:#888;display:flex;font-size:.8rem;gap:.5rem}.event-card-meta-value{color:#555;font-weight:500}.event-participants-section{border-top:1px solid #eee;margin-top:1rem;padding-top:1rem}.event-participants-toggle{align-items:center;background:none;border:none;color:#007bff;cursor:pointer;display:flex;font-size:.875rem;justify-content:space-between;padding:.5rem 0;transition:color .2s ease;width:100%}.event-participants-toggle:hover{color:#0056b3}.event-participants-content{margin-top:1rem}.event-songs-list{display:flex;flex-direction:column;gap:.75rem}.event-song-item{align-items:center;background:#f8f9fa;border:1px solid #eee;border-radius:8px;display:flex;gap:1rem;padding:.75rem}.event-song-cover{background:#e0e0e0;border-radius:6px;height:48px;object-fit:cover;width:48px}.event-song-info{flex:1 1}.event-song-info h4{color:#333;font-size:.9rem;margin:0 0 .125rem}.event-song-info p{color:#666;font-size:.8rem;margin:0}.event-song-author{color:#888;font-size:.75rem}.event-song-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.7rem;font-weight:500;gap:.35rem;padding:.25rem .625rem}.event-song-status.in-progress{background:#fff3cd;color:#856404}.event-song-status.done{background:#d4edda;color:#155724}.event-song-status.uploaded{background:#d1ecf1;color:#0c5460}.event-song-links{display:flex;flex-wrap:wrap;gap:.5rem}.event-song-link{align-items:center;background:#f0f0f0;border-radius:4px;color:#007bff;display:inline-flex;font-size:.7rem;gap:.25rem;padding:.25rem .5rem;text-decoration:none;transition:all .2s ease}.event-song-link:hover{background:#e3f2fd}.events-empty{color:#888;padding:4rem 2rem;text-align:center}.events-empty-icon{font-size:3rem;margin-bottom:1rem}.events-empty h3{color:#555;margin:0 0 .5rem}.events-empty p{margin:0}.events-loading{color:#666;padding:4rem 2rem;text-align:center}@media (max-width:768px){.community-events-page{padding:1rem}.active-event-alert{text-align:center}.active-event-alert,.active-event-alert-content,.event-card-header,.event-card-meta{flex-direction:column}.event-card-meta{gap:.75rem}}body{background:#f4f4f4;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;padding:0}.app-container{box-sizing:border-box;overflow-x:hidden;overflow-y:visible;padding:0;width:100%}.main-content{padding:calc(60px + 2rem) 4rem 2rem}h1{color:#333;font-size:2.2rem;letter-spacing:1px;margin-bottom:.5rem;text-align:center}.song-table{background:#fff;border-collapse:collapse;border-radius:6px;box-shadow:0 2px 8px #0000000d;overflow:hidden;width:100%}.song-table td,.song-table th{border-bottom:1px solid #eee;padding:1rem;text-align:left}.song-table th{background-color:#fafafa;color:#555}.status{border-radius:1rem;display:inline-block;font-size:.9rem;font-weight:700;padding:.25rem .75rem}.status.In\ Progress,.status.wip{background:#fff3cd;color:#856404}.status.Future\ Plans{background:#d1ecf1;color:#0c5460}.status.Released{background:#e3f2fd;color:#0d47a1}.unified-nav{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 12px #00000026;box-sizing:border-box;justify-content:space-between;margin:0;max-width:100vw;min-height:60px;overflow-x:hidden;overflow-y:visible;padding:.75rem 2rem;position:fixed;top:0;transition:box-shadow .2s;width:100%;z-index:10000}.nav-left,.unified-nav{align-items:center;display:flex}.nav-left{gap:1.5rem}.nav-brand{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.5px}.nav-links{align-items:center;display:flex;flex-wrap:nowrap;gap:.25rem}.nav-links a{border:1px solid #0000;border-radius:6px;color:#ffffffe6;font-size:.9rem;font-weight:600;padding:.4rem .75rem;text-decoration:none;transition:all .2s}.nav-links a:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.nav-links a.active{background:#fff3;border-color:#ffffff4d;box-shadow:0 2px 8px #0000001a;color:#fff}.nav-right{gap:1rem}.nav-right,.nav-user-info{align-items:center;display:flex}.nav-user-info{color:#fff;gap:.75rem}.nav-username{color:#ffffffe6;font-size:.9rem;font-weight:500}.nav-points{align-items:center;background:#ffffff26;border:1px solid #fff3;border-radius:20px;display:flex;gap:.25rem;padding:.25rem .5rem}.points-value{color:gold;font-size:.85rem;font-weight:700}.points-label{color:#ffffffb3;font-size:.7rem}.nav-online-users{display:inline-block;position:relative}.online-count{color:#ffffffb3;cursor:pointer;font-size:.75rem;text-decoration:underline;text-decoration-style:dotted}.online-tooltip{background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;margin-top:.5rem;max-width:250px;min-width:150px;padding:.5rem .75rem;position:absolute;right:0;top:100%;z-index:10000}.tooltip-header{color:#333;font-size:.75rem;font-weight:700;margin-bottom:.25rem}.tooltip-users{color:#666;font-size:.7rem}.tooltip-users div{margin-bottom:.1rem}.nav{display:none}.editable-cell{cursor:pointer;position:relative}.editable-cell:hover{background-color:#f0f0f0;border-radius:4px}.editable-cell:after{content:"✏️";font-size:.8rem;opacity:.4;position:absolute;right:5px;top:50%;transform:translateY(-50%)}.editable-cell[style*="cursor: default"]:after{display:none}td input{border:1px solid #ccc;border-radius:4px;font-size:1rem;padding:2px 4px;width:100%}.bulk-actions{align-items:center;background:#f5f5f5;border-radius:6px;display:flex;gap:12px;margin-bottom:10px;padding:8px 12px}th.sortable{cursor:pointer;padding-right:10px;position:relative;-webkit-user-select:none;user-select:none}th.sortable:hover{background-color:#f0f0f0}th.sortable:after{font-size:.75em;margin-left:5px}.group-header td{background-color:#f0f0f0;font-weight:700}.group-header button{background:none;border:none;cursor:pointer;font-size:1rem}.group-header{background-color:#f2f2f2;border-top:2px solid #ccc;font-size:1.1em}.group-subheader{background-color:#fafafa;font-style:italic}.stats-container{font-family:sans-serif;margin:auto;max-width:800px;padding:2rem}.stats-card{background:#fafafa;border:1px solid #ddd;border-radius:10px;box-shadow:0 2px 4px #0000000d;margin-bottom:1.5rem;padding:1rem 1.5rem}.stats-card h3{margin-bottom:.5rem}.stats-card ul{list-style:none;margin:0;padding:0}.stats-card li{display:flex;justify-content:space-between;padding:.3rem 0}.count{color:#555;font-weight:700}.toggle-btn{background:#eee;border:none;border-radius:5px;cursor:pointer;font-size:.85rem;margin-top:.5rem;padding:.3rem .7rem}.toggle-btn:hover{background:#ddd}.song-card{align-items:center;background:#fff;border:1px solid #ddd;border-radius:.5rem;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1rem}.song-card-left{flex:1 1}.song-card-right{align-items:center;display:flex;gap:1rem}.progress-bar-container{align-items:flex-end;display:flex;flex-direction:column;min-width:150px}.progress-bar-bg{background:#eee;border-radius:3px;height:6px;margin-bottom:.25rem;overflow:hidden;width:100%}.progress-bar-fill{background:#aaa;height:100%}.group-toggle{border:1px solid #ccc;border-radius:999px;display:inline-flex;font-size:.9rem;margin-bottom:1rem;overflow:hidden}.group-toggle span{background:#f7f7f7;cursor:pointer;padding:.5rem 1rem;transition:background .3s,color .3s;-webkit-user-select:none;user-select:none}.group-toggle span.active{background:#1db954;color:#fff;font-weight:700}.toggle-all-button{background:#f0f0f0;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:background .2s ease-in-out}.toggle-all-button:hover{background:#e0e0e0}.loading-spinner{color:#555;margin-bottom:1rem;text-align:center}.spinner{animation:spin .8s linear infinite;border:4px solid #ddd;border-radius:50%;border-top-color:#4caf50;height:32px;margin:0 auto;width:32px}.pretty-checkbox{appearance:none;-webkit-appearance:none;background:#fff;border:2px solid #bbb;border-radius:4px;box-shadow:0 1px 2px #00000008;cursor:pointer;height:1em;margin:0;outline:none;position:relative;transition:border-color .2s,box-shadow .2s;vertical-align:middle;width:1em}.pretty-checkbox:checked{background:linear-gradient(135deg,#4f8cff 60%,#7fd6ff);border-color:#4f8cff}.pretty-checkbox:checked:after{border:solid #fff;border-width:0 .14em .14em 0;content:"";display:block;height:.55em;left:.22em;position:absolute;top:.05em;transform:rotate(45deg);width:.28em}.pretty-checkbox:focus{border-color:#4f8cff;box-shadow:0 0 0 2px #cce3ff}@media (max-width:992px){.song-table td,.song-table th{font-size:.9rem;padding:.75rem .5rem}}@media (max-width:768px){.app-container{padding:1rem}h1{font-size:1.8rem;margin-bottom:1rem}.unified-nav{flex-direction:column;gap:1rem;min-height:auto;padding:1rem}.main-content{padding:1rem}.nav-left{justify-content:space-between;width:100%}.nav-brand{font-size:1.3rem}.nav-links{flex-wrap:wrap;gap:.3rem}.nav-links a{font-size:.8rem;min-width:60px;padding:.3rem .6rem;text-align:center}.nav-right{border-top:1px solid #fff3;justify-content:space-between;padding-top:.75rem;width:100%}.nav-user-info{gap:.5rem}.nav-username{font-size:.8rem}.nav-points{padding:.2rem .4rem}.points-value{font-size:.75rem}.points-label{font-size:.65rem}.nav{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:.5rem}.nav a{font-size:.9rem;min-width:80px;padding:.4rem .8rem;text-align:center}.song-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.song-table{min-width:600px}.song-table td,.song-table th{font-size:.8rem;max-width:120px;overflow:hidden;padding:.4rem .3rem;text-overflow:ellipsis;white-space:nowrap}.song-table th{font-size:.7rem;padding:.4rem .3rem}.song-table td:nth-child(n+7),.song-table th:nth-child(n+7){display:none}.status{font-size:.75rem;padding:.2rem .5rem}.bulk-actions{flex-direction:column;gap:8px;padding:12px}.stats-card,.stats-container{padding:1rem}.stats-card{margin-bottom:1rem}.song-card{align-items:flex-start;flex-direction:column;gap:.75rem}.song-card-right{justify-content:space-between;width:100%}.progress-bar-container{min-width:120px}.group-toggle{justify-content:center;width:100%}.group-toggle span{flex:1 1;font-size:.8rem;padding:.4rem .5rem;text-align:center}}@media (max-width:640px){.app-container{padding:.875rem}h1{font-size:1.6rem}.unified-nav{padding:.75rem}.nav-brand{font-size:1.2rem}.nav-links{gap:.25rem}.nav-links a{font-size:.75rem;min-width:50px;padding:.25rem .5rem}.nav-user-info{gap:.4rem}.nav-username{font-size:.75rem}.nav{gap:.375rem;padding:.45rem}.nav a{font-size:.85rem;min-width:75px;padding:.35rem .7rem}.song-table{min-width:500px}.song-table td,.song-table th{font-size:.8rem;max-width:100px;padding:.35rem .25rem}.song-table td:nth-child(n+6),.song-table th:nth-child(n+6){display:none}.status{font-size:.7rem;padding:.175rem .4rem}}@media (max-width:480px){.app-container{padding:.75rem}h1{font-size:1.5rem;letter-spacing:.5px}.unified-nav{gap:.75rem;padding:.5rem}.nav-left{gap:1rem}.nav-brand{font-size:1.1rem}.nav-links{flex-wrap:wrap;gap:.2rem}.nav-links a{font-size:.7rem;min-width:45px;padding:.2rem .4rem}.nav-right{gap:.5rem;padding-top:.5rem}.nav-user-info{align-items:flex-start;flex-direction:column;gap:.3rem}.nav-username{font-size:.7rem}.nav-points{padding:.15rem .3rem}.points-value{font-size:.65rem}.points-label{font-size:.6rem}.nav{gap:.25rem;padding:.4rem}.nav a{font-size:.8rem;min-width:70px;padding:.3rem .6rem}.song-table{min-width:400px}.song-table td,.song-table th{font-size:.75rem;max-width:80px;overflow:hidden;padding:.3rem .2rem;text-overflow:ellipsis}.song-table th{font-size:.65rem;padding:.3rem .2rem}.song-table td:nth-child(n+5),.song-table th:nth-child(n+5){display:none}.song-table td:first-child,.song-table th:first-child{max-width:120px;max-width:30px;min-width:90px;padding:.2rem .1rem;width:30px}.status{font-size:.6rem;padding:.15rem .3rem;white-space:nowrap}.bulk-actions{flex-wrap:wrap;padding:8px}.bulk-actions>*{font-size:.75rem;padding:.3rem .5rem}.stats-card{padding:.5rem}.progress-bar-container{min-width:80px}.group-toggle span{font-size:.7rem;padding:.25rem .3rem}.pretty-checkbox{height:.8em;width:.8em}.song-card{background:#f8f9fa;border:1px solid #e0e0e0;padding:.5rem}.song-card-right{flex-wrap:wrap;gap:.4rem;max-width:100%}.song-card-right>div{display:flex;flex-wrap:wrap;gap:.3rem;max-width:100%}.song-card-right .status,.song-card-right button{flex-shrink:0;font-size:.6rem;margin:.1rem;max-width:calc(50% - .2rem);overflow:hidden;padding:.15rem .3rem;text-overflow:ellipsis;white-space:nowrap}.song-table{background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.song-table th{background-color:#e9ecef}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.53a73b93.css.map*/