/* ═══════════════════════════════════════════════════════
   SELASSIE IBRAHIM × REFFA — landing page
   Cinematic gold-on-black design system
   ═══════════════════════════════════════════════════════ */

:root{
  --black:#0a0907;
  --coal:#12100c;
  --coal-2:#1a1712;
  --ivory:#f3ead8;
  --ivory-dim:#bdb29c;
  --gold:#d8ab4e;
  --gold-hi:#f6e27a;
  --gold-lo:#a87f2e;
  --gold-grad:linear-gradient(135deg,#f6e27a 0%,#d8ab4e 45%,#a87f2e 100%);
  --serif:"Cinzel",serif;
  --display:"Italiana",serif;
  --script:"Pinyon Script",cursive;
  --editorial:"Cormorant Garamond",serif;
  --sans:"Jost",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--ivory);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.7;
  letter-spacing:.01em;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:var(--black)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* scrollbar */
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:#3a3122;border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-lo)}

.container{width:min(1200px,90vw);margin-inline:auto}
.section{padding:clamp(90px,12vw,160px) 0;position:relative}

/* ═══════════ PRELOADER ═══════════ */
.preloader{
  position:fixed;inset:0;z-index:1000;
  background:var(--black);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .9s var(--ease),visibility .9s;
}
.preloader.is-done{opacity:0;visibility:hidden}
.preloader-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.preloader-star{width:84px;height:84px}
.preloader-star path{
  stroke-dasharray:340;stroke-dashoffset:340;
  animation:starDraw 1.6s var(--ease) forwards;
}
@keyframes starDraw{to{stroke-dashoffset:0}}
.preloader-word{
  font-family:var(--script);font-size:30px;
  color:var(--gold);opacity:0;animation:fadeUp .8s .9s var(--ease) forwards;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ═══════════ CURSOR GLOW ═══════════ */
.cursor-glow{
  position:fixed;width:520px;height:520px;border-radius:50%;
  pointer-events:none;z-index:1;
  background:radial-gradient(circle,rgba(216,171,78,.07) 0%,transparent 65%);
  transform:translate(-50%,-50%);
  left:-600px;top:-600px;
  transition:opacity .4s;
}
@media (hover:none){.cursor-glow{display:none}}

/* ═══════════ NAV ═══════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:800;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,4vw,56px);
  transition:background .5s,padding .5s,border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(10,9,7,.82);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  padding-block:14px;
  border-bottom-color:rgba(216,171,78,.14);
}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.22em;text-transform:uppercase}
.logo-star{width:20px;height:20px;flex:none;fill:var(--gold);filter:drop-shadow(0 0 8px rgba(216,171,78,.55))}
.nav-links{display:none;gap:clamp(16px,2.2vw,34px)}
.nav-links a{
  font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ivory-dim);
  position:relative;padding:6px 0;transition:color .3s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--gold);transition:width .4s var(--ease);
}
.nav-links a:hover{color:var(--ivory)}
.nav-links a:hover::after{width:100%}
.nav-cta{font-size:12px}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:5}
.nav-burger span{display:block;width:26px;height:1.5px;background:var(--gold);transition:transform .4s var(--ease),opacity .3s}
.nav.menu-open .nav-burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.menu-open .nav-burger span:nth-child(2){opacity:0}
.nav.menu-open .nav-burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ═══════════ BUTTONS ═══════════ */
.btn{
  display:inline-block;font-family:var(--sans);font-weight:500;
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  padding:14px 32px;border:1px solid transparent;cursor:pointer;
  position:relative;overflow:hidden;transition:color .35s,border-color .35s,box-shadow .35s,transform .35s;
}
.btn-lg{padding:18px 44px;font-size:14px}
.btn-gold{
  background:var(--gold-grad);color:#241a08;border-color:rgba(246,226,122,.4);
  box-shadow:0 0 0 rgba(216,171,78,0);
}
.btn-gold:hover{box-shadow:0 8px 36px rgba(216,171,78,.35);transform:translateY(-2px)}
.btn-ghost{color:var(--ivory);border-color:rgba(243,234,216,.35)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-hi);box-shadow:inset 0 0 24px rgba(216,171,78,.08);transform:translateY(-2px)}

.inline-link{
  color:var(--gold-hi);border-bottom:1px solid rgba(216,171,78,.5);
  transition:color .3s,border-color .3s;
}
.inline-link:hover{color:var(--ivory);border-color:var(--ivory)}

/* ═══════════ HERO ═══════════ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:center;
  overflow:hidden;
  padding:clamp(110px,14vh,150px) 0 clamp(60px,8vh,90px);
}
.hero-bg{position:absolute;inset:-6%}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;object-position:center 25%;
  animation:kenburns 30s ease-in-out infinite alternate;
  filter:saturate(.9) brightness(.45) blur(14px);
  transform:scale(1.05);
}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.16) translate(-1.5%,1.5%)}}
.hero-veil{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 70% at 22% 45%,rgba(216,171,78,.10),transparent 65%),
    linear-gradient(to bottom,rgba(10,9,7,.8) 0%,rgba(10,9,7,.55) 40%,rgba(10,9,7,.7) 75%,var(--black) 100%),
    radial-gradient(ellipse 140% 90% at 50% 40%,transparent 35%,rgba(10,9,7,.85) 100%);
}
#dust{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}

.hero-grid{
  position:relative;z-index:3;
  width:min(1340px,96vw);margin-inline:auto;
  display:grid;grid-template-columns:max-content 1fr;
  gap:clamp(28px,3vw,56px);align-items:center;
}
.hero-copy{max-width:640px}
.hero-script{
  font-family:var(--script);font-size:clamp(26px,3.4vw,40px);
  color:var(--gold-hi);line-height:1.2;
  text-shadow:0 0 30px rgba(216,171,78,.35);
}
.hero-script strong{
  font-family:var(--serif);font-weight:700;font-size:.62em;
  letter-spacing:.3em;color:var(--gold);vertical-align:middle;
}
.hero-name{
  font-weight:400;line-height:.92;
  margin:18px 0 26px;
  display:flex;flex-direction:column;
}
.hn-first{
  font-family:var(--display);
  font-size:clamp(64px,10.5vw,148px);
  letter-spacing:.04em;text-transform:uppercase;
  background:linear-gradient(180deg,#fdf6dd 0%,#e9cb84 55%,#c79a45 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 12px 44px rgba(216,171,78,.22));
}
.hn-last{
  font-family:var(--script);
  font-size:clamp(58px,9vw,128px);
  color:var(--ivory);
  margin:-.28em 0 0 clamp(40px,12vw,200px);
  transform:rotate(-3deg);
  text-shadow:0 8px 40px rgba(0,0,0,.6);
}
.hero-roles{
  font-size:clamp(11px,1.3vw,13.5px);letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;
}
.hero-bio{
  font-family:var(--editorial);font-size:clamp(18px,2vw,22px);font-weight:500;
  color:var(--ivory-dim);max-width:520px;line-height:1.6;
}
.hero-cta{display:flex;gap:18px;flex-wrap:wrap;margin-top:38px}

.hero-portrait{position:relative;justify-self:end;width:min(640px,100%)}
.hp-frame{
  position:relative;overflow:hidden;
  border:1px solid rgba(216,171,78,.45);
  padding:14px;
  background:rgba(10,9,7,.5);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  box-shadow:0 40px 100px rgba(0,0,0,.65),0 0 60px rgba(216,171,78,.08);
}
.hp-frame::after{
  content:"";position:absolute;inset:14px;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(216,171,78,.25);
}
.hp-frame img{
  width:100%;aspect-ratio:4/4.6;object-fit:cover;object-position:32% 18%;
  transition:transform 1.4s var(--ease);
}
.hero-portrait:hover .hp-frame img{transform:scale(1.05)}
.hero-portrait figcaption{
  margin-top:16px;text-align:center;
  font-family:var(--editorial);font-style:italic;font-size:15px;color:var(--ivory-dim);
  letter-spacing:.06em;
}

/* hero load choreography */
.hero-script,.hn-first,.hn-last,.hero-roles,.hero-bio,.hero-cta,.hero-portrait{
  opacity:0;transform:translateY(34px);
  transition:opacity 1.1s var(--ease),transform 1.1s var(--ease);
}
.hn-last{transform:translateY(34px) rotate(-3deg)}
body.is-loaded .hero-script{opacity:1;transform:none;transition-delay:.15s}
body.is-loaded .hn-first{opacity:1;transform:none;transition-delay:.3s}
body.is-loaded .hn-last{opacity:1;transform:rotate(-3deg);transition-delay:.5s}
body.is-loaded .hero-roles{opacity:1;transform:none;transition-delay:.7s}
body.is-loaded .hero-bio{opacity:1;transform:none;transition-delay:.82s}
body.is-loaded .hero-cta{opacity:1;transform:none;transition-delay:.95s}
body.is-loaded .hero-portrait{opacity:1;transform:none;transition-delay:.6s}

/* scroll cue */
.hero-scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
}
.hero-scroll-line{
  display:block;width:1px;height:64px;background:linear-gradient(to bottom,var(--gold),transparent);
  position:relative;overflow:hidden;
}
.hero-scroll-line::after{
  content:"";position:absolute;left:0;top:-40%;width:100%;height:40%;
  background:var(--gold-hi);animation:scrollDrip 2s ease-in-out infinite;
}
@keyframes scrollDrip{to{top:110%}}

/* ═══════════ MARQUEE ═══════════ */
.marquee{
  position:relative;z-index:4;
  background:var(--gold-grad);
  padding:16px 0;overflow:hidden;
  transform:rotate(-1.2deg) scale(1.02);
  box-shadow:0 18px 60px rgba(216,171,78,.18);
}
.marquee-track{
  display:flex;align-items:center;gap:36px;width:max-content;
  animation:marquee 28s linear infinite;
}
.marquee-track span{
  font-family:var(--serif);font-weight:600;font-size:15px;
  letter-spacing:.26em;text-transform:uppercase;color:#241a08;white-space:nowrap;
}
.marquee-track i{font-style:normal;color:#241a08;font-size:13px}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ═══════════ TYPO HELPERS ═══════════ */
.kicker{
  font-size:12px;letter-spacing:.45em;text-transform:uppercase;
  color:var(--gold);margin-bottom:22px;
  display:flex;align-items:center;gap:16px;
}
.kicker::after{content:"";height:1px;width:64px;background:linear-gradient(to right,var(--gold),transparent)}
h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(34px,5vw,60px);line-height:1.12;
  color:var(--ivory);margin-bottom:28px;
}
h2 em{
  font-style:normal;
  background:var(--gold-grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.lead{
  font-family:var(--editorial);font-size:clamp(19px,2.2vw,23px);font-weight:500;
  color:var(--ivory-dim);line-height:1.6;margin-bottom:22px;
}
.lead strong{color:var(--gold-hi);font-weight:600}
.lead-narrow{max-width:760px}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(44px);transition:opacity 1s var(--ease),transform 1s var(--ease);transition-delay:var(--d,0s)}
.reveal.in-view{opacity:1;transform:none}

/* ═══════════ HER STORY ═══════════ */
.story{
  background:
    radial-gradient(ellipse 55% 45% at 12% 8%,rgba(216,171,78,.06),transparent 60%),
    var(--black);
}
.story-media{position:relative;max-width:480px}
.story-sig{
  position:absolute;right:-6%;bottom:-7%;z-index:3;
  font-family:var(--script);font-size:clamp(54px,7vw,96px);
  color:var(--gold-hi);transform:rotate(-7deg);
  text-shadow:0 6px 30px rgba(0,0,0,.8),0 0 40px rgba(216,171,78,.3);
  pointer-events:none;
}
.story-copy p{color:var(--ivory-dim);margin-bottom:18px}
.story-quote{
  margin-top:34px;padding:26px 30px;
  border-left:2px solid var(--gold);
  background:linear-gradient(to right,rgba(216,171,78,.07),transparent 70%);
}
.story-quote p{
  font-family:var(--editorial);font-style:italic;font-weight:500;
  font-size:clamp(19px,2.2vw,24px);color:var(--ivory);margin-bottom:12px;
}
.story-quote cite{
  font-style:normal;font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);
}

/* ═══════════ ABOUT / FESTIVAL ═══════════ */
.about{
  background:
    radial-gradient(ellipse 60% 40% at 85% 10%,rgba(216,171,78,.05),transparent 60%),
    var(--black);
}
.split{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,7vw,100px);align-items:center}
.split-rev{grid-template-columns:1.1fr 1fr}
.about-media{position:relative}
.frame-img{position:relative;overflow:hidden}
.frame-img img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  transition:transform 1.2s var(--ease);
}
.frame-img:hover img{transform:scale(1.05)}
.frame-offset::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  border:1px solid rgba(216,171,78,.5);
  transform:translate(16px,16px);
  transition:transform .6s var(--ease);
}
.frame-offset:hover::before{transform:translate(8px,8px)}
.about-media-card{
  position:absolute;right:-12%;bottom:-10%;width:46%;
  border:6px solid var(--coal);
  box-shadow:0 30px 70px rgba(0,0,0,.6);
}
.about-media-card img{width:100%;aspect-ratio:3/4.2;object-fit:cover}
.about-copy p{color:var(--ivory-dim);margin-bottom:18px}
.about-pillars{list-style:none;margin-top:34px;display:grid;grid-template-columns:1fr 1fr;gap:24px 32px}
.about-pillars li{
  font-size:14.5px;color:var(--ivory-dim);line-height:1.6;
  padding-left:18px;border-left:1px solid rgba(216,171,78,.4);
}
.about-pillars strong{
  display:block;font-family:var(--serif);font-weight:600;font-size:15px;
  letter-spacing:.08em;color:var(--gold-hi);margin-bottom:6px;
}

/* ═══════════ STATS ═══════════ */
.stats{
  border-block:1px solid rgba(216,171,78,.16);
  background:linear-gradient(to bottom,rgba(216,171,78,.04),transparent);
  padding:clamp(54px,7vw,84px) 0;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat-num{
  font-family:var(--serif);font-weight:700;font-size:clamp(40px,6vw,72px);line-height:1;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:block;font-variant-numeric:tabular-nums;
}
.stat-lab{
  display:block;margin-top:14px;
  font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--ivory-dim);
}

/* ═══════════ QUOTE ═══════════ */
.quote-band{position:relative;padding:clamp(110px,15vw,190px) 0;overflow:hidden;text-align:center}
.quote-bg{position:absolute;inset:0}
.quote-bg img{width:100%;height:120%;object-fit:cover;object-position:center 25%;filter:brightness(.6)}
.quote-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom,var(--black) 0%,rgba(10,9,7,.72) 30%,rgba(10,9,7,.72) 70%,var(--black) 100%);
}
.quote-inner{position:relative;z-index:2;max-width:880px}
.quote-mark{width:52px;height:52px;color:var(--gold);margin-bottom:26px;opacity:.85}
.quote-band blockquote{
  font-family:var(--editorial);font-weight:500;
  font-size:clamp(26px,4vw,44px);line-height:1.35;color:var(--ivory);
}
.quote-band blockquote em{color:var(--gold-hi)}
.quote-band cite{
  display:block;margin-top:34px;font-style:normal;
  font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
}

/* ═══════════ LEGACY ═══════════ */
.legacy{background:var(--black)}
.legacy-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:1px;margin-top:64px;
  background:rgba(216,171,78,.18);
  border:1px solid rgba(216,171,78,.18);
}
.lcard{
  background:var(--coal);padding:42px 34px;position:relative;overflow:hidden;
  transition:background .5s;
}
.lcard::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(216,171,78,.12),transparent 55%);
  opacity:0;transition:opacity .5s;
}
.lcard:hover::before{opacity:1}
.lcard:hover{background:var(--coal-2)}
.lcard-no{
  font-family:var(--editorial);font-style:italic;font-size:50px;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(216,171,78,.55);
  display:block;margin-bottom:24px;
}
.lcard h3{
  font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.04em;
  color:var(--ivory);margin-bottom:8px;
}
.lcard-meta{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.lcard p{font-size:14.5px;color:var(--ivory-dim)}
.lcard p strong{color:var(--gold-hi);font-weight:500}

/* ═══════════ GALLERY ═══════════ */
.gallery{
  background:
    radial-gradient(ellipse 50% 35% at 10% 0%,rgba(216,171,78,.05),transparent 60%),
    var(--black);
}
.gallery-filters{display:flex;gap:12px;flex-wrap:wrap;margin:42px 0 36px}
.gf-btn{
  font-family:var(--sans);font-size:12px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ivory-dim);background:none;cursor:pointer;
  border:1px solid rgba(243,234,216,.22);padding:11px 24px;
  transition:all .35s;
}
.gf-btn:hover{border-color:var(--gold);color:var(--gold-hi)}
.gf-btn.is-active{
  background:var(--gold-grad);color:#241a08;border-color:transparent;
  box-shadow:0 6px 24px rgba(216,171,78,.25);
}
.gallery-grid{columns:3;column-gap:18px}
.g-item{
  break-inside:avoid;margin-bottom:18px;position:relative;overflow:hidden;
  cursor:zoom-in;
}
.g-item img{
  width:100%;transition:transform 1s var(--ease),filter .6s;
  filter:saturate(.92);
}
.g-item:hover img{transform:scale(1.06);filter:saturate(1.1)}
.g-item figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:42px 20px 16px;
  font-family:var(--editorial);font-style:italic;font-size:16px;color:var(--ivory);
  background:linear-gradient(to top,rgba(10,9,7,.88),transparent);
  opacity:0;transform:translateY(12px);
  transition:opacity .5s,transform .5s var(--ease);
  pointer-events:none;
}
.g-item:hover figcaption{opacity:1;transform:none}
.g-item.is-hidden{display:none}

/* ═══════════ LIGHTBOX ═══════════ */
.lightbox{
  position:fixed;inset:0;z-index:950;
  background:rgba(8,7,5,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .4s;
}
.lightbox[hidden]{display:none}
.lightbox.is-open{opacity:1}
.lb-stage{position:relative;max-width:86vw;max-height:84vh;display:flex;flex-direction:column;align-items:center}
.lb-stage img{
  max-width:86vw;max-height:76vh;object-fit:contain;
  box-shadow:0 30px 90px rgba(0,0,0,.7);
  border:1px solid rgba(216,171,78,.25);
}
.lb-stage figcaption{
  margin-top:18px;font-family:var(--editorial);font-style:italic;
  font-size:18px;color:var(--ivory-dim);
}
.lb-count{
  position:absolute;top:-34px;right:0;
  font-size:11px;letter-spacing:.3em;color:var(--gold);
}
.lb-close,.lb-prev,.lb-next{
  position:absolute;background:none;border:0;cursor:pointer;
  color:var(--ivory-dim);transition:color .3s,transform .3s;z-index:2;
  font-family:var(--editorial);
}
.lb-close{top:26px;right:36px;font-size:46px;line-height:1}
.lb-close:hover{color:var(--gold-hi);transform:rotate(90deg)}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);font-size:64px;padding:20px}
.lb-prev{left:18px}.lb-next{right:18px}
.lb-prev:hover,.lb-next:hover{color:var(--gold-hi)}

/* ═══════════ PROGRAMME / TIMELINE ═══════════ */
.programme{background:var(--coal)}
.timeline{position:relative;margin-top:70px;padding-left:clamp(28px,5vw,60px)}
.timeline::before{
  content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;
  background:linear-gradient(to bottom,var(--gold),rgba(216,171,78,.12));
}
.t-item{position:relative;padding-bottom:clamp(44px,6vw,70px);max-width:680px}
.t-item:last-child{padding-bottom:0}
.t-dot{
  position:absolute;left:calc(-1 * clamp(28px,5vw,60px) + 1px);top:8px;
  width:11px;height:11px;border-radius:50%;
  background:var(--gold-grad);
  box-shadow:0 0 0 5px rgba(216,171,78,.14),0 0 18px rgba(216,171,78,.6);
}
.t-dot-star{
  width:auto;height:auto;background:none;border-radius:0;box-shadow:none;
  color:var(--gold-hi);font-size:20px;line-height:1;top:2px;
  left:calc(-1 * clamp(28px,5vw,60px) - 4px);
  text-shadow:0 0 18px rgba(246,226,122,.8);
  animation:starPulse 2.4s ease-in-out infinite;
}
@keyframes starPulse{50%{text-shadow:0 0 34px rgba(246,226,122,1);transform:scale(1.18)}}
.t-date{
  font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  display:block;margin-bottom:10px;
}
.t-item h3{
  font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.6vw,27px);
  color:var(--ivory);margin-bottom:10px;
}
.t-item p{color:var(--ivory-dim);font-size:15.5px}
.t-item-grand h3{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-size:clamp(24px,3.4vw,34px);
}

/* ═══════════ EXPERIENCE / CTA ═══════════ */
.partner{position:relative;padding:clamp(120px,16vw,210px) 0;overflow:hidden;text-align:center}
.partner-bg{position:absolute;inset:0}
.partner-bg img{width:100%;height:115%;object-fit:cover;object-position:center 20%;filter:brightness(.5) saturate(.9)}
.partner-bg::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%,rgba(216,171,78,.10),transparent 70%),
    linear-gradient(to bottom,var(--coal) 0%,rgba(10,9,7,.78) 28%,rgba(10,9,7,.82) 72%,var(--black) 100%);
}
.partner-inner{position:relative;z-index:2;max-width:820px}
.partner-inner .kicker{justify-content:center}
.partner-inner .kicker::after{display:none}
.partner-inner .lead{margin-inline:auto;max-width:640px}
.partner-cta{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:44px}

/* ═══════════ FOOTER ═══════════ */
.footer{border-top:1px solid rgba(216,171,78,.16);background:var(--black)}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr .8fr;
  gap:clamp(30px,5vw,70px);
  padding:clamp(60px,8vw,90px) 0 50px;
}
.f-brand p{margin-top:20px;font-size:14px;color:var(--ivory-dim);max-width:300px}
.f-col h4{
  font-family:var(--serif);font-weight:600;font-size:13px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.f-col p{font-size:14px;color:var(--ivory-dim);margin-bottom:14px}
.f-col a{transition:color .3s}
.f-col a:hover{color:var(--gold-hi)}
.f-social{display:flex;flex-direction:column;gap:8px}
.footer-bar{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:24px 0;margin-top:10px;
  border-top:1px solid rgba(243,234,216,.08);
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:#6e6552;
}
.footer-bar a{color:var(--gold);transition:color .3s}
.footer-bar a:hover{color:var(--gold-hi)}
.footer .container{width:min(1200px,90vw)}
.footer-bar{width:min(1200px,90vw);margin-inline:auto}

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width:1024px){
  .gallery-grid{columns:2}
  .footer-grid{grid-template-columns:1fr 1fr}
  .about-pillars{grid-template-columns:1fr}
}
@media (max-width:920px){
  .hero{padding-top:120px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-copy{max-width:none}
  .hero-portrait{justify-self:center;width:min(420px,86vw)}
  .hn-last{margin-left:clamp(60px,18vw,160px)}
}
@media (max-width:860px){
  .split,.split-rev{grid-template-columns:1fr}
  .about-media,.story-media{max-width:480px;margin-inline:auto;margin-bottom:30px}
  .split-rev .about-media{order:-1}
  .nav-cta{font-size:11px;padding:11px 20px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:44px 20px}
}
@media (max-width:560px){
  .gallery-grid{columns:1}
  .footer-grid{grid-template-columns:1fr}
  .story-sig{right:0}
  .about-media-card{right:0}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;text-align:center}
  .lb-prev,.lb-next{font-size:44px;padding:12px}
}

/* ═══════════ REDUCED MOTION ═══════════ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .reveal,.hero-script,.hn-first,.hn-last,.hero-roles,.hero-bio,.hero-cta,.hero-portrait{opacity:1;transform:none}
}
