/* ============================================================
   NYZA STUDIOS — UNIFIED DESIGN SYSTEM
   Bold music-app energy · gold-anchored · dual theme (dark default)
   ------------------------------------------------------------
   ONE source of truth. Every page links this file and uses these
   classes. No page should ship its own <style> block — if a page
   needs something new, add it HERE as a shared class.
   ============================================================ */

/* ============================================================
   1 · DESIGN TOKENS
   Dark is the default (lives on :root → zero-FOUC for most users).
   Light is an override on :root[data-theme="light"].
   ============================================================ */
:root {
  /* — surfaces / ink (DARK) — */
  --bg:           #08080C;
  --bg-2:         #0D0D14;
  --surface:      #14141E;
  --surface-2:    #1B1B28;
  --surface-3:    #262636;
  --border:       rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.16);
  --text:         #F4F3F8;
  --text-muted:   #ABA9BC;
  --text-dim:     #6E6C82;

  /* — brand gold (the thread that keeps it Nyza) — */
  --gold:         #E6B85C;
  --gold-bright:  #FBE2A0;
  --gold-deep:    #A9842F;
  --on-gold:      #15110A;      /* text/icon sitting ON a gold fill */

  /* — energy accents (reserved for hero + ambient glow) — */
  --accent:       #9B4DFF;      /* electric violet */
  --accent-2:     #FF4D9D;      /* hot magenta */
  --on-accent:    #FFFFFF;      /* text/icon sitting ON an accent fill */

  /* — signature gradient: stage-light sweep, gold → magenta → violet — */
  --grad-brand: linear-gradient(100deg, var(--gold-bright) 0%, var(--gold) 24%, var(--accent-2) 68%, var(--accent) 100%);
  --grad-soft:  linear-gradient(135deg, rgba(155,77,255,.16), rgba(255,77,157,.10));

  /* — live / "on air" red (kept literal across themes) — */
  --live:        #FF3B47;

  /* — glow opacity (dialed down in light theme) — */
  --glow-1: rgba(155,77,255,.18);
  --glow-2: rgba(255,77,157,.13);
  --glow-3: rgba(230,184,92,.10);

  /* — type — */
  --font-display: 'Bebas Neue', 'Arial Narrow', sans-serif;
  --font-sans:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-mono:    ui-monospace, 'SF Mono', 'Roboto Mono', Menlo, monospace;

  /* — radii / elevation — */
  --r-sm: 8px;  --r-md: 14px;  --r-lg: 20px;  --r-pill: 999px;
  --shadow-card:  0 18px 44px -22px rgba(0,0,0,.75);
  --shadow-pop:   0 28px 70px -28px rgba(0,0,0,.85);
  --ring-gold:    0 0 0 1px var(--gold-deep) inset, 0 0 38px -8px rgba(230,184,92,.35);

  /* — spacing scale — */
  --space-xs:.5rem; --space-sm:1rem; --space-md:1.5rem; --space-lg:2.5rem;
  --space-xl:4rem;  --space-2xl:6rem; --space-3xl:8.5rem;

  /* — layout — */
  --max:        1240px;
  --max-narrow: 760px;
  --nav-h:      72px;

  /* — motion — */
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  color-scheme: dark;
}

:root[data-theme="light"] {
  --bg:           #FAF8F3;
  --bg-2:         #F1EEE6;
  --surface:      #FFFFFF;
  --surface-2:    #F6F3EC;
  --surface-3:    #ECE7DC;
  --border:       rgba(24,20,12,.12);
  --border-strong:rgba(24,20,12,.22);
  --text:         #161320;
  --text-muted:   #56525F;
  --text-dim:     #8A8693;

  --gold:         #97751E;       /* darkened so gold text/links pass contrast on light */
  --gold-bright:  #B8922F;
  --gold-deep:    #C9A84C;
  --on-gold:      #FFFFFF;

  --accent:       #7C3AED;
  --accent-2:     #DB2777;
  --on-accent:    #FFFFFF;

  --grad-soft:  linear-gradient(135deg, rgba(124,58,237,.08), rgba(219,39,119,.06));

  --glow-1: rgba(124,58,237,.10);
  --glow-2: rgba(219,39,119,.07);
  --glow-3: rgba(201,168,76,.10);

  --shadow-card: 0 18px 40px -26px rgba(40,30,10,.30);
  --shadow-pop:  0 28px 64px -30px rgba(40,30,10,.38);
  --ring-gold:   0 0 0 1px var(--gold) inset, 0 0 30px -10px rgba(201,168,76,.4);

  color-scheme: light;
}

/* ============================================================
   2 · RESET + BASE
   ============================================================ */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-h) + 12px);
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--text);
  font-size: 16px;
  line-height: 1.7;
  font-weight: 400;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background .4s var(--ease), color .4s var(--ease);
}

a   { color: inherit; text-decoration: none; }
img { display:block; max-width:100%; height:auto; }
svg { display:block; }
button { font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
input, textarea, select { font-family:inherit; font-size:inherit; }

h1,h2,h3,h4,h5 { color:var(--text); font-weight:700; line-height:1.12; letter-spacing:-.01em; }

::selection { background: var(--gold); color: var(--on-gold); }

::-webkit-scrollbar { width:10px; height:10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface-3); border-radius:var(--r-pill); border:2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: var(--gold-deep); }

/* ============================================================
   3 · LAYOUT
   ============================================================ */
.container { width:100%; max-width: var(--max); margin:0 auto; padding:0 clamp(1.25rem, 4vw, 2.5rem); }
.container-narrow { max-width: var(--max-narrow); }

.section { position:relative; padding: clamp(4rem, 9vw, var(--space-3xl)) 0; }
.section-alt { background: var(--bg-2); }
.section-tight { padding: clamp(2.5rem, 6vw, var(--space-xl)) 0; }

.grid-auto { display:grid; gap:clamp(1rem,2.5vw,1.5rem); }
.grid-auto--sm { grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); }
.grid-auto--md { grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); }
.grid-auto--lg { grid-template-columns: repeat(auto-fit,  minmax(300px,1fr)); }

/* two-column split (about / artist / release / contact …) */
.split { display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,5vw,4rem); align-items:center; }
.split--wide-text { grid-template-columns:0.9fr 1.1fr; }
.split img { border-radius:var(--r-md); width:100%; box-shadow:var(--shadow-card); }
@media (max-width:820px){
  .split, .split--wide-text { grid-template-columns:1fr; gap:2rem; }
  .split--reverse > :first-child { order:2; }
}

/* ============================================================
   4 · AMBIENT GLOW — fixed stage-light wash behind everything
   Add <div class="glow-bg" aria-hidden="true"></div> as first body child.
   ============================================================ */
.glow-bg {
  position: fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 12% -8%,  var(--glow-3) 0%, transparent 60%),
    radial-gradient(55vw 55vw at 88% 6%,   var(--glow-1) 0%, transparent 58%),
    radial-gradient(70vw 70vw at 78% 96%,  var(--glow-2) 0%, transparent 62%);
  filter: saturate(1.05);
}

/* ============================================================
   5 · TYPOGRAPHY HELPERS
   ============================================================ */
.eyebrow {
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:.72rem; font-weight:600; letter-spacing:.26em; text-transform:uppercase;
  color: var(--gold); margin-bottom: var(--space-sm);
}
.eyebrow::before { content:""; width:1.6rem; height:1px; background:var(--gold); opacity:.7; }
.eyebrow.no-rule::before { display:none; }

.display {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: .92;
  letter-spacing: .005em;
  font-size: clamp(3.2rem, 11vw, 8.5rem);
  text-transform: uppercase;
}

.section-title {
  font-family: var(--font-display);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: .01em;
  line-height: .95;
  font-size: clamp(2.4rem, 6vw, 4.5rem);
  margin-bottom: var(--space-md);
}
/* the "pop" word — wrap in <em> or <span class="grad"> */
.section-title em, .display em, .grad-text {
  font-style: normal;
  background: var(--grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

.section-intro { color: var(--text-muted); font-size: 1.05rem; line-height:1.7; max-width: 60ch; }

.section-header { margin-bottom: clamp(2rem, 5vw, var(--space-2xl)); }
.section-header.center { text-align:center; }
.section-header.center .eyebrow::before { display:none; }
.section-header.center .section-intro { margin-inline:auto; }
/* header with a trailing action (title block left, button right) */
.section-header.row { display:flex; align-items:flex-end; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; }

.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

/* ============================================================
   6 · BUTTONS
   ============================================================ */
.btn {
  --btn-pad: .92rem 1.9rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding: var(--btn-pad);
  font-size:.82rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  border-radius: var(--r-pill); border:1px solid transparent; white-space:nowrap;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease),
              background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
}
.btn:active { transform: translateY(0) scale(.98); }
.btn-sm { --btn-pad:.6rem 1.15rem; font-size:.72rem; }
.btn-lg { --btn-pad:1.1rem 2.4rem; font-size:.88rem; }

.btn-primary { background: var(--gold); color: var(--on-gold); border-color: var(--gold); }
.btn-primary:hover { background: var(--gold-bright); border-color: var(--gold-bright); transform: translateY(-2px); box-shadow: 0 14px 30px -12px rgba(230,184,92,.5); }

.btn-grad { background: var(--grad-brand); color: #fff; background-size:160% 160%; background-position:0% 50%; }
.btn-grad:hover { transform: translateY(-2px); background-position:100% 50%; box-shadow: 0 16px 40px -14px rgba(155,77,255,.5); }

.btn-outline { background:transparent; color:var(--text); border-color:var(--border-strong); }
.btn-outline:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

.btn-ghost { background: var(--surface-2); color:var(--text); border-color:var(--border); }
.btn-ghost:hover { border-color:var(--border-strong); background: var(--surface-3); }

/* ============================================================
   7 · PILLS / CHIPS / BADGES
   ============================================================ */
.pill, .chip {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.42rem .9rem; border-radius:var(--r-pill);
  font-size:.72rem; font-weight:600; letter-spacing:.06em;
  background: var(--surface-2); border:1px solid var(--border); color: var(--text-muted);
}
.chip--gold { color: var(--gold); border-color: rgba(230,184,92,.35); background: rgba(230,184,92,.08); }

.badge {
  position:absolute; top:.75rem; right:.75rem; z-index:2;
  padding:.34rem .7rem; border-radius:var(--r-pill);
  font-size:.66rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  background: rgba(0,0,0,.62); color: var(--gold-bright); backdrop-filter: blur(8px);
}
.badge--live { background: var(--live); color:#fff; left:.75rem; right:auto; display:inline-flex; align-items:center; gap:.4rem; }
.badge--live .dot { width:6px; height:6px; border-radius:50%; background:#fff; animation: nyzaPulse 1.6s ease-out infinite; }

/* "ON AIR" eyebrow variant */
.eyebrow.live { color: var(--live); }
.eyebrow.live::before { display:none; }
.live-dot { width:8px; height:8px; border-radius:50%; background:var(--live); box-shadow:0 0 0 0 rgba(255,59,71,.6); animation: nyzaPulse 1.6s ease-out infinite; }
@keyframes nyzaPulse { 0%{box-shadow:0 0 0 0 rgba(255,59,71,.7);} 70%{box-shadow:0 0 0 11px rgba(255,59,71,0);} 100%{box-shadow:0 0 0 0 rgba(255,59,71,0);} }

/* ============================================================
   8 · CARDS — base primitive for every grid card
   ============================================================ */
.card {
  position:relative; display:flex; flex-direction:column;
  background: var(--surface); border:1px solid var(--border); border-radius: var(--r-md);
  overflow:hidden; color:inherit;
  transition: transform .35s var(--ease-out), border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
}
.card:hover { transform: translateY(-5px); border-color: var(--border-strong); box-shadow: var(--shadow-card); }
.card.card--glow:hover { border-color: var(--gold-deep); box-shadow: var(--shadow-card), var(--ring-gold); }
.card a { color:inherit; display:block; }

.card-media { position:relative; overflow:hidden; background: var(--surface-2); }
.card-media.ar-square { aspect-ratio:1/1; }
.card-media.ar-video  { aspect-ratio:16/9; }
.card-media img { width:100%; height:100%; object-fit:cover; transition: transform .55s var(--ease-out), filter .3s var(--ease); }
.card:hover .card-media img { transform: scale(1.06); filter: saturate(1.1); }
.card-media .bg-cover { position:absolute; inset:0; background-size:cover; background-position:center; transition: transform .55s var(--ease-out); }
.card:hover .card-media .bg-cover { transform: scale(1.06); }

/* hover play affordance */
.card-play { position:absolute; inset:0; display:grid; place-items:center; background:rgba(0,0,0,.4); opacity:0; transition:opacity .25s var(--ease); }
.card:hover .card-play { opacity:1; }
.card-play svg { width:54px; height:54px; fill:#fff; filter: drop-shadow(0 6px 18px rgba(0,0,0,.6)); }

.card-body { padding:1.05rem 1.15rem 1.25rem; display:flex; flex-direction:column; gap:.4rem; }
.card-title { font-weight:700; font-size:1.02rem; line-height:1.25; color:var(--text); }
.card-title.display { font-family:var(--font-display); font-weight:400; font-size:1.5rem; letter-spacing:.02em; line-height:1; }
.card-meta { font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.card-meta .dot { width:3px; height:3px; border-radius:50%; background:currentColor; }
.card-eyebrow { font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.card-excerpt { font-size:.86rem; color:var(--text-muted); line-height:1.55;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* brand tile — sister-brand cards (homepage Network + /network/ index).
   Per-brand accent via inline `style="--brand-accent:#hex"` (data, not styling). */
.brand-tile { padding:1.5rem; }
.brand-tile-head { display:flex; align-items:center; gap:.75rem; margin-bottom:1rem; }
.brand-logo { width:46px; height:46px; border-radius:10px; background:#fff; padding:5px; object-fit:contain; border:1px solid var(--border); flex-shrink:0; }
.brand-cat { font-size:.64rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color: var(--brand-accent, var(--gold)); }
.brand-tile h3 { font-size:1.35rem; margin-bottom:.4rem; }
.brand-tile p { color:var(--text-muted); font-size:.9rem; line-height:1.55; }

/* ============================================================
   9 · FILTER BAR (catalog pages)
   ============================================================ */
.filters { display:flex; flex-wrap:wrap; gap:.6rem; }
.filter-btn {
  padding:.55rem 1.15rem; border-radius:var(--r-pill);
  background: var(--surface-2); border:1px solid var(--border); color:var(--text-muted);
  font-size:.78rem; font-weight:600; letter-spacing:.04em;
  transition: all .2s var(--ease);
}
.filter-btn:hover { color:var(--text); border-color:var(--border-strong); }
.filter-btn.active { background: var(--gold); border-color:var(--gold); color: var(--on-gold); }

/* ============================================================
   10 · FORMS
   ============================================================ */
.field { display:flex; flex-direction:column; gap:.45rem; margin-bottom:1.1rem; }
.field label { font-size:.74rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); }
.field input, .field textarea, .field select {
  width:100%; padding:.9rem 1rem; color:var(--text);
  background: var(--surface); border:1px solid var(--border); border-radius: var(--r-sm);
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.field input::placeholder, .field textarea::placeholder { color: var(--text-dim); }
.field input:focus, .field textarea:focus, .field select:focus {
  outline:none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(230,184,92,.18); background: var(--surface-2);
}
.field textarea { min-height:140px; resize:vertical; line-height:1.6; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-message { margin-top:.9rem; font-size:.86rem; min-height:1.2em; }
.form-message.success { color:#4ade80; }
.form-message.error   { color: var(--accent-2); }

/* ============================================================
   11 · NAV + THEME TOGGLE + MOBILE DRAWER
   ============================================================ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--nav-h);
  background: color-mix(in srgb, var(--bg) 62%, transparent);
  backdrop-filter: blur(18px) saturate(1.4); -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border-bottom:1px solid transparent;
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.nav.scrolled { background: color-mix(in srgb, var(--bg) 88%, transparent); border-bottom-color: var(--border); }
.nav-inner { max-width: var(--max); margin:0 auto; height:100%; padding:0 clamp(1.25rem,4vw,2.5rem);
  display:flex; align-items:center; justify-content:space-between; gap:1.25rem; }

.nav-brand { display:flex; align-items:center; gap:.65rem; flex-shrink:0; }
.nav-logo { width:38px; height:38px; border-radius:50%; object-fit:cover; background:var(--surface-3); }
.nav-brand-text { font-family:var(--font-display); font-size:1.35rem; letter-spacing:.12em; color:var(--text); }

.nav-menu { display:flex; align-items:center; gap:1.6rem; list-style:none; }
.nav-menu a { font-size:.82rem; font-weight:500; letter-spacing:.04em; color:var(--text-muted); position:relative; padding:.25rem 0; transition:color .2s var(--ease); }
.nav-menu a::after { content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--gold); transition:right .25s var(--ease); }
.nav-menu a:hover { color:var(--text); }
.nav-menu a:hover::after { right:0; }

.nav-actions { display:flex; align-items:center; gap:.85rem; flex-shrink:0; }
.nav-cta { font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  padding:.6rem 1.25rem; border-radius:var(--r-pill); border:1px solid var(--gold); color:var(--gold);
  transition: all .25s var(--ease); }
.nav-cta:hover { background:var(--gold); color:var(--on-gold); }

.theme-toggle {
  width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  background:var(--surface-2); border:1px solid var(--border); color:var(--text-muted);
  transition: color .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.theme-toggle:hover { color:var(--gold); border-color:var(--gold-deep); transform: rotate(12deg); }
.theme-toggle svg { width:18px; height:18px; }
.theme-toggle .moon { display:none; }
:root[data-theme="light"] .theme-toggle .sun { display:none; }
:root[data-theme="light"] .theme-toggle .moon { display:block; }

.hamburger { display:none; width:40px; height:40px; border-radius:10px; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.hamburger span { width:20px; height:2px; background:var(--text); border-radius:2px; transition: transform .3s var(--ease), opacity .3s var(--ease); }
.hamburger.active span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2){ opacity:0; }
.hamburger.active span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 880px) {
  .nav-menu {
    position:fixed; inset:var(--nav-h) 0 auto 0;
    flex-direction:column; align-items:flex-start; gap:0;
    background: var(--bg-2); border-bottom:1px solid var(--border);
    padding:.5rem clamp(1.25rem,4vw,2.5rem) 1.25rem;
    transform: translateY(-12px); opacity:0; pointer-events:none;
    transition: transform .3s var(--ease), opacity .3s var(--ease);
  }
  .nav-menu.open { transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav-menu li { width:100%; border-bottom:1px solid var(--border); }
  .nav-menu a { display:block; padding:1rem 0; font-size:.95rem; }
  .nav-cta { display:none; }
  .hamburger { display:flex; }
}

/* keep content clear of the fixed nav when a page starts with content (not a full hero) */
.has-fixed-nav { padding-top: var(--nav-h); }

/* ============================================================
   12 · HERO (home) + DETAIL HERO (song/story/playlist)
   ============================================================ */
.hero { position:relative; min-height: min(92vh, 820px); display:flex; flex-direction:column; align-items:center; text-align:center; padding: calc(var(--nav-h) + 1.5rem) 0 1.75rem; overflow:hidden; }
.hero-inner { position:relative; z-index:2; max-width: 940px; padding:0 1.5rem; margin:auto 0; }
.hero-logo { width:84px; height:84px; border-radius:50%; margin:0 auto 1.75rem; box-shadow:0 0 0 1px var(--border), 0 0 60px -10px rgba(230,184,92,.4); }
.hero-eyebrow { justify-content:center; }
.hero-title { margin:.5rem 0 1.25rem; }
.hero-desc { color:var(--text-muted); font-size:clamp(1rem,2vw,1.2rem); max-width:60ch; margin:0 auto 2rem; line-height:1.65; }
.hero-buttons { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero-scroll { position:relative; z-index:2; margin-top:1rem; flex-shrink:0;
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color:var(--text-dim); }
.hero-scroll::after { content:""; display:block; width:1px; height:34px; margin:.6rem auto 0; background:linear-gradient(var(--gold),transparent); animation: nyzaScroll 2s var(--ease) infinite; }
@keyframes nyzaScroll { 0%{transform:scaleY(0);transform-origin:top;} 50%{transform:scaleY(1);transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* detail hero: blurred backdrop image + dark overlay + foreground info */
.detail-hero { position:relative; padding: calc(var(--nav-h) + 3rem) 0 3rem; overflow:hidden; isolation:isolate; }
.detail-hero .backdrop { position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center; filter: blur(34px) saturate(1.2); transform: scale(1.18); opacity:.5; }
.detail-hero .backdrop-overlay { position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, color-mix(in srgb,var(--bg) 55%, transparent) 0%, var(--bg) 92%); }
.detail-hero-grid { display:grid; grid-template-columns: minmax(220px,300px) 1fr; gap: clamp(1.5rem,4vw,3rem); align-items:center; }
.detail-poster { border-radius:var(--r-md); overflow:hidden; box-shadow: var(--shadow-pop); aspect-ratio:1/1; background:var(--surface-2); }
.detail-poster.ar-video { aspect-ratio:16/9; }
.detail-poster img, .detail-poster .bg-cover { width:100%; height:100%; object-fit:cover; }
.detail-title { font-family:var(--font-display); font-weight:400; text-transform:uppercase; line-height:.95; letter-spacing:.01em; font-size:clamp(2.4rem,6vw,4.5rem); margin:.5rem 0 .75rem; }
.detail-sub { color:var(--text-muted); font-size:1.05rem; max-width:58ch; line-height:1.6; }
.detail-meta-row { display:flex; flex-wrap:wrap; gap:.6rem; margin:1.1rem 0; }
.detail-actions { display:flex; flex-wrap:wrap; gap:.75rem; margin-top:1.25rem; }
@media (max-width:680px){ .detail-hero-grid { grid-template-columns:1fr; text-align:center; }
  .detail-poster { max-width:280px; margin:0 auto; } .detail-meta-row, .detail-actions { justify-content:center; } }

/* ============================================================
   13 · MEDIA EMBED — responsive 16:9 iframe (YouTube etc.)
   ============================================================ */
.media-embed { position:relative; width:100%; aspect-ratio:16/9; border-radius:var(--r-md); overflow:hidden; background:#000; box-shadow:var(--shadow-card); border:1px solid var(--border); }
.media-embed iframe, .media-embed video { position:absolute; inset:0; width:100%; height:100%; border:0; }
/* click-to-load poster (lazy youtube facade) */
.embed-facade { position:absolute; inset:0; background-size:cover; background-position:center; cursor:pointer; display:grid; place-items:center; }
.embed-facade::before { content:""; position:absolute; inset:0; background:rgba(0,0,0,.3); transition:background .25s var(--ease); }
.embed-facade:hover::before { background:rgba(0,0,0,.15); }
.embed-facade .play-btn { position:relative; width:74px; height:74px; border-radius:50%; background:var(--gold); display:grid; place-items:center; box-shadow:0 10px 30px -8px rgba(0,0,0,.6); transition:transform .25s var(--ease); }
.embed-facade:hover .play-btn { transform:scale(1.08); }
.embed-facade .play-btn svg { width:30px; height:30px; fill:var(--on-gold); margin-left:4px; }

/* ============================================================
   14 · TRACKLIST / VIDEO LIST (playlist pages)
   ============================================================ */
.tracklist { display:flex; flex-direction:column; gap:.6rem; }
.track {
  display:grid; grid-template-columns:auto 96px 1fr auto; align-items:center; gap:1rem;
  padding:.7rem .9rem; border-radius:var(--r-sm); background:var(--surface);
  border:1px solid var(--border); transition: background .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.track:hover { background:var(--surface-2); border-color:var(--border-strong); transform: translateX(3px); }
.track-index { font-family:var(--font-mono); color:var(--text-dim); font-size:.85rem; width:1.5rem; text-align:right; }
.track-thumb { width:96px; aspect-ratio:16/9; border-radius:6px; object-fit:cover; background:var(--surface-3); }
.track-title { font-weight:600; font-size:.95rem; color:var(--text); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.track-meta { font-size:.74rem; color:var(--text-muted); letter-spacing:.05em; }
@media (max-width:560px){ .track { grid-template-columns:auto 64px 1fr; } .track-thumb{width:64px;} .track-meta{display:none;} }

/* ============================================================
   15 · PROSE — long-form article / story body
   Wrap article HTML in <div class="prose">…</div>
   ============================================================ */
.prose { max-width: 68ch; margin-inline:auto; color: var(--text); font-size:1.085rem; line-height:1.85; }
.prose > * + * { margin-top: 1.35em; }
.prose h2 { font-family:var(--font-display); font-weight:400; text-transform:uppercase; letter-spacing:.01em; font-size:1.9rem; line-height:1.05; margin-top:2.2em; margin-bottom:.2em; }
.prose h3 { font-weight:700; font-size:1.3rem; margin-top:1.8em; margin-bottom:.1em; }
.prose h4 { font-weight:700; font-size:1.08rem; color:var(--gold); letter-spacing:.02em; }
.prose p, .prose li { color: var(--text); }
.prose a { color: var(--gold); text-decoration:underline; text-underline-offset:3px; text-decoration-color: var(--gold-deep); }
.prose a:hover { color: var(--gold-bright); }
.prose strong { color:var(--text); font-weight:700; }
.prose em { font-style:italic; }
.prose ul, .prose ol { padding-left:1.4em; }
.prose li { margin-top:.5em; }
.prose li::marker { color: var(--gold); }
.prose img { border-radius:var(--r-md); margin-block:2em; box-shadow:var(--shadow-card); }
.prose blockquote, .quote {
  border-left:3px solid var(--gold); padding:.4em 0 .4em 1.4em; margin-block:1.8em;
  font-family:var(--font-display); font-weight:400; font-size:1.6rem; line-height:1.25;
  color:var(--text); text-transform:none; letter-spacing:.01em;
}
.prose code { font-family:var(--font-mono); font-size:.9em; background:var(--surface-2); padding:.15em .4em; border-radius:6px; border:1px solid var(--border); }
.prose pre { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:1.2rem; overflow:auto; }
.prose pre code { background:none; border:none; padding:0; }
.prose hr, .sep { border:none; height:1px; background: var(--border); margin-block:2.5em; }

/* lyrics block (song pages) — centered, airy */
.lyrics { white-space:pre-line; text-align:center; line-height:2; color:var(--text-muted); font-size:1.05rem; max-width:46ch; margin-inline:auto; }

/* ============================================================
   16 · BREADCRUMB + BACK LINK
   ============================================================ */
.breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.78rem; color:var(--text-dim); letter-spacing:.04em; flex-wrap:wrap; }
.breadcrumb a { color:var(--text-muted); }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb .sep-i { color:var(--text-dim); }
.back-link { display:inline-flex; align-items:center; gap:.5rem; color:var(--text-muted); font-size:.85rem; transition:color .2s var(--ease); }
.back-link:hover { color:var(--gold); }

/* ============================================================
   17 · SHARE / SOCIAL ROW
   ============================================================ */
.share-links, .social-row { display:flex; gap:.7rem; flex-wrap:wrap; align-items:center; }
.social-btn {
  width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  background:var(--surface-2); border:1px solid var(--border); color:var(--text-muted);
  transition: color .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease), background .2s var(--ease);
}
.social-btn:hover { color:var(--gold); border-color:var(--gold-deep); transform:translateY(-2px); }
.social-btn svg { width:18px; height:18px; fill:currentColor; }

/* ============================================================
   18 · READING PROGRESS BAR (blog)
   ============================================================ */
.progress-bar { position:fixed; top:0; left:0; height:3px; width:0; z-index:1100; background: var(--grad-brand); transition: width .1s linear; }

/* ============================================================
   19 · STAT / NUMBER ROW
   ============================================================ */
.stats { display:flex; gap:clamp(1.5rem,4vw,3rem); flex-wrap:wrap; margin-top:2rem; }
.stat-number { font-family:var(--font-display); font-weight:400; font-size:clamp(2.2rem,4vw,3rem); line-height:1; color:var(--gold); }
.stat-label { font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-muted); margin-top:.35rem; }

/* numbered service / feature card */
.feature { padding:1.75rem; border-radius:var(--r-md); background:var(--surface); border:1px solid var(--border); transition:border-color .3s var(--ease), transform .3s var(--ease-out); }
.feature:hover { border-color:var(--gold-deep); transform:translateY(-4px); }
.feature-num { font-family:var(--font-mono); font-size:.85rem; color:var(--gold); letter-spacing:.1em; }
.feature h3 { margin:.6rem 0 .5rem; font-size:1.2rem; }
.feature p { color:var(--text-muted); font-size:.92rem; line-height:1.6; }

/* ============================================================
   20 · FOOTER
   ============================================================ */
.site-footer { background: var(--bg-2); border-top:1px solid var(--border); padding: clamp(3rem,6vw,var(--space-2xl)) 0 2rem; }
.footer-grid { display:grid; grid-template-columns: 1.6fr repeat(4, 1fr); gap:clamp(1.5rem,3vw,2.5rem); }
.footer-brand img { width:48px; height:48px; border-radius:50%; margin-bottom:1rem; }
.footer-brand p { color:var(--text-muted); font-size:.9rem; line-height:1.6; max-width:32ch; }
.footer-social { display:flex; gap:.6rem; margin-top:1.1rem; }
.footer-col h4 { font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.footer-col a { color:var(--text-muted); font-size:.88rem; transition:color .2s var(--ease); }
.footer-col a:hover { color:var(--text); }
.footer-bottom { display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:clamp(2rem,4vw,3rem); padding-top:1.5rem; border-top:1px solid var(--border); }
.footer-bottom p { color:var(--text-dim); font-size:.8rem; }
.footer-bottom a { color:var(--gold); }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } .footer-brand{ grid-column:1/-1; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } .footer-bottom{ flex-direction:column; } }

/* ============================================================
   21 · REVEAL ON SCROLL (wired by nyza.js IntersectionObserver)
   ============================================================ */
.reveal { opacity:0; transform: translateY(26px); transition: opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.reveal.visible { opacity:1; transform:none; }
.reveal.d1 { transition-delay:.08s; } .reveal.d2 { transition-delay:.16s; } .reveal.d3 { transition-delay:.24s; }

@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; }
}

/* ============================================================
   22 · MISC UTILITIES
   ============================================================ */
.text-center { text-align:center; }
.mt-auto { margin-top:auto; }
.section-cta { text-align:center; margin-top:clamp(2rem,4vw,3rem); }
.divider { height:1px; background:var(--border); border:none; }
.sr-only, .visually-hidden { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
