/* ============================================================================
   player.css — global two-tab Listen player (Contemporary Works / Screen Scoring)
   Themed per THEME_SPEC: cream + deep gold in light, near-black + brand gold in
   dark. Own token set scoped to .gplayer so it looks identical on every page
   regardless of that page's variable system. Driven by body.theme-dark.
============================================================================ */
.gplayer {
  --pl-bg:        #efeae0;
  --pl-elev:      #e6e0d5;
  --pl-ink:       #161310;
  --pl-sub:       #5F5A55;
  --pl-line:      #D9D2CA;
  --pl-gold:      #9c7a2a;   /* deep gold reads on cream (progress/active) */
  --pl-gold-soft: #C6B18B;
  --pl-on:        #fffaf2;   /* text on a gold fill */

  position: fixed;
  right: clamp(12px, 2vw, 26px);
  bottom: clamp(12px, 2vw, 26px);
  width: min(352px, 94vw);
  z-index: 140;
  font-family: "Inter", "Avenir Next", system-ui, sans-serif;
  transform: translateY(140%);
  opacity: 0;
  pointer-events: none;
  transition: transform .55s cubic-bezier(.2,.8,.2,1), opacity .4s ease;
}
.gplayer.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }

body.theme-dark .gplayer {
  --pl-bg:        #17130f;
  --pl-elev:      #211c17;
  --pl-ink:       #d6b269;   /* gold headings in dark */
  --pl-sub:       #9a9084;
  --pl-line:      #322b22;
  --pl-gold:      #d6b269;
  --pl-gold-soft: #b08a3a;
  --pl-on:        #161310;
}

.gplayer__card {
  background: var(--pl-bg);
  border: 1px solid var(--pl-line);
  border-radius: 16px;
  box-shadow: 0 30px 80px rgba(0,0,0,.30);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: 76vh;
}

/* ---- header: tabs + close ---- */
.gplayer__head { display: flex; align-items: center; gap: 10px; padding: 13px 13px 12px; border-bottom: 1px solid var(--pl-line); }
.gplayer__tabs { display: flex; gap: 6px; flex: 1; }
.gplayer__tab {
  flex: 1; appearance: none; cursor: pointer; font: inherit;
  font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: 9px 8px; border-radius: 30px; border: 1px solid var(--pl-line);
  background: transparent; color: var(--pl-sub);
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.gplayer__tab.is-active { background: var(--pl-gold); color: var(--pl-on); border-color: var(--pl-gold); }
.gplayer--solo .gplayer__tab { pointer-events: none; }
.gplayer__close { appearance: none; border: none; background: none; cursor: pointer; color: var(--pl-sub); font-size: 21px; line-height: 1; padding: 2px 6px; }
.gplayer__close:hover { color: var(--pl-ink); }

/* ---- track list ---- */
/* show ~3 tracks at once, then scroll */
.gplayer__list { list-style: none; margin: 0; padding: 6px; overflow-y: auto; max-height: 174px; }
.gplayer__row { display: flex; align-items: center; gap: 12px; padding: 8px 10px; border-radius: 10px; cursor: pointer; transition: background .2s ease; }
.gplayer__row:hover, .gplayer__row.is-current { background: var(--pl-elev); }
.gplayer__art {
  width: 42px; height: 42px; border-radius: 7px; flex: 0 0 auto; object-fit: cover;
  background: linear-gradient(135deg, var(--pl-gold-soft), var(--pl-gold));
  display: flex; align-items: center; justify-content: center; color: var(--pl-on);
}
.gplayer__meta { flex: 1; min-width: 0; }
.gplayer__t { color: var(--pl-ink); font-size: 13.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gplayer__p { color: var(--pl-sub); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.gplayer__eq { flex: 0 0 auto; color: var(--pl-gold); opacity: 0; transition: opacity .2s ease; }
.gplayer__row.is-current .gplayer__eq { opacity: 1; }
.gplayer__eq span { display: inline-block; width: 2.5px; height: 11px; margin: 0 1px; background: currentColor; vertical-align: middle; transform-origin: bottom; animation: pl-eq 1s ease-in-out infinite; }
.gplayer__eq span:nth-child(2){ animation-delay: .25s; } .gplayer__eq span:nth-child(3){ animation-delay: .5s; }
.gplayer.is-paused .gplayer__eq span { animation-play-state: paused; }
@keyframes pl-eq { 0%,100%{ transform: scaleY(.4);} 50%{ transform: scaleY(1);} }

/* ---- now playing bar ---- */
.gplayer__now { border-top: 1px solid var(--pl-line); padding: 12px 14px 14px; background: var(--pl-elev); }
.gplayer__nowtop { display: flex; align-items: center; gap: 12px; }
.gplayer__nowart { width: 44px; height: 44px; border-radius: 8px; object-fit: cover; flex: 0 0 auto; background: linear-gradient(135deg, var(--pl-gold-soft), var(--pl-gold)); }
.gplayer__nowmeta { flex: 1; min-width: 0; }
.gplayer__nowt { color: var(--pl-ink); font-family: "Cormorant Garamond", serif; font-size: 18px; font-weight: 500; line-height: 1.1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gplayer__nowp { color: var(--pl-sub); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }
.gplayer__ctrls { display: flex; align-items: center; gap: 8px; }
.gplayer__btn { appearance: none; border: none; background: none; cursor: pointer; color: var(--pl-ink); display: flex; align-items: center; justify-content: center; padding: 4px; transition: color .2s ease; }
.gplayer__btn:hover { color: var(--pl-gold); }
.gplayer__play { width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--pl-gold); transition: background .2s ease, color .2s ease; }
.gplayer__play:hover { background: var(--pl-gold); color: var(--pl-on); }

.gplayer__seek { display: flex; align-items: center; gap: 10px; margin-top: 11px; }
.gplayer__time { font-size: 10.5px; color: var(--pl-sub); font-variant-numeric: tabular-nums; min-width: 30px; }
.gplayer__time--end { text-align: right; }
.gplayer__bar { flex: 1; height: 4px; border-radius: 3px; background: var(--pl-line); position: relative; cursor: pointer; }
.gplayer__fill { position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--pl-gold); border-radius: 3px; }
.gplayer__fill::after { content: ""; position: absolute; right: -4px; top: 50%; transform: translateY(-50%); width: 9px; height: 9px; border-radius: 50%; background: var(--pl-gold); }

.gplayer__vol { display: flex; align-items: center; gap: 8px; margin-top: 11px; color: var(--pl-sub); }
.gplayer__vol input[type=range] { -webkit-appearance: none; appearance: none; flex: 1; height: 3px; border-radius: 3px; background: var(--pl-line); accent-color: var(--pl-gold); cursor: pointer; }
.gplayer__vol input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; width: 12px; height: 12px; border-radius: 50%; background: var(--pl-gold); }

@media (max-width: 520px) {
  .gplayer { right: 8px; left: 8px; bottom: 8px; width: auto; }
}
