
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{display:block}
::-webkit-scrollbar{/*width:0;height:0*/}
/*  *{scrollbar-width:none}*/

/* ══ TOKENS ══ */
:root{
  --a1:#7b9cff;
  --a2:#b87dff;
  --a3:#f472b6;
  --accent:linear-gradient(135deg,var(--a1),var(--a2));
  --glow:rgba(123,156,255,.32);
  --glow2:rgba(184,125,255,.24);
  --glow-r:rgba(255,100,120,.28);

  --bg:#fff;
  --s1:#fff;
  --s2:rgb(33 33 45 / 2%);
  --s3:#181828;
  --s4:rgb(33 33 45 / 2%);
  --s5:#2a2a3a;
  --s6:#343448;

  --g0:rgba(255,255,255,.025);
  --g1:rgb(178 178 186 / 5%);
  --g2:rgba(255,255,255,.09);
  --g3:rgba(255,255,255,.14);
  --gb:rgba(255,255,255,.07);
  --gb2:rgba(255,255,255,.12);

  --t1:#4a4a6a;
  --t2:#6b6b6b;
  --t3:#4a4a6a;
  --t4:#2e2e48;
  --t5:#93939c;

  --red:#ff5577;
  --grn:#22e5a8;
  --gold:#ffcc55;

  --nav-h:64px;
  --mini-h:72px;
  --hdr-h:58px;
  --sb-w:268px;

  --r-sm:10px;
  --r-md:14px;
  --r-lg:18px;
  --r-xl:22px;

  --ease:cubic-bezier(.4,0,.2,1);
  --spring:cubic-bezier(.32,.72,0,1);
  --bounce:cubic-bezier(.34,1.56,.64,1);
}

/* ══ NOISE TEXTURE ══ */
html,body{height:100%;/*overflow:hidden*/}
body {
    font-family: 'DM Sans', sans-serif;
    background: var(--bg);
    color: var(--t1);
    -webkit-font-smoothing: antialiased;
    display: flex;
    flex-direction: column;
    position: relative;
    padding-top: 60px;
    background: #e4e8f3;
	
}
body::after{
  content:'';position:fixed;inset:0;z-index:1000;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity:.022;mix-blend-mode:overlay;
}

/* ══ AMBIENT ══ */
#amb{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;display:none}
.blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:0;transition:background 3.5s ease,opacity 2.8s ease}
#b1{width:800px;height:800px;top:-350px;left:-250px}
#b2{width:600px;height:600px;bottom:-100px;right:-200px}
#b3{width:400px;height:400px;top:45%;left:45%;transform:translate(-50%,-50%)}

/* ══ HEADER ══ */
.hdr {
    position: fixed;
    z-index: 501;
    flex-shrink: 0;
    height: var(--hdr-h);
    background: rgba(255, 255, 255, .8);
    backdrop-filter: blur(40px) saturate(200%);
    -webkit-backdrop-filter: blur(40px) saturate(200%);
    border-bottom: 1px solid var(--gb);
    box-shadow: -2px -4px 10px 0 rgb(17 19 22 / 14%);
    top: 0;
    right: 0;
    left: 0;
}

.head-bd {
    display: flex;
    align-items: center;
    padding: 0 16px;
    gap: 10px;
    height: var(--hdr-h);
    margin: 0 auto;
    max-width: 1200px;
    width: 100%;
} 
  



.hdr-logo{display:flex;align-items:center;gap:9px;flex-shrink:0}
.hdr-icon{
  width:34px;height:34px;border-radius:10px;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  /*box-shadow:0 0 24px var(--glow),0 2px 8px rgba(0,0,0,.4);*/
  flex-shrink:0;position:relative;overflow:hidden;
}
.hdr-icon::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);border-radius:inherit}
.hdr-icon svg{color:#fff;position:relative;z-index:1}
.hdr-name{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;letter-spacing:-.5px}
.hdr-name em{font-style:normal;color:var(--t3);font-weight:500;font-size:15px}

.search{
  flex:1;background:var(--g1);border:1px solid var(--gb);
  border-radius:var(--r-md);display:flex;align-items:center;
  padding:0 13px;gap:9px;height:38px;
  transition:border-color .25s,box-shadow .25s,background .25s;
}
.search:focus-within{
  border-color:rgba(123,156,255,.5);
  box-shadow:0 0 0 3px rgba(123,156,255,.12);
  background:var(--g2);
}
.search svg{color:var(--t3);flex-shrink:0;transition:color .2s}
.search:focus-within svg{color:var(--a1)}
.search input{
  border:none;background:none;outline:none;
  font-family:'DM Sans',sans-serif;font-size:14px;
  font-weight:400;color:var(--t1);width:100%;
}
.search input::placeholder{color:var(--t3)}

.hbtn{
  width:36px;height:36px;flex-shrink:0;
  background:var(--g1);border:1px solid var(--gb);
  border-radius:var(--r-sm);display:flex;align-items:center;
  justify-content:center;color:var(--t2);
  transition:background .2s,color .2s,border-color .2s,transform .15s,box-shadow .2s;
}
.hbtn:hover{background: rgb(33 33 45 / 2%);;color:var(--t1);border-color:var(--gb2)}
.hbtn:active{transform:scale(.86)}
.hbtn.on{
  background:linear-gradient(135deg,rgba(123,156,255,.2),rgba(184,125,255,.2));
  border-color:rgba(123,156,255,.4);
  color:var(--a1);
  box-shadow:0 0 20px rgba(123,156,255,.15);
}

/* ══ LAYOUT ══ */
.layout{
	flex:1;
	display:flex;
	position:relative;
	padding-bottom: 75px;
    margin: 0 auto;
    max-width: 1200px;
    width: 100%;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .08);	
    background: var(--bg);	
}

/* ══ SIDEBAR ══ */
.sidebar{
  width:var(--sb-w);flex-shrink:0;
  background:rgba(255,255,255,1);
  border-right:1px solid var(--gb);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .4s var(--spring);
  position:relative;z-index:30;
}

@media(max-width:768px){
  .sidebar{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);z-index:500;padding-top:var(--hdr-h)}
  .sidebar.open{transform:translateX(0)}
  .sb-overlay{display:block}
}

@media(min-width:769px){
  .sidebar { position: fixed; transform: none !important; bottom: 0; top: 50px;float: left;background: #edf0fb; }
  .sb-overlay{display:none!important}
  
  .content {
      width: colc(100% - var(--sb-w));
      padding-left: var(--sb-w);
  }  
  

  
}
.sb-overlay{display:none;position:fixed;inset:0;z-index:499;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);top:58px}

.sb-user{
  padding:22px 16px 18px;display:flex;align-items:center;gap:13px;
  border-bottom:1px solid var(--gb);flex-shrink:0;
  background:linear-gradient(180deg,rgba(123,156,255,.04) 0%,transparent 100%);
}
.sb-avatar{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:#fff;
  box-shadow:0 4px 18px var(--glow),0 0 0 2px rgba(123,156,255,.25);
  position:relative;
}
.sb-avatar::after{
  content:'';position:absolute;inset:-3px;border-radius:50%;
  border:1px solid rgba(123,156,255,.2);
}
.sb-uname{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;letter-spacing:-.2px}
.sb-usub{
  font-size:11px;color:transparent;margin-top:2px;
  background:var(--accent);-webkit-background-clip:text;background-clip:text;
  font-weight:500;
}

.sb-nav{flex:1;overflow-y:auto;padding:10px 10px}
.sb-section{
  font-family:'DM Mono',monospace;
  font-size:9.5px;font-weight:500;color:var(--t4);
  letter-spacing:1.4px;text-transform:uppercase;
  padding:16px 10px 7px;
}
.sb-item{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;
  /*border-radius:var(--r-md);*/
  color:var(--t2);font-size:13.5px;font-weight:500;
  transition:background .15s,color .15s,transform .1s;
  cursor:pointer;text-decoration:none;
  position:relative;overflow:hidden;
}
.sb-item::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:2px;border-radius:2px;
  background:var(--accent);opacity:0;transition:opacity .2s;
}
.sb-item svg{flex-shrink:0;opacity:.6;transition:opacity .15s,transform .2s}
.sb-item:hover{background:var(--g1);color:var(--t1)}
.sb-item:hover svg{opacity:1;transform:scale(1.08)}
.sb-item.active{background:rgba(123,156,255,.1);color:var(--a1)}
.sb-item.active::before{opacity:1}
.sb-item.active svg{opacity:1;color:var(--a1)}
.sb-badge{
  margin-left:auto;padding:2px 8px;border-radius:20px;
  background:rgba(123,156,255,.15);border:1px solid rgba(123,156,255,.25);
  color:var(--a1);font-size:10px;font-weight:600;
  font-family:'DM Mono',monospace;letter-spacing:.3px;
}

.sb-bottom{padding:10px 10px;border-top:1px solid var(--gb);flex-shrink:0}
.sb-item-sm{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:var(--r-sm);
  color:var(--t3);font-size:13px;font-weight:500;
  transition:background .15s,color .15s;cursor:pointer;
}
.sb-item-sm:hover{background:var(--g1);color:var(--t2)}
.sb-item-sm svg{flex-shrink:0}

/* ══ CONTENT ══ */
.content{flex:1;display:flex;flex-direction:column;min-width:0}

/* ══ STICKY TOP ══ */
.sticky-top{
  flex-shrink:0;z-index:20;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid transparent;
  will-change:transform;
  transition:border-color .3s,box-shadow .3s,transform .38s cubic-bezier(.32,.72,0,1);
}
.sticky-top.scrolled{
  border-bottom-color:var(--gb);
}

/* chips */
.chips{display:flex;gap:6px;padding:13px 16px 0;overflow-x:auto;flex-shrink:0}
.chip{
  flex-shrink:0;padding:5px 15px;border-radius:20px;
  font-size:12px;font-weight:600;letter-spacing:.15px;
  border:1px solid var(--gb);background:transparent;color:var(--t3);
  transition:all .2s;
}
.chip:hover{color:var(--t2);border-color:var(--t3);background:var(--g1)}
.chip.on{
  background:var(--accent);
  border-color:transparent;color:#fff;
  box-shadow:0 3px 16px var(--glow);
  font-weight:700;
}

/* tabs */
.tabs{display:flex;gap:3px;padding:16px 16px;overflow-x:auto;flex-shrink:0}
.tab{
  flex-shrink:0;padding:7px 18px;border-radius:20px;
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;
  border:1px solid var(--gb);background:transparent;color:var(--t3);
  transition:all .2s;
}
.tab:hover{color:var(--t2);border-color:var(--t3)}
.tab.on{
  background:var(--accent);
  border-color:transparent;color:#fff;
  box-shadow:0 3px 16px var(--glow);
}

/* section row */
.sec-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 16px 11px;
}
.sec-title{
  font-family:'Syne',sans-serif;font-size:20px;
  font-weight:800;letter-spacing:-.6px;
}
.sec-meta{
  font-family:'DM Mono',monospace;
  font-size:11px;color:var(--t4);
  background:var(--g1);border:1px solid var(--gb);
  padding:3px 9px;border-radius:20px;
}

.scroll-area{flex:1;overflow-y:auto;padding:4px;}

/* ══ TRACK ROW ══ */
.trow{
  display:flex;align-items:center;gap:11px;
  padding:7px 10px;
  /*border-radius:var(--r-lg);*/
  cursor:pointer;
  transition:background .18s;
  animation:rise .35s var(--ease) both;
  position:relative;overflow:hidden;
}
.trow::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(123,156,255,.06),transparent);
  opacity:0;transition:opacity .25s;border-radius:inherit;
}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.trow:hover{background:rgba(255,255,255,.04)}
.trow:hover::before{opacity:1}
.trow.pl{background:rgba(123,156,255,.08)}
.trow.pl::before{opacity:1}
.trow.pl .tn{color:var(--a1)}
.trow:active{background:var(--s2)}

.ti{
  width:24px;text-align:center;
  font-family:'DM Mono',monospace;font-size:11px;
  color:var(--t4);flex-shrink:0;
}
.trow.pl .ti{display:none}
.trow.pl .teq{/*display:flex*/}
.teq{
  display:none;width:24px;height:18px;
  align-items:flex-end;justify-content:center;
  gap:2.5px;flex-shrink:0;
}
.teq s{
  width:3px;border-radius:2px 2px 0 0;
  background:var(--a1);text-decoration:none;display:block;
  animation:eqp .75s ease-in-out infinite alternate;
}
.teq s:nth-child(1){height:35%;animation-delay:0s}
.teq s:nth-child(2){height:100%;animation-delay:.18s}
.teq s:nth-child(3){height:55%;animation-delay:.09s}
.trow.pa .teq s{animation-play-state:paused}
@keyframes eqp{from{transform:scaleY(.2)}to{transform:scaleY(1)}}

.tcov-wrap{position:relative;flex-shrink:0}
.tcov{
  width:48px;height:48px;border-radius:var(--r-sm);
  object-fit:cover;background:var(--s4);
  transition:box-shadow .3s,transform .25s;
}
.trow:hover .tcov{transform:scale(1.04)}
.trow.pl .tcov{
  /*box-shadow:0 0 0 2px var(--a1),0 6px 22px rgba(123,156,255,.35);*/
}
.tcov-overlay{
  position:absolute;inset:0;border-radius:var(--r-sm);
  background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s;
}
.trow:hover .tcov-overlay,.trow.pl .tcov-overlay{opacity:1}
.tcov-overlay svg{color:#fff}

.tinfo{flex:1;min-width:0}
.tn{
  font-size:14px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:color .2s;letter-spacing:-.1px;
}
.ta{
  font-size:12px;color:var(--t2);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ta-genre{
  display:inline-block;font-size:10px;
  color:var(--t3);font-family:'DM Mono',monospace;
  margin-left:4px;
}

.tr{display:flex;align-items:center;gap:3px;flex-shrink:0}

.pl .tr {z-index: 1;}


.tdur{
  font-family:'DM Mono',monospace;font-size:11px;
  color:var(--t4);margin-right:3px;
}
.lbtn{
  width:32px;height:32px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--t4);transition:all .15s;
}
.lbtn:hover{background:var(--s4);color:var(--t2)}
.lbtn:active{transform:scale(.78)}
.lbtn.on{color:var(--red)}
.lbtn.on svg{fill:var(--red);stroke:var(--red)}

/* ══ EMPTY ══ */
.empty{padding:70px 24px;text-align:center}
.empty-icon{
  width:70px;height:70px;border-radius:50%;
  background:var(--g1);border:1px solid var(--gb);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
}
.empty-icon svg{opacity:.25}
.empty p{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;color:var(--t2)}
.empty small{font-size:13px;color:var(--t3);margin-top:4px;display:block}



.mainpl {
    z-index: 222;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
}



/* ══ MINI PLAYER ══ */
.minip{
  position:fixed;bottom:-74px;left:0;right:0;
  z-index:200;height:var(--mini-h);
  will-change:transform,opacity;
  transition:all .4s ease;
  transform-origin: 0 0;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);  
   margin: 0 auto;
   max-width: 1200px;
   width: 100%; 
}

.minip.on {
    bottom: 64px;
}



.minip-inner{
  position:absolute;inset:0;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(40px) saturate(200%);
  -webkit-backdrop-filter:blur(40px) saturate(200%);
  border-top:1px solid var(--gb2);
  /*overflow:hidden;*/
  box-shadow: 0px 2px 10px 0 rgb(17 19 22 / 14%);
}
.mprog{position:absolute;top:0;left:0;right:0;height:2px;background:transparent;cursor:pointer;}

.mprog::after {
    content: '';
    display: table;
    clear: both;
    height: 20px;
    width: 100%;
    position: absolute;
    top: -10px;
    z-index: 1;	
}



.mprog-fill{
  height:100%;width:0%;
  background:var(--accent);
  border-radius:2px;transition:width .5s linear;
  box-shadow:0 0 8px var(--glow);
}
.minip-in{
  position:relative;display:flex;align-items:center;
  height:100%;padding:0 14px;gap:11px;
}
.mc{
  width:46px;height:46px;border-radius:10px;
  object-fit:cover;background:var(--s4);flex-shrink:0;
  display:none;cursor:pointer;
  /*box-shadow:0 4px 18px rgba(0,0,0,.5);*/
  transition:border-radius .5s var(--spring),box-shadow .3s;
}
.mc.spin{
  border-radius:50%;
  animation:spin 24s linear infinite;
  /*box-shadow:0 4px 20px var(--glow)*/;
}
@keyframes spin{to{transform:rotate(360deg)}}
.mi{flex:1;min-width:0;cursor:pointer}
.mname{
  font-family:'Syne',sans-serif;font-size:14px;font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:-.2px;
}
.mart{font-size:12px;color:var(--t2);margin-top:2px}
.mctl{display:flex;align-items:center;gap:2px;flex-shrink:0}
.mb{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--t2);transition:all .15s;
}
.mb:hover{background:var(--g2);color:var(--t1)}
.mb:active{transform:scale(.85)}
.mb.play{
  width:44px;height:44px;
  background:var(--accent);
  color:#fff!important;
  box-shadow:0 4px 20px var(--glow);
  transition:transform .15s,box-shadow .15s!important;
}
.mb.play:hover{transform:scale(1.1);box-shadow:0 6px 28px var(--glow)!important}
.mb.play:active{transform:scale(.88)!important}

/* ══ TOP NAV ══ */

.top-nav {
    position: relative;
    height: var(--nav-h);
    display: flex;
    align-items: center;
    padding: 0 4px;
    will-change: transform;
    transition: transform .38s var(--spring);
    gap: 10px;
}

@media(max-width:640px){
   .top-nav {
       display: none;
   }
   
   ::-webkit-scrollbar{width:0;height:0}
   *{scrollbar-width:none}
   
   
}

@media(min-width:640px){
    .top-nav .nav-item {
      display: flex;
      flex-direction: row;
	  height:100%;
	  border-radius:0;
      padding: 0 15px;	  
    }

    .top-nav .nav-item:hover {
      background:var(--g1);
    }


    .top-nav > .nav-item svg {
        margin-right:5px;
    }



    .bottom-nav {
        display: none !important;
    }
    .minip.on {
        bottom: 0;
    } 
	
    .mainpl {
        z-index: 222;
        transform: translateY(0px) !important;
    }

	
}










.sbToggle {
  display:block; 
  padding:10px 8px;
  margin:30px 0;  
  border:none;
  outline:none;
  background-color:transparent;
  
}

.navicon__holder {
    display:block;
    cursor:pointer;
  }

.nav-lin {
    position: relative;
    display: block;
    width: 26px;
    height: 2px;
    margin-bottom: 6px;
    border-radius: 5px;
    background-color: #bfbfc4;
    transition: all 0.25s cubic-bezier(0.57, 0.28, 0.25, 0.69);
}
.nav-lin:last-of-type {
      margin-bottom:0;
    }

.sbToggle.open .nav-lin:first-of-type {
    transform:
      rotate(45deg)
      translateY(6px)
      translateX(6px);
  }

.sbToggle.open .nav-lin:nth-of-type(2) {
    opacity:0.0;
    transform:scale(0);
  }

.sbToggle.open .nav-lin:last-of-type {
    transform:
      rotate(-45deg)
      translateY(-5px)
      translateX(5px);
  }











/* ══ BOTTOM NAV ══ */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;
  z-index:210;height:var(--nav-h);
  background:#f1f1f9;
  backdrop-filter:blur(36px) saturate(200%);
  -webkit-backdrop-filter:blur(36px) saturate(200%);
  border-top:1px solid var(--gb);
  display:flex;align-items:center;
  padding:0 4px;
  will-change:transform;
  transition:transform .38s var(--spring);
}
.nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:4px;
  padding:6px 4px;border-radius:0px;
  color:var(--t3);font-size:9.5px;font-weight:600;
  letter-spacing:.3px;text-transform:uppercase;
  transition:color .2s,background .2s;height:100%;
}
.nav-item svg{transition:transform .25s var(--bounce)}
.nav-item:hover{color:var(--t2)}
.nav-item.active { color: var(--a1); background: var(--s4); }
.nav-item.active svg{transform:scale(1.15)}
.nav-dot{
  width:4px;height:4px;border-radius:50%;
  background:var(--a1);opacity:0;margin-top:-2px;
  transition:opacity .2s,transform .2s;
  box-shadow:0 0 6px var(--glow);
}
.nav-item.active .nav-dot{opacity:1}

/* ══ FULL PLAYER ══ */
.fullp{
  position:fixed;inset:0;z-index:501;
  transform:translateY(120%);
  transition:transform .5s var(--spring), opacity .4s ease;
  overflow:hidden;
  will-change:transform,opacity;
  bottom:0;
  
}
.fullp.open{transform:translateY(0)}

.fp-bg{position:absolute;inset:0;background:var(--s1);z-index:0}
.fp-blur{
  position:absolute;inset:-30px;z-index:0;opacity:0;
  filter:blur(100px) saturate(240%) brightness(.22);
  background-size:cover;background-position:center;
  transition:opacity 1.5s ease;
}
.fp-blur.on{opacity:1}
/* vignette */
.fp-vign{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  /*background:radial-gradient(ellipse at 50% 0%, transparent 40%, rgba(5,5,9,.7) 100%);*/
}

.fp-body{
  position:relative;z-index:2;
  height:100%;overflow-y:auto;
  display:flex;flex-direction:column;
  padding-bottom:32px;
}

.drag-bar{
  width:40px;height:4px;
  background:rgba(0,0,0,.12);
  border-radius:3px;margin:14px auto 0;
  cursor:pointer;flex-shrink:0;
  transition:background .2s;
}
.drag-bar:hover{background:rgba(0,0,0,.25)}

.fp-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px 0;flex-shrink:0;
  display:none;
}
.fp-ico{
  width:36px;height:36px;
  background:var(--g1);border:1px solid var(--gb);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--t2);transition:all .2s;
}
.fp-ico:hover{background:var(--s4);color:var(--t1)}
.fp-lbl{
  font-family:'DM Mono',monospace;
  font-size:10px;font-weight:500;color:var(--t3);
  letter-spacing:1.2px;text-transform:uppercase;
}

/* Cover */
.fp-cov-w {
    padding: 22px 30px 0;
    flex-shrink: 0;
    display: flex;
    justify-content: center;
}
.fp-cov-shadow{
  border-radius:var(--r-xl);
  transition:box-shadow .4s;
  position:relative;
}
.fp-cov{
  width:100%;aspect-ratio:1;
  object-fit:cover;background:var(--s4);display:block;
  transition:transform .4s var(--ease);
  width: 260px;
}
.fp-cov.live{transform:scale(1.02)}
.fp-cov-shadow.live{
	/*box-shadow: -1px 10px 17px rgb(45 46 49 / 6%), 0 0 30px rgb(78 80 92 / 10%)*/
}


#pDot { pointer-events: none; }

/* Info */
.fp-info{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:24px 28px 0;
}
.fp-tt{
  /*font-family:'Syne',sans-serif;*/
  font-size:23px;font-weight:800;
  letter-spacing:-.6px;line-height:1.2;
}
.fp-ar{
  font-size:15px;color:var(--a1);font-weight:500;margin-top:5px;
  letter-spacing:-.1px;
}
.fp-ht{
  width:44px;height:44px;border-radius:50%;margin-top:0;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--t3);transition:all .22s;
}
.fp-ht:hover{background:var(--g1);color:var(--t1)}
.fp-ht.on{color:var(--red)}
.fp-ht.on svg{fill:var(--red);stroke:var(--red)}
.fp-ht:active{transform:scale(1.35)}

/* Controls */
.fp-ctl{padding:22px 26px 0;flex-shrink:0}

.prog-w{
  position:relative;height:4px;
  background:rgb(245 245 255 / 97%);
  border-radius:4px;cursor:pointer;margin-bottom:8px;
  transition:height .2s;
}
.prog-w:hover,.prog-w.drag{height:6px}
.prog-fill{
  position:absolute;inset:0 auto 0 0;
  background:var(--accent);
  border-radius:4px;pointer-events:none;
  box-shadow:0 0 10px var(--glow);
}
.prog-dot{
  position:absolute;top:50%;transform:translate(-50%,-50%);
  width:14px;height:14px;background:#fff;border-radius:50%;
  box-shadow:0 2px 8px rgba(0,0,0,.5),0 0 0 2px rgba(123,156,255,.4);
  pointer-events:none;opacity:0;transition:opacity .15s;
}
.prog-w:hover .prog-dot,.prog-w.drag .prog-dot{opacity:1}
.prog-inp{position:absolute;inset:-10px 0;opacity:0;cursor:pointer;width:100%;-webkit-appearance:none}
.ptimes{
  display:flex;justify-content:space-between;
  font-family:'DM Mono',monospace;font-size:11px;color:var(--t3);
}

.fp-btns{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:26px;
}
.sb-btn{
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--t5);transition:all .2s;
}
.sb-btn:hover{background:var(--g1);color:var(--t1)}
.sb-btn.on{color:var(--a1)}
.nb{
  width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--t1);transition:background .15s,transform .15s;
}
.nb:hover{color:#b87dff}
.nb:active{transform:scale(.84)}
.pbig{
  width:70px;height:70px;border-radius:50%;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 32px var(--glow),0 0 0 1px rgba(255,255,255,.1);
  transition:transform .15s,box-shadow .15s;
}
.pbig:hover{transform:scale(1.07);box-shadow:0 12px 42px var(--glow)}
.pbig:active{transform:scale(.9)}
.pbig svg{color:#fff;}

.vol-row{display:flex;align-items:center;gap:11px;margin-top:26px;display:none;}
.vol-row svg{color:var(--t3);flex-shrink:0}
.vol-tr{flex:1;height:3px;background:rgba(255,255,255,.08);border-radius:3px;position:relative;cursor:pointer}
.vol-fill{position:absolute;inset:0 auto 0 0;background:var(--t3);border-radius:3px}
.vol-inp{position:absolute;inset:-8px 0;opacity:0;cursor:pointer;width:100%;-webkit-appearance:none}

.fp-acts{
  display:flex;justify-content:space-around;
  margin-top:26px;padding-top:22px;
  border-top:1px solid var(--gb);
  display:none;
}
.fact{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  color:var(--t3);font-size:11px;font-weight:600;
  transition:color .2s;letter-spacing:.2px;
}
.fact:hover{color:var(--t2)}
.fact .iw{
  width:44px;height:44px;
  background:var(--g1);border:1px solid var(--gb);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.fact:hover .iw{background:var(--s4);border-color:var(--gb2)}
.fact:active .iw{transform:scale(.9)}

/* ══ QUEUE ══ */
.qpanel{position:fixed;inset:0;z-index:500;pointer-events:none;opacity:0;transition:opacity .3s}
.qpanel.open{pointer-events:all;opacity:1}
.qov{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);top:58px;}
.qsheet{
  position:absolute;bottom:0;left:0;right:0;
  background:#fff;
  border-radius:24px 24px 0 0;
  border:1px solid var(--gb);border-bottom:none;
  max-height:74vh;display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .4s var(--spring);
  box-shadow:0 -10px 50px rgba(0,0,0,.5);
}
.qpanel.open .qsheet{transform:translateY(0)}
.qdrag{width:40px;height:4px;background:var(--gb);border-radius:3px;margin:13px auto;flex-shrink:0;cursor:pointer}
.qhdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px 13px;flex-shrink:0;
  border-bottom:1px solid var(--gb);
}
.qhdr-t{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;letter-spacing:-.4px}
.qhdr-sub{font-family:'DM Mono',monospace;font-size:11px;color:var(--t3)}
.qhdr-c{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--t2);font-size:18px;
  background:var(--g1);border:1px solid var(--gb);
  transition:background .15s;
}
.qhdr-c:hover{background:var(--s4)}
.qlist{overflow-y:auto;flex:1;padding:8px 12px 16px}
.qi{
  display:flex;align-items:center;gap:11px;
  padding:8px 10px;border-radius:var(--r-md);
  cursor:pointer;transition:background .15s;
}
.qi:hover{background:var(--g1)}
.qi.active{background:rgba(123,156,255,.09)}
.qi.active .qi-n{color:var(--a1)}
.qi-num{
  width:22px;font-family:'DM Mono',monospace;font-size:11px;
  color:var(--t4);text-align:center;flex-shrink:0;
}
.qi-img{width:40px;height:40px;border-radius:9px;object-fit:cover;background:var(--s4);flex-shrink:0}
.qi-n{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qi-a{font-size:11px;color:var(--t2)}

/* ══ TOAST ══ */
.toast{
  position:fixed;left:50%;z-index:700;
  bottom:calc(var(--mini-h) + var(--nav-h) + 12px);
  transform:translateX(-50%) translateY(16px);
  background:var(--s5);border:1px solid var(--gb2);
  border-radius:24px;padding:9px 20px;
  font-size:13px;font-weight:500;color:var(--s1);
  opacity:0;pointer-events:none;white-space:nowrap;
  transition:opacity .22s,transform .25s var(--spring);
  box-shadow:0 4px 20px rgba(0,0,0,.4);
  backdrop-filter:blur(20px);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══ SCROLLBAR CUSTOM ══ */
.scroll-area::-webkit-scrollbar,.sb-nav::-webkit-scrollbar,.qlist::-webkit-scrollbar{width:0}
/* ══------------ ══ */

#fpCovShadow {
  touch-action: pan-y;
}

#fpCov {
  transition: transform .3s cubic-bezier(.32,.72,0,1), opacity .3s ease;
  will-change: transform, opacity;
  border-radius: var(--r-xl);
  box-shadow: -1px 10px 17px rgb(45 46 49 / 6%), 0 0 30px rgb(78 80 92 / 10%);  
}

#fpCovShadow:after{
    content: '';
    position: absolute;
    inset: 0;
    mix-blend-mode: overlay;
    z-index: 1;
}




/* Иконки next/prev при свайпе */
.swipe-hint {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) scale(.6);
  opacity: 0;
  pointer-events: none;
  width: 52px;
  height: 52px;
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .15s ease, transform .15s ease;
}
.swipe-hint.left  { left: 12px; }
.swipe-hint.right { right: 12px; }
.swipe-hint svg   { width: 24px; height: 24px; fill: #fff; }
.swipe-hint.show  { opacity: 1; transform: translateY(-50%) scale(1); }


/* Seek ripple */
.seek-ripple {
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
  pointer-events: none;
  border-radius: inherit;
  animation: seekFlash .55s cubic-bezier(.4,0,.2,1) forwards;
}
.seek-ripple.seek-left  { left: 0;  background: radial-gradient(ellipse at 30% 50%, rgba(255,255,255,.28) 0%, transparent 70%); border-radius: 16px 0 0 16px; }
.seek-ripple.seek-right { right: 0; background: radial-gradient(ellipse at 70% 50%, rgba(255,255,255,.28) 0%, transparent 70%); border-radius: 0 16px 16px 0; }

@keyframes seekFlash {
  0%   { opacity: 0;   transform: scale(.85); }
  25%  { opacity: 1;   transform: scale(1);   }
  100% { opacity: 0;   transform: scale(1.05);}
}