/* ─── RESET ─────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#c9a96e;--gold2:#e8d5b0;--gold-dim:rgba(201,169,110,.08);
  --bg:#080808;--bg2:#0f0e0d;--bg3:#151412;--bg4:#1c1a18;
  --ink:#f0ece4;--muted:#6e6358;
  --border:rgba(255,255,255,.06);--border2:rgba(201,169,110,.2);
  --fc:'Cormorant Garamond',Georgia,serif;
  --fi:'Inter',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease2:cubic-bezier(.25,.46,.45,.94);
}
html{scroll-behavior:smooth;background:var(--bg)}
body{background:var(--bg);color:var(--ink);font-family:var(--fi);overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.menu-open{overflow:hidden}

/* ─── SCROLL REVEALS ─────────────────────────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(50px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal="left"]{transform:translateX(-50px)}
[data-reveal="right"]{transform:translateX(50px)}
[data-reveal="scale"]{transform:scale(.95)}
[data-reveal].visible{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}
[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}
[data-delay="5"]{transition-delay:.5s}[data-delay="6"]{transition-delay:.6s}

/* ─── CLIP REVEALS ───────────────────────────────────────────────────────── */
.clip{overflow:hidden;display:block}
.clip>span{display:block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
[data-reveal].visible .clip>span{transform:none}

/* ══════════════════════════════════════════════════════
   FEATURE 1 — THEATRE CURTAIN LOADER
══════════════════════════════════════════════════════ */
#loading{position:fixed;inset:0;z-index:99999;pointer-events:all;display:flex;align-items:center;justify-content:center}
#loading.done{pointer-events:none;visibility:hidden}
.curtain{position:absolute;top:0;height:100%;width:50%;background:#0a0908;transition:transform 2.2s cubic-bezier(.77,0,.18,1)}
#loading.open .curtain-center{opacity:0;transition:opacity .25s}
#cl{left:0}
#cr{right:0}
/* Subtle curtain texture */
.curtain::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(255,255,255,.012) 0 1px,transparent 1px 40px);pointer-events:none}
#loading.open #cl{transform:translateX(-100%)}
#loading.open #cr{transform:translateX(100%)}
#loading.done #cl,#loading.done #cr{display:none}
.curtain-center{position:relative;z-index:2;text-align:center;pointer-events:none}
.curtain-logo{font-family:var(--fc);font-weight:300;font-size:2.5rem;letter-spacing:.45em;color:var(--gold);opacity:0;transform:translateY(12px);animation:cUp .8s .2s var(--ease) forwards}
.curtain-sub{font-family:var(--fi);font-size:.55rem;letter-spacing:.55em;text-transform:uppercase;color:var(--muted);margin-top:.5rem;opacity:0;animation:cUp .7s .55s var(--ease) forwards;display:block}
.curtain-rule{width:3rem;height:1px;background:var(--border);position:relative;overflow:hidden;margin:.75rem auto 0}
.curtain-rule::after{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-100%);animation:ruleFill 1s .65s var(--ease) forwards}
@keyframes cUp{to{opacity:1;transform:none}}
@keyframes ruleFill{to{transform:translateX(0)}}

/* ══════════════════════════════════════════════════════
   FEATURE 2 — SPOTLIGHT CURSOR OVERLAY
══════════════════════════════════════════════════════ */
#spotlight{position:fixed;inset:0;pointer-events:none;z-index:9990;opacity:0;transition:opacity 2s}
#spotlight.on{opacity:1}

/* ─── CUSTOM CURSOR ──────────────────────────────────────────────────────── */
#cursor{position:fixed;width:6px;height:6px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);opacity:0;transition:width .35s var(--ease),height .35s var(--ease),opacity .3s,background .3s}
#cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(201,169,110,.4);border-radius:50%;pointer-events:none;z-index:99997;transform:translate(-50%,-50%);opacity:0;transition:width .5s var(--ease),height .5s var(--ease),opacity .5s,left .12s linear,top .12s linear}
body.cursor-on #cursor,body.cursor-on #cursor-ring{opacity:1}
#cursor.lh{width:46px;height:46px;background:transparent;border:1px solid var(--gold)}
#cursor-ring.lh{width:8px;height:8px;opacity:.5}

/* ─── SCROLL PROGRESS ────────────────────────────────────────────────────── */
#scroll-progress{position:fixed;top:0;left:0;height:1px;background:linear-gradient(90deg,var(--gold),var(--gold2));z-index:9997;width:0%;will-change:width}

/* ─── NOISE ──────────────────────────────────────────────────────────────── */
#noise{position:fixed;inset:0;pointer-events:none;z-index:9995;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");background-size:300px}

/* ══════════════════════════════════════════════════════
   FEATURE 3 — FULL-SCREEN OVERLAY NAV
══════════════════════════════════════════════════════ */
#nav-overlay{position:fixed;inset:0;background:#060504;z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
#nav-overlay.open{opacity:1;pointer-events:all}
.ov-close{position:absolute;top:1.75rem;right:2rem;background:none;border:none;color:var(--muted);cursor:pointer;transition:color .3s;padding:.5rem;display:flex}
.ov-close:hover{color:var(--gold)}
.ov-inner{text-align:center}
.ov-link{display:block;font-family:var(--fc);font-weight:300;font-size:clamp(2rem,7vw,5rem);color:var(--muted);text-decoration:none;line-height:1.1;padding:.1em 0;letter-spacing:.02em;overflow:hidden;transition:color .4s,letter-spacing .5s}
.ov-link span{display:inline-block;transform:translateY(110%);transition:transform .85s var(--ease)}
#nav-overlay.open .ov-link span{transform:none}
.ov-link:hover{color:var(--ink);letter-spacing:.1em}
.ov-link:nth-child(1) span{transition-delay:.04s}
.ov-link:nth-child(2) span{transition-delay:.09s}
.ov-link:nth-child(3) span{transition-delay:.14s}
.ov-link:nth-child(4) span{transition-delay:.19s}
.ov-link:nth-child(5) span{transition-delay:.24s}
.ov-link:nth-child(6) span{transition-delay:.29s}
.ov-rule{width:2rem;height:1px;background:var(--gold);margin:2rem auto;transition:width .6s .35s var(--ease),opacity .4s .35s;opacity:0}
#nav-overlay.open .ov-rule{width:5rem;opacity:1}
.ov-contact{font-family:var(--fi);font-size:.65rem;letter-spacing:.45em;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .4s .45s}
#nav-overlay.open .ov-contact{opacity:1}

/* ─── NAV ────────────────────────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .6s,border-color .6s;border-bottom:1px solid transparent}
#nav.solid{background:rgba(8,8,8,.92);backdrop-filter:blur(16px);border-color:var(--border)}
.nav-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem;height:72px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--fc);font-weight:300;font-size:1.4rem;letter-spacing:.3em;color:var(--ink);text-decoration:none;transition:color .3s}
.logo:hover{color:var(--gold)}
.logo-sub{display:block;font-family:var(--fi);font-size:.55rem;letter-spacing:.5em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-family:var(--fi);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .4s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
/* Burger — always visible */
#nav-burger{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:.5rem;margin-left:1.5rem}
#nav-burger span{display:block;background:var(--ink);height:1px;width:22px;transition:transform .4s var(--ease),opacity .3s,background .3s}
#nav-burger:hover span{background:var(--gold)}
body.menu-open #nav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open #nav-burger span:nth-child(2){opacity:0}
body.menu-open #nav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:768px){.nav-links{display:none}}

/* ─── HERO ───────────────────────────────────────────────────────────────── */
#hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
#hero-img{width:100%;height:120%;object-fit:cover;object-position:center;will-change:transform}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,8,8,.5) 0%,rgba(8,8,8,.35) 40%,rgba(8,8,8,.82) 80%,var(--bg) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 1.5rem;max-width:980px}
.hero-eyebrow{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2.5rem;opacity:0;animation:fadeUp .8s .3s var(--ease) forwards}
.hero-line{width:3rem;height:1px;background:var(--gold)}
.hero-eyebrow-label{font-family:var(--fi);font-size:.6875rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold)}

/* ══════════════════════════════════════════════════════
   FEATURE 4 — LETTER-BY-LETTER HERO TITLE
══════════════════════════════════════════════════════ */
.hero-title{font-family:var(--fc);font-weight:300;font-size:clamp(3rem,7vw,7.5rem);letter-spacing:.06em;line-height:.9;color:var(--ink);text-align:center}
.hero-letter{display:inline-block;opacity:0;animation:letterDrop 1s var(--ease) forwards}
@keyframes letterDrop{from{opacity:0;transform:translateY(-35px) rotate(-5deg)}to{opacity:1;transform:none}}

.hero-subtitle{font-family:var(--fc);font-style:italic;font-size:clamp(1.2rem,2.8vw,2rem);color:var(--gold);margin-top:1.5rem;opacity:0;animation:fadeUp .8s .9s var(--ease) forwards}
.hero-body{font-family:var(--fi);font-size:.875rem;color:var(--muted);max-width:500px;margin:2rem auto 0;line-height:1.9;opacity:0;animation:fadeUp .8s 1.1s var(--ease) forwards}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2.5rem;opacity:0;animation:fadeUp .8s 1.3s var(--ease) forwards}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.35rem;color:var(--muted);text-decoration:none;transition:color .3s;animation:bounce 2s 1.5s infinite;z-index:2}
.hero-scroll:hover{color:var(--gold)}
.hero-scroll-lbl{font-family:var(--fi);font-size:.55rem;letter-spacing:.4em;text-transform:uppercase}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* ─── BUTTONS ────────────────────────────────────────────────────────────── */
.btn-primary,.btn-outline,.btn-gold-outline{position:relative;overflow:hidden;padding:.9rem 2.5rem;font-family:var(--fi);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;text-decoration:none;font-weight:500;display:inline-block}
.btn-primary::before,.btn-outline::before,.btn-gold-outline::before{content:'';position:absolute;inset:0;transform:translateY(100%);transition:transform .5s var(--ease)}
.btn-primary{background:var(--gold);color:var(--bg);transition:color .3s}
.btn-primary::before{background:var(--gold2)}
.btn-primary:hover::before{transform:none}
.btn-outline{border:1px solid rgba(240,236,228,.25);color:var(--ink);transition:border-color .3s,color .3s}
.btn-outline::before{background:rgba(201,169,110,.08)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline:hover::before{transform:none}
.btn-gold-outline{border:1px solid var(--gold);color:var(--gold);transition:color .3s}
.btn-gold-outline::before{background:var(--gold)}
.btn-gold-outline:hover{color:var(--bg)}
.btn-gold-outline:hover::before{transform:none}

/* ─── SECTIONS ───────────────────────────────────────────────────────────── */
.section{padding:8rem 0}
.section-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem}
.section-label{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem}
.section-label-line{flex:0 0 2rem;height:1px;background:var(--gold)}
.section-label-text{font-family:var(--fi);font-size:.6875rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold)}
.section-title{font-family:var(--fc);font-weight:300;font-size:clamp(2.5rem,6vw,5rem);line-height:1;color:var(--ink)}
.section-title em{font-style:italic;color:var(--gold)}
.divider{height:1px;background:var(--border);max-width:1400px;margin:0 auto}

/* ─── MARQUEE ────────────────────────────────────────────────────────────── */
.marquee-section{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:.875rem 0}
.marquee-track{display:flex;width:max-content;animation:marquee 32s linear infinite}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{font-family:var(--fc);font-style:italic;font-size:1.0625rem;color:var(--muted);white-space:nowrap;padding:0 2.5rem;display:flex;align-items:center;gap:2.5rem;transition:color .3s}
.marquee-item:hover{color:var(--gold)}
.marquee-dot{width:3px;height:3px;background:var(--border2);border-radius:50%;flex-shrink:0}

/* ─── ABOUT ──────────────────────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-text-body{font-size:.9375rem;line-height:1.9;color:var(--muted);margin-bottom:1.25rem}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid var(--border)}
.stat-num{font-family:var(--fc);font-size:2.5rem;color:var(--gold);line-height:1}
.stat-lbl{font-family:var(--fi);font-size:.7rem;color:var(--muted);line-height:1.5;margin-top:.4rem;white-space:pre-line}
.about-image-wrap{position:relative}
.about-image-wrap::before{content:'';position:absolute;top:-1.5rem;right:-1.5rem;width:5rem;height:5rem;border-top:1px solid var(--border2);border-right:1px solid var(--border2)}

/* ══════════════════════════════════════════════════════
   FEATURE 5 — GOLD SWEEP IMAGE REVEAL
══════════════════════════════════════════════════════ */
.img-reveal{position:relative;overflow:hidden}
.img-reveal img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top;filter:grayscale(100%) contrast(1.05);transition:filter .8s;opacity:0}
.img-reveal.show-img img{opacity:1}
.img-reveal img:hover{filter:grayscale(25%)}
/* gold sweep bar */
.img-reveal::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--gold) 0%,var(--gold2) 100%);transform:translateX(-101%);z-index:3;pointer-events:none}
.img-reveal.sweep-in::before{transform:translateX(0);transition:transform .6s var(--ease)}
.img-reveal.sweep-out::before{transform:translateX(101%);transition:transform .5s var(--ease)}
/* dark vignette overlay */
.img-reveal::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,8,.5),transparent);z-index:1;pointer-events:none}

.director-card{position:absolute;bottom:-2rem;left:-2rem;background:var(--bg3);border:1px solid var(--border);padding:1.5rem;max-width:240px;z-index:2}
.director-card-line{width:2rem;height:1px;background:var(--gold);margin-bottom:1rem}
.director-name{font-family:var(--fc);font-style:italic;font-size:1.125rem;color:var(--ink);margin-bottom:.3rem}
.director-title-text{font-family:var(--fi);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.quote-section{text-align:center;max-width:800px;margin:7rem auto 0;padding:4rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative}
.quote-section::before{content:'\201C';position:absolute;top:-2rem;left:50%;transform:translateX(-50%);font-family:var(--fc);font-size:12rem;color:var(--gold);opacity:.04;line-height:1;pointer-events:none}
.quote-mark{font-family:var(--fc);font-size:4rem;color:var(--gold);opacity:.2;line-height:1}
.quote-text{font-family:var(--fc);font-style:italic;font-size:clamp(1.25rem,2.5vw,1.75rem);color:var(--ink);font-weight:300;line-height:1.65;margin:.5rem 0 1.5rem}
.quote-attr{font-family:var(--fi);font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold)}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}.about-image-wrap{order:-1}.director-card{left:-1rem}}

/* ─── PROGRAMS ───────────────────────────────────────────────────────────── */
.programs-bg{background:var(--bg2)}
.programs-header{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:end;margin-bottom:1rem}
.prog-list{display:flex;flex-direction:column}
.prog-item{display:grid;grid-template-columns:4rem 1fr auto;gap:2rem;align-items:start;padding:2rem 0;border-bottom:1px solid var(--border);transition:padding-left .4s var(--ease);position:relative;overflow:hidden}
/* left gold bar grows on hover */
.prog-item::before{content:'';position:absolute;left:0;top:0;width:2px;height:100%;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .4s var(--ease)}
.prog-item:hover::before{transform:scaleY(1)}
.prog-item:hover{padding-left:1rem}
.prog-item:hover .prog-title,.prog-item:hover .prog-num{color:var(--gold)}
.prog-num{font-family:var(--fc);font-size:3rem;font-weight:300;color:rgba(201,169,110,.15);line-height:1;padding-top:.25rem;transition:color .4s}
.prog-title{font-family:var(--fc);font-size:clamp(1.3rem,2.5vw,1.75rem);color:var(--ink);line-height:1.2;margin-bottom:.75rem;transition:color .4s}
.prog-desc{font-family:var(--fi);font-size:.8125rem;color:var(--muted);line-height:1.8;max-width:560px}
.prog-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}
.prog-badge{background:var(--gold-dim);border:1px solid var(--border2);padding:.2rem .6rem;font-family:var(--fi);font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.prog-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;padding-top:.5rem}
.prog-meta-item{font-family:var(--fi);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.prog-meta-item span{color:var(--gold);margin-left:.4rem}
.prog-item.featured-row{background:linear-gradient(to right,rgba(201,169,110,.04),transparent)}
.prog-cta{text-align:center;margin-top:3.5rem}
@media(max-width:900px){.programs-header{grid-template-columns:1fr}}
@media(max-width:768px){.prog-item{grid-template-columns:3rem 1fr}.prog-meta{display:none}.prog-item:hover{padding-left:0}}

/* ─── GROUPS ─────────────────────────────────────────────────────────────── */
.group-item{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.group-item:nth-child(even) .group-img-wrap{order:1}
.group-img-wrap{position:relative;overflow:hidden}
.group-img-wrap img{width:100%;height:100%;min-height:400px;object-fit:cover;filter:grayscale(90%);transform:scale(1.04);transition:filter .8s,transform .8s}
.group-item:hover .group-img-wrap img{filter:grayscale(0);transform:scale(1)}
.group-img-wrap::after{content:'';position:absolute;inset:0;background:rgba(8,8,8,.35);transition:background .8s}
.group-item:hover .group-img-wrap::after{background:rgba(8,8,8,.1)}
.group-year{position:absolute;bottom:1.5rem;right:1.5rem;font-family:var(--fc);font-size:3.5rem;font-weight:300;color:rgba(201,169,110,.2);line-height:1}

/* ══════════════════════════════════════════════════════
   FEATURE 6 — 3D PERSPECTIVE TILT ON GROUP TEXT PANEL
══════════════════════════════════════════════════════ */
.group-text{background:var(--bg3);padding:4rem;display:flex;flex-direction:column;justify-content:center;border:1px solid var(--border);will-change:transform;transition:transform .25s var(--ease2)}
.group-name{font-family:var(--fc);font-size:clamp(1.4rem,2.5vw,2rem);color:var(--ink);margin-bottom:1.25rem;line-height:1.2}
.group-desc{font-family:var(--fi);font-size:.8125rem;color:var(--muted);line-height:1.85;margin-bottom:2rem}
.group-details{padding-top:1.5rem;border-top:1px solid var(--border)}
.group-detail{display:flex;gap:1.5rem;margin-bottom:.6rem;font-family:var(--fi);font-size:.75rem}
.group-detail-lbl{color:var(--muted);width:5rem;flex-shrink:0}
.group-detail-val{color:var(--gold)}
@media(max-width:900px){.group-item{grid-template-columns:1fr}.group-item:nth-child(even) .group-img-wrap{order:unset}}

/* ─── GALLERY ────────────────────────────────────────────────────────────── */
.gallery-bg{background:var(--bg2)}
.gallery-intro{padding:5rem 0 2rem}
.gallery-header{display:grid;grid-template-columns:1fr auto;align-items:end;gap:2rem}
.gallery-hint{font-family:var(--fi);font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.6rem}

/* ══════════════════════════════════════════════════════
   FEATURE 7 — PINNED HORIZONTAL SCROLL GALLERY
══════════════════════════════════════════════════════ */
.gallery-pin-track{position:relative}
.gallery-pin-sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}
.gallery-h-strip{display:flex;gap:1.5rem;padding:0 5vw;will-change:transform}
.gallery-h-item{flex-shrink:0;position:relative;overflow:hidden;cursor:pointer}
.gallery-h-item img{display:block;height:62vh;width:100%;object-fit:cover;filter:grayscale(75%);transition:filter .6s,transform .6s;pointer-events:none;vertical-align:top}
.gallery-h-item:hover img{filter:grayscale(0);transform:scale(1.03)}
.gallery-h-item::after{content:'';position:absolute;inset:0;background:rgba(8,8,8,.18);transition:background .5s;pointer-events:none}
.gallery-h-item:hover::after{background:transparent}
.gallery-h-num{position:absolute;bottom:.75rem;right:1rem;font-family:var(--fc);font-size:3.5rem;font-weight:300;color:rgba(201,169,110,.22);line-height:1;pointer-events:none}
/* Progress bar for horizontal gallery */
.gallery-h-progress-wrap{position:absolute;bottom:2.5rem;left:5vw;right:5vw;height:1px;background:var(--border)}
.gallery-h-progress{height:100%;background:var(--gold);width:0%;transition:width .05s linear;transform-origin:left}
.gallery-h-scroll-hint{position:absolute;bottom:2.5rem;right:5vw;font-family:var(--fi);font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.5rem;opacity:0;transition:opacity .5s;pointer-events:none}
.gallery-h-scroll-hint.show{opacity:1}
/* Mobile drag fallback */
.gallery-mobile-wrap{display:none;padding:0 2.5rem 2rem}
.gallery-mobile-scroll{overflow-x:auto;cursor:grab;scrollbar-width:none}
.gallery-mobile-scroll::-webkit-scrollbar{display:none}
.gallery-mobile-scroll.grabbing{cursor:grabbing}
.gallery-mobile-strip{display:flex;gap:.75rem;width:max-content}
.gallery-mobile-item{flex-shrink:0;overflow:hidden}
.gallery-mobile-item img{display:block;height:280px;width:auto;object-fit:cover;filter:grayscale(70%);transition:filter .5s}
.gallery-mobile-item:hover img{filter:grayscale(0)}
/* Videos */
.gallery-videos-wrap{max-width:1400px;margin:0 auto;padding:1.5rem 2.5rem 3rem}
.gallery-videos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.yt-card{position:relative;overflow:hidden;aspect-ratio:16/9;cursor:pointer;background:#000}
.yt-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.yt-thumb{position:absolute;inset:0}
.yt-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(60%);transition:filter .8s,transform .8s;display:block}
.yt-card:hover .yt-thumb img{filter:grayscale(0);transform:scale(1.03)}
.yt-overlay{position:absolute;inset:0;background:rgba(8,8,8,.5);display:flex;align-items:center;justify-content:center;transition:background .5s}
.yt-card:hover .yt-overlay{background:rgba(8,8,8,.25)}
.play-btn{width:4rem;height:4rem;border:2px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .3s}
.yt-card:hover .play-btn{background:rgba(201,169,110,.15)}
.play-tri{width:0;height:0;border-top:9px solid transparent;border-bottom:9px solid transparent;border-left:16px solid var(--gold);margin-left:4px}
.gallery-videos-cta{display:flex;justify-content:center;margin-top:2rem}
.yt-channel-link{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--fi);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(201,169,110,.35);padding:.65rem 1.4rem;transition:background .3s,border-color .3s}
.yt-channel-link:hover{background:rgba(201,169,110,.08);border-color:var(--gold)}
@media(max-width:900px){.gallery-videos-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.gallery-videos-grid{grid-template-columns:1fr}.gallery-videos-wrap{padding:1rem 1.25rem 2.5rem}}

/* ─── SCHEDULE ───────────────────────────────────────────────────────────── */
.schedule-layout{display:grid;grid-template-columns:1fr 2fr;gap:6rem;align-items:start}
.schedule-intro-body{font-family:var(--fi);font-size:.875rem;color:var(--muted);line-height:1.8;margin-top:1.5rem}
.cal-note{margin-top:1.5rem;display:flex;align-items:center;gap:.75rem;font-family:var(--fi);font-size:.7rem;color:var(--muted)}

/* ══════════════════════════════════════════════════════
   FEATURE 8 — ANIMATED TIMELINE DRAW LINE
══════════════════════════════════════════════════════ */
.timeline-wrap{position:relative}
.timeline-draw{position:absolute;left:2rem;top:0;width:1px;height:0;background:var(--border2);transition:height 2s var(--ease2);z-index:0}
.timeline-draw.drawn{height:100%}
.timeline{display:flex;flex-direction:column;gap:.75rem;position:relative;z-index:1}
.event{display:grid;grid-template-columns:4rem 1fr;gap:1.5rem;align-items:start;padding:1.5rem;border:1px solid var(--border);background:var(--bg3);transition:border-color .4s,background .4s,transform .35s var(--ease)}
.event:hover{border-color:var(--border2);background:var(--bg4);transform:translateX(6px)}
.event.hot{border-color:rgba(201,169,110,.35);background:rgba(26,22,18,.8);position:relative}
.event.hot::before{content:'';position:absolute;top:.75rem;right:.75rem;width:6px;height:6px;background:var(--gold);border-radius:50%;animation:hotpulse 2s ease-in-out infinite}
@keyframes hotpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}
.event-date{text-align:center}
.event-day{font-family:var(--fc);font-size:2rem;color:var(--gold);line-height:1}
.event-month{font-family:var(--fi);font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.event-title-text{font-family:var(--fc);font-size:1.125rem;color:var(--ink);line-height:1.3}
.event-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.4rem}
.event-tag{font-family:var(--fi);font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--border2);color:var(--gold);background:var(--gold-dim)}
.event-tag.plain{border-color:rgba(240,236,228,.15);color:var(--ink);background:rgba(240,236,228,.04)}
.event-sub{font-family:var(--fi);font-size:.75rem;color:var(--muted);margin-bottom:.75rem;line-height:1.6}
.event-meta{display:flex;flex-wrap:wrap;gap:.8rem;font-family:var(--fi);font-size:.65rem;color:var(--muted)}
.event-meta-item{display:flex;align-items:center;gap:.3rem}
@media(max-width:900px){.schedule-layout{grid-template-columns:1fr}}

/* ─── CONTACT ────────────────────────────────────────────────────────────── */
.contact-bg{background:var(--bg2)}
.contact-header{text-align:center;margin-bottom:5rem}
.contact-header p{font-family:var(--fi);font-size:.9rem;color:var(--muted);max-width:520px;margin:1.5rem auto 0;line-height:1.8}
.contact-grid{display:grid;grid-template-columns:1fr 1.7fr;gap:5rem}
.contact-block{display:flex;gap:1.25rem;margin-bottom:2rem}
.contact-icon{width:2.5rem;height:2.5rem;border:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:.15rem}
.contact-lbl{font-family:var(--fi);font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.contact-val{font-family:var(--fi);font-size:.875rem;color:var(--ink)}
.c-divider{height:1px;background:var(--border);margin:2rem 0}
.c-h5{font-family:var(--fi);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin-bottom:1.25rem}
.hours-row{display:flex;justify-content:space-between;font-family:var(--fi);font-size:.8125rem;margin-bottom:.5rem}
.hours-day{color:var(--muted)}.hours-val{color:var(--gold)}
.social-row{display:flex;gap:.75rem;margin-top:.5rem}
.social-btn{width:2.5rem;height:2.5rem;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;transition:color .3s,border-color .3s}
.social-btn:hover{color:var(--gold);border-color:var(--gold)}
.field-wrap{margin-bottom:1.25rem;position:relative}
.field-label{display:block;font-family:var(--fi);font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.field{width:100%;background:var(--bg4);border:1px solid var(--border);color:var(--ink);padding:.875rem 1rem;font-size:.875rem;font-family:var(--fi);outline:none;transition:border-color .3s;-webkit-appearance:none;border-radius:0}
.field::placeholder{color:var(--muted)}
.field:focus{border-color:var(--gold)}
.field-focus-line{position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.field-wrap:focus-within .field-focus-line{transform:scaleX(1)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.125rem;background:var(--gold);color:var(--bg);font-family:var(--fi);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;font-weight:500;border:none;cursor:pointer;margin-top:.5rem;position:relative;overflow:hidden}
.form-btn::before{content:'';position:absolute;inset:0;background:var(--gold2);transform:translateY(100%);transition:transform .5s var(--ease)}
.form-btn span,.form-btn i{position:relative;z-index:1}
.form-btn:hover::before{transform:none}
.form-btn:disabled{opacity:.6;cursor:not-allowed}
#form-error{display:none;padding:1rem;border:1px solid rgba(185,28,28,.5);background:rgba(127,29,29,.15);color:#fca5a5;font-family:var(--fi);font-size:.8125rem;margin-bottom:1rem;line-height:1.6}
#form-success{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;border:1px solid var(--border2);background:var(--bg4);min-height:360px}
.success-check{font-family:var(--fc);font-size:3rem;color:var(--gold);margin-bottom:1.5rem}
.success-title{font-family:var(--fc);font-size:1.75rem;color:var(--ink);margin-bottom:.75rem}
.success-sub{font-family:var(--fi);font-size:.8125rem;color:var(--muted)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

/* ─── FOOTER ─────────────────────────────────────────────────────────────── */
footer{background:#050505;border-top:1px solid var(--border);padding:5rem 0 3rem}
.footer-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:4rem;margin-bottom:4rem}
.footer-logo{font-family:var(--fc);font-weight:300;font-size:1.5rem;letter-spacing:.3em;color:var(--ink);margin-bottom:.5rem}
.footer-tagline{font-family:var(--fi);font-size:.55rem;letter-spacing:.45em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.footer-desc{font-family:var(--fi);font-size:.8125rem;color:var(--muted);line-height:1.8;max-width:280px}
.footer-nav-title{font-family:var(--fi);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.footer-nav-links{list-style:none}
.footer-nav-links li{margin-bottom:.75rem}
.footer-nav-links a{font-family:var(--fi);font-size:.8125rem;color:var(--muted);text-decoration:none;transition:color .3s;position:relative;display:inline-block}
.footer-nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.footer-nav-links a:hover{color:var(--gold)}
.footer-nav-links a:hover::after{width:100%}
.footer-contact-list{list-style:none}
.footer-contact-list li{font-family:var(--fi);font-size:.8125rem;color:var(--muted);margin-bottom:.75rem}
.footer-contact-list li.accent{color:var(--gold)}
.footer-bottom{padding-top:2rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem}
.footer-copy{font-family:var(--fi);font-size:.7rem;color:var(--muted)}
.footer-legal{display:flex;gap:2rem}
.footer-legal a{font-family:var(--fi);font-size:.7rem;color:var(--muted);text-decoration:none;transition:color .3s}
.footer-legal a:hover{color:var(--gold)}
@media(max-width:768px){.footer-top{grid-template-columns:1fr}}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* ─── COOKIE BANNER ──────────────────────────────────────────────────────── */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:8000;transform:translateY(100%);transition:transform .6s var(--ease);background:var(--bg3);border-top:1px solid var(--border2)}
#cookie-banner.show{transform:translateY(0)}
#cookie-inner{max-width:1400px;margin:0 auto;padding:1.25rem 2.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
#cookie-text-wrap{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:260px}
#cookie-icon-label{display:flex;align-items:flex-start;gap:.55rem;font-family:var(--fi);font-size:.8rem;color:var(--muted);line-height:1.7}
.cookie-link{background:none;border:none;cursor:pointer;font-family:var(--fi);font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.3rem;padding:0;transition:opacity .3s;text-align:left;width:fit-content}
.cookie-link:hover{opacity:.7}
#cookie-actions{display:flex;gap:.75rem;flex-shrink:0;flex-wrap:wrap}
.cookie-btn-secondary{padding:.65rem 1.5rem;background:none;border:1px solid var(--border);color:var(--muted);font-family:var(--fi);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;cursor:pointer;transition:border-color .3s,color .3s;white-space:nowrap}
.cookie-btn-secondary:hover{border-color:var(--muted);color:var(--ink)}
.cookie-btn-primary{padding:.65rem 1.5rem;background:var(--gold);border:1px solid var(--gold);color:var(--bg);font-family:var(--fi);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;cursor:pointer;font-weight:500;transition:background .3s;white-space:nowrap;position:relative;overflow:hidden}
.cookie-btn-primary::before{content:'';position:absolute;inset:0;background:var(--gold2);transform:translateY(100%);transition:transform .4s var(--ease)}
.cookie-btn-primary:hover::before{transform:none}
.cookie-btn-primary span{position:relative;z-index:1}
@media(max-width:600px){#cookie-inner{padding:1.25rem 1.5rem}#cookie-actions{width:100%}.cookie-btn-primary,.cookie-btn-secondary{flex:1;text-align:center}}

/* ─── LEGAL MODAL ────────────────────────────────────────────────────────── */
#legal-modal{position:fixed;inset:0;z-index:9500;display:flex;align-items:center;justify-content:center;padding:1.5rem;pointer-events:none;visibility:hidden}
#legal-modal.open{pointer-events:all;visibility:visible}
#modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.82);opacity:0;transition:opacity .4s var(--ease)}
#legal-modal.open #modal-overlay{opacity:1}
#modal-panel{position:relative;z-index:1;background:var(--bg3);border:1px solid var(--border);width:100%;max-width:680px;max-height:85vh;display:flex;flex-direction:column;opacity:0;transform:translateY(28px);transition:opacity .45s var(--ease),transform .45s var(--ease)}
#legal-modal.open #modal-panel{opacity:1;transform:none}
#modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;padding:2.5rem 2.5rem 2rem;border-bottom:1px solid var(--border);flex-shrink:0}
#modal-header-inner{display:flex;flex-direction:column;gap:.75rem}
.modal-rule{width:2rem;height:1px;background:var(--gold)}
#modal-title{font-family:var(--fc);font-weight:300;font-size:clamp(1.5rem,3vw,2.25rem);color:var(--ink);line-height:1.1}
#modal-updated{font-family:var(--fi);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted)}
#modal-close{background:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;padding:.5rem;flex-shrink:0;display:flex;transition:color .3s,border-color .3s;margin-top:.2rem}
#modal-close:hover{color:var(--gold);border-color:var(--gold)}
#modal-body{overflow-y:auto;padding:2.5rem;scroll-behavior:smooth}
#modal-body::-webkit-scrollbar{width:3px}
#modal-body::-webkit-scrollbar-thumb{background:var(--border2)}
.modal-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.modal-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.modal-section-heading{font-family:var(--fc);font-size:1.125rem;color:var(--gold);margin-bottom:.75rem;font-weight:400}
.modal-section-body{font-family:var(--fi);font-size:.8125rem;color:var(--muted);line-height:1.85}
@media(max-width:600px){#modal-header,#modal-body{padding:1.75rem}}

/* ─── LIGHTBOX ───────────────────────────────────────────────────────────── */
#lb{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s}
#lb.open{opacity:1;pointer-events:all}
#lb-bg{position:absolute;inset:0;background:rgba(4,4,4,.93);cursor:zoom-out}
#lb-media{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}
#lb-media img{max-width:90vw;max-height:88vh;object-fit:contain;display:block;user-select:none;box-shadow:0 0 80px rgba(0,0,0,.7)}
#lb-media iframe{width:min(88vw,calc(82vh * 16/9));height:min(calc(88vw * 9/16),82vh);display:block;border:0}
#lb-close{position:fixed;top:1.5rem;right:1.5rem;z-index:2;background:rgba(8,8,8,.6);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);cursor:pointer;padding:.65rem;display:flex;transition:color .3s,border-color .3s}
#lb-close:hover{color:var(--gold);border-color:var(--gold)}
#lb-prev,#lb-next{position:fixed;top:50%;transform:translateY(-50%);z-index:2;background:rgba(8,8,8,.6);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.6);cursor:pointer;padding:.85rem;display:flex;transition:color .3s,border-color .3s,opacity .25s}
#lb-prev{left:1.5rem}
#lb-next{right:1.5rem}
#lb-prev:hover,#lb-next:hover{color:var(--gold);border-color:var(--gold)}
#lb-prev.lb-hidden,#lb-next.lb-hidden{opacity:0;pointer-events:none}
@media(max-width:600px){#lb-prev{left:.6rem}#lb-next{right:.6rem}#lb-close{top:.6rem;right:.6rem}}
