*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden;scroll-behavior:smooth;font-size:16px;background:#FDF6E3}
body{
  background-color:#FDF6E3;
  background-image:
    radial-gradient(circle,rgba(196,30,58,.055) 1px,transparent 1px),
    radial-gradient(circle,rgba(212,175,55,.04) 1px,transparent 1px);
  background-size:36px 36px,18px 18px;
  background-position:0 0,9px 9px;
  color:#1a0505;font-family:'Inter',sans-serif;font-weight:300;
  overflow-x:hidden;-webkit-font-smoothing:antialiased
}

/* ── PROGRESS ── */
#PB{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,#FF8C00,#C41E3A,#E91E8C,#D4AF37);transform-origin:left;transform:scaleX(0);z-index:1001}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:800;padding:22px 40px;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(24px) saturate(180%);background:rgba(253,246,227,.88);border-bottom:1px solid rgba(196,30,58,.12)}
.nlogo{font-family:'Instrument Serif',serif;font-style:italic;font-size:18px;color:#1a0505}
.nlinks{list-style:none;display:flex;gap:32px}
.nlinks a{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(26,5,5,.45);text-decoration:none;transition:color .3s}
.nlinks a:hover{color:#C41E3A}

/* ════════════════════════════════
   FIXED GLOBAL CANVAS BACKGROUND
════════════════════════════════ */
#fluid{position:fixed;inset:0;z-index:0;pointer-events:none}

/* grain texture */
#grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.6 0 0 0 0 0.2 0 0 0 0 0.1 0 0 0 0.7 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:200px 200px}

/* ════════════════════════════════
   HERO
════════════════════════════════ */
#hero{position:relative;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;z-index:2}

/* tiny label at top */
.h-tag{
  position:absolute;top:96px;left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.45em;text-transform:uppercase;
  color:rgba(26,5,5,.45);
  opacity:0;animation:fadeIn 1s ease forwards .6s;
  display:flex;align-items:center;gap:12px;
}
.h-tag::before,.h-tag::after{
  content:'';width:30px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(196,30,58,.4),transparent);
}

.hero-stage{text-align:center;padding:0 24px;position:relative;z-index:3}

/* MAIN NAMES */
.h-name-wrap{
  position:relative;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:0;
  perspective:1200px;
}

.h-name{
  font-family:'Instrument Serif',serif;
  font-size:clamp(72px,13vw,200px);
  font-weight:400;line-height:1.1;letter-spacing:-.04em;
  display:block;overflow:hidden;padding-bottom:0;
}

.h-name .ch{
  display:inline-block;
  opacity:0;
  transform:translateY(110%) rotateX(-50deg);
  transform-origin:bottom center;
  animation:charReveal 1.4s cubic-bezier(.16,1,.3,1) forwards;
  background:linear-gradient(180deg,#2D0000 0%,#6B0010 55%,rgba(139,0,30,.7) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

@keyframes charReveal{
  to{opacity:1;transform:translateY(0) rotateX(0)}
}

/* AMP — saffron → crimson → rani pink → gold */
.h-amp{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-size:clamp(36px,5vw,80px);
  line-height:1.1;display:block;margin:-.08em 0;
  background:linear-gradient(135deg,#FF8C00 0%,#C41E3A 35%,#E91E8C 70%,#D4AF37 100%);
  background-size:300% 300%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  opacity:0;
  animation:ampReveal 1.4s cubic-bezier(.16,1,.3,1) forwards .6s,gradShift 8s ease-in-out infinite 2s;
  filter:drop-shadow(0 0 40px rgba(196,30,58,.25));
  position:relative;
}
.h-amp::before{
  content:'';position:absolute;top:50%;left:50%;
  width:300px;height:300px;margin:-150px 0 0 -150px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,140,0,.12),transparent 70%);
  z-index:-1;animation:ampBreathe 4s ease-in-out infinite;
}
@keyframes ampBreathe{
  0%,100%{transform:scale(1);opacity:.4}
  50%{transform:scale(1.4);opacity:.9}
}
@keyframes ampReveal{
  from{opacity:0;transform:scale(.7) rotate(-8deg);filter:blur(20px) drop-shadow(0 0 40px rgba(196,30,58,.25))}
  to{opacity:1;transform:scale(1) rotate(0);filter:blur(0) drop-shadow(0 0 40px rgba(196,30,58,.25))}
}
@keyframes gradShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* date */
.h-date{
  margin-top:32px;
  font-size:13px;letter-spacing:.42em;text-transform:uppercase;
  color:rgba(26,5,5,.5);
  opacity:0;animation:fadeIn 1s ease forwards 2s;font-weight:300;
}
.h-date b{color:#C41E3A;font-weight:500}

/* CTA */
.h-cta-row{
  margin-top:36px;display:inline-flex;gap:12px;
  opacity:0;animation:fadeIn 1s ease forwards 2.3s;
}
.h-cta{
  font-size:13px;letter-spacing:.02em;
  padding:12px 26px;border-radius:100px;
  background:#1a0505;color:#FDF6E3;border:none;cursor:pointer;
  transition:transform .3s cubic-bezier(.19,1,.22,1),background .3s,box-shadow .3s;
  text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  font-weight:500;box-shadow:0 4px 20px rgba(26,5,5,.18);
}
.h-cta:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 8px 40px rgba(196,30,58,.3)}
.h-cta.ghost{background:transparent;color:#1a0505;border:1.5px solid rgba(26,5,5,.25);box-shadow:none}
.h-cta.ghost:hover{background:rgba(26,5,5,.05);border-color:rgba(26,5,5,.5)}
.h-cta.bless{
  background:linear-gradient(135deg,#FF8C00,#C41E3A,#E91E8C);
  background-size:200% 200%;
  animation:gradShift 6s ease-in-out infinite;
  color:#fff;font-weight:500;
  box-shadow:0 4px 30px rgba(196,30,58,.35);
}
.h-cta.bless:hover{box-shadow:0 8px 50px rgba(196,30,58,.5)}
.h-cta-arrow{display:inline-block;transition:transform .3s}
.h-cta:hover .h-cta-arrow{transform:translateX(4px)}

/* ════════════════════════════════
   BLESSING OVERLAY — deep crimson/maroon
════════════════════════════════ */
#bless-overlay{
  position:fixed;inset:0;z-index:9990;
  background:radial-gradient(ellipse at center,rgba(60,5,15,.92),rgba(15,0,5,.97));
  backdrop-filter:blur(40px) saturate(180%);
  display:none;align-items:center;justify-content:center;
  padding:24px;opacity:0;transition:opacity .6s ease;
}
#bless-overlay.open{display:flex;opacity:1}
#bless-overlay.fading{opacity:0}

.bless-stage{
  text-align:center;max-width:760px;position:relative;
  opacity:0;transform:translateY(40px) scale(.95);
  transition:opacity 1.2s cubic-bezier(.19,1,.22,1),transform 1.2s cubic-bezier(.19,1,.22,1);
}
#bless-overlay.open .bless-stage{opacity:1;transform:translateY(0) scale(1);transition-delay:.4s}

.bless-eyebrow{
  font-size:11px;letter-spacing:.45em;text-transform:uppercase;
  color:rgba(255,215,0,.7);
  margin-bottom:32px;display:flex;align-items:center;justify-content:center;gap:14px;
}
.bless-eyebrow::before,.bless-eyebrow::after{
  content:'';width:40px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.6),transparent);
}

.bless-title{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(52px,9vw,108px);font-weight:400;
  line-height:1;letter-spacing:-.02em;margin-bottom:32px;
  background:linear-gradient(135deg,#FFD700 0%,#FF8C00 35%,#FFD700 70%,#fff 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;animation:gradShift 6s ease-in-out infinite;
}

.bless-body{
  font-family:'Instrument Serif',serif;
  font-size:clamp(18px,2.5vw,24px);font-weight:400;
  line-height:1.6;color:rgba(255,255,255,.75);
  margin-bottom:40px;font-style:italic;
}
.bless-body em{color:#FFD700;font-style:normal}

.bless-signature{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(20px,3vw,30px);color:#fff;margin-bottom:48px;
}

.bless-close{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,215,0,.25);
  color:rgba(255,255,255,.7);
  font-size:11px;letter-spacing:.25em;text-transform:uppercase;
  padding:12px 28px;border-radius:100px;
  cursor:pointer;transition:all .3s;font-family:inherit;
  backdrop-filter:blur(20px);
}
.bless-close:hover{background:rgba(255,215,0,.08);border-color:rgba(255,215,0,.5);color:#FFD700}

.bless-flourish{
  font-family:'Instrument Serif',serif;font-size:48px;
  color:rgba(255,215,0,.5);
  margin:0 auto 24px;display:block;line-height:1;
}

/* floor labels */
.h-floor-l{position:absolute;bottom:48px;left:40px;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(26,5,5,.4);opacity:0;animation:fadeIn 1s ease forwards 2.5s;z-index:5}
.h-floor-r{position:absolute;bottom:48px;right:40px;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(26,5,5,.4);opacity:0;animation:fadeIn 1s ease forwards 2.5s;z-index:5}

.h-scroll{position:absolute;bottom:56px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;opacity:0;animation:fadeIn 1s ease forwards 2.7s;z-index:5}
.h-scroll-icon{width:24px;height:24px;border:1px solid rgba(196,30,58,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:rgba(26,5,5,.5);animation:bounce 2s ease-in-out infinite}
.h-scroll span{font-size:9px;letter-spacing:.35em;text-transform:uppercase;color:rgba(26,5,5,.35)}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ════════════════════════════════
   DECORATIVE DIVIDER
════════════════════════════════ */
.section-divider{
  display:flex;align-items:center;justify-content:center;gap:16px;
  padding:20px 0;opacity:.5;
}
.section-divider::before,.section-divider::after{
  content:'';flex:1;max-width:120px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.6),transparent);
}
.section-divider-gem{
  width:8px;height:8px;
  background:linear-gradient(135deg,#FF8C00,#C41E3A);
  transform:rotate(45deg);
  flex-shrink:0;
}

/* ════════════════════════════════
   STICKY SCROLL STORY
════════════════════════════════ */
#story{position:relative;z-index:2}

.story-section{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  position:relative;padding:120px 40px;
}

/* subtle golden border between story sections */
.story-section + .story-section::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:80px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.5),transparent);
}

.story-content{max-width:900px;margin:0 auto;text-align:center;}

.story-eyebrow{
  font-size:11px;letter-spacing:.45em;text-transform:uppercase;
  color:rgba(26,5,5,.4);margin-bottom:24px;
}
.story-eyebrow .day{
  background:linear-gradient(135deg,#FF8C00,#C41E3A,#E91E8C);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;animation:gradShift 5s ease-in-out infinite;font-weight:500;
}

.story-bignum{
  font-family:'Instrument Serif',serif;
  font-size:clamp(140px,22vw,300px);font-weight:400;line-height:.8;letter-spacing:-.04em;
  background:linear-gradient(180deg,rgba(26,5,5,.1) 0%,rgba(196,30,58,.05) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;margin-bottom:24px;
}

.story-name{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(56px,8vw,108px);font-weight:400;line-height:1;
  letter-spacing:-.02em;margin-bottom:24px;padding-bottom:.15em;
  background:linear-gradient(135deg,#2D0000 0%,#C41E3A 50%,#2D0000 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  animation:gradShift 8s ease-in-out infinite;
}

.story-meta{
  font-size:14px;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(26,5,5,.5);
  display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
}
.story-meta-dot{
  width:4px;height:4px;border-radius:50%;
  background:linear-gradient(135deg,#FF8C00,#C41E3A);
}

.story-desc{
  margin-top:32px;font-size:15px;line-height:1.7;
  color:rgba(26,5,5,.55);max-width:560px;margin-left:auto;margin-right:auto;font-weight:300;
}

/* ════════════════════════════════
   VENUE
════════════════════════════════ */
#venue{position:relative;z-index:2;padding:160px 40px;display:flex;align-items:center;justify-content:center}

.venue-card{
  max-width:900px;width:100%;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(40px) saturate(180%);
  border:1px solid rgba(212,175,55,.35);
  border-radius:32px;padding:80px 60px;
  text-align:center;position:relative;overflow:hidden;
  box-shadow:0 8px 60px rgba(196,30,58,.08),0 2px 0 rgba(212,175,55,.3) inset;
}

/* top golden shimmer line */
.venue-card::before{
  content:'';position:absolute;top:-1px;left:-1px;right:-1px;height:2px;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.8),rgba(255,140,0,.6),rgba(212,175,55,.8),transparent);
}
/* light sweep on scroll */
.venue-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 30%,rgba(255,215,0,.07) 50%,transparent 70%);
  transform:translateX(-100%);
  transition:transform 1.4s cubic-bezier(.23,1,.32,1);
  border-radius:32px;
}
.venue-card.on::after{transform:translateX(100%)}

/* bottom ornamental border inside card */
.venue-card-inner-border{
  position:absolute;inset:12px;border-radius:24px;pointer-events:none;
  border:1px solid rgba(212,175,55,.15);
}

.venue-eyebrow{font-size:11px;letter-spacing:.45em;text-transform:uppercase;color:rgba(26,5,5,.4);margin-bottom:24px}
.venue-name{font-family:'Instrument Serif',serif;font-style:italic;font-size:clamp(56px,9vw,120px);line-height:.95;letter-spacing:-.02em;font-weight:400;margin-bottom:20px;color:#1a0505}
.venue-name em{
  font-style:italic;
  background:linear-gradient(135deg,#FF8C00,#C41E3A,#E91E8C);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;animation:gradShift 6s ease-in-out infinite;
}
.venue-loc{font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:rgba(26,5,5,.5);margin-bottom:48px}

.venue-divider{
  width:64px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.7),transparent);
  margin:0 auto 40px;position:relative;
}
.venue-divider::before{
  content:'◆';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:8px;color:rgba(212,175,55,.8);line-height:1;
  background:#fff;padding:0 4px;
}

.venue-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;text-align:center;margin-top:24px}
.vm-label{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(26,5,5,.35);margin-bottom:8px}
.vm-val{font-family:'Instrument Serif',serif;font-style:italic;font-size:clamp(20px,2.5vw,28px);font-weight:400;color:#1a0505}

/* ════════════════════════════════
   GALLERY
════════════════════════════════ */
#gallery{position:relative;z-index:2;padding:160px 40px}

.g-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:16px;max-width:1300px;margin-left:auto;margin-right:auto}
.g-title{font-family:'Instrument Serif',serif;font-style:italic;font-size:clamp(48px,7vw,84px);font-weight:400;line-height:.95;letter-spacing:-.02em;color:#1a0505}
.g-title em{
  font-style:normal;
  background:linear-gradient(135deg,#FF8C00,#C41E3A,#E91E8C);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradShift 5s ease-in-out infinite;
}
.g-meta{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(26,5,5,.35)}

/* CINEMATIC GALLERY */
.gg{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px;
  max-width:1400px;margin:0 auto;perspective:1500px;
}

.gi{
  overflow:hidden;position:relative;
  background:rgba(255,240,215,.55);
  cursor:pointer;border-radius:20px;
  transition:transform .8s cubic-bezier(.19,1,.22,1),box-shadow .6s;
  border:1px solid rgba(212,175,55,.25);
  transform-style:preserve-3d;
  box-shadow:0 8px 40px rgba(139,0,0,.1);
}

.gi:nth-child(1){grid-column:1/8;aspect-ratio:16/10}
.gi:nth-child(2){grid-column:8/13;aspect-ratio:4/5}
.gi:nth-child(3){grid-column:1/5;aspect-ratio:4/5}
.gi:nth-child(4){grid-column:5/9;aspect-ratio:1/1}
.gi:nth-child(5){grid-column:9/13;aspect-ratio:4/5}
.gi:nth-child(6){grid-column:1/13;aspect-ratio:21/7}

.gi:hover{
  z-index:5;
  box-shadow:0 20px 60px rgba(196,30,58,.2),0 0 0 2px rgba(212,175,55,.5);
}

/* number badge */
.gi-badge{
  position:absolute;top:20px;left:24px;z-index:4;
  font-family:'Instrument Serif',serif;font-style:italic;font-size:14px;
  color:rgba(26,5,5,.45);letter-spacing:.05em;
  opacity:0;transform:translateX(-10px);
  transition:opacity .5s .1s,transform .5s .1s cubic-bezier(.19,1,.22,1);
  pointer-events:none;text-shadow:0 1px 4px rgba(255,255,255,.6);
}
.gi:hover .gi-badge{opacity:1;transform:translateX(0)}

/* caption */
.gi-caption{
  position:absolute;bottom:0;left:0;right:0;padding:32px 28px;z-index:3;
  transform:translateY(20px);opacity:0;
  transition:opacity .5s .15s,transform .6s .15s cubic-bezier(.19,1,.22,1);
  pointer-events:none;
}
.gi:hover .gi-caption{opacity:1;transform:translateY(0)}

.gi-caption-title{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(20px,2.5vw,32px);font-weight:400;line-height:1.1;
  color:#fff;margin-bottom:6px;text-shadow:0 4px 20px rgba(0,0,0,.5);
}
.gi-caption-meta{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,215,0,.9);text-shadow:0 2px 10px rgba(0,0,0,.5);
}

/* gradient overlay (dark at bottom for caption readability) */
.gi-grad{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(26,5,5,.8) 0%,rgba(26,5,5,.25) 35%,transparent 60%,rgba(26,5,5,.1) 100%);
  opacity:.35;transition:opacity .5s;z-index:2;pointer-events:none;
}
.gi:hover .gi-grad{opacity:1}

/* warm tint on hover */
.gi-tint{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,140,0,.15),transparent 50%,rgba(196,30,58,.12));
  opacity:0;transition:opacity .6s;z-index:2;pointer-events:none;mix-blend-mode:multiply;
}
.gi:hover .gi-tint{opacity:1}

/* placeholder */
.gph{
  width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;position:relative;overflow:hidden;min-height:200px;
}
.gph::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 30% 20%,rgba(255,140,0,.1),transparent 50%),
    radial-gradient(ellipse at 70% 80%,rgba(196,30,58,.08),transparent 50%),
    linear-gradient(135deg,rgba(212,175,55,.05),transparent);
  animation:phShift 8s ease-in-out infinite;
}
@keyframes phShift{
  0%,100%{transform:scale(1) rotate(0deg)}
  50%{transform:scale(1.05) rotate(1deg)}
}
.gph::after{
  content:'';position:absolute;inset:24px;
  border:1px solid rgba(212,175,55,.2);border-radius:8px;pointer-events:none;
}

.gph-n{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(56px,6vw,96px);font-weight:400;
  color:rgba(139,0,0,.18);position:relative;z-index:1;
  transition:all .8s cubic-bezier(.19,1,.22,1);letter-spacing:-.02em;
}
.gi:hover .gph-n{
  background:linear-gradient(135deg,#FF8C00,#C41E3A,#E91E8C);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;transform:scale(1.1);animation:gradShift 4s ease-in-out infinite;
}

.gph-l{
  font-size:9px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(26,5,5,.3);position:relative;z-index:1;transition:color .5s;
}
.gi:hover .gph-l{color:rgba(255,140,0,.8)}

.gi img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s cubic-bezier(.19,1,.22,1),filter .8s;
  filter:saturate(.85) brightness(.9) contrast(1.05);
}
.gi:hover img{transform:scale(1.1);filter:saturate(1.15) brightness(.95) contrast(1.1);}

/* gold corner accents */
.gi-corner{position:absolute;width:24px;height:24px;z-index:4;pointer-events:none;opacity:0;transition:opacity .5s .2s}
.gi:hover .gi-corner{opacity:1}
.gi-corner.tl{top:14px;left:14px;border-top:1.5px solid rgba(212,175,55,.7);border-left:1.5px solid rgba(212,175,55,.7)}
.gi-corner.tr{top:14px;right:14px;border-top:1.5px solid rgba(212,175,55,.7);border-right:1.5px solid rgba(212,175,55,.7)}
.gi-corner.bl{bottom:14px;left:14px;border-bottom:1.5px solid rgba(212,175,55,.7);border-left:1.5px solid rgba(212,175,55,.7)}
.gi-corner.br{bottom:14px;right:14px;border-bottom:1.5px solid rgba(212,175,55,.7);border-right:1.5px solid rgba(212,175,55,.7)}

.gi-expand{
  position:absolute;top:20px;right:24px;z-index:4;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.65);backdrop-filter:blur(20px);
  border:1px solid rgba(212,175,55,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:#1a0505;
  opacity:0;transform:scale(.8);
  transition:opacity .4s .1s,transform .4s .1s cubic-bezier(.19,1,.22,1);
  pointer-events:none;
}
.gi:hover .gi-expand{opacity:1;transform:scale(1)}

.gi-ov{display:none}

/* ── LIGHTBOX ── */
#LB{display:none;position:fixed;inset:0;background:rgba(15,0,5,.97);z-index:9997;align-items:center;justify-content:center;padding:60px 20px 120px;backdrop-filter:blur(30px) saturate(180%)}
#LB.open{display:flex;flex-direction:column}
#LB::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(196,30,58,.08),transparent 70%);
  pointer-events:none;
}
#LBi{max-width:88vw;max-height:75vh;object-fit:contain;animation:lbIn .5s cubic-bezier(.19,1,.22,1);border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 0 1px rgba(212,175,55,.15)}
@keyframes lbIn{from{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}

#LB-info{
  position:absolute;bottom:60px;left:50%;transform:translateX(-50%);
  text-align:center;color:#fff;
  opacity:0;animation:lbIn .5s ease forwards .3s;max-width:80vw;
}
#LB-info-title{font-family:'Instrument Serif',serif;font-style:italic;font-size:clamp(20px,2.5vw,28px);margin-bottom:6px}
#LB-info-meta{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,215,0,.7)}
.lbb{position:absolute;background:rgba(255,255,255,.07);border:none;color:rgba(255,255,255,.8);cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .25s;backdrop-filter:blur(20px)}
.lbb:hover{background:rgba(255,215,0,.15);color:#FFD700}
#LBx{top:24px;right:28px;width:44px;height:44px;font-size:16px}
#LBp{left:28px;top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:18px}
#LBn{right:28px;top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:18px}
#LBc{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);font-size:11px;letter-spacing:.3em;color:rgba(255,255,255,.4)}

/* ── FOOTER ── */
footer{
  position:relative;z-index:2;
  background:linear-gradient(to bottom,transparent,rgba(212,175,55,.06));
  border-top:1px solid rgba(212,175,55,.25);
  padding:60px 40px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;
  backdrop-filter:blur(20px);
}
.fb{font-family:'Instrument Serif',serif;font-style:italic;font-size:24px;color:#1a0505}
.fb em{
  background:linear-gradient(135deg,#FF8C00,#C41E3A,#E91E8C);
  background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;font-style:normal;animation:gradShift 5s ease-in-out infinite
}
.fm{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(26,5,5,.35);text-align:right;line-height:2.2}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(60px);transition:opacity 1.2s cubic-bezier(.19,1,.22,1),transform 1.2s cubic-bezier(.19,1,.22,1)}
.rv.on{opacity:1;transform:translateY(0)}
.rv.d1{transition-delay:.15s}.rv.d2{transition-delay:.3s}.rv.d3{transition-delay:.45s}.rv.d4{transition-delay:.6s}

@media(max-width:768px){
  nav{padding:14px 20px}.nlinks{display:none}
  .h-tag{top:60px;font-size:9px;letter-spacing:.32em}
  .h-tag::before,.h-tag::after{width:16px}
  .h-name{font-size:clamp(64px,14vw,140px)}
  .h-amp{font-size:clamp(28px,6vw,56px);margin:-.06em 0}
  .h-cta-row{flex-direction:column;align-items:stretch;width:100%;max-width:300px;margin-left:auto;margin-right:auto;gap:10px}
  .h-cta{justify-content:center;text-align:center}
  .hero-stage{padding:0 24px}
  .h-floor-l,.h-floor-r{font-size:9px;bottom:20px}
  .h-floor-l{left:20px}.h-floor-r{right:20px}
  .h-scroll{bottom:32px}
  .story-section{min-height:auto;padding:80px 20px}
  #venue{padding:80px 20px}
  .venue-card{padding:48px 28px;border-radius:24px}
  .venue-meta{grid-template-columns:1fr;gap:20px}
  #gallery{padding:80px 20px}
  .gg{grid-template-columns:1fr 1fr;gap:5px}
  .gi:nth-child(n){grid-column:auto;aspect-ratio:1/1}
  footer{padding:36px 20px;flex-direction:column;text-align:center}.fm{text-align:center}
  #LBp{left:8px}#LBn{right:8px}
}

@media(max-width:480px){
  .h-name{font-size:clamp(48px,12vw,96px)}
  .h-amp{font-size:clamp(48px,12vw,96px);margin:-.04em 0}
  .hero-stage{padding:0 16px}
  .h-floor-l,.h-floor-r{display:none}
  .h-scroll{bottom:28px;left:50%;transform:translateX(-50%)}
}
