:root{--bg-base: #0d0d0d;--bg-primary: #121212;--bg-surface: #1e1e1e;--bg-elevated: #2a2a2a;--text-primary: #ffffff;--text-secondary: #d9d9d9;--text-tertiary: #a0a0a0;--accent: #00d9ff;--accent-hover: #00b8d4;--accent-dark: #0099b8;--accent-light: #00d9ff1a;--border: #333333;--error: #ff4444;--success: #00ff88;--warning: #ffbb33}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s}input,textarea,select{font-family:inherit;outline:none}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#404040}.container{max-width:1400px;margin:0 auto;padding:0 24px}.card{background:var(--bg-surface);border-radius:12px;padding:24px;border:1px solid var(--border)}.btn{padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.btn-primary{background:var(--accent);color:var(--bg-primary)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary)}.btn-secondary:hover{background:#333}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.input{width:100%;padding:12px 16px;background:var(--bg-elevated);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;transition:all .2s}.input:focus{border-color:var(--accent);background:var(--bg-surface)}.input::placeholder{color:var(--text-tertiary)}.label{display:block;margin-bottom:8px;color:var(--text-secondary);font-size:14px;font-weight:500}.error-message{color:var(--error);font-size:12px;margin-top:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}.spinner{border:3px solid var(--bg-elevated);border-top:3px solid var(--accent);border-radius:50%;width:40px;height:40px;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg-primary)}.auth-container{width:100%;max-width:480px;background:var(--bg-surface);border-radius:16px;padding:48px 40px;border:1px solid var(--border)}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:32px;margin-bottom:8px;font-weight:700}.logo-text{color:var(--accent)}.small{font-size:12px;margin-left:6px}.logo-image{margin-left:8px}.auth-header p{color:var(--text-secondary);font-size:14px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.input-hint{font-size:12px;color:var(--text-tertiary);margin-top:4px}.btn-full{width:100%;margin-top:8px}.auth-footer{margin-top:24px;text-align:center;padding-top:24px;border-top:1px solid var(--border)}.auth-footer p{color:var(--text-secondary);font-size:14px}.auth-footer a{color:var(--accent);font-weight:600}.auth-footer a:hover{color:var(--accent-hover)}.home-page{padding:32px 0}.home-section{margin-bottom:48px}.section-title{font-size:24px;font-weight:700;margin-bottom:24px}.songs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}.song-card{background:var(--bg-surface);border-radius:12px;padding:16px;border:1px solid var(--border);transition:all .3s;cursor:pointer}.song-card:hover{background:var(--bg-elevated)}.song-card-thumbnail{position:relative;width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--bg-elevated);margin-bottom:12px;display:flex;align-items:center;justify-content:center}.song-card-thumbnail img{width:100%;height:100%;object-fit:cover}.song-card-placeholder{color:var(--text-tertiary)}.song-card-play{position:absolute;bottom:8px;right:8px;width:48px;height:48px;border-radius:50%;background:var(--accent);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s}.song-card:hover .song-card-play{opacity:1}.song-card-content{display:flex;flex-direction:column;gap:4px}.song-card-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.song-card-title:hover{color:var(--accent)}.song-card-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-card-artist:hover{color:var(--text-primary)}.song-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.song-card-plays{font-size:11px;color:var(--text-tertiary)}.song-card-like{background:transparent;color:var(--text-tertiary);padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.song-card-like:hover{color:var(--error);background:#ff44441a}.song-card-like.liked{color:var(--error)}.song-card-like.liked:hover{color:var(--text-tertiary);background:#ffffff0d}.loading-page{display:flex;align-items:center;justify-content:center;min-height:60vh}@media(max-width:768px){.home-page{padding:16px 0}.home-section{margin-bottom:32px}.section-title{font-size:20px;padding:0 12px}.songs-grid{grid-template-columns:1fr;gap:8px;padding:0 12px}.song-card{display:flex;flex-direction:row;align-items:center;padding:8px;gap:12px}.song-card-thumbnail{width:60px;height:60px;margin-bottom:0;flex-shrink:0}.song-card-content{flex:1;min-width:0;gap:2px}.song-card-play{display:none}.song-card-title{font-size:14px}.song-card-artist{font-size:12px}.song-card-footer{display:flex;align-items:center;gap:8px;margin-top:4px;padding-top:4px;border-top:1px solid var(--border)}.song-card-plays{font-size:11px}}.playlist-page{padding-bottom:120px}.playlist-header{display:flex;gap:32px;margin-bottom:32px;padding:32px;background:var(--bg-surface);border-radius:12px}.playlist-cover{width:200px;height:200px;border-radius:12px;overflow:hidden;flex-shrink:0}.playlist-cover img{width:100%;height:100%;object-fit:cover}.playlist-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%)}.playlist-header-info{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:12px}.playlist-type{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}.playlist-title{font-size:48px;font-weight:900;margin:0;line-height:1.1}.playlist-description{color:var(--text-secondary);font-size:14px;margin:0}.playlist-meta{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px;font-weight:500}.playlist-actions{display:flex;gap:16px;margin-bottom:32px;padding:0 32px}.btn-play-playlist{display:flex;align-items:center;gap:8px;font-weight:600}.playlist-songs{padding:0 32px}.songs-table{width:100%}.songs-table-header{display:grid;grid-template-columns:40px 1fr 80px 60px;gap:16px;padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-tertiary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.song-row{display:grid;grid-template-columns:40px 1fr 80px 60px;gap:16px;padding:12px 16px;border-radius:8px;transition:background .2s;cursor:pointer}.song-row:hover{background:var(--bg-elevated)}.song-number{display:flex;align-items:center;justify-content:center;position:relative}.song-number-text{display:block;color:var(--text-tertiary);font-size:14px}.song-play-btn{position:absolute;display:none;background:transparent;color:var(--text-primary);padding:4px}.song-row:hover .song-number-text{display:none}.song-row:hover .song-play-btn{display:flex}.song-info{display:flex;align-items:center;gap:12px;min-width:0}.song-thumbnail{width:40px;height:40px;border-radius:4px;overflow:hidden;background:var(--bg-elevated);flex-shrink:0}.song-thumbnail img{width:100%;height:100%;object-fit:cover}.song-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.song-details{min-width:0;flex:1}.song-title{font-weight:500;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.song-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-duration{display:flex;align-items:center;justify-content:flex-end;color:var(--text-tertiary);font-size:14px}.song-actions{display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.song-row:hover .song-actions{opacity:1}.empty-playlist{text-align:center;padding:80px 20px;color:var(--text-secondary)}.empty-playlist svg{color:var(--text-tertiary);margin-bottom:16px}.empty-playlist h3{margin:16px 0 8px;color:var(--text-primary)}.empty-playlist p{margin-bottom:24px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px}.modal{background:var(--bg-surface);border-radius:12px;max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:20px;font-weight:600}.modal-header button{background:transparent;color:var(--text-secondary);font-size:32px;line-height:1;padding:0;width:32px;height:32px}.modal-body{flex:1;overflow-y:auto;padding:24px}.modal-search{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;margin-bottom:16px}.modal-search svg{color:var(--text-tertiary);flex-shrink:0}.modal-search-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:14px;outline:none}.modal-search-input::placeholder{color:var(--text-tertiary)}.add-songs-list{display:flex;flex-direction:column;gap:8px}.add-song-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background .2s}.add-song-item:hover,.add-song-item.selected{background:var(--bg-elevated)}.add-song-item input[type=checkbox]{cursor:pointer;appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid var(--border);border-radius:4px;background:var(--bg-surface);position:relative;transition:all .2s}.add-song-item input[type=checkbox]:hover{border-color:var(--accent)}.add-song-item input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.add-song-item input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:700}.song-thumbnail-small{width:40px;height:40px;border-radius:4px;overflow:hidden;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0}.song-thumbnail-small img{width:100%;height:100%;object-fit:cover}.song-info-small{flex:1;min-width:0}.song-title-small{font-weight:500;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist-small{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid var(--border)}.loading,.error{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}.error{color:var(--danger)}@media(max-width:768px){.playlist-header{flex-direction:column;align-items:center;text-align:center;padding:24px;gap:24px}.playlist-cover{width:160px;height:160px}.playlist-title{font-size:32px}.playlist-actions{flex-wrap:wrap;padding:0 16px}.playlist-songs{padding:0 16px}.songs-table-header,.song-row{grid-template-columns:40px 1fr 60px;padding:8px 12px}.song-duration{grid-column:3}.song-actions{display:none}.song-row:active .song-actions{opacity:1}}@media(max-width:480px){.playlist-cover{width:140px;height:140px}.playlist-title{font-size:24px}.playlist-actions{flex-direction:column;width:100%}.playlist-actions button{width:100%;justify-content:center}.modal{max-height:90vh}.modal-header,.modal-body,.modal-footer{padding:16px}}.playlist-page .btn-danger{background:#dc2626;color:#fff;border-radius:24px}.playlist-page .btn-danger:hover{background:#b91c1c}.playlist-page .btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;color:var(--text-secondary);border:none;border-radius:50%;cursor:pointer;transition:all .2s}.playlist-page .btn-icon:hover{background:var(--bg-elevated);color:var(--text-primary)}.playlists-page{padding-bottom:120px}.playlists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}.playlist-card{background:var(--bg-surface);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s;position:relative}.playlist-card:hover{background:var(--bg-elevated);transform:translateY(-4px);box-shadow:0 8px 24px #0003}.playlist-card-cover{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--bg-elevated);margin-bottom:16px;position:relative}.playlist-card-cover img{width:100%;height:100%;object-fit:cover}.playlist-card-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%)}.playlist-card-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.playlist-card:hover .playlist-card-overlay{opacity:1}.playlist-play-btn{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 12px #0000004d}.playlist-play-btn:hover{transform:scale(1.1);background:var(--accent-hover)}.playlist-card-info{min-height:80px}.playlist-card-title{font-size:16px;font-weight:600;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 8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.playlist-card-meta{font-size:12px;color:var(--text-tertiary);font-weight:500}.playlist-delete-btn{position:absolute;top:24px;right:24px;width:32px;height:32px;border-radius:50%;background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s;z-index:10}.playlist-card:hover .playlist-delete-btn{opacity:1}.playlist-delete-btn:hover{background:var(--danger);transform:scale(1.1)}.empty-state{text-align:center;padding:80px 20px;color:var(--text-secondary)}.empty-state svg{color:var(--text-tertiary);margin-bottom:24px}.empty-state h2{margin:0 0 12px;color:var(--text-primary);font-size:28px}.empty-state p{margin:0 0 32px;font-size:16px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text-secondary)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}textarea.input{resize:vertical;font-family:inherit}.loading{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}@media(max-width:768px){.playlists-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.playlist-card{padding:12px}.playlist-card-title{font-size:14px}.playlist-card-description{font-size:12px}.playlist-delete-btn{opacity:1}}@media(max-width:480px){.playlists-grid{grid-template-columns:1fr 1fr}.empty-state{padding:60px 20px}.empty-state h2{font-size:24px}.empty-state p{font-size:14px}}.edit-playlist-page{padding-bottom:120px}.edit-playlist-form{max-width:1000px;margin:0 auto}.form-row{display:grid;grid-template-columns:300px 1fr;gap:48px;margin-bottom:32px}.cover-section,.cover-upload{display:flex;flex-direction:column;gap:16px}.cover-preview{width:300px;height:300px;border-radius:12px;overflow:hidden;background:var(--bg-elevated);box-shadow:0 8px 24px #0003}.cover-preview img{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%)}.cover-actions{display:flex;gap:12px}.cover-info{font-size:12px;color:var(--text-tertiary);margin:0}.fields-section{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:600;color:var(--text-secondary)}.input{width:100%;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;transition:all .2s}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d9ff1a}textarea.input{resize:vertical;font-family:inherit;min-height:100px}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid var(--border);border-radius:4px;background:var(--bg-surface);position:relative;flex-shrink:0;margin:0;vertical-align:middle;transition:all .2s}.checkbox-label input[type=checkbox]:hover{border-color:var(--accent)}.checkbox-label input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.checkbox-label input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:700}.checkbox-label span{font-size:14px;color:var(--text-primary);line-height:1.2}.form-actions{display:flex;justify-content:flex-end;gap:16px;padding-top:24px;border-top:1px solid var(--border)}@media(max-width:768px){.form-row{grid-template-columns:1fr;gap:32px}.cover-preview{width:100%;max-width:300px;height:auto;aspect-ratio:1;margin:0 auto}.cover-actions{flex-direction:column}.cover-actions button,.cover-actions label{width:100%;justify-content:center}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;justify-content:center}}.fullscreen-player{position:fixed;inset:0;z-index:2000;transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);background:#1a1a2e;overflow:hidden}.fullscreen-player.open{transform:translateY(0)}body:has(.fullscreen-player.open){overflow:hidden}.fullscreen-player-container{height:100%;display:flex;flex-direction:column;padding:20px 24px;max-width:800px;margin:0 auto;overflow:hidden}.fullscreen-header{display:flex;justify-content:flex-end;align-items:flex-end;margin-bottom:16px;flex-shrink:0}.fullscreen-close-btn{background:#ffffff1a;color:#fff;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.fullscreen-close-btn:hover{background:#fff3}.fullscreen-queue-info{color:#fffc;font-size:14px;font-weight:500;margin-top:50px;position:absolute;left:50%;transform:translate(-50%)}.fullscreen-artwork{flex:0 1 auto;display:flex;justify-content:center;align-items:center;padding:20px 0;min-height:0}.fullscreen-artwork img{width:100%;max-width:400px;aspect-ratio:1;border-radius:16px;box-shadow:0 20px 60px #00000080;object-fit:cover;animation:fadeIn .5s ease-in}.fullscreen-artwork-placeholder{width:100%;max-width:400px;aspect-ratio:1;border-radius:16px;background:#ffffff1a;display:flex;align-items:center;justify-content:center;color:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.fullscreen-info{text-align:center;margin-bottom:24px;flex-shrink:0}.fullscreen-title{font-size:32px;font-weight:700;color:#fff;margin:0 0 12px;line-height:1.2}.fullscreen-artists{font-size:18px;color:#fffc;margin:0;font-weight:500}.fullscreen-progress-section{margin-top:24px;flex-shrink:0}.fullscreen-progress-slider{width:100%;height:6px;border-radius:3px;outline:none;appearance:none;background:#fff3;cursor:pointer;margin-bottom:8px}.fullscreen-progress-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0000004d;transition:transform .2s}.fullscreen-progress-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.fullscreen-progress-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 2px 8px #0000004d}.fullscreen-time-labels{display:flex;justify-content:space-between;color:#ffffffb3;font-size:14px;font-weight:500}.fullscreen-controls{display:flex;flex-direction:column;gap:20px;flex-shrink:0}.fullscreen-main-controls{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:75px}.fullscreen-control-btn{background:transparent;color:#fff;padding:12px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.fullscreen-control-btn:hover:not(:disabled){background:#ffffff1a}.fullscreen-control-btn:disabled{opacity:.3;cursor:not-allowed}.fullscreen-control-btn.active{color:var(--accent, #00d9ff)}.fullscreen-play-btn{width:80px;height:80px;border-radius:50%;background:#fff;color:#1a1a2e;display:flex;align-items:center;justify-content:center;transition:all .2s}.fullscreen-secondary-controls{display:flex;align-items:center;justify-content:space-between;padding:0 20px}.fullscreen-volume-control{display:flex;align-items:center;gap:12px;color:#fff}.fullscreen-volume-slider{width:120px;height:4px;border-radius:2px;outline:none;appearance:none;background:#fff3;cursor:pointer}.fullscreen-volume-slider::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer}.fullscreen-volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;border:none}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.fullscreen-player-container{padding:16px}.fullscreen-header{margin-bottom:20px}.fullscreen-artwork{padding:20px 0}.fullscreen-artwork img,.fullscreen-artwork-placeholder{max-width:320px}.fullscreen-title{font-size:24px}.fullscreen-artists{font-size:16px}.fullscreen-info{margin-bottom:32px}.fullscreen-progress-section{margin-bottom:24px}.fullscreen-play-btn{width:70px;height:70px}.fullscreen-main-controls{gap:16px}.fullscreen-volume-control{display:none}.fullscreen-secondary-controls{justify-content:center;gap:40px}}@media(max-width:480px){.fullscreen-player-container{padding:12px}.fullscreen-artwork img,.fullscreen-artwork-placeholder{max-width:280px}.fullscreen-title{font-size:20px}.fullscreen-artists{font-size:14px}.fullscreen-play-btn{width:64px;height:64px}.fullscreen-control-btn{padding:8px}.fullscreen-queue-info{font-size:12px}}@media(max-height:600px)and (orientation:landscape){.fullscreen-player-container{flex-direction:row;align-items:center;gap:24px;padding:16px}.fullscreen-header{position:absolute;top:16px;left:16px;right:16px;margin-bottom:0;z-index:10}.fullscreen-artwork{flex:0 0 auto;margin:0;padding:0;width:40%}.fullscreen-artwork img,.fullscreen-artwork-placeholder{max-width:250px}.fullscreen-info{text-align:left;margin-bottom:16px}.fullscreen-title{font-size:20px}.fullscreen-artists{font-size:14px}.fullscreen-progress-section{margin-bottom:16px}.fullscreen-controls{gap:16px}.fullscreen-play-btn{width:60px;height:60px}}.player{position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border);padding:16px 0;z-index:1000;cursor:pointer;transition:background .2s}.player:hover{background:var(--bg-elevated)}.player-mobile-compact{display:none}.player-content{display:grid;grid-template-columns:1fr 2fr 1fr;gap:24px;align-items:center}.player-song-info{display:flex;align-items:center;gap:16px}.player-thumbnail{width:56px;height:56px;border-radius:8px;overflow:hidden;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.player-thumbnail img{width:100%;height:100%;object-fit:cover}.player-thumbnail-placeholder{color:var(--text-tertiary)}.player-details{min-width:0}.player-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-controls{display:flex;flex-direction:column;gap:12px}.player-buttons{display:flex;align-items:center;justify-content:center;gap:12px}.player-btn{background:transparent;color:var(--text-secondary);padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.player-btn:hover{color:var(--text-primary);background:var(--bg-elevated)}.player-btn.active{color:var(--accent)}.player-btn-primary{background:var(--accent);color:var(--bg-primary);width:40px;height:40px}.player-btn-primary:hover{background:var(--accent-hover)}.player-progress{display:flex;align-items:center;gap:12px}.player-time{font-size:12px;color:var(--text-tertiary);min-width:40px;text-align:center}.player-slider{flex:1;height:4px;border-radius:2px;outline:none;appearance:none;background:#ffffff1a;cursor:pointer;position:relative}.player-slider:hover{background:#ffffff26}.player-slider::-webkit-slider-thumb{appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}.player-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.player-volume{display:flex;align-items:center;gap:12px;justify-content:flex-end}.player-volume svg{color:var(--text-secondary)}.player-volume-slider{width:100px}@media(max-width:1024px){.player-content{grid-template-columns:1fr 2fr}.player-volume{display:none}}@media(max-width:768px){.player{bottom:70px;padding:0;background:var(--bg-surface);border-top:none}.player-content{display:none}.player-mobile-compact{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-surface)}.player-mobile-thumbnail{width:48px;height:48px;border-radius:6px;overflow:hidden;background:var(--bg-elevated);flex-shrink:0;display:flex;align-items:center;justify-content:center}.player-mobile-thumbnail img{width:100%;height:100%;object-fit:cover}.player-mobile-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.player-mobile-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.player-mobile-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-mobile-play-btn{width:48px;height:48px;border-radius:50%;background:transparent;color:var(--text-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-mobile-play-btn:hover{background:var(--bg-elevated)}}.navbar{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:16px 24px;position:fixed;top:0;left:0;right:0;width:100%;z-index:100;box-sizing:border-box}.navbar-content{display:flex;align-items:center;gap:32px;max-width:1400px;margin:0 auto;width:100%}.navbar-brand{font-size:24px;font-weight:700;color:var(--accent);text-decoration:none}.navbar-search{flex:1;max-width:500px;position:relative;display:flex;align-items:center;gap:12px;background:var(--bg-elevated);border:2px solid var(--border);border-radius:24px;padding:10px 20px}.navbar-search svg{color:var(--text-tertiary);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:14px;outline:none}.search-input::placeholder{color:var(--text-tertiary)}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:8px;max-height:400px;overflow-y:auto;box-shadow:0 4px 12px #0000004d;z-index:1000}.search-section{margin-bottom:12px}.search-section:last-child{margin-bottom:0}.search-section-title{font-size:12px;font-weight:600;color:var(--text-tertiary);padding:8px 12px;text-transform:uppercase;letter-spacing:.5px}.search-result-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;text-decoration:none;color:var(--text-primary);transition:background .2s}.search-result-item:hover{background:var(--bg-elevated)}.search-result-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.search-result-info{flex:1;min-width:0}.search-result-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-meta{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-links{display:flex;align-items:center;gap:8px}.nav-link{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;color:var(--text-secondary);text-decoration:none;transition:all .2s;font-size:14px;font-weight:500}.nav-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-link.active{background:var(--accent-light);color:var(--accent)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;padding:12px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:110;box-sizing:border-box;align-items:center;gap:12px}.mobile-header-brand{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:700;text-decoration:none;flex-shrink:0}.mobile-header-search{flex:1;position:relative;display:flex;align-items:center;gap:10px;background:var(--bg-elevated);border:2px solid var(--border);border-radius:16px;padding:9px 12px}.mobile-header-search .search-input{font-size:13px}@media(max-width:1024px){.navbar-search{display:none}}@media(max-width:768px){.desktop-navbar{display:none}.mobile-header{display:flex}.navbar-links{flex-direction:column;align-items:stretch}.nav-link span{display:none}}#root{width:100%;min-height:100vh}img,.unselectable{-webkit-user-select:none;user-select:none;pointer-events:none;-moz-user-select:none;-webkit-user-drag:none}button,a,[role=button],.clickable{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-webkit-touch-callout:none}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-bottom:100px;width:100%}@media(min-width:480px){.main-content{padding-top:80px}}@media(max-width:768px){.main-content{padding-top:75px}}.mobile-nav{display:none}.page{min-height:calc(100vh - 180px);padding:32px 24px;display:flex;flex-direction:column;align-items:center}.container{max-width:1400px;margin:0 auto;width:100%}.page-header{margin-bottom:32px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;width:100%}.page-header-actions{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:16px;text-align:left}.page-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0}.page-subtitle{font-size:16px;color:var(--text-secondary);margin-top:8px}@media(max-width:768px){.page-header-actions{flex-direction:column;align-items:stretch}.page-header-actions .btn,.page-header-actions button,.page-header-actions a{width:100%;justify-content:center}.page-header-actions .page-title,.page-header-actions .page-subtitle{text-align:left}}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:24px;transition:all .2s}.card:hover{border-color:var(--accent)}.grid{display:grid;gap:24px}.grid-2{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.profile-header{position:relative;width:100vw;margin-left:calc(-50vw + 50%);padding:80px 24px 40px;background-size:cover;background-position:center;margin-bottom:32px}.profile-header-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,var(--bg-base) 100%)}.profile-header-content{position:relative;display:flex;align-items:center;gap:32px;max-width:1400px;margin:0 auto;padding:0 24px}.profile-avatar{width:180px;height:180px;border-radius:50%;overflow:hidden;flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;font-weight:700;color:var(--text-tertiary)}.profile-info{flex:1}.profile-name{font-size:48px;font-weight:700;margin:0 0 8px;color:var(--text-primary)}.profile-username{font-size:18px;color:var(--text-secondary);margin:0 0 16px}.profile-stats{display:flex;gap:24px;margin-bottom:16px}.profile-stat{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.profile-bio{max-width:600px;margin:16px 0;color:var(--text-primary);line-height:1.6}.profile-links{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}.profile-link{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;color:var(--text-secondary);text-decoration:none;font-size:14px;transition:all .2s}.profile-link:hover{border-color:var(--accent);color:var(--accent)}.profile-actions{margin-top:24px;display:inline-flex;align-items:center;gap:12px;padding:12px 14px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.section-title{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.songs-list{display:flex;flex-direction:column;gap:8px}.song-list-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;transition:all .2s}.song-list-item:hover{background:var(--bg-elevated);border-color:var(--accent)}.song-list-number{width:24px;text-align:center;color:var(--text-tertiary);font-size:14px;font-weight:500}.song-list-thumbnail{width:48px;height:48px;border-radius:6px;overflow:hidden;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);flex-shrink:0}.song-list-thumbnail img{width:100%;height:100%;object-fit:cover}.song-list-info{flex:1;min-width:0}.song-list-title{display:block;font-weight:600;color:var(--text-primary);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.song-list-title:hover{color:var(--accent)}.song-list-meta{font-size:13px;color:var(--text-secondary)}.song-list-private{color:var(--accent);font-weight:600}.song-list-actions{display:flex;gap:8px;align-items:center}.song-action-btn{width:36px;height:36px;border-radius:50%;background:transparent;color:var(--text-secondary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;text-decoration:none}.song-action-btn:hover{background:var(--bg-elevated);border-color:var(--accent);color:var(--accent)}.song-action-delete{color:#ef4444}.song-action-delete:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.song-list-like{width:40px;height:40px;border-radius:50%;background:transparent;color:var(--text-secondary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.song-list-like:hover{background:var(--bg-base);border-color:var(--accent)}.song-list-play{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;color:var(--text-tertiary)}.empty-state p{margin-top:16px;font-size:16px}.loading-page{display:flex;align-items:center;justify-content:center;min-height:50vh}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;cursor:pointer;text-decoration:none;color:var(--text-primary)}.dashboard-card h3{margin:16px 0 0;font-size:20px;font-weight:600}.dashboard-card p{margin:8px 0 0;color:var(--text-secondary)}.analytics-stat-card{display:flex;flex-direction:column;gap:12px}.analytics-stat-header{display:flex;align-items:center;gap:8px}.analytics-stat-label{color:var(--text-secondary);font-size:14px;font-weight:500}.analytics-stat-value{font-size:32px;font-weight:700;color:var(--text-primary);margin:0}.song-details-hero{display:flex;gap:32px;margin-bottom:48px;padding:32px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px}.song-details-thumbnail{flex-shrink:0;width:300px;height:300px;border-radius:12px;overflow:hidden;background:var(--bg-base)}.song-details-thumbnail img{width:100%;height:100%;object-fit:cover}.song-details-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:var(--bg-base)}.song-details-info{flex:1;display:flex;flex-direction:column;gap:16px}.song-details-title{font-size:36px;font-weight:700;margin:0;color:var(--text-primary)}.song-details-artist{font-size:20px;color:var(--text-secondary);text-decoration:none;display:inline-block;margin-bottom:8px}.song-details-artist:hover{color:var(--accent)}.song-details-stats{display:flex;gap:24px;margin:16px 0}.song-stat{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px}.song-details-actions{display:flex;gap:12px;margin-top:auto}.btn-lg{padding:14px 28px;font-size:16px}.song-details-section{margin-bottom:32px;padding:24px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px}.song-details-section .section-title{font-size:20px;font-weight:600;margin:0 0 16px;color:var(--text-primary)}.collaborators-list{display:flex;flex-direction:column;gap:12px}.collaborator-item{display:flex;justify-content:space-between;padding:12px;background:var(--bg-base);border-radius:8px}.collaborator-name{font-weight:500;color:var(--text-primary)}.collaborator-role{color:var(--text-secondary);font-size:14px}.external-links{display:flex;gap:12px;flex-wrap:wrap}.external-link{padding:10px 20px;background:var(--bg-base);border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text-primary);font-weight:500;transition:all .2s}.external-link:hover{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.edit-profile-form{max-width:600px;margin:0 auto}.form-section{margin-bottom:24px}.form-label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:8px;font-size:14px}.form-input,.form-textarea{width:100%;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;font-family:inherit;transition:border-color .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent)}.form-textarea{min-height:100px;resize:vertical}.image-upload-container{margin-bottom:24px}.image-preview{position:relative;width:200px;height:200px;border-radius:12px;overflow:hidden;margin-bottom:12px;background:var(--bg-base);display:flex;align-items:center;justify-content:center}.image-preview img{width:100%;height:100%;object-fit:cover}.image-preview-placeholder{color:var(--text-tertiary)}.image-remove-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:#000000b3;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.image-remove-btn:hover{background:#ef4444}.image-upload-btn{display:inline-block;cursor:pointer}.image-upload-btn input[type=file]{display:none}.image-upload-wrapper{width:100%}.background-wrapper,.profile-wrapper{margin-bottom:24px}.image-preview-container{position:relative;border-radius:12px;overflow:hidden;background:var(--bg-elevated)}.background-preview{width:100%;height:200px}.profile-image-preview{width:200px;height:200px}.image-preview-container img{width:100%;height:100%;object-fit:cover;display:block}.image-upload-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;border:2px dashed var(--border);border-radius:12px;background:var(--bg-elevated);cursor:pointer;transition:all .2s;color:var(--text-secondary)}.image-upload-box:hover{border-color:var(--accent);background:var(--bg-surface);color:var(--accent)}.background-box{width:100%;min-height:150px}.profile-box{width:200px;height:200px}.image-upload-box input[type=file]{display:none}.image-upload-box span{font-size:14px;font-weight:500}.links-section{margin-bottom:24px}.link-input-group{display:flex;gap:8px;margin-bottom:12px}.link-input-group input{flex:1}.btn-icon-danger{padding:8px 12px;background:transparent;border:1px solid var(--border);color:#ef4444;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon-danger:hover{background:#ef44441a;border-color:#ef4444}.btn-text{padding:10px 20px;background:transparent;border:1px solid var(--border);color:var(--text-primary);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-text:hover{background:var(--bg-secondary)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}@media(max-width:768px){.main-content{padding-bottom:140px}.page{padding:16px 12px}.container{padding:0 8px}.page-title{font-size:24px}.navbar{display:none}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:var(--bg-surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;padding:0 16px;z-index:100}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;color:var(--text-secondary);text-decoration:none;transition:color .2s;cursor:pointer;background:transparent;border:none}.mobile-nav-item.active,.mobile-nav-item:hover{color:var(--accent)}.mobile-nav-item span{font-size:11px;font-weight:500}.song-details-hero{flex-direction:column;padding:20px;gap:20px}.song-details-thumbnail{width:100%;height:280px}.song-details-title{font-size:24px}.song-details-actions{flex-wrap:wrap}.profile-header{padding:20px 12px}.profile-header-content{flex-direction:column;text-align:center;gap:16px;padding:0 12px}.profile-avatar{width:100px;height:100px;border-width:3px}.profile-avatar-placeholder{font-size:36px}.profile-name{font-size:24px}.profile-username{font-size:14px}.profile-stats{justify-content:center;flex-wrap:wrap;gap:16px}.profile-stat{font-size:13px}.profile-bio{font-size:14px;text-align:center}.profile-links{justify-content:center}.profile-actions{width:100%;margin-top:16px;padding:12px;box-shadow:none}.profile-actions .btn{width:100%;justify-content:center}.songs-grid{grid-template-columns:1fr;gap:8px}.song-card{display:flex;flex-direction:row;align-items:center;padding:8px;gap:12px}.song-card-thumbnail{width:60px;height:60px;margin-bottom:0;flex-shrink:0}.song-card-content{flex:1;min-width:0}.song-card-play{position:static;width:36px;height:36px;opacity:1;flex-shrink:0}.song-card-footer{margin-top:4px;padding-top:4px}.dashboard-grid{grid-template-columns:1fr}.dashboard-card{padding:32px 24px}.dashboard-card h3{font-size:18px}.dashboard-card svg{width:40px;height:40px}.edit-profile-form{padding:0 12px}.image-preview{width:150px;height:150px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.song-list-item{padding:8px;gap:10px}.song-list-number{display:none}.song-list-thumbnail{width:56px;height:56px;border-radius:4px}.song-list-info{flex:1;min-width:0}.song-list-title{font-size:14px;font-weight:600}.song-list-meta{font-size:12px}.song-list-play,.song-list-like{width:36px;height:36px}.song-list-play svg,.song-list-like svg{width:18px;height:18px}.song-action-btn{width:32px;height:32px}.song-action-btn svg{width:16px;height:16px}.song-list-actions{gap:4px}}@media(max-width:480px){.songs-grid{grid-template-columns:1fr}.song-details-actions{flex-direction:column}.song-details-actions button{width:100%}}
