/* ============================================================
   NBH ENTERTAINMENT GROUP — naturalbornhustle.com
   Street-luxury: ink black / blood red / antique gold / bone
   ============================================================ */

:root {
  --ink: #0b0908;
  --smoke: #161210;
  --coal: #1f1a17;
  --bone: #f2ead9;
  --blood: #e5202c;
  --blood-deep: #8f1119;
  --gold: #c9a227;
  --dim: #8a8073;
  --hair: rgba(242, 234, 217, 0.12);
  --font-display: "Big Shoulders Display", sans-serif;
  --font-body: "Archivo", sans-serif;
  --font-mono: "IBM Plex Mono", monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%; text-size-adjust: 100%; /* lock iOS font scaling */
}

/* faster taps, no 300ms delay on interactive elements */
a, button, .track, .single-art, .feature-row, .video-frame, .edd-frame, .player-progress {
  touch-action: manipulation;
}

html { overflow-x: clip; }
body {
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: clip;
}

::selection { background: var(--blood); color: var(--bone); }

img { display: block; max-width: 100%; }
a { color: inherit; }

/* ---- film grain ---- */
.grain {
  position: fixed; inset: -50%;
  width: 200%; height: 200%;
  pointer-events: none; z-index: 9999;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grain 8s steps(10) infinite;
}
@keyframes grain {
  0%,100% { transform: translate(0,0); }
  20% { transform: translate(-3%,2%); }
  40% { transform: translate(2%,-3%); }
  60% { transform: translate(-2%,-2%); }
  80% { transform: translate(3%,3%); }
}

/* ============ NAV ============ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 2rem;
  padding-left: max(2rem, env(safe-area-inset-left));
  padding-right: max(2rem, env(safe-area-inset-right));
  background: linear-gradient(to bottom, rgba(11,9,8,0.95), rgba(11,9,8,0.75) 70%, transparent);
  backdrop-filter: blur(6px);
}
.nav-brand { text-decoration: none; display: flex; align-items: baseline; gap: 0.6rem; }
.brand-mark {
  font-family: var(--font-display); font-weight: 900; font-size: 1.9rem;
  color: var(--blood); letter-spacing: 0.02em; line-height: 1;
}
.brand-sub {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.28em;
  color: var(--dim);
}
.nav-links { display: flex; align-items: center; gap: 1.75rem; }
.nav-links a {
  text-decoration: none; font-family: var(--font-mono);
  font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bone); opacity: 0.8; transition: opacity 0.2s, color 0.2s;
}
.nav-links a:hover { opacity: 1; color: var(--gold); }
.nav-cta {
  border: 1px solid var(--blood); padding: 0.5rem 1rem;
  color: var(--blood) !important; opacity: 1 !important;
}
.nav-cta:hover { background: var(--blood); color: var(--bone) !important; }

/* ============ HERO ============ */
.hero {
  position: relative; min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 7rem 2rem 4rem;
  overflow: hidden;
}
.hero-glow {
  position: absolute; top: -20%; right: -10%;
  width: 70vw; height: 70vw; max-width: 900px; max-height: 900px;
  background: radial-gradient(circle, rgba(229,32,44,0.22), transparent 65%);
  filter: blur(40px); pointer-events: none;
}
.hero-eyebrow {
  font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.35em;
  color: var(--gold); margin-bottom: 1rem;
  display: flex; align-items: center; gap: 0.7rem;
  animation: rise 0.8s 0.1s both cubic-bezier(0.2, 0.8, 0.2, 1);
}
.dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--blood);
  box-shadow: 0 0 12px var(--blood);
  animation: pulse 2s infinite;
}
@keyframes pulse { 50% { opacity: 0.35; } }

.hero-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(5rem, 19vw, 17rem);
  line-height: 0.82; letter-spacing: 0.01em;
  text-transform: uppercase; position: relative; z-index: 2;
}
.hero-title .line { display: block; }
.line-1 {
  color: var(--bone);
  animation: rise 0.9s 0.25s both cubic-bezier(0.2, 0.8, 0.2, 1);
}
.line-2 {
  color: transparent;
  -webkit-text-stroke: 2px var(--blood);
  animation: rise 0.9s 0.4s both cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes rise {
  from { opacity: 0; transform: translateY(60px); }
  to { opacity: 1; transform: translateY(0); }
}

.hero-tag {
  margin-top: 1.6rem;
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.3em;
  color: var(--dim);
  animation: rise 0.8s 0.55s both cubic-bezier(0.2, 0.8, 0.2, 1);
}
.hero-actions {
  display: flex; gap: 1rem; margin-top: 2.4rem; flex-wrap: wrap;
  position: relative; z-index: 2;
  animation: rise 0.8s 0.7s both cubic-bezier(0.2, 0.8, 0.2, 1);
}

.btn {
  font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.15em;
  text-transform: uppercase; text-decoration: none; cursor: pointer;
  padding: 1rem 1.8rem; border: none; transition: all 0.25s;
}
.btn-blood {
  background: var(--blood); color: var(--bone);
  box-shadow: 6px 6px 0 var(--blood-deep);
}
.btn-blood:hover { transform: translate(-2px,-2px); box-shadow: 9px 9px 0 var(--blood-deep); }
.btn-ghost {
  background: transparent; color: var(--bone); border: 1px solid var(--hair);
}
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); }

/* floating covers */
.hero-covers { position: absolute; right: 3vw; bottom: 6%; z-index: 1; }
.hero-covers .cover {
  position: absolute; right: 0; bottom: 0;
  width: clamp(150px, 21vw, 300px); max-width: none; aspect-ratio: 1;
  object-fit: cover; border: 1px solid var(--hair);
  box-shadow: 0 30px 60px rgba(0,0,0,0.7);
}
.cover.c1 { transform: rotate(-8deg) translate(-58%, -22%); opacity: 0.55; animation: float 7s ease-in-out infinite; }
.cover.c2 { transform: rotate(5deg) translate(-26%, -6%); opacity: 0.8; animation: float 8s 0.8s ease-in-out infinite; }
.cover.c3 { transform: rotate(-2deg); animation: float 6s 0.4s ease-in-out infinite; }
@keyframes float {
  50% { margin-bottom: 14px; }
}

/* ============ EDD SPOTLIGHT ============ */
.edd-spotlight {
  max-width: 1100px; margin: 4.5rem auto 0; padding: 0 2rem;
}
.edd-head { text-align: center; margin-bottom: 1.6rem; }
.edd-kicker {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.26em;
  color: var(--blood); display: inline-flex; align-items: center; gap: 0.6rem;
  margin-bottom: 0.8rem;
}
.edd-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2.6rem, 8vw, 5rem); line-height: 0.9; text-transform: uppercase;
  color: var(--bone);
}
.edd-title span { color: var(--gold); -webkit-text-stroke: 0; }
.edd-stats {
  font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.08em;
  color: var(--dim); margin-top: 0.7rem;
}
.edd-stats strong { color: var(--blood); }
.edd-frame {
  position: relative; aspect-ratio: 16/9; overflow: hidden;
  border: 1px solid var(--hair); cursor: pointer;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(229,32,44,0.25);
}
.edd-frame img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s, opacity 0.3s; }
.edd-frame:hover img { transform: scale(1.03); opacity: 1; }
.edd-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.edd-frame .video-playbtn {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 88px; height: 88px; border-radius: 50%;
  background: rgba(229,32,44,0.95); display: grid; place-items: center;
  color: var(--bone); font-size: 1.8rem; padding-left: 6px;
  box-shadow: 0 0 50px rgba(229,32,44,0.6); transition: transform 0.25s; pointer-events: none;
  animation: pulse-btn 2.4s ease-in-out infinite;
}
@keyframes pulse-btn {
  0%,100% { box-shadow: 0 0 50px rgba(229,32,44,0.6); }
  50% { box-shadow: 0 0 80px rgba(229,32,44,0.9); }
}
.edd-frame:hover .video-playbtn { transform: translate(-50%,-50%) scale(1.12); }
.edd-frame .video-label {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 2.5rem 1.4rem 1.2rem;
  background: linear-gradient(transparent, rgba(11,9,8,0.92)); pointer-events: none;
}
.edd-frame .video-title { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; text-transform: uppercase; }
.edd-frame .video-views { font-family: var(--font-mono); font-size: 0.62rem; color: var(--gold); letter-spacing: 0.2em; }
.edd-actions { display: flex; gap: 1rem; justify-content: center; margin-top: 1.6rem; flex-wrap: wrap; }

/* ============ MARQUEE ============ */
.marquee {
  background: var(--blood); color: var(--ink);
  overflow: hidden; white-space: nowrap;
  border-top: 1px solid var(--blood-deep); border-bottom: 1px solid var(--blood-deep);
  transform: rotate(-1.2deg) scale(1.02); transform-origin: center;
}
.marquee-track {
  display: inline-block;
  font-family: var(--font-display); font-weight: 800; font-size: 1.5rem;
  letter-spacing: 0.08em; padding: 0.45rem 0;
  animation: marquee 22s linear infinite;
}
.marquee-track span { padding-right: 1rem; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ============ SECTIONS ============ */
.section { padding: 6rem 2rem; max-width: 1280px; margin: 0 auto; }

.section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 2rem; margin-bottom: 3.5rem; flex-wrap: wrap;
}
.section-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(3.4rem, 8vw, 6.5rem); line-height: 0.85;
  text-transform: uppercase; color: var(--bone);
}
.section-title.gold { color: var(--gold); }
.section-note {
  font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.12em;
  color: var(--dim); max-width: 320px; text-align: right;
}

.subhead {
  font-family: var(--font-display); font-weight: 800; font-size: 1.6rem;
  letter-spacing: 0.06em; color: var(--bone);
  margin: 3.5rem 0 1.5rem; display: flex; align-items: center; gap: 1rem;
}
.subhead .num {
  font-family: var(--font-mono); font-size: 0.7rem; color: var(--blood);
  border: 1px solid var(--blood); padding: 0.2rem 0.5rem;
}
.subhead::after { content: ""; flex: 1; height: 1px; background: var(--hair); }

/* ---- singles ---- */
.singles-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1.5rem;
}
.single-card {
  background: var(--smoke); border: 1px solid var(--hair);
  transition: transform 0.3s, border-color 0.3s;
}
.single-card:hover { transform: translateY(-6px); border-color: var(--blood); }
.single-art { position: relative; cursor: pointer; overflow: hidden; }
.single-art img { width: 100%; aspect-ratio: 1; object-fit: cover; transition: transform 0.5s; }
.single-card:hover .single-art img { transform: scale(1.05); }
.play-overlay {
  position: absolute; inset: 0; display: grid; place-items: center;
  background: rgba(11,9,8,0.45); opacity: 0; transition: opacity 0.25s;
}
.single-art:hover .play-overlay, .single-art.playing .play-overlay { opacity: 1; }
.play-overlay span {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--blood); display: grid; place-items: center;
  font-size: 1.3rem; color: var(--bone); padding-left: 4px;
  box-shadow: 0 0 30px rgba(229,32,44,0.6);
}
.single-art.playing .play-overlay span { padding-left: 0; }
.single-info { padding: 1rem 1.1rem 1.2rem; }
.single-title { font-weight: 700; font-size: 1rem; letter-spacing: 0.01em; }
.single-year { font-family: var(--font-mono); font-size: 0.68rem; color: var(--dim); letter-spacing: 0.15em; margin-top: 0.25rem; }

/* ---- albums ---- */
.album-block {
  display: grid; grid-template-columns: minmax(220px, 380px) 1fr;
  gap: 2.5rem; margin-bottom: 4rem;
  background: var(--smoke); border: 1px solid var(--hair); padding: 2rem;
}
.album-cover-wrap { position: relative; }
.album-cover-wrap img {
  width: 100%; aspect-ratio: 1; object-fit: cover;
  border: 1px solid var(--hair); box-shadow: 14px 14px 0 var(--coal);
}
.album-badge {
  position: absolute; top: -12px; left: -12px;
  background: var(--gold); color: var(--ink);
  font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.2em;
  padding: 0.35rem 0.7rem; font-weight: 500;
}
.album-meta h4 {
  font-family: var(--font-display); font-weight: 900; font-size: 2.2rem;
  line-height: 0.95; text-transform: uppercase; margin-bottom: 0.3rem;
}
.album-meta .album-sub {
  font-family: var(--font-mono); font-size: 0.7rem; color: var(--dim);
  letter-spacing: 0.18em; margin-bottom: 1.4rem;
}
.tracklist { list-style: none; }
.track {
  display: flex; align-items: center; gap: 0.9rem;
  padding: 0.55rem 0.6rem; border-bottom: 1px solid var(--hair);
  cursor: pointer; transition: background 0.2s;
}
.track:hover { background: rgba(229,32,44,0.08); }
.track.active { background: rgba(229,32,44,0.14); }
.track-no {
  font-family: var(--font-mono); font-size: 0.68rem; color: var(--dim);
  width: 1.6rem; text-align: right;
}
.track.active .track-no, .track:hover .track-no { color: var(--blood); }
.track-name { font-size: 0.92rem; flex: 1; }
.track-eq { display: none; gap: 2px; align-items: flex-end; height: 14px; }
.track.active .track-eq { display: flex; }
.track-eq i {
  width: 3px; background: var(--blood); display: block;
  animation: eq 0.8s ease-in-out infinite;
}
.track-eq i:nth-child(1) { height: 60%; }
.track-eq i:nth-child(2) { height: 100%; animation-delay: 0.2s; }
.track-eq i:nth-child(3) { height: 40%; animation-delay: 0.4s; }
@keyframes eq { 50% { transform: scaleY(0.4); } }

/* ---- features ---- */
.features-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1rem; }
.feature-row {
  display: flex; align-items: center; gap: 1rem; min-width: 0;
  background: var(--smoke); border: 1px solid var(--hair);
  padding: 0.8rem; cursor: pointer; transition: border-color 0.2s, transform 0.2s;
}
.feature-row:hover { border-color: var(--gold); transform: translateX(4px); }
.feature-row img { width: 56px; height: 56px; object-fit: cover; }
.feature-meta { flex: 1; min-width: 0; }
.feature-title { font-size: 0.88rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feature-sub { font-family: var(--font-mono); font-size: 0.62rem; color: var(--dim); letter-spacing: 0.12em; margin-top: 0.15rem; }
.feature-play { color: var(--gold); font-size: 0.9rem; }

/* ---- EDD streams spotlight band ---- */
.streams-band {
  margin-top: 4rem;
  border: 1px solid var(--hair);
  background:
    radial-gradient(ellipse at 50% 0%, rgba(229,32,44,0.16), transparent 60%),
    linear-gradient(var(--smoke), var(--ink));
  padding: 3.5rem 2rem; text-align: center; position: relative; overflow: hidden;
}
.streams-band::before {
  content: ""; position: absolute; inset: 0;
  background-image: repeating-linear-gradient(90deg, var(--hair) 0 1px, transparent 1px 64px);
  opacity: 0.4; pointer-events: none;
}
.streams-inner { position: relative; z-index: 1; }
.streams-kicker {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.28em;
  color: var(--dim); margin-bottom: 0.8rem;
}
.streams-kicker span { color: var(--gold); }
.streams-count .count {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(3.6rem, 13vw, 9rem); line-height: 0.9;
  color: var(--blood);
  text-shadow: 0 0 50px rgba(229,32,44,0.45);
  font-variant-numeric: tabular-nums; letter-spacing: 0.01em;
}
.streams-label {
  font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.22em;
  color: var(--bone); opacity: 0.7; margin-top: 0.6rem;
}
.streams-split {
  display: flex; justify-content: center; gap: 3.5rem; margin-top: 2.2rem; flex-wrap: wrap;
}
.streams-split div { display: flex; flex-direction: column; }
.streams-split .count {
  font-family: var(--font-display); font-weight: 800; font-size: 2.2rem; color: var(--bone);
  font-variant-numeric: tabular-nums;
}
.streams-split em {
  font-family: var(--font-mono); font-style: normal; font-size: 0.62rem;
  letter-spacing: 0.18em; color: var(--dim); text-transform: uppercase; margin-top: 0.3rem;
}

/* ---- platform row ---- */
.platform-row {
  margin-top: 4rem; padding: 1.5rem 0; border-top: 1px solid var(--hair);
  display: flex; align-items: center; gap: 2rem; flex-wrap: wrap;
}
.platform-label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.25em; color: var(--dim); }
.platform-row a {
  font-family: var(--font-display); font-weight: 800; font-size: 1.4rem;
  text-decoration: none; text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--bone); transition: color 0.2s;
}
.platform-row a:hover { color: var(--blood); }

/* ============ VIDEOS ============ */
.section-videos { position: relative; }
.video-featured { margin-bottom: 1.5rem; }
.video-frame {
  position: relative; aspect-ratio: 16/9; background: var(--smoke);
  border: 1px solid var(--hair); overflow: hidden; cursor: pointer;
}
.video-frame img { width: 100%; height: 100%; object-fit: cover; opacity: 0.85; transition: opacity 0.3s, transform 0.5s; }
.video-frame:hover img { opacity: 1; transform: scale(1.03); }
.video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-label {
  position: absolute; left: 0; bottom: 0; right: 0;
  padding: 2rem 1.2rem 1rem;
  background: linear-gradient(transparent, rgba(11,9,8,0.92));
  pointer-events: none;
}
.video-title { font-family: var(--font-display); font-weight: 800; font-size: 1.35rem; text-transform: uppercase; letter-spacing: 0.03em; }
.video-views { font-family: var(--font-mono); font-size: 0.62rem; color: var(--gold); letter-spacing: 0.2em; }
.video-playbtn {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 76px; height: 76px; border-radius: 50%;
  background: rgba(229,32,44,0.92); display: grid; place-items: center;
  color: var(--bone); font-size: 1.5rem; padding-left: 5px;
  box-shadow: 0 0 40px rgba(229,32,44,0.55);
  transition: transform 0.25s; pointer-events: none;
}
.video-frame:hover .video-playbtn { transform: translate(-50%,-50%) scale(1.12); }
.video-featured .video-title { font-size: 2.2rem; }

.video-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}

/* ============ LABEL ============ */
.section-label {
  border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair);
  background:
    radial-gradient(ellipse at 20% 50%, rgba(201,162,39,0.07), transparent 60%),
    var(--smoke);
  max-width: none;
}
.label-inner { max-width: 820px; margin: 0 auto; text-align: center; }
.label-kicker { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.4em; color: var(--blood); margin-bottom: 1rem; }
.label-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2.6rem, 6vw, 4.6rem); text-transform: uppercase;
  line-height: 0.9; margin-bottom: 1.6rem;
}
.label-copy { color: var(--dim); max-width: 620px; margin: 0 auto 2.8rem; }
.label-copy strong { color: var(--bone); }
.label-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--hair); border: 1px solid var(--hair);
  margin-bottom: 2.8rem;
}
.stat { background: var(--ink); padding: 1.6rem 1rem; }
.stat-num {
  display: block; font-family: var(--font-display); font-weight: 900;
  font-size: 2.6rem; color: var(--gold); line-height: 1;
}
.stat-label { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.2em; color: var(--dim); text-transform: uppercase; }

/* ============ FOOTER ============ */
.footer {
  padding: 3.5rem 2rem 8rem; text-align: center;
}
.footer-brand {
  font-family: var(--font-display); font-weight: 900; font-size: 3rem;
  color: var(--bone); line-height: 1;
}
.footer-brand span { color: var(--blood); }
.footer-links { display: flex; justify-content: center; gap: 2rem; margin: 1.4rem 0; flex-wrap: wrap; }
.footer-links a {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em;
  text-transform: uppercase; text-decoration: none; color: var(--dim);
  transition: color 0.2s;
}
.footer-links a:hover { color: var(--gold); }
.footer-fine { font-family: var(--font-mono); font-size: 0.62rem; color: var(--dim); opacity: 0.6; letter-spacing: 0.08em; }

/* ============ STICKY PLAYER ============ */
.player[hidden] { display: none; }
.player {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 200;
  display: flex; align-items: center; gap: 1rem;
  background: rgba(22,18,16,0.97); backdrop-filter: blur(12px);
  border-top: 2px solid var(--blood);
  padding: 0.7rem 1.2rem;
  padding-bottom: max(0.7rem, env(safe-area-inset-bottom));
  padding-left: max(1.2rem, env(safe-area-inset-left));
  padding-right: max(1.2rem, env(safe-area-inset-right));
  animation: playerUp 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes playerUp { from { transform: translateY(100%); } }
.player-art { width: 48px; height: 48px; object-fit: cover; border: 1px solid var(--hair); }
.player-meta { display: flex; flex-direction: column; min-width: 0; width: 200px; }
.player-title { font-weight: 700; font-size: 0.85rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.player-album { font-family: var(--font-mono); font-size: 0.6rem; color: var(--dim); letter-spacing: 0.1em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.player-controls { display: flex; gap: 0.4rem; }
.player-controls button {
  background: none; border: 1px solid var(--hair); color: var(--bone);
  width: 38px; height: 38px; cursor: pointer; font-size: 0.85rem;
  transition: all 0.2s;
}
.player-controls button:hover { border-color: var(--blood); color: var(--blood); }
#player-toggle { background: var(--blood); border-color: var(--blood); }
#player-toggle:hover { color: var(--bone); filter: brightness(1.15); }
.player-progress {
  flex: 1; height: 4px; background: var(--coal); cursor: pointer; position: relative;
}
.player-bar { height: 100%; width: 0%; background: linear-gradient(90deg, var(--blood), var(--gold)); }
.player-note { font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.2em; color: var(--dim); }
.player-close {
  background: none; border: none; color: var(--dim); cursor: pointer;
  font-size: 0.9rem; padding: 0.4rem;
}
.player-close:hover { color: var(--bone); }

/* ============ RESPONSIVE ============ */
@media (max-width: 860px) {
  .nav-links a:not(.nav-cta) { display: none; }
  .hero-covers { display: none; }
  .album-block { grid-template-columns: 1fr; }
  .section-note { text-align: left; }
  .label-stats { grid-template-columns: repeat(2, 1fr); }
  .player-note { display: none; }
}

/* ---- phones (Instagram bio traffic) ---- */
@media (max-width: 600px) {
  body { font-size: 15px; }
  .nav { padding: 0.8rem 1.1rem; }
  .brand-mark { font-size: 1.5rem; }
  .brand-sub { font-size: 0.5rem; letter-spacing: 0.2em; }
  .nav-cta { padding: 0.6rem 0.9rem; font-size: 0.68rem; } /* ~44px tap height */

  .hero { padding: 6rem 1.3rem 3rem; min-height: 92svh; }
  .hero-actions { gap: 0.7rem; }
  .btn { padding: 1rem 1.4rem; font-size: 0.74rem; flex: 1 1 auto; text-align: center; min-height: 48px; display: inline-flex; align-items: center; justify-content: center; }

  .marquee-track { font-size: 1.1rem; }

  .section { padding: 4rem 1.3rem; }
  .section-head { margin-bottom: 2.2rem; }
  .subhead { font-size: 1.3rem; margin: 2.5rem 0 1.2rem; }

  /* EDD spotlight */
  .edd-spotlight { padding: 0 1.3rem; margin-top: 3rem; }
  .edd-frame .video-playbtn { width: 68px; height: 68px; font-size: 1.4rem; }
  .edd-frame .video-title { font-size: 1.1rem; }
  .edd-actions .btn { flex: 1 1 100%; }

  /* singles: 2-up grid reads better than tiny 1-up */
  .singles-grid { grid-template-columns: repeat(2, 1fr); gap: 0.9rem; }
  .single-info { padding: 0.8rem 0.8rem 1rem; }
  .single-title { font-size: 0.85rem; }

  /* albums */
  .album-block { padding: 1.3rem; gap: 1.5rem; }
  .album-cover-wrap img { box-shadow: 8px 8px 0 var(--coal); }
  .album-meta h4 { font-size: 1.7rem; }
  .track { padding: 0.7rem 0.4rem; } /* taller tap target */
  .track-name { font-size: 0.86rem; }

  /* features single column */
  .features-list { grid-template-columns: 1fr; }
  .feature-row { padding: 0.7rem; }

  /* streams band */
  .streams-band { padding: 2.5rem 1.3rem; }
  .streams-split { gap: 2rem; }

  .platform-row { gap: 1.2rem; }
  .platform-row a { font-size: 1.15rem; }

  .video-grid { grid-template-columns: 1fr; gap: 1.1rem; }
  .video-featured .video-title { font-size: 1.4rem; }

  .section-label { padding: 4rem 1.3rem; }
  .label-copy { font-size: 0.95rem; }
  .stat { padding: 1.2rem 0.6rem; }
  .stat-num { font-size: 2rem; }

  /* sticky player: compact, thumb-friendly, full-width controls */
  .player { gap: 0.6rem; padding: 0.6rem 0.9rem; padding-bottom: max(0.6rem, env(safe-area-inset-bottom)); }
  .player-art { width: 42px; height: 42px; }
  .player-meta { flex: 1; width: auto; min-width: 0; }
  .player-controls button { width: 44px; height: 44px; } /* min 44px touch */
  .player-progress { display: none; } /* reclaim space on tiny screens */
  .player-close { padding: 0.5rem; }

  .footer { padding-bottom: calc(7rem + env(safe-area-inset-bottom)); }
}

/* honor reduced-motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}
