/* =========================================================
   SOUND SCAPES COFFEE ROASTERS
   Edgy / music / desert parallax
   ========================================================= */

:root{
  --bg:        #0b0a0f;   /* desert night */
  --bg-2:      #121019;
  --ink:       #ece7da;   /* bone / kraft */
  --ink-dim:   #9a93a6;
  --ember:     #ff6b35;   /* neon ember accent */
  --magenta:   #e85d9a;   /* dusk */
  --violet:    #7a5cff;   /* deep desert sky */
  --amber:     #f0a23c;
  --line:      rgba(236,231,218,.14);
  --card:      rgba(255,255,255,.035);

  --font-display: 'Orbitron', sans-serif;
  --font-body:    'Space Grotesk', system-ui, sans-serif;
  --font-mono:    'Space Mono', monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
  --maxw: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:default;
}

a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
::selection{ background:var(--ember); color:#fff; }

/* ---------- Grain overlay ---------- */
.grain{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:9000; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
}

/* ---------- Custom cursor glow ---------- */
.cursor-glow{
  position:fixed; top:0; left:0; width:380px; height:380px;
  border-radius:50%; pointer-events:none; z-index:8000;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,107,53,.10), transparent 60%);
  transition:opacity .3s; opacity:0;
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(20px,4vw,48px);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(11,10,15,.78);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  padding-top:12px; padding-bottom:12px;
}
.nav__brand{ display:flex; align-items:center; gap:12px; line-height:1; }
.nav__brand-mark{
  font-family:var(--font-display); font-weight:900;
  font-size:15px; letter-spacing:.04em; line-height:.92;
}
.nav__brand-sub{
  font-family:var(--font-mono); font-size:9.5px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--ink-dim); align-self:flex-end; padding-bottom:1px;
}
.nav__links{ display:flex; align-items:center; gap:clamp(14px,2vw,30px); }
.nav__links a{
  font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-dim); transition:color .25s; position:relative;
}
.nav__links a:not(.nav__cta)::after{
  content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0;
  background:var(--ember); transition:width .3s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }
.nav__cta{
  border:1px solid var(--line); border-radius:40px; padding:9px 18px;
  color:var(--ink) !important; transition:all .3s var(--ease);
}
.nav__cta:hover{ background:var(--ember); border-color:var(--ember); color:#fff !important; box-shadow:0 0 24px rgba(255,107,53,.5); }

.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__toggle span{ width:26px; height:2px; background:var(--ink); transition:.3s var(--ease); }
.nav__toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__toggle.open span:nth-child(2){ opacity:0; }
.nav__toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; height:100vh; height:100svh; min-height:640px;
  overflow:hidden; display:flex; align-items:center; justify-content:center;
}
.layer{ position:absolute; inset:0; width:100%; will-change:transform; }

.layer--photo{
  height:120%; background-size:cover; background-position:center 30%;
}
.layer--sky{
  background:
    radial-gradient(100% 70% at 18% 14%, rgba(255,107,53,.18), transparent 46%),
    radial-gradient(90% 80% at 92% 88%, rgba(232,93,154,.20), transparent 52%),
    linear-gradient(180deg, rgba(7,6,12,.78) 0%, rgba(11,10,15,.45) 42%, rgba(11,10,15,.55) 78%, rgba(7,6,12,.92) 100%);
  height:120%;
}
.sun{ display:none; } /* desert sun removed for the music pivot */
.stars{ position:absolute; inset:0; }
.star{
  position:absolute; width:2px; height:2px; border-radius:50%;
  background:#fff; opacity:.7; animation:twinkle var(--tw,3s) ease-in-out infinite;
}
@keyframes twinkle{ 0%,100%{opacity:.1;} 50%{opacity:.65;} }

/* fixed bg images turn into scroll-jank on mobile — make them scroll */
@media (max-width:900px){ .subscribe, .studio{ background-attachment:scroll, scroll; } }

/* foreground equalizer skyline (replaces the desert Joshua trees) */
.hero__eq{
  position:absolute; left:0; right:0; bottom:0; z-index:4; height:30%;
  display:flex; align-items:flex-end; justify-content:center; gap:1.2%;
  padding:0 4%; pointer-events:none;
  mask-image:linear-gradient(180deg, transparent, #000 38%);
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 38%);
}
.hero__eq span{
  flex:1; max-width:26px; border-radius:6px 6px 0 0;
  background:linear-gradient(180deg, var(--ember), rgba(232,93,154,.55) 70%, transparent);
  height:18%; transform-origin:bottom;
  animation:eqbar 1.4s ease-in-out infinite;
}
@keyframes eqbar{ 0%,100%{ transform:scaleY(.22); } 50%{ transform:scaleY(1); } }

/* hero copy */
.hero__copy{
  position:relative; z-index:5; text-align:center;
  padding:0 20px; transform:translateY(0);
}
.hero__eyebrow{
  font-family:var(--font-mono); font-size:clamp(10px,1.4vw,12.5px);
  letter-spacing:.42em; text-transform:uppercase; color:var(--amber);
  margin-bottom:22px; text-shadow:0 2px 20px rgba(0,0,0,.6);
}
.hero__wordmark{
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(54px,15vw,200px); line-height:.82; letter-spacing:-.01em;
  position:relative; text-shadow:0 6px 40px rgba(0,0,0,.55);
}
.hero__wordmark span{ display:block; }
.hero__wordmark span:nth-child(2){ color:var(--ink); }
/* RGB glitch echo */
.hero__wordmark::before,
.hero__wordmark::after{
  content:attr(data-text); position:absolute; inset:0; white-space:pre-line;
  pointer-events:none; opacity:.55; mix-blend-mode:screen;
}
.hero__wordmark::before{ color:var(--magenta); animation:glitch 6s steps(2,end) infinite; }
.hero__wordmark::after{ color:var(--violet); animation:glitch 6s steps(2,end) .15s infinite reverse; }
@keyframes glitch{
  0%,92%,100%{ transform:translate(0,0); opacity:0; }
  93%{ transform:translate(-3px,1px); opacity:.5; }
  95%{ transform:translate(3px,-1px); opacity:.5; }
  97%{ transform:translate(-2px,-1px); opacity:.4; }
}
.hero__sub{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(13px,2.4vw,22px); letter-spacing:.55em;
  text-transform:uppercase; margin:14px 0 0; padding-left:.55em;
  color:var(--ink);
}

/* soundwave */
.soundwave{ display:flex; align-items:center; justify-content:center; gap:4px; height:42px; margin:26px 0 22px; }
.soundwave span{
  width:4px; border-radius:3px; background:linear-gradient(var(--ember),var(--magenta));
  animation:wave 1.1s ease-in-out infinite; height:14px;
}
.soundwave span:nth-child(odd){ animation-duration:.9s; }
.soundwave span:nth-child(3n){ animation-duration:1.4s; }
.soundwave span:nth-child(3n+1){ animation-delay:.2s; }
.soundwave span:nth-child(5n){ animation-delay:.45s; }
@keyframes wave{ 0%,100%{ transform:scaleY(.3); } 50%{ transform:scaleY(1.6); } }

.hero__tagline{
  max-width:560px; margin:0 auto; color:rgba(236,231,218,.85);
  font-size:clamp(14px,1.7vw,17px); text-shadow:0 2px 18px rgba(0,0,0,.6);
}
.hero__actions{ display:flex; gap:14px; justify-content:center; margin-top:30px; flex-wrap:wrap; }

/* buttons */
.btn{
  font-family:var(--font-body); font-weight:700; font-size:14px;
  letter-spacing:.04em; padding:14px 28px; border-radius:50px;
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  transition:all .3s var(--ease); border:1px solid transparent;
}
.btn--primary{ background:var(--ember); color:#1a0a04; box-shadow:0 8px 30px rgba(255,107,53,.35); }
.btn--primary:hover{ transform:translateY(-3px); box-shadow:0 14px 44px rgba(255,107,53,.55); background:#ff7d4d; }
.btn--ghost{ border-color:var(--line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-3px); }

/* scroll cue */
.hero__scroll{
  position:absolute; bottom:96px; left:50%; transform:translateX(-50%);
  z-index:6; display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.3em;
  text-transform:uppercase; color:var(--ink-dim);
}
.hero__scroll-line{ width:1px; height:42px; background:linear-gradient(var(--ember),transparent); animation:scrollpulse 2s ease-in-out infinite; }
@keyframes scrollpulse{ 0%,100%{transform:scaleY(.4);opacity:.4;} 50%{transform:scaleY(1);opacity:1;} }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{
  position:relative; z-index:10; overflow:hidden; white-space:nowrap;
  background:var(--ember); color:#150803;
  border-top:2px solid #000; border-bottom:2px solid #000;
  padding:14px 0;
}
.marquee__track{ display:inline-flex; animation:marquee 26s linear infinite; }
.marquee__track span{
  font-family:var(--font-display); font-weight:700; font-size:15px;
  letter-spacing:.06em; text-transform:uppercase; padding-right:30px;
}
@keyframes marquee{ from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* =========================================================
   THE DROP / NOW PLAYING
   ========================================================= */
.drop{
  position:relative; background:
    radial-gradient(120% 70% at 80% 0%, rgba(122,92,255,.10), transparent 55%),
    radial-gradient(100% 60% at 0% 100%, rgba(232,93,154,.10), transparent 55%),
    var(--bg);
  padding:clamp(80px,12vw,150px) clamp(20px,5vw,60px);
}
.drop__inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,90px); align-items:center;
}

/* vinyl + bag art */
.drop__art{ position:relative; display:flex; align-items:center; justify-content:center; min-height:420px; }
.vinyl{
  position:absolute; left:-6%; width:78%; aspect-ratio:1; z-index:1;
  animation:spin 8s linear infinite;
}
.vinyl.paused{ animation-play-state:paused; }
.vinyl__disc{
  width:100%; height:100%; border-radius:50%;
  background:
    repeating-radial-gradient(circle at 50% 50%, #0c0c0e 0 2px, #161618 2px 4px);
  box-shadow:0 30px 70px rgba(0,0,0,.6), inset 0 0 0 2px rgba(255,255,255,.04);
  position:relative; display:flex; align-items:center; justify-content:center;
}
.vinyl__grooves{ position:absolute; inset:8%; border-radius:50%; box-shadow:inset 0 0 60px rgba(0,0,0,.8); }
.vinyl__label{
  width:42%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle,var(--ember),#c8401a);
  display:flex; align-items:center; justify-content:center; text-align:center;
  box-shadow:0 0 0 6px #0c0c0e;
}
.vinyl__label span{ font-family:var(--font-display); font-weight:900; font-size:clamp(10px,1.5vw,15px); line-height:.95; color:#1a0a04; }
.vinyl__hole{ position:absolute; width:3.5%; aspect-ratio:1; border-radius:50%; background:var(--bg); box-shadow:inset 0 0 4px #000; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* kraft bag (recreation of the hand-stamped bag) */
.bag{
  position:relative; z-index:2; width:62%; aspect-ratio:.72; margin-left:40%;
  background:#c4b596 url('assets/bag.jpg') center/cover no-repeat;
  border-radius:6px;
  box-shadow:0 30px 60px rgba(0,0,0,.55);
  display:flex; align-items:flex-end; justify-content:center;
  padding:0 0 9%; transform:rotate(2deg); transition:transform .5s var(--ease);
}
/* real photo supplied — hide the CSS-drawn fallback stamp/crimp */
.bag::before, .bag__seam, .bag__stamp{ display:none; }
.drop__art:hover .bag{ transform:rotate(0deg) translateY(-6px); }
.bag::before{ /* top crimp */
  content:""; position:absolute; top:0; left:8%; right:8%; height:5%;
  background:repeating-linear-gradient(90deg,#a89878 0 5px,#c2b390 5px 10px);
  border-radius:3px;
}
.bag__seam{ position:absolute; top:6%; left:50%; width:1px; height:90%; background:rgba(0,0,0,.06); }
.bag__stamp{
  width:84%; background:#14110d; color:#d9cfb8; text-align:center;
  padding:10px 6px 12px; border-radius:2px; transform:rotate(-1deg);
  box-shadow:0 0 0 3px #14110d, 4px 4px 0 rgba(0,0,0,.25);
}
.bag__stamp-1,.bag__stamp-2{ display:block; font-family:var(--font-display); font-weight:900; line-height:.9; }
.bag__stamp-1{ font-size:clamp(16px,3.2vw,30px); }
.bag__stamp-2{ font-size:clamp(16px,3.2vw,30px); }
.bag__stamp-3{ display:block; font-family:var(--font-mono); font-size:clamp(8px,1.3vw,11px); letter-spacing:.14em; margin-top:4px; text-transform:uppercase; }

/* drop info */
.badge{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ember); margin-bottom:18px;
}
.badge::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--ember); box-shadow:0 0 0 0 rgba(255,107,53,.6); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(255,107,53,.6);} 70%{box-shadow:0 0 0 10px rgba(255,107,53,0);} 100%{box-shadow:0 0 0 0 rgba(255,107,53,0);} }

.drop__title{
  font-family:var(--font-display); font-weight:900; line-height:.92;
  font-size:clamp(38px,6vw,76px); margin-bottom:18px;
}
.drop__title span{ display:block; color:var(--ember); font-size:.5em; letter-spacing:.05em; margin-top:6px; }
.drop__desc{ color:var(--ink-dim); max-width:46ch; margin-bottom:30px; }

/* tracklist */
.tracklist{ list-style:none; border-top:1px solid var(--line); margin-bottom:28px; }
.track{
  display:grid; grid-template-columns:auto 1fr auto; align-items:center;
  gap:6px 16px; padding:16px 4px; border-bottom:1px solid var(--line);
  transition:background .3s, padding .3s;
}
.track:hover{ background:var(--card); padding-left:14px; }
.track__side{ font-family:var(--font-mono); color:var(--ember); font-size:14px; }
.track__name{ font-family:var(--font-display); font-weight:700; font-size:clamp(16px,2.2vw,21px); }
.track__pct{ font-family:var(--font-mono); font-size:15px; color:var(--ink); }
.track__notes{ grid-column:2; font-size:13px; color:var(--ink-dim); letter-spacing:.01em; }

.drop__meta{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:14px 24px; margin-bottom:32px; }
.drop__meta li{ font-size:15px; }
.drop__meta span{ display:block; font-family:var(--font-mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:3px; }

/* starter pack "what's in the pressing" */
.drop__starter-label{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:14px; }
.drop__includes{ list-style:none; display:grid; gap:11px; margin-bottom:28px; }
.drop__includes li{ position:relative; padding-left:30px; font-size:15px; color:var(--ink); }
.drop__includes li span{ color:var(--ink-dim); }
.drop__includes li strong{ color:var(--ember); font-weight:700; }
.drop__includes li::before{ content:"♪"; position:absolute; left:0; top:-1px; color:var(--ember); font-size:15px; }
.drop__actions{ display:flex; gap:14px; flex-wrap:wrap; }
.drop__ship-note{ margin-top:16px; font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--ink-dim); }

/* =========================================================
   HEAVY ROTATION CLUB / CONTINUITY
   ========================================================= */
.club{ position:relative; padding:clamp(80px,12vw,150px) clamp(20px,5vw,60px); overflow:hidden;
  background:
    radial-gradient(90% 90% at 12% 8%, rgba(255,107,53,.12), transparent 55%),
    radial-gradient(90% 90% at 92% 92%, rgba(122,92,255,.14), transparent 55%),
    var(--bg-2); }
.club__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(40px,6vw,80px); align-items:center; }
.club__copy .section-head__kick,.club__copy .section-head__title{ text-align:left; }
.club__lead{ color:var(--ink-dim); margin:18px 0 26px; max-width:46ch; }
.club__perks{ list-style:none; display:grid; gap:14px; margin-bottom:32px; }
.club__perks li{ display:flex; align-items:flex-start; gap:14px; font-size:15.5px; color:var(--ink); }
.club__perks li span{ flex:none; width:30px; height:30px; border-radius:50%; display:grid; place-items:center; background:rgba(255,107,53,.12); color:var(--ember); font-size:14px; }
.club__actions{ display:flex; gap:14px; flex-wrap:wrap; }
.club__note{ margin-top:16px; font-family:var(--font-mono); font-size:12px; color:var(--ink-dim); }

/* membership card */
.club__card{ position:relative; background:linear-gradient(155deg,#15121d,#0d0b13); border:1px solid var(--line); border-radius:20px; padding:26px; box-shadow:0 30px 70px rgba(0,0,0,.5); overflow:hidden; }
.club__card::before{ content:""; position:absolute; inset:0; background:radial-gradient(70% 50% at 80% 0%, rgba(255,107,53,.16), transparent 60%); pointer-events:none; }
.club__card-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.club__card-kick{ font-family:var(--font-mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--ember); }
.club__card-eq{ display:flex; align-items:flex-end; gap:3px; height:22px; }
.club__card-eq i{ width:4px; border-radius:3px; background:linear-gradient(var(--ember),var(--magenta)); height:30%; animation:wave 1s ease-in-out infinite; }
.club__card-eq i:nth-child(2){ animation-delay:.1s; } .club__card-eq i:nth-child(3){ animation-delay:.25s; } .club__card-eq i:nth-child(4){ animation-delay:.15s; }
.club__card-eq i:nth-child(5){ animation-delay:.3s; } .club__card-eq i:nth-child(6){ animation-delay:.05s; } .club__card-eq i:nth-child(7){ animation-delay:.2s; }
.club__card-disc{ width:64%; aspect-ratio:1; margin:0 auto 22px; border-radius:50%;
  background:repeating-radial-gradient(circle at 50% 50%, #0c0c0e 0 2px, #18181c 2px 4px);
  display:grid; place-items:center; box-shadow:0 12px 30px rgba(0,0,0,.5); animation:spin 9s linear infinite; }
.club__card-vinyl{ width:36%; aspect-ratio:1; border-radius:50%; background:radial-gradient(circle,var(--ember),#c8401a); box-shadow:0 0 0 5px #0c0c0e; }
.club__card-name{ font-family:var(--font-display); font-weight:700; font-size:20px; text-align:center; }
.club__card-sub{ font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; color:var(--ink-dim); text-align:center; margin:4px 0 18px; }
.club__card-row{ display:flex; gap:12px; align-items:center; font-size:14px; padding:9px 0; border-top:1px solid var(--line); color:var(--ink); }
.club__card-row span{ font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ember); width:54px; flex:none; }

/* =========================================================
   DISCOGRAPHY
   ========================================================= */
.section-head{ max-width:var(--maxw); margin:0 auto clamp(40px,6vw,70px); text-align:center; }
.section-head__kick{ font-family:var(--font-mono); font-size:12px; letter-spacing:.32em; text-transform:uppercase; color:var(--ember); margin-bottom:14px; }
.section-head__title{ font-family:var(--font-display); font-weight:900; font-size:clamp(32px,5.5vw,64px); line-height:.98; }
.section-head__lead{ color:var(--ink-dim); max-width:50ch; margin:18px auto 0; }

.disco{ padding:clamp(80px,11vw,140px) clamp(20px,5vw,60px); background:var(--bg-2); }
.disco__grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.release{ background:var(--card); border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:transform .4s var(--ease), border-color .4s, box-shadow .4s; }
.release:hover{ transform:translateY(-8px); border-color:rgba(255,107,53,.45); box-shadow:0 24px 50px rgba(0,0,0,.4); }
.release--feature{ grid-row:span 1; }
.release__sleeve{
  aspect-ratio:1; position:relative; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(140deg,#2a1840,#5a2747 55%,#b5453f) center/cover;
  background-image:linear-gradient(160deg,rgba(20,10,30,.25),rgba(20,10,30,.55)),url('assets/art-warm.jpg');
  background-size:cover; background-position:center; overflow:hidden;
}
.release__sleeve--soon{ background-image:linear-gradient(160deg,rgba(16,18,30,.35),rgba(16,18,30,.62)),url('assets/art-soon.jpg'); }
.release__sleeve--b{ background-image:linear-gradient(160deg,rgba(20,10,30,.28),rgba(20,10,30,.58)),url('assets/art-bright.jpg'); }
.release__sleeve--c{ background-image:linear-gradient(160deg,rgba(10,10,18,.4),rgba(10,10,18,.62)),url('assets/art-dark.jpg'); }
.release__vol{ font-family:var(--font-display); font-weight:900; font-size:clamp(26px,4.4vw,44px); color:#fff; letter-spacing:.02em; text-shadow:0 2px 18px rgba(0,0,0,.75), 0 1px 3px rgba(0,0,0,.9); z-index:2; }
.release__sleeve--soon .release__vol{ opacity:.55; }
.release__wave{ position:absolute; inset:auto 0 0 0; height:46%; display:flex; align-items:flex-end; justify-content:center; gap:5px; padding-bottom:14px; }
.release__wave span{ width:7px; background:rgba(255,255,255,.5); border-radius:4px; animation:wave 1.2s ease-in-out infinite; height:30%; }
.release__wave span:nth-child(2){ animation-delay:.15s; } .release__wave span:nth-child(3){ animation-delay:.3s; }
.release__wave span:nth-child(4){ animation-delay:.45s; } .release__wave span:nth-child(5){ animation-delay:.2s; } .release__wave span:nth-child(6){ animation-delay:.35s; }
.release__meta{ padding:18px 18px 22px; }
.release__tag{ display:inline-block; font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; padding:4px 10px; border-radius:30px; border:1px solid var(--line); color:var(--ink-dim); margin-bottom:12px; }
.tag--live{ color:#1a0a04; background:var(--ember); border-color:var(--ember); }
.tag--soon{ color:var(--violet); border-color:rgba(122,92,255,.5); }
.release__meta h3{ font-family:var(--font-display); font-weight:700; font-size:18px; margin-bottom:6px; }
.release__meta p{ font-size:13.5px; color:var(--ink-dim); }
.disco__note{ max-width:var(--maxw); margin:26px auto 0; font-family:var(--font-mono); font-size:11px; color:var(--ink-dim); text-align:center; opacity:.6; }

/* =========================================================
   THE STUDIO
   ========================================================= */
.studio{ position:relative; padding:clamp(80px,12vw,150px) clamp(20px,5vw,60px); overflow:hidden;
  background:linear-gradient(rgba(11,10,15,.88),rgba(11,10,15,.93)),url('assets/studio-music.jpg') center/cover fixed, var(--bg); }
.studio__inner{ position:relative; max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,80px); align-items:center; }
.studio__copy p{ color:var(--ink-dim); margin-top:20px; max-width:48ch; }
.studio__copy p strong{ color:var(--ink); }
.studio__copy .section-head__title{ text-align:left; margin-bottom:8px; }
.studio__copy .section-head__kick{ text-align:left; }
.studio__stats{ display:flex; gap:clamp(20px,4vw,48px); margin-top:38px; }
.studio__stats div{ display:flex; flex-direction:column; }
.studio__stats strong{ font-family:var(--font-display); font-weight:900; font-size:clamp(26px,4vw,42px); color:var(--ember); line-height:1; }
.studio__stats span{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-dim); margin-top:8px; }

/* roast card */
.roast-card{ background:#0e0d14; border:1px solid var(--line); border-radius:16px; padding:20px; box-shadow:0 30px 60px rgba(0,0,0,.45); }
.roast-card__head{ display:flex; justify-content:space-between; align-items:center; font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; color:var(--ink-dim); margin-bottom:16px; }
.roast-card__head span:first-child{ color:var(--ember); }
.roast-card__graph{ width:100%; height:180px; }
.roast-card__grid line{ stroke:rgba(236,231,218,.07); stroke-width:1; }
.roast-card__bean{ fill:none; stroke:var(--ember); stroke-width:3; stroke-linecap:round; filter:drop-shadow(0 0 6px rgba(255,107,53,.5)); stroke-dasharray:600; stroke-dashoffset:600; }
.roast-card__ror{ fill:none; stroke:var(--violet); stroke-width:2; stroke-dasharray:4 5; opacity:.7; }
.roast-card.in-view .roast-card__bean{ animation:draw 2.4s var(--ease) forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
.roast-card__legend{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:14px; font-family:var(--font-mono); font-size:11px; color:var(--ink-dim); }
.dot{ display:inline-block; width:9px; height:9px; border-radius:50%; margin-right:-8px; vertical-align:middle; }
.dot--bean{ background:var(--ember); } .dot--ror{ background:var(--violet); }
.roast-card__time{ margin-left:auto; color:var(--ink); }

/* =========================================================
   CONCEPT / MOODS
   ========================================================= */
/* =========================================================
   THE ROASTER / FOUNDER
   ========================================================= */
.roaster{ padding:clamp(80px,12vw,150px) clamp(20px,5vw,60px); background:var(--bg); overflow:hidden; }
.roaster__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:center; }
.roaster__media{ display:flex; flex-direction:column; gap:14px; }
.roaster__photo{ position:relative; overflow:hidden; border-radius:14px; border:1px solid var(--line); box-shadow:0 24px 50px rgba(0,0,0,.4); }
.roaster__photo img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s var(--ease); }
.roaster__photo:hover img{ transform:scale(1.05); }
.roaster__photo--main{ aspect-ratio:4/3; }
.roaster__thumbs{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.roaster__thumbs .roaster__photo{ aspect-ratio:1; }
.roaster__tag{ position:absolute; top:14px; left:14px; font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#1a0a04; background:var(--ember); padding:5px 12px; border-radius:30px; z-index:3; box-shadow:0 4px 16px rgba(255,107,53,.4); }
.roaster__copy .section-head__kick,.roaster__copy .section-head__title{ text-align:left; }
.roaster__copy p{ color:var(--ink-dim); margin-top:20px; max-width:46ch; }
.roaster__copy em{ color:var(--ink); font-style:italic; }
.roaster__quote{ margin-top:30px; padding-left:20px; border-left:3px solid var(--ember); font-family:var(--font-display); font-weight:500; font-size:clamp(16px,2.1vw,21px); line-height:1.45; color:var(--ink); }

/* =========================================================
   FIELD RECORDINGS / GALLERY
   ========================================================= */
.gallery{ padding:clamp(80px,11vw,140px) clamp(20px,5vw,60px); background:var(--bg); }
.gallery__grid{ max-width:var(--maxw); margin:0 auto; column-count:3; column-gap:16px; }
.gallery__item{ break-inside:avoid; margin:0 0 16px; overflow:hidden; border-radius:12px; border:1px solid var(--line); position:relative; }
.gallery__item img{ width:100%; display:block; transition:transform .6s var(--ease); }
.gallery__item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(11,10,15,.35)); opacity:0; transition:opacity .4s; }
.gallery__item:hover img{ transform:scale(1.06); }
.gallery__item:hover::after{ opacity:1; }

/* =========================================================
   CONCEPT / MOODS
   ========================================================= */
.concept{ padding:clamp(80px,11vw,140px) clamp(20px,5vw,60px); background:var(--bg-2); }
.moods{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.mood{
  text-align:left; background:var(--card); border:1px solid var(--line); border-radius:16px;
  padding:30px 26px 34px; cursor:pointer; font-family:var(--font-body); color:var(--ink);
  transition:transform .4s var(--ease), border-color .4s, background .4s;
}
.mood:hover{ transform:translateY(-6px); border-color:rgba(255,107,53,.4); background:rgba(255,107,53,.05); }
.mood__eq{ display:flex; align-items:flex-end; gap:5px; height:50px; margin-bottom:22px; }
.mood__eq i{ width:7px; border-radius:4px; background:linear-gradient(var(--ember),var(--magenta)); height:20%; transition:height .2s; }
.mood:hover .mood__eq i,.mood.active .mood__eq i{ animation:wave 1s ease-in-out infinite; }
.mood__eq i:nth-child(2){ animation-delay:.1s!important; } .mood__eq i:nth-child(3){ animation-delay:.25s!important; }
.mood__eq i:nth-child(4){ animation-delay:.15s!important; } .mood__eq i:nth-child(5){ animation-delay:.3s!important; }
.mood[data-mood="bright"] .mood__eq i{ background:linear-gradient(var(--amber),var(--ember)); }
.mood[data-mood="dark"] .mood__eq i{ background:linear-gradient(var(--violet),#3a2e5c); }
.mood__name{ display:block; font-family:var(--font-display); font-weight:700; font-size:21px; margin-bottom:8px; }
.mood__desc{ display:block; color:var(--ink-dim); font-size:14.5px; }

/* =========================================================
   TOUR
   ========================================================= */
.tour{ padding:clamp(80px,11vw,140px) clamp(20px,5vw,60px); background:var(--bg); }
.tour__list{ max-width:var(--maxw); margin:0 auto; list-style:none; border-top:1px solid var(--line); }
.tour__row{
  display:grid; grid-template-columns:160px 1fr auto auto; align-items:center; gap:20px;
  padding:26px 8px; border-bottom:1px solid var(--line); transition:background .3s, padding .3s;
}
.tour__row:hover{ background:var(--card); padding-left:20px; }
.tour__when{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; color:var(--ember); }
.tour__where{ font-family:var(--font-display); font-weight:700; font-size:clamp(17px,2.4vw,24px); }
.tour__what{ color:var(--ink-dim); font-size:14px; }
.tour__cta{ font-family:var(--font-mono); font-size:12px; padding:8px 16px; border:1px solid var(--line); border-radius:30px; color:var(--ink-dim); }
.tour__row:hover .tour__cta{ border-color:var(--ember); color:var(--ember); }

/* =========================================================
   SUBSCRIBE
   ========================================================= */
.subscribe{
  position:relative; padding:clamp(90px,13vw,170px) clamp(20px,5vw,60px); text-align:center;
  background:
    linear-gradient(rgba(11,10,15,.82),rgba(11,10,15,.9)),
    url('assets/cta-music.jpg') center/cover fixed,
    var(--bg-2);
}
.subscribe__inner{ max-width:680px; margin:0 auto; }
.subscribe__title{ font-family:var(--font-display); font-weight:900; font-size:clamp(34px,6vw,68px); line-height:.95; margin:14px 0 18px; }
.subscribe__lead{ color:var(--ink-dim); max-width:46ch; margin:0 auto 36px; }
.subscribe__form{ display:flex; gap:12px; max-width:480px; margin:0 auto; flex-wrap:wrap; justify-content:center; }
.subscribe__form input{
  flex:1; min-width:240px; background:rgba(255,255,255,.05); border:1px solid var(--line);
  border-radius:50px; padding:15px 24px; color:var(--ink); font-family:var(--font-body); font-size:15px;
  transition:border-color .3s, box-shadow .3s;
}
.subscribe__form input::placeholder{ color:var(--ink-dim); }
.subscribe__form input:focus{ outline:none; border-color:var(--ember); box-shadow:0 0 0 4px rgba(255,107,53,.15); }
.subscribe__msg{ margin-top:18px; min-height:22px; font-family:var(--font-mono); font-size:13px; color:var(--ember); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:#07060c; padding:clamp(50px,7vw,80px) clamp(20px,5vw,60px) 36px; border-top:1px solid var(--line); }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; padding-bottom:36px; border-bottom:1px solid var(--line); }
.footer__mark{ display:block; font-family:var(--font-display); font-weight:900; font-size:clamp(26px,4vw,44px); letter-spacing:.02em; }
.footer__sub{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; color:var(--ink-dim); text-transform:uppercase; }
.footer__links{ display:flex; gap:22px; flex-wrap:wrap; }
.footer__links a{ font-size:14px; color:var(--ink-dim); transition:color .25s; }
.footer__links a:hover{ color:var(--ember); }
.footer__bottom{ max-width:var(--maxw); margin:24px auto 0; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-family:var(--font-mono); font-size:11.5px; color:var(--ink-dim); }

/* =========================================================
   STICKY PLAYER
   ========================================================= */
.player{
  position:fixed; left:50%; bottom:18px; transform:translateX(-50%) translateY(150%);
  z-index:2000; width:min(94vw,760px);
  display:grid; grid-template-columns:auto 1fr auto auto; align-items:center; gap:16px;
  background:rgba(18,16,25,.86); backdrop-filter:blur(18px);
  border:1px solid var(--line); border-radius:60px; padding:10px 16px 10px 10px;
  box-shadow:0 20px 50px rgba(0,0,0,.5); transition:transform .6s var(--ease);
}
.player.show{ transform:translateX(-50%) translateY(0); }
.player__btn{
  width:46px; height:46px; flex:none; border-radius:50%; border:0; cursor:pointer;
  background:var(--ember); color:#1a0a04; display:grid; place-items:center;
  transition:transform .2s, box-shadow .3s; box-shadow:0 0 20px rgba(255,107,53,.5);
}
.player__btn:hover{ transform:scale(1.08); }
.player__btn svg{ width:22px; height:22px; fill:currentColor; }
.player__icon-pause{ display:none; }
.player.playing .player__icon-play{ display:none; }
.player.playing .player__icon-pause{ display:block; }
.player__track{ min-width:0; }
.player__now{ display:block; font-family:var(--font-mono); font-size:9.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--ember); }
.player__title{ display:block; font-size:13.5px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.player__viz{ display:flex; align-items:center; gap:3px; height:26px; }
.player__viz span{ width:3px; height:20%; border-radius:2px; background:var(--ink-dim); transition:background .3s; }
.player.playing .player__viz span{ background:linear-gradient(var(--ember),var(--magenta)); animation:wave 1s ease-in-out infinite; }
.player__viz span:nth-child(odd){ animation-duration:.8s!important; }
.player__viz span:nth-child(3n){ animation-delay:.2s!important; }
.player__viz span:nth-child(3n+1){ animation-delay:.4s!important; }
.player__progress{ display:flex; align-items:center; gap:10px; padding-right:8px; }
.player__time{ font-family:var(--font-mono); font-size:11px; color:var(--ink-dim); }
.player__bar{ width:90px; height:4px; border-radius:4px; background:rgba(255,255,255,.12); overflow:hidden; }
.player__fill{ width:36%; height:100%; background:var(--ember); border-radius:4px; transition:width .3s linear; }

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:24px;
    background:rgba(11,10,15,.97); backdrop-filter:blur(20px); padding:40px;
    transform:translateX(100%); transition:transform .45s var(--ease); border-left:1px solid var(--line);
  }
  .nav__links.open{ transform:translateX(0); }
  .nav__links a{ font-size:18px; }
  .nav__toggle{ display:flex; z-index:1001; }
  .drop__inner{ grid-template-columns:1fr; gap:60px; }
  .drop__art{ min-height:340px; }
  .studio__inner{ grid-template-columns:1fr; }
  .roaster__inner{ grid-template-columns:1fr; }
  .club__inner{ grid-template-columns:1fr; }
  .club__card{ max-width:420px; margin:0 auto; width:100%; }
  .gallery__grid{ column-count:2; }
  .studio__copy .section-head__title{ text-align:left; }
  .disco__grid{ grid-template-columns:repeat(2,1fr); }
  .moods{ grid-template-columns:1fr; }
  .tour__row{ grid-template-columns:1fr auto; gap:6px 14px; }
  .tour__what{ grid-column:1; }
  .player__progress{ display:none; }
  .player{ grid-template-columns:auto 1fr auto; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  /* keep the floating player from hiding the last of the content */
  .footer{ padding-bottom:104px; }
  .gallery__grid{ column-count:1; }
  .roaster__quote{ font-size:17px; }

  /* hero: tighten vertical rhythm so copy + buttons don't collide */
  .hero{ min-height:600px; }
  .hero__eyebrow{ letter-spacing:.24em; margin-bottom:14px; font-size:10px; }
  .hero__sub{ letter-spacing:.45em; }
  .soundwave{ height:30px; margin:16px 0 14px; }
  .hero__tagline{ font-size:13.5px; }
  .hero__actions{ margin-top:22px; gap:10px; }
  .hero__scroll{ display:none; }

  /* the drop: center the vinyl + bag so the disc stops clipping */
  .drop__art{ min-height:300px; }
  .vinyl{ left:4%; width:64%; }
  .bag{ width:54%; margin-left:34%; }

  .disco__grid{ grid-template-columns:1fr; }
  .player{ width:94vw; bottom:12px; }
  .player__viz{ display:none; }
  .footer__top{ flex-direction:column; align-items:flex-start; }

  /* full-width subscribe controls (and 16px to stop iOS focus-zoom) */
  .subscribe__form input{ min-width:100%; font-size:16px; }
  .subscribe__form .btn{ width:100%; justify-content:center; }
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .reveal{ opacity:1; transform:none; }
  .marquee__track{ animation:none; }
  .vinyl{ animation:none; }
}
