:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}.icon-svg{width:24px;height:24px;color:currentColor}.icon-svg-md{width:32px;height:32px;color:currentColor}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.icon-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:inherit;color:inherit}.icon-button .icon{width:24px;height:24px;margin-bottom:4px}.icon-button .button-text{font-size:12px}.icon-button:hover{background-color:#0000001a;border-radius:4px}.app{height:100vh;display:flex;flex-direction:column;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}*{box-sizing:border-box}body{margin:0;padding:0;background-color:#181818}:root{--navbar-height: 60px;--mini-player-height: 60px;--navbar-height-mobile: 50px;--mini-player-height-mobile: 70px;--primary-color: #1DB954;--accent-color: #FF6347;--background-color: #121212;--background-color-secondary: #282828;--card-background: #181818;--text-color: #FFFFFF;--text-color-primary: #FFFFFF;--text-color-secondary: #B3B3B3;--text-color-light: #000000;--border-color: #404040}@media (max-width: 768px){:root{--navbar-height: var(--navbar-height-mobile);--mini-player-height: var(--mini-player-height-mobile)}}@media (max-width: 480px){.app{min-height:890px}}.search-form{width:100%;max-width:400px}.search-input-group{display:flex;gap:.5rem;align-items:center}.search-input{flex:1;padding:.5rem 1rem;border:1px solid #3a4b5d;border-radius:4px;background-color:#1a2332;color:#d4f0e5;font-size:.9rem;transition:border-color .3s,box-shadow .3s}.search-input:focus{outline:none;border-color:#1db954;box-shadow:0 0 0 2px #1db95433}.search-input::placeholder{color:#b5cec4}.search-input:disabled{opacity:.6;cursor:not-allowed}.search-submit-btn{padding:.5rem 1rem;background-color:#1db954;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .3s;white-space:nowrap}.search-submit-btn:hover:not(:disabled){background-color:#1aa34a}.search-submit-btn:disabled{background-color:#3a4b5d;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.search-form{max-width:100%}.search-input-group{gap:.375rem}.search-input,.search-submit-btn{padding:.375rem .75rem;font-size:.85rem}}@media (max-width: 480px){.search-input-group{flex-direction:row;gap:.25rem}.search-input{flex:1 1 auto;min-width:0}.search-submit-btn{width:auto;padding:.375rem .5rem;font-size:.8rem}}.navbar{position:fixed;top:0;left:0;right:0;background-color:#212529;color:#fff;padding:1rem;z-index:1000;box-shadow:0 2px 4px #0000001a;height:var(--navbar-height);display:flex;align-items:center}.navbar-content{display:flex;align-items:center;max-width:1200px;margin:0 auto;width:100%;gap:1rem}.navbar-content>.search-form{flex:1;max-width:400px;margin:0 1rem}@media (max-width: 768px){.navbar-content>.search-form{max-width:300px;margin:0 .5rem}}@media (max-width: 480px){.navbar-content>.search-form{display:block;max-width:200px;margin:0 .25rem}}.navbar-title{margin:0;font-size:1.5rem;font-weight:700}.navbar-menu{display:flex;gap:1rem;align-items:center;flex:1}.navbar-button{background:none;border:none;color:#fff;cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s}.navbar-button:hover{background-color:#ffffff1a}.navbar-title-link,.navbar-title-link:hover{text-decoration:none;color:#fff}.navbar-right-section{display:flex;align-items:center;gap:1rem;margin-left:auto}.navbar-user{display:flex;align-items:center;gap:1rem}.navbar-user-email{font-size:.9rem;color:#adb5bd}.navbar-auth{display:flex;gap:.5rem}.navbar-auth .navbar-button{text-decoration:none;display:inline-block;text-align:center}.navbar-mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .3s;flex-direction:column;justify-content:center;align-items:center;gap:3px}.navbar-mobile-toggle:hover{background-color:#ffffff1a}.hamburger-line{width:20px;height:2px;background-color:#fff;transition:all .3s ease;transform-origin:center}.navbar-mobile-toggle.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.navbar-mobile-toggle.active .hamburger-line:nth-child(2){opacity:0}.navbar-mobile-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}@media (max-width: 768px){.navbar{padding:.75rem;height:var(--navbar-height-mobile)}.navbar-title{font-size:1.25rem}.navbar-menu{gap:.5rem}.navbar-button{padding:.375rem .75rem;font-size:.875rem}.navbar-user{gap:.5rem}.navbar-user-email{font-size:.8rem}}@media (max-width: 480px){.navbar-mobile-toggle{display:flex;order:3;flex-shrink:0;margin-left:.5rem}.navbar-content{gap:0}.navbar-title{font-size:1.1rem;order:1;flex:1;flex-shrink:0;margin-right:.5rem}.navbar-content>.search-form{order:2;flex:1 1 0;max-width:none;min-width:0;margin:0}.navbar-menu{position:absolute;top:100%;left:0;right:0;background-color:#212529;flex-direction:column;padding:1rem;gap:.5rem;box-shadow:0 4px 8px #0000004d;transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .3s ease;z-index:999}.navbar-menu.mobile-menu-open{transform:translateY(0);opacity:1;visibility:visible}.navbar-menu.mobile-menu-open .navbar-button{display:block;width:100%;text-align:center;padding:.75rem 1rem;font-size:.9rem}.navbar-right-section{flex-direction:column;align-items:stretch;gap:.5rem;margin-left:0;width:100%}.navbar-user{flex-direction:column;align-items:stretch;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #495057}.navbar-user-email{font-size:.8rem;text-align:center}.navbar-auth{flex-direction:column;align-items:stretch;gap:.5rem}.navbar-auth .navbar-button{display:block;width:100%;text-align:center;padding:.75rem 1rem;font-size:.9rem}}.mini-player{position:fixed;bottom:0;left:0;width:100%;background-color:#282828;color:#fff;padding:10px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 -2px 10px #00000080;z-index:1000;transform:translateY(100%);transition:transform .3s ease-out;height:var(--mini-player-height)}.mini-player.active{transform:translateY(0)}.mini-player-progress-bar{width:100%;height:4px;background-color:#404040;position:absolute;top:0;left:0}.mini-player-progress-fill{height:100%;background-color:#1db954;transition:width .1s linear}.mini-player-content{display:flex;justify-content:space-between;align-items:center;width:100%;padding-top:5px}.track-info{display:flex;align-items:center;flex-grow:1;max-width:65%;cursor:pointer}.album-cover{width:50px;height:50px;border-radius:50%;margin-right:15px;object-fit:cover}.track-details{display:flex;flex-direction:column;overflow:hidden}.track-title{font-size:1em;margin:0;font-weight:700;white-space:nowrap;display:inline-block}.track-title.playing{animation:marquee 15s linear infinite}@keyframes marquee{0%{transform:translate(100%)}to{transform:translate(-150%)}}.artist-name{font-size:.8em;color:#b3b3b3;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-controls{display:flex;align-items:center;gap:8px;flex-grow:0}.control-button{background:none;border:none;color:#fff;font-size:1.5em;cursor:pointer;padding:5px;transition:color .2s ease-in-out}.control-button:hover{color:#1db954}.playlist-controls{display:flex;align-items:center;gap:10px;flex-grow:0}.playlist-btn{font-size:1.5em}.playlist-position{font-size:.9em;color:#b3b3b3}@media (max-width: 768px){.mini-player{padding:10px 15px}.track-info{max-width:70%}.track-title{font-size:.9em}.player-controls{gap:10px}.control-button{font-size:1.4em}.control-button .icon-svg{width:24px;height:24px}.play-button{font-size:2.2em}.play-button .icon-svg{width:30px;height:30px}.playlist-btn{font-size:1.4em}.playlist-btn .icon-svg{width:24px;height:24px}}@media (max-width: 480px){.mini-player{padding:5px 10px}.track-info{max-width:60%}.album-cover{width:40px;height:40px;margin-right:10px}.track-title{font-size:.8em}.artist-name{font-size:.7em}.player-controls{gap:5px}.control-button{font-size:1.2em}.control-button .icon-svg{width:20px;height:20px}.play-button{font-size:1.8em}.play-button .icon-svg{width:26px;height:26px}.playlist-btn{font-size:1.2em}.playlist-btn .icon-svg{width:20px;height:20px}.playlist-position{display:none}}@media (display-mode: standalone),(display-mode: fullscreen){.mini-player{padding-bottom:calc(20px + env(safe-area-inset-bottom))}}.search-results-container{padding:20px;color:var(--text-color)}.search-results-title{font-size:2em;margin-bottom:20px;color:var(--primary-color)}.music-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.music-card{background-color:var(--card-bg-color);border-radius:8px;overflow:hidden;box-shadow:0 4px 8px #0003;transition:transform .2s ease;display:flex;flex-direction:column}.music-card:hover{transform:translateY(-5px)}.music-card-img{width:100%;height:200px;overflow:hidden;cursor:pointer}.music-card-img img{width:100%;height:100%;object-fit:cover}.in-queue-icon{position:absolute;top:8px;right:8px;background-color:var(--primary-color);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 5px #0003}.in-queue-icon .icon-svg{width:14px;height:14px}.music-card-body{padding:15px;flex-grow:1;display:flex;flex-direction:column;justify-content:space-between}.music-card-title{font-size:1.2em;margin:0 0 5px;color:var(--primary-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-card-artist{font-size:.9em;color:var(--secondary-text-color);margin:0 0 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.music-card-duration{font-size:.8em;color:var(--secondary-text-color)}.music-card-actions{display:flex;gap:8px;position:relative}.music-card-add-btn,.music-card-download-btn{background-color:var(--button-bg-color);color:var(--button-text-color);border:none;padding:8px;border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.music-card-add-btn:hover,.music-card-download-btn:hover{background-color:var(--button-hover-bg-color)}.music-card-add-btn.in-playlist{background-color:var(--primary-color);color:#fff}.music-card-add-btn.in-playlist:hover{background-color:var(--primary-color-dark)}.music-card-download-btn.downloaded{background-color:var(--success-color);color:#fff}.music-card-download-btn.downloaded:hover{background-color:var(--success-color);cursor:default}.music-card-download-btn.downloading{background-color:var(--secondary-color);color:#fff;cursor:default}.music-card-download-btn.downloading .spinner{border:2px solid rgba(255,255,255,.3);border-top:2px solid #fff;border-radius:50%;width:16px;height:16px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.add-to-playlist-modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem}.add-to-playlist-modal{background-color:#1a2332;border-radius:12px;box-shadow:0 10px 30px #00000080;width:100%;max-width:400px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden}.add-to-playlist-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #3a4b5d}.add-to-playlist-modal-title{margin:0;font-size:1.25rem;font-weight:700;color:#d4f0e5}.add-to-playlist-modal-close{background:none;border:none;color:#b5cec4;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:background-color .3s,color .3s}.add-to-playlist-modal-close:hover{background-color:#ffffff1a;color:#d4f0e5}.add-to-playlist-modal-content{flex:1;overflow-y:auto;padding:1.5rem}.selected-song-info{display:flex;align-items:center;gap:.75rem;padding:1rem;background-color:#1db9541a;border-radius:8px;margin-bottom:1.5rem}.selected-song-artwork{width:40px;height:40px;border-radius:6px;flex-shrink:0;object-fit:cover}.selected-song-details{flex:1;min-width:0;overflow:hidden}.selected-song-title{margin:0 0 .25rem;font-size:.9rem;font-weight:500;color:#d4f0e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-song-artist{margin:0;font-size:.8rem;color:#b5cec4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-selection-list{display:flex;flex-direction:column;gap:.5rem}.playlist-selection-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background-color:#ffffff0d;border-radius:8px;border:1px solid #3a4b5d;cursor:pointer;transition:all .3s;width:100%}.playlist-selection-item:hover:not(.disabled){background-color:#1db9541a;border-color:#1db954;transform:translateY(-1px)}.playlist-selection-item.disabled{opacity:.6;cursor:not-allowed;background-color:#1db9540d}.added-text{color:#1db954;font-weight:700;font-size:.9rem}.playlist-selection-info{flex:1;min-width:0;overflow:hidden}.playlist-selection-name{margin:0 0 .25rem;font-size:1rem;font-weight:500;color:#d4f0e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-selection-count{margin:0;font-size:.8rem;color:#b5cec4}.playlist-selection-item svg{color:#1db954;flex-shrink:0;width:20px;height:20px}.add-to-queue-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background-color:#ffffff0d;border-radius:8px;border:1px solid #3a4b5d;cursor:pointer;transition:all .3s;width:100%;color:#d4f0e5;font-size:1rem;font-weight:500;margin-bottom:1rem}.add-to-queue-btn:hover{background-color:#1db9541a;border-color:#1db954;transform:translateY(-1px)}.add-to-queue-btn svg{color:#1db954;flex-shrink:0;width:20px;height:20px}.no-playlists-message{text-align:center;padding:2rem 1rem;color:#b5cec4}.no-playlists-message p{margin:.5rem 0;font-size:.9rem}@media (max-width: 768px){.add-to-playlist-modal-overlay{padding:.5rem}.add-to-playlist-modal{max-height:80vh}.add-to-playlist-modal-header{padding:1rem}.add-to-playlist-modal-title{font-size:1.1rem}.add-to-playlist-modal-content{padding:1rem}.selected-song-info{padding:.75rem;gap:.5rem}.selected-song-artwork{width:35px;height:35px}.selected-song-title{font-size:.85rem}.selected-song-artist{font-size:.75rem}.playlist-selection-item{padding:.75rem}.add-to-queue-btn{padding:.75rem;font-size:.9rem}.playlist-selection-name{font-size:.9rem}.playlist-selection-count{font-size:.75rem}}@media (max-width: 480px){.add-to-playlist-modal-header{padding:.75rem}.add-to-playlist-modal-title{font-size:1rem}.add-to-playlist-modal-content{padding:.75rem}.selected-song-info{padding:.5rem}.selected-song-artwork{width:30px;height:30px}.selected-song-title{font-size:.8rem}.selected-song-artist{font-size:.7rem}.playlist-selection-item{padding:.5rem}.add-to-queue-btn{padding:.5rem;font-size:.85rem}.playlist-selection-name{font-size:.85rem}.playlist-selection-count{font-size:.7rem}}.explore-container{padding:20px;color:var(--text-color)}.explore-title{font-size:1.2em;margin-bottom:20px;color:var(--primary-color)}.chart-tabs{display:flex;justify-content:center;margin-bottom:20px;gap:5px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:5px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.chart-tabs::-webkit-scrollbar{display:none}.chart-tab-button{flex-shrink:0;background-color:var(--background-color-secondary);color:var(--text-color-secondary);border:1px solid var(--border-color);padding:8px 15px;font-size:.9em;border-radius:5px;cursor:pointer;transition:background-color .2s ease-in-out,color .2s ease-in-out,border-color .2s ease-in-out}.chart-tab-button:hover{background-color:var(--primary-color);color:var(--text-color-light);border-color:var(--primary-color)}.chart-tab-button.active{background-color:var(--primary-color);color:var(--text-color-light);border-color:var(--primary-color);font-weight:700}.chart-tab-button.play-now-button{background-color:var(--primary-color);color:var(--text-color-light);border-color:var(--primary-color);border-radius:50%;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;margin-left:5px}.chart-tab-button.play-now-button .icon-svg{width:20px;height:20px}.trending-cards-row{display:flex;overflow-x:auto;gap:20px;padding-bottom:15px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--primary-color) var(--background-color)}.trending-cards-row::-webkit-scrollbar{height:8px}.trending-cards-row::-webkit-scrollbar-track{background:var(--background-color)}.trending-cards-row::-webkit-scrollbar-thumb{background-color:var(--primary-color);border-radius:10px;border:2px solid var(--background-color)}.trending-cards-row .music-card{flex:0 0 auto;width:220px;background-color:var(--card-background);border-radius:10px;overflow:hidden;box-shadow:0 4px 8px #0003;transition:transform .2s ease-in-out;cursor:pointer}.trending-cards-row .music-card:hover{transform:translateY(-5px)}.trending-cards-row .music-card-img{position:relative;width:100%;padding-top:100%;overflow:hidden}.trending-cards-row .music-card-img img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.in-queue-icon{position:absolute;top:10px;right:10px;background-color:#000000b3;border-radius:50%;padding:5px;display:flex;align-items:center;justify-content:center}.in-queue-icon .icon-svg{width:20px;height:20px;color:var(--primary-color)}.trending-cards-row .music-card-body{padding:15px}.trending-cards-row .music-card-title{font-size:1.1em;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trending-cards-row .music-card-artist{font-size:.9em;color:var(--text-secondary-color);margin-bottom:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trending-cards-row .music-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.trending-cards-row .music-card-duration{font-size:.8em;color:var(--text-secondary-color)}.trending-cards-row .music-card-actions{display:flex;gap:10px}.trending-cards-row .music-card-add-btn,.trending-cards-row .music-card-download-btn{background:none;border:none;color:var(--text-color);cursor:pointer;padding:5px;border-radius:5px;transition:background-color .2s ease-in-out}.trending-cards-row .music-card-add-btn:hover,.trending-cards-row .music-card-download-btn:hover{background-color:#ffffff1a}.trending-cards-row .music-card-download-btn.downloaded{color:var(--primary-color)}.trending-cards-row .music-card-download-btn.downloading{color:var(--accent-color)}.trending-cards-row .music-card-actions .icon-svg{width:20px;height:20px}.initial-loading-spinner-container{display:flex;justify-content:center;align-items:center;padding:20px 0}.loading-spinner{width:20px;height:20px;vertical-align:middle;animation:rotate 2s linear infinite}.loading-spinner .path{stroke:var(--accent-color);stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}.recommendations-section{padding-bottom:20px}.recommendations-section .trending-cards-row{scrollbar-width:thin;scrollbar-color:var(--primary-color) var(--background-color)}.recommendations-section .trending-cards-row::-webkit-scrollbar{height:8px}.recommendations-section .trending-cards-row::-webkit-scrollbar-track{background:var(--background-color)}.recommendations-section .trending-cards-row::-webkit-scrollbar-thumb{background-color:var(--primary-color);border-radius:10px;border:2px solid var(--background-color)}.recommendations-section .trending-cards-row .load-more-card{display:flex;justify-content:center;align-items:center;width:calc(var(--music-card-width) / 2);height:var(--music-card-height);background-color:var(--card-background);border-radius:10px;cursor:pointer;transition:transform .2s ease-in-out;flex-shrink:0;margin-right:20px;box-shadow:0 4px 8px #0003}.recommendations-section .trending-cards-row .load-more-card:hover{transform:translateY(-5px)}.recommendations-section .trending-cards-row .load-more-card .load-more-content{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.recommendations-section .trending-cards-row .load-more-card .load-more-arrow{width:48px;height:48px;color:var(--primary-color)}@media (min-width: 1200px){.trending-cards-row .music-card{width:calc(25% - 15px)}.recommendations-section .trending-cards-row .load-more-card{width:calc((25% - 15px)/2)}}@media (min-width: 768px) and (max-width: 1199px){.trending-cards-row .music-card{width:calc((100% / 3) - 13.33px)}.recommendations-section .trending-cards-row .load-more-card{width:calc(((100% / 3) - 13.33px) / 2)}}@media (max-width: 767px){.trending-cards-row .music-card{width:calc(65% - 10px)}.recommendations-section .trending-cards-row .load-more-card{width:calc((65% - 10px)/2)}}.main-container{position:fixed;top:var(--navbar-height);bottom:var(--mini-player-height);left:0;right:0;overflow-y:auto;background-color:#0a141a}@media (max-width: 768px){.content-wrapper{padding:1rem .75rem}}@media (max-width: 480px){.content-wrapper{padding:.75rem .5rem}}.section-title{padding-top:30px;font-size:1.5rem;font-weight:700;color:#d4f0e5}.search-results{background-color:#1a2332;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.song-item{display:flex;align-items:center;padding:1rem;border-bottom:1px solid #3a4b5d;transition:background-color .3s}.song-item:hover{background-color:#ffffff0d}.song-item:last-child{border-bottom:none}.song-info{flex:1;min-width:0}.song-title{margin:0;font-size:1rem;font-weight:500;color:#d4f0e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist{margin:.25rem 0 0;font-size:.875rem;color:#b5cec4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-duration{font-size:.875rem;color:#b5cec4;margin-right:1rem;flex-shrink:0}.play-song-button{background:none;border:none;color:#1db954;cursor:pointer;padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:background-color .3s;flex-shrink:0}.play-song-button:hover{background-color:#1db9541a}.loading-more{position:sticky;bottom:80px;display:flex;align-items:center;justify-content:center;padding:1rem;gap:0}.loading-text{color:#b5cec4;font-size:.9rem}.additional-content{margin-bottom:2rem;padding-bottom:30px}.playlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.playlist-item{background-color:#1a2332;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;transition:transform .3s,box-shadow .3s}.playlist-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.playlist-cover{width:100%;height:150px;object-fit:cover}.playlist-title{margin:1rem;font-size:1rem;font-weight:500;color:#d4f0e5}.playlist-description{margin:0 1rem 1rem;font-size:.875rem;color:#b5cec4}@media (max-width: 768px){.playlist-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.playlist-item{border-radius:6px}.playlist-cover{height:120px}.playlist-title{margin:.75rem;font-size:.9rem}.playlist-description{margin:0 .75rem .75rem;font-size:.8rem}.song-item{padding:.75rem}.song-title{font-size:.9rem}.song-artist{font-size:.8rem}.play-song-button{width:36px;height:36px;padding:.375rem}}@media (max-width: 480px){.playlist-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.playlist-cover{height:100px}.playlist-title{margin:.5rem;font-size:.85rem}.playlist-description{margin:0 .5rem .5rem;font-size:.75rem}.section-title{font-size:1.25rem;margin-bottom:1rem}.song-item{padding:.5rem}.song-title{font-size:.85rem}.song-artist{font-size:.75rem}.song-duration{font-size:.8rem}.play-song-button{width:32px;height:32px;padding:.25rem}}.playlist-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.playlist-modal{background-color:#1a2332;border-radius:12px;box-shadow:0 10px 30px #00000080;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.playlist-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #3a4b5d}.playlist-modal-title{margin:0;font-size:1.5rem;font-weight:700;color:#d4f0e5}.playlist-modal-close{background:none;border:none;color:#b5cec4;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:background-color .3s,color .3s}.playlist-modal-close:hover{background-color:#ffffff1a;color:#d4f0e5}.playlist-modal-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #3a4b5d;gap:1rem}.playback-mode-controls{display:flex;gap:.5rem}.playback-mode-btn{background:none;border:1px solid #3a4b5d;color:#b5cec4;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .3s}.playback-mode-btn:hover{border-color:#1db954;color:#1db954}.playback-mode-btn.active{background-color:#1db954;border-color:#1db954;color:#fff}.clear-playlist-btn,.save-queue-btn{background:none;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem}.save-queue-btn:hover:not(:disabled){background-color:#1db954}.clear-playlist-btn:hover:not(:disabled){background-color:#c82333}.clear-playlist-btn:disabled{background-color:#6c757d;cursor:not-allowed}.playlist-modal-content{flex:1;overflow-y:auto;padding:0}.empty-playlist{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:#b5cec4}.empty-playlist p{margin:.5rem 0;font-size:1rem}.playlist-download-btn.downloading{position:relative;color:transparent;pointer-events:none}.playlist-download-btn.downloading .spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid #1db954;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.playlist-items{padding:0}.playlist-item{display:flex;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #3a4b5d;transition:background-color .3s;gap:1rem}.playlist-item:hover{background-color:#ffffff0d}.playlist-item.current{background-color:#1db9541a;border-left:4px solid #1db954}.playlist-item:last-child{border-bottom:none}.playlist-item-info{display:flex;align-items:center;flex:1;min-width:0;gap:.75rem}.playlist-item-artwork{width:50px;height:50px;border-radius:6px;flex-shrink:0;object-fit:cover}.playlist-item-details{flex:1;min-width:0;overflow:hidden}.playlist-item-title{margin:0 0 .25rem;font-size:1rem;font-weight:500;color:#d4f0e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item-artist{margin:0;font-size:.875rem;color:#b5cec4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item-controls{display:flex;gap:.5rem;flex-shrink:0}.playlist-play-btn,.playlist-remove-btn,.playlist-download-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:all .3s;font-size:1rem}.playlist-play-btn{color:#1db954}.playlist-play-btn:hover{background-color:#1db9541a;transform:scale(1.1)}.playlist-remove-btn{color:#f9ced2}.playlist-remove-btn:hover{background-color:#dc35451a;transform:scale(1.1)}@media (max-width: 768px){.playlist-modal-overlay{padding:.5rem}.playlist-modal{max-height:90vh}.playlist-modal-header{padding:1rem}.playlist-modal-title{font-size:1.25rem}.playlist-modal-controls{padding:.75rem 1rem;gap:.75rem}.playback-mode-controls{justify-content:center}.playlist-item{padding:.75rem 1rem;gap:.75rem}.playlist-item-artwork{width:40px;height:40px}.playlist-item-title{font-size:.9rem}.playlist-item-artist{font-size:.8rem}.playlist-play-btn,.playlist-remove-btn{width:32px;height:32px;padding:.375rem;font-size:.9rem}}@media (max-width: 480px){.playlist-modal-header{padding:.75rem}.playlist-modal-title{font-size:1.1rem}.playlist-modal-controls{padding:.5rem .75rem}.playback-mode-btn{padding:.375rem .5rem;font-size:.8rem}.clear-playlist-btn{padding:.375rem .75rem;font-size:.8rem}.playlist-item{padding:.5rem .75rem}.playlist-item-info{gap:.5rem}.playlist-item-artwork{width:35px;height:35px}.playlist-item-title{font-size:.85rem}.playlist-item-artist{font-size:.75rem}.playlist-item-controls{gap:.25rem}.playlist-play-btn,.playlist-remove-btn{width:28px;height:28px;padding:.25rem;font-size:.8rem}}.playlist-add-to-playlist-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:all .3s;color:#b5cec4;font-size:1rem}.playlist-add-to-playlist-btn:hover{background-color:#1db9541a;color:#1db954;transform:scale(1.1)}@media (max-width: 768px){.login-card{max-width:90vw;margin-top:1rem;border-radius:16px}.login-header{padding:1.5rem 1rem}.login-header h3{font-size:1.5rem}.login-body{padding:1.5rem 1rem}.form-control{padding:.625rem .875rem;font-size:.95rem}.btn-login{padding:.625rem 1.5rem;font-size:.95rem}.login-footer{padding:.75rem 1rem 1rem}}@media (max-width: 480px){.login-card{max-width:95vw;margin:.5rem auto;border-radius:12px}.login-header{padding:1.25rem .875rem}.login-header h3{font-size:1.375rem}.login-body{padding:1.25rem .875rem}.form-group{margin-bottom:1.25rem}.form-label{font-size:.9rem}.form-control{padding:.5rem .75rem;font-size:.9rem}.btn-login{padding:.5rem 1.25rem;font-size:.9rem}.login-footer{padding:.5rem .875rem .875rem}.login-footer p{font-size:.85rem}}.login-header{background:linear-gradient(135deg,#0a141a,#1a2332);color:#d4f0e5;padding:2rem 1.5rem;text-align:center;margin:0;border-bottom:1px solid #3a4b5d;margin-top:1rem}.login-header h3{margin:0;font-size:1.8rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.form-label{color:#b5cec4;font-weight:500;margin-bottom:.5rem;display:block}.form-control{border:2px solid #1f4468;border-radius:10px;padding:.75rem 1rem;font-size:1rem;transition:all .3s ease;background-color:#122130;width:100%}.form-control:focus{border-color:#20364d;box-shadow:0 0 0 3px #667eea1a;background-color:#172533}.form-check{display:flex;align-items:center;margin-bottom:1.5rem}.form-check-input{margin-right:.5rem;width:18px;height:18px}.form-check-label{color:#666;font-weight:400;cursor:pointer}.login-footer{text-align:center;padding:1rem 1.5rem 1.5rem;background-color:linear-gradient(135deg,#0a141a 0%,#1a2332 100%);border-top:1px solid #e9ecef}.login-footer p{margin:0;color:#666;font-size:.9rem}.login-footer a{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s ease}.login-footer a:hover{color:#764ba2;text-decoration:underline}.forgot-password-link{margin-top:15px}.forgot-password-link a{color:#61dafb;text-decoration:none;font-weight:500;transition:color .3s ease}.forgot-password-link a:hover{color:#4fa3d1;text-decoration:underline}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#282c34;padding:30px;border-radius:8px;box-shadow:0 4px 15px #00000080;width:90%;max-width:400px;text-align:center;color:#fff;position:relative}.modal-content h2{margin-bottom:20px;color:#61dafb}.form-group{margin-bottom:15px;text-align:left}.form-group label{display:block;margin-bottom:8px;font-weight:700}.form-group input[type=email]{width:calc(100% - 20px);padding:10px;border:1px solid #444;border-radius:4px;background-color:#3a3f47;color:#fff;font-size:16px}.form-group input[type=email]:focus{outline:none;border-color:#61dafb;box-shadow:0 0 0 2px #61dafb80}.submit-button{background-color:#61dafb;color:#282c34;padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .3s ease;width:100%;margin-top:10px;display:flex;justify-content:center;align-items:center;min-height:40px}.submit-button:hover{background-color:#4fa3d1}.loading-spinner{animation:rotate 2s linear infinite;height:20px;width:20px}.loading-spinner .path{stroke:#282c34;stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.close-button{background:none;border:none;color:#aaa;font-size:14px;cursor:pointer;margin-top:20px;transition:color .3s ease}.close-button:hover{color:#fff}.success-message{color:#4caf50;margin-top:15px}.error-message{color:#f44336;margin-top:15px}.alert-banner{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1000;min-width:300px;max-width:500px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideDown .3s ease-out}.alert-banner--success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-banner--error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-banner__content{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}.alert-banner__message{flex:1;font-size:14px;font-weight:500}.alert-banner__close{background:none;border:none;font-size:20px;font-weight:700;cursor:pointer;padding:0;margin-left:12px;color:inherit;opacity:.7;transition:opacity .2s ease}.alert-banner__close:hover{opacity:1}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@media (max-width: 600px){.alert-banner{left:10px;right:10px;transform:none;min-width:auto}}.alert-banner--confirm{position:fixed;top:0;width:100%;height:100%;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001;animation:fadeIn .3s ease-out forwards}.alert-banner--confirm .alert-banner__content{background-color:#282828;border:1px solid #555;border-radius:8px;box-shadow:0 8px 20px #0006;padding:25px;max-width:400px;width:90%;flex-direction:column;text-align:center}.alert-banner--confirm .alert-banner__message{margin-bottom:20px;font-size:1.1em;color:#fff}.alert-banner__actions{display:flex;justify-content:center;gap:15px;width:100%}.alert-banner__button{padding:10px 20px;border-radius:5px;border:none;cursor:pointer;font-size:1em;font-weight:700;transition:background-color .2s ease}.alert-banner__button--confirm{background-color:#f44336;color:#fff}.alert-banner__button--confirm:hover{background-color:#d32f2f}.alert-banner__button--cancel{background-color:#555;color:#fff}.alert-banner__button--cancel:hover{background-color:#777}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-container{position:fixed;inset:0;overflow-y:auto;background:linear-gradient(135deg,#0a141a,#1a2332)}.content-wrapper{max-width:1200px;margin:0 auto;padding:2rem 1rem}.centered-content{display:flex;align-items:center;justify-content:center;min-height:100vh;padding-top:2rem}.login-card{background:#0a141a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:20px;box-shadow:0 20px 40px #0000004d;overflow:hidden;max-width:400px;width:100%;margin-top:3rem}.login-body{padding:2rem 1.5rem}.login-body h2{color:#d4f0e5;margin-bottom:20px;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{color:#b5cec4;font-weight:500;margin-bottom:.5rem;display:block}.form-group input[type=password]{border:2px solid #1f4468;border-radius:10px;padding:.75rem 1rem;font-size:1rem;transition:all .3s ease;background-color:#122130;width:100%;color:#fff}.form-group input[type=password]:focus{border-color:#20364d;box-shadow:0 0 0 3px #667eea1a;background-color:#172533;outline:none}.btn-login{background:#172533;border:none;border-radius:10px;padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#d4f0e5;width:100%;transition:all .3s ease;cursor:pointer}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-login:disabled{opacity:.7;cursor:not-allowed}.alert-danger{background-color:#fee;border:1px solid #fcc;color:#c33;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.alert-success{background-color:#e6ffe6;border:1px solid #ccffcc;color:#3c3;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.max-player-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#1a1a1a;color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:20px;box-sizing:border-box;z-index:1000;overflow-y:auto}.max-player-container.no-song{justify-content:center;text-align:center}.back-button{position:absolute;top:20px;left:20px;background:none;border:none;color:#fff;font-size:1.2em;cursor:pointer;padding:5px 10px;border-radius:5px;transition:background-color .2s ease}.song-metadata{text-align:center;margin-bottom:30px}.song-artwork{width:300px;height:300px;object-fit:cover;border-radius:10px;margin-bottom:20px;box-shadow:0 4px 15px #00000080}.song-title-wrapper{overflow:hidden;width:100%}.song-title-marquee-content{display:flex;white-space:nowrap}.song-title{font-size:2.2em;font-weight:700;white-space:nowrap;padding-right:2rem}.song-title-marquee-content.playing{animation:marquee 12s linear infinite}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.song-artist{font-size:1.2em;color:#bbb}.playback-controls{width:100%;max-width:500px;margin-bottom:0}.progress-bar-container{display:flex;align-items:center;gap:10px;margin-bottom:20px}.progress-bar{flex-grow:1;-webkit-appearance:none;appearance:none;height:6px;background:#555;border-radius:3px;outline:none;cursor:pointer}.progress-bar::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#1db954;border-radius:50%;cursor:pointer}.progress-bar::-moz-range-thumb{width:16px;height:16px;background:#1db954;border-radius:50%;cursor:pointer}.current-time,.duration{font-size:.9em;color:#aaa;width:40px;text-align:center}.control-buttons{display:flex;justify-content:center;gap:15px;align-items:center}.control-button{background:none;border:none;color:#fff;font-size:1.1em;cursor:pointer;padding:10px 15px;border-radius:5px;transition:background-color .2s ease,transform .1s ease}.control-button:hover{background-color:#ffffff1a}.control-button:active{transform:scale(.95)}.control-button.play-pause{font-size:1.5em;padding:12px 20px;background-color:#1db954;border-radius:50px;min-width:100px;color:#000}.control-button.play-pause:hover{background-color:#1ed760}.lyrics-placeholder{margin-top:40px;text-align:center;width:100%;max-width:600px;padding:20px;background-color:#282828;border-radius:10px;box-shadow:0 2px 10px #0000004d}.lyrics-placeholder h3{margin-top:0;color:#1db954}.lyrics-placeholder p{color:#ccc;line-height:1.6}@media (max-width: 768px){.song-artwork{width:200px;height:200px}.song-title{font-size:1.8em;animation:none}.song-artist{font-size:1em}.control-buttons{flex-wrap:wrap;gap:10px}.control-button{font-size:1em;padding:8px 12px}.control-button.play-pause{font-size:1.3em;padding:10px 18px;min-width:80px}}@media (max-width: 480px){.max-player-container{padding:15px}.player-content-grid{display:flex;flex-direction:column;align-items:center;gap:40px;flex-grow:1;justify-content:flex-start;padding-top:30px}.song-metadata{display:flex;flex-direction:column;align-items:center;gap:5px;margin-bottom:0;width:100%;max-width:100%}.back-button{top:15px;left:15px;font-size:1em}.song-artwork{width:200px;height:200px;margin-bottom:0}.song-title{font-size:1.5em;animation:none;margin:0}.song-title-wrapper{overflow:hidden;max-width:100%}.song-artist{font-size:.9em}.lyrics-placeholder{padding:15px;margin-top:0;text-align:center}.progress-bar-container{flex-wrap:wrap;justify-content:center}.current-time,.duration{width:auto}.control-buttons{gap:8px}.control-button{font-size:.9em;padding:6px 10px}.control-button.play-pause{font-size:1.1em;padding:8px 15px;min-width:70px}}@media (min-width: 769px){.max-player-container{display:grid;grid-template-rows:minmax(0,1fr) auto;grid-template-columns:1fr;gap:20px;padding:20px;height:100vh;overflow:hidden}.player-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;width:100%;max-width:1200px;margin:0 auto;align-items:start;height:100%;overflow:hidden}.song-metadata{text-align:center;margin-bottom:0;display:flex;flex-direction:column;align-items:center;height:100%;overflow:hidden;min-width:0}.song-artwork{max-width:100%;height:auto;width:360px;height:360px}.lyrics-placeholder{margin-top:0;text-align:left;height:100%;overflow-y:auto;min-width:0}.playback-controls{grid-column:1 / -1;width:100%;max-width:600px;margin:0 auto}.back-button{font-size:3em}}@media (display-mode: standalone),(display-mode: fullscreen){.max-player-container{padding-bottom:calc(20px + env(safe-area-inset-bottom))}}.library-page{position:fixed;inset:0;padding:20px;color:#fff;background-color:#1a1a1a;overflow-y:auto;z-index:1000}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;position:relative}.library-page h2{font-size:2em;color:#fff;padding-top:0;position:absolute;left:50%;transform:translate(-50%);margin:0}.library-controls{margin-bottom:20px;display:flex;gap:10px;align-items:center}.create-playlist-btn{background:none;border:none;color:#fff;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:1em;transition:background-color .2s ease}.create-playlist-btn:hover{background-color:#ffffff1a}.create-playlist-form{display:flex;gap:10px}.create-playlist-form input[type=text]{padding:8px;border-radius:5px;border:1px solid #555;background-color:#333;color:#fff}.create-playlist-form button{background:none;border:none;color:#fff;padding:8px 12px;border-radius:5px;cursor:pointer;transition:background-color .2s ease}.create-playlist-form button:hover{background-color:#ffffff1a}.empty-library{text-align:center;padding:50px;border:1px dashed #555;border-radius:8px;background-color:#282828;margin-top:30px}.empty-library p{font-size:1.1em;margin-bottom:10px;color:#bbb}.playlist-tabs{margin-top:20px}.playlist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.playlist-actions{display:flex;gap:10px}.rename-btn,.delete-btn{background:none;border:none;color:#bbb;cursor:pointer;padding:5px;border-radius:3px;display:flex;align-items:center;justify-content:center}.rename-btn:hover,.delete-btn:hover{background-color:#ffffff1a}.tab-header input[type=text]{padding:5px;border-radius:3px;border:1px solid #555;background-color:#333;color:#fff;font-size:.9em}.tab-content .play-all-btn{background-color:#1db954;color:#fff;border:none;cursor:pointer;transition:background-color .2s ease}.tab-content .play-all-btn:hover{background-color:#1ed760}.tab-content .playlist-items{display:grid;gap:15px}.tab-content .playlist-item{position:relative;overflow:hidden;border-radius:8px;background-color:#333;box-shadow:0 4px 15px #00000080}.tab-content .playlist-item-swipe-content{display:flex;align-items:center;flex-grow:1;width:100%;padding:15px;background-color:#333;border-radius:8px;transition:transform .3s ease-out;cursor:pointer;gap:15px;position:relative;z-index:1}.tab-content .playlist-item-swipe-content:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0006}.tab-content .playlist-item-info{display:flex;align-items:center;flex-grow:1;gap:15px}.tab-content .playlist-item-artwork{width:60px;height:60px;border-radius:8px;flex-shrink:0;object-fit:cover;box-shadow:0 2px 8px #0000004d}.tab-content .playlist-item-details{flex-grow:1;min-width:0}.tab-content .playlist-item-title{font-size:1.2em;margin:0 0 5px;color:#fff;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tab-content .playlist-item-artist{font-size:1em;color:#bbb;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tab-content .playlist-item-remove-btn{position:absolute;right:0;top:0;bottom:0;width:80px;background-color:#333;color:#fff;border:none;padding:0;border-radius:0 8px 8px 0;cursor:pointer;font-size:.9em;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease-in-out;z-index:0}.tab-content .playlist-item-remove-btn:hover{background-color:#d32f2f}@media (min-width: 769px){.tab-content .playlist-item{display:flex;align-items:center;gap:15px;border-bottom:1px solid #555;transition:background-color .3s;background-color:#333;box-shadow:0 4px 15px #00000080;border-radius:8px;padding:15px}.tab-content .playlist-item:hover{background-color:#404040}.tab-content .playlist-item-swipe-content{display:flex;align-items:center;transform:translate(0)!important;transition:none!important;flex-grow:1;padding:0;background-color:transparent;box-shadow:none;cursor:default;flex:1 1 auto;gap:15px;min-width:0}.tab-content .playlist-item-swipe-content:hover{transform:none;box-shadow:none}.tab-content .playlist-item-info{display:flex;align-items:center;flex:1 1 0%;gap:15px;overflow:hidden;min-width:0}.tab-content .playlist-item-artwork{width:60px;height:60px;border-radius:8px;flex-shrink:0}.tab-content .playlist-item-details{flex:1 1 0%;overflow:hidden;min-width:0}.tab-content .playlist-item-remove-btn{background:none;border:none;color:#fff;padding:8px 12px;border-radius:5px;cursor:pointer;font-size:.9em;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;position:static;z-index:auto;flex-shrink:0;margin-left:10px}.tab-content .playlist-item-remove-btn:hover{background-color:#f003;transform:none}}.library-loading{text-align:center;padding:50px;font-size:1.2em;color:#bbb}.icon-svg{width:16px;height:16px;vertical-align:middle}.library-actions-right{display:flex;gap:10px;align-items:center}.icon-button{background:none;border:none;color:#fff;padding:5px 10px;border-radius:5px;cursor:pointer;font-size:1em;transition:background-color .2s ease;display:flex;align-items:center;gap:5px}.icon-button:hover{background-color:#ffffff1a}.import-playlist-btn,.export-btn{background:none;border:none;color:#fff;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:1em;transition:background-color .2s ease;display:flex;align-items:center;gap:5px}.import-playlist-btn:hover,.export-btn:hover{background-color:#ffffff1a}@media (max-width: 768px){.tab-content .playlist-items{width:100%}.tab-content .playlist-item-swipe-content{padding:10px;gap:10px}.tab-content .playlist-item-artwork{width:50px;height:50px}.tab-content .playlist-item-title{font-size:1em}.tab-content .playlist-item-artist{font-size:.8em}.tab-content .playlist-item-remove-btn{width:70px;font-size:.8em}}@media (max-width: 480px){.tab-content .playlist-item-swipe-content{padding:8px;gap:8px}.tab-content .playlist-item-artwork{width:40px;height:40px}.tab-content .playlist-item-title{font-size:.9em}.tab-content .playlist-item-artist{font-size:.7em}.tab-content .playlist-item-remove-btn{width:60px;font-size:.7em}}.change-password-container{padding:20px;background-color:#282828;border-radius:8px;color:#fff}.change-password-container h3{font-size:1.8em;margin-bottom:20px;color:#1db954;text-align:center}.change-password-form .form-group{margin-bottom:15px}.change-password-form label{display:block;margin-bottom:8px;font-weight:700;color:#bbb}.change-password-form input[type=password]{width:100%;padding:10px;border-radius:5px;border:1px solid #555;background-color:#333;color:#fff;font-size:1em;box-sizing:border-box}.change-password-form input[type=password]:focus{outline:none;border-color:#1db954;box-shadow:0 0 0 2px #1db95480}.change-password-form button[type=submit]{width:100%;padding:12px;background-color:#1db954;color:#fff;border:none;border-radius:5px;font-size:1.1em;font-weight:700;cursor:pointer;transition:background-color .2s ease}.change-password-form button[type=submit]:hover:not(:disabled){background-color:#1ed760}.change-password-form button[type=submit]:disabled{background-color:#555;cursor:not-allowed}.readme-content{padding:20px;color:#fff;background-color:#282828;border-radius:8px}.readme-content h3{font-size:1.5em;margin-bottom:20px;border-bottom:1px solid #555;padding-bottom:10px}.readme-content p,.readme-content li{font-size:1em;line-height:1.6;margin-bottom:10px;color:#bbb}.readme-content ul{list-style-type:decimal;padding-left:20px}.readme-content .version{margin-top:20px;font-style:italic;color:#888}.clear-data-btn{background-color:#f44336;color:#fff;border:none;padding:10px 20px;text-align:center;text-decoration:none;display:inline-block;font-size:16px;margin:10px 0;cursor:pointer;border-radius:5px;transition:background-color .3s ease}.clear-data-btn:hover{background-color:#d32f2f}.clear-data-btn:disabled{background-color:#555;cursor:not-allowed}.settings-page{position:fixed;inset:0;padding:20px;color:#fff;background-color:#1a1a1a;overflow-y:auto;z-index:1000}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;position:relative}.back-button{position:static;background:none;border:none;color:#fff;font-size:1.2em;cursor:pointer;padding:5px 10px;border-radius:5px;transition:background-color .2s ease;z-index:10}.back-button:hover{background-color:#ffffff1a}.settings-page h2{font-size:2em;color:#fff;padding-top:0;position:absolute;left:50%;transform:translate(-50%);margin:0}.settings-tabs{margin-top:20px}.tab-headers{display:flex;flex-wrap:nowrap;gap:2px;margin-bottom:20px;border-bottom:1px solid #555;padding-bottom:10px;overflow-x:auto;scrollbar-width:none}.tab-headers::-webkit-scrollbar{display:none}.tab-header{padding:10px 15px;cursor:pointer;border-radius:5px 5px 0 0;background-color:#282828;border:1px solid #555;border-bottom:none;display:flex;align-items:center;gap:10px;transition:background-color .2s ease,border-color .2s ease}.tab-header.active{background-color:#1db954;color:#fff;border-color:#1db954}.tab-header:hover:not(.active){background-color:#ffffff1a}.tab-header span{font-weight:700}.tab-content{background-color:#282828;border:1px solid #555;border-radius:0 8px 8px;padding:20px}.devices-placeholder{text-align:center;padding:50px;border:1px dashed #555;border-radius:8px;background-color:#282828;margin-top:30px}.devices-placeholder h3{font-size:1.5em;margin-bottom:10px;color:#fff}.devices-placeholder p{font-size:1.1em;margin-bottom:10px;color:#bbb}
