:root{
  --bg1:#050812;
  --bg2:#071021;
  --card:#0b1222cc;
  --stroke:#1f2a44;
  --text:#e6eefc;
  --muted:#94a3b8;
  --blue:#3b82f6;
  --blue2:#60a5fa;
  --glow: rgba(59,130,246,.55);
  --glow2: rgba(99,102,241,.35);
}

*{box-sizing:border-box}
html,body{
  height:100%;
  margin:0;
  overflow:hidden;
}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 700px at 20% 10%, #0b1a3a 0%, transparent 55%),
              radial-gradient(900px 500px at 80% 20%, #1b0b3a 0%, transparent 60%),
              linear-gradient(180deg, var(--bg2), var(--bg1));
  color:var(--text);
}

.player-shell{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px;
}

.player-card{
  width:100%;
  max-width:860px;
  height:100%;
  border:1px solid var(--stroke);
  background: var(--card);
  backdrop-filter: blur(14px);
  border-radius:14px;
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  padding:10px;
  display:flex;
  flex-direction:column;
}

.top{
  display:grid;
  grid-template-columns: 100px 1fr;
  gap:10px;
  align-items:start;
}

.cover-wrap{
  width:100px;
  height:100px;
  border-radius:12px;
  overflow:hidden;
  position:relative;
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 0 0 1px rgba(59,130,246,.15), 0 0 30px var(--glow);
  flex:0 0 auto;
}
.cover-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform: scale(1.02);
  transition: opacity .25s ease, transform .35s ease;
}
.cover-wrap.playing img{
  animation: slowSpin 12s linear infinite;
}
@keyframes slowSpin{
  from{ transform: scale(1.02) rotate(0deg); }
  to{ transform: scale(1.02) rotate(360deg); }
}
.cover-glow{
  position:absolute; inset:-40px;
  background: radial-gradient(circle at 30% 20%, var(--glow) 0%, transparent 60%),
              radial-gradient(circle at 70% 80%, var(--glow2) 0%, transparent 55%);
  filter: blur(18px);
  opacity:.7;
  pointer-events:none;
}

.meta{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}
.badge{
  display:inline-flex;
  padding:3px 7px;
  border-radius:999px;
  background: rgba(59,130,246,.12);
  border: 1px solid rgba(59,130,246,.25);
  color: var(--blue2);
  font-weight:600;
  font-size:9px;
  letter-spacing:.3px;
  align-self:flex-start;
}
.artist{
  font-size:14px;
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.title{
  font-size:11px;
  color: var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.subrow{
  display:flex;
  gap:6px;
  align-items:center;
}
.status{
  width:7px;
  height:7px;
  border-radius:50%;
  background:#334155;
  box-shadow: 0 0 0 3px rgba(148,163,184,.10);
}
.status.live{
  background:#22c55e;
  box-shadow: 0 0 0 3px rgba(34,197,94,.12), 0 0 12px rgba(34,197,94,.35);
}
.status-text{
  font-size:10px;
  color: var(--muted);
}

.social{
  display:flex;
  gap:4px;
  flex-wrap:wrap;
}
.social-btn{
  text-decoration:none;
  color: var(--text);
  font-size:9px;
  padding:4px 6px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(2,6,23,.35);
  transition: transform .15s ease, border-color .15s ease;
}
.social-btn:hover{
  transform: translateY(-1px);
  border-color: rgba(96,165,250,.35);
}

.controls{
  margin-top:8px;
  padding-top:8px;
  border-top: 1px solid rgba(255,255,255,.06);
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px;
  align-items:start;
}

.buttons{
  display:flex;
  flex-direction:column;
  gap:6px;
  grid-column: 1;
}
.btn{
  cursor:pointer;
  border:none;
  border-radius:10px;
  padding:7px 10px;
  font-weight:700;
  letter-spacing:.2px;
  font-size:11px;
  width:100%;
}
.btn.primary{
  background: linear-gradient(135deg, rgba(59,130,246,.95), rgba(99,102,241,.85));
  color:white;
  box-shadow: 0 10px 25px rgba(59,130,246,.22);
}
.btn.ghost{
  background: rgba(148,163,184,.10);
  color: var(--text);
  border: 1px solid rgba(255,255,255,.08);
}
.btn:hover{ filter: brightness(1.04); }

.right-column{
  grid-column: 2;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.volume{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.vol-label{ font-size:10px; color:var(--muted); }
.vol-value{ font-size:10px; color:var(--muted); text-align:right; }
input[type="range"]{
  width:100%;
  accent-color: var(--blue);
}

#viz{
  width:100%;
  height:35px;
  display:block;
  background: rgba(2,6,23,.35);
  border: 1px solid rgba(255,255,255,.06);
  border-radius:10px;
}

.external{
  margin-top:4px;
}
.external-title{
  font-size:9px;
  color: var(--muted);
  margin-bottom:4px;
  text-transform:uppercase;
  letter-spacing:.5px;
}
.external-row{
  display:flex;
  gap:4px;
  flex-wrap:wrap;
}
.ext{
  display:flex;
  flex-direction:column;
  gap:3px;
  align-items:center;
  padding:5px;
  border-radius:8px;
  text-decoration:none;
  color: var(--text);
  background: rgba(2,6,23,.35);
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .15s ease, border-color .15s ease;
  flex:1;
  min-width:0;
}
.ext:hover{
  transform: translateY(-1px);
  border-color: rgba(96,165,250,.35);
}
.ext img{
  width:18px;
  height:18px;
  object-fit:contain;
  filter: drop-shadow(0 0 10px rgba(59,130,246,.2));
}
.ext span{ font-size:8px; color: var(--muted); font-weight:700; }

@media (max-width:720px){
  /* Korrektes Grid-Verhalten für kleine Breiten */
  .top{ grid-template-columns: 1fr; }
  .cover-wrap{ width:140px; height:140px; }
  .buttons{ width:100%; }
  .btn{ flex:1; }
}