body{margin:0;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:#121212;color:#fff}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--spotify-green: #1DB954;--spotify-black: #191414;--spotify-white: #FFFFFF;--spotify-grey: #535353}.app{min-height:100vh;display:flex;flex-direction:column}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.5rem;color:var(--spotify-white)}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{display:inline-block;border:none;padding:.75rem 1.5rem;border-radius:2rem;font-weight:700;cursor:pointer;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:var(--spotify-green);color:var(--spotify-white)}.btn-primary:hover{background-color:#1ed760;transform:scale(1.05)}.card{background-color:#282828;border-radius:8px;padding:1.5rem;margin:1rem 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .5s ease-in}.login-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(to bottom,#191414,#121212)}.login-content{text-align:center;max-width:500px;padding:2rem;border-radius:10px;background-color:#282828cc;box-shadow:0 8px 24px #00000080;animation:fadeIn .8s ease-in}.login-title{font-size:3rem;color:var(--spotify-green);margin-bottom:.5rem}.login-subtitle{font-size:1.25rem;color:var(--spotify-white);margin-bottom:2rem}.login-button{padding:.75rem 2rem;font-size:1.1rem;margin-bottom:2rem}.login-info{color:var(--spotify-grey);font-size:.9rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard{padding:2rem 0}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-header h1{color:var(--spotify-green);font-size:2.5rem;margin-bottom:1.5rem}.user-profile{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}.profile-image{width:150px;height:150px;border-radius:50%;border:3px solid var(--spotify-green);object-fit:cover;margin-bottom:1rem;box-shadow:0 4px 12px #0006}.user-profile h2{margin:.5rem 0;font-size:1.8rem}.user-profile p{color:var(--spotify-grey);font-size:1rem}.dashboard-content{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:768px){.dashboard-content{grid-template-columns:1fr 1fr}}.card{background-color:#282828;border-radius:10px;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0000004d}.card h2{color:var(--spotify-white);margin-top:0;margin-bottom:1rem}.card p{color:#b3b3b3;margin-bottom:1.5rem}.card-links{display:flex;flex-direction:column;gap:1rem}@media(min-width:576px){.card-links{flex-direction:row}}.dashboard-link{display:block;background-color:var(--spotify-green);color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:2rem;text-align:center;font-weight:600;transition:all .2s ease}.dashboard-link:hover{background-color:#1ed760;transform:scale(1.05)}.stats-preview{background-color:#282828;border-radius:10px;padding:2rem}.stats-preview h2{color:var(--spotify-white);margin-top:0;margin-bottom:1rem}.stats-preview p{color:#b3b3b3;margin-bottom:1rem}.note{font-size:.9rem;color:var(--spotify-grey);font-style:italic}.loading,.error-message{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.2rem}.top-items-container{padding:2rem 0}.page-title{color:var(--spotify-white);text-align:center;font-size:2.5rem;margin-bottom:2rem}.time-range-selector{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}.time-range-selector p{margin-bottom:.5rem;color:var(--spotify-grey)}.time-range-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.time-range-button{background-color:#333;color:var(--spotify-white);border:none;padding:.5rem 1rem;border-radius:2rem;cursor:pointer;transition:all .2s ease}.time-range-button:hover{background-color:#444}.time-range-button.active{background-color:var(--spotify-green)}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem}.item-card{background-color:#282828;border-radius:8px;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease}.item-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0006}.item-rank{position:absolute;top:10px;left:10px;background-color:#000000b3;color:var(--spotify-white);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;z-index:1}.item-image{width:100%;aspect-ratio:1;object-fit:cover}.item-image-placeholder{width:100%;aspect-ratio:1;background-color:#333;display:flex;align-items:center;justify-content:center;color:var(--spotify-grey)}.item-details{padding:1rem}.item-name{margin-top:0;margin-bottom:.5rem;color:var(--spotify-white);font-size:1.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-artist,.item-followers,.item-album,.item-duration{color:var(--spotify-grey);margin:.25rem 0;font-size:.9rem}.item-genres{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.genre-tag{background-color:#333;color:#b3b3b3;font-size:.8rem;padding:.25rem .5rem;border-radius:1rem}.no-data{text-align:center;margin-top:2rem;color:var(--spotify-grey)}@media(max-width:768px){.items-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}}.top-five-genres{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:3rem}.top-genre-item{display:flex;align-items:baseline;gap:.75rem}.top-genre-rank{font-weight:700;color:var(--spotify-green)}.top-genre-name{color:var(--spotify-white);text-transform:capitalize}.top-genre-item.rank-1{font-size:2.8rem}.top-genre-item.rank-2{font-size:2.2rem}.top-genre-item.rank-3{font-size:1.8rem}.top-genre-item.rank-4{font-size:1.4rem}.top-genre-item.rank-5{font-size:1.2rem}.genre-chart{max-width:800px;margin:0 auto}.chart-title{color:var(--spotify-white);text-align:center;margin-bottom:1.5rem;font-size:1.5rem}.chart-bars{display:flex;flex-direction:column;gap:.6rem}.chart-row{display:flex;align-items:center;gap:.75rem}.chart-label{flex:0 0 140px;text-align:right;color:var(--spotify-white);font-size:.85rem;text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-bar-container{flex:1;height:24px;background-color:#282828;border-radius:4px;overflow:hidden}.chart-bar{height:100%;background:linear-gradient(90deg,var(--spotify-green),#1ed760);border-radius:4px;min-width:4px;animation:growBar .6s ease-out forwards;transform-origin:left}@keyframes growBar{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.chart-value{flex:0 0 36px;color:var(--spotify-grey);font-size:.8rem;text-align:left}@media(max-width:768px){.top-genre-item.rank-1{font-size:2rem}.top-genre-item.rank-2{font-size:1.6rem}.top-genre-item.rank-3{font-size:1.3rem}.top-genre-item.rank-4{font-size:1.1rem}.top-genre-item.rank-5{font-size:1rem}.chart-label{flex:0 0 100px;font-size:.75rem}}.navbar{background-color:#121212e6;padding:1rem 0;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000004d}.navbar-container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 1rem}.navbar-logo a{color:var(--spotify-green);font-size:1.5rem;font-weight:700;text-decoration:none;letter-spacing:1px}.navbar-menu{display:flex;list-style:none;margin:0;padding:0}.navbar-item{margin-left:1.5rem}.navbar-link{color:var(--spotify-white);text-decoration:none;font-weight:600;transition:color .2s ease;padding:.5rem;border-radius:4px;background-color:transparent;border:none;cursor:pointer;font-size:1rem}.navbar-link:hover{color:var(--spotify-green)}.logout-btn{color:var(--spotify-white);background-color:transparent;border:1px solid var(--spotify-grey);padding:.5rem 1rem}.logout-btn:hover{border-color:var(--spotify-green)}@media(max-width:768px){.navbar-container{flex-direction:column;align-items:flex-start}.navbar-menu{flex-direction:column;width:100%;margin-top:1rem}.navbar-item{margin-left:0;margin-bottom:.5rem}}
