html,body,#root{width:100%;min-width:100%;height:100%;min-height:100%;margin:0}body{overflow:hidden}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{color:#edf2f7;background:#111827;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}button,input,select{font:inherit}button{cursor:pointer}.app{background:linear-gradient(135deg,#101722,#121c2a);grid-template-rows:1fr 98px;grid-template-columns:280px 1fr;height:100vh;display:grid}.sidebar{background:#182438;border-right:1px solid #2b3d58;flex-direction:column;gap:12px;padding:24px;display:flex}.brand{align-items:center;gap:12px;margin-bottom:28px;display:flex}.logo{color:#111827;background:#ddb15f;border-radius:13px;place-items:center;width:48px;height:48px;font-size:24px;display:grid}.brand h1{margin:0;font-size:25px}.brand p{color:#a8b8cc;margin:2px 0 0}.nav,.upload,.topbar button{color:#edf2f7;background:#223149;border:0;border-radius:12px;align-items:center;gap:11px;padding:14px 16px;display:flex}.nav.active,.nav:hover{background:#365174}.upload{color:#111827;background:#ddb15f;justify-content:center;margin-top:22px;font-weight:900}.playlistBox{background:#223149;border:1px solid #365174;border-radius:14px;margin-top:auto;padding:18px}.playlistTitle{justify-content:space-between;align-items:center;display:flex}.playlistTitle h3{margin:0}.playlistTitle button{color:#fff;background:#365174;border:0;border-radius:9px;width:34px;height:34px}.playlistBox p{color:#a8b8cc}.miniPlaylist{color:#edf2f7;text-align:left;background:0 0;border:0;width:100%;padding:9px 0}.main{padding:32px;overflow:auto}.topbar{gap:14px;margin-bottom:32px;display:flex}.search{background:#182438;border:1px solid #2b3d58;border-radius:12px;align-items:center;gap:10px;width:520px;padding:0 16px;display:flex}.search input{color:#fff;background:0 0;border:0;outline:0;width:100%;padding:16px 0}.topbar button{width:auto}.empty{text-align:center;place-content:center;justify-items:center;height:calc(100vh - 230px);display:grid}.emptyIcon{color:#ddb15f;background:#263b59;border-radius:22px;place-items:center;width:96px;height:96px;margin-bottom:18px;font-size:46px;display:grid}.empty h2{margin:0 0 8px;font-size:38px}.empty p{color:#a8b8cc;margin:0 0 24px}.empty button{color:#111827;background:#ddb15f;border:0;border-radius:12px;align-items:center;gap:10px;padding:14px 20px;font-weight:900;display:flex}.library h2{margin:0;font-size:40px}.library>p{color:#a8b8cc;margin:8px 0 22px}.songList{flex-direction:column;gap:10px;display:flex}.songRow{background:#182438;border:1px solid #2b3d58;border-radius:14px;grid-template-columns:34px 56px 1fr auto 44px;align-items:center;gap:14px;min-height:76px;padding:10px 16px;display:grid}.songRow:hover,.activeSong{background:#223149}.cover,.miniCover{color:#ddb15f;background:#263b59;place-items:center;display:grid;overflow:hidden}.cover{border-radius:12px;width:56px;height:56px}.cover img,.miniCover img{object-fit:cover;width:100%;height:100%}.songInfo h3{margin:0 0 4px;font-size:17px}.songInfo p{color:#a8b8cc;margin:0}.songRow select{color:#edf2f7;background:#223149;border:1px solid #365174;border-radius:9px;padding:9px}.round{color:#111827;background:#ddb15f;border:0;border-radius:50%;place-items:center;width:40px;height:40px;display:grid}.player{background:#182438;border-top:1px solid #2b3d58;grid-column:1/-1;grid-template-columns:360px 1fr 260px;align-items:center;padding:16px 28px;display:grid}.track{align-items:center;gap:14px;display:flex}.miniCover{border-radius:13px;width:60px;height:60px}.track h4{margin:0 0 4px}.track p{color:#a8b8cc;margin:0}.controls button{color:#fff;background:#223149;border:0;border-radius:12px;place-items:center;width:42px;height:42px;display:grid}.controls .play{color:#111827;background:#ddb15f;border-radius:50%;width:54px;height:54px}.volume{color:#a8b8cc;align-items:center;gap:12px;display:flex}.volume div{background:#365174;border-radius:999px;flex:1;height:8px}@media (width<=850px){.app{grid-template-columns:1fr}.sidebar{display:none}.player{grid-template-columns:1fr}.track,.volume{display:none}}.visualizer{background:#182438;border:1px solid #2b3d58;border-radius:14px;width:100%;height:110px;margin:18px 0}.miniVisualizer{opacity:.95;background:#101722;border:1px solid #2b3d58;border-radius:10px;width:90px;height:38px;margin-left:28px;transition:opacity .2s}.controls{justify-content:center;align-items:center;gap:12px;display:flex}.miniVisualizer{background:#101722;border:1px solid #2b3d58;border-radius:12px;width:120px;height:42px;margin-left:24px}.controlActive{color:#111827!important;background:#ddb15f!important}.controls button{position:relative}.loopOne{font-size:10px;font-weight:900;position:absolute;bottom:6px;right:7px}.modalBackdrop{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:999;background:#080c12b8;place-items:center;display:grid;position:fixed;inset:0}.modal{background:#182438;border:1px solid #365174;border-radius:20px;width:420px;padding:28px;position:relative;box-shadow:0 30px 100px #00000073}.closeModal{color:#fff;background:#223149;border:0;border-radius:10px;place-items:center;width:36px;height:36px;display:grid;position:absolute;top:14px;right:14px}.modalIcon{color:#ddb15f;background:#263b59;border-radius:16px;place-items:center;width:64px;height:64px;margin-bottom:18px;font-size:30px;display:grid}.modal h2{margin:0 0 8px;font-size:30px}.modal p{color:#a8b8cc;margin:0 0 20px}.modal input{color:#fff;background:#101722;border:1px solid #365174;border-radius:12px;outline:none;width:100%;margin-bottom:16px;padding:14px 16px}.modalCreate{color:#111827;background:#ddb15f;border:0;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 16px;font-weight:900;display:flex}.selectedMini{color:#ddb15f;font-weight:800}.emptyPlaylistPage{text-align:center;color:#a8b8cc;border:1px dashed #365174;border-radius:16px;place-content:center;justify-items:center;gap:10px;min-height:360px;display:grid}.emptyPlaylistPage svg{color:#ddb15f;font-size:48px}.emptyPlaylistPage h3{color:#edf2f7;margin:0;font-size:26px}.emptyPlaylistPage button{color:#111827;background:#ddb15f;border:0;border-radius:12px;padding:12px 18px;font-weight:900}.editBtn{color:#edf2f7;background:#223149;border:0;border-radius:9px;padding:9px 12px}.editBtn:hover{background:#365174}.coverUpload{color:#ddb15f;cursor:pointer;background:#101722;border:1px dashed #365174;border-radius:12px;place-items:center;width:100%;margin-bottom:16px;padding:14px 16px;display:grid}.miniVisualizer{opacity:0;width:130px;height:42px;margin-left:24px;transition:opacity .25s,transform .25s;transform:translateY(8px);background:0 0!important;border:none!important;border-radius:0!important}.miniVisualizer.show{opacity:1;transform:translateY(0)}.songRow select{max-width:120px}.addPlaylistBtn{color:#edf2f7;background:#223149;border:0;border-radius:10px;align-items:center;gap:7px;padding:9px 12px;display:flex}.addPlaylistBtn:hover{background:#365174}.playlistPicker{flex-direction:column;gap:10px;display:flex}.playlistPicker button{color:#edf2f7;text-align:left;background:#101722;border:1px solid #365174;border-radius:12px;justify-content:space-between;align-items:center;width:100%;padding:14px;display:flex}.playlistPicker button:hover:not(:disabled){background:#223149}.playlistPicker button:disabled{opacity:.5;cursor:not-allowed}.playlistPicker span{flex-direction:column;gap:4px;display:flex}.playlistPicker small{color:#a8b8cc}.emptyAdd{text-align:center;border:1px dashed #365174;border-radius:12px;padding:22px}.emptyAdd button{color:#111827;background:#ddb15f;border:0;border-radius:10px;align-items:center;gap:8px;padding:11px 14px;font-weight:900;display:inline-flex}.volumeSlider{accent-color:#ddb15f;width:150px}.deleteBtn{color:#a8b8cc;background:#223149;border:0;border-radius:10px;place-items:center;width:38px;height:38px;display:grid}.deleteBtn:hover{color:#fff;background:#5f2930}.volumeSlider{accent-color:#ddb15f;cursor:pointer;height:8px;width:160px!important;display:block!important}.player{grid-template-columns:360px 1fr 260px!important}.miniVisualizer{display:none!important}.trackText{min-width:0}.trackTitleLine{align-items:center;gap:10px;min-width:0;display:flex}.trackTitleLine h4{white-space:nowrap;text-overflow:ellipsis;max-width:230px;margin:0 0 4px;overflow:hidden}.spotifyViz{opacity:0;background:0 0;border:0;flex:none;width:34px;height:22px;transition:opacity .18s,transform .18s;transform:translateY(4px)}.spotifyViz.show{opacity:1;transform:translateY(0)}.spotifyViz{display:none!important}.rowViz{opacity:0;background:0 0;border:0;width:54px;height:34px;transition:opacity .18s,transform .18s;transform:translateY(4px)}.rowViz.show{opacity:1;transform:translateY(0)}.rowViz{display:none!important}.spotifyBars{opacity:0;justify-content:center;align-items:flex-end;gap:5px;width:52px;height:34px;transition:opacity .18s,transform .18s;display:flex;transform:translateY(4px)}.spotifyBars.active{opacity:1;transform:translateY(0)}.spotifyBars span{background:#ddb15f;border-radius:999px 999px 3px 3px;width:6px;height:6px;animation:.65s ease-in-out infinite spotifyBar;box-shadow:0 0 10px #ddb15f33}.spotifyBars span:first-child{animation-delay:0s}.spotifyBars span:nth-child(2){animation-delay:.12s}.spotifyBars span:nth-child(3){animation-delay:.24s}.spotifyBars span:nth-child(4){animation-delay:.36s}.spotifyBars span:nth-child(5){animation-delay:.48s}.spotifyBars:not(.active) span{height:6px;animation:none}@keyframes spotifyBar{0%,to{height:7px}30%{height:28px}60%{height:16px}}.spotifyBars{display:none!important}.tinyViz{opacity:0;background:0 0;border:0;width:36px;height:22px;transition:opacity .15s,transform .15s;transform:translateY(3px)}.spotifyBars,.rowViz,.spotifyViz,.miniVisualizer{display:none!important}.tinyViz{opacity:0;transition:opacity .15s,transform .15s;transform:translateY(3px);background:0 0!important;border:0!important;width:28px!important;height:18px!important}.tinyViz{align-self:center!important;width:38px!important;height:22px!important;margin-top:0!important;display:block!important;transform:none!important}.tinyViz.show{opacity:1;transform:none!important}.playVizGroup{justify-content:flex-start;min-width:92px;align-items:center!important;gap:10px!important;display:flex!important}.secondaryUpload:hover{background:#365174!important}.dragOverlay h2{margin:0 0 8px;font-size:34px}.dragOverlay p{color:#a8b8cc;margin:0}.app.dragging{filter:saturate(1.08)}.selectionControls button:hover:not(:disabled){background:#365174}.selectionControls .dangerSelect:hover:not(:disabled){background:#8b3744}.selectionControls button:disabled{opacity:.45;cursor:not-allowed}.secondaryUpload{color:#edf2f7!important;background:#223149!important}.dragOverlay{z-index:1000;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);text-align:center;color:#edf2f7;pointer-events:none;background:#101722e0;border:2px dashed #ddb15f;border-radius:26px;place-content:center;display:grid;position:fixed;inset:18px}.dragOverlay svg{color:#ddb15f;margin:0 auto 14px;font-size:54px}.libraryHeaderRow{justify-content:space-between;align-items:center;gap:16px;margin:8px 0 22px;display:flex}.libraryHeaderRow p{color:#a8b8cc;margin:0}.selectionControls{align-items:center;gap:10px;display:flex}.selectionControls button{color:#edf2f7;background:#223149;border:0;border-radius:10px;padding:9px 13px}.selectionControls .dangerSelect{background:#6b2f38}.songCheck{accent-color:#ddb15f;width:18px;height:18px}.favoriteBtn{color:#a8b8cc;background:0 0;border:0;font-size:18px}.favoriteBtn.favorited{color:#ddb15f}.deleteBtn,.addPlaylistBtn{color:#edf2f7;background:#223149;border:0;border-radius:10px;padding:9px 12px}.deleteBtn{place-items:center;width:38px;height:38px;display:grid}.deleteBtn:hover{background:#5f2930}.playVizGroup{align-items:center;gap:10px;min-width:92px;display:flex}.tinyViz{opacity:0;background:0 0!important;border:0!important;width:38px!important;height:22px!important;display:block!important}.tinyViz.show{opacity:1}.volume{align-items:center;gap:12px;min-width:220px;display:flex!important}.volumeSlider{accent-color:#ddb15f;cursor:pointer;width:160px!important;display:block!important}.addPlaylistBtn{color:#a8b8cc!important;background:0 0!important;border:0!important;border-radius:10px!important;place-items:center!important;width:38px!important;height:38px!important;padding:0!important;font-size:18px!important;transition:all .15s!important;display:grid!important}.addPlaylistBtn:hover{color:#ddb15f!important;background:#223149!important}.songRow{grid-template-columns:34px 56px minmax(220px,1fr) 38px 38px 38px 92px!important;align-items:center!important;column-gap:14px!important;min-height:76px!important;padding:10px 18px!important}.songRow:has(.songCheck){grid-template-columns:34px 24px 56px minmax(220px,1fr)!important}.songInfo{min-width:0!important}.songInfo h3{white-space:nowrap!important;text-overflow:ellipsis!important;margin:0 0 4px!important;font-size:17px!important;line-height:1.15!important;overflow:hidden!important}.songInfo p{white-space:nowrap!important;text-overflow:ellipsis!important;margin:0!important;overflow:hidden!important}.addPlaylistBtn,.favoriteBtn,.deleteBtn{justify-self:center!important}.playVizGroup{justify-self:end!important}@media (height<=850px),(width<=1200px){.sidebar{padding:18px!important}.main{padding:22px!important}.brand h1{font-size:21px!important}.nav,.upload,.topbar button{padding:11px 13px!important}.library h2{font-size:32px!important}.songRow{min-height:64px!important;padding:8px 14px!important}.cover{width:48px!important;height:48px!important}.player{grid-template-rows:84px!important;height:84px!important;padding:12px 22px!important}.miniCover{width:50px!important;height:50px!important}.controls .play{width:46px!important;height:46px!important}.controls button{width:36px!important;height:36px!important}}.track{min-width:220px}.track:empty{min-width:0}:root{font-size:14px}.app{grid-template-rows:1fr 84px!important;grid-template-columns:250px 1fr!important}.sidebar{padding:18px!important}.main{padding:24px!important}.logo{width:42px!important;height:42px!important}.brand h1{font-size:21px!important}.brand p,.nav,.upload,.playlistBox p{font-size:14px!important}.nav,.upload{padding:11px 14px!important}.emptyIcon{width:84px!important;height:84px!important}.empty h2{font-size:34px!important}.player{grid-template-columns:300px 1fr 230px!important;padding:12px 22px!important}.controls button{width:36px!important;height:36px!important}.controls .play{width:48px!important;height:48px!important}.player{grid-column:1/-1!important;grid-template-columns:1fr auto 1fr!important;align-items:center!important;height:84px!important;padding:0 32px!important;display:grid!important}.track{justify-self:start!important;min-width:0!important}.controls{justify-content:center!important;justify-self:center!important;align-items:center!important;gap:14px!important;display:flex!important}.volume{justify-self:end!important;align-items:center!important;display:flex!important}.app{grid-template-rows:1fr!important;min-height:100vh!important}.sidebar{height:100vh!important;min-height:100vh!important}.main{min-height:100vh!important}.player{z-index:50;bottom:0;left:0;right:0;position:fixed!important}.app{grid-template-rows:1fr auto!important;grid-template-columns:250px 1fr!important;height:100vh!important;min-height:100vh!important;display:grid!important}.sidebar{grid-row:1/-1!important;height:auto!important;min-height:0!important}.main{height:auto!important;min-height:0!important;overflow:auto!important}.player{grid-area:2/2/3/3!important;height:84px!important;position:static!important}
