*{box-sizing:border-box}
html{scroll-behavior:smooth;width:100%}
body{margin:0;background:#090000;color:#fff;font-family:"Montserrat",Arial,sans-serif;width:100%;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit}
.page{
  width:100%;
  max-width:none;
  margin:0;
  background:radial-gradient(circle at 30% 20%,#5b0310 0,#1a0004 38%,#060000 100%);
  min-height:100vh;
  overflow-x:hidden;
}
.section{padding:46px clamp(18px,4vw,48px)}
.section-tight{padding:20px 0 10px}
.hero{
  position:relative;
  min-height:100svh;
  display:grid;
  place-items:end center;
  padding:0 18px 74px;
}
.hero-image{position:absolute;inset:0;background:url("assets/hero.jpg") center 30%/cover no-repeat;filter:contrast(1.08) brightness(.82)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.05),rgba(38,0,5,.24) 40%,rgba(70,0,10,.96))}
.hero-content{position:relative;text-align:center;z-index:1}
.hero h1,
.program-section h2,
.places-section h2,
.hotels-section h2,
.dress-section h2,
.gifts-section h2,
.rsvp-section h2,
.countdown-section h2{
  margin:0 auto 22px;
  width:100%;
  display:block;
  text-align:center;
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:clamp(2.35rem,9vw,4.2rem);
  line-height:.86;
  text-transform:uppercase;
  letter-spacing:-.04em;
  color:#fff;
  text-shadow:0 10px 30px rgba(0,0,0,.48);
}
.hero h1 span{display:block}
.hero h1{font-size:clamp(3.1rem,13vw,5.9rem);margin-bottom:0}
.date,.eyebrow{text-transform:uppercase;letter-spacing:.24em;font-size:.78rem;margin-top:26px;color:#f7eae7}
.calendar-section{background:linear-gradient(to bottom,#5f030d,#360006 62%,#150003);text-align:center}
.calendar{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:10px;
  margin:22px auto 32px;
  width:min(100%,860px);
  background:transparent;
  border:0;
}
.calendar div{
  min-height:auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 0 4px;
  color:rgba(255,255,255,.82);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:transparent;
}
.calendar button{
  appearance:none;
  min-height:94px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  padding:12px 4px;
  font:inherit;
  box-shadow:0 18px 34px rgba(0,0,0,.18);
}
.calendar button .day-number{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:2rem;
  font-weight:700;
  line-height:1;
}
.calendar button small{
  display:block;
  font-size:.62rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.68);
}
.calendar button.is-outside{
  opacity:.72;
}
.calendar .wedding-day{
  background:linear-gradient(135deg,#b2071d,#5d020b);
  border-color:rgba(255,255,255,.26);
  box-shadow:0 20px 40px rgba(121,5,25,.34);
  transform:translateY(-2px);
}
.calendar .wedding-day small{
  color:#ffe2e7;
  font-weight:700;
}
.intro-text{font-family:"Cormorant Garamond",Georgia,serif;text-transform:uppercase;font-weight:700;font-size:.92rem;line-height:1.52;max-width:720px;margin:18px auto}
.intro-text.small{font-size:.8rem;opacity:.96}
.photo-break img{width:100%;height:auto}
.program-section{background:#080000;text-align:center}
.program-list{max-width:430px;margin:auto}
.program-list div{display:grid;grid-template-columns:78px 1fr;text-align:left;gap:14px;margin:16px 0}
.program-list time{font-size:.78rem;font-weight:700}
.program-list p{margin:0;text-transform:uppercase;font-size:.68rem;font-weight:700;line-height:1.45}
.program-list span{opacity:.82}
.note{font-family:"Cormorant Garamond",serif;text-transform:uppercase;font-weight:700;font-size:.84rem;line-height:1.42;margin:34px auto 0;max-width:720px}
.places-section{background:radial-gradient(circle at top,#5a020c,#090000 70%)}
.places-grid{display:grid;gap:24px}
.place-card{display:grid;grid-template-columns:1fr;gap:16px;align-items:center;color:#fff;text-decoration:none;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:14px;border-radius:22px;transition:transform .22s ease, box-shadow .22s ease}
.place-card:hover,.hotel-list a:hover,.dress-card:hover{transform:translateY(-3px);box-shadow:0 16px 28px rgba(0,0,0,.28)}
.place-card img{width:100%;aspect-ratio:1.18/1;object-fit:cover;border-radius:14px}
.place-card h3{margin:0 0 6px;font-family:"Cormorant Garamond",serif;text-transform:uppercase;font-size:1.2rem}
.place-card p{font-size:.72rem;text-transform:uppercase;margin:0 0 10px;line-height:1.42}
.place-card span,.hotel-list a span:last-child{display:inline-flex;align-items:center;gap:8px;color:#ffe3e7;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.gallery-section{background:#100004}
.gallery-slider{overflow:hidden;padding:10px 0 16px;width:100%}
.slider-track{display:flex;width:max-content;will-change:transform;}
.slider-group{display:flex;gap:16px;flex:none;padding-right:16px}
.slide-card{margin:0;flex:none;width:39vw;max-width:240px;min-width:145px;padding:0;background:transparent;border-radius:16px}
.slide-card img{width:100%;height:100%;aspect-ratio:5/11;object-fit:cover;border-radius:16px;border:2px solid rgba(255,255,255,.78);box-shadow:0 10px 26px rgba(0,0,0,.35)}

.scripture-section{text-align:center;background:#100004}
.scripture-section p,.scripture-section h3,.scripture-section blockquote{font-family:"Cormorant Garamond",serif;text-transform:uppercase}
.scripture-section p{font-weight:700;margin:0 0 8px}
.scripture-section h3{margin:12px 0 8px;font-size:1.3rem}
.scripture-section blockquote{font-weight:700;font-size:.95rem;line-height:1.5;margin:0 auto;max-width:760px}
.hotels-section{background:linear-gradient(#100004,#5a020c 50%,#100004)}
.hotel-list{display:grid;gap:16px}
.hotel-list a{display:block;text-align:center;text-decoration:none;color:#fff;background:rgba(255,255,255,.86);border:1px solid rgba(255,255,255,.45);border-radius:20px;padding:18px 14px;box-shadow:0 14px 26px rgba(0,0,0,.28);transition:transform .22s ease, box-shadow .22s ease}
.hotel-list strong{display:block;color:#3a0006;font-family:"Cormorant Garamond",serif;text-transform:uppercase;font-size:1.05rem}
.hotel-list span{display:block;color:#210004;text-transform:uppercase;font-size:.78rem;margin-top:6px;line-height:1.45;font-weight:700}
.dress-section{text-align:center;background:#080000}
.dress-subtitle,.gifts-section p,.rsvp-section p{font-family:"Cormorant Garamond",serif;font-weight:700;font-size:1rem;line-height:1.45}
.dress-grid{display:grid;gap:18px;margin-top:24px}
.dress-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:22px;overflow:hidden;transition:transform .22s ease, box-shadow .22s ease}
.dress-card img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center center}
.dress-copy{padding:18px 16px 20px}
.dress-copy strong{display:block;font-family:"Cormorant Garamond",serif;text-transform:uppercase;font-size:1.35rem;letter-spacing:.02em;margin-bottom:8px}
.dress-copy span{font-size:.8rem;text-transform:uppercase;line-height:1.5;letter-spacing:.04em}
.gifts-section{text-align:center;background:radial-gradient(circle at top,#7b0311,#080000 66%);padding-bottom:70px}
.rsvp-section{text-align:center;background:#070000;padding-bottom:52px}
form{display:grid;gap:14px;text-align:left;max-width:720px;margin:0 auto}
label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
input,select,textarea{width:100%;margin-top:8px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);color:#fff;border-radius:14px;padding:14px;font:inherit;outline:none}
select option{color:#111}
textarea{resize:vertical}
form button{margin-top:8px;border:0;border-radius:999px;background:#fff;color:#3b0007;padding:15px 18px;text-transform:uppercase;font-weight:800;letter-spacing:.08em;cursor:pointer}
.form-status{text-align:center;min-height:20px;color:#ffd9df}
.countdown-section{text-align:center;background:linear-gradient(180deg,#070000 0,#150003 55%,#2e0006 100%);padding-bottom:80px}
.countdown{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:760px;margin:26px auto 0}
.countdown div{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.15);border-radius:18px;padding:16px 8px;backdrop-filter:blur(6px)}
.countdown strong{display:block;font-family:"Cormorant Garamond",serif;font-size:2.25rem;line-height:1}
.countdown span{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em}

@media (min-width:700px){
  .section{padding:60px clamp(32px,5vw,72px)}
  .hero{min-height:100vh;padding-bottom:86px}
  .date,.eyebrow{font-size:.88rem}
  .calendar>*{min-height:44px;font-size:.76rem}
  .program-list{max-width:520px}
  .program-list p{font-size:.76rem}
  .program-list time{font-size:.84rem}
  .places-grid{grid-template-columns:1fr 1fr}
  .place-card{grid-template-columns:42% 1fr;padding:16px 18px}
  .place-card.reverse{grid-template-columns:1fr 42%}
  .place-card.reverse img{order:2}
  .slide-card{width:24vw;max-width:250px}
  .hotel-list{grid-template-columns:repeat(2,1fr)}
  .dress-grid{grid-template-columns:1fr 1fr;align-items:start}
  .countdown{grid-template-columns:repeat(4,1fr)}
}

@media (min-width:980px){
  .section{padding-left:72px;padding-right:72px}
  .hero-image{background-position:center 25%}
  .gallery-slider{padding:16px 0 26px}
  .slide-card{max-width:270px}
}


/* Lieux section ohne Bilder */
.places-grid{
  max-width:760px;
  margin:0 auto;
}
.place-card,
.place-card.reverse{
  grid-template-columns:1fr !important;
  text-align:center;
  padding:22px 18px;
}
.place-card img{
  display:none !important;
}
.place-card.reverse img{
  order:0;
}

.hotel-list em{
  display:block;
  margin-top:10px;
  color:#6d0711;
  font-style:normal;
  font-size:.68rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}


@media (max-width:480px){
  .hero{
    min-height:92svh;
    padding:0 14px 56px;
  }
  .hero h1{
    font-size:clamp(2.9rem,14vw,4.3rem);
  }
  .date,.eyebrow{
    font-size:.74rem;
    letter-spacing:.18em;
  }
  .section{
    padding:36px 16px;
  }
  .program-list div{
    grid-template-columns:70px 1fr;
    gap:10px;
  }
  .calendar{
    gap:6px;
  }
  .calendar div{
    font-size:.62rem;
    letter-spacing:.05em;
  }
  .calendar button{
    min-height:72px;
    border-radius:18px;
    padding:10px 2px;
  }
  .calendar button .day-number{
    font-size:1.55rem;
  }
  .calendar button small{
    font-size:.52rem;
  }
  .countdown strong{
    font-size:2rem;
  }
}


.men-card img{
  object-position:72% center;
}

.women-card img{
  object-position:78% center;
}


.scripture-section > p,
.scripture-section > h3,
.scripture-section > blockquote{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.hotel-list{
  max-width: 1100px;
  margin: 0 auto;
}


/* Modern polish — layout bleibt gleich */
:root{
  --wine:#53030c;
  --deep:#070000;
  --soft-white:rgba(255,255,255,.92);
  --glass:rgba(255,255,255,.075);
  --line:rgba(255,255,255,.14);
}

.page{
  background:
    radial-gradient(circle at 50% 0%, rgba(144,4,22,.55), transparent 34%),
    linear-gradient(180deg,#070000 0%,#180003 34%,#090000 72%,#1a0004 100%);
}

.section{
  position:relative;
}

.hero-overlay{
  background:
    linear-gradient(to bottom,rgba(0,0,0,.10),rgba(35,0,5,.22) 42%,rgba(95,0,14,.92)),
    radial-gradient(circle at 50% 78%,rgba(145,6,23,.55),transparent 38%);
}

.hero h1{
  letter-spacing:-.055em;
  text-wrap:balance;
}

.date,
.eyebrow{
  color:var(--soft-white);
  font-weight:700;
}

.calendar{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 20px 50px rgba(0,0,0,.28);
}

.calendar > *{
  background:rgba(20,0,3,.82);
}

.calendar div{
  background:rgba(255,255,255,.08);
}

.calendar .wedding-day{
  background:linear-gradient(135deg,#9b0619,#5d020c);
}

.intro-text,
.note,
.scripture-section blockquote,
.gifts-section p,
.rsvp-section p{
  color:var(--soft-white);
}

.program-list{
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  padding:20px 18px;
  box-shadow:0 18px 42px rgba(0,0,0,.22);
}

.program-list div{
  border-bottom:1px solid rgba(255,255,255,.08);
  padding-bottom:13px;
}

.program-list div:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.place-card,
.dress-card{
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 18px 42px rgba(0,0,0,.22);
}

.place-card span,
.hotel-list em{
  opacity:.92;
}

.slide-card img{
  border:1px solid rgba(255,255,255,.82);
  box-shadow:0 18px 34px rgba(0,0,0,.42);
}

.scripture-section{
  background:
    radial-gradient(circle at 50% 0%,rgba(90,2,12,.52),transparent 45%),
    #100004;
}

.hotels-section{
  background:
    radial-gradient(circle at 50% 30%,rgba(116,4,18,.50),transparent 42%),
    linear-gradient(#090000,#300007 54%,#090000);
}

.hotel-list a{
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(235,226,226,.88));
  border:1px solid rgba(255,255,255,.65);
}

.dress-section{
  background:
    radial-gradient(circle at 50% 0%,rgba(92,2,13,.42),transparent 42%),
    #080000;
}

.dress-card{
  padding:10px;
}

.dress-card img{
  border-radius:16px;
}

.dress-copy{
  padding-top:16px;
}

.gifts-section{
  background:
    radial-gradient(circle at 50% 12%,rgba(155,5,25,.58),transparent 44%),
    linear-gradient(180deg,#120003,#070000);
}

.rsvp-section{
  background:
    radial-gradient(circle at 50% 0%,rgba(70,2,10,.55),transparent 40%),
    #070000;
}

input,
select,
textarea{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(255,255,255,.55);
}

form button{
  box-shadow:0 14px 30px rgba(0,0,0,.32);
  transition:transform .2s ease, box-shadow .2s ease;
}

form button:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 38px rgba(0,0,0,.38);
}

.countdown div{
  background:linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.055));
  box-shadow:0 16px 34px rgba(0,0,0,.25);
}

@media (max-width:480px){
  .program-list{
    padding:18px 14px;
  }

  .dress-card{
    padding:8px;
  }
}


/* Optimized premium animations + language toggle */
:root{
  --ease-premium:cubic-bezier(.16,1,.3,1);
}

html,
body,
.page{
  overflow-x:hidden;
}

body{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.lang-toggle{
  position:fixed;
  top:16px;
  right:16px;
  z-index:1100;
  display:flex;
  gap:8px;
  padding:8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(8,0,1,.48);
  backdrop-filter:blur(12px);
  box-shadow:0 10px 26px rgba(0,0,0,.25);
}

.lang-btn{
  border:0;
  border-radius:999px;
  padding:10px 14px;
  min-width:52px;
  background:transparent;
  color:rgba(255,255,255,.84);
  font:700 .74rem/1 "Montserrat",Arial,sans-serif;
  letter-spacing:.08em;
  cursor:pointer;
  transition:background-color .25s ease, color .25s ease, transform .25s ease;
}

.lang-btn:hover{
  transform:translateY(-1px);
}

.lang-btn.active{
  background:#ffffff;
  color:#3c0007;
}

.hero{
  perspective:1200px;
  overflow:hidden;
}

.hero-image{
  transform:scale(1.11);
  animation:heroZoomSmooth 1800ms var(--ease-premium) forwards;
  will-change:transform;
}

.hero-overlay{
  animation:heroOverlayIn 1400ms var(--ease-premium) forwards;
}

.hero-content{
  opacity:0;
  transform:translate3d(0,28px,0);
  animation:heroContentIn 950ms var(--ease-premium) .18s forwards;
  will-change:opacity,transform;
}

.hero h1{
  will-change:transform;
  animation:titleFloatSmooth 5.8s ease-in-out infinite alternate;
}

.date{
  opacity:0;
  transform:translate3d(0,10px,0);
  animation:dateIn 750ms var(--ease-premium) .48s forwards;
}

.reveal{
  opacity:0;
  transform:translate3d(0,34px,0);
  transition:
    opacity 760ms var(--ease-premium),
    transform 760ms var(--ease-premium);
  will-change:opacity,transform;
}

.reveal.in-view{
  opacity:1;
  transform:translate3d(0,0,0);
}

.reveal.delay-1{transition-delay:70ms}
.reveal.delay-2{transition-delay:140ms}
.reveal.delay-3{transition-delay:210ms}

.program-list div{
  opacity:0;
  transform:translate3d(0,20px,0);
  transition:
    opacity 560ms var(--ease-premium),
    transform 560ms var(--ease-premium);
  will-change:opacity,transform;
}

.program-section.in-view .program-list div{
  opacity:1;
  transform:translate3d(0,0,0);
}

.program-section.in-view .program-list div:nth-child(1){transition-delay:60ms}
.program-section.in-view .program-list div:nth-child(2){transition-delay:120ms}
.program-section.in-view .program-list div:nth-child(3){transition-delay:180ms}
.program-section.in-view .program-list div:nth-child(4){transition-delay:240ms}
.program-section.in-view .program-list div:nth-child(5){transition-delay:300ms}
.program-section.in-view .program-list div:nth-child(6){transition-delay:360ms}

.photo-break img{
  opacity:0;
  transform:scale(1.025);
  transition:
    opacity 900ms var(--ease-premium),
    transform 1200ms var(--ease-premium);
  will-change:opacity,transform;
}

.photo-break.in-view img{
  opacity:1;
  transform:scale(1);
}

.gallery-section,
.gallery-slider{
  overflow:hidden;
  max-width:100vw;
}

.gallery-slider{
  position:relative;
  padding-left:10px;
  padding-right:10px;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
}

.slider-track{
  transform:translate3d(0,0,0);
  will-change:transform;
}

.slide-card img,
.dress-card img,
.place-card,
.hotel-list a,
.dress-card,
form button{
  transform:translateZ(0);
  backface-visibility:hidden;
}

.slide-card img{
  transition:transform .55s ease;
}

.slide-card:hover img{
  transform:scale(1.026);
}

.place-card,
.hotel-list a,
.dress-card{
  transition:
    transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease;
}

.place-card:hover,
.hotel-list a:hover,
.dress-card:hover{
  transform:translate3d(0,-5px,0);
}

form button{
  transition:transform .24s ease, box-shadow .24s ease;
}

form button:hover{
  transform:translate3d(0,-3px,0);
}

.section:not(.hero),
.photo-break,
.gallery-section{
  content-visibility:auto;
  contain-intrinsic-size:700px;
}

@keyframes heroZoomSmooth{
  from{transform:scale(1.11)}
  to{transform:scale(1.03)}
}

@keyframes heroOverlayIn{
  from{opacity:.86}
  to{opacity:1}
}

@keyframes heroContentIn{
  from{opacity:0;transform:translate3d(0,28px,0)}
  to{opacity:1;transform:translate3d(0,0,0)}
}

@keyframes dateIn{
  from{opacity:0;transform:translate3d(0,10px,0)}
  to{opacity:1;transform:translate3d(0,0,0)}
}

@keyframes titleFloatSmooth{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(0,-6px,0)}
}

@media (max-width:640px){
  .lang-toggle{
    top:12px;
    right:12px;
    padding:6px;
  }

  .lang-btn{
    min-width:48px;
    padding:9px 12px;
    font-size:.7rem;
  }
}

@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }

  .reveal,
  .program-list div,
  .photo-break img,
  .hero-content,
  .date{
    opacity:1 !important;
    transform:none !important;
  }
}


@media (max-width:640px){
  .gallery-slider{
    -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 16%, #000 84%, transparent 100%);
    mask-image:linear-gradient(to right, transparent 0%, #000 16%, #000 84%, transparent 100%);
    padding-left:8px;
    padding-right:8px;
  }
}


/* Calendar redesign inspired by save-the-date layout */
.calendar-section .calendar{
  display:grid !important;
  grid-template-columns:repeat(7,minmax(0,1fr)) !important;
  gap:8px 16px !important;
  margin:24px auto 34px !important;
  width:min(100%,740px) !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  overflow:visible !important;
  box-shadow:none !important;
}

.calendar-section .calendar > *{
  background:transparent !important;
}

.calendar-section .calendar div{
  min-height:auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:0 0 2px !important;
  color:rgba(255,255,255,.82) !important;
  font-size:.9rem !important;
  font-weight:500 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  box-shadow:none !important;
  border:0 !important;
}

.calendar-section .calendar button{
  appearance:none !important;
  min-height:auto !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  color:#fff !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  gap:2px !important;
  padding:4px 0 !important;
  font:inherit !important;
  box-shadow:none !important;
  position:relative !important;
  transform:none !important;
}

.calendar-section .calendar button .day-number{
  font-family:"Cormorant Garamond",Georgia,serif !important;
  font-size:2.35rem !important;
  font-weight:600 !important;
  line-height:1 !important;
  position:relative !important;
  z-index:2 !important;
}

.calendar-section .calendar button small{
  display:block !important;
  font-size:.68rem !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
  color:rgba(255,255,255,.62) !important;
  position:relative !important;
  z-index:2 !important;
}

.calendar-section .calendar button.is-outside{
  opacity:.56 !important;
}

.calendar-section .calendar .wedding-day{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}

.calendar-section .calendar .wedding-day::before{
  content:"♥";
  position:absolute;
  left:50%;
  top:44%;
  transform:translate(-50%,-50%);
  font-size:2.6rem;
  color:rgba(204,20,52,.92);
  z-index:1;
  filter:drop-shadow(0 6px 10px rgba(0,0,0,.16));
}

.calendar-section .calendar .wedding-day small{
  color:#ffd7df !important;
  font-weight:700 !important;
}

@media (max-width:480px){
  .calendar-section .calendar{
    gap:6px 10px !important;
    width:min(100%,100%) !important;
  }

  .calendar-section .calendar div{
    font-size:.72rem !important;
    letter-spacing:.10em !important;
  }

  .calendar-section .calendar button .day-number{
    font-size:1.8rem !important;
  }

  .calendar-section .calendar button small{
    font-size:.54rem !important;
    letter-spacing:.08em !important;
  }

  .calendar-section .calendar .wedding-day::before{
    font-size:2.1rem !important;
    top:42% !important;
  }
}


/* Programme timeline redesign inspired by reference */
.program-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(109,7,20,.30), transparent 32%),
    linear-gradient(180deg,#120002 0%, #1b0004 100%) !important;
}

.program-section h2{
  margin-bottom:28px;
}

.program-list{
  position:relative;
  max-width:940px !important;
  margin:34px auto 22px !important;
  padding:34px 0 10px !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

.program-list::before{
  content:"";
  position:absolute;
  top:18px;
  bottom:10px;
  left:50%;
  width:2px;
  transform:translateX(-50%);
  background:linear-gradient(180deg, rgba(183,145,74,.9), rgba(150,116,52,.95));
  box-shadow:0 0 0 1px rgba(255,255,255,.03);
}

.program-list::after{
  content:"";
  position:absolute;
  top:-8px;
  left:50%;
  transform:translateX(-50%);
  width:18px;
  height:28px;
  background:
    linear-gradient(#b7914a,#b7914a) center/3px 100% no-repeat,
    linear-gradient(#b7914a,#b7914a) center 38%/100% 3px no-repeat;
}

.program-list div{
  position:relative;
  width:calc(50% - 38px);
  min-height:120px;
  margin:0 0 30px !important;
  padding:22px 20px 18px;
  display:block !important;
  text-align:left !important;
  background:rgba(250,246,242,.98);
  border:1px solid rgba(255,255,255,.55);
  border-radius:26px;
  box-shadow:0 20px 40px rgba(0,0,0,.16);
  color:#62595b;
}

.program-list div:nth-child(odd){
  margin-right:auto !important;
}

.program-list div:nth-child(even){
  margin-left:auto !important;
}

.program-list div::before{
  content:"";
  position:absolute;
  top:30px;
  width:22px;
  height:2px;
  background:#b7914a;
}

.program-list div:nth-child(odd)::before{
  right:-22px;
}

.program-list div:nth-child(even)::before{
  left:-22px;
}

.program-list div::after{
  content:"";
  position:absolute;
  top:23px;
  width:14px;
  height:14px;
  border-radius:50%;
  background:#b7914a;
  box-shadow:0 0 0 4px rgba(183,145,74,.16);
}

.program-list div:nth-child(odd)::after{
  right:-45px;
}

.program-list div:nth-child(even)::after{
  left:-45px;
}

.program-list time{
  display:block;
  margin-bottom:10px;
  font-family:"Cormorant Garamond", Georgia, serif !important;
  font-size:2.05rem !important;
  font-weight:700;
  line-height:1;
  letter-spacing:.06em;
  color:#a6803d !important;
}

.program-list p{
  margin:0 !important;
  font-family:"Cormorant Garamond", Georgia, serif !important;
  text-transform:uppercase !important;
  font-size:2rem;
  font-weight:700 !important;
  line-height:1.02 !important;
  letter-spacing:.04em;
  color:#666064 !important;
}

.program-list p span{
  display:block;
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid rgba(104,86,60,.16);
  font-family:"Cormorant Garamond", Georgia, serif !important;
  text-transform:none !important;
  font-size:1.2rem !important;
  font-weight:500 !important;
  line-height:1.4 !important;
  letter-spacing:0 !important;
  color:#7c7173 !important;
  opacity:1 !important;
}

.program-section .note{
  max-width:760px;
  margin:18px auto 0;
  color:rgba(255,255,255,.88);
}

@media (max-width:860px){
  .program-list{
    max-width:700px !important;
  }

  .program-list div{
    width:calc(50% - 28px);
    padding:18px 16px 16px;
    min-height:104px;
  }

  .program-list time{
    font-size:1.72rem !important;
  }

  .program-list p{
    font-size:1.55rem !important;
  }

  .program-list p span{
    font-size:1.02rem !important;
  }

  .program-list div::before{
    width:16px;
  }

  .program-list div:nth-child(odd)::before{
    right:-16px;
  }

  .program-list div:nth-child(even)::before{
    left:-16px;
  }

  .program-list div:nth-child(odd)::after{
    right:-33px;
  }

  .program-list div:nth-child(even)::after{
    left:-33px;
  }
}

@media (max-width:560px){
  .program-list{
    margin-top:26px !important;
    padding-top:28px !important;
  }

  .program-list::before{
    top:16px;
    bottom:6px;
  }

  .program-list::after{
  content:"";
  position:absolute;
  top:-8px;
  left:50%;
  transform:translateX(-50%);
  width:18px;
  height:28px;
  background:
    linear-gradient(#b7914a,#b7914a) center/3px 100% no-repeat,
    linear-gradient(#b7914a,#b7914a) center 38%/100% 3px no-repeat;
}

  .program-list div{
    width:calc(50% - 18px);
    padding:16px 12px 14px;
    border-radius:22px;
    min-height:auto;
    margin-bottom:22px !important;
  }

  .program-list time{
    font-size:1.35rem !important;
    letter-spacing:.04em;
    margin-bottom:7px;
  }

  .program-list p{
    font-size:1.05rem !important;
    line-height:1.08 !important;
  }

  .program-list p span{
    margin-top:10px;
    padding-top:10px;
    font-size:.86rem !important;
    line-height:1.34 !important;
  }

  .program-list div::before{
    top:24px;
    width:12px;
  }

  .program-list div:nth-child(odd)::before{
    right:-12px;
  }

  .program-list div:nth-child(even)::before{
    left:-12px;
  }

  .program-list div::after{
    top:18px;
    width:10px;
    height:10px;
    box-shadow:0 0 0 3px rgba(183,145,74,.14);
  }

  .program-list div:nth-child(odd)::after{
    right:-25px;
  }

  .program-list div:nth-child(even)::after{
    left:-25px;
  }
}


/* Cleaner modern override */
.page{
  background:
    radial-gradient(circle at 50% 0%, rgba(130,7,24,.28), transparent 28%),
    linear-gradient(180deg,#060000 0%, #130003 34%, #090000 68%, #170004 100%) !important;
}

.section{
  position:relative;
}

.section::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  transform:translateX(-50%);
  width:min(92%,880px);
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  pointer-events:none;
}

.section:last-of-type::after,
.countdown-section::after{
  display:none;
}

.hero-overlay{
  background:
    linear-gradient(to bottom, rgba(0,0,0,.12), rgba(40,0,7,.18) 38%, rgba(95,0,14,.88)),
    radial-gradient(circle at 50% 75%, rgba(171,7,30,.35), transparent 40%) !important;
}

.place-card,
.hotel-list a,
.dress-card,
.countdown div,
form{
  backdrop-filter:blur(12px);
}

.place-card,
.hotel-list a,
.dress-card{
  border:1px solid rgba(255,255,255,.13) !important;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.045)) !important;
  box-shadow:0 18px 40px rgba(0,0,0,.18) !important;
}

.hotel-list a{
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,239,239,.88)) !important;
}

.countdown div{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05)) !important;
  border:1px solid rgba(255,255,255,.10);
}

form{
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius:26px;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
}

input,
select,
textarea{
  background:rgba(255,255,255,.08) !important;
  border:1px solid rgba(255,255,255,.14) !important;
}

form button{
  background:linear-gradient(135deg, #f8f3f3, #dfd3d3) !important;
  color:#3c0007 !important;
}

/* Programme without boxes */
.program-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(132,8,24,.25), transparent 34%),
    linear-gradient(180deg,#100002 0%, #180003 100%) !important;
}

.program-list{
  max-width:980px !important;
  padding:34px 0 4px !important;
}

.program-list::before{
  background:linear-gradient(180deg, rgba(194,157,83,.98), rgba(145,109,48,.92)) !important;
}

.program-list div{
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  min-height:auto !important;
  padding:0 0 0 0 !important;
  color:#f4eeee !important;
}

.program-list div:nth-child(odd){
  padding-right:18px !important;
}

.program-list div:nth-child(even){
  padding-left:18px !important;
}

.program-list time{
  color:#d0a654 !important;
  font-size:2.08rem !important;
  margin-bottom:8px !important;
}

.program-list p{
  color:#fff7f8 !important;
  font-size:1.9rem !important;
  line-height:1.02 !important;
  letter-spacing:.045em !important;
  text-shadow:0 6px 18px rgba(0,0,0,.15);
}

.program-list p span{
  border-top:0 !important;
  margin-top:12px !important;
  padding-top:0 !important;
  color:rgba(255,240,242,.82) !important;
  font-size:1.06rem !important;
  line-height:1.45 !important;
}

.program-list div::before{
  background:#c59b4d !important;
  opacity:.88;
}

.program-list div::after{
  background:#c59b4d !important;
  box-shadow:0 0 0 5px rgba(197,155,77,.12) !important;
}

.program-section .note{
  max-width:780px;
  color:rgba(255,255,255,.82);
}

@media (max-width:860px){
  .program-list div{
    width:calc(50% - 24px) !important;
  }

  .program-list p{
    font-size:1.42rem !important;
  }

  .program-list p span{
    font-size:.96rem !important;
  }
}

@media (max-width:560px){
  .program-list{
    max-width:100% !important;
    padding-top:24px !important;
  }

  .program-list div{
    width:calc(50% - 16px) !important;
  }

  .program-list div:nth-child(odd){
    padding-right:10px !important;
  }

  .program-list div:nth-child(even){
    padding-left:10px !important;
  }

  .program-list time{
    font-size:1.25rem !important;
    margin-bottom:6px !important;
  }

  .program-list p{
    font-size:1rem !important;
    line-height:1.08 !important;
  }

  .program-list p span{
    margin-top:8px !important;
    font-size:.8rem !important;
    line-height:1.34 !important;
  }
}


/* Lieux + Hotels modern redesign, slider removed */
.gallery-section,
.gallery-slider,
.slider-track,
.slider-group,
.slide-card{
  display:none !important;
}

.places-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(135,9,25,.30), transparent 36%),
    linear-gradient(180deg,#090000 0%, #1b0004 100%) !important;
}

.places-grid{
  max-width:1040px !important;
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:18px !important;
  margin:0 auto !important;
}

.place-card,
.place-card.reverse{
  position:relative;
  min-height:230px;
  display:flex !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  text-align:left !important;
  overflow:hidden;
  padding:28px !important;
  border-radius:30px !important;
  background:
    linear-gradient(140deg, rgba(255,255,255,.12), rgba(255,255,255,.045)),
    radial-gradient(circle at 85% 15%, rgba(201,158,74,.20), transparent 34%) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:0 24px 60px rgba(0,0,0,.24) !important;
}

.place-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, transparent, rgba(0,0,0,.18)),
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.09), transparent 28%);
  pointer-events:none;
}

.place-card::after{
  content:"→";
  position:absolute;
  right:24px;
  top:22px;
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(255,255,255,.11);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:1.4rem;
  transition:transform .28s ease, background-color .28s ease;
}

.place-card:hover::after{
  transform:translate3d(4px,-4px,0);
  background:rgba(255,255,255,.18);
}

.place-card > div{
  position:relative;
  z-index:2;
  max-width:88%;
}

.place-card h3{
  margin:0 0 12px !important;
  font-size:clamp(1.8rem,3vw,2.7rem) !important;
  line-height:.92 !important;
  letter-spacing:-.03em;
  color:#fff !important;
}

.place-card p{
  margin:0 0 18px !important;
  color:rgba(255,238,241,.82) !important;
  font-size:.88rem !important;
  line-height:1.55 !important;
  letter-spacing:.04em !important;
}

.place-card span{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
  color:#fff !important;
  font-size:.68rem !important;
}

.hotels-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(166,10,31,.34), transparent 34%),
    linear-gradient(180deg,#090000 0%, #250006 52%, #090000 100%) !important;
}

.hotel-list{
  max-width:1120px !important;
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:14px !important;
  margin:0 auto !important;
}

.hotel-list a{
  position:relative;
  min-height:220px;
  display:flex !important;
  flex-direction:column;
  align-items:flex-start;
  justify-content:space-between;
  text-align:left !important;
  overflow:hidden;
  border-radius:28px !important;
  padding:24px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(236,226,226,.88)),
    radial-gradient(circle at 80% 0%, rgba(130,0,18,.14), transparent 36%) !important;
  border:1px solid rgba(255,255,255,.58) !important;
  box-shadow:0 22px 56px rgba(0,0,0,.22) !important;
}

.hotel-list a::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 16% 12%, rgba(95,0,14,.10), transparent 30%),
    linear-gradient(180deg, transparent, rgba(95,0,14,.08));
  pointer-events:none;
}

.hotel-list a::after{
  content:"↗";
  position:absolute;
  right:18px;
  top:18px;
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(77,0,11,.08);
  color:#3b0007;
  font-weight:800;
}

.hotel-list strong,
.hotel-list span,
.hotel-list em{
  position:relative;
  z-index:2;
}

.hotel-list strong{
  color:#320006 !important;
  font-size:clamp(1.15rem,1.7vw,1.55rem) !important;
  line-height:1.05 !important;
  letter-spacing:-.02em !important;
}

.hotel-list span{
  color:#4b1a20 !important;
  font-size:.78rem !important;
  line-height:1.5 !important;
  font-weight:700 !important;
  margin-top:16px !important;
}

.hotel-list em{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  align-self:flex-start;
  min-height:38px;
  margin-top:22px !important;
  padding:0 14px;
  border-radius:999px;
  background:#3b0007;
  color:#fff !important;
  font-size:.63rem !important;
  letter-spacing:.08em;
}

@media (max-width:980px){
  .hotel-list{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .places-grid{
    grid-template-columns:1fr !important;
  }

  .place-card,
  .place-card.reverse{
    min-height:200px;
  }
}

@media (max-width:560px){
  .places-grid,
  .hotel-list{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .place-card,
  .place-card.reverse{
    min-height:180px;
    border-radius:24px !important;
    padding:22px !important;
  }

  .place-card h3{
    font-size:2rem !important;
  }

  .hotel-list a{
    min-height:180px;
    border-radius:24px !important;
    padding:22px !important;
  }
}


/* Ultra modern redesign: Lieux, Hotels, Contact */
.places-section,
.hotels-section,
.rsvp-section{
  position:relative;
  overflow:hidden;
}

.places-section::before,
.hotels-section::before,
.rsvp-section::before{
  content:"";
  position:absolute;
  inset:-20% -10% auto -10%;
  height:320px;
  background:radial-gradient(circle, rgba(198,22,54,.18), transparent 58%);
  filter:blur(10px);
  pointer-events:none;
}

.places-section h2,
.hotels-section h2,
.rsvp-section h2{
  margin-bottom:16px !important;
}

.places-section .note,
.hotels-section .note,
.rsvp-section p{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}

/* LIEUX — more premium / editorial */
.places-grid{
  gap:20px !important;
  max-width:1180px !important;
}

.place-card,
.place-card.reverse{
  min-height:300px !important;
  padding:30px !important;
  border-radius:34px !important;
  background:
    linear-gradient(160deg, rgba(255,255,255,.14), rgba(255,255,255,.03) 58%),
    radial-gradient(circle at 100% 0%, rgba(207,162,72,.22), transparent 34%),
    linear-gradient(180deg, rgba(20,0,4,.82), rgba(44,0,8,.64)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:
    0 30px 80px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
  isolation:isolate;
}

.place-card::before{
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.22)),
    radial-gradient(circle at 20% 15%, rgba(255,255,255,.12), transparent 24%) !important;
}

.place-card::after{
  content:"MAPS" !important;
  right:22px !important;
  top:22px !important;
  width:auto !important;
  height:42px !important;
  padding:0 14px;
  border-radius:999px !important;
  background:rgba(255,255,255,.09) !important;
  border:1px solid rgba(255,255,255,.13) !important;
  color:#fff !important;
  font-size:.7rem !important;
  font-weight:700 !important;
  letter-spacing:.12em;
  box-shadow:0 8px 24px rgba(0,0,0,.18);
}

.place-card > div{
  max-width:78% !important;
}

.place-card h3{
  font-size:clamp(2.1rem, 3vw, 3rem) !important;
  line-height:.94 !important;
  margin-bottom:14px !important;
  text-shadow:0 10px 30px rgba(0,0,0,.18);
}

.place-card p{
  margin-bottom:20px !important;
  font-size:.9rem !important;
  line-height:1.65 !important;
  color:rgba(255,241,243,.84) !important;
}

.place-card span{
  min-height:44px !important;
  padding:0 18px !important;
  background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.08)) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  font-size:.7rem !important;
  font-weight:700 !important;
  letter-spacing:.12em;
  box-shadow:0 12px 26px rgba(0,0,0,.16);
}

.place-card:hover,
.place-card.reverse:hover{
  transform:translate3d(0,-8px,0) scale(1.008) !important;
  box-shadow:
    0 40px 100px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.09) !important;
}

/* HOTELS — sleek cards */
.hotel-list{
  max-width:1180px !important;
  gap:18px !important;
}

.hotel-list a{
  min-height:240px !important;
  padding:26px !important;
  border-radius:30px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,238,238,.88)),
    radial-gradient(circle at 100% 0%, rgba(124,0,21,.16), transparent 38%) !important;
  border:1px solid rgba(255,255,255,.62) !important;
  box-shadow:
    0 24px 70px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.65) !important;
}

.hotel-list a::after{
  width:42px !important;
  height:42px !important;
  right:18px !important;
  top:18px !important;
  border:1px solid rgba(59,0,7,.08);
  background:rgba(77,0,11,.06) !important;
  font-size:1rem !important;
}

.hotel-list strong{
  max-width:84%;
  font-family:"Cormorant Garamond", Georgia, serif !important;
  font-size:clamp(1.45rem, 1.8vw, 1.95rem) !important;
  line-height:.95 !important;
  letter-spacing:0 !important;
  color:#2e0006 !important;
}

.hotel-list span{
  margin-top:18px !important;
  font-size:.8rem !important;
  line-height:1.6 !important;
  letter-spacing:.03em !important;
  color:#5b252b !important;
  text-transform:none !important;
}

.hotel-list em{
  min-height:40px !important;
  margin-top:18px !important;
  padding:0 16px !important;
  background:linear-gradient(135deg, #420009, #670013) !important;
  font-size:.64rem !important;
  font-weight:700 !important;
  box-shadow:0 14px 28px rgba(67,0,10,.18);
}

.hotel-list a:hover{
  transform:translate3d(0,-8px,0) scale(1.008) !important;
  box-shadow:
    0 34px 90px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,.7) !important;
}

/* CONTACT / RSVP — much more modern */
.rsvp-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(166,11,31,.32), transparent 34%),
    linear-gradient(180deg,#080000 0%, #180003 100%) !important;
}

.rsvp-section > p{
  color:rgba(255,240,242,.82) !important;
  margin-bottom:26px !important;
}

.rsvp-section form{
  position:relative;
  max-width:980px !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px !important;
  padding:28px !important;
  border-radius:34px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
    radial-gradient(circle at 100% 0%, rgba(205,155,77,.16), transparent 34%) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:
    0 30px 80px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
  backdrop-filter:blur(18px);
}

.rsvp-section form::before{
  content:"Confirmation";
  position:absolute;
  top:18px;
  right:22px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.78);
  font-size:.66rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.rsvp-section form label{
  display:flex !important;
  flex-direction:column;
  gap:10px;
  padding:18px 18px 16px;
  border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:#fff !important;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.7rem !important;
  font-weight:700 !important;
}

.rsvp-section form label:nth-of-type(3){
  grid-column:1 / -1;
}

.rsvp-section input,
.rsvp-section select,
.rsvp-section textarea{
  width:100%;
  margin-top:0 !important;
  min-height:54px;
  padding:16px 18px !important;
  border-radius:18px !important;
  background:rgba(255,255,255,.08) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  color:#fff !important;
  font-size:.96rem !important;
  box-shadow:none !important;
}

.rsvp-section textarea{
  min-height:160px;
  resize:vertical;
}

.rsvp-section input::placeholder,
.rsvp-section textarea::placeholder{
  color:rgba(255,255,255,.44);
}

.rsvp-section select option{
  color:#120002;
}

.rsvp-section input:focus,
.rsvp-section select:focus,
.rsvp-section textarea:focus{
  border-color:rgba(214,171,92,.56) !important;
  background:rgba(255,255,255,.1) !important;
  box-shadow:0 0 0 4px rgba(214,171,92,.10) !important;
}

.rsvp-section button{
  grid-column:1 / -1;
  min-height:58px;
  margin-top:2px;
  border-radius:999px !important;
  background:
    linear-gradient(135deg, #ffffff, #ead8d8 56%, #d1b2b2) !important;
  color:#3b0007 !important;
  font-size:.84rem !important;
  font-weight:800 !important;
  letter-spacing:.16em;
  text-transform:uppercase;
  border:0 !important;
  box-shadow:0 18px 34px rgba(0,0,0,.22) !important;
}

.rsvp-section button:hover{
  transform:translate3d(0,-4px,0) !important;
  box-shadow:0 24px 40px rgba(0,0,0,.26) !important;
}

.rsvp-section .form-status{
  grid-column:1 / -1;
  margin:0 !important;
  text-align:center;
  color:rgba(255,244,245,.82) !important;
  font-size:.82rem !important;
}

@media (max-width:980px){
  .place-card,
  .place-card.reverse{
    min-height:250px !important;
  }

  .hotel-list{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }
}

@media (max-width:700px){
  .rsvp-section form{
    grid-template-columns:1fr !important;
    padding:22px !important;
    border-radius:28px !important;
  }

  .rsvp-section form label,
  .rsvp-section form label:nth-of-type(3){
    grid-column:auto !important;
  }

  .rsvp-section form::before{
    top:14px;
    right:16px;
  }
}

@media (max-width:560px){
  .place-card,
  .place-card.reverse{
    min-height:210px !important;
    padding:24px !important;
    border-radius:28px !important;
  }

  .place-card > div{
    max-width:100% !important;
  }

  .place-card::after{
    top:18px !important;
    right:18px !important;
    height:38px !important;
    padding:0 12px !important;
  }

  .hotel-list a{
    min-height:200px !important;
    padding:22px !important;
    border-radius:26px !important;
  }

  .hotel-list strong{
    max-width:100%;
    font-size:1.72rem !important;
  }

  .rsvp-section form{
    gap:14px !important;
  }

  .rsvp-section form label{
    padding:16px 14px 14px;
    border-radius:20px;
  }

  .rsvp-section input,
  .rsvp-section select,
  .rsvp-section textarea{
    min-height:50px;
    padding:14px 16px !important;
    border-radius:16px !important;
  }

  .rsvp-section textarea{
    min-height:140px;
  }
}


/* Calendar heart refinement */
.calendar-section .calendar .wedding-day{
  position:relative;
}

.calendar-section .calendar .wedding-day .day-number{
  color:#fff !important;
  text-shadow:0 6px 16px rgba(0,0,0,.18);
}

.calendar-section .calendar .wedding-day::before{
  content:"" !important;
  position:absolute;
  left:50%;
  top:44%;
  width:48px;
  height:48px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle, rgba(214,28,67,.30) 0%, rgba(214,28,67,.16) 46%, rgba(214,28,67,0) 74%);
  filter:blur(1px);
  z-index:0;
}

.calendar-section .calendar .wedding-day::after{
  content:"♥" !important;
  position:absolute;
  left:50%;
  top:43%;
  transform:translate(-50%,-50%);
  font-size:1.15rem;
  line-height:1;
  color:#cf1c46;
  text-shadow:0 4px 10px rgba(0,0,0,.12);
  z-index:1;
}

@media (max-width:480px){
  .calendar-section .calendar .wedding-day::before{
    width:40px;
    height:40px;
    top:42%;
  }

  .calendar-section .calendar .wedding-day::after{
    font-size:1rem;
    top:41%;
  }
}


/* Calendar heart stronger refinement */
.calendar-section .calendar .wedding-day{
  position:relative;
  isolation:isolate;
}

.calendar-section .calendar .wedding-day .day-number{
  position:relative;
  z-index:3;
  color:#fff !important;
  text-shadow:0 8px 18px rgba(0,0,0,.24);
}

.calendar-section .calendar .wedding-day small{
  position:relative;
  z-index:3;
}

.calendar-section .calendar .wedding-day::before{
  content:"♥" !important;
  position:absolute;
  left:50%;
  top:42%;
  transform:translate(-50%,-50%);
  font-size:2.3rem;
  line-height:1;
  color:#d81f52;
  opacity:.96;
  text-shadow:
    0 10px 22px rgba(216,31,82,.34),
    0 2px 6px rgba(0,0,0,.18);
  z-index:1;
}

.calendar-section .calendar .wedding-day::after{
  content:"" !important;
  position:absolute;
  left:50%;
  top:42%;
  width:62px;
  height:62px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle, rgba(216,31,82,.36) 0%, rgba(216,31,82,.18) 42%, rgba(216,31,82,0) 72%);
  filter:blur(2px);
  z-index:0;
}

@media (max-width:480px){
  .calendar-section .calendar .wedding-day::before{
    font-size:2rem;
    top:41%;
  }

  .calendar-section .calendar .wedding-day::after{
    width:54px;
    height:54px;
    top:41%;
  }
}


/* Hero name size adjustment */
.hero h1{
  font-size:clamp(3.7rem, 16vw, 7.2rem) !important;
  line-height:.76 !important;
}

@media (max-width:480px){
  .hero h1{
    font-size:clamp(3.35rem, 17vw, 5.1rem) !important;
  }
}


/* Zara / Nike modern full-site override */
:root{
  --bg-1:#050505;
  --bg-2:#0d0d0f;
  --surface-dark:rgba(255,255,255,.045);
  --surface-dark-2:rgba(255,255,255,.065);
  --surface-light:#f7f3ef;
  --line-soft:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.16);
  --text-soft:rgba(255,255,255,.78);
  --accent-metal:#c5a25d;
  --accent-soft:#8e182f;
}

body{
  background:#050505 !important;
}

.page{
  background:
    radial-gradient(circle at 50% 0%, rgba(122,9,29,.14), transparent 26%),
    linear-gradient(180deg,#050505 0%, #0a0a0b 28%, #0c0809 54%, #050505 100%) !important;
}

.section{
  padding-top:56px !important;
  padding-bottom:56px !important;
}

.section::after{
  width:min(92%,1200px) !important;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent) !important;
}

.hero{
  min-height:100svh !important;
}

.hero-overlay{
  background:
    linear-gradient(to bottom, rgba(0,0,0,.14), rgba(8,8,8,.18) 34%, rgba(0,0,0,.55) 72%, rgba(70,0,12,.62)),
    radial-gradient(circle at 50% 78%, rgba(130,10,28,.20), transparent 34%) !important;
}

.hero h1{
  font-size:clamp(4rem, 16vw, 7.6rem) !important;
  line-height:.75 !important;
  letter-spacing:-.06em !important;
  text-shadow:0 10px 34px rgba(0,0,0,.24) !important;
}

.date,
.eyebrow{
  font-weight:700 !important;
  letter-spacing:.22em !important;
  color:rgba(255,255,255,.92) !important;
}

.lang-toggle{
  top:18px !important;
  right:18px !important;
  padding:6px !important;
  border-radius:999px !important;
  background:rgba(6,6,7,.56) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:0 16px 32px rgba(0,0,0,.22) !important;
}

.lang-btn{
  min-width:50px !important;
  font-size:.72rem !important;
  letter-spacing:.12em !important;
}

.lang-btn.active{
  background:#ffffff !important;
  color:#080808 !important;
}

/* Heading system */
.program-section h2,
.places-section h2,
.hotels-section h2,
.dress-section h2,
.gifts-section h2,
.rsvp-section h2,
.countdown-section h2{
  font-size:clamp(2.9rem, 8vw, 5rem) !important;
  line-height:.85 !important;
  letter-spacing:-.045em !important;
  margin-bottom:14px !important;
}

/* Calendar — cleaner luxury */
.calendar-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(135,10,28,.16), transparent 28%),
    linear-gradient(180deg,#080808 0%, #111112 100%) !important;
}

.calendar-section .calendar{
  margin-top:26px !important;
}

.calendar-section .calendar div{
  color:rgba(255,255,255,.66) !important;
  font-weight:600 !important;
}

.calendar-section .intro-text{
  max-width:820px !important;
  color:rgba(255,255,255,.82) !important;
}

.calendar-section .calendar .wedding-day::before{
  color:#da1d54 !important;
  text-shadow:
    0 10px 24px rgba(218,29,84,.24),
    0 4px 8px rgba(0,0,0,.14) !important;
}

.calendar-section .calendar .wedding-day::after{
  background:radial-gradient(circle, rgba(218,29,84,.30) 0%, rgba(218,29,84,.14) 40%, rgba(218,29,84,0) 72%) !important;
}

/* General copy */
.intro-text,
.note,
.scripture-section > p,
.scripture-section blockquote,
.gifts-section p,
.rsvp-section > p,
.form-status{
  color:var(--text-soft) !important;
}

/* Programme — cleaner editorial line */
.program-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(128,10,28,.12), transparent 30%),
    linear-gradient(180deg,#080808 0%, #0f0f10 100%) !important;
}

.program-list::before{
  width:1px !important;
  background:linear-gradient(180deg, rgba(197,162,93,.85), rgba(197,162,93,.45)) !important;
}

.program-list::after{
  content:"";
  position:absolute;
  top:-8px;
  left:50%;
  transform:translateX(-50%);
  width:18px;
  height:28px;
  background:
    linear-gradient(#b7914a,#b7914a) center/3px 100% no-repeat,
    linear-gradient(#b7914a,#b7914a) center 38%/100% 3px no-repeat;
}

.program-list div{
  backdrop-filter:none !important;
}

.program-list time{
  color:var(--accent-metal) !important;
}

.program-list p{
  color:#ffffff !important;
}

.program-list p span{
  color:rgba(255,255,255,.68) !important;
}

/* Lieux — Zara/Nike minimal dark cards */
.places-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(132,11,28,.16), transparent 32%),
    linear-gradient(180deg,#060606 0%, #0e0e10 100%) !important;
}

.places-grid{
  gap:20px !important;
}

.place-card,
.place-card.reverse{
  min-height:310px !important;
  border-radius:28px !important;
  padding:30px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025)),
    linear-gradient(135deg, rgba(255,255,255,.025), rgba(255,255,255,0)) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  box-shadow:
    0 30px 70px rgba(0,0,0,.20),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
}

.place-card::before{
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.18)),
    radial-gradient(circle at 18% 14%, rgba(255,255,255,.08), transparent 24%) !important;
}

.place-card::after{
  content:"OPEN" !important;
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  color:#fff !important;
  box-shadow:none !important;
}

.place-card h3{
  font-size:clamp(2rem, 3vw, 3rem) !important;
  color:#fff !important;
  margin-bottom:14px !important;
}

.place-card p{
  color:rgba(255,255,255,.74) !important;
  font-size:.9rem !important;
  line-height:1.62 !important;
  letter-spacing:.03em !important;
}

.place-card span{
  background:#ffffff !important;
  color:#0a0a0a !important;
  border:0 !important;
  min-height:42px !important;
  font-size:.68rem !important;
  font-weight:800 !important;
  letter-spacing:.12em !important;
  box-shadow:none !important;
}

.place-card:hover,
.place-card.reverse:hover{
  transform:translate3d(0,-6px,0) !important;
  box-shadow:
    0 40px 86px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
}

/* Hotels — ultra clean white cards */
.hotels-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(135,12,28,.16), transparent 30%),
    linear-gradient(180deg,#080808 0%, #111112 54%, #080808 100%) !important;
}

.hotel-list{
  max-width:1240px !important;
  gap:18px !important;
}

.hotel-list a{
  min-height:230px !important;
  border-radius:26px !important;
  padding:24px !important;
  background:linear-gradient(180deg, #faf7f3, #f2ece7) !important;
  border:1px solid rgba(255,255,255,.72) !important;
  box-shadow:0 26px 60px rgba(0,0,0,.18) !important;
}

.hotel-list a::before{
  background:
    linear-gradient(180deg, transparent, rgba(0,0,0,.015)),
    radial-gradient(circle at 18% 16%, rgba(255,255,255,.9), transparent 28%) !important;
}

.hotel-list a::after{
  background:#ffffff !important;
  border:1px solid rgba(0,0,0,.06) !important;
  color:#111 !important;
  box-shadow:0 6px 16px rgba(0,0,0,.06) !important;
}

.hotel-list strong{
  max-width:88% !important;
  color:#171717 !important;
  font-size:clamp(1.45rem, 1.8vw, 1.95rem) !important;
  line-height:.94 !important;
  letter-spacing:-.02em !important;
}

.hotel-list span{
  color:#5d5652 !important;
  font-size:.8rem !important;
  line-height:1.58 !important;
  letter-spacing:.02em !important;
}

.hotel-list em{
  background:#111111 !important;
  color:#fff !important;
  min-height:38px !important;
  padding:0 16px !important;
  border-radius:999px !important;
  box-shadow:none !important;
}

.hotel-list a:hover{
  transform:translate3d(0,-6px,0) !important;
  box-shadow:0 34px 78px rgba(0,0,0,.22) !important;
}

/* Dress code — minimalist luxury */
.dress-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(115,9,24,.14), transparent 28%),
    linear-gradient(180deg,#060606 0%, #0f0f10 100%) !important;
}

.dress-subtitle{
  color:rgba(255,255,255,.74) !important;
  font-size:.95rem !important;
  letter-spacing:.04em !important;
}

.dress-card{
  border-radius:28px !important;
  padding:10px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.028)) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:0 22px 56px rgba(0,0,0,.18) !important;
}

.dress-card img{
  border-radius:22px !important;
}

.dress-copy strong{
  color:#fff !important;
  font-size:1.1rem !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}

.dress-copy span{
  color:rgba(255,255,255,.76) !important;
}

/* Gifts */
.gifts-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(128,10,28,.14), transparent 28%),
    linear-gradient(180deg,#080808 0%, #111112 100%) !important;
}

/* RSVP / Contact — Nike/Zara clean form */
.rsvp-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(140,11,29,.18), transparent 32%),
    linear-gradient(180deg,#060606 0%, #101011 100%) !important;
}

.rsvp-section form{
  max-width:1040px !important;
  border-radius:30px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  box-shadow:
    0 30px 70px rgba(0,0,0,.20),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

.rsvp-section form::before{
  content:"RSVP" !important;
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  color:rgba(255,255,255,.84) !important;
}

.rsvp-section form label{
  border-radius:22px !important;
  background:rgba(255,255,255,.03) !important;
  border:1px solid rgba(255,255,255,.06) !important;
  color:rgba(255,255,255,.92) !important;
}

.rsvp-section input,
.rsvp-section select,
.rsvp-section textarea{
  min-height:56px !important;
  border-radius:16px !important;
  background:rgba(255,255,255,.05) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  color:#fff !important;
  box-shadow:none !important;
}

.rsvp-section input:focus,
.rsvp-section select:focus,
.rsvp-section textarea:focus{
  border-color:rgba(255,255,255,.24) !important;
  background:rgba(255,255,255,.07) !important;
  box-shadow:0 0 0 4px rgba(255,255,255,.06) !important;
}

.rsvp-section button{
  min-height:58px !important;
  border-radius:999px !important;
  background:#ffffff !important;
  color:#101010 !important;
  font-size:.8rem !important;
  font-weight:800 !important;
  letter-spacing:.16em !important;
  box-shadow:none !important;
}

.rsvp-section button:hover{
  transform:translate3d(0,-3px,0) !important;
  box-shadow:0 14px 34px rgba(0,0,0,.18) !important;
}

.form-status{
  color:rgba(255,255,255,.72) !important;
}

/* Countdown */
.countdown-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(128,10,28,.14), transparent 30%),
    linear-gradient(180deg,#080808 0%, #101011 100%) !important;
}

.countdown div{
  border-radius:24px !important;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:none !important;
}

.countdown strong{
  color:#fff !important;
}

.countdown span{
  color:rgba(255,255,255,.66) !important;
}

/* Hover / motion — keep layout stable */
.place-card,
.hotel-list a,
.dress-card,
.rsvp-section button,
.lang-btn{
  transition:
    transform .24s ease,
    box-shadow .24s ease,
    background-color .24s ease,
    border-color .24s ease !important;
}

@media (max-width:980px){
  .hotel-list{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}

@media (max-width:560px){
  .section{
    padding-top:42px !important;
    padding-bottom:42px !important;
  }

  .hero h1{
    font-size:clamp(3.5rem, 17vw, 5.5rem) !important;
  }

  .place-card,
  .place-card.reverse{
    min-height:220px !important;
    border-radius:24px !important;
    padding:22px !important;
  }

  .hotel-list,
  .places-grid{
    gap:14px !important;
  }

  .hotel-list a{
    min-height:186px !important;
    border-radius:22px !important;
    padding:20px !important;
  }

  .dress-card{
    border-radius:24px !important;
  }

  .rsvp-section form{
    border-radius:24px !important;
    padding:20px !important;
  }

  .rsvp-section form label{
    border-radius:18px !important;
  }

  .rsvp-section input,
  .rsvp-section select,
  .rsvp-section textarea{
    min-height:50px !important;
    border-radius:14px !important;
  }
}


/* Restore original red tone */
:root{
  --original-red:#5f030d;
  --original-red-dark:#360006;
  --original-red-deep:#150003;
  --original-red-bright:#910617;
}

.page{
  background:
    radial-gradient(circle at 50% 0%, rgba(95,3,13,.44), transparent 34%),
    linear-gradient(180deg,#070000 0%, #5f030d 28%, #360006 58%, #080000 100%) !important;
}

.hero-overlay{
  background:
    linear-gradient(to bottom, rgba(0,0,0,.08), rgba(95,3,13,.20) 38%, rgba(95,3,13,.92)),
    radial-gradient(circle at 50% 78%, rgba(145,6,23,.50), transparent 40%) !important;
}

.calendar-section,
.program-section,
.places-section,
.hotels-section,
.dress-section,
.gifts-section,
.rsvp-section,
.countdown-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(145,6,23,.34), transparent 36%),
    linear-gradient(180deg,#080000 0%, #5f030d 54%, #150003 100%) !important;
}

.calendar-section{
  background:
    linear-gradient(to bottom,#5f030d,#360006 62%,#150003) !important;
}

.hotels-section{
  background:
    radial-gradient(circle at 50% 0%, rgba(145,6,23,.36), transparent 34%),
    linear-gradient(180deg,#080000 0%, #5f030d 50%, #080000 100%) !important;
}

.gifts-section{
  background:
    radial-gradient(circle at 50% 12%, rgba(145,6,23,.58), transparent 44%),
    linear-gradient(180deg,#5f030d,#080000) !important;
}

.place-card,
.place-card.reverse{
  background:
    linear-gradient(160deg, rgba(255,255,255,.12), rgba(255,255,255,.035) 58%),
    radial-gradient(circle at 100% 0%, rgba(145,6,23,.42), transparent 38%),
    linear-gradient(180deg, rgba(95,3,13,.82), rgba(54,0,6,.70)) !important;
}

.place-card span{
  background:#ffffff !important;
  color:#5f030d !important;
}

.hotel-list em,
.rsvp-section button,
form button{
  background:linear-gradient(135deg,#5f030d,#910617) !important;
}

.rsvp-section button,
form button{
  color:#ffffff !important;
}

.lang-btn.active{
  background:#ffffff !important;
  color:#5f030d !important;
}

.calendar-section .calendar .wedding-day::before{
  color:#d81f52 !important;
}

.calendar-section .calendar .wedding-day::after{
  background:radial-gradient(circle, rgba(216,31,82,.36) 0%, rgba(145,6,23,.20) 42%, rgba(145,6,23,0) 72%) !important;
}

.countdown div,
.dress-card,
.rsvp-section form{
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035)),
    radial-gradient(circle at 100% 0%, rgba(145,6,23,.18), transparent 38%) !important;
}


/* Bottom photo slider after countdown */
.bottom-gallery-section{
  width:100%;
  overflow:hidden;
  padding:28px 0 46px;
  background:
    radial-gradient(circle at 50% 0%, rgba(145,6,23,.34), transparent 36%),
    linear-gradient(180deg,#080000 0%, #5f030d 52%, #080000 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
}

.bottom-gallery-track{
  display:flex;
  width:max-content;
  gap:0;
  animation:bottomGalleryMove 34s linear infinite;
  will-change:transform;
  transform:translate3d(0,0,0);
}

.bottom-gallery-group{
  display:flex;
  flex:none;
  gap:18px;
  padding-right:18px;
}

.bottom-gallery-section figure{
  margin:0;
  width:clamp(220px, 28vw, 360px);
  aspect-ratio:3 / 4.35;
  border-radius:28px;
  overflow:hidden;
  background:#120003;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 24px 60px rgba(0,0,0,.28);
}

.bottom-gallery-section img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  transform:translateZ(0);
}

@keyframes bottomGalleryMove{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(-33.333%,0,0)}
}

@media (max-width:560px){
  .bottom-gallery-section{
    padding:22px 0 34px;
    -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 14%, #000 86%, transparent 100%);
    mask-image:linear-gradient(to right, transparent 0%, #000 14%, #000 86%, transparent 100%);
  }

  .bottom-gallery-group{
    gap:12px;
    padding-right:12px;
  }

  .bottom-gallery-section figure{
    width:72vw;
    border-radius:22px;
  }
}

.invite-intro{position:fixed;inset:0;background:#f6f1ea;z-index:999999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:.8s}
.invite-intro.hide{opacity:0;visibility:hidden}
.invite-envelope{width:min(420px,80vw);height:260px;background:#e7d6bb;position:relative;box-shadow:0 20px 50px rgba(0,0,0,.15)}
.invite-envelope:before{content:'';position:absolute;left:0;right:0;top:0;height:55%;background:#dcc7a5;clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top;transition:1s}
.invite-intro.open .invite-envelope:before{transform:rotateX(180deg)}
.invite-seal{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:#b88746;color:#2a1404;display:grid;place-items:center;font-weight:700}
.invite-open-btn{margin-top:30px}
