body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-container{margin-top:100px;text-align:center}.auth-btn{background-color:#1db954;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:18px;margin:10px;padding:10px 20px}.auth-btn:disabled{background-color:grey;cursor:not-allowed}.logout-btn{background-color:#ff4b4b}.auth-btn:hover:not(:disabled){opacity:.8}.spinner-container{align-items:center;display:flex;justify-content:center;min-height:200px}.spinner{animation:rotate 1s linear infinite;border-radius:50%;height:50px;position:relative;width:50px}.spinner:before{animation:prixClipFix 2s linear infinite;border:5px solid #1db954;border-radius:50%;box-sizing:border-box;content:"";inset:0;position:absolute}@keyframes rotate{to{transform:rotate(1turn)}}@keyframes prixClipFix{0%{clip-path:polygon(50% 50%,0 0,0 0,0 0,0 0,0 0)}25%{clip-path:polygon(50% 50%,0 0,100% 0,100% 0,100% 0,100% 0)}50%{clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,100% 100%,100% 100%)}75%{clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 100%)}to{clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 0)}}.playlist-container{color:#fff;height:auto;margin:0 auto;max-width:1200px;padding:20px}.playlist-title{color:#fff;font-size:2rem;font-weight:700;margin-bottom:30px}.playlist-list{height:auto;list-style:none;padding:0}.playlist-list,.playlists-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.playlists-grid{padding:20px}.playlist-card,.playlist-item{background:#282828;border-radius:8px;cursor:pointer;padding:16px;transition:all .3s ease}.playlist-item:hover{background:#383838;transform:translateY(-4px)}.playlist-card:hover{background:#333;transform:translateY(-5px)}.playlist-image{aspect-ratio:1;border-radius:4px;height:100%;left:0;margin-bottom:12px;object-fit:cover;position:absolute;top:0;width:100%}.playlist-image-container{margin-bottom:16px;padding-bottom:100%;position:relative;width:100%}.playlist-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.playlist-card:hover .playlist-overlay{opacity:1}.play-icon{color:#1db954;font-size:3rem}.playlist-info{margin-top:8px;text-align:left}.playlist-name{color:#fff;font-size:1rem;font-weight:700;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-tracks{color:#b3b3b3;font-size:.9rem;margin:4px 0 0}.loading-container{padding:40px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#1db954;height:40px;margin:0 auto 20px;width:40px}.error-container{color:#f55;padding:40px;text-align:center}.error-container button{background:#1db954;border:none;border-radius:20px;color:#fff;cursor:pointer;margin-top:20px;padding:10px 20px}.no-playlists{color:#b3b3b3;padding:40px;text-align:center}@media only screen and (max-width:768px){.playlist-container{padding:10px 10px 90px}.playlist-title{font-size:1.5rem;margin-bottom:15px;text-align:center}.playlists-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}.playlist-card{cursor:pointer;margin:0 auto;max-width:400px;padding:10px}.playlist-image-container{position:relative;width:100%}.playlist-image{border-radius:8px;height:auto;width:100%}.playlist-overlay{align-items:center;background-color:#0000004d;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.playlist-card:hover .playlist-overlay{opacity:1}.playlist-info{margin-top:10px;text-align:center}.playlist-name{font-size:1.2rem;margin-bottom:5px}.playlist-tracks{color:#666;font-size:.9rem}}@media only screen and (max-width:480px){.playlist-title{font-size:1.3rem}.playlist-card{padding:8px}.playlist-name{font-size:1.1rem}.playlist-tracks{font-size:.8rem}}.tracks-container{color:#fff;margin-bottom:20px;padding:20px;text-align:center}.tracks-header{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:40px;text-align:center;text-shadow:0 2px 4px #0003}.playlist-header{align-items:flex-end;background:linear-gradient(#0000,#00000080);display:flex;margin-bottom:30px;padding:20px;position:relative}.back-button{align-items:center;background:#00000080;border:none;border-radius:50%;bottom:20px;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:20px;transition:all .2s ease;width:36px}.back-button:hover{background:#000000b3;transform:scale(1.1)}.back-button svg{height:16px;width:16px}.playlist-cover{border-radius:4px;box-shadow:0 4px 60px #00000080;height:180px;margin-right:20px;object-fit:cover;width:180px}.playlist-info{padding-bottom:10px}.playlist-info h1{font-size:2.5rem;font-weight:700;margin:0 0 8px}.playlist-info p{color:#b3b3b3;font-size:.9rem;margin:0}.tracks-list{display:flex;flex-direction:column;gap:12px;margin:30px auto 20px;max-width:800px;padding:0 20px}.track-item{align-items:center;background:#ffffff1a;border-radius:4px;cursor:pointer;display:grid;grid-template-columns:50px 60px minmax(0,1fr) 80px 50px;height:60px;padding:12px 20px;transition:background-color .2s ease}.track-item:hover{background-color:#ffffff1a;transform:translateX(5px)}.track-number{color:#b3b3b3}.track-image{border-radius:4px;height:40px;margin-right:16px;width:40px}.track-info{display:flex;flex:1 1;flex-direction:column;justify-content:center;margin-left:16px;min-width:0;overflow:visible;width:100%}.track-details{flex-grow:1;text-align:left}.track-name{color:#fff;display:block;font-size:1.1rem;font-weight:500;margin:0;position:relative;width:100%;z-index:2}.track-artist,.track-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-artist{color:#b3b3b3;font-size:.9rem;margin:4px 0 0}.track-duration{color:#b3b3b3;font-size:.9rem;margin-left:auto;text-align:right;width:45px}.tracks-list .track-item .track-play-button{align-items:center;background:#0000;border:none;color:#1db954;cursor:pointer;display:flex;flex-shrink:0;height:45px;justify-content:center;margin-left:24px;opacity:.8;transition:opacity .2s ease;width:45px}.tracks-list .track-item .track-play-button svg{height:20px;width:20px}.tracks-list .track-item .track-play-button:has(svg[data-testid=play-icon]){height:45px!important;width:45px!important}.tracks-list .track-item .track-play-button:has(svg[data-testid=play-icon]) svg{height:32px!important;width:32px!important}.tracks-list .track-item .track-play-button .download-icon,.tracks-list .track-item .track-play-button .spin{height:20px;width:20px}.tracks-list .track-item .track-play-button:hover{opacity:1}.download-btn{color:#ffffffb3}.download-btn.loading{color:#1db954;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.action-btn{align-items:center;background:none;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;justify-content:center;margin-left:0;padding:8px;transition:all .3s ease}.action-btn:hover{color:#0cc;transform:scale(1.1)}.action-btn.loading{color:#0ccc;cursor:not-allowed}.download-icon,.play-icon-card{font-size:1em}.play-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;color:#00ccccd9}.download-btn:hover,.play-btn:hover{color:#0cc}.play-icon-card{font-size:.9em}.action-button{align-items:center;background:none;border:none;color:#ffffffb3;cursor:pointer;display:flex;height:32px;justify-content:center;margin-left:auto;padding:6px;transition:all .2s ease;width:32px}.action-button svg{height:18px;width:18px}.play-icon{color:#00ccccd9;font-size:1.8em}.action-button.loading svg{height:18px;width:18px}.action-button:hover{color:#0cc;transform:scale(1.1)}.action-button.loading{color:#0ccc;cursor:not-allowed}.tracks-footer{align-items:center;border-top:1px solid #ffffff1a;color:#b3b3b3;display:flex;font-size:.9rem;justify-content:center;margin-top:10px;min-height:50px;padding:15px 0;text-align:center}@media only screen and (max-width:768px){.tracks-list .track-item .track-info{display:flex!important;flex:1 1!important;flex-direction:column!important;justify-content:center!important;margin-left:8px!important;min-width:0!important;overflow:visible!important;z-index:1000!important}.tracks-list .track-item .track-info,.tracks-list .track-item .track-info .track-name{background:#0000!important;border:none!important;outline:none!important;width:100%!important}.tracks-list .track-item .track-info .track-name{color:#fff!important;display:block!important;font-size:1.1rem!important;font-weight:500!important;margin:0!important;overflow:hidden!important;position:relative!important;text-overflow:ellipsis!important;white-space:nowrap!important;z-index:2000!important}}@media only screen and (max-width:500px){.tracks-list .track-item{grid-template-columns:40px 40px minmax(0,1fr) 50px 35px;padding:8px 12px}.tracks-list .track-item .track-number{margin:0;padding-left:0;text-align:left;width:30px!important}.tracks-list .track-item .track-image{margin-left:0!important;margin-right:0!important}.tracks-list .track-info{margin-left:0!important}.track-info,.tracks-list .track-info{background:#0000!important;border:none!important;flex:1 1!important;min-width:0!important;outline:none!important;overflow:visible!important;padding:0 4px;width:100%!important;z-index:1000!important}.track-info{margin-left:4px!important}.tracks-list .track-item .track-info .track-name{background:#0000!important;border:none!important;color:#fff!important;display:block!important;font-size:1.1rem!important;font-weight:500!important;margin:0!important;outline:none!important;overflow:hidden!important;position:relative!important;text-overflow:ellipsis!important;white-space:nowrap!important;width:100%!important;z-index:2000!important}}.cover-art{align-items:center;background-color:#282828;border-radius:8px;display:flex;height:204px;justify-content:center;margin-bottom:20px;margin-top:60px;overflow:hidden;width:204px}.cover-art img{border-radius:8px;height:100%;height:auto;max-width:100%;object-fit:contain;width:100%}.track-info{color:#fff;margin-bottom:20px;margin-top:10px;text-align:center}.track-title{font-size:1.1rem;font-size:1.2rem;font-weight:600;margin:0}.artist-name{color:#b3b3b3;color:#777;font-size:.9rem;font-size:1rem;margin:5px 0 0;margin:0}.controls{gap:20px;margin-top:15px;width:100%}.control-btn,.controls{align-items:center;display:flex;justify-content:center}.control-btn{background:none;border:none;border-radius:50%;color:#b3b3b3;cursor:pointer;font-size:1.5rem;margin:0 10px;padding:8px;transition:all .2s ease}.control-btn:hover{color:#fff;transform:scale(1.1)}.play-btn{background:#1db954;color:#fff;height:40px;width:40px}.play-btn:hover{background:#1ed760;transform:scale(1.1)}.progress-container{align-items:center;display:flex;margin-top:15px;width:100%}.progress-container .time{font-size:.9rem}.progress-bar{background:#ffffff1a;background-color:#ccc;border-radius:2px;border-radius:4px;cursor:pointer;flex-grow:1;height:4px;height:8px;margin:0 10px;position:relative;transition:height .2s ease}.progress-bar:hover{height:6px}.progress-bar:hover .progress-fill{background:#0cc}.progress-fill{background:#0ccc;background-color:#1db954;border-radius:2px;border-radius:4px;height:100%;left:0;position:absolute;top:0;transition:width .1s linear,background-color .2s ease}.time{color:#ffffffb3;font-size:.8rem;min-width:40px;text-align:center}.music-player{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(160deg,#4b0082f2,#00cccce3);box-shadow:2px 0 15px #0003;display:flex;flex-direction:column;height:calc(100vh - 40px);padding:20px;z-index:1000}@media only screen and (max-width:768px){.music-player{padding:15px}.track-title{font-size:1rem}.artist-name{font-size:.9rem}.progress-container .time{font-size:.8rem}.progress-bar{height:6px;margin:0 8px}.control-btn{font-size:1.3rem;margin:0 8px}.music-player{background:#181818;border-top:1px solid #282828;bottom:0;flex-direction:row;height:80px;left:0;padding:0 16px;position:fixed;top:auto;width:100%;z-index:1000}.cover-art{flex-shrink:0;height:60px;margin:0 12px 0 0;width:60px}.cover-art img{border-radius:4px;height:100%;object-fit:cover;width:100%}.player-right{display:flex;flex:1 1;flex-direction:column;gap:8px;justify-content:center}.progress-container{gap:8px;margin:0;padding:0;width:100%}.progress-bar{height:3px;margin:0}.time{font-size:10px;min-width:35px}.controls{gap:16px;justify-content:center;margin:0}.control-btn{font-size:16px;padding:4px}.play-btn{height:32px;width:32px}.track-info{display:none}}@media only screen and (max-width:480px){.music-player{height:70px;padding:0 12px}.cover-art{height:50px;margin-right:8px;width:50px}.control-btn{font-size:14px}}@media only screen and (max-width:768px){.music-player{background:#181818!important;border-top:1px solid #282828!important;bottom:0!important;flex-direction:row!important;height:120px!important;left:0!important;padding:0 16px!important;position:fixed!important;top:auto!important;width:100%!important;z-index:1000!important}.cover-art{flex-shrink:0;height:64px!important;margin:0 12px 0 0;width:64px!important}}.navbar{background:linear-gradient(90deg,#4b0082f2,#00ccccd9);border-bottom:1px solid #ffffff1a;box-shadow:0 2px 8px #0003;height:80px;padding:0 40px}.navbar,.navbar-container{justify-content:space-between}.navbar-container{align-items:center;display:flex;margin:0 auto;max-width:1400px}.navbar-left h1{color:#fff;font-size:2.2rem;font-weight:700;letter-spacing:1px;margin:0 0 0 20px}.navbar-right{gap:1rem}.navbar-right,.user-profile{align-items:center;display:flex}.user-profile{gap:20px;margin-left:auto}.profile-picture{border:1px solid #ffffff1a;border-radius:50%;object-fit:cover}.profile-picture,.profile-picture-placeholder{background-color:#282828;height:32px;width:32px}.profile-picture-placeholder{align-items:center;border-radius:50%;display:flex;justify-content:center}.profile-picture-placeholder,.username{color:#fff;font-size:14px;font-weight:500}.username{margin:0 12px}.welcome-text{font-size:1.1rem}.logout-btn,.welcome-text{color:#fff;font-weight:500}.logout-btn{background-color:initial;border:1px solid #4f8fa4;border-radius:20px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.logout-btn:hover{background-color:#fff;color:#000}@media only screen and (max-width:768px){.navbar{height:60px;padding:0 20px}.navbar-container{align-items:center;flex-direction:column;justify-content:center}.navbar-left h1{font-size:1.8rem;margin-left:0;text-align:center}.navbar-right{gap:.5rem;margin-top:8px}.user-profile{flex-direction:row;gap:10px}.profile-picture,.profile-picture-placeholder{font-size:12px;height:28px;width:28px}.username{font-size:12px;margin:0 8px}.welcome-text{font-size:1rem;margin-left:15px}.logout-btn{font-size:12px;padding:4px 10px}}.home-container{background:linear-gradient(135deg,indigo,#0ccc);display:flex;min-height:100vh}.content-container{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000001a;height:calc(100vh - 50px);margin-left:300px;overflow-y:auto;padding:20px;position:relative;transition:all .3s ease;width:calc(100% - 300px)}.content-container::-webkit-scrollbar{width:8px}.content-container::-webkit-scrollbar-track{background:#0000001a}.content-container::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.content-container::-webkit-scrollbar-thumb:hover{background:#fff6}.content-container h2{color:#fff;font-size:2rem;font-weight:700;margin-bottom:24px;text-shadow:0 2px 4px #0003}.home{background-color:#121212;display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{display:flex;flex-direction:row;height:calc(100vh - 50px);margin-top:50px;position:relative}.music-player{border-right:1px solid #282828;box-sizing:border-box;height:calc(100vh - 50px);top:50px;width:300px;z-index:900}.music-player,.navbar{background-color:#181818;left:0;position:fixed}.navbar{align-items:center;display:flex;height:50px;padding:0 20px;right:0;top:0;z-index:1000}.navbar .app-name{color:#1db954;font-size:1.2rem;font-weight:700;margin-right:auto}.navbar .user-profile{align-items:center;display:flex;gap:8px}.navbar .profile-picture{border-radius:50%;height:24px;object-fit:cover;width:24px}.navbar .profile-picture-placeholder{align-items:center;background-color:#282828;border-radius:50%;color:#fff;display:flex;font-size:1rem;height:24px;justify-content:center;width:24px}.navbar .username{color:#fff;font-size:.9rem}.navbar .logout-button{background-color:initial;border:1px solid #1db954;border-radius:12px;color:#1db954;cursor:pointer;font-size:.8rem;margin-left:16px;padding:4px 8px;transition:background-color .2s ease}.navbar .logout-button:hover{background-color:#1db954;color:#fff}@media only screen and (max-width:768px){.main-content{flex-direction:column}.content-container{margin-bottom:120px;margin-left:0;order:1;padding-bottom:100px;width:100%}.music-player{background-color:#181818;border-top:1px solid #282828;bottom:0;height:100px;left:0;order:2;position:fixed;width:100%;z-index:10}.playlist-header{align-items:center;flex-direction:column;padding:10px}.playlist-cover{height:140px;margin-bottom:10px;margin-right:0;width:140px}.playlist-info{text-align:center;width:100%}.playlist-info h1{font-size:2rem;margin:10px 0 8px}.music-player{background-color:#181818;border-top:1px solid #282828;bottom:0;height:100px;left:0;position:fixed;width:100%;z-index:10}}body,html{height:100%;margin:0;overflow:hidden;padding:0;width:100%}body{font-family:Arial,sans-serif}.login-container{align-items:center;background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;flex-direction:column;justify-content:center;margin:0;min-height:100vh;padding:0;position:relative;width:100vw}.login-container:before{background:#0009;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.login-content{align-items:center;color:#fff;display:flex;flex-direction:column;padding:20px;position:relative;text-align:center;z-index:2}.login-content h1{color:#fff;font-size:3.5rem;font-weight:800;margin-bottom:20px;text-shadow:2px 2px 8px #000000b3}.tagline{-webkit-text-fill-color:#0000;background:linear-gradient(70deg,#7af2ff,#b050ff);-webkit-background-clip:text;font-size:2rem;font-weight:600;letter-spacing:1px;margin:1rem 0;text-shadow:2px 2px 4px #00000080}.subtitle{color:#e0e0e0;font-size:1.4rem;letter-spacing:.5px;line-height:1.8;margin:1.5rem auto 2.5rem;max-width:600px;text-shadow:2px 2px 4px #0009}.login-button{align-items:center;background:linear-gradient(45deg,#1db954,#4caf50);border:none;border-radius:30px;box-shadow:0 4px 15px #1db9544d;color:#fff;cursor:pointer;display:inline-flex;font-size:18px;font-weight:700;gap:10px;justify-content:center;letter-spacing:1.5px;margin-top:30px;padding:16px 40px;text-transform:uppercase;transition:all .3s ease}.login-button:hover{background:linear-gradient(45deg,#4caf50,#1db954);box-shadow:0 6px 20px #1db95480;transform:scale(1.05)}.spotify-icon{fill:currentColor;flex-shrink:0;height:24px;width:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInTop{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-100px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}.fade-in{animation:fadeIn 1s ease-out}.slide-in-top{animation:slideInTop 1s ease-out}.slide-in-left{animation:slideInLeft 1s ease-out .3s;animation-fill-mode:both}.slide-in-right{animation:slideInRight 1s ease-out .6s;animation-fill-mode:both}.bounce{animation:bounce 2s ease infinite;animation-delay:1s}
/*# sourceMappingURL=main.5ed5f74b.css.map*/