/* Global bottom player bar */

#globalPlayer{
  --gp-progress-row-height: 22px;
  --gp-transport-row-height: 44px;
  --gp-left-width: 360px;
}

.global-player {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 40;
  background: color-mix(in srgb, var(--gp-bg) 94%, var(--page-bg) 6%);
  color: var(--gp-fg);
  border-top: 1px solid var(--gp-border);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  font-size: 0.96rem;
  box-sizing: border-box;
  box-shadow: 0 -12px 30px rgba(0,0,0,0.12);
  padding: 0.45rem 0.9rem calc(0.45rem + env(safe-area-inset-bottom));
}

body[data-theme="dark"] .global-player{
  box-shadow: 0 -12px 30px rgba(0,0,0,0.45);
}

.global-player.hidden {
  display: none;
}

.gp-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1.1rem;
  position: relative;
}

/* LEFT: artwork + title/artist */

.gp-left {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  flex: 0 0 var(--gp-left-width);
  max-width: var(--gp-left-width);
  min-width: 0;
  padding: 0.22rem 0.55rem;
  cursor: pointer;
}

.gp-left > * {
  position: relative;
  z-index: 1;
}

.gp-left::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  background: var(--gp-hover);
  opacity: 0;
  transition: opacity 140ms ease;
  pointer-events:none;
}

.gp-left::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(148, 163, 184, 0);
  transition: border-color 140ms ease;
  pointer-events: none;
}

.gp-left:hover::before,
.gp-left:focus-visible::before {
  opacity: 1;
}

.gp-left:hover::after,
.gp-left:focus-visible::after {
  border-color: var(--gp-focus-ring);
}

.gp-left:focus-visible {
  outline: none;
}

.gp-art-wrapper {
  width: 54px;
  aspect-ratio: 1 / 1;
  height: auto;
  overflow: hidden;
  background: #111827;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border-radius: calc(var(--radius-panel) + 4px);
}

.gp-art {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.gp-art-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.9rem;
  opacity: 0.5;
}

.gp-text {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}

.gp-title {
  min-width: 0;
  flex: 1 1 auto;
  font-size: 0.95rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gp-meta {
  font-size: 0.8rem;
  opacity: 0.8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gp-marquee-inner{
  display: inline-block;
  white-space: nowrap;
  will-change: transform;
}

.gp-title-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto auto;
  row-gap: 0.1rem;
  min-width: 0;
}

.gp-title-grid #globalPlayerLive{
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  align-self: center;
  min-width: 0;
  width: auto;
  transform: translateY(-2px);
}

.gp-title-grid #globalPlayerTitle{
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

.gp-title-grid #globalPlayerMeta{
  grid-column: 1;
  grid-row: 2;
  min-width: 0;
}

.gp-marquee-shell.gp-marquee-idle{
  -webkit-mask-image: linear-gradient(to right, #000 0, #000 calc(100% - 14px), transparent 100%);
  mask-image: linear-gradient(to right, #000 0, #000 calc(100% - 14px), transparent 100%);
}

.gp-marquee-shell.gp-marquee-active{
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%);
  mask-image: linear-gradient(to right, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%);
}

.gp-marquee-shell{
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  min-width: 0;
  text-overflow: clip;
}

.gp-live{
  font-family: var(--font-header);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  padding: 0.12rem 0.38rem;
  border: 1px solid color-mix(in srgb, var(--gp-fg) 75%, transparent);
  color: var(--gp-fg);
  border-radius: 0.35rem;
  opacity: 0.85;
  flex: 0 0 auto;
  animation: none;
  width: auto !important;
  max-width: none;
  align-self: center;
  display: inline-flex;
}

.gp-live.gp-live-flash{
  animation: gp-live-pulse 1.8s ease-in-out infinite;
}

.gp-live.gp-live-paused{
  animation: none;
  opacity: 0.45;
}

.gp-live.hidden { display:none; }

@keyframes gp-live-pulse{
  0%,100%{ opacity:0.45; }
  50%{ opacity:0.95; }
}

.gp-transport{
  position: relative;
  width: 100%;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;     /* pins controls + timeline to true center */
  justify-content: center;
  gap: 0.22rem;
}

.gp-controls{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

/* Radio: add LIVE column + gap, and show badge */
.global-player[data-kind="radio"] .gp-title-grid{
  grid-template-columns: auto minmax(0, 1fr);
  column-gap: 0.55rem;
}

.global-player[data-kind="radio"] .gp-title-grid #globalPlayerLive{
  display: inline-flex;
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  align-self: center;
  transform: translateY(-2px); /* your “smidgen up” */
}

.global-player[data-kind="radio"] .gp-title-grid #globalPlayerTitle{
  grid-column: 2;
  grid-row: 1;
}

.global-player[data-kind="radio"] .gp-title-grid #globalPlayerMeta{
  grid-column: 1 / -1;
  grid-row: 2;
}

.gp-progress{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0.55rem;
  width: 100%;
}

.global-player[data-kind="radio"] .gp-progress{
  display: none !important;
}

.global-player[data-kind="radio"] .gp-transport{ gap: 0; }

/* CENTER: controls + long progress bar */

.gp-center{
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  width: 100%;
}

.gp-btn {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: none;
  background: rgba(249, 250, 251, 0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  cursor: pointer;
  font-size: 1rem;
}

.gp-btn,
.gp-volume-btn{
  background: var(--gp-control-bg);
}

.gp-btn-play {
  width: 36px;
  height: 36px;
  font-size: 1.05rem;
  background: color-mix(in srgb, var(--gp-fg) 10%, transparent);
  color: var(--gp-fg);
}

.gp-volume-btn:hover,
.gp-volume-btn:focus-visible,
.gp-btn:hover,
.gp-btn:focus-visible{
  background: var(--gp-control-bg-hover);
}

.gp-btn-play:hover,
.gp-btn-play:focus-visible {
  background: color-mix(in srgb, var(--gp-fg) 16%, transparent);
}

.gp-time {
  min-width: 2.8rem;
  text-align: center;
  opacity: 0.9;
  font-family: var(--font-header);
}

.gp-seek{
  height: 6px;
  background: color-mix(in srgb, var(--gp-fg) 18%, transparent);
  border-radius: 999px;
}

.gp-seek::-webkit-slider-thumb{
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--gp-fg);
}

.gp-seek::-moz-range-thumb{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--gp-fg);
  border: 0;
}

/* ===== Volume: icon + hover/focus pop slider (no layout width) ===== */

.gp-right{
  position: relative;
  display: inline-flex;
  align-items: center;
}

.gp-right::after{
  content:"";
  position:absolute;
  right:0;
  bottom:100%;
  width:160px;
  height:14px;
  pointer-events:auto;
}

.gp-volume-btn{
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: none;
  background: rgba(249, 250, 251, 0.12);
  color: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.gp-volume-pop{
  position: absolute;
  right: 0;
  bottom: calc(100% + 8px);
  width: 160px;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--gp-pop-bg);
  border: 1px solid var(--gp-border);
  box-shadow: 0 18px 34px rgba(0,0,0,0.45);
  opacity: 0;
  pointer-events: none;
  transform: translateY(6px);
  transition: opacity 140ms ease, transform 140ms ease;
  z-index: 1000;
}

/* Reveal */
.gp-right:hover .gp-volume-pop,
.gp-right:focus-within .gp-volume-pop{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  outline: none;
  box-shadow:
    0 18px 34px rgba(0,0,0,0.18),
    0 0 0 1px color-mix(in srgb, var(--gp-fg) 18%, transparent);
}

@media (pointer: fine){
  .gp-right::after{ /* keep bridge */ }
}

.gp-volume{
  width: 100%;
  --vol-pct: 100%;
  height: 18px;             /* gives room for thumb */
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
}

/* WebKit track */
.gp-volume::-webkit-slider-runnable-track{
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(
    to right,
    var(--gp-vol-fill) 0%,
    var(--gp-vol-fill) var(--vol-pct),
    var(--gp-vol-track) var(--vol-pct),
    var(--gp-vol-track) 100%
  );
}

/* WebKit thumb */
.gp-volume::-webkit-slider-thumb{
  -webkit-appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: var(--gp-vol-thumb);
  border: 2px solid color-mix(in srgb, var(--gp-pop-bg) 85%, transparent);
  box-shadow: 0 0 0 3px var(--gp-vol-thumb-ring);
  margin-top: -3px; /* centers thumb on 8px track */
}

/* Firefox track */
.gp-volume::-moz-range-track{
  height: 8px;
  border-radius: 999px;
  background: var(--gp-vol-track);
}
.gp-volume::-moz-range-progress{
  height: 8px;
  border-radius: 999px;
  background: var(--gp-vol-fill);
}
.gp-volume::-moz-range-thumb{
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: var(--gp-vol-thumb);
  border: 2px solid color-mix(in srgb, var(--gp-pop-bg) 85%, transparent);
  box-shadow: 0 0 0 3px var(--gp-vol-thumb-ring);
}

/* Video element stays hidden in the bar itself */
#globalPlayerVideo.hidden {
  display: none;
}

/* Responsive tweaks */

@media (max-width: 900px) {
  #globalPlayer{ --gp-left-width: 280px; }

  .gp-inner {
    gap: 0.7rem;
  }

  .gp-left{
    padding-right: 0.2rem;
  }

  .gp-title {
    flex: 1 1 auto;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  .gp-transport{
    gap: 0.35rem;
  }
}

.gp-skip-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.gp-skip-icon .gp-skip-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.42em;
  font-weight: 700;
  pointer-events: none;
}

/* -------- Desktop: Deezer-style (>= 901px) -------- */
@media (min-width: 901px){
  .global-player .gp-center{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: clamp(360px, 44vw, 680px);
  }

  .global-player .gp-right{
    position: absolute;
    right: 0.25rem;
    top: 50%;
    transform: translateY(-50%);
  }
}

/* -------- Tablet: grid (741–900px) -------- */
@media (max-width: 900px) and (min-width: 741px){
  .global-player .gp-inner{
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 1fr) auto;
    align-items: center;
    column-gap: 12px;
  }

  .global-player .gp-left{ grid-column: 1; max-width: none; }
  .global-player .gp-right{ grid-column: 3; justify-self: end; }
  .global-player .gp-center{ grid-column: 2; position: static; transform: none; width: auto; }
}

/* -------- Mobile: 2-col grid (<= 740px) -------- */
@media (max-width: 740px){
  .global-player .gp-inner{
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 12px;
  }

  .global-player .gp-left{ grid-column: 1; max-width: none; }
  .global-player .gp-center{ grid-column: 2; position: static; transform: none; width: auto; }
  .global-player .gp-right{ display: none !important; }

  .global-player .gp-time{ display: none; }
}

/* Fullscreen global player sheet */
:root{
  --gp-fs-bg: color-mix(in srgb, var(--gp-bg) 85%, #fff);
}

body[data-theme="dark"]{
  --gp-fs-bg: color-mix(in srgb, var(--gp-bg) 70%, #000);
}

#globalPlayer { transition: opacity 160ms ease, transform 160ms ease; }

#globalPlayerFullscreen{
  position: fixed;
  left: 0;
  right: 0;
  top: var(--topbar-h);
  bottom: 0;
  z-index: var(--gp-fs-z);
  background: var(--gp-fs-bg);
  transform: translateY(100%);
  transition: transform var(--gp-fs-ms) var(--gp-fs-ease);
  will-change: transform;
}

#globalPlayerFullscreen.is-open{ transform: translateY(0); }
#globalPlayerFullscreen.hidden{ display: none !important; }

#globalPlayerFullscreen.gp-fs.is-open{
  transform: translateY(0);
}

#globalPlayerFullscreen.gp-fs.hidden{
  display: none !important;
}

#globalPlayerFullscreen .gp-fs-inner{
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 24px;
  box-sizing: border-box;
}

#globalPlayerFullscreen .gp-fs-left{
  display: flex;
  align-items: center;
  justify-content: center;
}

#globalPlayerFullscreen .gp-fs-art{
  width: min(92%, 560px);
  max-height: calc(100vh - var(--topbar-h) - 48px);
  height: auto;
  border-radius: 18px;
  object-fit: cover;
}

#globalPlayerFullscreen .gp-fs-collapse{
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 0;
  background: transparent;
}

#globalPlayerFullscreen .gp-fs-collapse:hover,
#globalPlayerFullscreen .gp-fs-collapse:focus-visible{
  background: color-mix(in srgb, currentColor 10%, transparent);
  outline: none;
}

#globalPlayerFullscreen .gp-fs-right{
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  min-width: 0;
}

#globalPlayerFullscreen .gp-fs-title{
  font-family: var(--font-header);
  font-size: 2.0rem;
  line-height: 1.1;
}

#globalPlayerFullscreen .gp-fs-meta{
  opacity: 0.85;
  margin-top: 0.4rem;
  font-size: 1.05rem;
}

#globalPlayerFullscreen .gp-fs-controls{
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 8px;
}

#globalPlayerFullscreen .gp-fs-controls button{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, currentColor 12%, transparent);
}

#globalPlayerFullscreen .gp-fs-controls button:hover,
#globalPlayerFullscreen .gp-fs-controls button:focus-visible{
  background: color-mix(in srgb, currentColor 18%, transparent);
  outline: none;
}

body.gp-fs-open #globalPlayer{
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
}

@media (max-width: 900px){
  #globalPlayerFullscreen .gp-fs-inner{
    grid-template-columns: 1fr;
  }
  #globalPlayerFullscreen .gp-fs-art{
    max-height: 44vh;
  }
}

.gp-listeners {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.6rem;
  border-radius: 999px;
  background: var(--gp-control-bg);
  color: var(--gp-fg);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1;
  flex: 0 0 auto;
}

.gp-listeners i {
  font-size: 0.78rem;
  opacity: 0.85;
}

.gp-listeners.hidden {
  display: none !important;
}

/* Desktop: absolutely position it just to the left of the volume button */
@media (min-width: 901px) {
  .global-player .gp-listeners {
    position: absolute;
    right: calc(0.25rem + 32px + 0.6rem); /* volume btn width + gap */
    top: 50%;
    transform: translateY(-50%);
  }
}

/* Tablet (741–900px): let it sit in the grid flow next to gp-right */
@media (max-width: 900px) and (min-width: 741px) {
  .global-player .gp-inner {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 1fr) auto auto;
  }
  .global-player .gp-listeners { grid-column: 3; justify-self: end; }
  .global-player .gp-right { grid-column: 4; }
}

/* Mobile (≤740px): hide to save space */
@media (max-width: 740px) {
  .global-player .gp-listeners { display: none !important; }
}
