/* ==========================================================================
   MUNEEBA SHEIKH — LUXURY ARTIST PORTFOLIO
   Premium dark cinematic design system
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  --bg-0:#07050a;
  --bg-1:#0d0810;
  --bg-2:#15101c;
  --bg-3:#1c1426;
  --plum:#2a1a32;
  --plum-deep:#1a0f22;
  --purple:#5e2c7a;
  --purple-soft:#7a3f97;
  --rose:#d8a8b9;
  --rose-gold:#e6b89c;
  --rose-glow:#ffb8c6;
  --pink-soft:#ffd6df;
  --gold:#d4a76a;
  --gold-warm:#f0c987;
  --pearl:#f6eee5;
  --pearl-dim:#cfc4b8;
  --muted:#8b7d8f;
  --line:rgba(255,255,255,.07);
  --line-strong:rgba(255,255,255,.14);
  --glass:rgba(255,255,255,.04);
  --glass-strong:rgba(255,255,255,.08);

  --grad-rose:linear-gradient(135deg,#ffb8c6 0%,#d8a8b9 35%,#e6b89c 70%,#d4a76a 100%);
  --grad-plum:linear-gradient(180deg,rgba(42,26,50,.5),rgba(7,5,10,1));
  --grad-aurora:radial-gradient(60% 50% at 20% 10%,rgba(122,63,151,.35) 0%,transparent 60%),radial-gradient(50% 50% at 80% 20%,rgba(255,184,198,.18) 0%,transparent 60%),radial-gradient(70% 60% at 50% 100%,rgba(212,167,106,.18) 0%,transparent 60%);

  --shadow-soft:0 10px 40px -10px rgba(0,0,0,.6);
  --shadow-glow:0 20px 80px -30px rgba(255,184,198,.35),0 0 60px -20px rgba(122,63,151,.4);

  --radius-sm:10px;
  --radius:16px;
  --radius-lg:28px;
  --radius-xl:36px;

  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --font-display:"Cormorant Garamond","Playfair Display",Georgia,serif;
  --font-sans:"Inter","Helvetica Neue",Arial,sans-serif;

  --maxw:1200px;
  --page-pad:clamp(20px,4vw,48px);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  background:var(--bg-0);
  color:var(--pearl);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  min-height:100vh;
  font-size:16px;
}
img,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
[hidden]{display:none!important}
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:500;letter-spacing:-.01em;line-height:1.1;margin:0 0 .5em}
p{margin:0 0 1em}

/* ---------- Background ambience ---------- */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(1200px 800px at 80% -10%,rgba(122,63,151,.18),transparent 60%),
    radial-gradient(900px 700px at -10% 30%,rgba(255,184,198,.08),transparent 60%),
    radial-gradient(700px 600px at 50% 110%,rgba(212,167,106,.08),transparent 60%),
    var(--bg-0);
  z-index:-2;
  pointer-events:none;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.16;
  z-index:-1;
  pointer-events:none;
  mix-blend-mode:overlay;
}

/* ---------- Container & utility ---------- */
.container{
  width:min(var(--maxw),calc(100vw - (var(--page-pad) * 2)));
  max-width:none;
  margin:0 auto;
  padding:0;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-sans);font-size:11px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--rose);
}
.eyebrow::before{
  content:"";width:32px;height:1px;
  background:linear-gradient(90deg,transparent,var(--rose-glow));
}
.section-title{
  font-size:clamp(2.2rem,5vw,4.2rem);
  font-weight:400;letter-spacing:-.02em;
  background:linear-gradient(180deg,#fff 0%,#cfc4b8 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin:.4em 0 .3em;
}
.section-title em{
  font-style:italic;
  background:var(--grad-rose);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-lede{
  max-width:640px;color:var(--pearl-dim);font-size:1.05rem;
}
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:22px;
  margin-bottom:42px;
}
.section-actions{display:flex;align-items:center;flex-wrap:wrap;gap:12px}
.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
section{position:relative;padding:120px 0}
section.compact{padding:80px 0}
#vision{scroll-margin-top:110px}

/* ---------- Floating brand mark ---------- */
.floating-brand{
  --scroll-progress:0deg;
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:180;
  width:56px;
  height:56px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:
    conic-gradient(from -90deg,var(--gold-warm) var(--scroll-progress),rgba(216,168,185,.28) 0),
    rgba(255,255,255,.16);
  border:1px solid rgba(240,201,135,.54);
  padding:3px;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.95),0 10px 30px -22px rgba(240,201,135,.85),inset 0 1px 0 rgba(255,255,255,.95);
  transition:transform .35s var(--ease),filter .35s var(--ease);
  animation:floatingBrand 4.8s ease-in-out infinite;
  isolation:isolate;
  overflow:hidden;
}
.floating-brand::before{
  content:"";
  position:absolute;
  inset:3px;
  z-index:0;
  border-radius:inherit;
  background:
    radial-gradient(circle at 50% 100%,rgba(212,167,106,.18),transparent 58%),
    linear-gradient(180deg,#fffaf3 0%,#f4e7da 100%);
  border:1px solid rgba(122,63,151,.08);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.7),inset 0 -10px 18px rgba(212,167,106,.1);
}
.floating-brand::after{
  content:"";
  position:relative;
  z-index:1;
  width:12px;
  height:12px;
  border-top:2px solid var(--plum-deep);
  border-left:2px solid var(--plum-deep);
  transform:translateY(3px) rotate(45deg);
}
.floating-brand img{
  display:none;
}
.floating-brand:hover{
  transform:translateY(-4px) scale(1.04);
  filter:brightness(1.08);
}
@keyframes floatingBrand{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

/* ---------- Buttons ---------- */
.btn{
  --bg:transparent;
  --fg:var(--pearl);
  --bd:rgba(255,255,255,.18);
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:14px 26px;border-radius:999px;
  background:var(--bg);color:var(--fg);
  border:1px solid var(--bd);
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  transition:transform .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
  overflow:hidden;isolation:isolate;
}
.btn .arrow{display:inline-block;transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:var(--grad-rose);opacity:0;transition:opacity .35s var(--ease);
  z-index:-1;
}
.btn:hover{transform:translateY(-2px);border-color:transparent;color:#1a0f22;box-shadow:var(--shadow-glow)}
.btn:hover::before{opacity:1}
.btn-ghost{--bd:rgba(255,255,255,.12)}
.btn-primary{
  background:var(--grad-rose);color:#1a0f22;border-color:transparent;
  box-shadow:0 10px 40px -15px rgba(255,184,198,.55);
}
.btn-primary:hover{box-shadow:0 20px 60px -15px rgba(255,184,198,.7);transform:translateY(-2px)}
.btn-primary::before{display:none}

/* ---------- Preloader ---------- */
.preloader{
  position:fixed;inset:0;z-index:9999;
  background:
    radial-gradient(900px 620px at 18% 4%,rgba(216,168,185,.24),transparent 62%),
    radial-gradient(760px 560px at 86% 12%,rgba(240,201,135,.24),transparent 60%),
    linear-gradient(180deg,#fffaf3 0%,#f7efe6 54%,#eadfd4 100%);
  display:grid;place-items:center;
  transition:opacity .55s var(--ease),visibility .55s var(--ease);
}
.preloader.hide{opacity:0;visibility:hidden}
.preloader-inner{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:28px;
}
.preloader-logo{
  width:122px;
  height:auto;
  position:relative;z-index:2;
  animation:logoBreath 2.4s var(--ease) infinite;
  filter:drop-shadow(0 12px 18px rgba(42,26,50,.18));
}
.preloader-aura{
  display:none;
}
.preloader-spark{
  display:none;
}
.preloader-name{
  font-family:var(--font-display);font-size:1.36rem;
  letter-spacing:.42em;text-indent:.42em;
  color:var(--plum-deep);font-weight:600;
  opacity:0;animation:fadeUp .55s .1s var(--ease) forwards;
}
.preloader-bar{
  width:220px;height:2px;
  background:rgba(42,26,50,.12);overflow:hidden;border-radius:999px;
}
.preloader-bar::after{
  content:"";display:block;width:100%;height:100%;
  background:var(--grad-rose);
  transform-origin:left;
  transform:scaleX(0);
  animation:barFill 1s var(--ease-out) forwards;
}
@keyframes logoBreath{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes auraPulse{0%,100%{opacity:.7;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.08)}}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes fadeUp{to{opacity:.9;transform:translateY(0)}from{opacity:0;transform:translateY(10px)}}
@keyframes barFill{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:14px 0;
  transition:padding .35s var(--ease),background .35s var(--ease),backdrop-filter .35s var(--ease);
}
.nav.scrolled{
  padding:10px 0;
  background:#07050a;
  border-bottom:1px solid rgba(255,255,255,.09);
  box-shadow:0 18px 42px -34px rgba(0,0,0,.95);
}
.nav-inner{
  width:min(var(--maxw),calc(100vw - (var(--page-pad) * 2)));
  max-width:none;
  margin:0 auto;
  display:flex;align-items:center;justify-content:flex-start;gap:0;
  min-height:86px;
}
.brand{display:flex;align-items:center;gap:16px;flex:0 0 auto;margin-right:24px;min-width:0}
.brand-mark{
  position:relative;
  width:76px;height:100px;
  display:grid;place-items:center;
  transition:transform .35s var(--ease);
  flex:0 0 76px;
  isolation:isolate;
}
.brand-mark::before{
  content:"";
  position:absolute;
  left:50%;
  top:3px;
  width:68px;
  height:94px;
  border-radius:30px;
  transform:translateX(-50%);
  background:
    radial-gradient(ellipse at 50% 100%,rgba(212,167,106,.16),transparent 58%),
    linear-gradient(145deg,#fffdf8 0%,#f4e7da 100%);
  border:1px solid rgba(240,201,135,.4);
  box-shadow:0 14px 28px -24px rgba(0,0,0,.9),0 8px 20px -18px rgba(240,201,135,.75),inset 0 1px 0 rgba(255,255,255,.92);
  z-index:-1;
}
.brand-mark::after{
  display:none;
}
.brand-mark img{
  position:relative;
  z-index:1;
  max-height:84px;
  width:auto;
  object-fit:contain;
  filter:drop-shadow(0 5px 7px rgba(42,26,50,.22));
}
.brand:hover .brand-mark{transform:scale(1.06)}
.brand-text{
  font-family:var(--font-display);
  font-size:25px;
  letter-spacing:.09em;
  text-transform:none;
  font-weight:700;
  color:var(--pearl);
  line-height:1.05;
  white-space:nowrap;
}
.brand-text small{
  display:block;font-family:var(--font-sans);
  font-size:10px;
  letter-spacing:.28em;
  color:var(--rose);
  margin-top:7px;
  font-weight:700;
  text-transform:uppercase;
  white-space:nowrap;
}
.nav-links{
  display:flex;align-items:center;gap:4px;
  margin-left:auto;
  background:rgba(13,8,16,.72);
  border:1px solid rgba(255,255,255,.11);
  padding:6px;border-radius:999px;
  box-shadow:0 16px 46px -34px rgba(0,0,0,.9);
}
.nav-links a{
  position:relative;padding:8px 16px;border-radius:999px;
  font-size:13px;letter-spacing:.06em;color:var(--pearl-dim);
  transition:color .3s var(--ease);
}
.nav-links a:hover{color:var(--pearl)}
.nav-links a.active{color:#1a0f22;background:var(--grad-rose);font-weight:500}
.nav-dropdown{position:relative}
.nav-drop-trigger{display:inline-flex;align-items:center;gap:8px}
.nav-drop-trigger::after{
  content:"";
  width:6px;height:6px;
  border-right:1px solid currentColor;
  border-bottom:1px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  opacity:.75;
}
.nav-menu{
  position:absolute;
  left:50%;
  top:calc(100% + 12px);
  min-width:170px;
  padding:8px;
  border-radius:18px;
  background:rgba(13,8,16,.9);
  border:1px solid var(--line-strong);
  box-shadow:var(--shadow-soft);
  transform:translate(-50%,8px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s var(--ease);
}
.nav-menu::before{
  content:"";
  position:absolute;
  left:0;right:0;top:-14px;height:14px;
}
.nav-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  white-space:nowrap;
}
.nav-menu a:hover{background:rgba(255,255,255,.06)}
.nav-dropdown:hover .nav-menu,
.nav-dropdown:focus-within .nav-menu{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translate(-50%,0);
}
.nav-cta{display:none;align-items:center;gap:12px;margin-left:0}
.nav-toggle{
  display:none;width:44px;height:44px;border-radius:12px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  position:relative;
}
.nav-toggle span{
  position:absolute;left:50%;top:50%;width:18px;height:1.5px;background:var(--pearl);
  transform:translate(-50%,-50%);transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.nav-toggle span:nth-child(1){transform:translate(-50%,calc(-50% - 5px))}
.nav-toggle span:nth-child(3){transform:translate(-50%,calc(-50% + 5px))}
.nav-toggle.open span:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translate(-50%,-50%) rotate(-45deg)}

/* mobile drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:150;
  background:
    radial-gradient(900px 700px at 18% 10%,rgba(122,63,151,.2),transparent 62%),
    radial-gradient(760px 620px at 90% 20%,rgba(255,184,198,.1),transparent 60%),
    var(--bg-0);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  display:grid;place-items:center;
  opacity:0;visibility:hidden;
  transition:opacity .45s var(--ease),visibility .45s var(--ease);
}
.mobile-menu.open{opacity:1;visibility:visible}
body.menu-open .nav{
  background:var(--bg-0);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mobile-menu nav{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
.mobile-menu a{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,6vw,2.6rem);
  color:var(--pearl);
  padding:8px 20px;
  position:relative;
  transition:color .3s var(--ease),transform .3s var(--ease);
}
.mobile-menu a:hover{color:var(--rose-glow);transform:translateY(-2px)}
.mobile-menu .mobile-meta{
  margin-top:24px;display:flex;gap:14px;
  font-size:11px;letter-spacing:.3em;color:var(--muted);text-transform:uppercase;
}
.mobile-subnav{
  display:flex;
  gap:8px;
  margin:-4px 0 6px;
  padding:6px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.04);
}
.mobile-menu .mobile-subnav a{
  font-family:var(--font-sans);
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:8px 12px;
  border-radius:999px;
  color:var(--pearl-dim);
}
.mobile-menu .mobile-subnav a:hover{
  color:#1a0f22;
  background:var(--grad-rose);
  transform:none;
}
.mobile-aura{
  position:absolute;inset:0;pointer-events:none;
  background:var(--grad-aurora);
  opacity:.6;
}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;
  padding:140px 0 80px;
  display:flex;align-items:center;
  overflow:hidden;
  isolation:isolate;
}
.hero-media{
  position:absolute;inset:0;z-index:-1;
}
.hero-media picture{
  display:block;
  width:100%;
  height:100%;
}
.hero-media img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  transform:scale(1.04);
  filter:brightness(1.13) saturate(1.06);
}
@keyframes heroZoom{from{transform:scale(1.18)}to{transform:scale(1.04)}}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(7,5,10,.42) 0%,rgba(7,5,10,.28) 38%,rgba(7,5,10,.74) 82%,#07050a 100%),
    radial-gradient(70% 60% at 28% 50%,rgba(94,44,122,.18),transparent 70%);
}
.hero-content{
  position:relative;z-index:2;
  display:grid;grid-template-columns:minmax(0,620px) 1fr;gap:60px;align-items:end;
  width:100%;
}
.hero-left{padding-bottom:24px}
.hero-tag{margin-bottom:24px}
.hero-title{
  font-size:clamp(4rem,9.4vw,8rem);
  font-weight:700;
  letter-spacing:-.035em;
  line-height:.86;
  margin:0 0 24px;
  text-shadow:0 18px 48px rgba(0,0,0,.55);
}
.hero-title .line1{
  display:block;
  color:var(--pearl);
}
.hero-title .line2{
  display:block;
  width:max-content;
  margin-top:.04em;
  margin-left:0;
  font-style:italic;
  font-weight:700;
  background:none;
  -webkit-background-clip:border-box;background-clip:border-box;
  color:var(--pearl);
  letter-spacing:-.045em;
  position:relative;
  text-shadow:0 18px 48px rgba(0,0,0,.55);
}
.hero-title .line2::after{
  content:"";
  position:absolute;
  left:.06em;
  right:.08em;
  bottom:-.08em;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--rose-glow),var(--gold),transparent);
  opacity:.78;
}
.hero-sub{
  max-width:520px;color:var(--pearl-dim);font-size:1.1rem;line-height:1.7;
  margin-bottom:36px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-meta{
  display:flex;flex-direction:column;gap:18px;
  padding:28px;
  background:rgba(13,8,16,.72);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:0 18px 54px -34px rgba(0,0,0,.86);
  position:relative;
}
.hero-meta::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(255,184,198,.4),transparent 40%,rgba(212,167,106,.3));
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;
}
.hero-meta .row{display:flex;gap:24px;align-items:center}
.hero-meta .row + .row{padding-top:18px;border-top:1px solid var(--line)}
.hero-meta .label{
  font-size:10px;letter-spacing:.36em;text-transform:uppercase;color:var(--rose);
  margin-bottom:4px;
}
.hero-meta .val{font-family:var(--font-display);font-size:1.3rem;color:var(--pearl);font-weight:400}
.hero-scroll{
  position:absolute;left:28px;bottom:28px;z-index:3;
  display:flex;align-items:center;gap:14px;
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--pearl-dim);
}
.hero-scroll .scroll-line{
  width:60px;height:1px;background:rgba(255,255,255,.2);position:relative;overflow:hidden;
}
.hero-scroll .scroll-line::after{
  content:"";position:absolute;left:-30px;top:0;width:30px;height:1px;
  background:var(--rose-glow);
  animation:scrollLine 2.4s ease-in-out infinite;
}
@keyframes scrollLine{0%{left:-30px}100%{left:60px}}
.hero-floats{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-floats span{
  position:absolute;width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle,var(--rose-glow),transparent 70%);
  filter:blur(1px);
  opacity:.6;
  display:none;
}
.hero-floats span:nth-child(1){left:8%;top:30%;animation-delay:0s}
.hero-floats span:nth-child(2){left:18%;top:55%;width:14px;height:14px;animation-delay:1.2s;background:radial-gradient(circle,var(--gold-warm),transparent 70%)}
.hero-floats span:nth-child(3){left:78%;top:25%;width:6px;height:6px;animation-delay:2.4s}
.hero-floats span:nth-child(4){left:88%;top:60%;width:10px;height:10px;animation-delay:3.6s;background:radial-gradient(circle,var(--purple-soft),transparent 70%)}
.hero-floats span:nth-child(5){left:50%;top:18%;width:5px;height:5px;animation-delay:4.8s}
@keyframes float{0%,100%{transform:translateY(0) translateX(0);opacity:.4}50%{transform:translateY(-30px) translateX(8px);opacity:.85}}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s var(--ease-out),transform .55s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.12s}
.reveal.delay-2{transition-delay:.24s}
.reveal.delay-3{transition-delay:.36s}
.reveal.delay-4{transition-delay:.48s}

/* ---------- Featured / About preview ---------- */
.about-prev{
  display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center;
}
.about-prev-img{
  position:relative;border-radius:var(--radius-xl);overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:var(--shadow-soft);
  transform:perspective(1200px) rotateY(-3deg) rotateX(2deg);
  transition:transform .9s var(--ease);
}
.about-prev-img:hover{transform:perspective(1200px) rotateY(0) rotateX(0)}
.about-prev-img img{width:100%;height:100%;object-fit:cover}
.about-prev-img::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(7,5,10,.55) 100%);
  z-index:1;
}
.about-prev-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,184,198,.12),transparent 60%);
  pointer-events:none;
  z-index:2;
}
.about-prev-frame{
  position:absolute;inset:18px;border:1px solid rgba(255,255,255,.18);border-radius:calc(var(--radius-xl) - 14px);
  pointer-events:none;z-index:3;
}
.about-prev-quote{
  position:absolute;left:24px;bottom:24px;right:24px;
  z-index:4;font-family:var(--font-display);font-size:1.05rem;color:var(--pearl);
}
.kicker{font-size:1.05rem;color:var(--pearl-dim);max-width:520px;margin-bottom:30px;line-height:1.8}
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px;
}
.stat{
  padding:22px;background:var(--glass);border:1px solid var(--line);
  border-radius:var(--radius);
  transition:transform .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease);
}
.stat:hover{transform:translateY(-4px);background:var(--glass-strong);border-color:var(--line-strong)}
.stat .num{
  font-family:var(--font-display);font-size:2.4rem;font-weight:400;
  background:var(--grad-rose);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;display:block;margin-bottom:6px;
}
.stat .lbl{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--pearl-dim)}
.about-stats{grid-template-columns:repeat(4,1fr);max-width:980px;margin:0 auto}

/* ---------- Vision strip ---------- */
.vision-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.vision-card{
  position:relative;
  padding:36px 30px;
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
  overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s var(--ease);
  isolation:isolate;
}
.vision-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(255,184,198,.4),transparent 60%);
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.4;transition:opacity .5s var(--ease);
  pointer-events:none;
}
.vision-card::after{
  content:"";position:absolute;left:50%;top:-30%;width:300px;height:300px;
  background:radial-gradient(circle,rgba(255,184,198,.15),transparent 60%);
  transform:translateX(-50%);z-index:-1;
  opacity:0;transition:opacity .6s var(--ease);
}
.vision-card:hover{transform:translateY(-6px);border-color:transparent}
.vision-card:hover::before{opacity:1}
.vision-card:hover::after{opacity:1}
.vision-card .num{
  font-family:var(--font-display);font-style:italic;font-size:.95rem;color:var(--rose);
  letter-spacing:.2em;
}
.vision-card h3{
  font-size:1.7rem;margin:14px 0 12px;color:var(--pearl);
}
.vision-card p{color:var(--pearl-dim);font-size:.95rem;margin:0}

/* ---------- Editorial split section ---------- */
.editorial{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.editorial.reverse{grid-template-columns:1fr 1fr}
.editorial.reverse .editorial-img{order:2}
.editorial-img{
  position:relative;aspect-ratio:5/6;border-radius:var(--radius-xl);overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.editorial-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.editorial-img:hover img{transform:scale(1.05)}
.editorial-text h2{font-size:clamp(2rem,4vw,3.4rem);margin-bottom:18px}
.editorial-text p{color:var(--pearl-dim);font-size:1.05rem;margin-bottom:18px;line-height:1.8}
.editorial .tag{
  display:inline-flex;gap:8px;align-items:center;
  padding:6px 12px;border-radius:999px;
  background:rgba(255,184,198,.08);
  border:1px solid rgba(255,184,198,.2);
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--rose-glow);
  margin-bottom:18px;
}
.editorial-text-dense h2{font-size:clamp(1.7rem,3vw,2.6rem);margin-bottom:14px;line-height:1.18}
.editorial-text-dense p{font-size:.95rem;line-height:1.65;margin-bottom:12px}
.editorial-text-dense .editorial-list-lead{
  margin-top:6px;margin-bottom:6px;color:var(--pearl);font-size:.95rem;
}
.editorial-text-dense .editorial-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.editorial-text-dense .editorial-list li{
  position:relative;padding-left:18px;
  color:var(--pearl-dim);font-size:.92rem;line-height:1.55;
}
.editorial-text-dense .editorial-list li::before{
  content:"";position:absolute;left:0;top:.65em;
  width:6px;height:6px;border-radius:50%;
  background:var(--grad-rose);
}

/* ---------- Gallery preview / grid ---------- */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:120px;
  gap:18px;
}
.gallery-item{
  position:relative;border-radius:var(--radius);overflow:hidden;
  cursor:pointer;
  background:var(--bg-2);
  isolation:isolate;
  transition:transform .5s var(--ease);
}
.gallery-item img,.gallery-item video{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter .5s var(--ease)}
.gallery-item:hover img,.gallery-item:hover video{transform:scale(1.06);filter:brightness(1.1)}
.gallery-item::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(7,5,10,.6) 100%);
  opacity:.6;transition:opacity .4s var(--ease);
}
.gallery-item:hover::after{opacity:1}
.gallery-item .meta{
  position:absolute;left:18px;right:18px;bottom:18px;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
  transform:translateY(8px);opacity:0;transition:transform .45s var(--ease),opacity .45s var(--ease);
}
.gallery-item:hover .meta{transform:translateY(0);opacity:1}
.gallery-item .meta .ttl{font-family:var(--font-display);font-size:1.05rem;color:var(--pearl)}
.gallery-item .meta .cat{font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--rose)}
.gallery-item.video-card::before{
  content:"";position:absolute;left:50%;top:50%;
  width:64px;height:64px;border-radius:50%;
  background:rgba(13,8,16,.55);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.25);
  transform:translate(-50%,-50%);
  z-index:3;
  transition:transform .4s var(--ease),background .4s var(--ease);
}
.gallery-item.video-card .play-icon{
  position:absolute;left:50%;top:50%;transform:translate(-42%,-50%);
  width:0;height:0;border-style:solid;border-width:10px 0 10px 16px;
  border-color:transparent transparent transparent var(--pearl);
  z-index:4;pointer-events:none;
}
.gallery-item.video-card:hover::before{transform:translate(-50%,-50%) scale(1.1);background:rgba(255,184,198,.85)}
.gallery-item.video-card:hover .play-icon{border-left-color:#1a0f22}

/* gallery layout patterns */
.gi-1{grid-column:span 7;grid-row:span 4}
.gi-2{grid-column:span 5;grid-row:span 4}
.gi-3{grid-column:span 4;grid-row:span 3}
.gi-4{grid-column:span 4;grid-row:span 3}
.gi-5{grid-column:span 4;grid-row:span 3}
.gi-6{grid-column:span 6;grid-row:span 4}
.gi-7{grid-column:span 6;grid-row:span 4}
.gi-8{grid-column:span 4;grid-row:span 3}
.gi-9{grid-column:span 4;grid-row:span 3}
.gi-10{grid-column:span 4;grid-row:span 3}
.gi-11{grid-column:span 5;grid-row:span 4}
.gi-12{grid-column:span 7;grid-row:span 4}

/* ---------- Homepage media showcase ---------- */
.home-media-showcase{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);
  gap:22px;
  align-items:stretch;
}
.home-album-feature,
.home-mini-card,
.home-video-card{
  position:relative;
  overflow:hidden;
  background:rgba(13,8,16,.55);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  isolation:isolate;
}
.home-album-feature{
  min-height:560px;
  border-radius:var(--radius-xl);
  display:flex;
  align-items:flex-end;
}
.home-album-feature img,
.home-mini-card img,
.home-video-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1.2s var(--ease),filter .5s var(--ease);
}
.home-album-feature:hover img,
.home-mini-card:hover img,
.home-video-card:hover img{transform:scale(1.06);filter:brightness(1.08)}
.home-album-feature::after,
.home-mini-card::after,
.home-video-card::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,5,10,.05) 20%,rgba(7,5,10,.85) 100%);
  z-index:1;
}
.home-album-feature > div,
.home-mini-card span,
.home-video-card div{
  position:relative;
  z-index:2;
}
.home-album-feature > div{padding:34px;max-width:680px}
.home-album-feature small,
.home-mini-card small,
.home-video-card small{
  display:block;
  font-size:10px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--rose-glow);
  margin-bottom:8px;
}
.home-album-feature h3{
  font-size:clamp(2rem,4vw,3.6rem);
  color:var(--pearl);
  margin-bottom:12px;
}
.home-album-feature p{
  max-width:560px;
  color:var(--pearl-dim);
  margin:0;
}
.home-media-stack{
  display:grid;
  gap:22px;
  grid-auto-rows:1fr;
  align-content:stretch;
}
.home-mini-card,
.home-video-card{
  min-height:240px;
  border-radius:var(--radius-lg);
  display:flex;
  align-items:flex-end;
}
.home-mini-card span,
.home-video-card div{padding:24px}
.home-mini-card strong,
.home-video-card strong{
  display:block;
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.35rem;
  color:var(--pearl);
  line-height:1.15;
}
.home-video-card .play{
  position:absolute;
  left:24px;
  top:24px;
  z-index:3;
  width:54px;
  height:54px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(13,8,16,.62);
  border:1px solid rgba(255,184,198,.35);
  backdrop-filter:blur(10px);
}
.home-video-card .play span{
  width:0;height:0;
  border-style:solid;
  border-width:8px 0 8px 13px;
  border-color:transparent transparent transparent var(--pearl);
  margin-left:3px;
}

/* ---------- Media hub / Albums ---------- */
.media-page-hero{padding-bottom:64px}
.media-tabs{
  width:max-content;
  max-width:100%;
  margin:34px auto 0;
  display:flex;
  gap:6px;
  padding:7px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  backdrop-filter:blur(12px);
}
.media-tabs button{
  min-width:120px;
  padding:11px 20px;
  border-radius:999px;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--pearl-dim);
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);
}
.media-tabs button:hover{color:var(--pearl)}
.media-tabs button.active{
  color:#1a0f22;
  background:var(--grad-rose);
  font-weight:600;
}
.media-toolbar{
  max-width:760px;
  margin-bottom:28px;
}
.media-toolbar .section-title{margin-bottom:.18em}
.category-bar{
  display:flex;flex-wrap:wrap;gap:10px;
  margin:0 0 36px;
  padding:8px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  width:fit-content;max-width:100%;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.category-bar button{
  padding:11px 22px;
  border-radius:999px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--pearl-dim);font-weight:500;
  background:transparent;border:none;cursor:pointer;
  transition:color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease);
  white-space:nowrap;
}
.category-short{display:none}
.category-bar button:hover{color:var(--pearl)}
.category-bar button.active{
  color:#1a0f22;
  background:var(--grad-rose);
  font-weight:600;
  box-shadow:0 6px 18px -8px rgba(255,184,198,.5);
}
.album-empty{
  text-align:center;color:var(--pearl-dim);padding:60px 20px;
  border:1px dashed var(--line);border-radius:var(--radius-lg);
}
@media (max-width:680px){
  .category-bar{
    position:sticky;
    top:78px;
    z-index:30;
    width:100%;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    margin-bottom:24px;
    padding:6px;
    border-radius:22px;
    background:rgba(13,8,16,.86);
    box-shadow:0 18px 40px -28px rgba(0,0,0,.9);
  }
  .category-bar button{
    min-height:50px;
    padding:10px 8px;
    border-radius:16px;
    text-align:center;
    white-space:normal;
    letter-spacing:.12em;
    line-height:1.15;
  }
  .category-title{display:none}
  .category-short{display:block}
}
.album-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  align-items:stretch;
}
.album-card{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:100%;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025)),
    rgba(13,8,16,.58);
  border:1px solid var(--line);
  box-shadow:0 18px 60px -36px rgba(0,0,0,.9);
  cursor:pointer;
  isolation:isolate;
  transition:transform .45s var(--ease),border-color .45s var(--ease),background .45s var(--ease),box-shadow .45s var(--ease);
}
.album-card::before,
.album-card::after{
  display:none;
}
.album-card:hover{
  transform:translateY(-7px);
  border-color:rgba(255,184,198,.28);
  background:rgba(255,255,255,.055);
  box-shadow:0 24px 80px -42px rgba(255,184,198,.45),0 24px 80px -34px rgba(0,0,0,.9);
}
.album-card:focus-visible{
  outline:2px solid var(--rose-glow);
  outline-offset:5px;
}
.album-cover{
  position:relative;
  z-index:1;
  aspect-ratio:16/11;
  overflow:hidden;
  background:var(--bg-2);
}
.album-cover::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,5,10,.04) 35%,rgba(7,5,10,.62) 100%);
  pointer-events:none;
  z-index:2;
}
.album-cover > img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1.2s var(--ease),filter .45s var(--ease);
}
.album-card:hover .album-cover > img{transform:scale(1.04);filter:brightness(1.06)}
.album-count{
  position:absolute;
  right:16px;
  bottom:16px;
  z-index:4;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(13,8,16,.72);
  border:1px solid rgba(255,255,255,.18);
  color:var(--pearl);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  backdrop-filter:blur(10px);
}
.album-body{
  min-width:0;
  position:relative;
  z-index:1;
  padding:24px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.album-body small{
  display:block;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--rose);
  margin-bottom:10px;
}
.album-body h3{font-size:1.65rem;color:var(--pearl);margin-bottom:10px;overflow-wrap:anywhere}
.album-body p{color:var(--pearl-dim);font-size:.95rem;margin-bottom:18px;flex:1;overflow-wrap:anywhere}
.album-preview{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin:0 0 18px;
}
.album-shot{
  position:relative;
  overflow:hidden;
  border-radius:12px;
  border:1px solid var(--line);
  background:var(--bg-2);
  aspect-ratio:4/3;
}
.album-shot img{width:100%;height:100%;object-fit:cover}
.album-open{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--rose-glow);
}
.album-open .arrow{
  display:inline-block;
  transition:transform .3s var(--ease);
}
.album-card:hover .album-open .arrow{transform:translateX(4px)}
.album-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  margin-bottom:20px;
}
.album-head > div{text-align:right}
.album-head h2{
  font-size:clamp(2.3rem,5vw,4rem);
  margin:.16em 0 .12em;
}
.album-head p{color:var(--pearl-dim);margin:0}
.album-mosaic{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,185px),1fr));
  gap:6px;
  align-items:stretch;
}
.album-photo{
  position:relative;
  margin:0;
  overflow:hidden;
  border-radius:7px;
  background:var(--bg-2);
  cursor:pointer;
  aspect-ratio:1/1;
  border:0;
  box-shadow:none;
}
.album-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .35s var(--ease)}
@media (max-width:680px){
  .album-mosaic{grid-template-columns:repeat(3,1fr);gap:4px}
}
.album-photo:hover img{transform:scale(1.06);filter:brightness(1.1)}
.video-library .video-grid{margin-top:0}

/* ---------- Filters ---------- */
.filters{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 auto 50px;
  padding:8px;border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  width:fit-content;
  max-width:100%;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.filters button{
  padding:10px 20px;border-radius:999px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--pearl-dim);
  transition:color .3s var(--ease),background .3s var(--ease);
  white-space:nowrap;
}
.filters button:hover{color:var(--pearl)}
.filters button.active{color:#1a0f22;background:var(--grad-rose);font-weight:500}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:500;
  background:rgba(7,5,10,.92);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  display:none;align-items:center;justify-content:center;
  padding:60px 28px;
  opacity:0;transition:opacity .4s var(--ease);
}
.lightbox.open{display:flex;opacity:1}
.lightbox-stage{
  position:relative;max-width:1200px;width:100%;max-height:88vh;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.lightbox-media{
  position:relative;width:100%;max-height:78vh;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-glow);
  background:#000;
}
.lightbox-media img,.lightbox-media video{max-width:100%;max-height:78vh;object-fit:contain;display:block}
.reel-preview{
  position:relative;
  width:100%;
  min-height:min(62vh,620px);
  display:grid;
  place-items:center;
  background:#000;
  overflow:hidden;
}
.reel-preview img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  max-height:none;
  object-fit:cover;
  opacity:.52;
}
.reel-preview div{
  position:relative;
  z-index:2;
  text-align:center;
  padding:32px;
  color:var(--pearl);
}
.reel-preview span,
.reel-preview small{
  display:block;
  font-family:var(--font-sans);
  font-size:10px;
  letter-spacing:.34em;
  text-transform:uppercase;
}
.reel-preview span{color:var(--rose-glow);margin-bottom:14px}
.reel-preview strong{
  display:block;
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(2rem,5vw,3.6rem);
  margin-bottom:14px;
}
.reel-preview small{color:var(--pearl-dim)}
.lightbox-cap{
  display:flex;justify-content:space-between;width:100%;gap:14px;color:var(--pearl-dim);
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:absolute;width:56px;height:56px;border-radius:50%;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,184,198,.5);
  color:#1a0f22;
  display:grid;place-items:center;
  transition:transform .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease);
  z-index:520;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.6),0 0 0 1px rgba(255,184,198,.2);
  cursor:pointer;
}
.lightbox-close svg,.lightbox-prev svg,.lightbox-next svg{
  width:22px;height:22px;stroke-width:2;
}
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{
  transform:scale(1.08);
  background:var(--grad-rose);
  color:#1a0f22;
  box-shadow:0 12px 32px -6px rgba(255,184,198,.55);
}
.lightbox-close{top:20px;right:20px}
.lightbox-prev{left:24px;top:50%;transform:translateY(-50%)}
.lightbox-next{right:24px;top:50%;transform:translateY(-50%)}
.lightbox-prev:hover,.lightbox-next:hover{transform:translateY(-50%) scale(1.08)}
@media (max-width:760px){
  .lightbox-close,.lightbox-prev,.lightbox-next{width:48px;height:48px}
  .lightbox-prev{left:10px}
  .lightbox-next{right:10px}
}

/* ---------- Page hero ---------- */
.page-hero{
  position:relative;padding:230px 0 92px;
  text-align:center;
  overflow:hidden;isolation:isolate;
}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--grad-aurora);
  opacity:.7;
}
.page-hero h1{
  font-size:clamp(3rem,8vw,6rem);font-weight:300;
}
.page-hero h1 em{
  font-style:italic;
  background:var(--grad-rose);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-hero p{max-width:680px;margin:24px auto 0;color:var(--pearl-dim);font-size:1.05rem;line-height:1.8}
.page-hero .crumbs{
  display:inline-flex;gap:10px;margin-bottom:18px;
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--rose);
}
.page-hero .crumbs span{opacity:.4}

/* ---------- Vision page ---------- */
.statement{
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.4rem);font-weight:300;
  line-height:1.25;letter-spacing:-.01em;
  color:var(--pearl);
  max-width:980px;margin:0 auto;
  text-align:center;
}
.statement em{
  font-style:italic;
  background:var(--grad-rose);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.values{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:60px;
}
.value{
  padding:30px 24px;border-radius:var(--radius-lg);
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease);
}
.value:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.value .icon{
  width:42px;height:42px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(255,184,198,.15),rgba(212,167,106,.1));
  border:1px solid rgba(255,184,198,.2);
  color:var(--rose-glow);
  margin-bottom:18px;
}
.value h4{font-size:1.15rem;color:var(--pearl);margin-bottom:8px}
.value p{font-size:.92rem;color:var(--pearl-dim);margin:0}

/* ---------- Highlights timeline ---------- */
.timeline{position:relative;padding:20px 0}
.timeline::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent,var(--rose-glow) 20%,var(--rose-glow) 80%,transparent);
  transform:translateX(-50%);
  opacity:.4;
}
.timeline-row{
  display:grid;grid-template-columns:1fr 80px 1fr;gap:24px;margin-bottom:60px;
  align-items:center;
}
.timeline-row .dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--grad-rose);justify-self:center;
  box-shadow:0 0 30px rgba(255,184,198,.7);
}
.timeline-card{
  padding:28px;border-radius:var(--radius-lg);
  background:rgba(13,8,16,.55);
  border:1px solid var(--line);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  position:relative;
}
.timeline-card .yr{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--rose);margin-bottom:8px}
.timeline-card h4{font-size:1.3rem;margin-bottom:8px;color:var(--pearl)}
.timeline-card p{margin:0;color:var(--pearl-dim);font-size:.95rem}
.timeline-row.right{grid-template-columns:1fr 80px 1fr}
.timeline-row.right .timeline-card{grid-column:3}
.timeline-row.left .timeline-card{grid-column:1;text-align:right}

.highlights-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.highlight-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;
}
.highlight-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.highlight-card:hover img{transform:scale(1.06)}
.highlight-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(7,5,10,.92) 100%);
}
.highlight-card .body{
  position:absolute;left:24px;right:24px;bottom:22px;z-index:2;
}
.highlight-card .body small{
  display:inline-block;padding:4px 10px;border-radius:999px;
  font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--rose-glow);
  background:rgba(255,184,198,.12);border:1px solid rgba(255,184,198,.25);
  margin-bottom:10px;
}
.highlight-card .body h4{font-size:1.25rem;color:var(--pearl);margin-bottom:6px}
.highlight-card .body p{font-size:.9rem;color:var(--pearl-dim);margin:0}

/* ---------- Testimonials / Reviews ---------- */
.testi-rating-summary{
  display:inline-flex;align-items:center;gap:18px;
  margin-top:32px;padding:14px 22px;border-radius:999px;
  background:rgba(255,184,198,.06);
  border:1px solid rgba(255,184,198,.22);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.testi-stars-big{display:inline-flex;gap:3px;color:#f5c66a;font-size:18px;line-height:1}
.testi-rating-meta{display:inline-flex;align-items:baseline;gap:10px;color:var(--pearl-dim);font-size:.88rem}
.testi-rating-meta strong{font-family:var(--font-display);font-size:1.55rem;color:var(--pearl);font-weight:500}
.testi-rating-meta em{font-style:normal;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--rose)}
.testimonials-section .testi-toolbar{
  display:flex;justify-content:space-between;align-items:end;
  flex-wrap:wrap;gap:24px;margin-bottom:46px;
}
.testi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,330px),1fr));
  gap:22px;
}
.testi-card{
  position:relative;
  padding:28px 26px 24px;
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:18px;
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);
  overflow:hidden;
}
.testi-card::before{
  content:"\201C";
  position:absolute;top:-22px;right:14px;
  font-family:var(--font-display);font-size:120px;line-height:1;
  color:rgba(255,184,198,.08);pointer-events:none;
}
.testi-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,184,198,.32);
  box-shadow:0 20px 40px -28px rgba(0,0,0,.85);
}
.testi-card-top{display:flex;justify-content:space-between;align-items:center;gap:12px}
.testi-stars{display:inline-flex;gap:2px;font-size:14px;line-height:1}
.testi-stars .on{color:#f5c66a}
.testi-stars .off{color:rgba(245,198,106,.22)}
.testi-date{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--pearl-dim)}
.testi-message{
  font-family:var(--font-display);
  font-size:1.05rem;line-height:1.55;color:var(--pearl);
  margin:0;font-weight:300;
}
.testi-meta{
  display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid var(--line);
}
.testi-avatar{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--grad-rose);
  color:#1a0f22;font-weight:600;font-size:1rem;
  flex-shrink:0;
}
.testi-meta strong{display:block;color:var(--pearl);font-size:.95rem;font-weight:500}
.testi-meta small{display:block;color:var(--pearl-dim);font-size:.78rem;margin-top:2px}

.review-form-wrap{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;
  padding:46px;border-radius:var(--radius-xl);
  background:linear-gradient(160deg,rgba(255,184,198,.06),rgba(255,255,255,.01));
  border:1px solid rgba(255,184,198,.18);
  box-shadow:var(--shadow-soft);
}
.review-form-intro h2{font-size:clamp(1.8rem,3.2vw,2.6rem);margin:.2em 0 .4em}
.review-form-intro p{color:var(--pearl-dim);font-size:.98rem;line-height:1.7;margin-bottom:22px}
.review-form-points{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
}
.review-form-points li{
  position:relative;padding-left:22px;
  color:var(--pearl-dim);font-size:.9rem;line-height:1.5;
}
.review-form-points li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:8px;height:8px;border-radius:50%;background:var(--grad-rose);
}
.review-form{display:flex;flex-direction:column;gap:18px}
.rf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rf-field{display:flex;flex-direction:column;gap:8px}
.rf-field > span{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--rose);font-weight:500;
}
.rf-field input,
.rf-field textarea{
  width:100%;
  padding:14px 16px;border-radius:14px;
  background:rgba(7,5,10,.55);
  border:1px solid var(--line-strong);
  color:var(--pearl);font-family:var(--font-sans);font-size:.95rem;line-height:1.5;
  transition:border-color .3s var(--ease),background .3s var(--ease);
  resize:vertical;
}
.rf-field input::placeholder,
.rf-field textarea::placeholder{color:rgba(255,255,255,.32)}
.rf-field input:focus,
.rf-field textarea:focus{
  outline:none;
  border-color:rgba(255,184,198,.55);
  background:rgba(7,5,10,.75);
}
.rf-stars{display:inline-flex;gap:6px;align-items:center}
.rf-stars button{
  background:none;border:none;cursor:pointer;
  font-size:26px;line-height:1;color:rgba(245,198,106,.32);
  transition:color .2s var(--ease),transform .2s var(--ease);
  padding:2px 4px;
}
.rf-stars button:hover{transform:scale(1.12)}
.rf-stars button.on{color:#f5c66a}
.rf-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:6px}
.rf-status{font-size:.85rem;color:var(--pearl-dim)}
.rf-status.ok{color:#9ee7a3}
.rf-status.err{color:#ff9aab}
.rf-note{
  margin-top:6px;font-size:.8rem;line-height:1.55;
  color:var(--pearl-dim);
  padding-top:14px;border-top:1px solid var(--line);
}
.testi-empty{
  grid-column:1 / -1;
  text-align:center;
  padding:64px 28px;
  border-radius:var(--radius-xl);
  border:1px dashed var(--line);
  background:rgba(255,255,255,.02);
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.testi-empty-mark{
  font-family:var(--font-display);font-size:90px;line-height:.6;
  color:rgba(255,184,198,.35);
}
.testi-empty h3{font-size:1.6rem;color:var(--pearl);margin:0}
.testi-empty p{color:var(--pearl-dim);max-width:460px;margin:0}
.testi-pending{
  margin-left:auto;
  font-size:9px;letter-spacing:.24em;text-transform:uppercase;
  color:#f5c66a;background:rgba(245,198,106,.1);
  border:1px solid rgba(245,198,106,.28);
  padding:4px 8px;border-radius:999px;
}

@media (max-width:900px){
  .review-form-wrap{grid-template-columns:1fr;padding:32px;gap:30px}
  .rf-row{grid-template-columns:1fr}
  .testimonials-section .testi-toolbar{align-items:flex-start}
}
@media (max-width:560px){
  .testi-rating-summary{flex-direction:column;gap:10px;border-radius:18px}
  .testi-rating-meta{flex-direction:column;align-items:center;gap:4px}
}

/* ---------- Events page ---------- */
.event-feature{
  display:grid;
  grid-template-columns:minmax(0,1.18fr) minmax(360px,.82fr);
  min-height:560px;
  border-radius:var(--radius-xl);
  overflow:hidden;
  background:rgba(13,8,16,.58);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.event-feature-media{
  position:relative;
  min-height:420px;
  overflow:hidden;
}
.event-feature-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.event-feature:hover .event-feature-media img{transform:scale(1.04)}
.event-feature-media::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 54%,rgba(7,5,10,.5) 100%);
}
.event-feature-body{
  padding:54px 46px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.event-feature-body .tag{
  width:max-content;
  display:inline-flex;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,184,198,.08);
  border:1px solid rgba(255,184,198,.22);
  color:var(--rose-glow);
  font-size:10px;
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-bottom:18px;
}
.event-feature-body h2{
  font-size:clamp(2.4rem,5vw,4.6rem);
  color:var(--pearl);
  margin-bottom:16px;
}
.event-feature-body p{
  color:var(--pearl-dim);
  font-size:1.05rem;
  line-height:1.8;
  margin-bottom:24px;
}
.event-facts{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-bottom:28px;
}
.event-facts div{
  padding:16px 14px;
  border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
}
.event-facts small{
  display:block;
  color:var(--rose);
  font-size:9px;
  letter-spacing:.28em;
  text-transform:uppercase;
  margin-bottom:5px;
}
.event-facts strong{
  display:block;
  color:var(--pearl);
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:500;
}
.event-journal{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.event-entry{
  display:flex;
  flex-direction:column;
  min-height:100%;
  overflow:hidden;
  border-radius:var(--radius-lg);
  background:rgba(13,8,16,.58);
  border:1px solid var(--line);
  transition:transform .45s var(--ease),border-color .45s var(--ease),background .45s var(--ease);
}
.event-entry:hover{
  transform:translateY(-6px);
  border-color:rgba(255,184,198,.28);
  background:rgba(255,255,255,.055);
}
.event-entry img{
  width:100%;
  aspect-ratio:16/11;
  object-fit:cover;
}
.event-entry div{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:24px;
}
.event-entry small{
  display:block;
  color:var(--rose);
  font-size:10px;
  letter-spacing:.27em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.event-entry h3{font-size:1.55rem;color:var(--pearl);margin-bottom:10px}
.event-entry p{color:var(--pearl-dim);font-size:.95rem;line-height:1.75;flex:1}
.event-entry a{
  width:max-content;
  color:var(--rose-glow);
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
}
.event-entry a span{display:inline-block;transition:transform .3s var(--ease)}
.event-entry a:hover span{transform:translateX(4px)}
.event-directions{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:50px;
  align-items:center;
}
.event-directions-copy p{
  max-width:560px;
  color:var(--pearl-dim);
  line-height:1.8;
  margin-bottom:28px;
}
.event-type-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.event-type{
  min-height:190px;
  padding:26px 24px;
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02));
  border:1px solid var(--line);
}
.event-type small{
  display:block;
  color:var(--rose);
  font-family:var(--font-display);
  font-style:italic;
  letter-spacing:.18em;
  margin-bottom:14px;
}
.event-type strong{
  display:block;
  color:var(--pearl);
  font-family:var(--font-display);
  font-size:1.45rem;
  font-weight:500;
  margin-bottom:10px;
}
.event-type span{display:block;color:var(--pearl-dim);font-size:.94rem;line-height:1.7}

.event-spotlight{
  display:grid;grid-template-columns:1.2fr 1fr;gap:0;
  border-radius:var(--radius-xl);overflow:hidden;
  background:rgba(13,8,16,.55);
  border:1px solid var(--line);
  margin-bottom:24px;
}
.event-spotlight.alt{grid-template-columns:1fr 1.2fr}
.event-spotlight.alt .es-img{order:2}
.es-img{position:relative;aspect-ratio:4/3;overflow:hidden;min-height:380px}
.es-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.event-spotlight:hover .es-img img{transform:scale(1.05)}
.es-body{padding:50px 44px;display:flex;flex-direction:column;justify-content:center}
.es-body .when{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--rose);margin-bottom:14px}
.es-body h3{font-size:clamp(1.6rem,3vw,2.4rem);color:var(--pearl);margin-bottom:14px}
.es-body p{color:var(--pearl-dim);font-size:1rem;margin-bottom:16px}
.es-body .where{
  display:inline-flex;gap:8px;align-items:center;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--pearl-dim);
}

/* ---------- Videos page ---------- */
.video-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));gap:24px;
}
.video-card{
  position:relative;aspect-ratio:16/10;
  border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;
  background:var(--bg-2);isolation:isolate;
  transition:transform .5s var(--ease);
}
.video-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter .4s var(--ease)}
.video-card:hover img{transform:scale(1.06);filter:brightness(1.1)}
.video-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(7,5,10,.85) 100%);
}
.video-card .play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:78px;height:78px;border-radius:50%;
  background:rgba(13,8,16,.55);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,184,198,.4);
  display:grid;place-items:center;
  z-index:3;transition:transform .35s var(--ease),background .35s var(--ease)}
.video-card:hover .play{transform:translate(-50%,-50%) scale(1.1);background:var(--grad-rose);border-color:transparent}
.video-card .play .tri{width:0;height:0;border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent var(--pearl);margin-left:4px}
.video-card:hover .play .tri{border-left-color:#1a0f22}
.video-card .info{position:absolute;left:24px;right:24px;bottom:22px;z-index:2}
.video-card .info small{font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--rose-glow)}
.video-card .info h4{font-size:1.15rem;color:var(--pearl);margin:8px 0 0}

.coming-soon{
  position:absolute;top:18px;right:18px;z-index:4;
  padding:6px 12px;border-radius:999px;
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--pearl);
  background:rgba(13,8,16,.65);
  border:1px solid rgba(255,184,198,.4);
  backdrop-filter:blur(10px);
}

/* ---------- Contact page ---------- */
.connect-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch;
}
.connect-card{
  padding:28px;border-radius:var(--radius-xl);
  background:rgba(13,8,16,.55);
  border:1px solid var(--line);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  position:relative;overflow:hidden;
}
.connect-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(255,184,198,.4),transparent 60%);
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.connect-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:18px;
}
.connect-item{
  display:flex;align-items:center;gap:14px;padding:16px;
  border-radius:var(--radius);border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  transition:transform .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease);
}
.connect-item:hover{transform:translateY(-2px);background:rgba(255,184,198,.06);border-color:rgba(255,184,198,.3)}
.connect-item .ico{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg,rgba(255,184,198,.15),rgba(212,167,106,.1));
  border:1px solid rgba(255,184,198,.25);
  display:grid;place-items:center;color:var(--rose-glow);
  flex-shrink:0;
}
.connect-item .who{display:flex;flex-direction:column;flex:1;min-width:0}
.connect-item .who small{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--rose);margin-bottom:2px}
.connect-item .who strong{font-family:var(--font-display);font-weight:500;font-size:.98rem;color:var(--pearl);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.connect-side{
  position:relative;border-radius:var(--radius-xl);overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:var(--shadow-soft);
}
.connect-side img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.connect-side::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(7,5,10,.6) 100%);
}
.connect-side .quote{
  position:absolute;left:24px;right:24px;bottom:24px;
  font-family:var(--font-display);color:var(--pearl);font-size:1.1rem;
}
.contact-form{
  padding:38px 34px;
  min-height:100%;
  border-radius:var(--radius-xl);
  background:rgba(13,8,16,.58);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.contact-form h2{
  font-size:clamp(1.8rem,3vw,2.5rem);
  color:var(--pearl);
  margin:12px 0 22px;
}
.contact-form h2 em{
  font-style:italic;
  background:var(--grad-rose);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.contact-form label{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:14px;
}
.contact-form label span{
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--rose);
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border:1px solid var(--line-strong);
  border-radius:14px;
  background:rgba(255,255,255,.045);
  color:var(--pearl);
  padding:14px 15px;
  font:500 .95rem var(--font-sans);
  outline:none;
  transition:border-color .25s var(--ease),background .25s var(--ease);
}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color:rgba(255,184,198,.46);
  background:rgba(255,255,255,.07);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:rgba(207,196,184,.56)}
.contact-form .btn{margin-top:6px}
.compact-side{
  aspect-ratio:16/10;
  margin-bottom:18px;
}

/* ---------- Footer ---------- */
.footer{
  position:relative;padding:80px 0 30px;margin-top:80px;
  border-top:1px solid var(--line);
  overflow:hidden;
  isolation:isolate;
}
.footer::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(40% 60% at 20% 100%,rgba(122,63,151,.15),transparent 70%),
    radial-gradient(40% 60% at 80% 100%,rgba(212,167,106,.1),transparent 70%);
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;
}
.footer-brand{display:flex;flex-direction:column;gap:18px;max-width:320px}
.footer-mark{display:flex;align-items:center;gap:14px}
.footer-mark img{height:60px;width:auto;filter:drop-shadow(0 0 16px rgba(255,184,198,.35))}
.footer-mark .name{font-family:var(--font-display);font-size:1.4rem;color:var(--pearl);letter-spacing:.05em}
.footer-mark .name small{display:block;font-family:var(--font-sans);font-size:9px;letter-spacing:.5em;color:var(--rose);text-transform:uppercase;margin-top:6px}
.footer-brand p{color:var(--pearl-dim);font-size:.92rem;margin:0;line-height:1.7}
.footer-col h5{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--rose);margin-bottom:18px;font-family:var(--font-sans);font-weight:600}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:var(--pearl-dim);font-size:.92rem;transition:color .3s var(--ease)}
.footer-col a:hover{color:var(--rose-glow)}
.footer-bottom{
  margin-top:60px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-size:11px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;
}
.footer-bottom .made{display:flex;align-items:center;gap:8px}
.footer-bottom .heart{color:var(--rose-glow)}

/* ---------- Marquee ---------- */
.marquee{
  position:relative;overflow:hidden;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:32px 0;
  background:linear-gradient(90deg,rgba(94,44,122,.08),rgba(212,167,106,.05),rgba(94,44,122,.08));
  white-space:nowrap;
}
.marquee-track{display:inline-flex;gap:60px;animation:marquee 32s linear infinite;will-change:transform}
.marquee-item{
  font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2.2rem);font-weight:300;
  color:var(--pearl);letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:60px;
}
.marquee-item .dot{width:8px;height:8px;border-radius:50%;background:var(--grad-rose);display:inline-block}
.marquee-item em{font-style:italic;background:var(--grad-rose);-webkit-background-clip:text;background-clip:text;color:transparent}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Connect CTA ---------- */
.connect-cta{
  position:relative;padding:80px 0;text-align:center;
  border-radius:var(--radius-xl);
  background:
    radial-gradient(60% 80% at 50% 0%,rgba(94,44,122,.35),transparent 70%),
    rgba(13,8,16,.55);
  border:1px solid var(--line);
  overflow:hidden;
}
.connect-cta::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(2px 2px at 20% 30%,rgba(255,184,198,.6),transparent 50%),
    radial-gradient(1px 1px at 70% 70%,rgba(212,167,106,.6),transparent 50%),
    radial-gradient(1.5px 1.5px at 40% 80%,rgba(255,184,198,.4),transparent 50%),
    radial-gradient(1px 1px at 90% 40%,rgba(255,184,198,.5),transparent 50%);
  opacity:.7;animation:twinkle 4s var(--ease) infinite alternate;
}
@keyframes twinkle{0%{opacity:.4}100%{opacity:.85}}
.connect-cta h2{font-size:clamp(2.2rem,5vw,4rem);margin-bottom:14px}
.connect-cta p{max-width:640px;margin:0 auto 30px;color:var(--pearl-dim)}

/* ---------- Image utilities ---------- */
.lazy{opacity:0;transition:opacity .8s var(--ease)}
.lazy.loaded{opacity:1}

/* ---------- Performance tuning ---------- */
body::after{display:none}
section:not(.hero):not(.page-hero){
  content-visibility:auto;
  contain-intrinsic-size:800px;
}
.connect-cta::before{
  animation:none!important;
}
.nav-links,
.nav-menu,
.mobile-menu,
.hero-meta,
.home-video-card .play,
.media-tabs,
.category-bar,
.album-count,
.filters,
.lightbox,
.timeline-card,
.video-card .play,
.coming-soon,
.connect-card{
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}
.gallery-item img,
.home-album-feature img,
.home-mini-card img,
.home-video-card img,
.album-shot img,
.album-photo img,
.highlight-card img,
.event-feature-media img,
.event-entry img,
.editorial-img img,
.video-card img,
.es-img img{
  transition:transform .45s var(--ease),filter .25s var(--ease);
}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .hero-content{grid-template-columns:1fr;gap:40px}
  .hero-left{padding-bottom:0}
  .section-head,.media-toolbar{align-items:flex-start}
  .home-media-showcase{grid-template-columns:1fr}
  .home-album-feature{min-height:500px}
  .home-media-stack{grid-template-columns:repeat(2,1fr);grid-template-rows:auto;grid-auto-rows:auto}
  .home-mini-card,.home-video-card{min-height:220px}
  .about-stats{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-auto-rows:90px}
  .gi-1,.gi-2,.gi-3,.gi-4,.gi-5,.gi-6,.gi-7,.gi-8,.gi-9,.gi-10,.gi-11,.gi-12{grid-column:span 6;grid-row:span 3}
  .vision-strip{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr 1fr}
  .editorial,.editorial.reverse{grid-template-columns:1fr;gap:40px}
  .editorial.reverse .editorial-img{order:0}
  .about-prev{grid-template-columns:1fr;gap:50px}
  .event-spotlight,.event-spotlight.alt{grid-template-columns:1fr}
  .event-spotlight.alt .es-img{order:0}
  .event-feature{grid-template-columns:1fr;min-height:0}
  .event-feature-media{min-height:460px}
  .event-feature-media::after{background:linear-gradient(180deg,transparent 45%,rgba(7,5,10,.72) 100%)}
  .event-journal{grid-template-columns:1fr 1fr}
  .event-directions{grid-template-columns:1fr;gap:34px}
  .es-body{padding:32px 28px}
  .connect-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .footer-brand{grid-column:span 2}
  .nav-links{display:none}
  .nav-cta{display:flex;margin-left:auto}
  .nav-toggle{display:grid;place-items:center}
  .timeline::before{left:24px}
  .timeline-row,.timeline-row.right,.timeline-row.left{grid-template-columns:48px 1fr;gap:18px}
  .timeline-row .dot{justify-self:start;margin-left:18px}
  .timeline-row.left .timeline-card,.timeline-row.right .timeline-card{grid-column:2;text-align:left}
  .highlights-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .album-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:680px){
  :root{--page-pad:16px}
  body{font-size:15px}
  section{padding:64px 0}
  section.compact{padding:58px 0}
  .container{width:min(var(--maxw),calc(100vw - 32px))}
  .page-hero{padding:120px 0 52px;text-align:left}
  .page-hero h1{font-size:clamp(2.55rem,13vw,4.2rem);line-height:1.02}
  .page-hero p{margin:18px 0 0;font-size:.98rem;line-height:1.65}
  .page-hero .crumbs{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:8px;margin-bottom:14px;letter-spacing:.22em}
  .section-title{font-size:clamp(2rem,11vw,3rem);line-height:1.05}
  .section-lede,.kicker,.editorial-text p,.event-feature-body p{font-size:.98rem;line-height:1.7}
  .eyebrow{gap:8px;font-size:9px;letter-spacing:.22em}
  .eyebrow::before{width:22px}
  .section-head,.media-toolbar,.album-head{display:flex;flex-direction:column;align-items:stretch;gap:18px}
  .section-actions{width:100%;flex-direction:column;align-items:stretch}
  .section-actions .btn{justify-content:center}
  .btn{width:100%;justify-content:center;min-height:50px;padding:13px 18px;font-size:11px;letter-spacing:.13em}
  .floating-brand{right:16px;bottom:calc(16px + env(safe-area-inset-bottom));width:48px;height:48px}
  .hero{min-height:100svh;padding:104px 0 64px;align-items:flex-end}
  .hero-content{display:block}
  .hero-tag{margin-bottom:16px}
  .hero-media img{
    object-position:67% center;
    transform:scale(1.02);
  }
  .hero-title{font-size:clamp(3.3rem,16vw,4.8rem);margin-bottom:18px}
  .hero-title .line2{margin-left:0}
  .hero-sub{font-size:1rem;line-height:1.65;margin-bottom:24px}
  .hero-scroll{display:none}
  .nav{padding:8px 0;background:#07050a;border-bottom:1px solid rgba(255,255,255,.09)}
  .nav.scrolled{padding:6px 0}
  .nav-inner{width:calc(100vw - 24px);min-height:58px}
  .brand{gap:9px;margin-right:10px}
  .brand-mark{width:46px;height:58px;flex:0 0 46px}
  .brand-mark::before{top:1px;width:42px;height:56px;border-radius:18px}
  .brand-mark img{max-height:50px}
  .brand-text{font-size:18px;letter-spacing:.04em;line-height:1}
  .brand-text small{font-size:7px;letter-spacing:.18em;margin-top:4px}
  .nav-toggle{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.06)}
  .mobile-menu{display:block;padding:calc(76px + env(safe-area-inset-top)) 16px calc(18px + env(safe-area-inset-bottom));overflow-y:auto}
  .mobile-menu nav{width:100%;min-height:calc(100dvh - 110px);display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:10px;text-align:left}
  .mobile-menu a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    min-height:52px;
    padding:14px 16px;
    border-radius:16px;
    border:1px solid var(--line);
    background:rgba(255,255,255,.045);
    font-family:var(--font-sans);
    font-size:1rem;
    letter-spacing:.04em;
  }
  .mobile-menu a:hover{transform:none}
  .mobile-subnav{
    display:grid;
    grid-template-columns:1fr 1fr;
    margin:0;
    padding:6px;
    border-radius:18px;
  }
  .mobile-menu .mobile-subnav a{
    justify-content:center;
    min-height:44px;
    padding:11px 8px;
    border:0;
    border-radius:13px;
    background:transparent;
    font-size:.72rem;
    letter-spacing:.14em;
  }
  .mobile-menu .mobile-meta{justify-content:center;flex-wrap:wrap;gap:8px;margin-top:14px;letter-spacing:.18em}
  .home-album-feature{min-height:420px;border-radius:var(--radius-lg)}
  .home-album-feature > div{padding:24px}
  .home-media-stack{grid-template-columns:1fr}
  .home-mini-card,.home-video-card{min-height:190px}
  .event-feature-body{padding:34px 24px}
  .event-feature-media{min-height:320px}
  .event-facts{grid-template-columns:1fr}
  .event-journal{grid-template-columns:1fr}
  .event-type-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .connect-list{grid-template-columns:1fr}
  .contact-form{padding:34px 24px}
  .media-tabs{width:100%;margin-top:24px;padding:5px;box-shadow:0 18px 40px -28px rgba(0,0,0,.9)}
  .media-tabs button{flex:1;min-width:0;min-height:46px;padding:10px 8px;letter-spacing:.14em}
  .media-toolbar{margin-bottom:20px}
  .album-grid{grid-template-columns:1fr;gap:16px}
  .album-card{border-radius:22px}
  .album-cover{aspect-ratio:4/3}
  .album-body{padding:20px}
  .album-body small{font-size:9px;letter-spacing:.18em}
  .album-body h3{font-size:1.45rem}
  .album-preview{display:none}
  .album-count{right:12px;bottom:12px;font-size:9px;letter-spacing:.14em}
  .album-head > div{text-align:left}
  .album-mosaic{grid-template-columns:repeat(3,1fr);gap:4px}
  .album-head .btn{width:auto;align-self:flex-start}
  .gallery-grid{grid-auto-rows:64px;gap:10px}
  .gallery-item .meta{opacity:1;transform:none;left:12px;right:12px;bottom:12px}
  .gallery-item .meta .ttl{font-size:.92rem}
  .gallery-item .meta .cat{display:none}
  .gi-1,.gi-2,.gi-3,.gi-4,.gi-5,.gi-6,.gi-7,.gi-8,.gi-9,.gi-10,.gi-11,.gi-12{grid-column:span 6;grid-row:span 4}
  .vision-strip{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stat{padding:18px}
  .stat .num{font-size:1.75rem}
  .stat .lbl{font-size:9px;letter-spacing:.16em}
  .highlights-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-brand{grid-column:span 1}
  .footer{padding:58px 0 26px;margin-top:42px}
  .footer-bottom{justify-content:center;text-align:center;letter-spacing:.12em}
  .hero-meta{padding:22px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{justify-content:center}
  .filters{padding:6px;gap:4px}
  .filters button{padding:8px 14px;font-size:10px;letter-spacing:.18em}
  .marquee-item{font-size:1.2rem;gap:30px}
  .lightbox{padding:30px 14px}
  .connect-cta{padding:52px 18px;border-radius:24px}
  .connect-cta p{font-size:.96rem}
}

@media (max-width:420px){
  .brand-text{font-size:17px}
  .brand-text small{display:none}
  .page-hero{padding-top:110px}
  .hero-title{font-size:clamp(3rem,17vw,4.2rem)}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- Selection ---------- */
::selection{background:rgba(255,184,198,.35);color:#1a0f22}
