/* ============================================================
   BRAV DIVI — Marcus Henry Brown Waters
   Artist site. Clean, modern, web-native.
   Palette + mood from the brand: deep charcoal, antique gold,
   parchment text, warm serif type. A WEBSITE — not an album jacket.
   ============================================================ */

:root{
  --charcoal:#0E0E10;
  --charcoal-2:#16161b;
  --charcoal-3:#1f1f25;
  --sepia:#5A3B26;
  --gold:#C6A267;
  --gold-bright:#e0c08a;
  --parchment:#F2E6CF;
  --parchment-dim:#b9b09c;
  --skyline:#4A5A66;
  --bronze:#7E6242;
  --ink:#0a0a0c;

  --serif-display:'Playfair Display', Georgia, serif;
  --serif-head:'Cormorant Garamond', Georgia, serif;
  --serif-body:'EB Garamond', Georgia, serif;
  --script:'Pinyon Script', cursive;

  --maxw:1140px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--charcoal);color:var(--parchment);
  font-family:var(--serif-body);font-size:18px;line-height:1.75;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--gold);color:var(--ink);}

/* ---------- shared ---------- */
.section{padding:120px 24px;max-width:var(--maxw);margin:0 auto;}
.section-head{text-align:center;margin-bottom:64px;}
.kicker{
  font-family:var(--serif-head);letter-spacing:.42em;text-transform:uppercase;
  font-size:.8rem;color:var(--gold);margin-bottom:16px;
}
.section-head h2{
  font-family:var(--serif-display);font-size:clamp(2.4rem,5vw,3.6rem);
  color:var(--parchment);font-weight:700;line-height:1.1;
}
.section-head .sub{
  font-family:var(--serif-body);font-style:italic;color:var(--parchment-dim);
  max-width:620px;margin:18px auto 0;font-size:1.05rem;
}
.btn{
  display:inline-block;padding:13px 30px;font-family:var(--serif-head);
  text-transform:uppercase;letter-spacing:.2em;font-size:.85rem;font-weight:600;
  cursor:pointer;transition:.25s;border:1px solid var(--gold);background:transparent;color:var(--gold);
}
.btn-gold{background:var(--gold);color:var(--ink);}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-2px);}
.btn-ghost:hover{background:rgba(198,162,103,.1);transform:translateY(-2px);}

/* ============ NAV ============ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:400;
  display:flex;align-items:center;justify-content:space-between;padding:20px 36px;
  background:linear-gradient(to bottom,rgba(10,10,12,.85),transparent);transition:.3s;
}
.site-nav.scrolled{
  background:rgba(12,12,16,.97);padding:14px 36px;border-bottom:1px solid rgba(198,162,103,.15);
}
.nav-brand{font-family:var(--serif-display);font-weight:800;letter-spacing:.18em;color:var(--gold);font-size:1.1rem;}
.nav-links{display:flex;gap:32px;}
.nav-links a{font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.18em;font-size:.82rem;color:var(--parchment-dim);transition:color .2s;}
.nav-links a:hover{color:var(--gold);}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;}
.nav-toggle span{width:26px;height:2px;background:var(--gold);transition:.3s;}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:flex-end;
  overflow:hidden;padding:140px 0 0;
}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:30% 18%;
  filter:saturate(1.02) contrast(1.05);
}
/* asymmetric veil: his face stays visible upper-left, text sits in the darker lower area */
.hero-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom,rgba(10,10,12,.2) 0%,rgba(10,10,12,.05) 30%,rgba(10,10,12,.5) 62%,rgba(10,10,12,.96) 100%),
    linear-gradient(to right,rgba(10,10,12,.0) 0%,rgba(10,10,12,.0) 45%,rgba(10,10,12,.4) 100%);
}
.hero-inner{
  position:relative;z-index:2;width:100%;max-width:var(--maxw);
  margin:0 auto;padding:0 24px 100px;text-align:left;
}
.hero-eyebrow{
  font-family:var(--serif-head);letter-spacing:.4em;text-transform:uppercase;
  font-size:.82rem;color:var(--gold);margin-bottom:14px;text-shadow:0 2px 14px rgba(0,0,0,.8);
}
.hero-name{
  font-family:var(--script);font-size:clamp(4.5rem,13vw,9.5rem);
  color:var(--gold);line-height:.85;font-weight:400;margin-bottom:14px;
  text-shadow:0 6px 50px rgba(0,0,0,.85),0 2px 70px rgba(198,162,103,.25);
}
.hero-fullname{
  font-family:var(--serif-display);font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  font-size:clamp(1rem,2.2vw,1.3rem);color:var(--parchment);margin-bottom:10px;text-shadow:0 2px 14px rgba(0,0,0,.85);
}
.hero-dates{
  font-family:var(--serif-head);letter-spacing:.3em;text-transform:uppercase;
  font-size:.92rem;color:var(--parchment-dim);text-shadow:0 2px 14px rgba(0,0,0,.85);
}
.hero-rule{height:1px;width:120px;margin:24px 0;background:linear-gradient(to right,var(--gold),transparent);}
.hero-line{
  font-family:var(--serif-body);font-style:italic;font-size:clamp(1.1rem,2.4vw,1.4rem);
  color:var(--parchment);line-height:1.55;margin-bottom:32px;max-width:520px;
  text-shadow:0 2px 18px rgba(0,0,0,.9);
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.hero-scroll{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;
  color:var(--gold);font-size:1.3rem;animation:bob 2s ease-in-out infinite;opacity:.6;
}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ============ THE MUSIC ============ */
.section-music{background:var(--charcoal);}

/* --- Album tile grid --- */
.album-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:700px;margin:0 auto;box-sizing:border-box;}
.album-tile{text-align:center;cursor:pointer;transition:transform .3s;min-width:0;overflow:hidden;}
.album-tile:active{transform:scale(.97);}
.album-art{width:100%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(198,162,103,.2);transition:border-color .3s,box-shadow .3s;}
.album-tile:hover .album-art{border-color:rgba(198,162,103,.5);box-shadow:0 12px 40px rgba(0,0,0,.4);}
.album-art img{width:100%;height:100%;object-fit:cover;}
.album-label{font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.06em;font-size:clamp(.72rem,2.5vw,.95rem);color:var(--parchment);margin-top:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.album-sub{font-style:italic;color:var(--parchment-dim);font-size:.82rem;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* placeholder cover art */
.placeholder-art{background:linear-gradient(145deg,var(--ink),var(--charcoal-2));padding:20px;overflow:hidden;}
.ph-logo{width:40px;max-height:50px;object-fit:contain;opacity:.4;margin-bottom:8px;flex-shrink:0;}
.ph-title{font-family:var(--serif-display);font-size:clamp(1.3rem,4vw,2.2rem);color:var(--parchment);text-transform:uppercase;letter-spacing:.08em;line-height:1.2;}
.ph-artist{font-family:var(--serif-body);font-style:italic;color:var(--gold);font-size:clamp(.78rem,2.2vw,.95rem);margin-top:12px;letter-spacing:.06em;}
.salvashunn-art{background:url('/assets/img/logo-silhouette.png') center 22% / 45% no-repeat, linear-gradient(145deg,#1a1520,#2a1f30,#1a1520);}
.singles-art{background:url('/assets/img/logo-silhouette.png') center 22% / 45% no-repeat, linear-gradient(145deg,#18191f,#1f2028,#18191f);}

/* --- Album immersive overlay --- */
.alb-overlay{
  position:fixed;inset:0;z-index:500;background:rgba(8,8,12,.98);
  display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .4s cubic-bezier(.2,.9,.3,1);
  overflow:hidden;
}
.alb-overlay.open{transform:translateY(0);}
.alb-close{
  position:absolute;top:0;left:0;z-index:10;background:none;border:none;
  color:var(--parchment);font-family:var(--serif-head);font-size:.85rem;
  letter-spacing:.12em;text-transform:uppercase;padding:20px 24px;cursor:pointer;
  transition:color .2s;
}
.alb-close:hover{color:var(--gold);}
.alb-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:70px 24px 20px;}
.alb-hero{width:min(280px,60vw);aspect-ratio:1;margin:0 auto 28px;overflow:hidden;border:1px solid rgba(198,162,103,.25);}
.alb-hero .placeholder-art{width:100%;height:100%;}
.alb-meta{text-align:center;margin-bottom:32px;}
.alb-title{font-family:var(--serif-display);font-size:clamp(1.6rem,5vw,2.4rem);color:var(--parchment);text-transform:uppercase;letter-spacing:.1em;margin:0;}
.alb-artist{font-family:var(--serif-body);font-style:italic;color:var(--gold);font-size:1rem;margin-top:6px;letter-spacing:.08em;}
.alb-tracklist{list-style:none;max-width:500px;margin:0 auto;padding:0;}
.alb-tracklist li{
  display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:14px;
  padding:14px 8px;border-bottom:1px solid rgba(198,162,103,.1);cursor:pointer;transition:.2s;
}
.alb-tracklist li:hover{background:rgba(198,162,103,.06);padding-left:14px;}
.alb-tracklist li.playing{background:rgba(198,162,103,.1);padding-left:14px;}
.alb-tracklist .t-num{font-family:var(--serif-head);color:var(--gold);font-size:1rem;}
.alb-tracklist .t-name{text-transform:uppercase;letter-spacing:.06em;font-size:.95rem;color:var(--parchment);}
.alb-tracklist .t-feat{font-style:italic;color:var(--parchment-dim);font-size:.82rem;}

/* overlay player */
.alb-player{
  flex-shrink:0;background:rgba(12,12,16,.95);border-top:1px solid rgba(198,162,103,.2);
  padding:16px 24px calc(16px + env(safe-area-inset-bottom, 0px));
  display:none;flex-direction:column;gap:10px;
}
.alb-player.visible{display:flex;}
.alb-now{text-align:center;}
.alb-now-title{display:block;font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.1em;font-size:.9rem;color:var(--parchment);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.alb-now-status{display:block;font-size:.7rem;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-top:2px;}
.alb-seek-row{display:flex;align-items:center;gap:10px;}
.alb-seek{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:rgba(198,162,103,.2);border-radius:2px;cursor:pointer;}
.alb-seek::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--gold);border-radius:50%;cursor:pointer;}
.alb-seek::-moz-range-thumb{width:16px;height:16px;background:var(--gold);border:none;border-radius:50%;cursor:pointer;}
.alb-time{font-family:var(--serif-head);font-size:.75rem;color:var(--parchment-dim);min-width:34px;}
.alb-time:last-child{text-align:right;}
.alb-controls{display:flex;align-items:center;justify-content:center;gap:28px;}
.alb-btn{background:none;border:none;color:var(--parchment);cursor:pointer;font-size:1.4rem;padding:8px;transition:color .2s,transform .15s;}
.alb-btn:hover{color:var(--gold);}
.alb-btn:active{transform:scale(.9);}
.alb-play{width:56px;height:56px;border-radius:50%;background:var(--gold);color:var(--ink);font-size:1.3rem;display:flex;align-items:center;justify-content:center;}
.alb-play:hover{background:var(--gold-bright);color:var(--ink);}

/* --- Shared track styles --- */
.music-wrap{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:54px;align-items:start;}
.music-art img{box-shadow:0 24px 60px rgba(0,0,0,.55);}
.art-cap{margin-top:14px;font-style:italic;color:var(--parchment-dim);font-size:.92rem;text-align:center;}
.list-tag{font-family:var(--serif-head);letter-spacing:.32em;text-transform:uppercase;font-size:.78rem;color:var(--gold);margin-bottom:20px;}
.tracklist{list-style:none;}
.track{
  display:grid;grid-template-columns:30px 1fr auto;align-items:center;gap:16px;
  padding:15px 4px;border-bottom:1px solid rgba(198,162,103,.12);cursor:pointer;transition:.2s;
}
.track:hover{background:rgba(198,162,103,.06);padding-left:12px;}
.track.no-audio{opacity:.45;cursor:default;}
.track.no-audio:hover{background:transparent;padding-left:4px;}
.track.playing{background:rgba(198,162,103,.1);padding-left:12px;}
.t-num{font-family:var(--serif-head);color:var(--gold);font-size:1.05rem;}
.t-name{text-transform:uppercase;letter-spacing:.08em;font-size:1rem;}
.t-feat{font-style:italic;color:var(--parchment-dim);font-size:.85rem;}
.t-play{display:none;}
.list-foot{margin-top:28px;font-style:italic;color:var(--gold);font-size:1.05rem;}
.streaming-soon{margin-top:34px;}
.ss-label{font-family:var(--serif-head);letter-spacing:.28em;text-transform:uppercase;font-size:.72rem;color:var(--parchment-dim);display:block;margin-bottom:14px;}
.ss-icons{display:flex;gap:10px;flex-wrap:wrap;}
.ss-btn,.c-btn{
  font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;
  color:var(--parchment-dim);padding:9px 18px;border:1px solid rgba(198,162,103,.22);cursor:default;transition:.2s;
}
.ss-btn:hover,.c-btn:hover{border-color:var(--gold);color:var(--gold);}

/* ============ THE STORY ============ */
.section-story{background:var(--charcoal-2);}
.story-flow{display:flex;flex-direction:column;gap:90px;}
.story-block{display:grid;grid-template-columns:minmax(260px,400px) 1fr;gap:54px;align-items:center;}
.story-block.reverse{direction:rtl;}
.story-block.reverse > *{direction:ltr;}
.story-img img{aspect-ratio:4/5;object-fit:cover;width:100%;box-shadow:0 20px 50px rgba(0,0,0,.5);}
.story-copy h3{font-family:var(--serif-display);font-size:clamp(1.8rem,3.5vw,2.5rem);color:var(--gold);font-weight:700;margin-bottom:18px;line-height:1.15;}
.story-copy p{margin-bottom:16px;color:var(--parchment);font-size:1.05rem;}
.story-copy strong{color:var(--gold-bright);}
.story-copy em{font-style:italic;}
.quote-band{margin-top:80px;text-align:center;padding:54px 24px;border-top:1px solid rgba(198,162,103,.18);border-bottom:1px solid rgba(198,162,103,.18);}
.quote-band p{font-family:var(--serif-display);font-style:italic;font-size:clamp(1.4rem,3.5vw,2.1rem);color:var(--gold);line-height:1.5;}

/* ============ THE FAMILY ============ */
.section-family{background:var(--charcoal);}
.family-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;}
.fam-card{background:var(--charcoal-2);overflow:hidden;display:flex;flex-direction:column;transition:.3s;}
.fam-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.45);}
.fam-card img{width:100%;object-fit:cover;aspect-ratio:16/10;}
.fam-card.wide img{aspect-ratio:16/9;}
.fam-card figcaption{padding:28px;}
.fam-card h4{font-family:var(--serif-display);color:var(--gold);font-size:1.4rem;margin-bottom:10px;font-weight:700;}
.fam-card p{font-size:1rem;color:var(--parchment-dim);}
.fam-card strong{color:var(--gold-bright);}
.fam-card em{font-style:italic;}
.family-note{text-align:center;margin:40px auto 0;font-style:italic;color:var(--parchment-dim);font-size:1rem;max-width:680px;}
.family-note strong{color:var(--gold);font-style:normal;}

/* ============ GALLERY ============ */
.section-gallery{background:var(--charcoal-2);}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;}
.g-item{overflow:hidden;}
.g-item img{width:100%;height:100%;object-fit:cover;transition:.5s;}
.g-item:hover img{transform:scale(1.06);}
.g-item.tall{grid-row:span 2;}
.g-item.wide{grid-column:span 2;}
.gallery-note{text-align:center;margin-top:30px;font-style:italic;color:var(--parchment-dim);}

/* ============ SHOP ============ */
.section-shop{background:var(--charcoal);}
.shop-soon{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;}
.shop-card.placeholder{aspect-ratio:4/5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--charcoal-2);border:1px dashed rgba(198,162,103,.3);text-align:center;padding:24px;}
.shop-card.placeholder span{font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.2em;color:var(--parchment);font-size:.95rem;}
.shop-card.placeholder em{color:var(--gold);font-style:italic;letter-spacing:.1em;}

/* ============ CONNECT ============ */
.section-connect{background:var(--ink);}
.connect-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:34px;}
.connect-form{display:flex;max-width:480px;margin:0 auto;border:1px solid rgba(198,162,103,.3);}
.connect-form input{flex:1;background:rgba(15,15,18,.6);border:none;padding:14px 18px;font-family:var(--serif-body);color:var(--parchment);font-size:1rem;outline:none;}
.connect-form input::placeholder{color:var(--parchment-dim);}
.connect-form .btn{border:none;border-left:1px solid rgba(198,162,103,.3);}
.connect-note{text-align:center;margin-top:18px;font-style:italic;color:var(--parchment-dim);font-size:.9rem;}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink);text-align:center;padding:80px 24px 50px;border-top:1px solid rgba(198,162,103,.15);}
.foot-quote{font-family:var(--serif-display);font-style:italic;font-size:1.4rem;color:var(--gold);margin-bottom:18px;}
.foot-rule{height:1px;width:90px;margin:16px auto;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.foot-name{font-family:var(--serif-display);font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--parchment);font-size:1.05rem;}
.foot-dates{font-family:var(--serif-head);letter-spacing:.26em;text-transform:uppercase;color:var(--parchment-dim);font-size:.85rem;margin-top:6px;}
.foot-tag{font-family:var(--serif-head);letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-size:.75rem;margin-top:24px;}
.foot-copy{color:var(--parchment-dim);font-size:.78rem;margin-top:28px;opacity:.55;}

/* ============ STICKY AUDIO PLAYER ============ */
.player{
  position:fixed;left:50%;bottom:calc(18px + env(safe-area-inset-bottom, 0px));transform:translate(-50%,140%);z-index:300;
  display:flex;flex-direction:column;gap:8px;background:rgba(15,15,18,.97);
  border:1px solid rgba(198,162,103,.35);border-radius:14px;padding:14px 18px 16px;box-shadow:0 20px 60px rgba(0,0,0,.6);
  width:min(560px,calc(100vw - 32px));transition:transform .4s cubic-bezier(.2,.9,.3,1.15);
}
.player.show{transform:translate(-50%,0);}
.p-row-top{display:flex;align-items:center;gap:10px;}
.p-row-seek{display:flex;align-items:center;gap:10px;}
.p-prev,.p-next{background:none;border:none;color:var(--parchment);cursor:pointer;font-size:1.2rem;padding:6px;opacity:.65;transition:opacity .2s,color .2s;}
.p-prev:hover,.p-next:hover{opacity:1;color:var(--gold);}
.p-toggle{background:var(--gold);color:var(--ink);border:none;width:42px;height:42px;flex:0 0 42px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;}
.p-toggle:hover{background:var(--gold-bright);}
.p-info{display:flex;flex-direction:column;min-width:0;flex:1;overflow:hidden;}
.p-title{font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;color:var(--parchment);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.p-status{font-size:.7rem;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;}
.p-seek{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:rgba(198,162,103,.25);cursor:pointer;border-radius:2px;}
.p-seek::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--gold);border-radius:50%;cursor:pointer;}
.p-seek::-moz-range-thumb{width:16px;height:16px;background:var(--gold);border:none;border-radius:50%;cursor:pointer;}
.p-time{font-family:var(--serif-head);font-size:.78rem;color:var(--parchment-dim);min-width:36px;text-align:right;}
.p-close{background:none;border:none;color:var(--parchment-dim);cursor:pointer;font-size:.9rem;margin-left:auto;padding:4px;}
.p-close:hover{color:var(--gold);}

/* ============ SCROLL REVEAL ============ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .nav-links{
    position:fixed;top:0;right:-100%;height:100vh;width:min(280px,80vw);
    background:rgba(12,12,16,.99);flex-direction:column;justify-content:center;align-items:flex-start;
    padding:40px;gap:24px;transition:right .35s;border-left:1px solid rgba(198,162,103,.2);
  }
  .nav-links.open{right:0;}
  .nav-links a{font-size:1rem;}
  .nav-toggle{display:flex;z-index:201;}
  .nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.active span:nth-child(2){opacity:0;}
  .nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .hero-inner{padding-bottom:70px;}
  .music-wrap{grid-template-columns:1fr;gap:32px;}
  .music-art{max-width:380px;margin:0 auto;}
  .story-block,.story-block.reverse{grid-template-columns:1fr;gap:24px;direction:ltr;}
  .story-img{max-width:420px;margin:0 auto;}
  .family-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;}
  .g-item.tall{grid-row:span 1;}
  .section{padding:90px 20px;}
}
@media (max-width:560px){
  body{font-size:17px;}
  .hero-bg{background-position:38% 14%;}
  .player{padding:10px 14px 12px;gap:6px;}
  .p-row-top{gap:8px;}
  .p-toggle{width:38px;height:38px;flex:0 0 38px;font-size:.9rem;}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:240px;}
  .g-item.wide,.g-item.tall{grid-column:span 1;grid-row:span 1;}
  .connect-form{flex-direction:column;}
  .connect-form .btn{border-left:none;border-top:1px solid rgba(198,162,103,.3);}
}

/* ---- music section image strip ---- */
.music-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px;}
.music-imgs figure{display:flex;flex-direction:column;}
.music-imgs img{aspect-ratio:4/3;object-fit:cover;width:100%;}
.music-imgs figcaption{margin-top:10px;font-style:italic;color:var(--parchment-dim);font-size:.9rem;}

/* ---- people section ---- */
.section-people{background:var(--charcoal-2);}
.people-hero{margin:0 auto 50px;max-width:880px;}
.people-hero img{width:100%;object-fit:cover;aspect-ratio:16/10;box-shadow:0 24px 60px rgba(0,0,0,.5);}
.people-hero figcaption{margin-top:16px;font-size:1.02rem;color:var(--parchment-dim);text-align:center;max-width:740px;margin-left:auto;margin-right:auto;}
.people-hero strong{color:var(--gold-bright);font-style:normal;}
.people-hero em{font-style:italic;}
.people-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.p-card{background:var(--charcoal);overflow:hidden;display:flex;flex-direction:column;transition:.3s;}
.p-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.4);}
.p-card img{width:100%;object-fit:cover;aspect-ratio:4/5;}
.p-card figcaption{padding:20px;}
.p-card h4{font-family:var(--serif-display);color:var(--gold);font-size:1.25rem;margin-bottom:6px;font-weight:700;}
.p-card p{font-size:.95rem;color:var(--parchment-dim);}
.people-note{text-align:center;margin:40px auto 0;font-style:italic;color:var(--parchment-dim);font-size:1rem;max-width:680px;}
.people-note strong{color:var(--gold);font-style:normal;}

/* ---- his words ---- */
.section-words{background:var(--charcoal);}
.words-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;}
.words-grid blockquote{
  font-family:var(--serif-display);font-style:italic;font-size:clamp(1.2rem,2.4vw,1.6rem);
  color:var(--gold);line-height:1.5;padding:34px 30px;background:var(--charcoal-2);
  border-left:2px solid var(--gold);
}

@media (max-width:900px){
  .music-imgs{grid-template-columns:1fr;}
  .people-grid{grid-template-columns:repeat(2,1fr);}
  .words-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .people-grid{grid-template-columns:1fr;}
}

/* ============================================================
   v-final structure styles
   ============================================================ */

/* ---- THE MUSIC: feature photo ---- */
.music-feature{margin:60px auto 0;max-width:760px;}
.music-feature img{width:100%;object-fit:cover;aspect-ratio:16/10;box-shadow:0 20px 50px rgba(0,0,0,.5);}
.music-feature figcaption{margin-top:16px;text-align:center;font-style:italic;color:var(--parchment-dim);font-size:1rem;max-width:640px;margin-left:auto;margin-right:auto;}
.music-feature strong{color:var(--gold-bright);font-style:normal;}

/* ---- HIS STORY: closing paragraph ---- */
.story-close{max-width:760px;margin:80px auto 0;text-align:center;}
.story-close p{font-family:var(--serif-display);font-style:italic;font-size:clamp(1.25rem,2.6vw,1.6rem);color:var(--parchment);line-height:1.6;}

/* ---- HIS FAMILY ---- */
.section-family{background:var(--charcoal-2);}
.family-hero{margin:0 auto 50px;max-width:900px;}
.family-hero img{width:100%;object-fit:cover;aspect-ratio:16/9;box-shadow:0 24px 60px rgba(0,0,0,.5);}
.family-hero figcaption{margin-top:16px;text-align:center;font-size:1.02rem;color:var(--parchment-dim);max-width:760px;margin-left:auto;margin-right:auto;}
.family-hero strong{color:var(--gold-bright);}
.family-text{max-width:760px;margin:0 auto;}
.family-text p{margin-bottom:18px;color:var(--parchment);font-size:1.05rem;}
.family-text strong{color:var(--gold-bright);}
.family-text em{font-style:italic;}
.lyric{
  font-family:var(--serif-display);font-style:italic;font-size:clamp(1.3rem,2.8vw,1.75rem);
  color:var(--gold);line-height:1.55;text-align:center;margin:30px 0;padding:24px 20px;
  border-top:1px solid rgba(198,162,103,.2);border-bottom:1px solid rgba(198,162,103,.2);
}

/* ---- FROM HIS DAUGHTERS ---- */
.section-daughters{background:var(--charcoal);}
.daughters-wrap{display:grid;grid-template-columns:minmax(280px,400px) 1fr;gap:54px;align-items:center;max-width:var(--maxw);margin:0 auto;}
.daughters-img img{width:100%;object-fit:cover;aspect-ratio:4/5;box-shadow:0 20px 50px rgba(0,0,0,.5);}
.daughters-letter p{margin-bottom:18px;color:var(--parchment);font-size:1.1rem;font-style:italic;line-height:1.7;}
.daughters-letter .signed{font-family:var(--serif-display);font-style:normal;color:var(--gold);letter-spacing:.08em;margin-top:8px;}

/* ---- HIS WORDS ---- */
.section-words{background:var(--charcoal-2);}
.words-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;}
.words-grid blockquote{
  font-family:var(--serif-display);font-style:italic;font-size:clamp(1.2rem,2.4vw,1.55rem);
  color:var(--gold);line-height:1.5;padding:34px 30px;background:var(--charcoal);
  border-left:2px solid var(--gold);
}

/* ---- CLOSING BAND ---- */
.closing-band{
  background:var(--charcoal-2);text-align:center;padding:80px 24px;
  border-top:1px solid rgba(198,162,103,.15);border-bottom:1px solid rgba(198,162,103,.15);
}
.closing-band p{
  font-family:var(--serif-display);font-style:italic;font-size:clamp(1.3rem,3vw,1.9rem);
  color:var(--parchment);line-height:1.6;max-width:780px;margin:0 auto;
}

/* ---- gallery: keep it clean ---- */
.section-gallery{background:var(--charcoal);}

@media (max-width:900px){
  .daughters-wrap{grid-template-columns:1fr;gap:28px;}
  .daughters-img{max-width:420px;margin:0 auto;}
  .words-grid{grid-template-columns:1fr;}
}

/* ============================================================
   MULTI-PAGE: sub-page headers, teaser blocks, lightbox carousel
   ============================================================ */

/* ---- sub-page top header (music.html, gallery.html) ---- */
body.subpage{padding-top:0;}
.page-head{
  padding:160px 24px 60px;text-align:center;max-width:760px;margin:0 auto;
  border-bottom:1px solid rgba(198,162,103,.12);
}
.page-head h1{
  font-family:var(--serif-display);font-size:clamp(2.6rem,6vw,4.2rem);
  color:var(--parchment);font-weight:700;line-height:1.05;margin:8px 0 0;
}
.page-head .kicker{font-family:var(--serif-head);letter-spacing:.42em;text-transform:uppercase;font-size:.8rem;color:var(--gold);}
.page-head .sub{font-family:var(--serif-body);font-style:italic;color:var(--parchment-dim);margin-top:16px;font-size:1.05rem;}
.site-nav.active,.nav-links a.active{color:var(--gold);}
.nav-links a.active{color:var(--gold);}

/* ---- TEASER blocks on the home page ---- */
.section-music-teaser{background:var(--charcoal);}
.teaser{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:54px;align-items:center;max-width:var(--maxw);margin:0 auto;}
.teaser-img img{width:100%;display:block;box-shadow:0 24px 60px rgba(0,0,0,.55);transition:transform .4s;}
.teaser-img:hover img{transform:scale(1.02);}
.teaser-copy .kicker{font-family:var(--serif-head);letter-spacing:.42em;text-transform:uppercase;font-size:.8rem;color:var(--gold);margin-bottom:14px;}
.teaser-copy h2{font-family:var(--serif-display);font-size:clamp(2.2rem,4.5vw,3.4rem);color:var(--parchment);font-weight:700;line-height:1.1;margin-bottom:16px;}
.teaser-copy p{color:var(--parchment-dim);font-size:1.05rem;margin-bottom:26px;}

.section-gallery-teaser{background:var(--charcoal-2);}
.teaser-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.teaser-grid a{overflow:hidden;display:block;}
.teaser-grid img{width:100%;height:240px;object-fit:cover;transition:transform .5s;filter:saturate(.92);}
.teaser-grid a:hover img{transform:scale(1.07);filter:saturate(1.1);}
.teaser-cta{text-align:center;margin-top:30px;}

/* ---- GALLERY page grid (clickable → lightbox) ---- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;}
.g-item{overflow:hidden;display:block;cursor:zoom-in;}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s;filter:saturate(.92);}
.g-item:hover img{transform:scale(1.06);filter:saturate(1.12);}
.g-item.tall{grid-row:span 2;}
.g-item.wide{grid-column:span 2;}
.gallery-note{text-align:center;margin-top:30px;font-style:italic;color:var(--parchment-dim);}

/* ---- LIGHTBOX / CAROUSEL ---- */
.lb{
  position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;
  background:rgba(8,8,10,.97);
}
.lb.open{display:flex;}
.lb-stage{max-width:92vw;max-height:84vh;display:flex;align-items:center;justify-content:center;}
.lb-stage img,.lb-stage video{max-width:92vw;max-height:84vh;width:auto;height:auto;box-shadow:0 30px 90px rgba(0,0,0,.7);border:1px solid rgba(198,162,103,.25);}
.lb-close,.lb-prev,.lb-next{
  position:fixed;background:rgba(20,20,24,.6);border:1px solid rgba(198,162,103,.3);color:var(--gold);
  cursor:pointer;font-size:1.6rem;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:.2s;backdrop-filter:blur(4px);
}
.lb-close{top:24px;right:24px;width:48px;height:48px;font-size:1.3rem;}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:54px;height:64px;font-size:2.2rem;}
.lb-prev{left:24px;}
.lb-next{right:24px;}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(198,162,103,.2);color:var(--gold-bright);}
.lb-count{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);font-family:var(--serif-head);letter-spacing:.2em;color:var(--parchment-dim);font-size:.85rem;}

@media (max-width:900px){
  .teaser{grid-template-columns:1fr;gap:28px;}
  .teaser-img{max-width:380px;margin:0 auto;}
  .teaser-grid{grid-template-columns:repeat(2,1fr);}
  .teaser-grid img{height:200px;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;}
  .g-item.tall{grid-row:span 1;}
  .page-head{padding-top:130px;}
  .lb-prev,.lb-next{width:42px;height:52px;font-size:1.7rem;}
}
@media (max-width:560px){
  .teaser-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:240px;}
  .g-item.wide,.g-item.tall{grid-column:span 1;grid-row:span 1;}
  .lb-close{top:14px;right:14px;}
  .lb-prev{left:8px;} .lb-next{right:8px;}
}

/* ---- From His Daughters: two stacked images ---- */
.daughters-imgs{display:flex;flex-direction:column;gap:14px;}
.daughters-imgs .daughters-img img{aspect-ratio:4/5;object-fit:cover;width:100%;box-shadow:0 14px 36px rgba(0,0,0,.45);}

/* ---- video items in the gallery ---- */
.g-item.video-item{position:relative;}
.g-item.video-item::after{
  content:"►";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(10,10,12,.55);border:1px solid rgba(198,162,103,.55);color:var(--gold);
  font-size:1.2rem;padding-left:3px;pointer-events:none;transition:.2s;
}
.g-item.video-item:hover::after{background:rgba(198,162,103,.85);color:var(--ink);}

/* ---- lightbox: give video its native controls room; hide the slide counter so it doesn't cover the scrubber ---- */
.lb.has-video .lb-count{display:none;}
.lb-stage video{max-height:80vh;}

/* ---- gallery: separated Videos / Photos sub-sections ---- */
.gallery-subhead{
  font-family:var(--serif-display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--gold);
  font-weight:700;text-align:center;margin:0 0 24px;
}
.gallery-subhead + .video-grid,
.gallery-subhead + .gallery-grid{margin-bottom:60px;}
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.video-grid .g-item{aspect-ratio:16/9;}
@media (max-width:760px){ .video-grid{grid-template-columns:1fr;} .video-grid .g-item{aspect-ratio:16/9;} }

/* ============================================================
   MOBILE PASS — no overflow, phone-first
   ============================================================ */
html,body{max-width:100%;overflow-x:hidden;}
h1,h2,h3,h4,p,blockquote,figcaption{overflow-wrap:break-word;word-wrap:break-word;}
img,video{max-width:100%;height:auto;}

@media (max-width:600px){
  /* hero name fits on small screens */
  .hero-name{font-size:clamp(2.6rem,14vw,4.5rem);line-height:.9;}
  .hero-inner{padding:0 18px 70px;}
  .hero-line{font-size:1.05rem;}
  .hero-fullname{font-size:.95rem;letter-spacing:.12em;}
  .hero-dates{font-size:.78rem;letter-spacing:.2em;}
  .hero-eyebrow{font-size:.72rem;letter-spacing:.28em;}
  .hero-actions .btn{padding:11px 20px;font-size:.78rem;letter-spacing:.14em;}

  .section{padding:70px 18px;}
  .section-head{margin-bottom:44px;}
  .section-head h2{font-size:clamp(1.9rem,7vw,2.6rem);}
  .kicker,.section-head .kicker{letter-spacing:.28em;font-size:.72rem;}

  /* music page */
  .page-head{padding:120px 18px 44px;}
  .page-head h1{font-size:clamp(2rem,9vw,3rem);}
  .track{grid-template-columns:26px 1fr;row-gap:2px;padding:13px 2px;}
  .t-feat{grid-column:2;font-size:.78rem;opacity:.8;}
  .music-feature figcaption,.family-hero figcaption,.story-close p,.closing-band p{font-size:1rem;}

  /* daughters */
  .daughters-letter p{font-size:1rem;}

  /* words */
  .words-grid blockquote{padding:24px 20px;font-size:1.1rem;}

  /* gallery */
  .gallery-subhead{font-size:1.5rem;}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:auto;}
  .gallery-grid .g-item{aspect-ratio:4/5;}
  .gallery-grid .g-item.wide,.gallery-grid .g-item.tall{grid-column:span 1;grid-row:span 1;}
  .video-grid{grid-template-columns:1fr;}

  /* teaser blocks */
  .teaser{grid-template-columns:1fr;gap:24px;}
  .teaser-img{max-width:100%;}
  .teaser-copy h2{font-size:clamp(1.8rem,7vw,2.4rem);}
  .teaser-grid{grid-template-columns:1fr 1fr;}
  .teaser-grid img{height:160px;}

  /* sticky player */
  .player{bottom:calc(10px + env(safe-area-inset-bottom, 0px));width:calc(100vw - 16px);padding:10px 12px 12px;gap:6px;}
  .p-title{font-size:.78rem;}

  /* lightbox */
  .lb-stage img,.lb-stage video{max-width:96vw;max-height:78vh;}
  .lb-close{top:10px;right:10px;width:40px;height:40px;}
  .lb-prev,.lb-next{width:38px;height:48px;font-size:1.5rem;}
  .lb-prev{left:6px;} .lb-next{right:6px;}

  /* footer */
  .site-footer{padding:60px 18px 40px;}
  .foot-quote{font-size:1.2rem;}
  .foot-name{font-size:.95rem;letter-spacing:.1em;}
}

@media (max-width:380px){
  .hero-name{font-size:13vw;}
  .section-head h2{font-size:6.5vw;}
}

/* ============================================================
   MOBILE NAV — hamburger + slide-out sidebar (with dim backdrop)
   ============================================================ */
@media (max-width:900px){
  .site-nav{flex-direction:row;align-items:center;padding:14px 20px;}
  .nav-toggle{display:flex;z-index:301;position:relative;}
  /* sidebar */
  .nav-links{
    position:fixed;top:0;right:-100%;height:100vh;height:100dvh;width:min(300px,82vw);
    background:rgba(13,13,17,.99);flex-direction:column;justify-content:flex-start;align-items:flex-start;
    gap:0;padding:90px 32px 32px;transition:right .35s cubic-bezier(.2,.85,.3,1);
    border-left:1px solid rgba(198,162,103,.25);box-shadow:-20px 0 60px rgba(0,0,0,.6);
    z-index:300;overflow-y:auto;
  }
  .nav-links.open{right:0;}
  .nav-links a{
    display:block;width:100%;font-size:1.05rem;letter-spacing:.14em;padding:18px 4px;
    border-bottom:1px solid rgba(198,162,103,.14);color:#f7efda;font-weight:500;
  }
  .nav-links a:last-child{border-bottom:none;}
  .nav-links a:hover,.nav-links a:active,.nav-links a.active{color:var(--gold);}
  /* dim backdrop behind the open sidebar (below the nav's stacking context so the sidebar stays clickable) */
  .nav-backdrop{
    position:fixed;inset:0;background:rgba(8,8,10,.6);z-index:380;opacity:0;pointer-events:none;
    transition:opacity .35s;
  }
  .nav-backdrop.show{opacity:1;pointer-events:auto;}
  /* hamburger → X */
  .nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.active span:nth-child(2){opacity:0;}
  .nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .hero{padding-top:0;}
  .page-head{padding-top:120px;}
}

/* ============================================================
   ANCHOR SCROLL — land at the top of sections, clear of the fixed nav
   ============================================================ */
.hero,.section,section[id],[id]{scroll-margin-top:84px;}
@media (max-width:900px){ .hero,.section,section[id],[id]{scroll-margin-top:72px;} }

/* ============================================================
   MOBILE HERO — show his whole face, no crop (natural aspect ratio)
   ============================================================ */
@media (max-width:760px){
  .hero{display:block;min-height:auto;padding:0;}
  .hero-bg{position:relative;inset:auto;width:100%;height:auto;aspect-ratio:628/863;background-position:center;}
  .hero-veil{background:linear-gradient(to bottom,transparent 28%,rgba(10,10,12,.45) 58%,rgba(10,10,12,.92) 86%,rgba(10,10,12,.99) 100%);}
  .hero-inner{position:absolute;bottom:0;left:0;right:0;padding:0 18px 24px;text-align:left;}
  .hero-scroll{display:none;}
}

/* ---- footer logo (the Brav Divi silhouette) ---- */
.foot-logo{display:block;height:96px;width:auto;margin:0 auto 26px;opacity:.92;}
@media (max-width:600px){ .foot-logo{height:74px;margin-bottom:20px;} }

/* ---- footer logo: bigger ---- */
.foot-logo{height:150px !important;margin-bottom:30px !important;}
@media (max-width:600px){ .foot-logo{height:110px !important;margin-bottom:22px !important;} }

/* ---- nav mark (small logo next to BRAV DIVI) ---- */
.nav-brand{display:inline-flex;align-items:center;gap:10px;}
.nav-mark{height:22px;width:auto;display:block;}
@media (max-width:900px){ .nav-mark{height:20px;} }

/* ---- hero eyebrow: stronger ---- */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--serif-head);letter-spacing:.34em;text-transform:uppercase;
  font-size:1rem;font-weight:600;color:var(--gold-bright);
  text-shadow:0 2px 14px rgba(0,0,0,.85);margin-bottom:18px;
}
.hero-eyebrow::before,.hero-eyebrow::after{content:"";height:1px;width:34px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
@media (max-width:600px){ .hero-eyebrow{font-size:.82rem;letter-spacing:.24em;gap:10px;} .hero-eyebrow::before,.hero-eyebrow::after{width:20px;} }

/* ---- daughters intro line ---- */
.daughters-intro{
  max-width:760px;margin:0 auto 50px;text-align:center;
  font-family:var(--serif-display);font-style:italic;font-size:clamp(1.2rem,2.6vw,1.6rem);
  color:var(--parchment);line-height:1.6;
}
.daughters-intro strong{color:var(--gold-bright);font-style:normal;}

/* ============================================================
   HERO v-final — quote-led, minimal
   ============================================================ */
.hero-line{
  font-family:var(--serif-display);font-style:italic;
  font-size:clamp(1.5rem,4vw,2.6rem);color:var(--parchment);line-height:1.45;
  max-width:640px;margin-bottom:0;text-shadow:0 3px 24px rgba(0,0,0,.9),0 1px 8px rgba(0,0,0,.8);
}
.hero-engraving{
  font-family:var(--serif-head);letter-spacing:.26em;text-transform:uppercase;
  font-size:.85rem;color:var(--parchment-dim);text-shadow:0 2px 14px rgba(0,0,0,.85);
  margin-bottom:30px;
}
.hero-rule{margin:22px 0;}
@media (max-width:600px){
  .hero-line{font-size:clamp(1.3rem,5.5vw,1.9rem);}
  .hero-engraving{font-size:.72rem;letter-spacing:.18em;}
  .hero-line br{display:inline;}  /* keep the line break; it reads as an epitaph */
}

/* ---- shop: real tee images ---- */
.shop-soon{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:880px;margin:0 auto;}
.shop-card{display:flex;flex-direction:column;background:#0a0a0c;border:1px solid rgba(198,162,103,.18);overflow:hidden;transition:.3s;}
.shop-card:hover{border-color:rgba(198,162,103,.4);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.5);}
.shop-card img{width:100%;aspect-ratio:1/1;object-fit:contain;background:#0a0a0c;}
.shop-card figcaption{
  padding:18px 20px;font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.16em;
  font-size:.85rem;color:var(--parchment);display:flex;justify-content:space-between;align-items:center;gap:12px;
  border-top:1px solid rgba(198,162,103,.14);
}
.shop-card .soon{font-style:italic;text-transform:none;letter-spacing:.06em;color:var(--gold);font-family:var(--serif-body);font-size:.95rem;}
@media (max-width:700px){ .shop-soon{grid-template-columns:1fr;max-width:420px;} }

/* ---- .btn-play: a CSS-drawn play triangle (no emoji, always the text color) ---- */
.btn-play{display:inline-flex;align-items:center;gap:11px;}
.btn-play::before{
  content:"";display:inline-block;width:0;height:0;
  border-style:solid;border-width:6px 0 6px 10px;
  border-color:transparent transparent transparent currentColor;
  flex:0 0 auto;
}

/* ---- story pull-quote (breaks up the prose, lighter than the .quote-band) ---- */
.story-pull{
  max-width:820px;margin:70px auto;text-align:center;padding:0 24px;
}
.story-pull p{
  font-family:var(--serif-display);font-style:italic;
  font-size:clamp(1.5rem,3.8vw,2.4rem);color:var(--gold);line-height:1.45;
}
@media (max-width:600px){ .story-pull{margin:48px auto;} .story-pull p{font-size:clamp(1.3rem,5.5vw,1.8rem);} }

/* ---- text-only story block (no photo) ---- */
.story-block.story-text-only{grid-template-columns:1fr;max-width:760px;margin:0 auto;}
.story-block.story-text-only .story-copy h3{text-align:left;}

/* ============ MUSIC PAGE — "Meant 2 Be" marquee feature ============ */
.marquee-block{
  max-width:760px;margin:0 auto;padding:70px 24px 50px;text-align:center;
  border-bottom:1px solid rgba(198,162,103,.14);
}
.marquee-block .kicker{margin-bottom:14px;}
.marquee-title{
  font-family:var(--serif-display);font-size:clamp(2.6rem,7vw,4.4rem);color:var(--gold);
  font-weight:800;line-height:1;margin-bottom:14px;text-shadow:0 2px 30px rgba(198,162,103,.18);
}
.marquee-note{
  font-family:var(--serif-body);font-style:italic;color:var(--parchment-dim);
  font-size:1.1rem;max-width:560px;margin:0 auto 28px;line-height:1.6;
}
.marquee-play{
  display:inline-flex;align-items:center;gap:11px;margin:0 auto 32px;justify-content:center;
  background:var(--gold);color:var(--ink);border:none;
  font-family:var(--serif-head);text-transform:uppercase;letter-spacing:.22em;font-size:.85rem;font-weight:600;
  padding:15px 34px;cursor:pointer;transition:.25s;
}
.marquee-play:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 8px 28px rgba(198,162,103,.3);}
.marquee-play.playing{background:var(--gold);}
.marquee-play::before{content:"";display:inline-block;width:0;height:0;border-style:solid;border-width:6px 0 6px 10px;border-color:transparent transparent transparent currentColor;}
.marquee-quotes{list-style:none;margin:0 auto;max-width:600px;}
.marquee-quotes li{
  font-family:var(--serif-display);font-style:italic;color:var(--parchment);
  font-size:1.05rem;line-height:1.5;padding:14px 0;border-top:1px solid rgba(198,162,103,.1);
}
.marquee-quotes li:first-child{border-top:none;}
/* the #1 track row, marked */
.track.is-marquee{background:rgba(198,162,103,.07);}
.track.is-marquee .t-feat{color:var(--gold);font-style:normal;letter-spacing:.06em;}
@media (max-width:600px){ .marquee-block{padding:48px 18px 36px;} .marquee-title{font-size:clamp(2.2rem,9vw,3rem);} .marquee-note,.marquee-quotes li{font-size:1rem;} }
