:root{
  --bg:#140d0b;
  --bg-2:#1b110e;
  --panel:rgba(255,248,243,.06);
  --panel-2:rgba(255,248,243,.09);
  --line:rgba(255,255,255,.10);
  --text:#f7efe7;
  --muted:#d6c6bc;
  --butter:#f0ddb0;
  --sand:#d4c6b7;
  --chocolate:#3c2019;
  --shadow:0 30px 80px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:"Inter",system-ui,sans-serif;
  background:
    radial-gradient(circle at 10% 10%, rgba(130,46,29,.18), transparent 25%),
    radial-gradient(circle at 85% 10%, rgba(66,76,117,.16), transparent 24%),
    linear-gradient(180deg, #1b100d 0%, #110b09 100%);
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font:inherit}
.wrap{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.narrow{max-width:820px}
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.05;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.85) 0 1px, transparent 1.5px),
    radial-gradient(circle at 70% 60%, rgba(255,255,255,.7) 0 1px, transparent 1.5px),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,.5) 0 1px, transparent 1.5px);
  background-size:150px 150px, 210px 210px, 170px 170px;
}
.spot{
  position:fixed; border-radius:999px; filter:blur(100px); pointer-events:none; z-index:0; opacity:.22;
}
.spot-a{width:34vw;height:34vw; background:#6b281a; top:-10vw; right:-6vw; animation:float1 16s ease-in-out infinite}
.spot-b{width:30vw;height:30vw; background:#32405f; left:-8vw; bottom:-10vw; animation:float2 18s ease-in-out infinite}
@keyframes float1{50%{transform:translate(-3vw,4vw) scale(1.05)}}
@keyframes float2{50%{transform:translate(4vw,-2vw) scale(.95)}}

.preloader{
  position:fixed; inset:0; display:grid; place-items:center; background:#100907; z-index:100;
  transition:opacity .8s ease, visibility .8s ease;
}
.preloader.is-hidden{opacity:0;visibility:hidden}
.preloader__inner{text-align:center}
.preloader__eyebrow{
  color:var(--muted); text-transform:uppercase; letter-spacing:.24em; font-size:12px; margin-bottom:12px;
}
.preloader__title{
  font-family:"Cormorant Garamond", serif !important;
  font-weight:600;
  font-size:clamp(42px,7vw,84px);
  line-height:.95;
  letter-spacing:-0.02em;
  opacity:1;
  visibility:visible;
  transform:none;
}
.preloader__date{margin-top:10px; color:var(--butter); letter-spacing:.18em; text-transform:uppercase; font-size:12px}

.topbar{
  position:sticky; top:0; z-index:40; padding:14px 0 0;
}
.topbar__row{
  min-height:62px; display:flex; align-items:center; justify-content:space-between;
  border:1px solid var(--line); border-radius:999px;
  background:rgba(255,255,255,.05); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  padding:0 18px; box-shadow:var(--shadow);
}
.topbar__brand{
  text-transform:uppercase; letter-spacing:.18em; font-size:13px;
}
.topbar__nav{display:flex; gap:20px}
.topbar__nav a{font-size:13px; color:var(--muted)}
.topbar__nav a:hover{color:var(--text)}

.hero{
  position:relative; z-index:2; min-height:calc(100vh - 78px);
  display:grid; align-items:center; padding:42px 0 56px;
}
.hero__grid{
  display:grid; grid-template-columns:1.02fr .98fr; gap:44px; align-items:center;
}
.eyebrow{
  color:var(--butter); text-transform:uppercase; letter-spacing:.22em; font-size:12px; margin-bottom:16px;
}
h1,h2,h3{
  margin:0;
  font-family:"Cormorant Garamond", serif;
  font-weight:600;
  letter-spacing:-.02em;
}
h1{font-size:clamp(68px,11vw,150px); line-height:.84; margin-bottom:20px}
h2{font-size:clamp(42px,6vw,78px); line-height:.92; margin-bottom:14px}
h3{font-size:34px; line-height:.95; margin-bottom:12px}
.hero__lead,.lead,.body-text,.program-item p,.info-card p{
  color:var(--muted); line-height:1.75;
}
.hero__lead,.lead{font-size:18px}
.body-text{font-size:16px}
.center{text-align:center}

.hero__actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:28px}
.btn{
  border:none; border-radius:999px; padding:15px 22px; cursor:pointer;
  text-transform:uppercase; letter-spacing:.16em; font-size:12px;
  transition:transform .25s ease, background .25s ease, border-color .25s ease, color .25s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn--light{background:var(--text); color:#1a110e}
.btn--ghost{background:rgba(255,255,255,.04); color:var(--text); border:1px solid var(--line)}

.photo-frame{
  background:#fff; padding:14px; border-radius:30px; box-shadow:var(--shadow);
  transform:perspective(1300px) rotateY(-8deg) rotateX(3deg);
  transition:transform .35s ease;
}
.photo-frame img{
  width:100%; border-radius:18px; aspect-ratio:3/4.3; object-fit:cover;
}
.hero-note{
  position:absolute; right:-10px; bottom:22px;
  background:rgba(255,255,255,.08); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid var(--line); border-radius:22px; padding:16px 18px; box-shadow:var(--shadow);
}
.hero-note span{display:block; color:var(--muted); text-transform:uppercase; font-size:11px; letter-spacing:.18em}
.hero-note strong{display:block; margin-top:8px; font-size:18px; font-weight:600}

.ticker{
  position:relative; z-index:2; overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.03);
}
.ticker__track{
  display:flex; gap:44px; min-width:max-content; white-space:nowrap; padding:18px 0;
  animation:ticker 28s linear infinite;
  text-transform:uppercase; letter-spacing:.20em; font-size:12px; color:var(--sand);
}
@keyframes ticker{to{transform:translateX(-50%)}}

.section{position:relative; z-index:2; padding:96px 0}
.section--center{text-align:center}
.split-card,.countdown-panel,.location-card,.rsvp-panel{
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius:34px;
  box-shadow:var(--shadow);
}
.split-card{
  padding:34px; display:grid; grid-template-columns:1.15fr .85fr; gap:28px; align-items:start;
}
.quote-box{
  border:1px solid var(--line); border-radius:28px; background:rgba(255,255,255,.04); padding:28px;
}
.quote-box__line{width:48px;height:1px;background:var(--butter); margin-bottom:18px}
.quote-box p{font-family:"Cormorant Garamond", serif; font-size:38px; line-height:1.05; margin:0}

.countdown-panel{padding:34px}
.countdown{
  margin-top:22px; display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
.countdown__item{
  padding:24px 12px; border-radius:24px; border:1px solid var(--line); background:rgba(255,255,255,.04); text-align:center;
}
.countdown__item strong{
  display:block; font-family:"Cormorant Garamond", serif; font-size:54px; line-height:1; margin-bottom:8px;
}
.countdown__item span{
  color:var(--muted); text-transform:uppercase; font-size:11px; letter-spacing:.18em;
}

.program-grid{
  margin-top:26px; display:grid; grid-template-columns:repeat(2,1fr); gap:18px;
}
.program-item{
  border:1px solid var(--line); border-radius:28px; padding:24px; background:rgba(255,255,255,.04);
}
.program-item span{
  display:block; color:var(--butter); text-transform:uppercase; letter-spacing:.18em; font-size:12px; margin-bottom:10px;
}
.program-item strong{display:block; font-size:24px; margin-bottom:10px}

.cards-3{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.info-card{
  border:1px solid var(--line); border-radius:28px; padding:26px; background:rgba(255,255,255,.04);
  box-shadow:var(--shadow);
}

.location-card{
  padding:34px; display:grid; grid-template-columns:1.15fr .85fr; gap:20px; align-items:stretch;
}
.location-card__meta{
  display:grid; gap:16px;
}
.meta-box{
  min-height:160px; border-radius:28px; border:1px solid var(--line);
  background:
    radial-gradient(circle at 20% 20%, rgba(240,221,176,.14), transparent 30%),
    linear-gradient(180deg, rgba(60,32,25,.48), rgba(34,20,17,.68));
  padding:24px; display:flex; flex-direction:column; justify-content:flex-end;
}
.meta-box span{color:var(--muted); text-transform:uppercase; font-size:12px; letter-spacing:.18em}
.meta-box strong{font-family:"Cormorant Garamond", serif; font-size:46px; line-height:.95; margin-top:10px}

/* ===== RSVP CLEAN REBUILD ===== */
.rsvp-panel{
  padding:34px;
  text-align:center;
}

.rsvp-popup{
  display:none;
  margin-top:24px;
  width:100%;
}

.rsvp-popup.is-open{
  display:block;
}

.rsvp-form{
  margin-top:24px;
  display:grid;
  gap:14px;
  max-width:700px;
  margin-inline:auto;
}

.rsvp-form input[type="text"],
.rsvp-form textarea,
.rsvp-form select{
  width:100%;
  display:block;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:16px 18px;
  outline:none;
  box-sizing:border-box;
}

.rsvp-form textarea{
  min-height:120px;
  resize:vertical;
}

.rsvp-form input[type="text"]::placeholder,
.rsvp-form textarea::placeholder{
  color:var(--muted);
}

.form-block{
  text-align:left;
  padding:18px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
}

.form-label{
  margin-bottom:12px;
  color:var(--text);
  font-weight:600;
}

.choice-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
  color:var(--muted);
  cursor:pointer;
  user-select:none;
}

.choice-row input[type="radio"],
.choice-row input[type="checkbox"]{
  width:18px;
  height:18px;
  min-width:18px;
  min-height:18px;
  margin:0;
  padding:0;
  border:none;
  background:none;
  box-shadow:none;
  appearance:auto;
  -webkit-appearance:auto;
  accent-color:#f0ddb0;
  cursor:pointer;
  flex:0 0 auto;
}

.choice-row span{
  display:inline-block;
}

.form-success{
  display:none;
  color:var(--butter);
  margin-top:4px;
}

.rsvp-form.is-sent .form-success{
  display:block;
}

.reveal{
  opacity:0; transform:translateY(26px); transition:opacity .9s ease, transform .9s ease;
}
.reveal-delay{transition-delay:.16s}
.reveal.is-visible{opacity:1; transform:none}

.card-float{animation:softFloat 5s ease-in-out infinite}
@keyframes softFloat{50%{transform:translateY(-7px)}}

@media (max-width: 980px){
  .hero__grid,.split-card,.location-card,.cards-3,.program-grid{grid-template-columns:1fr}
  .countdown{grid-template-columns:repeat(2,1fr)}
  .photo-frame{transform:none}
}
@media (max-width: 680px){
  .wrap{width:min(100% - 20px, 1180px)}
  .topbar__nav{display:none}
  .topbar__row{padding:0 14px}
  .section{padding:72px 0}
  .split-card,.countdown-panel,.location-card,.rsvp-panel{padding:24px}
  h1{font-size:64px}
  .hero__lead,.lead{font-size:16px}
  .quote-box p{font-size:32px}
  .countdown__item strong{font-size:42px}
}

.dresscode-lead{
  max-width: 860px;
  margin-bottom: 26px;
}
.palette-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin:26px 0 22px;
}
.palette-item{
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.04);
  padding:18px;
  display:flex;
  align-items:center;
  gap:14px;
  box-shadow:var(--shadow);
}
.palette-item strong{
  font-size:15px;
  font-weight:600;
  letter-spacing:.02em;
}
.swatch{
  width:34px;
  height:34px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
  flex:0 0 auto;
}
.swatch-1{background:#301D17;}
.swatch-2{background:#1F1511;}
.swatch-3{background:#D6CBB6;}
.swatch-4{background:#E6D7BE;}
.swatch-5{background:#F4EEE4;}
.swatch-6{background:#384168;}
.swatch-7{background:#4A4A4A;}
.swatch-8{background:#111111;}

.cards-2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}

@media (max-width: 980px){
  .palette-grid{grid-template-columns:repeat(2,1fr)}
  .cards-2{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .palette-grid{grid-template-columns:1fr}
}

.looks-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin:8px 0 24px;
}
.look-card{
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  box-shadow:var(--shadow);
}
.look-photo{
  height:180px;
  background-size:cover;
  background-position:center;
}
.look-a{background:
linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.28)),
radial-gradient(circle at 50% 20%, #f4eee4 0 20%, transparent 21%),
linear-gradient(180deg,#d6cbb6 0%, #bba890 100%);}
.look-b{background:
linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.28)),
linear-gradient(135deg,#e6d7be 0%, #c6b08c 100%);}
.look-c{background:
linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.28)),
linear-gradient(135deg,#384168 0%, #111 100%);}
.look-d{background:
linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.28)),
linear-gradient(135deg,#4a4a4a 0%, #1f1511 100%);}
.look-card strong{
 display:block;padding:14px 14px 4px;font-size:15px;
}
.look-card span{
 display:block;padding:0 14px 16px;color:var(--muted);font-size:13px;line-height:1.5;
}
@media (max-width:980px){
 .looks-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
 .looks-grid{grid-template-columns:1fr}
}

.look-photo{
  width:100%;
  height:220px;
  object-fit:cover;
  display:block;
  background:#1c1c1c;
}

.looks-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin:8px 0 24px;
}
.look-card{
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  box-shadow:var(--shadow);
}
.look-photo{
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
  background:#1c1c1c;
}
.look-card strong{
  display:block;
  padding:14px 14px 4px;
  font-size:15px;
}
.look-card span{
  display:block;
  padding:0 14px 16px;
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
}

.single-look-panel{
  margin:0 0 24px;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  box-shadow:var(--shadow);
  display:grid;
  grid-template-columns: 0.95fr 1.05fr;
  align-items:stretch;
}
.single-look-panel__image img{
  width:100%;
  height:100%;
  min-height:320px;
  object-fit:cover;
  display:block;
}
.single-look-panel__copy{
  padding:26px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.single-look-panel__copy h3{
  margin-bottom:10px;
}
.single-look-panel__copy p{
  color:var(--muted);
  line-height:1.75;
}

@media (max-width: 980px){
  .looks-grid{grid-template-columns:repeat(2,1fr)}
  .single-look-panel{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .looks-grid{grid-template-columns:1fr}
  .look-photo{height:300px}
}

/* Enhanced scroll animations */
.reveal[data-anim="fade-up"]{transform:translateY(42px) scale(.98)}
.reveal[data-anim="fade-right"]{transform:translateX(-42px); opacity:0}
.reveal[data-anim="fade-left"]{transform:translateX(42px); opacity:0}
.reveal[data-anim="zoom-up"]{transform:translateY(30px) scale(.94); opacity:0}
.reveal.is-visible[data-anim]{transform:none; opacity:1}

.stagger-grid > *{
  opacity:0;
  transform:translateY(26px) scale(.98);
  transition:opacity .8s ease, transform .8s ease, box-shadow .35s ease;
}
.stagger-grid.is-visible > *{opacity:1; transform:none}
.stagger-grid.is-visible > *:nth-child(1){transition-delay:.05s}
.stagger-grid.is-visible > *:nth-child(2){transition-delay:.14s}
.stagger-grid.is-visible > *:nth-child(3){transition-delay:.23s}
.stagger-grid.is-visible > *:nth-child(4){transition-delay:.32s}
.stagger-grid.is-visible > *:nth-child(5){transition-delay:.41s}
.stagger-grid.is-visible > *:nth-child(6){transition-delay:.50s}

.heading-glow{
  position:relative;
}
.heading-glow::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:72px;
  height:2px;
  background:linear-gradient(90deg, var(--butter), transparent);
  transform:scaleX(0);
  transform-origin:left center;
  opacity:.9;
  transition:transform 1s ease .2s;
}
.reveal.is-visible .heading-glow::after{
  transform:scaleX(1);
}

.program-item:hover,
.info-card:hover,
.look-card:hover,
.palette-item:hover,
.meta-box:hover{
  transform:translateY(-4px);
  box-shadow:0 28px 70px rgba(0,0,0,.42);
}

.single-look-panel{
  opacity:0;
  transform:translateY(24px) scale(.985);
  transition:opacity .9s ease, transform .9s ease;
}
.single-look-panel.is-visible{
  opacity:1;
  transform:none;
}

.parallax-soft{
  will-change: transform;
}

@media (prefers-reduced-motion: reduce){
  .reveal, .stagger-grid > *, .single-look-panel, .heading-glow::after{
    transition:none !important;
    animation:none !important;
    transform:none !important;
    opacity:1 !important;
  }
}

/* Requested: original size, new photo, remove white frame */
.photo-frame{
  background: transparent !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden;
  transform: none !important;
}
.photo-frame img{
  border-radius: 0 !important;
  box-shadow: 0 22px 70px rgba(0,0,0,.28);
}
.hero__visual{
  max-width: unset;
}

/* Full image visible, no crop, same visual width */
.hero__visual{
  width:min(420px, 82vw) !important;
  margin:0 auto !important;
}
.photo-frame{
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}
.photo-frame img{
  width:100% !important;
  height:auto !important;
  max-height:none !important;
  aspect-ratio:auto !important;
  object-fit:contain !important;
  object-position:center top !important;
  display:block !important;
  border-radius:0 !important;
  box-shadow:0 22px 70px rgba(0,0,0,.28);
}
@media (max-width:680px){
  .hero__visual{
    width:min(330px, 84vw) !important;
  }
}
.looks-section {
  margin: 50px 0 70px;
}

.looks-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 48px;
  line-height: 1;
  text-align: center;
  color: #f4e8dc;
  margin-bottom: 24px;
  letter-spacing: 0.5px;
}

.luxury-slider {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 14px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

.luxury-slider::-webkit-scrollbar {
  height: 6px;
}

.luxury-slider::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.04);
  border-radius: 999px;
}

.luxury-slider::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.18);
  border-radius: 999px;
}

.looks-track {
  display: flex;
  gap: 22px;
  width: max-content;
  padding: 4px 6px;
}

.luxury-slide {
  flex: 0 0 auto;
  width: 290px;
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  box-shadow: 0 18px 50px rgba(0,0,0,0.22);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.luxury-slide:hover {
  transform: translateY(-6px) scale(1.015);
  box-shadow: 0 28px 70px rgba(0,0,0,0.28);
}

.luxury-slide img {
  width: 100%;
  height: 430px;
  object-fit: cover;
  display: block;
}

@media (max-width: 768px) {
  .looks-title {
    font-size: 38px;
    margin-bottom: 18px;
  }

  .luxury-slide {
    width: 240px;
    border-radius: 20px;
  }

  .luxury-slide img {
    height: 360px;
  }

  .looks-section {
    margin: 40px 0 55px;
  }
}

/* Swiper looks block */
.looks-section {
  margin: 50px 0 70px;
}

.looks-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 48px;
  line-height: 1;
  text-align: center;
  color: #f4e8dc;
  margin-bottom: 24px;
  letter-spacing: 0.5px;
}

.luxury-slider {
  max-width: 320px;
  margin: 0 auto;
  overflow: visible;
  position: relative;
}

.luxury-slide {
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  box-shadow: 0 18px 50px rgba(0,0,0,0.22);
}

.luxury-slide img {
  width: 100%;
  height: 430px;
  object-fit: cover;
  display: block;
}

.swiper-button-prev,
.swiper-button-next {
  color: #f4e8dc;
  transform: scale(0.7);
}

.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 22px;
}

@media (max-width: 768px) {
  .looks-title {
    font-size: 38px;
    margin-bottom: 18px;
  }

  .luxury-slider {
    max-width: 260px;
  }

  .luxury-slide img {
    height: 360px;
  }

  .looks-section {
    margin: 40px 0 55px;
  }
}

/* Premium coverflow looks block */
.looks-section {
  margin: 56px 0 78px;
}

.looks-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 50px;
  line-height: 1;
  text-align: center;
  color: #f4e8dc;
  margin-bottom: 10px;
  letter-spacing: 0.4px;
}

.looks-subtitle {
  text-align: center;
  color: rgba(244, 232, 220, 0.72);
  font-size: 15px;
  letter-spacing: 0.08em;
  margin: 0 0 26px;
}

.luxury-slider {
  max-width: 520px;
  margin: 0 auto;
  overflow: visible;
  position: relative;
  padding: 6px 0 10px;
}

.luxury-slider .swiper-wrapper {
  align-items: center;
}

.luxury-slide {
  border-radius: 28px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  box-shadow: 0 18px 50px rgba(0,0,0,0.22);
}

.luxury-slide img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  display: block;
}

.luxury-slider .swiper-slide {
  opacity: 0.55;
  transform: scale(0.92);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.luxury-slider .swiper-slide-active {
  opacity: 1;
  transform: scale(1);
}

.swiper-button-prev,
.swiper-button-next {
  color: #f4e8dc;
  transform: scale(0.72);
}

.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 22px;
}

@media (max-width: 768px) {
  .looks-title {
    font-size: 38px;
    margin-bottom: 8px;
  }

  .looks-subtitle {
    font-size: 14px;
    margin-bottom: 20px;
  }

  .luxury-slider {
    max-width: 320px;
  }

  .luxury-slide img {
    height: 420px;
  }

  .looks-section {
    margin: 44px 0 60px;
  }
}

.organizers-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 24px;
}

.organizer-card {
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 24px;
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
  text-align: center;
}

.organizer-card h3 {
  margin-bottom: 10px;
}

.organizer-card p {
  margin-bottom: 16px;
  color: var(--muted);
}

.tg-button {
  display: inline-block;
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.05);
  color: var(--text);
}

.final-gallery-section {
  padding-top: 40px;
}

.final-gallery {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,0.28);
}

.final-gallery__slides {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4.2;
  background: #1b100d;
}

.final-gallery__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.final-gallery__img.is-active {
  opacity: 1;
}

.final-gallery__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  text-align: center;
  padding: 36px 24px;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0.02) 0%,
    rgba(0,0,0,0.18) 55%,
    rgba(0,0,0,0.42) 100%
  );
}

.final-gallery__title {
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(42px, 6vw, 72px);
  line-height: 0.95;
  color: #f7efe7;
  margin: 0 0 10px;
}

.final-gallery__text {
  font-size: 18px;
  color: #f7efe7;
  margin: 0 0 4px;
}

.final-gallery__names {
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(34px, 5vw, 56px);
  line-height: 1;
  color: #f7efe7;
  margin: 0;
}

@media (max-width: 768px) {
  .organizers-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .final-gallery {
    border-radius: 24px;
  }

  .final-gallery__overlay {
    padding: 26px 18px;
  }

  .final-gallery__text {
    font-size: 16px;
  }
}

/* ===== iPHONE LUXURY PRO MAX OVERRIDE ===== */
@media (max-width: 768px) {
  html, body {
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
  }

  body {
    background:
      radial-gradient(circle at 10% 8%, rgba(126,49,33,.26), transparent 28%),
      radial-gradient(circle at 88% 10%, rgba(57,73,112,.22), transparent 26%),
      linear-gradient(180deg, #1a110e 0%, #120b09 52%, #0f0908 100%);
  }

  .wrap {
    width: min(100% - 24px, 1180px) !important;
  }

  .grain {
    opacity: .03;
  }

  .spot-a,
  .spot-b {
    opacity: .14;
    filter: blur(90px);
  }

  .topbar {
    padding: 10px 0 0;
  }

  .topbar__row {
    min-height: 54px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.06);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    box-shadow: 0 12px 38px rgba(0,0,0,.16);
  }

  .topbar__brand {
    font-size: 12px;
    letter-spacing: .16em;
  }

  .topbar__nav {
    display: none !important;
  }

  .section {
    padding: 58px 0 !important;
  }

  .hero {
    min-height: auto;
    padding: 24px 0 34px;
  }

  .hero__grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    align-items: start;
  }

  .hero__copy {
    text-align: center;
  }

  h1 {
    font-size: clamp(54px, 15vw, 74px) !important;
    line-height: .88 !important;
    letter-spacing: -.035em;
    margin-bottom: 14px !important;
    text-wrap: balance;
  }

  h2 {
    font-size: clamp(34px, 9.5vw, 50px) !important;
    line-height: .96 !important;
    letter-spacing: -.025em;
    margin-bottom: 12px !important;
    text-wrap: balance;
  }

  h3 {
    font-size: 28px !important;
    line-height: .98 !important;
  }

  .eyebrow {
    font-size: 11px !important;
    letter-spacing: .18em !important;
    margin-bottom: 12px !important;
  }

  .lead,
  .hero__lead {
    font-size: 16px !important;
    line-height: 1.72 !important;
    color: rgba(247,239,231,.84) !important;
  }

  .body-text,
  .program-item p,
  .info-card p,
  .organizer-card p,
  .single-look-panel__copy p {
    font-size: 15px !important;
    line-height: 1.72 !important;
    color: rgba(247,239,231,.78) !important;
  }

  .hero__actions {
    justify-content: center;
    gap: 10px;
    margin-top: 22px;
  }

  .btn {
    min-height: 48px;
    padding: 14px 18px;
    font-size: 11px;
    letter-spacing: .14em;
    border-radius: 999px;
    box-shadow: 0 10px 24px rgba(0,0,0,.14);
  }

  .btn--light {
    background: linear-gradient(180deg, #fff8f2 0%, #efe2d3 100%);
    color: #1b120e;
  }

  .btn--ghost {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.10);
  }

  .hero__visual {
    width: min(100%, 345px) !important;
    margin: 0 auto !important;
  }

  .photo-frame {
    background: transparent !important;
    padding: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  .photo-frame img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: center top !important;
    border-radius: 0 !important;
    box-shadow: 0 22px 58px rgba(0,0,0,.28) !important;
  }

  .ticker {
    margin-top: 8px;
  }

  .ticker__track {
    gap: 28px;
    padding: 13px 0;
    font-size: 11px;
    letter-spacing: .16em;
  }

  .countdown-panel,
  .location-card,
  .rsvp-panel,
  .split-card {
    padding: 22px 18px !important;
    border-radius: 28px !important;
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)) !important;
    border: 1px solid rgba(255,255,255,.09) !important;
    box-shadow: 0 18px 48px rgba(0,0,0,.20) !important;
  }

  .countdown {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
    margin-top: 18px;
  }

  .countdown__item {
    border-radius: 20px !important;
    padding: 18px 8px !important;
    background: rgba(255,255,255,.045) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  }

  .countdown__item strong {
    font-size: 34px !important;
  }

  .countdown__item span {
    font-size: 10px;
    letter-spacing: .14em;
  }

  .program-grid,
  .cards-2,
  .cards-3,
  .organizers-grid,
  .location-card,
  .hero__grid,
  .split-card,
  .single-look-panel {
    grid-template-columns: 1fr !important;
  }

  .program-grid,
  .cards-2,
  .cards-3,
  .organizers-grid {
    gap: 14px !important;
  }

  .program-item,
  .info-card,
  .organizer-card,
  .meta-box {
    border-radius: 24px !important;
    padding: 20px !important;
    background: rgba(255,255,255,.045) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: 0 16px 42px rgba(0,0,0,.16) !important;
  }

  .program-item strong {
    font-size: 22px !important;
  }

  .location-card__copy .btn {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .meta-box {
    min-height: 126px;
  }

  .meta-box strong {
    font-size: 34px !important;
  }

  .dresscode-lead {
    margin-bottom: 18px !important;
  }

  .palette-image img {
    width: 100%;
    display: block;
    border-radius: 20px;
    box-shadow: 0 18px 46px rgba(0,0,0,.18);
  }

  .looks-section {
    margin: 36px 0 48px !important;
  }

  .looks-title {
    font-size: 34px !important;
    margin-bottom: 6px !important;
  }

  .looks-subtitle {
    font-size: 13px !important;
    line-height: 1.62;
    margin: 0 0 18px !important;
    padding: 0 12px;
    color: rgba(247,239,231,.70) !important;
  }

  .luxury-slider {
    max-width: 100% !important;
    padding: 4px 4px 10px !important;
  }

  .luxury-slide,
  .look-card {
    border-radius: 22px !important;
    overflow: hidden;
    box-shadow: 0 18px 48px rgba(0,0,0,.18) !important;
  }

  .luxury-slide img {
    height: 390px !important;
    object-fit: cover;
  }

  .swiper-button-prev,
  .swiper-button-next {
    display: none !important;
  }

  .single-look-panel {
    border-radius: 24px !important;
    overflow: hidden;
  }

  .single-look-panel__image img {
    min-height: 260px !important;
  }

  .single-look-panel__copy {
    padding: 20px !important;
  }

  .rsvp-panel {
    padding: 22px 16px !important;
  }

  .rsvp-form {
    gap: 12px !important;
    margin-top: 18px !important;
  }

  .rsvp-form input[type="text"],
  .rsvp-form textarea,
  .rsvp-form select {
    min-height: 52px;
    padding: 14px 16px !important;
    border-radius: 18px !important;
    font-size: 16px;
    border: 1px solid rgba(255,255,255,.09) !important;
    background: rgba(255,255,255,.05) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  }

  .rsvp-form textarea {
    min-height: 110px !important;
  }

  .form-block {
    padding: 16px !important;
    border-radius: 20px !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    background: rgba(255,255,255,.045) !important;
  }

  .form-label {
    font-size: 15px;
    margin-bottom: 10px !important;
  }

  .choice-row {
    gap: 10px !important;
    align-items: flex-start !important;
    margin-bottom: 12px !important;
  }

  .choice-row input[type="radio"],
  .choice-row input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    margin-top: 2px !important;
  }

  .choice-row span {
    font-size: 15px;
    line-height: 1.5;
  }

  .organizer-card .tg-button,
  .tg-button {
    width: 100%;
    text-align: center;
    padding: 14px 16px;
  }

  .final-gallery-section {
    padding-top: 10px !important;
  }

  .final-gallery {
    border-radius: 24px !important;
    box-shadow: 0 24px 60px rgba(0,0,0,.22) !important;
  }

  .final-gallery__slides {
    aspect-ratio: 3 / 4.5 !important;
  }

  .final-gallery__overlay {
    padding: 22px 16px !important;
    background: linear-gradient(
      180deg,
      rgba(0,0,0,0.00) 0%,
      rgba(0,0,0,0.16) 54%,
      rgba(0,0,0,0.48) 100%
    ) !important;
  }

  .final-gallery__title {
    font-size: clamp(32px, 9vw, 46px) !important;
    margin-bottom: 8px !important;
  }

  .final-gallery__text {
    font-size: 15px !important;
  }

  .final-gallery__names {
    font-size: clamp(28px, 8vw, 40px) !important;
  }

  .reveal {
    transition-duration: .8s !important;
  }
}

@media (max-width: 430px) {
  .wrap {
    width: min(100% - 18px, 1180px) !important;
  }

  h1 {
    font-size: 48px !important;
  }

  h2 {
    font-size: 31px !important;
  }

  .btn {
    width: 100%;
  }

  .hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .luxury-slide img {
    height: 350px !important;
  }

  .countdown__item strong {
    font-size: 30px !important;
  }

  .program-item,
  .info-card,
  .organizer-card,
  .meta-box,
  .form-block {
    border-radius: 20px !important;
  }
}
body{
  background:
    radial-gradient(circle at 10% 10%, rgba(130,46,29,.12), transparent 25%),
    radial-gradient(circle at 85% 10%, rgba(66,76,117,.10), transparent 24%),
    linear-gradient(
      180deg,
      #120b09 0%,
      #140d0b 18%,
      #1b110e 42%,
      #110b09 100%
    ) !important;
}
.split-card,
.countdown-panel,
.location-card,
.rsvp-panel,
.program-item,
.info-card,
.organizer-card,
.meta-box,
.form-block,
.countdown__item{
  background:
    linear-gradient(
      180deg,
      rgba(60,32,25,.32),
      rgba(34,20,17,.38)
    ) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}