body{background-color:#000;color:#fff;overflow:hidden;font-family:Inter,sans-serif}.spotify-layout{display:grid;grid-template-rows:minmax(0,1fr) 0px;grid-template-columns:320px 1fr;height:100vh;padding:8px;gap:8px;box-sizing:border-box;transition:grid-template-rows .3s ease}.spotify-layout.has-player{grid-template-rows:minmax(0,1fr) 90px}.spotify-sidebar{display:flex;flex-direction:column;gap:8px}.sidebar-nav,.sidebar-library{background-color:#121212;border-radius:8px;padding:20px}.sidebar-brand{font-size:1.5rem;font-weight:800;margin-bottom:20px;color:#fff;text-decoration:none;display:flex;align-items:center}.sidebar-nav{display:flex;flex-direction:column;gap:20px}.sidebar-nav a{color:var(--text-muted);text-decoration:none;font-weight:700;font-size:1rem;display:flex;align-items:center;gap:15px;transition:color .2s}.sidebar-nav a:hover,.sidebar-nav a.active{color:#fff}.sidebar-nav i{font-size:1.25rem;width:24px;text-align:center}.sidebar-library{flex:1;overflow-y:hidden;display:flex;flex-direction:column}.library-header{display:flex;justify-content:space-between;align-items:center;color:var(--text-muted);font-weight:700;margin-bottom:20px;cursor:pointer}.library-header:hover{color:#fff}.library-filters{display:flex;gap:10px;margin-bottom:20px}.lib-chip{background:#ffffff1a;padding:5px 12px;border-radius:16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.lib-chip:hover{background:#fff3}.library-list{display:flex;flex-direction:column;gap:15px;overflow-y:auto;flex:1}.library-list::-webkit-scrollbar{display:none}.lib-item{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}.lib-item:hover{background:#ffffff0d}.lib-item img,.liked-icon{width:48px;height:48px;border-radius:4px;object-fit:cover}.liked-icon{background:linear-gradient(135deg,#450af5,#c4efd9);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.lib-item-info h4{font-size:.95rem;margin-bottom:4px;color:#fff;font-weight:600}.lib-item-info p{font-size:.8rem;color:var(--text-muted);font-weight:500}.spotify-main{background-color:#121212;border-radius:8px;position:relative;overflow:hidden;display:flex;flex-direction:column}.view-section{display:none;flex:1;min-height:0;flex-direction:column}.view-section.active{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-header{position:sticky;top:0;z-index:100;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.main-header.solid-bg{background-color:#121212e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.main-header.transparent{background:linear-gradient(to bottom,rgba(0,0,0,.4) 0%,transparent 100%)}.header-left{display:flex;align-items:center;gap:10px}.nav-btn{border:none;border-radius:50%;width:32px;height:32px;background:#00000080;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.search-bar{background:#242424;border-radius:20px;padding:10px 15px;display:flex;align-items:center;gap:10px;width:300px;margin-left:10px}.search-bar input{background:transparent;border:none;color:#fff;outline:none;width:100%;font-size:.9rem}.header-right{display:flex;align-items:center;gap:15px}.install-app-btn{background:#fff;color:#000;border:none;border-radius:20px;padding:8px 16px;font-weight:700;font-size:.85rem;cursor:pointer}.profile-icon{width:32px;height:32px;border-radius:50%;background:#242424;display:flex;align-items:center;justify-content:center;cursor:pointer}.mobile-header,.mobile-bottom-nav{display:none}.home-content{flex:1;overflow-y:auto;padding:0 24px 40px}.home-content::-webkit-scrollbar{display:none}.top-chips{display:flex;gap:10px;margin-top:10px;margin-bottom:24px;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.top-chips::-webkit-scrollbar{display:none}.top-chips .chip{background:#ffffff1a;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}.top-chips .chip.active{background:#fff;color:#000}.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-bottom:40px}.recent-card{display:flex;align-items:center;background:#ffffff0d;border-radius:4px;overflow:hidden;cursor:pointer;transition:background .3s}.recent-card:hover{background:#fff3}.recent-card img,.recent-card .liked-gradient{width:64px;height:64px;object-fit:cover}.recent-card .liked-gradient{background:linear-gradient(135deg,#450af5,#c4efd9);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.recent-card span{padding:0 16px;font-weight:700;font-size:1rem}.shelf{margin-bottom:40px}.shelf-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:20px}.shelf-header h2{font-size:1.5rem;font-weight:800;margin:0}.shelf-header a{color:var(--text-muted);font-size:.85rem;font-weight:700;text-decoration:none}.shelf-header a:hover{text-decoration:underline}.cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px}.song-card{background:#181818;padding:16px;border-radius:8px;cursor:pointer;transition:background .3s;position:relative}.song-card:hover{background:#282828}.song-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;margin-bottom:16px;box-shadow:0 8px 24px #00000080}.song-card.artist-card img{border-radius:50%}.song-card h4{font-size:1rem;font-weight:700;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-card p{font-size:.85rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.play-overlay{position:absolute;bottom:90px;right:24px;width:48px;height:48px;background:#1ed760;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#000;font-size:1.2rem;opacity:0;transform:translateY(10px);transition:all .3s ease;box-shadow:0 8px 8px #0000004d}.song-card:hover .play-overlay{opacity:1;transform:translateY(0)}.background-blur{position:absolute;top:0;left:0;right:0;bottom:0;background-image:url(https://images.unsplash.com/photo-1614613535308-eb5fbd3d2c17?q=80&w=600&auto=format&fit=crop);background-size:cover;background-position:center;filter:blur(80px) brightness(.4);z-index:0;transform:scale(1.2)}.lyrics-container{position:relative;z-index:10;flex:1;overflow-y:auto;padding:0 40px;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.lyrics-container::-webkit-scrollbar{display:none}.lyrics-padding-top{height:40vh}.lyrics-padding-bottom{height:60vh}.lyric-line{font-size:clamp(2rem,3.5vw,3rem);font-weight:800;line-height:1.3;margin-bottom:24px;color:#ffffff80;transition:all .4s cubic-bezier(.25,.46,.45,.94);transform-origin:left center;cursor:pointer;letter-spacing:-1px}.lyric-line:hover{color:#fffc}.lyric-line.active{color:#fff;transform:scale(1.05);text-shadow:0 0 20px rgba(255,255,255,.2)}.lyric-line.passed{color:#ffffff4d}.spotify-player{grid-column:1 / -1;background-color:#000;display:none;align-items:center;justify-content:space-between;padding:0 16px;border-top:1px solid rgba(255,255,255,.1)}.spotify-layout.has-player .spotify-player{display:flex}.player-left{display:flex;align-items:center;gap:15px;width:30%}.player-left img{width:56px;height:56px;border-radius:4px}.player-song-info h4{margin:0;font-size:.9rem;font-weight:600}.player-song-info p{margin:0;font-size:.75rem;color:var(--text-muted)}.player-center{width:40%;display:flex;flex-direction:column;align-items:center;gap:8px}.player-controls{display:flex;align-items:center;gap:20px}.player-controls i{color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:color .2s}.player-controls i:hover{color:#fff}.play-pause-btn{background:#fff;color:#000!important;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.player-progress{display:flex;align-items:center;gap:10px;width:100%}.progress-time{font-size:.75rem;color:var(--text-muted);min-width:40px}.progress-bar{flex:1;height:4px;background:#ffffff4d;border-radius:2px;cursor:pointer;position:relative}.progress-fill{height:100%;background:#fff;border-radius:2px;width:0%}.player-right{width:30%;display:flex;justify-content:flex-end}.player-right .active-icon{color:#1ed760!important}@media(max-width:768px){.spotify-layout{display:flex;flex-direction:column;padding:0;gap:0}.spotify-sidebar,.desktop-header,.desktop-chips,.desktop-only{display:none!important}.spotify-main{border-radius:0;flex:1}.mobile-header{display:flex;align-items:center;gap:15px;padding:20px 16px 10px;background-color:#121212;position:sticky;top:0;z-index:100}.top-chips{margin-bottom:0;margin-top:0}.mobile-chip-active{background:#1ed760!important;color:#000!important}.home-content{padding:10px 16px 160px}.recent-grid{grid-template-columns:1fr 1fr;gap:8px}.recent-card img,.recent-card .liked-gradient{width:56px;height:56px}.recent-card span{font-size:.8rem;padding:0 8px}.shelf-header h2{font-size:1.2rem}.cards-container{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.song-card h4{font-size:.9rem}.song-card p{font-size:.8rem}.play-overlay{display:none}.spotify-player{position:fixed;bottom:66px;left:8px;right:8px;border-radius:8px;background:#3c3427;padding:8px 12px;border:none;z-index:200;display:none!important;justify-content:flex-start;align-items:center;box-shadow:0 4px 12px #00000080}.spotify-layout.has-player .spotify-player{display:flex!important}.player-left{flex:1;min-width:0;display:flex;align-items:center;gap:10px}.player-left img{width:40px;height:40px;border-radius:4px;flex-shrink:0}.player-song-info{flex:1;min-width:0;display:flex;flex-direction:column}.player-song-info h4{font-size:.85rem;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-song-info p{font-size:.75rem;color:#ffffffb3;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-left .fa-heart{display:none}.player-center{width:auto;order:3}.player-right{width:auto;display:flex;align-items:center;order:2}.player-right i{margin-right:0!important;margin-left:15px}.play-pause-btn{background:transparent;color:#fff!important;width:auto;height:auto;font-size:1.4rem;margin-left:15px}.mobile-bottom-nav{display:flex;justify-content:space-around;align-items:center;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:fixed;bottom:0;left:0;right:0;height:60px;z-index:200;border-top:1px solid rgba(255,255,255,.05)}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-muted);text-decoration:none;font-size:.65rem;font-weight:600}.mobile-bottom-nav a.active{color:#fff}.mobile-bottom-nav i{font-size:1.3rem}#lyrics-view .main-header{padding-top:20px}.lyrics-container{padding:0 20px}.lyric-line{font-size:clamp(1.5rem,6vw,2.5rem)}body{overscroll-behavior-y:none}.pull-to-refresh{position:fixed;top:-50px;left:0;width:100%;height:50px;display:flex;justify-content:center;align-items:center;z-index:1000;pointer-events:none;transition:transform .2s ease}.ptr-spinner{width:30px;height:30px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#1ed760;opacity:0;transition:opacity .2s ease,transform .2s ease}.ptr-spinner.spinning{animation:ptr-spin 1s linear infinite}@keyframes ptr-spin{to{transform:rotate(360deg)}}.bottom-sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.bottom-sheet-overlay.active{opacity:1;pointer-events:all}.bottom-sheet{position:absolute;bottom:0;left:0;right:0;background:#242424;border-radius:16px 16px 0 0;padding:12px 16px 24px;transform:translateY(100%);transition:transform .3s cubic-bezier(.2,.8,.2,1)}.bottom-sheet-overlay.active .bottom-sheet{transform:translateY(0)}.sheet-handle{width:40px;height:4px;background:#ffffff4d;border-radius:2px;margin:0 auto 20px}.sheet-item{display:flex;align-items:center;gap:16px;padding:12px 0;color:#fff;cursor:pointer}.sheet-item i{font-size:1.5rem;color:var(--text-muted);width:24px;text-align:center}.sheet-item-text h4{margin:0;font-size:1rem;font-weight:600}.sheet-item-text p{margin:0;font-size:.8rem;color:var(--text-muted)}}input[type=file]::file-selector-button{background-color:#333;color:#fff;border:none;padding:10px 20px;border-radius:20px;margin-right:15px;cursor:pointer;font-weight:600;font-family:inherit;transition:background .2s,transform .1s}input[type=file]::file-selector-button:hover{background-color:#444}input[type=file]::file-selector-button:active{transform:scale(.98)}
