/* CRISTIAN & JORDAN — VELVET GANACHE THEME */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ganache:#2e1419;--ganache2:#3d1a1e;
  --mulberry:#7a2a35;--mulberry-lt:#a84455;
  --taupe:#9e7b6e;--taupe-lt:#c4a090;
  --champagne:#e8d5b0;--champ-lt:#f5ead0;
  --alabaster:#f8f3ec;--cream:#fdf8f4;
  --serif:'Libre Baskerville',Georgia,serif;
  --script:'Great Vibes',cursive;
  --sans:'Tenor Sans',sans-serif;
  --body:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--cream);color:var(--ganache);font-family:var(--body);font-size:16px;line-height:1.8;overflow-x:hidden;cursor:none}
a{color:var(--mulberry);text-decoration:none;transition:color .3s}
a:hover{color:var(--mulberry-lt)}

#cursor{width:10px;height:10px;background:var(--mulberry);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:transform .15s ease,opacity .3s;mix-blend-mode:multiply}
#cursor-ring{width:32px;height:32px;border:1px solid rgba(122,42,53,.5);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);opacity:.5}
#petal-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}

nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 44px}
.nav-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:78px;transition:background .5s,border-color .5s;border-bottom:1px solid transparent}
nav.solid .nav-inner{background:rgba(253,248,244,.97);border-color:rgba(122,42,53,.12);backdrop-filter:blur(12px)}
.nav-logo{font-family:var(--script);font-size:1.9rem;color:rgba(255,255,255,.92);letter-spacing:.04em;transition:color .4s}
nav.solid .nav-logo{color:var(--ganache)}
.nav-links{list-style:none;display:flex;gap:26px;align-items:center}
.nav-links a{font-family:var(--sans);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.72);transition:color .3s;position:relative}
nav.solid .nav-links a{color:var(--ganache2)}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--champagne);transition:right .3s ease}
.nav-links a:hover::after{right:0}
.nav-links a:hover{color:var(--champagne)!important}
.nav-rsvp{color:var(--champagne)!important;border:1px solid rgba(232,213,176,.35);padding:7px 18px!important;transition:background .3s,color .3s!important}
nav.solid .nav-rsvp{color:var(--mulberry)!important;border-color:var(--mulberry)}
.nav-rsvp:hover{background:var(--mulberry);color:white!important;border-color:var(--mulberry)!important}
.nav-rsvp::after{display:none!important}
.nav-right{display:flex;align-items:center;gap:14px}
.lang-btn{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.82);font-family:var(--sans);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;padding:7px 14px;cursor:none;transition:background .3s,border-color .3s,color .3s}
nav.solid .lang-btn{background:rgba(122,42,53,.07);border-color:rgba(122,42,53,.22);color:var(--ganache2)}
.lang-btn:hover{background:var(--mulberry);border-color:var(--mulberry);color:white}
.lang-flag{font-size:.9rem}
.hamburger{display:none;background:none;border:none;cursor:none;flex-direction:column;gap:5px;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:white;transition:background .4s}
nav.solid .hamburger span{background:var(--ganache)}
.mobile-menu{display:none;flex-direction:column;background:var(--cream);padding:20px 44px 28px;border-bottom:1px solid var(--champ-lt)}
.mobile-menu a{font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ganache2);padding:13px 0;border-bottom:1px solid var(--champ-lt)}
.mobile-menu.open{display:flex}

.hero{height:100vh;min-height:700px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-bg{position:absolute;inset:0;background:url('images/hero.jpg') center/cover no-repeat;}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:rgba(20,8,10,.55);
}
.hero-botanical{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='900' height='900' viewBox='0 0 900 900'%3E%3Cg fill='none' stroke='%23e8d5b0' stroke-opacity='0.055' stroke-width='1'%3E%3Cellipse cx='800' cy='80' rx='200' ry='320' transform='rotate(-20 800 80)'/%3E%3Cellipse cx='820' cy='100' rx='130' ry='220' transform='rotate(-38 820 100)'/%3E%3Cellipse cx='100' cy='800' rx='180' ry='300' transform='rotate(22 100 800)'/%3E%3Cellipse cx='75' cy='820' rx='110' ry='200' transform='rotate(38 75 820)'/%3E%3C/g%3E%3C/svg%3E");background-size:cover;opacity:.8}
.hero-grain{position:absolute;inset:0;z-index:2;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.04;mix-blend-mode:overlay;animation:grain 2.5s steps(1) infinite}
@keyframes grain{0%{transform:translate(0,0)}25%{transform:translate(-2px,3px)}50%{transform:translate(2px,-2px)}75%{transform:translate(-1px,2px)}100%{transform:translate(0,0)}}
.hero-content{position:relative;z-index:5;text-align:center;padding:0 24px}
.hero-pre{font-family:var(--sans);font-size:.62rem;letter-spacing:.45em;text-transform:uppercase;color:rgba(232,213,176,.52);display:block;margin-bottom:20px;animation:fadeUp 1.2s ease both}
.hero-script{font-family:var(--script);font-size:clamp(5rem,13vw,10rem);color:var(--alabaster);line-height:.88;display:block;letter-spacing:.02em;animation:fadeUp 1.2s .2s ease both;text-shadow:0 0 100px rgba(232,213,176,.18)}
.hero-amp{display:inline-block;font-family:var(--script);font-size:clamp(2.5rem,6vw,4.5rem);color:var(--champagne);vertical-align:middle;margin:.1em .25em;animation:fadeUp 1.2s .3s ease both}
.hero-rule{display:flex;align-items:center;justify-content:center;gap:14px;margin:28px auto;max-width:360px;animation:fadeUp 1.2s .4s ease both}
.hero-rule-line{flex:1;height:1px;background:linear-gradient(to right,transparent,rgba(232,213,176,.38),transparent)}
.hero-rule-diamond{width:6px;height:6px;background:var(--champagne);transform:rotate(45deg);flex-shrink:0}
.hero-date-block{animation:fadeUp 1.2s .5s ease both}
.hero-date-top{font-family:var(--serif);font-style:italic;font-size:clamp(.92rem,2.4vw,1.2rem);color:rgba(248,243,236,.7);display:block;margin-bottom:6px;letter-spacing:.04em}
.hero-date-num{font-family:var(--sans);font-size:.66rem;letter-spacing:.45em;text-transform:uppercase;color:var(--champagne)}
.hero-location{font-family:var(--sans);font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.28);display:block;margin-top:8px}
.hero-cta{display:inline-block;margin-top:48px;font-family:var(--sans);font-size:.64rem;letter-spacing:.35em;text-transform:uppercase;color:var(--alabaster);border:1px solid rgba(232,213,176,.32);padding:16px 48px;position:relative;overflow:hidden;animation:fadeUp 1.2s .65s ease both;transition:color .4s}
.hero-cta::before{content:'';position:absolute;inset:0;background:var(--mulberry);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.hero-cta span{position:relative;z-index:1}
.hero-cta:hover::before{transform:scaleX(1)}
.hero-cta:hover{color:white}
.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:12px}
.scroll-text{font-family:var(--sans);font-size:.52rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.18);writing-mode:vertical-rl}
.scroll-line{width:1px;height:64px;background:linear-gradient(to bottom,rgba(232,213,176,.45),transparent);animation:scrollDrop 2.2s ease-in-out infinite}
@keyframes scrollDrop{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom;opacity:0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

.countdown-strip{background:var(--ganache);padding:0;position:relative;overflow:hidden}
.countdown-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(122,42,53,.14) 0%,transparent 60%),radial-gradient(ellipse at 80% 50%,rgba(232,213,176,.05) 0%,transparent 60%)}
.countdown-inner{position:relative;max-width:1000px;margin:0 auto;padding:64px 40px;display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center}
.count-block{text-align:center;padding:0 20px}
.count-num{font-family:var(--script);font-size:clamp(3.5rem,8vw,5.5rem);color:var(--champagne);line-height:1;display:block}
.count-lbl{font-family:var(--sans);font-size:.55rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(232,213,176,.28);display:block;margin-top:10px}
.count-divider{font-size:2rem;color:rgba(232,213,176,.1);text-align:center}

.s-label{font-family:var(--sans);font-size:.58rem;letter-spacing:.38em;text-transform:uppercase;color:var(--mulberry);display:block;margin-bottom:14px}
.s-title{font-family:var(--script);font-size:clamp(3rem,7vw,5.5rem);color:var(--ganache);line-height:1;margin-bottom:48px}
.s-title.light{color:var(--alabaster)}
.ornament{color:var(--mulberry);opacity:.4;font-size:1.6rem;display:block;margin-bottom:40px;letter-spacing:.3em}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}

/* STORY */
.story{padding:140px 40px;background:var(--cream);position:relative;overflow:hidden;text-align:center}
.story::before{content:'';position:absolute;right:-80px;top:-80px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(122,42,53,.04) 0%,transparent 70%)}
.story-wrap{max-width:960px;margin:0 auto}
/* Timeline: single column with center line, items alternate via nth-child */
.story-grid{
  display:flex;flex-direction:column;
  margin-top:60px;text-align:left;position:relative;
  padding:0 0 20px;
}
.story-grid::before{
  content:'';position:absolute;
  left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom,transparent,rgba(122,42,53,.2) 8%,rgba(122,42,53,.2) 92%,transparent);
  transform:translateX(-50%);
}
.story-spacer{display:none}/* no longer needed */
.story-item{
  width:calc(50% - 32px);
  padding:0 0 56px;
  position:relative;
}
/* Left side items */
.story-item.left{
  align-self:flex-start;
  margin-right:auto;
  text-align:right;
  padding-right:40px;
}
/* Right side items */
.story-item.right{
  align-self:flex-end;
  margin-left:auto;
  text-align:left;
  padding-left:40px;
}
.story-dot{
  width:12px;height:12px;background:var(--mulberry);border-radius:50%;
  position:absolute;top:4px;
  border:2px solid var(--cream);
  box-shadow:0 0 0 4px rgba(122,42,53,.15);
}
.story-item.left .story-dot{right:-7px;transform:translateX(50%)}
.story-item.right .story-dot{left:-7px;transform:translateX(-50%)}
.story-yr{font-family:var(--sans);font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--mulberry);margin-bottom:10px;display:block}
.story-h{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ganache);margin-bottom:12px;line-height:1.35}
.story-p{font-size:.93rem;color:var(--ganache2);line-height:1.9}

/* THEME SECTION */
.theme-section{padding:140px 40px;position:relative;overflow:hidden;text-align:center}
.theme-bg{position:absolute;inset:0;background:var(--ganache2)}
.theme-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 0% 100%,rgba(122,42,53,.22) 0%,transparent 50%),radial-gradient(ellipse at 100% 0%,rgba(232,213,176,.05) 0%,transparent 45%)}
.theme-bg::after{content:'';position:absolute;top:20px;left:20px;right:20px;bottom:20px;border:1px solid rgba(232,213,176,.06);pointer-events:none}
.theme-wrap{position:relative;z-index:1;max-width:1100px;margin:0 auto}
.theme-section .s-label{color:rgba(232,213,176,.7)}
.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(232,213,176,.07);margin-top:64px}
.theme-card{background:rgba(20,8,10,.5);padding:52px 36px;text-align:center;transition:background .4s}
.theme-card:hover{background:rgba(122,42,53,.12)}
.theme-icon{font-size:2.2rem;display:block;margin-bottom:20px}
.theme-card h3{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--champagne);margin-bottom:16px}
.theme-card p{font-size:.88rem;color:rgba(232,213,176,.5);line-height:1.95}
.palette-row{display:flex;gap:0;margin-top:60px;overflow:hidden;border:1px solid rgba(232,213,176,.08)}
.swatch{flex:1;height:72px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:10px;transition:flex .4s ease}
.swatch:hover{flex:2}
.swatch span{font-family:var(--sans);font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* DETAILS */
.details{padding:140px 40px;background:var(--ganache);position:relative;overflow:hidden;text-align:center}
.details::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 0% 0%,rgba(122,42,53,.15) 0%,transparent 50%),radial-gradient(ellipse at 100% 100%,rgba(232,213,176,.04) 0%,transparent 50%)}
.details::after{content:'';position:absolute;top:0;right:0;width:280px;height:280px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 280 280'%3E%3Cg stroke='%23e8d5b0' stroke-opacity='0.06' fill='none'%3E%3Cellipse cx='260' cy='20' rx='90' ry='180' transform='rotate(-30 260 20)'/%3E%3C/g%3E%3C/svg%3E")}
.details-wrap{position:relative;z-index:1;max-width:1100px;margin:0 auto}
.details .s-label{color:var(--champ-lt)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(232,213,176,.1);border:1px solid rgba(232,213,176,.1);margin-top:64px}.card{background:rgba(20,8,10,.82);padding:56px 36px;text-align:center;position:relative;transition:background .4s}
.card:hover{background:rgba(122,42,53,.1)}
.card-icon{width:44px;height:1px;background:rgba(232,213,176,.4);margin:0 auto 32px;position:relative}
.card-icon::before,.card-icon::after{content:'';position:absolute;top:50%;transform:translateY(-50%);width:5px;height:5px;background:var(--champagne);border-radius:50%}
.card-icon::before{left:-2px}.card-icon::after{right:-2px}
.card-h{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--alabaster);margin-bottom:18px}
.card-meta{font-family:var(--sans);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--champagne);line-height:2.5}
.card-body{font-size:.93rem;color:rgba(248,243,236,.38);line-height:1.85;margin-top:14px}
.card-note{font-style:italic;font-size:.82rem;color:rgba(232,213,176,.32);margin-top:16px}
.dresscode{margin-top:60px;border:1px solid rgba(232,213,176,.14);padding:52px 56px;position:relative}
.dresscode::before{content:'';position:absolute;top:-1px;left:-1px;width:20px;height:20px;border-top:1px solid var(--champagne);border-left:1px solid var(--champagne)}
.dresscode::after{content:'';position:absolute;top:-1px;right:-1px;width:20px;height:20px;border-top:1px solid var(--champagne);border-right:1px solid var(--champagne)}
.corner-bl{position:absolute;bottom:-1px;left:-1px;width:20px;height:20px;border-bottom:1px solid var(--champagne);border-left:1px solid var(--champagne)}
.corner-br{position:absolute;bottom:-1px;right:-1px;width:20px;height:20px;border-bottom:1px solid var(--champagne);border-right:1px solid var(--champagne)}
.dresscode h3{font-family:var(--script);font-size:2.8rem;color:var(--champagne);margin-bottom:14px}
.dresscode p{color:rgba(248,243,236,.38);font-size:.95rem}

/* PARTY */
.party{padding:140px 40px;background:var(--alabaster);text-align:center}
.party-wrap{max-width:1400px;margin:0 auto}
.party-row{display:flex;gap:0;margin-top:48px;border:1px solid rgba(122,42,53,.1)}
.party-card{flex:1;padding:48px 20px;border-right:1px solid rgba(122,42,53,.07);transition:background .3s;cursor:none}
.party-card:last-child{border-right:none}
.party-card:hover{background:rgba(122,42,53,.04)}
.party-img{width:110px;height:138px;margin:0 auto 22px;background:var(--champ-lt);clip-path:polygon(50% 0%,100% 15%,100% 85%,50% 100%,0% 85%,0% 15%);display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:.52rem;color:rgba(122,42,53,.28);letter-spacing:.1em}
.party-name{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--ganache);margin-bottom:5px}
.party-role{font-family:var(--sans);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mulberry)}
.party-sub{font-family:var(--sans);font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(46,20,25,.28);margin:60px 0 0;display:block}

/* PARTY GRID - 9 per row */
.party-grid-9{display:grid;grid-template-columns:repeat(9,1fr);gap:0;margin-top:48px;border:1px solid rgba(122,42,53,.1)}
.party-grid-9 .party-card{padding:32px 10px;border-right:1px solid rgba(122,42,53,.07)}
.party-grid-9 .party-card:last-child{border-right:none}
.party-grid-9 .party-img{width:80px;height:100px}
.party-grid-9 .party-name{font-size:.85rem}
.party-grid-9 .party-role{font-size:.48rem}

@media(max-width:1200px){
  .party-grid-9{grid-template-columns:repeat(5,1fr)}
}
@media(max-width:960px){
  .party-grid-9{grid-template-columns:repeat(3,1fr)}
  .party-row{flex-wrap:wrap}
  .party-card{flex:1 1 45%}
}
@media(max-width:600px){
  .party-grid-9{grid-template-columns:repeat(2,1fr)}
  .party-row{flex-direction:column}
  .party-card{border-right:none;border-bottom:1px solid rgba(122,42,53,.07)}
}
/* VENUE */
.venue{display:grid;grid-template-columns:55% 45%;min-height:640px}
.venue-img{position:relative;overflow:hidden;background:url('images/curtissmansion.jpg') center/cover no-repeat;}
.venue-img-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}
.big-text{font-family:var(--script);font-size:6rem;color:rgba(255,255,255,.06)}
.small-text{font-family:var(--sans);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.18)}
.venue-img::after{content:'';position:absolute;top:0;right:-1px;width:80px;height:100%;background:var(--alabaster);clip-path:polygon(100% 0,100% 100%,0 100%)}
.venue-text{background:var(--alabaster);padding:100px 80px;display:flex;flex-direction:column;justify-content:center}
.venue-text p{font-size:.95rem;color:var(--ganache2);line-height:1.92;margin-bottom:18px}
.btn-lined{display:inline-block;font-family:var(--sans);font-size:.63rem;letter-spacing:.28em;text-transform:uppercase;color:var(--mulberry);border-bottom:1px solid var(--mulberry);padding-bottom:3px;margin-top:24px;transition:color .3s,border-color .3s}
.btn-lined:hover{color:var(--ganache);border-color:var(--ganache)}

.church{direction:ltr}
.church .venue-text{background:var(--ganache);order:-1}
.church .venue-text .s-label{color:var(--champ-lt)}
.church .venue-text .s-title{color:var(--alabaster)}
.church .venue-text .ornament{color:var(--champagne)}
.church .venue-text p{color:rgba(248,243,236,.6)}
.church .venue-text .btn-lined{color:var(--champagne);border-color:var(--champagne)}
.church-img{background:linear-gradient(135deg,var(--ganache) 0%,var(--ganache2) 50%,var(--mulberry) 100%)}

/* GALLERY */
.gallery{padding:140px 40px;background:var(--ganache);text-align:center}
.gallery .s-title{color:var(--alabaster)}.gallery .s-label{color:var(--champ-lt)}
.gallery-masonry{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:180px 180px 180px;gap:5px;margin:60px auto 0;max-width:1200px}
.gitem{overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;cursor:none}
.gitem::after{content:'';position:absolute;inset:0;background:rgba(122,42,53,0);transition:background .4s}
.gitem:hover::after{background:rgba(122,42,53,.22)}
.gitem span{font-family:var(--sans);font-size:.52rem;letter-spacing:.15em;color:rgba(232,213,176,.22);position:absolute;z-index:1;text-transform:uppercase}
.g1{grid-column:1/5;grid-row:1/3;background:#3d1a1e}.g2{grid-column:5/8;grid-row:1/2;background:#5c2228}
.g3{grid-column:8/13;grid-row:1/2;background:#4a1c22}.g4{grid-column:5/9;grid-row:2/4;background:#521e24}
.g5{grid-column:9/13;grid-row:2/3;background:#3a1618}.g6{grid-column:1/5;grid-row:3/4;background:#481c20}
.g7{grid-column:9/13;grid-row:3/4;background:#5e2430}
.gallery-note{font-family:var(--sans);font-size:.6rem;letter-spacing:.15em;color:rgba(232,213,176,.18);margin-top:28px}

/* MUSIC */
.music-section{padding:140px 40px;background:var(--ganache2);text-align:center;position:relative;overflow:hidden}
.music-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(122,42,53,.28) 0%,transparent 55%)}
.music-wrap{position:relative;z-index:1;max-width:1200px;margin:0 auto}
.music-section .s-label{color:rgba(232,213,176,.65)}
.music-intro{font-size:.97rem;color:rgba(232,213,176,.45);max-width:680px;margin:0 auto 72px;line-height:1.95}
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.video-card{text-align:left;background:rgba(10,4,6,.45);border:1px solid rgba(232,213,176,.07);transition:border-color .3s}
.video-card:hover{border-color:rgba(232,213,176,.18)}
.video-frame{position:relative;width:100%;padding-top:56.25%;background:var(--ganache);overflow:hidden}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%}
.video-info{padding:28px 28px 32px}
.video-info h3{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--champagne);margin-bottom:10px}
.video-info p{font-size:.85rem;color:rgba(232,213,176,.42);line-height:1.85}
.video-note{font-family:var(--sans);font-size:.6rem;color:rgba(232,213,176,.18);letter-spacing:.12em;margin-top:40px;font-style:italic}

/* TRAVEL */
.travel{padding:140px 40px;background:var(--cream)}
.travel-wrap{max-width:1100px;margin:0 auto}
.travel-header{text-align:center;margin-bottom:80px}
.travel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(122,42,53,.1)}
.tcard{background:var(--cream);padding:52px 48px;position:relative}
.tcard::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--mulberry);transition:height .8s ease}
.tcard.in::before{height:100%}
.tcard-num{font-family:var(--script);font-size:4.5rem;color:rgba(122,42,53,.07);position:absolute;top:28px;right:36px;line-height:1}
.tcard h3{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ganache);margin-bottom:14px;position:relative}
.tcard p{font-size:.92rem;color:var(--ganache2);line-height:1.85;margin-bottom:10px}
.tcard ul{list-style:none;padding:0}
.tcard li{font-size:.88rem;color:var(--ganache2);padding:8px 0;border-bottom:1px solid rgba(122,42,53,.09)}

/* REGISTRY */
.registry{padding:140px 40px;background:var(--ganache);text-align:center;position:relative;overflow:hidden}
.registry::before{content:'C & J';font-family:var(--script);font-size:40vw;color:rgba(255,255,255,.012);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;line-height:1}
.registry p{color:rgba(232,213,176,.38);font-size:.95rem;max-width:520px;margin:0 auto}
.registry-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:880px;margin:56px auto 0}
.rcard{border:1px solid rgba(232,213,176,.1);padding:48px 28px;transition:border-color .3s,transform .3s;cursor:none;display:flex;flex-direction:column;align-items:center;gap:10px}
.rcard:hover{border-color:var(--champagne);transform:translateY(-4px)}
.rcard-store{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--champ-lt)}
.rcard-link{font-family:var(--sans);font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(232,213,176,.32)}
.rcard:hover .rcard-link{color:var(--champagne)}

/* RSVP */
.rsvp{padding:140px 40px;background:var(--alabaster);text-align:center;position:relative;overflow:hidden}
.rsvp::before,.rsvp::after{content:'';position:absolute;width:600px;height:600px;border-radius:50%;border:1px solid rgba(122,42,53,.06);pointer-events:none}
.rsvp::before{top:-220px;left:-220px}.rsvp::after{bottom:-220px;right:-220px}
.rsvp-wrap{position:relative;z-index:1;max-width:860px;margin:0 auto}
.rsvp p{font-size:.95rem;color:var(--ganache2);margin-bottom:36px}
.form-box{background:var(--cream);border:1px solid rgba(122,42,53,.14);padding:64px 52px;box-shadow:0 20px 80px rgba(122,42,53,.07)}
.form-placeholder{font-family:var(--sans);font-size:.78rem;color:rgba(46,20,25,.38);line-height:2.5}
.form-placeholder p{margin-bottom:6px}
.form-placeholder code{display:inline-block;background:var(--champ-lt);border:1px dashed rgba(122,42,53,.22);padding:12px 20px;font-family:monospace;font-size:.72rem;color:var(--mulberry);margin:8px 0;word-break:break-all}

/* FAQ */
.faq{padding:140px 40px;background:var(--cream)}
.faq-wrap{max-width:780px;margin:0 auto}
.faq-header{text-align:center;margin-bottom:60px}
.faq-item{border-bottom:1px solid rgba(122,42,53,.11)}
.faq-item summary{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--ganache);padding:22px 56px 22px 0;list-style:none;cursor:none;position:relative;transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'';position:absolute;right:0;top:50%;width:18px;height:1px;background:var(--mulberry);transform:translateY(-50%)}
.faq-item summary::before{content:'';position:absolute;right:8px;top:50%;width:1px;height:18px;background:var(--mulberry);transform:translateY(-50%);transition:opacity .3s}
.faq-item[open] summary::before{opacity:0}
.faq-item summary:hover{color:var(--mulberry)}
.faq-item p{padding:0 0 22px;font-size:.92rem;color:var(--ganache2);line-height:1.9}

/* FOOTER */
footer{background:var(--ganache);padding:100px 40px 60px;text-align:center;position:relative;overflow:hidden}
footer::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(122,42,53,.18) 0%,transparent 60%)}
.footer-inner{position:relative;z-index:1}
.footer-mono{font-family:var(--script);font-size:6rem;color:var(--champagne);display:block;line-height:1;opacity:.72;margin-bottom:4px}
.footer-date{font-family:var(--sans);font-size:.6rem;letter-spacing:.42em;text-transform:uppercase;color:rgba(232,213,176,.18);display:block;margin-bottom:44px}
.footer-rule{display:flex;align-items:center;justify-content:center;gap:18px;max-width:360px;margin:0 auto 36px}
.footer-rule-line{flex:1;height:1px;background:linear-gradient(to right,transparent,rgba(232,213,176,.18),transparent)}
.footer-diamond{width:5px;height:5px;background:rgba(232,213,176,.28);transform:rotate(45deg)}
.footer-quote{font-family:var(--serif);font-style:italic;font-size:1rem;color:rgba(232,213,176,.25);max-width:440px;margin:0 auto 28px;line-height:1.85}
.footer-credit{font-family:var(--sans);font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,213,176,.1)}

@media(max-width:960px){
  .nav-links{display:none}.hamburger{display:flex}
  nav{padding:0 24px}
  .countdown-inner{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:36px;padding:56px 24px}
  .count-divider{display:none}
.cards{grid-template-columns:repeat(2,1fr)}.theme-grid{grid-template-columns:1fr}
  .story-grid{padding:0}
  .story-grid::before{left:16px;transform:none}
  .story-item{width:100%;padding-left:40px;padding-right:0;text-align:left;align-self:auto;margin:0}
  .story-item.left,.story-item.right{text-align:left;padding-left:40px;padding-right:0}

  .venue{grid-template-columns:1fr}.venue-img{min-height:300px}.venue-img::after{display:none}
  .venue-text{padding:60px 40px}
  .travel-grid,.registry-cards,.video-grid{grid-template-columns:1fr}
  .form-box{padding:40px 28px}
  .party-row{flex-wrap:wrap}.party-card{flex:1 1 45%}
  .gallery-masonry{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .g1,.g2,.g3,.g4,.g5,.g6,.g7{grid-column:auto;grid-row:auto;aspect-ratio:1}
}
@media(max-width:600px){
  .party-row{flex-direction:column}
  .party-card{border-right:none;border-bottom:1px solid rgba(122,42,53,.07)}
  .story,.theme-section,.details,.party,.travel,.registry,.rsvp,.faq,.music-section{padding-left:24px;padding-right:24px}
  .venue-text{padding:48px 24px}.tcard{padding:40px 24px}
  .form-box,.dresscode{padding:36px 20px}
  .gallery-masonry{grid-template-columns:1fr}
  .palette-row{flex-wrap:wrap}.swatch{flex:1 1 33%;height:56px}
  .lang-label{display:none}
}
