/* style.css — Neon Plasma Player */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{
  background:#050508;
  font-family:'Outfit',sans-serif;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px 16px;
}
/* ══════════════════════════════════════════
   PLAYER PRINCIPAL
══════════════════════════════════════════ */
.v1-shell{
  position:relative;
  border-radius:24px;
  padding:2px;
  background:linear-gradient(135deg,#0ff,#f0f,#0ff,#0af);
  background-size:300% 300%;
  animation:gradShift 4s linear infinite;
  box-shadow:0 0 40px rgba(0,255,255,.3),0 0 80px rgba(255,0,255,.2);
  width:95%;
}
@keyframes gradShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.v1-inner{
  border-radius:22px;
  background:#05060f;
  overflow:hidden;
  position:relative;
}
.v1-canvas-wrap{
  position:relative;
  height:150px;
  width:100%;
  overflow:hidden;
}
canvas.v1-cv{
  display:block;
  width:100%;
  height:100%;
}
.v1-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(5,6,15,.4) 0%,transparent 30%,transparent 70%,rgba(5,6,15,.8) 100%);
  pointer-events:none;
}
.v1-info{
  padding:12px 20px 4px;
  display:flex;flex-direction:column;gap:2px;
}
.v1-artist{
  font-family:'Orbitron',monospace;font-size:9px;font-weight:400;
  color:#0ff;letter-spacing:3px;text-transform:uppercase;
  text-shadow:0 0 10px #0ff;
}
.v1-title{
  font-family:'Orbitron',monospace;font-size:15px;font-weight:700;
  color:#fff;letter-spacing:1px;
  text-shadow:0 0 20px rgba(255,0,255,.6);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.v1-progress{
  margin:8px 20px 0;
  height:6px;background:rgba(255,255,255,.1);border-radius:3px;cursor:pointer;
}
.v1-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,#0ff,#f0f);
  border-radius:3px;
  box-shadow:0 0 8px #0ff;
  transition:width .1s linear;
  pointer-events:none;
}
.v1-time{
  display:flex;justify-content:space-between;
  padding:3px 20px 0;
  font-size:10px;color:rgba(255,255,255,.3);font-family:'Space Mono',monospace;
}
.v1-controls{
  display:flex;align-items:center;justify-content:center;
  gap:16px;padding:8px 20px 8px;
}
.v1-btn{
  width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.5);
  font-size:16px;display:flex;align-items:center;justify-content:center;
  transition:.2s;border:1px solid rgba(255,255,255,.08);
}
.v1-btn:hover{background:rgba(0,255,255,.1);color:#0ff;border-color:rgba(0,255,255,.3);box-shadow:0 0 12px rgba(0,255,255,.2)}
.v1-btn.play{
  width:54px;height:54px;font-size:20px;
  background:linear-gradient(135deg,rgba(0,255,255,.2),rgba(255,0,255,.2));
  color:#fff;border-color:rgba(0,255,255,.4);
  box-shadow:0 0 24px rgba(0,255,255,.25),inset 0 0 12px rgba(0,255,255,.05);
}
.v1-btn.play:hover{box-shadow:0 0 36px rgba(0,255,255,.5),inset 0 0 20px rgba(0,255,255,.1)}
.v1-btn:active{transform:scale(.92)}
/* ══════════════════════════════════════════
   BOTÕES GOSTEI / NÃO GOSTEI (na linha do play)
══════════════════════════════════════════ */
.v1-react{
  width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.04);
  font-size:16px;display:flex;align-items:center;justify-content:center;
  transition:.2s;border:1px solid rgba(255,255,255,.08);
  filter:grayscale(.6);opacity:.7;
}
.v1-react:hover{background:rgba(0,255,255,.1);border-color:rgba(0,255,255,.3);filter:grayscale(0);opacity:1}
.v1-react:active{transform:scale(.9)}
.v1-react.active-like{
  opacity:1;
  background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.7);
  box-shadow:0 0 16px rgba(255,255,255,.5);
  filter:grayscale(1) brightness(3);
}
.v1-react.active-dislike{
  opacity:1;
  background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.7);
  box-shadow:0 0 16px rgba(255,255,255,.5);
  filter:grayscale(1) brightness(3);
}
/* ══════════════════════════════════════════
   LINHA EXTRA: VOLUME ISOLADO
══════════════════════════════════════════ */
.v1-extra{
  display:flex;align-items:center;justify-content:center;
  padding:0 20px 18px;
}
.v1-vol-wrap{
  display:flex;align-items:center;gap:10px;width:100%;max-width:240px;
}
.v1-vol-icon{font-size:15px;opacity:.6}
.v1-vol{
  -webkit-appearance:none;appearance:none;
  flex:1;height:4px;border-radius:2px;cursor:pointer;
  background:linear-gradient(90deg,#0ff,#f0f);
  outline:none;
}
.v1-vol::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:16px;height:16px;border-radius:50%;
  background:#fff;cursor:pointer;
  box-shadow:0 0 8px #0ff,0 0 4px #fff;
}
.v1-vol::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;border:none;
  background:#fff;cursor:pointer;
  box-shadow:0 0 8px #0ff;
}
.v1-vol-pct{
  font-family:'Space Mono',monospace;font-size:10px;
  color:rgba(255,255,255,.5);min-width:34px;text-align:right;
}
/* ══════════════════════════════════════════
   MINI-PLAYER FLUTUANTE
══════════════════════════════════════════ */
#miniPlayer{
  position:fixed;
  bottom:28px;
  right:20px;
  z-index:9999;
  display:none;
}
.mini-bubble{
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#0ff,#f0f);
  box-shadow:0 0 20px rgba(0,255,255,.6),0 0 40px rgba(255,0,255,.3);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  animation:bubblePulse 2s ease-in-out infinite;
  transition:transform .2s;
  position:relative;
  overflow:hidden;
}
.mini-bubble:active{transform:scale(.9)}
@keyframes bubblePulse{
  0%,100%{box-shadow:0 0 20px rgba(0,255,255,.6),0 0 40px rgba(255,0,255,.3)}
  50%{box-shadow:0 0 35px rgba(0,255,255,.9),0 0 60px rgba(255,0,255,.5)}
}
.mini-bubble canvas{
  position:absolute;inset:0;width:100%;height:100%;border-radius:50%;opacity:.5;
}
.mini-bubble .mini-icon{
  position:relative;z-index:1;
  font-size:22px;color:#05060f;font-weight:bold;
  pointer-events:none;
}
.mini-controls{
  position:absolute;bottom:0;right:0;
  width:220px;
  background:rgba(5,6,15,.95);
  border:1px solid rgba(0,255,255,.25);
  border-radius:20px;
  padding:12px 14px 14px;
  box-shadow:0 0 30px rgba(0,255,255,.2);
  display:none;
  flex-direction:column;gap:8px;
}
.mini-controls.open{display:flex}
.mini-close{
  align-self:flex-end;
  background:none;border:none;color:rgba(255,255,255,.3);
  font-size:14px;cursor:pointer;line-height:1;padding:2px 4px;
}
.mini-close:hover{color:#f0f}
.mini-track{
  font-family:'Orbitron',monospace;font-size:9px;color:#0ff;
  letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  text-align:center;
}
.mini-prog{
  height:2px;background:rgba(255,255,255,.1);border-radius:2px;cursor:pointer;
}
.mini-prog-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,#0ff,#f0f);
  border-radius:2px;pointer-events:none;
}
.mini-btns{
  display:flex;align-items:center;justify-content:center;gap:14px;
}
.mini-btn{
  width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.04);color:rgba(255,255,255,.5);
  font-size:13px;display:flex;align-items:center;justify-content:center;
  transition:.2s;border:1px solid rgba(255,255,255,.08);
}
.mini-btn:hover{background:rgba(0,255,255,.1);color:#0ff}
.mini-btn.mplay{
  width:42px;height:42px;font-size:16px;
  background:linear-gradient(135deg,rgba(0,255,255,.2),rgba(255,0,255,.2));
  color:#fff;border-color:rgba(0,255,255,.4);
}
.mini-btn:active{transform:scale(.9)}
