.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background-color:var(--bg-secondary);border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 8px 32px #0000004d}.auth-card h1{font-size:32px;font-weight:700;color:var(--accent);text-align:center;margin-bottom:8px}.auth-card h2{font-size:24px;font-weight:600;text-align:center;margin-bottom:32px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input{width:100%;padding:12px;background-color:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.submit-btn{width:100%;padding:12px;background-color:var(--accent);color:#fff;border-radius:6px;font-size:16px;font-weight:600;transition:background-color .2s;margin-top:8px}.submit-btn:hover:not(:disabled){background-color:var(--accent-hover)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#e221341a;border:1px solid var(--error);color:var(--error);padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px}.auth-link{text-align:center;margin-top:24px;color:var(--text-secondary);font-size:14px}.auth-link a{color:var(--accent);font-weight:500}.auth-link a:hover{text-decoration:underline}.edit-track-modal{background:var(--bg-secondary);border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.modal-close-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.modal-close-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.edit-track-form{padding:24px}.form-error{padding:12px;background-color:#ff44441a;border:1px solid #ff4444;border-radius:4px;color:#f44;margin-bottom:20px;font-size:14px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.form-group input[type=text],.form-group input[type=number]{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1db9541a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cover-art-group{margin-bottom:24px}.cover-art-preview-container{display:flex;flex-direction:column;align-items:center;gap:12px}.cover-art-preview{width:200px;height:200px;object-fit:cover;border-radius:8px;box-shadow:0 4px 12px #0000004d}.cover-art-placeholder{width:200px;height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:8px;color:var(--text-secondary)}.cover-art-upload-btn{padding:10px 20px;border-radius:4px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.cover-art-upload-btn:hover{background:var(--bg-primary);border-color:var(--accent);color:var(--accent)}.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.recognize-buttons{display:flex;gap:8px}.form-actions-right{display:flex;gap:12px}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;border:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#1ed760;transform:scale(1.02)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-primary);border-color:var(--accent)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.edit-track-modal{width:95%;max-height:95vh}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column;gap:12px}.form-actions-right{width:100%;flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}}.library{padding:32px 32px 160px}.library-header{margin-bottom:32px}.library-header h1{font-size:32px;font-weight:700;margin-bottom:16px}.search-input{width:100%;max-width:500px;padding:12px 16px;background-color:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:16px}.search-input:focus{outline:none;border-color:var(--accent)}.tracks-container{overflow-x:auto}.tracks-table thead{border-bottom:2px solid var(--border);position:sticky;top:0;background-color:var(--bg-primary);z-index:10}.tracks-table th{text-align:left;padding:12px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}.tracks-table th:first-child{width:60px;text-align:center}.tracks-table th:last-child{width:100px;text-align:center}.track-row{border-bottom:1px solid var(--border);transition:background-color .2s;cursor:pointer}.track-row td{padding:12px 16px;vertical-align:middle}.track-cover-cell{width:60px;text-align:center}.track-cover{width:48px;height:48px;border-radius:4px;object-fit:cover}.track-cover-placeholder{width:48px;height:48px;background:linear-gradient(135deg,var(--accent, #1db954),#1ed760);border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto}.track-title-cell{min-width:200px}.track-title{font-size:14px;font-weight:500;color:var(--text-primary)}.track-artist-cell,.track-album-cell{min-width:150px;font-size:14px;color:var(--text-secondary)}.track-genre-cell{min-width:100px;font-size:14px;color:var(--text-secondary)}.track-year-cell{width:80px;font-size:14px;color:var(--text-secondary);text-align:center}.track-duration-cell{width:80px;font-size:14px;color:var(--text-secondary);text-align:right}.track-actions-cell{width:100px;text-align:center;position:relative}.track-actions{position:relative;display:inline-block}.action-menu{position:absolute;top:100%;right:0;margin-top:4px;background-color:var(--bg-primary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:1500;min-width:200px;overflow:hidden}.action-menu-item{width:100%;padding:12px 16px;background-color:transparent;border:none;color:var(--text-primary);cursor:pointer;font-size:14px;text-align:left;display:flex;align-items:center;gap:12px;transition:background-color .2s}.action-menu-item:hover{background-color:var(--bg-secondary)}.action-menu-item.danger{color:var(--error, #ff4444)}.action-menu-item.danger:hover{background-color:#ff44441a}.modal-content{background-color:var(--bg-primary);border-radius:12px;padding:32px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.modal-content h2{margin:0 0 8px;font-size:24px;font-weight:700}.modal-subtitle{margin:0 0 24px;font-size:14px;color:var(--text-secondary)}.no-playlists{text-align:center;padding:32px}.no-playlists p{margin-bottom:16px;color:var(--text-secondary)}.playlists-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.playlist-select-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.playlist-select-item:hover{background-color:var(--bg-tertiary);border-color:var(--accent, #1db954)}.playlist-select-info{flex:1}.playlist-select-name{font-size:14px;font-weight:600;margin-bottom:4px}.playlist-select-count{font-size:12px;color:var(--text-secondary)}@media (max-width: 768px){.library{padding:60px 12px 12px}.library-header{margin-bottom:20px;position:sticky;top:0;background-color:var(--bg-primary);z-index:10;padding-bottom:12px}.library-header h1{font-size:20px;margin-bottom:12px;font-weight:600}.search-input{font-size:14px;padding:10px 14px}.tracks-container{overflow-x:visible}.tracks-table{display:none}.tracks-table-mobile{display:block}.track-card{background-color:var(--bg-secondary);position:relative;border-radius:8px;padding:12px;margin-bottom:8px;display:flex;align-items:center;gap:12px;transition:background-color .2s}.track-card:active{background-color:var(--bg-tertiary)}.track-card-cover{width:56px;height:56px;border-radius:6px;object-fit:cover;flex-shrink:0}.track-card-cover-placeholder{width:56px;height:56px;background:linear-gradient(135deg,var(--accent, #1db954),#1ed760);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.track-card-info{flex:1;min-width:0}.track-card-title{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-card-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-card-duration{font-size:12px;color:var(--text-secondary);margin-left:auto;padding-left:8px}.modal-content{width:95%;padding:20px;max-height:85vh}.action-menu-mobile{position:fixed;bottom:100px;left:50%;transform:translate(-50%);right:auto;width:calc(100% - 32px);max-width:400px;margin-top:0;top:auto}.track-card-actions{position:relative;display:flex;align-items:center;margin-left:8px}}.split-modal{max-width:600px}.modal-info{margin:0 0 20px;font-size:13px;color:var(--text-secondary);padding:8px 12px;background-color:var(--bg-secondary);border-radius:6px}.split-timestamps-form{margin-bottom:24px}.split-input-group{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.split-time-input{flex:1;min-width:100px;padding:10px 12px;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px}.split-time-input:focus{outline:none;border-color:var(--accent, #1db954)}.split-title-input{flex:2;min-width:150px;padding:10px 12px;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px}.split-title-input:focus{outline:none;border-color:var(--accent, #1db954)}.btn-add-timestamp{padding:10px 16px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-timestamp:hover{background-color:var(--accent-hover, #1ed760)}.split-timestamps-list{margin-top:20px;padding:16px;background-color:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.split-timestamps-list h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary)}.split-timestamps-list ul{list-style:none;padding:0;margin:0}.split-timestamp-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background-color:var(--bg-primary);border-radius:6px;margin-bottom:8px;border:1px solid var(--border)}.split-timestamp-item:last-child{margin-bottom:0}.timestamp-time{font-size:12px;font-weight:600;color:var(--accent, #1db954);min-width:100px;font-family:monospace}.timestamp-title{flex:1;font-size:14px;color:var(--text-primary)}.btn-remove-timestamp{padding:6px;background-color:transparent;border:none;color:var(--error, #ff4444);cursor:pointer;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.btn-remove-timestamp:hover{background-color:#ff44441a}@media (max-width: 768px){.split-input-group{flex-direction:column}.split-time-input,.split-title-input,.btn-add-timestamp{width:100%}.split-timestamp-item{flex-wrap:wrap}.timestamp-time{min-width:auto}}.upload{padding:32px 32px 160px}.upload h1{font-size:32px;font-weight:700;margin-bottom:32px}.upload h2{font-size:20px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.youtube-search-section,.youtube-section,.upload-section{margin-bottom:48px}.youtube-search-form{display:flex;flex-direction:column;gap:12px}.youtube-search-input-group{display:flex;gap:12px;align-items:stretch}.youtube-search-input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit}.youtube-search-input:focus{outline:none;border-color:var(--accent, #1db954)}.youtube-search-input:disabled{opacity:.6;cursor:not-allowed}.youtube-search-limit{padding:12px 16px;border:1px solid var(--border);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit;cursor:pointer;min-width:140px}.youtube-search-limit:focus{outline:none;border-color:var(--accent, #1db954)}.youtube-search-limit:disabled{opacity:.6;cursor:not-allowed}.album-only-checkbox-label{display:flex;align-items:center;gap:8px;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer;white-space:nowrap;transition:all .2s}.album-only-checkbox-label:hover{border-color:var(--accent, #1db954);background-color:var(--bg-tertiary)}.album-only-checkbox-label:has(.album-only-checkbox:disabled){opacity:.6;cursor:not-allowed}.album-only-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--accent, #1db954)}.album-only-checkbox:disabled{cursor:not-allowed}.youtube-search-btn{padding:12px 24px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.youtube-search-btn:hover:not(:disabled){background-color:var(--accent-hover, #1ed760);transform:scale(1.02)}.youtube-search-btn:disabled{opacity:.6;cursor:not-allowed}.youtube-search-error{font-size:14px;color:var(--error, #ff4444);padding:12px;background-color:#ff44441a;border-radius:6px;border:1px solid var(--error, #ff4444)}.youtube-search-results{margin-top:24px}.youtube-search-results h3{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.search-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.search-result-card{background-color:var(--bg-secondary);border-radius:12px;overflow:hidden;border:1px solid var(--border);transition:all .2s;display:flex;flex-direction:column}.search-result-card:hover{border-color:var(--accent, #1db954);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.result-thumbnail{width:100%;aspect-ratio:16 / 9;overflow:hidden;background-color:var(--bg-tertiary)}.result-thumbnail img{width:100%;height:100%;object-fit:cover}.result-content{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}.result-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-channel{font-size:14px;color:var(--text-secondary);margin:0}.result-meta{display:flex;gap:12px;align-items:center;font-size:12px;color:var(--text-secondary);margin-top:4px}.result-duration{font-weight:500}.result-views{opacity:.8}.result-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.album-badge{display:inline-block;padding:4px 8px;background-color:var(--accent, #1db954);color:#fff;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.result-description{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:8px 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.result-timestamps{margin:12px 0;padding:10px;background-color:#1db9541a;border-radius:6px;border:1px solid rgba(29,185,84,.3)}.result-timestamps strong{display:block;font-size:12px;color:var(--accent, #1db954);margin-bottom:6px}.timestamps-list{list-style:none;padding:0;margin:0;font-size:12px;color:var(--text-primary)}.timestamps-list li{padding:4px 0 4px 12px;position:relative}.timestamps-list li:before{content:"▶";position:absolute;left:0;font-size:10px;color:var(--accent, #1db954)}.timestamps-more{font-style:italic;color:var(--text-secondary)}.result-actions{margin-top:auto;display:flex;gap:8px;flex-wrap:wrap}.result-download-status{margin-top:12px;padding:12px;background-color:var(--bg-tertiary);border-radius:8px;border-left:4px solid var(--text-secondary)}.result-download-status.queue-item-pending{border-left-color:var(--text-secondary)}.result-download-status.queue-item-downloading{border-left-color:var(--accent, #1db954)}.result-download-status.queue-item-completed{border-left-color:var(--accent, #1db954);opacity:.8}.result-download-status.queue-item-failed{border-left-color:var(--error, #ff4444)}.result-download-status.queue-item-paused{border-left-color:var(--text-secondary);opacity:.7}.result-download-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.result-download-status-info{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600}.result-download-actions{display:flex;gap:6px;align-items:center}.result-download-action-btn{padding:4px 6px;background-color:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.result-download-action-btn:hover{background-color:var(--bg-secondary);border-color:var(--accent, #1db954);color:var(--accent, #1db954)}.result-download-progress{margin-top:8px}.result-download-message{font-size:12px;color:var(--text-secondary);margin-bottom:6px}.result-download-progress-info{display:flex;gap:12px;font-size:12px;color:var(--text-secondary);margin-top:6px}.result-download-error{font-size:12px;color:var(--error, #ff4444);margin-top:8px}.result-download-success{font-size:12px;color:var(--accent, #1db954);margin-top:8px}.result-download-btn{flex:1;min-width:120px;padding:10px 16px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.result-download-btn:hover:not(:disabled){background-color:var(--accent-hover, #1ed760);transform:scale(1.02)}.result-download-btn:disabled{opacity:.6;cursor:not-allowed}.result-parse-btn{padding:10px 16px;background-color:transparent;color:var(--accent, #1db954);border:2px dashed var(--accent, #1db954);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.result-parse-btn:hover:not(:disabled){background-color:var(--accent, #1db954);color:#fff;border-style:solid;transform:scale(1.02)}.result-parse-btn:disabled{opacity:.6;cursor:not-allowed}.result-parse-btn .spinning{animation:spin 1s linear infinite}.youtube-form{display:flex;flex-direction:column;gap:12px}.youtube-input-group{display:flex;gap:12px}.youtube-input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit}.youtube-input:focus{outline:none;border-color:var(--accent, #1db954)}.youtube-input:disabled{opacity:.6;cursor:not-allowed}.youtube-download-btn{padding:12px 24px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.youtube-download-btn:hover:not(:disabled){background-color:var(--accent-hover, #1ed760);transform:scale(1.02)}.youtube-download-btn:disabled{opacity:.6;cursor:not-allowed}.youtube-hint{font-size:12px;color:var(--text-secondary);padding:8px 12px;background-color:var(--bg-secondary);border-radius:6px}.youtube-error{font-size:14px;color:var(--error, #ff4444);padding:12px;background-color:#ff44441a;border-radius:6px;border:1px solid var(--error, #ff4444)}.youtube-progress{padding:16px;border-radius:8px;font-size:14px;font-weight:500}.youtube-progress.downloading,.youtube-progress.success{color:var(--accent, #1db954);background-color:#1db9541a;border:1px solid var(--accent, #1db954)}.progress-message{margin-bottom:12px}.progress-bar-container{display:flex;align-items:center;gap:12px}.progress-bar{flex:1;height:8px;background-color:#ffffff1a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:var(--accent, #1db954);border-radius:4px;transition:width .3s ease}.progress-fill.progress-indeterminate{width:30%;animation:progress-indeterminate 1.5s ease-in-out infinite;background:linear-gradient(90deg,transparent,var(--accent, #1db954),transparent)}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}.youtube-progress.error{color:var(--error, #ff4444);background-color:#ff44441a;border:1px solid var(--error, #ff4444)}.upload-area{border:2px dashed var(--border);border-radius:12px;padding:64px;text-align:center;cursor:pointer;transition:all .2s;position:relative}.upload-area:hover{border-color:var(--accent);background-color:var(--bg-secondary)}.upload-area p{font-size:18px;color:var(--text-secondary);margin-bottom:16px}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.files-list{margin-top:32px}.files-list h2{font-size:20px;font-weight:600;margin-bottom:16px}.file-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--bg-secondary);border-radius:8px;margin-bottom:8px}.file-item button{padding:6px 12px;background-color:var(--error);color:#fff;border-radius:4px;font-size:14px}@media (max-width: 768px){.upload{padding:60px 12px 140px}.upload h1{font-size:20px;font-weight:600;margin-bottom:20px}.upload h2{font-size:16px;margin-bottom:12px}.youtube-search-section,.youtube-section,.upload-section{margin-bottom:24px}.youtube-search-input-group,.youtube-input-group{flex-direction:column;gap:12px}.youtube-search-input,.youtube-search-limit{width:100%;font-size:14px;padding:10px 14px}.youtube-search-btn{width:100%;padding:12px 20px;font-size:14px}.search-results-grid{grid-template-columns:1fr;gap:12px}.search-result-card{border-radius:8px}.result-content{padding:12px}.result-title{font-size:14px}.result-channel{font-size:13px}.result-description{font-size:12px;-webkit-line-clamp:2}.youtube-input{width:100%;font-size:14px;padding:10px 14px}.youtube-download-btn{width:100%;padding:12px 20px;font-size:14px}.youtube-hint{font-size:11px;padding:8px 10px}.upload-area{padding:32px 16px}.upload-area p{font-size:14px}.files-list{margin-top:24px}.files-list h2{font-size:16px}.file-item{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px}.file-item button{width:100%;padding:8px 12px}}.upload-btn{margin-top:16px;padding:12px 24px;background-color:var(--accent);color:#fff;border-radius:8px;font-size:16px;font-weight:600;transition:background-color .2s}.upload-btn:hover:not(:disabled){background-color:var(--accent-hover)}.upload-btn:disabled{opacity:.6;cursor:not-allowed}.progress-bar{margin-top:16px;width:100%;height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:var(--accent);transition:width .3s}.download-queue-section{margin-bottom:48px}.queue-list{display:flex;flex-direction:column;gap:12px}.queue-item{background-color:var(--bg-secondary);border-radius:12px;padding:16px;border:1px solid var(--border);transition:all .2s}.queue-item-pending{border-left:4px solid var(--text-secondary)}.queue-item-downloading{border-left:4px solid var(--accent, #1db954)}.queue-item-completed{border-left:4px solid var(--accent, #1db954);opacity:.8}.queue-item-failed{border-left:4px solid var(--error, #ff4444)}.queue-item-paused{border-left:4px solid var(--text-secondary);opacity:.7}.queue-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.queue-item-status{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}.status-icon{flex-shrink:0}.status-icon.completed{color:var(--accent, #1db954)}.status-icon.failed{color:var(--error, #ff4444)}.status-icon.downloading{color:var(--accent, #1db954)}.status-icon.pending,.status-icon.paused{color:var(--text-secondary)}.status-icon.spinning{animation:spin 1s linear infinite}.queue-item-actions{display:flex;gap:8px;align-items:center}.queue-action-btn{padding:6px 8px;background-color:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.queue-pause-btn:hover{background-color:var(--text-secondary);border-color:var(--text-secondary);color:#fff}.queue-resume-btn:hover{background-color:var(--accent, #1db954);border-color:var(--accent, #1db954);color:#fff}.queue-cancel-btn:hover{background-color:var(--error, #ff4444);border-color:var(--error, #ff4444);color:#fff}.queue-item-url{font-size:13px;color:var(--text-secondary);word-break:break-all;margin-bottom:12px}.queue-item-progress{margin-top:12px}.queue-item-progress .progress-bar{margin-bottom:8px}.progress-status-message{font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.progress-info{display:flex;gap:16px;align-items:center;font-size:12px;color:var(--text-secondary)}.progress-speed,.progress-eta{font-weight:500}.queue-item-error{margin-top:12px;padding:8px 12px;background-color:#ff44441a;border-radius:6px;color:var(--error, #ff4444);font-size:13px}.queue-item-success{margin-top:12px;padding:8px 12px;background-color:#1db9541a;border-radius:6px;color:var(--accent, #1db954);font-size:13px;font-weight:500}@media (max-width: 768px){.download-queue-section{margin-bottom:24px}.queue-item{padding:12px}.queue-item-header{flex-direction:column;align-items:flex-start;gap:8px}.queue-item-actions{align-self:flex-end;width:100%;justify-content:flex-end}.progress-info{flex-direction:column;align-items:flex-start;gap:4px}}.selected-count{color:var(--accent);font-weight:600}.track-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0;width:100%}.track-checkbox{cursor:pointer;width:16px;height:16px;flex-shrink:0}.track-time{font-weight:500;color:var(--text-secondary);min-width:60px;font-size:12px}.track-title{flex:1;font-size:13px}.track-selected{background-color:#1db9540d;border-radius:4px;padding:2px 4px}.timestamps-more.clickable{cursor:pointer;color:var(--accent);font-weight:500;text-decoration:underline}.timestamps-more.clickable:hover{color:var(--accent-hover)}.playlist-modal{max-width:500px;width:90%}.modal-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.modal-info{font-size:13px;color:var(--text-secondary);margin-bottom:20px;padding:8px 12px;background-color:var(--bg-secondary);border-radius:6px}.playlist-options{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.radio-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:6px;transition:background-color .2s}.radio-option:hover{background-color:var(--bg-secondary)}.radio-option input[type=radio]{cursor:pointer;width:18px;height:18px;flex-shrink:0}.radio-option span{font-size:14px;color:var(--text-primary)}.playlist-select,.playlist-name-input{margin-left:26px;padding:10px 12px;border:1px solid var(--border);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit;width:calc(100% - 26px)}.playlist-select{cursor:pointer}.playlist-name-input:focus,.playlist-select:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-cancel,.btn-primary{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-primary{background-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.playlist-modal{width:95%;max-width:none}.modal-actions{flex-direction:column}.btn-cancel,.btn-primary{width:100%}.playlist-select,.playlist-name-input{width:calc(100% - 26px)}}.playlists{padding:32px 32px 160px}.playlists-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.playlists-header h1{font-size:32px;font-weight:700}.create-playlist-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.create-playlist-btn:hover{transform:scale(1.05);background-color:var(--accent-hover, #1ed760)}.playlists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.playlist-card{background-color:var(--bg-secondary);border-radius:8px;padding:20px;transition:all .2s;cursor:pointer;display:flex;flex-direction:column;align-items:center;text-align:center}.playlist-card:hover{background-color:var(--bg-tertiary);transform:translateY(-2px)}.playlist-icon{width:120px;height:120px;background:linear-gradient(135deg,var(--accent, #1db954),#1ed760);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:#fff;overflow:hidden;position:relative}.playlist-thumbnail{width:100%;height:100%;object-fit:cover}.playlist-name{font-size:16px;font-weight:600;margin-bottom:8px;width:100%}.playlist-info{font-size:14px;color:var(--text-secondary)}.loading,.empty-state{text-align:center;padding:64px;color:var(--text-secondary);font-size:18px;display:flex;flex-direction:column;align-items:center;gap:16px}.empty-state p{margin:0}.create-first-playlist-btn{padding:12px 24px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.create-first-playlist-btn:hover{transform:scale(1.05);background-color:var(--accent-hover, #1ed760)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background-color:var(--bg-primary);border-radius:12px;padding:32px;width:90%;max-width:500px;box-shadow:0 8px 32px #0000004d}.modal-content h2{margin:0 0 24px;font-size:24px;font-weight:700}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent, #1db954)}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn-cancel,.btn-primary{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background-color:var(--bg-secondary);color:var(--text-primary)}.btn-cancel:hover{background-color:var(--bg-tertiary)}.btn-primary{background-color:var(--accent, #1db954);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover, #1ed760)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.playlists{padding:60px 12px 140px}.playlists-header{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:20px;position:sticky;top:0;background-color:var(--bg-primary);z-index:10;padding-bottom:12px}.playlists-header h1{font-size:20px;font-weight:600}.create-playlist-btn{width:100%;justify-content:center;padding:12px 20px;font-size:14px}.playlists-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.playlist-card{padding:14px}.playlist-icon{width:90px;height:90px}.playlist-thumbnail{width:100%;height:100%;object-fit:cover}.playlist-name{font-size:13px}.playlist-info{font-size:11px}.modal-content{width:95%;padding:20px;max-height:85vh}}.edit-playlist-modal{background:var(--bg-secondary);border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.edit-playlist-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.edit-playlist-modal .modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.edit-playlist-modal .modal-close-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.edit-playlist-modal .modal-close-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.edit-playlist-form{padding:24px}.edit-playlist-form .form-error{padding:12px;background-color:#ff44441a;border:1px solid #ff4444;border-radius:4px;color:#f44;margin-bottom:20px;font-size:14px}.edit-playlist-form .form-group{margin-bottom:20px}.edit-playlist-form .form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.edit-playlist-form .form-group input[type=text],.edit-playlist-form .form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:all .2s;font-family:inherit}.edit-playlist-form .form-group textarea{resize:vertical;min-height:80px}.edit-playlist-form .form-group input:focus,.edit-playlist-form .form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1db9541a}.edit-playlist-form .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary)}.edit-playlist-form .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.edit-playlist-form .cover-art-group{margin-bottom:24px}.edit-playlist-form .cover-art-preview-container{display:flex;flex-direction:column;align-items:center;gap:12px}.edit-playlist-form .cover-art-preview{width:200px;height:200px;object-fit:cover;border-radius:8px;box-shadow:0 4px 12px #0000004d}.edit-playlist-form .cover-art-placeholder{width:200px;height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:8px;color:var(--text-secondary)}.edit-playlist-form .cover-art-upload-btn{padding:10px 20px;border-radius:4px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.edit-playlist-form .cover-art-upload-btn:hover{background:var(--bg-primary);border-color:var(--accent);color:var(--accent)}.edit-playlist-form .form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.edit-playlist-form .btn-primary,.edit-playlist-form .btn-secondary{padding:10px 20px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;border:none}.edit-playlist-form .btn-primary{background:var(--accent);color:#fff}.edit-playlist-form .btn-primary:hover:not(:disabled){background:#1ed760;transform:scale(1.02)}.edit-playlist-form .btn-primary:disabled{opacity:.6;cursor:not-allowed}.edit-playlist-form .btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.edit-playlist-form .btn-secondary:hover:not(:disabled){background:var(--bg-primary);border-color:var(--accent)}.edit-playlist-form .spinning{animation:spin 1s linear infinite}@media (max-width: 768px){.edit-playlist-modal{width:95%;max-height:95vh}.edit-playlist-form .form-actions{flex-direction:column}.edit-playlist-form .btn-primary,.edit-playlist-form .btn-secondary{width:100%;justify-content:center}}.playlist-detail{padding:32px 32px 160px}.back-btn{display:flex;align-items:center;gap:8px;margin-bottom:24px;padding:8px 16px;background-color:transparent;border:none;color:var(--text-primary);cursor:pointer;font-size:14px;transition:all .2s}.back-btn:hover{color:var(--accent, #1db954)}.playlist-header{display:flex;gap:32px;margin-bottom:48px}.playlist-cover{width:240px;height:240px;border-radius:8px;overflow:hidden;flex-shrink:0;box-shadow:0 8px 24px #0000004d}.playlist-cover img{width:100%;height:100%;object-fit:cover}.playlist-cover-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--accent, #1db954),#1ed760);display:flex;align-items:center;justify-content:center;color:#fff}.playlist-info{flex:1;display:flex;flex-direction:column;justify-content:flex-end}.playlist-header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.playlist-type{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.public-badge{display:inline-flex;align-items:center;color:var(--accent);margin-left:4px}.playlist-menu-container{position:relative}.playlist-menu-btn{padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.playlist-menu-btn:hover{color:var(--text-primary);background-color:#ffffff1a}.playlist-menu{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000004d;min-width:200px;z-index:100;overflow:hidden}.playlist-menu-item{width:100%;padding:12px 16px;display:flex;align-items:center;gap:12px;background:transparent;border:none;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s;text-align:left}.playlist-menu-item:hover{background-color:var(--bg-tertiary)}.playlist-menu-item.danger{color:#f44}.playlist-menu-item.danger:hover{background-color:#ff44441a}.playlist-info h1{font-size:48px;font-weight:900;margin:0 0 16px;line-height:1.2}.playlist-description{font-size:16px;color:var(--text-secondary);margin:0 0 16px}.playlist-stats{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.playlist-controls{display:flex;align-items:center;gap:12px}.play-playlist-btn{display:flex;align-items:center;gap:8px;padding:14px 32px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:24px;cursor:pointer;font-size:16px;font-weight:700;transition:all .2s;width:fit-content}.play-playlist-btn:hover{transform:scale(1.05);background-color:var(--accent-hover, #1ed760)}.playlist-controls .control-btn{width:40px;height:40px;border-radius:50%;background-color:transparent;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.playlist-controls .control-btn:hover{border-color:var(--text-primary);color:var(--text-primary);transform:scale(1.1)}.playlist-controls .control-btn.active{border-color:var(--accent, #1db954);color:var(--accent, #1db954);background-color:#1db9541a}.playlist-tracks{margin-top:32px}.empty-tracks{text-align:center;padding:64px;color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:16px}.tracks-table{width:100%;border-collapse:collapse}.tracks-table thead{border-bottom:1px solid var(--border)}.tracks-table th{text-align:left;padding:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}.tracks-table th:first-child{width:40px;text-align:center}.tracks-table th:last-child{width:100px;text-align:right}.track-row{border-bottom:1px solid var(--border);transition:background-color .2s}.track-row:hover{background-color:var(--bg-secondary)}.track-row td{padding:12px;vertical-align:middle}.track-number{text-align:center;color:var(--text-secondary);font-size:14px}.track-info{min-width:200px}.track-title{font-size:14px;font-weight:500;margin-bottom:4px}.track-artist{font-size:13px;color:var(--text-secondary)}.track-album,.track-duration{font-size:14px;color:var(--text-secondary)}.track-actions{display:flex;gap:8px;justify-content:flex-end}.action-btn{padding:6px;background-color:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.loading,.error{text-align:center;padding:64px;color:var(--text-secondary);font-size:18px}@media (max-width: 768px){.playlist-detail{padding:60px 12px 180px}.tracks-table-desktop{display:none}.tracks-table-mobile{display:block}.track-card{background-color:var(--bg-secondary);border-radius:8px;padding:12px;margin-bottom:8px;display:flex;align-items:center;gap:12px}.track-card-number{font-size:14px;color:var(--text-secondary);min-width:24px;text-align:center}.track-card-info{flex:1;min-width:0}.track-card-title{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-card-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-card-duration{font-size:12px;color:var(--text-secondary);margin-left:auto;padding-left:8px}.track-card-actions{display:flex;gap:8px;margin-left:8px}.track-card .action-btn{padding:10px;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);border-radius:8px}.track-card .action-btn:active{background-color:var(--accent);color:#fff}.back-btn{margin-bottom:16px;padding:6px 12px;font-size:13px}.playlist-header{flex-direction:column;gap:16px;margin-bottom:20px}.playlist-cover{width:100%;max-width:180px;height:180px;margin:0 auto}.playlist-info{text-align:center}.playlist-info h1{font-size:24px;margin-bottom:8px}.playlist-stats{font-size:13px;margin-bottom:16px}.playlist-controls{flex-wrap:wrap;gap:8px;justify-content:center}.play-playlist-btn{flex:1;min-width:140px;padding:12px 24px;font-size:14px}.playlist-controls .control-btn{width:44px;height:44px}.tracks-table{display:none}}@media (min-width: 769px){.tracks-table-mobile{display:none}}.offline-controls{margin-top:16px;padding:16px;background-color:var(--bg-secondary);border-radius:8px;display:flex;flex-direction:column;gap:12px}.offline-selection-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.offline-btn-small{padding:6px 12px;background-color:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer;transition:all .2s}.offline-btn-small:hover{background-color:var(--bg-primary);border-color:var(--accent, #1db954)}.offline-selected-count{margin-left:auto;color:var(--text-secondary);font-size:13px}.offline-download-btn{padding:10px 20px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.offline-download-btn:hover:not(:disabled){background-color:var(--accent-hover, #1ed760);transform:scale(1.02)}.offline-download-btn:disabled{opacity:.6;cursor:not-allowed}.track-offline-checkbox,.track-card-offline-checkbox{padding:8px;display:flex;align-items:center;justify-content:center}.offline-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;position:relative}.offline-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent, #1db954)}.offline-checkbox-label input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.offline-indicator{color:var(--accent, #1db954);flex-shrink:0}.public-playlists{padding:32px 32px 160px}.public-playlists-header{margin-bottom:32px}.public-playlists-header h1{font-size:32px;font-weight:700;margin:0 0 8px;color:var(--text-primary)}.public-playlists-header p{font-size:16px;color:var(--text-secondary);margin:0}.empty-playlists{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-secondary);gap:16px}.empty-playlists p{font-size:16px;margin:0}.playlists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}.playlist-card{background:var(--bg-secondary);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;border:1px solid var(--border)}.playlist-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:var(--accent)}.playlist-card-cover{width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg-tertiary);position:relative}.playlist-card-cover img{width:100%;height:100%;object-fit:cover}.playlist-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#1ed760);color:#fff}.playlist-card-info{padding:16px}.playlist-card-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-card-description{font-size:13px;color:var(--text-secondary);margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.playlist-card-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary)}.playlist-card-creator{display:flex;align-items:center;gap:6px}.playlist-card-stats{font-variant-numeric:tabular-nums}@media (max-width: 768px){.public-playlists{padding:16px 16px 120px}.playlists-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}}.edit-user-modal{background:var(--bg-secondary);border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.edit-user-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.edit-user-modal .modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.edit-user-modal .modal-close-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.edit-user-modal .modal-close-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.edit-user-form{padding:24px}.edit-user-form .form-error{padding:12px;background-color:#ff44441a;border:1px solid #ff4444;border-radius:4px;color:#f44;margin-bottom:20px;font-size:14px}.user-stats{background:var(--bg-tertiary);border-radius:8px;padding:16px;margin-bottom:24px}.user-stats h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}.stat-item{text-align:center}.stat-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.stat-value{font-size:20px;font-weight:600;color:var(--text-primary)}.format-breakdown{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.format-breakdown h4{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.format-list{display:flex;flex-direction:column;gap:8px}.format-item{display:grid;grid-template-columns:80px 1fr auto auto;gap:12px;align-items:center;padding:8px 12px;background:var(--bg-primary);border-radius:4px;font-size:13px}.format-name{font-weight:600;color:var(--accent)}.format-count{color:var(--text-secondary)}.format-size{color:var(--text-primary);font-weight:500;text-align:right}.format-bitrate{color:var(--text-secondary);font-size:11px;text-align:right}.diagnostic-info{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.diagnostic-info h4{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.diagnostic-warning{padding:8px 12px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:4px;color:#ffc107;font-size:12px;margin-bottom:8px}.diagnostic-info-text{padding:6px 12px;color:var(--text-secondary);font-size:12px;margin-bottom:4px}.edit-user-form .form-group{margin-bottom:20px}.edit-user-form .form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.edit-user-form .form-group input[type=text],.edit-user-form .form-group input[type=email],.edit-user-form .form-group input[type=password]{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:all .2s}.edit-user-form .form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1db9541a}.form-hint{display:block;font-size:12px;color:var(--text-secondary);margin-top:4px}.edit-user-form .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary)}.edit-user-form .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.edit-user-form .form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.edit-user-form .btn-primary,.edit-user-form .btn-secondary{padding:10px 20px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;border:none}.edit-user-form .btn-primary{background:var(--accent);color:#fff}.edit-user-form .btn-primary:hover:not(:disabled){background:#1ed760;transform:scale(1.02)}.edit-user-form .btn-primary:disabled{opacity:.6;cursor:not-allowed}.edit-user-form .btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.edit-user-form .btn-secondary:hover:not(:disabled){background:var(--bg-primary);border-color:var(--accent)}.edit-user-form .spinning{animation:spin 1s linear infinite}@media (max-width: 768px){.edit-user-modal{width:95%;max-height:95vh}.stats-grid{grid-template-columns:1fr}.edit-user-form .form-actions{flex-direction:column}.edit-user-form .btn-primary,.edit-user-form .btn-secondary{width:100%;justify-content:center}}.users{padding:2rem;padding-bottom:160px;max-width:1200px;margin:0 auto}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.users-header h1{margin:0;font-size:2rem;color:var(--text-primary)}.create-user-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .2s}.create-user-btn:hover{background:var(--primary-hover)}.users-table-container{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:var(--bg-secondary)}.users-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:1rem;border-top:1px solid var(--border-color)}.users-table tbody tr:hover{background:var(--bg-secondary)}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:500;color:var(--text-primary)}.user-id{font-size:.875rem;color:var(--text-secondary)}.user-email{display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.user-role{display:flex;align-items:center}.admin-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#ffc1071a;color:#ffc107;border-radius:6px;font-size:.875rem;font-weight:500}.user-badge{display:inline-block;padding:.375rem .75rem;background:#6c757d1a;color:var(--text-secondary);border-radius:6px;font-size:.875rem}.user-date{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.user-actions{display:flex;align-items:center;gap:8px}.action-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:transparent;border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary)}.action-btn:hover{background-color:var(--bg-secondary);border-color:var(--primary-color)}.action-btn.edit-btn:hover{color:var(--primary-color)}.action-btn.delete-btn:hover{color:#f44;border-color:#f44}.error-message{padding:.75rem;background:#dc35451a;color:#dc3545;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state svg{margin-bottom:1rem;opacity:.5}.loading{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}@media (max-width: 768px){.users{padding:60px 12px 140px}.users-header{flex-direction:column;gap:12px;align-items:stretch;margin-bottom:20px;position:sticky;top:0;background-color:var(--bg-primary);z-index:10;padding-bottom:12px}.users-header h1{font-size:20px;font-weight:600;margin:0}.create-user-btn{width:100%;justify-content:center;padding:12px 20px;font-size:14px}.users-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table{min-width:600px}.users-table th,.users-table td{padding:10px 8px;font-size:13px}.user-info{gap:10px}.user-avatar{width:36px;height:36px;font-size:14px}.user-name{font-size:13px}.user-id{font-size:11px}.modal-content{width:95%;padding:20px;max-height:85vh}}.youtube-cookies{padding:32px 32px 160px}.youtube-cookies-header{margin-bottom:32px}.youtube-cookies-header h1{font-size:32px;font-weight:700;margin-bottom:16px}.youtube-cookies-header .description{color:var(--text-secondary);line-height:1.6;max-width:800px}.upload-section{background-color:var(--bg-secondary);border-radius:8px;padding:24px;margin-bottom:32px}.upload-section h2{font-size:20px;font-weight:600;margin-bottom:20px}.upload-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input[type=file]{padding:8px;border:1px solid var(--border);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px}.form-group input[type=text]{padding:10px;border:1px solid var(--border);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px}.file-info{font-size:12px;color:var(--text-secondary);margin-top:4px}.upload-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background-color:var(--accent, #1db954);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;align-self:flex-start}.upload-btn:hover:not(:disabled){background-color:var(--accent-hover, #1ed760);transform:translateY(-1px)}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cookies-list h2{font-size:20px;font-weight:600;margin-bottom:20px}.empty-state{text-align:center;padding:64px;color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:16px}.cookies-table{width:100%;border-collapse:collapse;background-color:var(--bg-secondary);border-radius:8px;overflow:hidden}.cookies-table thead{background-color:var(--bg-tertiary)}.cookies-table th{padding:12px;text-align:left;font-size:14px;font-weight:600;color:var(--text-primary)}.cookies-table td{padding:12px;font-size:14px;color:var(--text-primary);border-top:1px solid var(--border)}.cookies-table tr.active{background-color:#1db9541a}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.active{background-color:#1db95433;color:#1db954}.status-badge.inactive{background-color:#ffffff1a;color:var(--text-secondary)}.actions{display:flex;gap:8px;flex-wrap:wrap}.test-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;background-color:var(--accent, #1db954);color:#fff}.test-btn:hover:not(:disabled){background-color:var(--accent-hover, #1ed760)}.test-btn:disabled{opacity:.5;cursor:not-allowed}.test-result{display:flex;align-items:center;gap:6px;margin-top:8px;padding:6px 10px;border-radius:4px;font-size:12px;font-weight:500}.test-result.success{background-color:#1db9541a;color:#1db954}.test-result.error{background-color:#ff00001a;color:#f44}.toggle-btn,.delete-btn{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.toggle-btn.activate{background-color:var(--accent, #1db954);color:#fff}.toggle-btn.activate:hover{background-color:var(--accent-hover, #1ed760)}.toggle-btn.deactivate{background-color:var(--bg-tertiary);color:var(--text-primary)}.toggle-btn.deactivate:hover{background-color:var(--bg-primary)}.delete-btn{background-color:transparent;color:var(--text-secondary);padding:6px}.delete-btn:hover{background-color:#ff00001a;color:#f44}@media (max-width: 768px){.youtube-cookies{padding:60px 12px 140px}.cookies-table{font-size:12px}.cookies-table th,.cookies-table td{padding:8px}.actions{flex-direction:column}}.share-page{min-height:100vh;background:linear-gradient(180deg,#1a1a1a,#2d2d2d);display:flex;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-primary, #ffffff)}.share-container{max-width:800px;width:100%}.share-loading,.share-error{text-align:center;padding:60px 20px}.share-error h2{margin:20px 0 10px;font-size:24px}.share-error p{color:var(--text-secondary, #b3b3b3);font-size:16px}.share-header{display:flex;gap:24px;margin-bottom:40px;align-items:flex-start}.share-cover{flex-shrink:0;width:200px;height:200px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary, #333);box-shadow:0 8px 24px #00000080}.share-cover img{width:100%;height:100%;object-fit:cover}.share-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #b3b3b3)}.share-info{flex:1;padding-top:20px}.share-info h1{font-size:32px;font-weight:700;margin:0 0 12px;line-height:1.2}.share-artist{font-size:18px;color:var(--text-secondary, #b3b3b3);margin:0 0 8px}.share-meta{font-size:14px;color:var(--text-secondary, #b3b3b3);margin:0}.share-tracks{margin-bottom:40px}.share-tracks h2{font-size:20px;font-weight:600;margin:0 0 16px}.share-track-list{background:#ffffff0d;border-radius:8px;overflow:hidden}.share-track-item{display:flex;align-items:center;gap:16px;padding:12px 16px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid rgba(255,255,255,.05)}.share-track-item:last-child{border-bottom:none}.share-track-item:hover{background:#ffffff1a}.share-track-item.active{background:#1db95433;color:var(--accent, #1db954)}.share-track-number{width:24px;text-align:center;font-size:14px;color:var(--text-secondary, #b3b3b3)}.share-track-item.active .share-track-number{color:var(--accent, #1db954)}.share-track-info{flex:1;min-width:0}.share-track-title{font-size:16px;font-weight:500;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-track-artist{font-size:14px;color:var(--text-secondary, #b3b3b3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-track-duration{font-size:14px;color:var(--text-secondary, #b3b3b3);font-variant-numeric:tabular-nums}.share-player{background:#ffffff0d;border-radius:12px;padding:24px;position:relative}.share-player-info{text-align:center;margin-bottom:20px}.share-player-track-title{font-size:18px;font-weight:600;margin-bottom:4px}.share-player-track-artist{font-size:14px;color:var(--text-secondary, #b3b3b3)}.share-player-controls{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px}.share-control-btn{padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary, #b3b3b3);background:transparent;border:none;cursor:pointer}.share-control-btn:hover:not(:disabled){color:var(--text-primary, #ffffff);background:#ffffff1a;transform:scale(1.1)}.share-control-btn:disabled{opacity:.3;cursor:not-allowed}.share-play-btn{background-color:var(--text-primary, #ffffff);color:var(--bg-primary, #1a1a1a);width:48px;height:48px;box-shadow:0 4px 12px #0000004d}.share-play-btn:hover:not(:disabled){background-color:var(--accent, #1db954);color:#fff;transform:scale(1.1)}.share-progress-container{cursor:pointer;margin-bottom:16px}.share-progress-bar{width:100%;height:4px;background-color:#ffffff4d;border-radius:2px;margin-bottom:8px;transition:height .2s}.share-progress-container:hover .share-progress-bar{height:6px}.share-progress-fill{height:100%;background-color:var(--accent, #1db954);border-radius:2px;transition:width .1s linear}.share-time-display{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary, #b3b3b3);font-variant-numeric:tabular-nums}.share-volume{display:flex;justify-content:center;position:relative}.share-volume-btn{padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary, #b3b3b3);background:transparent;border:none;cursor:pointer}.share-volume-btn:hover{color:var(--text-primary, #ffffff);background:#ffffff1a}.share-volume-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;z-index:1999}.share-volume-modal{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);background-color:var(--bg-primary, #1a1a1a);border:1px solid var(--border, rgba(255, 255, 255, .1));border-radius:12px;padding:20px;min-width:100px;box-shadow:0 8px 32px #00000080;z-index:2000}.share-volume-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.share-volume-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary, #ffffff)}.share-volume-modal-close{background:none;border:none;color:var(--text-secondary, #b3b3b3);font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.share-volume-modal-close:hover{color:var(--text-primary, #ffffff)}.share-volume-modal-content{display:flex;flex-direction:column;align-items:center;gap:16px}.share-volume-icon-btn{background:none;border:none;color:var(--text-primary, #ffffff);cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s}.share-volume-icon-btn:hover{background-color:var(--bg-secondary, #2d2d2d)}.share-volume-slider{width:6px;height:200px;writing-mode:vertical-lr;direction:rtl;background:var(--bg-secondary, #2d2d2d);border-radius:3px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.share-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background-color:var(--accent, #1db954);cursor:pointer}.share-volume-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background-color:var(--accent, #1db954);cursor:pointer;border:none}.share-volume-percentage{font-size:18px;font-weight:600;color:var(--text-primary, #ffffff);min-width:50px;text-align:center;font-variant-numeric:tabular-nums}@media (max-width: 768px){.share-header{flex-direction:column;align-items:center;text-align:center}.share-cover{width:150px;height:150px}.share-info h1{font-size:24px}.share-player-controls{gap:4px}.share-control-btn{padding:6px}.share-play-btn{width:44px;height:44px}}.queue-panel{position:fixed;right:0;top:0;bottom:90px;width:400px;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:400;box-shadow:-4px 0 20px #00000080;transform:translate(100%);transition:transform .3s ease}.queue-panel.show{transform:translate(0)}.queue-header{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.queue-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.queue-close-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.queue-close-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.queue-content{flex:1;overflow-y:auto;padding:8px}.queue-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);gap:16px}.queue-empty p{margin:0;font-size:14px}.queue-list{display:flex;flex-direction:column;gap:4px}.queue-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:4px;cursor:move;transition:all .2s;background:transparent}.queue-item:hover{background-color:var(--bg-tertiary)}.queue-item.current{background-color:#1db9541a;border-left:3px solid var(--accent)}.queue-item.dragging{opacity:.5}.queue-item.drag-over{border-top:2px solid var(--accent)}.queue-item-drag-handle{color:var(--text-secondary);cursor:grab;display:flex;align-items:center}.queue-item-drag-handle:active{cursor:grabbing}.queue-item-number{font-size:12px;color:var(--text-secondary);min-width:20px;text-align:right;font-variant-numeric:tabular-nums}.queue-item-info{flex:1;min-width:0;cursor:pointer}.queue-item-title{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.queue-item.current .queue-item-title{color:var(--accent)}.queue-item-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-duration{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:40px;text-align:right}.queue-item-play,.queue-item-remove{padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;opacity:0}.queue-item:hover .queue-item-play,.queue-item:hover .queue-item-remove{opacity:1}.queue-item-play:hover{color:var(--accent);background-color:#1db9541a}.queue-item-remove:hover{color:#f44;background-color:#ff44441a}@media (max-width: 768px){.queue-panel{width:100%;bottom:100px}}.equalizer-panel{position:fixed;right:0;top:0;bottom:90px;width:350px;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:400;box-shadow:-4px 0 20px #00000080;transform:translate(100%);transition:transform .3s ease}.equalizer-panel.show{transform:translate(0)}.equalizer-header{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.equalizer-header-title{display:flex;align-items:center;gap:8px}.equalizer-header-title h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.equalizer-close-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.equalizer-close-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.equalizer-content{flex:1;overflow-y:auto;padding:16px}.equalizer-toggle{margin-bottom:24px}.equalizer-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary)}.equalizer-toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.equalizer-presets{margin-bottom:24px}.equalizer-presets label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.preset-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.preset-btn{padding:8px 12px;border-radius:4px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.preset-btn:hover:not(:disabled){background:var(--bg-primary);color:var(--text-primary);border-color:var(--accent)}.preset-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.preset-btn:disabled{opacity:.5;cursor:not-allowed}.equalizer-controls{display:flex;flex-direction:column;gap:24px}.eq-control{display:flex;flex-direction:column;gap:8px}.eq-control label{font-size:13px;font-weight:500;color:var(--text-primary)}.eq-slider-container{display:flex;align-items:center;gap:12px}.eq-label-left,.eq-label-right{font-size:11px;color:var(--text-secondary);min-width:30px;text-align:center}.eq-slider{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;outline:none;-webkit-appearance:none;cursor:pointer;transition:height .2s}.eq-slider:hover{height:8px}.eq-slider:disabled{opacity:.5;cursor:not-allowed}.eq-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform .2s}.eq-slider:hover::-webkit-slider-thumb{transform:scale(1.2)}.eq-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;transition:transform .2s}.eq-slider:hover::-moz-range-thumb{transform:scale(1.2)}.eq-value{font-size:12px;font-weight:600;color:var(--accent);min-width:45px;text-align:right;font-variant-numeric:tabular-nums}@media (max-width: 768px){.equalizer-panel{width:100%;bottom:100px}}.player{flex-shrink:0;height:110px;min-height:110px;max-height:110px;background:linear-gradient(to top,#181818,#282828);border-top:1px solid rgba(255,255,255,.1);padding:0 16px;display:flex;align-items:center;z-index:500;box-shadow:0 -4px 20px #00000080;position:relative;overflow:visible}.player-content{width:100%;display:grid;grid-template-columns:250px 1fr 200px;align-items:center;gap:16px;min-height:90px;max-height:90px;position:relative}.player-left{display:flex;align-items:center;gap:12px;min-width:0}.player-album-art{flex-shrink:0;width:56px;height:56px;border-radius:4px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.album-art-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.album-art-image.playing{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.album-art-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:linear-gradient(135deg,#333,#444)}.player-track-info{flex:1;min-width:0}.player-track-info .track-title{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;cursor:pointer;transition:color .2s}.player-track-info .track-title:hover{color:var(--accent);text-decoration:underline}.player-track-info .track-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:color .2s}.player-track-info .track-artist:hover{color:var(--text-primary)}.like-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;flex-shrink:0}.like-btn:hover{color:var(--accent);background-color:#ffffff1a}.like-btn.liked{color:var(--accent)}.player-center{display:flex;flex-direction:column;align-items:center;gap:8px}.control-buttons{display:flex;align-items:center;gap:8px;margin-bottom:4px}.control-btn{padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.control-btn:hover{color:var(--text-primary);background-color:#ffffff1a;transform:scale(1.1)}.control-btn.active,.shuffle-btn.active,.repeat-btn.active{color:var(--accent)}.play-btn{background-color:var(--text-primary);color:var(--bg-primary);width:40px;height:40px;box-shadow:0 2px 8px #0000004d}.play-btn:hover{transform:scale(1.1);background-color:var(--accent);color:#fff}.progress-container{width:100%;max-width:600px;cursor:pointer;position:relative;min-height:50px;max-height:50px;display:flex;flex-direction:column;gap:2px;flex-shrink:0;justify-content:flex-end}.waveform-container{width:100%;height:40px;margin-bottom:0;opacity:.6;transition:opacity .2s;flex-shrink:0;display:block}.progress-container:hover .waveform-container{opacity:1}.progress-bar{width:100%;height:4px;min-height:4px;max-height:6px;background-color:#ffffff4d;border-radius:2px;cursor:pointer;margin-bottom:0;transition:height .2s;flex-shrink:0;display:block;visibility:visible;opacity:1}.progress-bar:hover{height:6px}.progress-fill{height:100%;background-color:var(--accent);border-radius:2px;transition:width .1s linear;position:relative}.progress-fill:after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background-color:var(--accent);opacity:0;transition:opacity .2s}.progress-bar:hover .progress-fill:after{opacity:1}.time-display{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;min-height:14px;height:14px;width:100%;margin-top:2px;visibility:visible;opacity:1}.player-right{display:flex;align-items:center;justify-content:flex-end;gap:8px;position:relative;flex-shrink:0}.queue-btn{padding:8px;border-radius:4px;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer}.queue-btn:hover{color:var(--text-primary);background-color:#ffffff1a}.queue-btn.active{color:var(--accent)}.player-volume{display:flex;align-items:center;gap:8px;min-width:120px;max-width:180px}.volume-icon-btn{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;flex-shrink:0}.volume-icon-btn:hover{color:var(--text-primary);background-color:#ffffff1a}.volume-slider{flex:1;height:4px;background-color:#ffffff4d;border-radius:2px;outline:none;-webkit-appearance:none;cursor:pointer;transition:height .2s}.volume-slider:hover{height:6px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background-color:var(--accent);cursor:pointer;opacity:0;transition:opacity .2s}.volume-slider:hover::-webkit-slider-thumb{opacity:1}.volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background-color:var(--accent);cursor:pointer;border:none;opacity:0;transition:opacity .2s}.volume-slider:hover::-moz-range-thumb{opacity:1}.volume-percentage{font-size:11px;color:var(--text-secondary);min-width:35px;text-align:right;font-variant-numeric:tabular-nums}.player-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#f44;color:#fff;padding:6px 16px;border-radius:4px;font-size:12px;z-index:501;white-space:nowrap;pointer-events:none;max-width:90%;text-align:center}.player-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-secondary);font-size:12px;z-index:501;white-space:nowrap;pointer-events:none}@media (max-width: 768px){.player{height:auto;min-height:100px;padding:10px 12px}.player-content{grid-template-columns:1fr;gap:10px}.player-left{order:1;width:100%}.player-album-art{width:48px;height:48px}.player-track-info .track-title{font-size:13px}.player-track-info .track-artist{font-size:11px}.player-center{order:2;width:100%}.control-buttons{gap:12px}.play-btn{width:44px;height:44px}.player-right{order:3;width:100%;justify-content:center;gap:8px}.player-volume{width:100%;max-width:100%;padding:0 20px}.volume-percentage,.queue-btn{display:none}.volume-modal{bottom:calc(100% + 8px);right:0;left:auto;transform:none}}.volume-btn-wrapper{position:relative;display:flex;align-items:center}.volume-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;z-index:1999}.volume-modal{position:fixed;background-color:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:20px;min-width:100px;box-shadow:0 8px 32px #00000080;z-index:2000}.volume-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.volume-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.volume-modal-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.volume-modal-close:hover{color:var(--text-primary)}.volume-modal-content{display:flex;flex-direction:column;align-items:center;gap:16px;min-height:250px}.volume-icon-btn-modal{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s}.volume-icon-btn-modal:hover{background-color:var(--bg-secondary)}.volume-slider-modal{width:6px;height:200px;writing-mode:vertical-lr;direction:rtl;background:var(--bg-secondary);border-radius:3px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.volume-slider-modal::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background-color:var(--accent);cursor:pointer}.volume-slider-modal::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background-color:var(--accent);cursor:pointer;border:none}.volume-percentage-modal{font-size:18px;font-weight:600;color:var(--text-primary);min-width:50px;text-align:center;font-variant-numeric:tabular-nums}.skip-btn{opacity:.7;transition:opacity .2s}.skip-btn:hover:not(:disabled){opacity:1}.skip-btn:disabled{opacity:.3;cursor:not-allowed}.layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative}.layout-content-wrapper{display:flex;flex:1;overflow:hidden}.sidebar{width:240px;background-color:var(--bg-secondary);display:flex;flex-direction:column;border-right:1px solid var(--border);transition:transform .3s ease;z-index:100}.mobile-menu-btn{position:fixed;top:16px;left:16px;z-index:101;width:40px;height:40px;border-radius:50%;background-color:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);display:none;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000004d}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:99}@media (max-width: 768px){.mobile-menu-btn{display:flex;position:fixed;top:12px;left:12px;z-index:1002;width:44px;height:44px;background-color:var(--bg-secondary);border:1px solid var(--border);box-shadow:0 2px 8px #0006}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;max-width:85vw;transform:translate(-100%);box-shadow:2px 0 12px #00000080;z-index:1001;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:1000}.main-content{width:100%}.sidebar-header{padding:20px 50px 20px 16px}.sidebar-header h1{font-size:20px}.sidebar-nav{padding:12px 8px}.nav-item{padding:14px 16px;font-size:15px}.sidebar-footer{padding:12px 16px;position:sticky;bottom:0;background-color:var(--bg-secondary);margin-top:auto;z-index:10}}.sidebar-header{padding:24px;border-bottom:1px solid var(--border);position:relative}.sidebar-close-btn{position:absolute;top:20px;right:20px;width:32px;height:32px;border-radius:50%;background-color:transparent;border:1px solid var(--border);color:var(--text-secondary);display:none;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.sidebar-close-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.sidebar-header h1{font-size:24px;font-weight:700;color:var(--accent)}@media (max-width: 768px){.sidebar-header{padding:20px 50px 20px 16px}.sidebar-close-btn{display:flex;top:16px;right:16px}}.sidebar-nav{flex:1;padding:16px 8px;overflow-y:auto}@media (max-width: 768px){.sidebar-nav{padding-bottom:80px}}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;color:var(--text-secondary);transition:all .2s;margin-bottom:4px}.nav-item:hover,.nav-item.active{background-color:var(--bg-tertiary);color:var(--text-primary)}.metadata-stats{padding:12px 16px;margin:8px;background-color:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border);flex-shrink:0}.metadata-stats-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.metadata-stats-content{display:flex;flex-direction:column;gap:6px}.metadata-stat-item{display:flex;justify-content:space-between;align-items:center;font-size:13px}.metadata-stat-label{color:var(--text-secondary)}.metadata-stat-value{color:var(--text-primary);font-weight:600}.metadata-stat-recognized{color:var(--accent, #1db954)}.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}@media (max-width: 768px){.sidebar-footer{padding:16px;min-height:60px}}.user-info{display:flex;align-items:center;gap:12px;flex:1}.user-avatar{width:32px;height:32px;border-radius:50%;background-color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-details{flex:1;min-width:0}.user-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{padding:8px;border-radius:4px;color:var(--text-secondary);transition:all .2s}.logout-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.main-content{flex:1;overflow-y:auto;background-color:var(--bg-primary);padding-bottom:110px}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #121212;--bg-secondary: #181818;--bg-tertiary: #282828;--text-primary: #ffffff;--text-secondary: #b3b3b3;--accent: #1db954;--accent-hover: #1ed760;--error: #e22134;--border: #333333}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}#root{min-height:100vh}button{cursor:pointer;border:none;background:none;color:inherit;font-family:inherit}input,textarea{font-family:inherit;color:inherit}a{color:inherit;text-decoration:none}@media (max-width: 768px){body{font-size:14px}}
