:root{
  --cream:#F8EFD9;
  --cream-2:#EFE0BD;
  --ivory:#FDF8E8;
  --ink:#2E2C24;
  --ink-soft:#5B5645;
  --sage:#6FA557;
  --sage-dark:#DD3F7B;
  --sage-pale:#BFDDB6;
  --pink:#E27590;
  --pink-pale:#F9C4CA;
  --coral:#E54E47;
  --gold:#D78A1F;
  --gold-soft:#EFB94A;
  --gold-deep:#9C6314;
  --plum:#9C2B5E;
  --rule:rgba(46,44,36,0.28);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Lato',sans-serif;
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.serif{font-family:'Cormorant Garamond',serif}
.italic{font-style:italic}

/* === Top mark === */
.topbar{
  position:absolute;top:0;left:0;right:0;
  z-index:10;
  display:flex;justify-content:space-between;align-items:center;
  padding:28px 48px;
  color:var(--ink);
  font-family:'Cormorant Garamond',serif;
  font-size:14px;
  letter-spacing:0.35em;
  text-transform:uppercase;
}
.topbar .mono{font-weight:500}
.topbar .right{font-style:italic;letter-spacing:0.2em;text-transform:none;font-size:15px}

/* === Hero === */
.hero{
  position:relative;
  min-height:100vh;
  display:grid;
  grid-template-columns:1.15fr 1fr;
  align-items:stretch;
  background:var(--cream);
}
.hero__copy{
  position:relative;
  padding:90px 64px 60px;
  display:flex;flex-direction:column;justify-content:center;
  background:var(--cream);
}
.hero__copy::before{
  content:"";position:absolute;inset:48px;
  border:1px solid var(--rule);
  pointer-events:none;
}
.hero__eyebrow{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:22px;
  color:var(--sage-dark);
  margin-bottom:18px;
  letter-spacing:0.02em;
}
.hero__eyebrow::before, .hero__eyebrow::after{
  content:"";display:inline-block;width:36px;height:1px;
  background:var(--sage-dark);
  vertical-align:middle;margin:0 14px 6px;
}
.hero__title{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(56px, 8.5vw, 132px);
  line-height:0.95;
  letter-spacing:-0.01em;
  color:var(--gold);
  text-shadow:1px 1px 0 rgba(215,138,31,0.22), 2px 2px 0 rgba(215,138,31,0.1);
  margin-bottom:8px;
  position:relative;
  z-index:5;
}
.title-wrap{
  position:relative;
  padding:80px 0 50px;
}
.hero__title .of{
  display:block;
  font-style:italic;
  font-weight:300;
  font-size:0.35em;
  color:var(--gold);
  letter-spacing:0.15em;
  margin:18px 0 6px;
  text-transform:lowercase;
}
.hero__title .name{
  display:block;
  font-family:'Allura', cursive;
  font-weight:400;
  font-style:normal;
  font-size:1.55em;
  line-height:1.05;
  color:#D63469;
  text-shadow:
    0 0 1px rgba(214,52,105,0.6),
    1px 1px 0 rgba(214,52,105,0.32),
    2px 2px 0 rgba(214,52,105,0.18),
    3px 3px 6px rgba(214,52,105,0.15);
  margin-top:-0.05em;
  letter-spacing:0;
  padding-top:0.1em;
  position:relative;
  z-index:6;
}
.hero__title .name-img{
  display:block;
  width:clamp(240px, 60%, 520px);
  height:auto;
  margin:6px 0 0;
  filter:drop-shadow(0 8px 18px rgba(214,52,105,0.20));
  position:relative;
  z-index:6;
}
@media (max-width:980px){
  .hero__title .name-img{margin-left:auto;margin-right:auto;width:clamp(240px, 78%, 480px);}
}
@media (max-width:520px){
  .hero__title .name-img{width:clamp(220px, 88%, 360px);}
}
.hero__meta{
  display:flex;align-items:stretch;gap:28px;
  margin-top:42px;
  padding-top:32px;
  border-top:1px solid var(--rule);
  font-family:'Cormorant Garamond',serif;
}
.hero__meta .col{display:flex;flex-direction:column;justify-content:flex-start}
.hero__meta .lbl{
  font-family:'Lato',sans-serif;font-size:11px;
  letter-spacing:0.3em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:400;margin-bottom:18px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  text-align:center;
  line-height:1.35;
  min-height:3em;
}
.hero__meta .val{
  font-size:22px;font-weight:400;color:var(--ink);
}
.hero__meta .val em{font-style:italic;color:var(--sage-dark)}
.hero__meta .sub{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:13px;
  color:var(--ink-soft);
  margin-top:6px;
  line-height:1.25;
  opacity:0.85;
}
.hero__meta .sep{width:1px;height:42px;background:var(--rule)}

.hero__cta{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:44px;
  padding:18px 36px;
  background:var(--gold);
  border:1px solid var(--gold);
  color:var(--ivory);
  text-decoration:none;
  font-family:'Lato',sans-serif;
  font-size:12px;letter-spacing:0.24em;text-transform:uppercase;
  font-weight:500;
  transition:all .4s ease;
  align-self:flex-start;
  cursor:pointer;
  box-shadow:0 14px 32px -14px rgba(215,138,31,0.55);
}
.hero__cta:hover{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--ivory);box-shadow:0 18px 38px -14px rgba(215,138,31,0.7)}
.hero__cta .arrow{display:inline-block;transition:transform .4s ease}
.hero__cta:hover .arrow{transform:translateX(6px)}

.hero__photo{
  position:relative;
  background:var(--cream-2);
  overflow:hidden;
}
.hero__photo img{
  width:100%;height:100%;object-fit:cover;object-position:center 15%;
  display:block;
  filter:saturate(0.92) contrast(1.02);
}
.hero__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(246,241,231,0.0) 60%,rgba(246,241,231,0.25));
  pointer-events:none;
}
.hero__date-badge{
  position:absolute;
  bottom:32px;left:32px;
  background:var(--ivory);
  padding:20px 30px;
  text-align:center;
  box-shadow:0 30px 80px -30px rgba(61,58,51,0.35);
}
.hero__date-badge .d{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:13px;
  letter-spacing:0.3em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:6px;
}
.hero__date-badge .big{
  font-family:'Cormorant Garamond',serif;
  font-size:54px;line-height:1;color:var(--ink);
}
.hero__date-badge .mo{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:18px;
  letter-spacing:0.15em;
  color:var(--sage-dark);
  margin-top:6px;
  text-transform:lowercase;
}
.hero__year{
  position:absolute;
  top:64px;right:64px;
  writing-mode:vertical-rl;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--ivory);
  font-size:15px;
  letter-spacing:0.5em;
  text-transform:uppercase;
  opacity:0.85;
}

/* Decorative botanical SVG */
.botanical{
  position:absolute;pointer-events:none;
  opacity:0.55;
  color:var(--sage);
}
.botanical svg{display:block;width:100%;height:100%}

/* === Section base === */
section{padding:96px 64px;position:relative}
.section-head{
  text-align:center;margin-bottom:60px;
}
.section-head .kicker{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:18px;
  color:var(--gold);
  letter-spacing:0.15em;
  margin-bottom:14px;
  display:inline-flex;align-items:center;gap:18px;
}
.section-head .kicker::before,
.section-head .kicker::after{
  content:"";width:42px;height:1px;background:var(--gold);
}
.section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:clamp(40px, 5.5vw, 76px);
  color:var(--ink);
  line-height:1;
  letter-spacing:-0.005em;
}
.section-head h2 em{
  font-style:italic;color:var(--sage-dark);
}
.section-head .sub{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:21px;
  color:var(--ink-soft);
  margin-top:18px;
  max-width:540px;margin-left:auto;margin-right:auto;
  line-height:1.4;
}

/* === Programme === */
.programme{
  background:var(--ivory);
  padding:90px 64px;
}
.timeline{
  max-width:760px;margin:0 auto;
  position:relative;
}
.timeline::before{
  content:"";position:absolute;
  left:140px;top:14px;bottom:14px;
  width:1px;background:var(--rule);
}
.tl-item{
  display:grid;
  grid-template-columns:120px 40px 1fr;
  gap:32px;
  padding:24px 0;
  align-items:start;
}
.tl-time{
  font-family:'Cormorant Garamond',serif;
  font-size:30px;font-weight:300;
  color:var(--gold);
  text-align:right;
  line-height:1;
  padding-top:4px;
}
.tl-time .min{font-style:italic;font-size:18px;color:var(--ink-soft);margin-left:2px}
.tl-dot{
  position:relative;
  width:14px;height:14px;
  margin:8px auto 0;
  border-radius:50%;
  background:var(--ivory);
  border:1px solid var(--gold);
}
.tl-dot::after{
  content:"";position:absolute;inset:3px;
  border-radius:50%;
  background:var(--gold);
}
.tl-body h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:30px;color:var(--ink);
  line-height:1.2;margin-bottom:8px;
}
.tl-body h3 em{font-style:italic;color:var(--sage-dark)}
.tl-body p{
  color:var(--ink-soft);
  font-size:15px;
  max-width:380px;
}

/* === Infos pratiques === */
.infos{
  background:var(--cream);
  position:relative;
  overflow:hidden;
}
.infos-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1px;
  background:var(--rule);
  max-width:800px;margin:0 auto;
  border:1px solid var(--rule);
}
.info-card{
  background:var(--cream);
  padding:56px 36px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.info-card .icon{
  width:42px;height:42px;
  margin-bottom:22px;
  color:var(--sage-dark);
}
.info-card .icon svg{width:100%;height:100%;display:block;stroke:currentColor;fill:none;stroke-width:1.2}
.info-card .lbl{
  font-family:'Lato',sans-serif;
  font-size:10px;letter-spacing:0.35em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:16px;
}
.info-card .val{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;
  color:var(--ink);
  line-height:1.4;
}
.info-card .val em{font-style:italic;color:var(--sage-dark)}
.info-card .val .small{display:block;font-size:15px;color:var(--ink-soft);margin-top:4px;font-style:italic}

@media (max-width:480px){.infos-grid{grid-template-columns:1fr}}

/* === RSVP === */
.rsvp{
  background:linear-gradient(180deg,var(--ivory) 0%,var(--cream-2) 100%);
  position:relative;
  overflow:hidden;
}
.rsvp-wrap{
  max-width:680px;margin:0 auto;
  position:relative;
  padding:72px 56px;
  background:var(--ivory);
  box-shadow:0 60px 120px -60px rgba(61,58,51,0.25);
}
.rsvp-wrap::before{
  content:"";position:absolute;inset:14px;
  border:1px solid var(--rule);
  pointer-events:none;
}
.rsvp-form{display:flex;flex-direction:column;gap:28px;position:relative;z-index:1}
.field{display:flex;flex-direction:column;gap:8px}
.field label{
  font-family:'Lato',sans-serif;
  font-size:10px;letter-spacing:0.35em;text-transform:uppercase;
  color:var(--ink-soft);
}
.field input, .field select, .field textarea{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:400;
  color:var(--ink);
  background:transparent;
  border:none;border-bottom:1px solid var(--rule);
  padding:10px 0 12px;
  outline:none;
  transition:border-color .3s ease;
  appearance:none;
  border-radius:0;
}
.field input:focus, .field select:focus, .field textarea:focus{
  border-bottom-color:var(--gold);
}
.field input::placeholder, .field textarea::placeholder{
  color:var(--ink-soft);font-style:italic;opacity:0.7;
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.field select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23B89764' stroke-width='1'/></svg>");
  background-repeat:no-repeat;
  background-position:right 4px center;
  padding-right:24px;
}
.attend-toggle{display:flex;gap:0;border:1px solid var(--rule)}
.attend-toggle label{
  flex:1;
  text-align:center;
  padding:18px 14px;
  cursor:pointer;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:19px;color:var(--ink-soft);
  border-right:1px solid var(--rule);
  transition:all .3s ease;
  background:transparent;
  letter-spacing:0;
  text-transform:none;
}
.attend-toggle label:last-child{border-right:none}
.attend-toggle input{display:none}
.attend-toggle input:checked + label,
.attend-toggle label.is-on{
  background:var(--sage-pale);
  color:var(--sage-dark);
}
.submit{
  margin-top:18px;
  align-self:center;
  background:var(--gold);
  color:var(--ivory);
  border:1px solid var(--gold);
  padding:18px 56px;
  font-family:'Lato',sans-serif;
  font-size:11px;letter-spacing:0.35em;text-transform:uppercase;
  font-weight:400;
  cursor:pointer;
  transition:all .35s ease;
  display:inline-flex;align-items:center;gap:14px;
}
.submit:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
.submit.sent{background:var(--sage);border-color:var(--sage)}
.rsvp-deadline{
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--ink-soft);
  margin-top:36px;
  font-size:16px;
}
.rsvp-deadline .gold{color:var(--gold)}
.thanks{
  text-align:center;
  padding:32px 0 16px;
  font-family:'Cormorant Garamond',serif;
  color:var(--sage-dark);
}
.thanks .big{font-size:34px;font-style:italic;line-height:1.1;display:block;margin-bottom:10px}
.thanks .sm{font-size:15px;color:var(--ink-soft);font-style:normal}

/* === Footer === */
footer{
  background-color:#F8E7C7;
  background-image:url('/pictos/fabric.jpg');
  background-repeat:repeat;
  background-size:480px auto;
  background-blend-mode:multiply;
  color:var(--ink-soft);
  text-align:center;
  padding:42px 32px 36px;
  position:relative;
  border-top:1px solid rgba(215,138,31,0.25);
}
.footer-logo{
  display:block;
  margin:0 auto 28px;
  width:280px;
  max-width:80%;
  text-decoration:none;
  transition:transform .4s ease;
}
.footer-logo img{
  width:100%;height:auto;display:block;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,0.35));
}
.footer-logo:hover{transform:translateY(-3px) scale(1.04)}

footer .fine a{
  color:var(--gold-deep);
  text-decoration:none;
  border-bottom:1px solid rgba(156,99,20,0.45);
  transition:border-color .3s ease, color .3s ease;
}
footer .fine a:hover{
  color:var(--gold);
  border-bottom-color:var(--gold);
}
footer .name{
  font-family:'Cormorant Garamond',serif;
  font-size:38px;font-weight:300;letter-spacing:0.05em;
}
footer .name em{font-style:italic;color:var(--gold-soft)}
footer .when{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:rgba(246,241,231,0.7);
  margin:14px 0 40px;
  font-size:18px;
}
footer .rule{width:60px;height:1px;background:var(--gold-soft);margin:0 auto 32px;opacity:0.5}
footer .fine{
  font-family:'Lato',sans-serif;
  font-size:10px;letter-spacing:0.4em;
  text-transform:uppercase;
  color:var(--ink-soft);
}

/* botanicals positioning */
.bot-1{top:-40px;left:-40px;width:280px;height:280px;transform:rotate(-15deg)}
.bot-2{bottom:-30px;right:-30px;width:260px;height:260px;transform:rotate(140deg)}
.bot-3{top:80px;right:48px;width:200px;height:200px;opacity:0.35}
.bot-4{bottom:60px;left:48px;width:200px;height:200px;opacity:0.35;transform:scaleX(-1) rotate(20deg)}

/* responsive */
@media (max-width:980px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__copy{padding:100px 36px 60px;order:2;text-align:center;align-items:center}
  .hero__copy::before{inset:24px}
  .hero__photo{order:1;min-height:520px}
  .hero__date-badge{left:50%;transform:translateX(-50%);bottom:24px}
  .hero__year{display:none}
  .topbar{padding:24px 28px;font-size:11px}
  .topbar .right{font-size:13px}
  section{padding:64px 28px}
  .programme{padding:64px 24px}
  .timeline::before{left:80px}
  .tl-item{grid-template-columns:64px 28px 1fr;gap:18px}
  .tl-time{font-size:22px}
  .tl-body h3{font-size:24px}
  .rsvp-wrap{padding:48px 28px}
  .field-row{grid-template-columns:1fr}
  .hero__meta{
    display:flex;
    flex-direction:row;
    align-items:stretch;
    justify-content:center;
    gap:0;
    width:100%;
  }
  .hero__meta .col{
    flex:1 1 0;
    min-width:0;
    align-items:center;
    text-align:center;
    padding:0 6px;
    border-left:1px solid var(--rule);
    justify-content:flex-start;
  }
  .hero__meta .col:first-child{border-left:none}
  .hero__meta .sep{display:none}
  .hero__cta{align-self:center;justify-content:center}
  .title-wrap{width:100%}
}

/* ============== ANIMATIONS ============== */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes zoomIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(214,162,74,0.25);transform:scale(1)}
  50%{box-shadow:0 0 0 8px rgba(214,162,74,0);transform:scale(1.15)}
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
@keyframes sway{
  0%,100%{transform:rotate(var(--rot,0deg))}
  50%{transform:rotate(calc(var(--rot,0deg) + 4deg))}
}
@keyframes kenburns{
  0%{transform:scale(1) translate(0,0)}
  100%{transform:scale(1.08) translate(-1%,-1%)}
}
@keyframes shimmer{
  0%{background-position:-200% 0}
  100%{background-position:200% 0}
}
@keyframes petalFall{
  0%{transform:translate(0,-20px) rotate(0deg);opacity:0}
  8%{opacity:0.6}
  100%{transform:translate(var(--dx,30px), 110vh) rotate(360deg);opacity:0}
}
@keyframes riseUp{
  from{opacity:0;transform:translateY(40px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes riseUpSmall{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes slideInLeft{
  from{opacity:0;transform:translateX(-40px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes drawLine{
  from{transform:scaleY(0);transform-origin:top}
  to{transform:scaleY(1);transform-origin:top}
}

/* Hero entrance — staggered */
.hero__eyebrow{opacity:0;animation:riseUpSmall .8s ease both .2s}
.hero__title{opacity:0;animation:riseUp 1.1s cubic-bezier(.2,.7,.2,1) both .35s}
.hero__meta{opacity:0;animation:riseUpSmall .8s ease both .9s}
.hero__cta{opacity:0;animation:riseUpSmall .8s ease both 1.1s}
.hero__photo img{animation:kenburns 14s ease-in-out infinite alternate}
.hero__date-badge{animation:riseUp 1s ease both 1.3s, float 5s ease-in-out infinite 2.3s}
.hero__year{opacity:0;animation:fadeIn 1s ease both 1.5s}

/* Botanicals sway */
.bot-1{--rot:-15deg;animation:sway 7s ease-in-out infinite}
.bot-2{--rot:140deg;animation:sway 8s ease-in-out infinite .8s}
.bot-3{--rot:0deg;animation:sway 6s ease-in-out infinite .4s}
.bot-4{--rot:20deg;animation:sway 7.5s ease-in-out infinite 1.2s}

/* CTA shimmer on hover */
.hero__cta{position:relative;overflow:hidden}
.hero__cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.4) 50%, transparent 70%);
  background-size:200% 100%;
  background-position:200% 0;
  pointer-events:none;
}
.hero__cta:hover::before{animation:shimmer 1.2s ease}

/* Scroll-reveal */
.section-head{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1)}
.section-head.is-in{opacity:1;transform:translateY(0)}

.tl-item{opacity:0;transform:translateX(-30px);transition:opacity .8s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.tl-item.is-in{opacity:1;transform:translateX(0)}

.info-card{opacity:0;transform:translateY(24px)}
.info-card.is-in{opacity:1;transform:translateY(0);transition:opacity .8s ease, transform .9s cubic-bezier(.2,.7,.2,1), background .3s ease}
.infos-grid.is-in .info-card:nth-child(1){transition-delay:.05s}
.infos-grid.is-in .info-card:nth-child(2){transition-delay:.18s}
.infos-grid.is-in .info-card:nth-child(3){transition-delay:.31s}
.infos-grid.is-in .info-card:nth-child(4){transition-delay:.44s}

.timeline.is-in .tl-item:nth-child(1){transition-delay:.05s}
.timeline.is-in .tl-item:nth-child(2){transition-delay:.16s}
.timeline.is-in .tl-item:nth-child(3){transition-delay:.27s}
.timeline.is-in .tl-item:nth-child(4){transition-delay:.38s}
.timeline.is-in .tl-item:nth-child(5){transition-delay:.49s}
.timeline.is-in .tl-item:nth-child(6){transition-delay:.60s}

.rsvp-wrap{opacity:0;transform:translateY(30px);transition:opacity 1s ease, transform 1.1s cubic-bezier(.2,.7,.2,1)}
.rsvp-wrap.is-in{opacity:1;transform:translateY(0)}

.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* Timeline dot pulse */
.tl-dot{transition:transform .4s ease}
.tl-item:hover .tl-dot{transform:scale(1.3)}
.tl-item:hover .tl-dot::after{background:var(--coral)}

/* Info card hover lift */
.info-card{transition:background .3s ease, transform .3s ease}
.info-card:hover{background:var(--ivory);transform:translateY(-4px)}
.info-card:hover .icon{color:var(--coral);transform:scale(1.1);transition:color .3s ease, transform .3s ease}
.info-card .icon{transition:color .3s ease, transform .3s ease}

/* Submit button shimmer + bounce */
.submit{position:relative;overflow:hidden}
.submit::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg, transparent 35%, rgba(255,255,255,0.45) 50%, transparent 65%);
  background-size:200% 100%;
  background-position:200% 0;
  pointer-events:none;
}
.submit:hover::before{animation:shimmer 1.4s ease}
.submit:hover{transform:translateY(-2px)}
.submit:active{transform:translateY(0)}

/* Floating petals on page */
.petal{
  position:fixed;
  top:-20px;
  width:14px;height:14px;
  pointer-events:none;
  z-index:5;
  will-change:transform,opacity;
}
.petal svg{width:100%;height:100%;display:block}

.footer-logo{animation:float 6s ease-in-out infinite}

.section-head .kicker, .section-head h2, .section-head .sub{
  display:block;
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .petal{display:none}
}

/* ============== INVITATION PICTOGRAMS ============== */
.picto{
  position:absolute;
  pointer-events:none;
  display:block;
  z-index:3;
}
.picto svg{width:100%;height:100%;display:block;overflow:visible}
.pic-layer{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:2;
}
@keyframes wobble{
  0%,100%{transform:rotate(var(--rot,0deg)) translateY(0)}
  50%{transform:rotate(calc(var(--rot,0deg) + 3deg)) translateY(-4px)}
}
@keyframes twinkle{
  0%,100%{opacity:0.5;transform:scale(1)}
  50%{opacity:1;transform:scale(1.15)}
}
@keyframes heartbeat{
  0%,100%{transform:scale(1)}
  15%{transform:scale(1.18)}
  30%{transform:scale(1)}
  45%{transform:scale(1.12)}
  60%{transform:scale(1)}
}
@keyframes spin-slow{
  from{transform:rotate(0deg)}to{transform:rotate(360deg)}
}
.pc-smiley{animation:wobble 4s ease-in-out infinite}
.pc-heart-arrow{animation:heartbeat 3.5s ease-in-out infinite}
.pc-magen{animation:wobble 6s ease-in-out infinite .5s}
.pc-heart-sm{animation:heartbeat 2.5s ease-in-out infinite}
.pc-sun > svg > g{animation:spin-slow 30s linear infinite;transform-origin:center}
.pc-sun{animation:spin-slow 60s linear infinite}
.pc-star{animation:twinkle 2.4s ease-in-out infinite}
.pc-flower{animation:wobble 5s ease-in-out infinite}

/* ============== SLIDER ============== */
.slider-section{
  background:linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
  padding:96px 64px;
  position:relative;
  overflow:hidden;
}
.slider-section::before, .slider-section::after{
  content:"";position:absolute;
  width:400px;height:400px;
  border-radius:50%;
  filter:blur(100px);
  opacity:0.35;
  pointer-events:none;
}
.slider-section::before{background:var(--pink-pale);top:-120px;left:-120px}
.slider-section::after{background:var(--sage-pale);bottom:-120px;right:-120px}

.slider{
  position:relative;
  max-width:1100px;
  margin:0 auto;
  aspect-ratio:16/10;
  overflow:hidden;
  box-shadow:0 40px 90px -40px rgba(52,50,42,0.4);
  background:var(--cream-2);
}
.slides{
  position:absolute;inset:0;
  display:flex;
  transition:transform 1s cubic-bezier(.6,.0,.2,1);
  will-change:transform;
}
.slide{
  flex:0 0 100%;
  height:100%;
  position:relative;
  overflow:hidden;
}
.slide img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  animation:kenburns 12s ease-in-out infinite alternate;
}
.slide::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(34,32,26,0.55));
  pointer-events:none;
}
.slide-caption{
  position:absolute;
  bottom:42px;left:48px;
  color:var(--ivory);
  z-index:2;
  pointer-events:none;
}
.slide-caption .num{
  font-family:'Lato',sans-serif;
  font-size:11px;letter-spacing:0.4em;text-transform:uppercase;
  opacity:0.7;margin-bottom:8px;display:block;
}
.slide-caption .ttl{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:42px;line-height:1;
  color:var(--gold-soft);
}

.slider-controls{
  position:absolute;
  bottom:36px;right:48px;
  display:flex;align-items:center;gap:16px;
  z-index:3;
}
.slider-btn{
  width:46px;height:46px;
  border:1px solid rgba(255,255,255,0.6);
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(6px);
  color:var(--ivory);
  border-radius:50%;
  cursor:pointer;
  font-family:'Cormorant Garamond',serif;
  font-size:20px;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s ease;
}
.slider-btn:hover{background:var(--gold);border-color:var(--gold)}
.slider-dots{
  position:absolute;
  bottom:44px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;
  z-index:3;
}
.slider-dots button{
  width:8px;height:8px;
  border-radius:50%;
  background:rgba(255,255,255,0.4);
  border:none;
  padding:0;
  cursor:pointer;
  transition:all .3s ease;
}
.slider-dots button.is-on{
  width:28px;
  border-radius:4px;
  background:var(--gold-soft);
}

/* ============== SCRAPBOOK / POLAROIDS ============== */
.scrapbook{
  padding:70px 32px;
  position:relative;
  background:var(--cream);
  overflow:hidden;
}
.scrapbook .scrap-head{
  text-align:center;
  margin-bottom:54px;
}
.scrap-head .kicker{
  font-family:'Caveat', cursive;
  font-size:28px;
  color:var(--coral);
  display:block;
  margin-bottom:8px;
  transform:rotate(-2deg);
}
.scrap-head h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:clamp(36px, 5vw, 60px);
  color:var(--ink);
  line-height:1;
}
.scrap-head h3 em{font-style:italic;color:var(--sage-dark)}

.polaroids{
  position:relative;
  max-width:1200px;margin:0 auto;
  display:flex;flex-wrap:wrap;
  justify-content:center;
  gap:32px 28px;
  align-items:flex-start;
}
.polaroid{
  background:#fff;
  padding:12px 12px 50px;
  box-shadow:0 18px 40px -16px rgba(52,50,42,0.45), 0 2px 6px rgba(52,50,42,0.15);
  transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s ease;
  will-change:transform;
  cursor:zoom-in;
  position:relative;
}
.polaroid img{
  width:240px;height:300px;
  object-fit:cover;
  display:block;
  background:var(--cream-2);
}
.polaroid .cap{
  position:absolute;
  bottom:14px;left:0;right:0;
  text-align:center;
  font-family:'Caveat', cursive;
  font-size:24px;
  color:var(--ink-soft);
}
.polaroid:nth-child(1){transform:rotate(-4deg) translateY(0)}
.polaroid:nth-child(2){transform:rotate(3deg) translateY(28px)}
.polaroid:nth-child(3){transform:rotate(-2deg) translateY(-16px)}
.polaroid:nth-child(4){transform:rotate(5deg) translateY(20px)}
.polaroid:nth-child(5){transform:rotate(-3deg) translateY(-8px)}
.polaroid:hover{
  transform:rotate(0deg) translateY(-6px) scale(1.05);
  z-index:5;
  box-shadow:0 30px 60px -20px rgba(52,50,42,0.5);
}
.polaroid::before{
  content:"";position:absolute;
  top:-10px;left:50%;transform:translateX(-50%) rotate(-2deg);
  width:80px;height:22px;
  background:rgba(214,162,74,0.35);
  border-left:1px dashed rgba(184,134,47,0.4);
  border-right:1px dashed rgba(184,134,47,0.4);
}
.polaroid:nth-child(even)::before{
  background:rgba(232,154,146,0.35);
  transform:translateX(-50%) rotate(3deg);
}

/* Floating accent photos */
.float-photo{
  position:absolute;
  pointer-events:auto;
  z-index:3;
  background:#fff;
  padding:8px 8px 10px;
  box-shadow:0 14px 30px -12px rgba(52,50,42,0.4);
  cursor:zoom-in;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.float-photo img{
  width:130px;height:170px;
  object-fit:cover;
  display:block;
}
.float-photo .cap{
  position:absolute;
  bottom:8px;left:0;right:0;
  text-align:center;
  font-family:'Caveat', cursive;
  font-size:18px;
  color:var(--ink-soft);
}
.float-photo:hover{transform:rotate(0deg) scale(1.06)}

@media (max-width:880px){
  .slider-section{padding:80px 24px}
  .slide-caption{bottom:28px;left:24px}
  .slide-caption .ttl{font-size:28px}
  .slider-controls{bottom:24px;right:24px;gap:10px}
  .slider-btn{width:38px;height:38px}
  .slider-dots{bottom:28px}
  .scrapbook{padding:54px 20px}
  .polaroids{gap:24px 16px}
  .polaroid img{width:170px;height:215px}
  .float-photo{display:none}
}

/* ============== WIZARD FORM ============== */
.rsvp-wizard{display:flex;flex-direction:column;gap:20px;position:relative;min-height:340px}
.steps{
  display:flex;justify-content:center;gap:10px;
  margin-bottom:6px;
}
.steps .step{
  width:10px;height:10px;
  border-radius:50%;
  background:rgba(214,162,74,0.25);
  transition:all .4s ease;
}
.steps .step.is-on{
  width:36px;border-radius:5px;background:var(--gold);
}
.steps .step.is-done{background:var(--sage);width:10px;border-radius:50%}
.step-panel{
  display:none;
  flex-direction:column;gap:20px;
  animation:fadeIn .45s ease both;
}
.step-panel.is-active{display:flex}
.step-title{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:30px;
  color:var(--ink);
  text-align:center;
  line-height:1.2;
  margin-bottom:8px;
}
.step-title em{font-style:italic;color:var(--sage-dark)}
.step-actions{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:14px;gap:14px;
}
.next-btn, .prev-btn{
  font-family:'Lato',sans-serif;
  font-size:11px;letter-spacing:0.3em;text-transform:uppercase;
  padding:14px 28px;
  cursor:pointer;
  transition:all .3s ease;
  background:transparent;
}
.next-btn{
  background:var(--gold);color:var(--ivory);border:1px solid var(--gold);
  margin:0 auto;
}
.next-btn:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
.prev-btn{
  color:var(--ink-soft);border:1px solid var(--rule);
}
.prev-btn:hover{color:var(--ink);border-color:var(--ink-soft)}

/* Attendance choice */
.att-choice{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.att-btn{
  border:1px solid var(--rule);
  background:transparent;
  padding:26px 16px;
  cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  text-align:center;
  transition:all .3s ease;
  font-family:'Cormorant Garamond',serif;
}
.att-btn .icn{
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  margin-bottom:10px;
}
.att-btn .icn svg{width:100%;height:100%;display:block;overflow:visible}
.att-btn .lbl-big{
  font-size:22px;font-style:italic;color:var(--ink);line-height:1.15;
  white-space:nowrap;
}
.att-btn .lbl-sm{
  font-family:'Lato',sans-serif;
  font-size:10px;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--ink-soft);
  white-space:nowrap;
}
.att-btn.is-on{
  background:var(--sage-pale);border-color:var(--sage);
}
.att-btn.is-on .lbl-big{color:var(--sage-dark)}

/* Counters */
.counters{display:flex;flex-direction:column;gap:22px;margin-top:8px}
.counter{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
  border:1px solid var(--rule);
  transition:border-color .3s ease;
}
.counter:hover{border-color:var(--gold)}
.counter-info{display:flex;flex-direction:column;gap:2px}
.counter-label{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;color:var(--ink);font-style:italic;
}
.counter-sub{
  font-family:'Lato',sans-serif;
  font-size:10px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--ink-soft);
}
.counter-ctl{
  display:flex;align-items:center;gap:14px;
}
.counter-ctl button{
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid var(--rule);
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  font-family:'Cormorant Garamond',serif;
  font-size:22px;line-height:1;
  transition:all .25s ease;
  display:flex;align-items:center;justify-content:center;
}
.counter-ctl button:hover{
  background:var(--gold);color:var(--ivory);border-color:var(--gold);
  transform:scale(1.08);
}
.counter-ctl button:disabled{
  opacity:0.35;cursor:not-allowed;
}
.counter-ctl button:disabled:hover{
  background:transparent;color:var(--ink);border-color:var(--rule);transform:none;
}
.counter-val{
  font-family:'Cormorant Garamond',serif;
  font-size:30px;color:var(--ink);
  min-width:36px;text-align:center;
}

/* ============== SECTION PICTOS ============== */
.sec-picto{
  position:absolute;
  pointer-events:none;
  display:block;
  z-index:2;
}
.sec-picto svg{width:100%;height:100%;display:block;overflow:visible}

.rsvp, .infos, .programme, .scrapbook, footer{position:relative}

@media (max-width:880px){
  .att-choice{grid-template-columns:1fr}
  .step-title{font-size:24px}
}
.float-info-1, .float-info-2, .float-info-3, .float-info-4,
.float-rsvp-1, .float-rsvp-2{z-index:2}
.float-info-1 img, .float-info-2 img, .float-info-3 img, .float-info-4 img,
.float-rsvp-1 img, .float-rsvp-2 img{width:120px;height:155px}

/* Tablet — shrink */
@media (max-width:1100px){
  .float-info-1 img, .float-info-2 img, .float-info-3 img, .float-info-4 img,
  .float-rsvp-1 img, .float-rsvp-2 img{width:95px;height:120px}
}

/* Mobile — much smaller, repositioned to extreme corners of each section */
@media (max-width:760px){
  .float-info-1 img, .float-info-2 img, .float-info-3 img, .float-info-4 img,
  .float-rsvp-1 img, .float-rsvp-2 img{width:74px;height:94px}
  .float-photo{padding:6px 6px 8px;box-shadow:0 8px 16px -8px rgba(52,50,42,0.4)}
  .float-info-1{top:22px !important;left:4px !important}
  .float-info-2{top:22px !important;right:4px !important}
  .float-info-3{bottom:36px !important;left:4px !important}
  .float-info-4{bottom:56px !important;right:4px !important}
  .float-rsvp-1{top:28px !important;right:4px !important}
  .float-rsvp-2{bottom:32px !important;left:4px !important}
}

/* Very small phones — thin out to 2 per section to avoid clutter */
@media (max-width:420px){
  .float-info-3, .float-rsvp-2{display:none}
  .float-info-1 img, .float-info-2 img, .float-info-4 img,
  .float-rsvp-1 img{width:64px;height:82px}
}

/* Pictogram <img> rendering — embroidered look */
.picto img, .sec-picto img{
  width:100%;height:100%;display:block;
  object-fit:contain;
}

/* Fabric texture — "cousu" canvas background */
body{
  background:var(--cream);
  background-image:url('/pictos/fabric.jpg');
  background-repeat:repeat;
  background-size:480px auto;
  background-blend-mode:multiply;
}
.hero{background:transparent}
.hero__copy{background:transparent}
.gallery, .slider-section, .programme, .scrapbook, .infos, .rsvp{
  background-image:url('/pictos/fabric.jpg');
  background-repeat:repeat;
  background-size:480px auto;
  background-blend-mode:multiply;
  position:relative;
}
/* Color rhythm — tinted backgrounds with the canvas overlay */
.slider-section{ background-color:#FAEFD2 !important }
.scrapbook:nth-of-type(odd){ background-color:#FCE8DF !important }
.scrapbook:nth-of-type(even){ background-color:#E8F0D8 !important }
.programme{ background-color:#F8E7C7 !important }
.infos{ background-color:#FBE9D3 !important }
.rsvp{ background-color:#FAD9CC !important }
.rsvp-wrap{background:var(--ivory)}

/* Single-source pictogram backgrounds */
.pc-heart-arrow{ background-image:url('/pictos/heart-arrow.png'); }
.pc-magen{ background-image:url('/pictos/magen.png'); }
.pc-smiley{ background-image:url('/pictos/smiley.png'); }
.pc-flower{ background-image:url('/pictos/flowers.png'); }
.pc-sun{ background-image:url('/pictos/sun.png'); }
.pc-star{ background-image:url('/pictos/star.png'); }

.pc-heart-arrow, .pc-magen, .pc-smiley, .pc-flower, .pc-sun, .pc-star{
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}
.picto > img, .sec-picto > img{ display:none }

/* ============== CLOTHESLINE — "Quelques premières fois" ============== */
/* Photos hung on a jute rope with little wooden clothespins.
   Rope is built per-photo so it stays continuous on each wrapped row,
   which keeps it clean in the 2-per-row mobile layout. */
.scrapbook--rope .polaroids{ padding-top:38px; }
.scrapbook--rope .polaroid{ margin-top:14px; }

/* gentler tilt + flat baseline so the rope reads continuous */
.scrapbook--rope .polaroid:nth-child(1){ transform:rotate(-2deg) translateY(0); }
.scrapbook--rope .polaroid:nth-child(2){ transform:rotate(1.6deg) translateY(0); }
.scrapbook--rope .polaroid:nth-child(3){ transform:rotate(-1.6deg) translateY(0); }
.scrapbook--rope .polaroid:nth-child(4){ transform:rotate(2deg) translateY(0); }
.scrapbook--rope .polaroid:nth-child(5){ transform:rotate(-1.4deg) translateY(0); }

/* Rope segment (twisted jute) — extends past each photo to meet neighbours */
.scrapbook--rope .polaroid::before,
.scrapbook--rope .polaroid:nth-child(even)::before{
  content:"";
  position:absolute;
  top:-19px;
  left:-18px; right:-18px;
  width:auto;
  height:3px;
  background:repeating-linear-gradient(90deg, #C9A877 0 5px, #AE8A55 5px 10px);
  border:none;
  border-radius:2px;
  box-shadow:0 1px 1px rgba(0,0,0,0.2);
  transform:none;
  z-index:0;
}

/* Wooden clothespin clipping the photo to the rope */
.scrapbook--rope .polaroid::after{
  content:"";
  position:absolute;
  top:-27px;
  left:50%;
  transform:translateX(-50%);
  width:11px; height:25px;
  border-radius:3px;
  background:
    linear-gradient(90deg, transparent 44%, rgba(120,80,30,0.42) 44%, rgba(120,80,30,0.42) 56%, transparent 56%),
    linear-gradient(180deg, #E3C48C 0%, #C79E61 100%);
  box-shadow:0 1px 2px rgba(0,0,0,0.3), inset -1px 0 0 rgba(255,255,255,0.3), inset 0 0 0 0.5px rgba(120,80,30,0.25);
  z-index:4;
}

@media (max-width:520px){
  .scrapbook--rope .polaroids{ padding-top:32px; }
  .scrapbook--rope .polaroid::before,
  .scrapbook--rope .polaroid:nth-child(even)::before{ top:-16px; left:-14px; right:-14px; }
  .scrapbook--rope .polaroid::after{ top:-23px; width:10px; height:22px; }
}

/* ============== INTRO SPLASH ============== */
.intro{
  position:fixed;inset:0;z-index:2000;
  display:flex;align-items:center;justify-content:center;
  background-color:var(--cream);
  background-image:url('/pictos/fabric.jpg');
  background-repeat:repeat;
  background-size:480px auto;
  background-blend-mode:multiply;
  transition:opacity .7s ease, visibility .7s ease;
}
.intro.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.intro__inner{
  display:flex;flex-direction:column;align-items:center;gap:18px;
  padding:24px;
  text-align:center;
}
.intro__logo{
  width:min(74vw, 440px);
  height:auto;display:block;
  filter:drop-shadow(0 12px 34px rgba(221,63,123,0.16));
  animation:introReveal 1.7s cubic-bezier(.2,.7,.2,1) both;
}
.intro__date{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:clamp(15px,4vw,20px);
  letter-spacing:0.18em;
  color:var(--gold);
  text-transform:uppercase;
  opacity:0;
  animation:fadeIn .9s ease both 1s;
}
@keyframes introReveal{
  0%{opacity:0;clip-path:inset(0 100% 0 0);transform:translateY(10px) scale(.96)}
  55%{opacity:1}
  100%{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0) scale(1)}
}

/* ============== PRACTICAL ACTION BUTTONS ============== */
.infos-actions{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px;
  max-width:1000px;margin:50px auto 0;
  position:relative;z-index:1;
}
.info-action{
  display:inline-flex;align-items:center;gap:11px;
  padding:15px 26px;
  border:1px solid var(--gold);
  color:var(--gold-deep);
  background:var(--ivory);
  font-family:'Lato',sans-serif;
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  text-decoration:none;
  transition:all .3s ease;
  cursor:pointer;
}
.info-action svg{width:19px;height:19px;flex:none}
.info-action:hover{background:var(--gold);color:var(--ivory);transform:translateY(-2px)}
.info-action--wa{border-color:#1FAE54;color:#168a42}
.info-action--wa:hover{background:#25D366;color:#fff;border-color:#25D366}
@media (max-width:600px){
  .infos-actions{flex-direction:column;align-items:stretch;gap:12px;margin-top:38px}
  .info-action{justify-content:center;font-size:12px;padding:17px 20px;letter-spacing:0.16em}
}

/* ============== CONFETTI BURST ============== */
.confetti{
  position:fixed;
  z-index:1500;
  pointer-events:none;
  will-change:transform,opacity;
}
.confetti svg{width:100%;height:100%;display:block}
@keyframes confettiBurst{
  0%{transform:translate(0,0) rotate(0deg) scale(.4);opacity:0}
  12%{opacity:1;transform:translate(calc(var(--dx)*.28), calc(var(--dy)*.28)) rotate(calc(var(--rot)*.28)) scale(1)}
  100%{transform:translate(var(--dx), var(--dy)) rotate(var(--rot)) scale(.85);opacity:0}
}

@media (prefers-reduced-motion: reduce){
  .intro__logo, .intro__date{animation:none}
  .confetti{display:none}
}

/* ============== MOBILE TABLET (≤760px) ============== */
@media (max-width:760px){
  body{font-size:15px}
  section{padding:56px 22px}

  /* Hero */
  .topbar{padding:20px 22px;font-size:10px;letter-spacing:0.25em}
  .topbar .right{font-size:12px}
  .hero__copy{padding:84px 26px 56px}
  .hero__copy::before{inset:16px}
  .hero__photo{min-height:440px}
  .hero__eyebrow{font-size:18px;margin-bottom:14px}
  .hero__eyebrow::before, .hero__eyebrow::after{width:22px;margin:0 10px 5px}
  .title-wrap{padding:60px 0 44px}
  .hero__title{font-size:clamp(48px, 14vw, 84px)}
  .hero__title .of{font-size:0.32em;margin:10px 0 4px}
  .hero__title .name{font-size:1.5em}
  .hero__meta{margin-top:32px;padding-top:26px;gap:0}
  .hero__meta .val{font-size:17px;line-height:1.25}
  .hero__meta .val em{display:inline-block}
  .hero__meta .lbl{font-size:10px;letter-spacing:0.18em;margin-bottom:14px;line-height:1.15}
  .hero__meta .sub{font-size:11px;margin-top:5px;line-height:1.2}
  .hero__meta .col{padding:6px 5px}
  .hero__cta{
    margin-top:32px;
    padding:18px 26px;
    font-size:13px;
    letter-spacing:0.14em;
    font-weight:400;
    background:var(--gold);
    color:var(--ivory);
    width:100%;
    max-width:340px;
    align-self:center;
    justify-content:center;
  }
  .hero__cta:hover{background:var(--gold-soft);color:var(--ivory);border-color:var(--gold-soft)}
  .hero__date-badge{padding:14px 22px;bottom:20px}
  .hero__date-badge .big{font-size:44px}
  .hero__date-badge .d{font-size:11px}
  .hero__date-badge .mo{font-size:16px}
  .botanical{display:none}

  /* Hero pictograms — rescale + reposition for narrow title (override inline styles) */
  .title-wrap .pc-smiley{width:38px !important;height:38px !important;top:6px !important;left:30% !important}
  .title-wrap .pc-heart-arrow{width:80px !important;height:60px !important;margin-left:-34px !important;top:24px !important}
  .title-wrap .pc-magen{width:54px !important;height:54px !important;top:-4px !important;right:8% !important}
  .title-wrap .pc-sun{width:50px !important;height:50px !important;top:120px !important;right:-6px !important}
  .title-wrap .pc-flower{width:64px !important;height:46px !important}
  .title-wrap .pc-heart-sm{width:18px !important;height:18px !important}
  .title-wrap .pc-star{width:9px !important;height:9px !important}

  /* Section heads */
  .section-head{margin-bottom:40px}
  .section-head .kicker{font-size:15px;letter-spacing:0.12em}
  .section-head .kicker::before, .section-head .kicker::after{width:26px}
  .section-head h2{font-size:clamp(34px, 8vw, 52px)}
  .section-head .sub{font-size:17px;margin-top:14px;padding:0 6px}

  /* Slider */
  .slider-section{padding:64px 18px}
  .slider{aspect-ratio:4/5;max-width:100%}
  .slide-caption{bottom:90px;left:22px;right:22px}
  .slide-caption .num{font-size:10px;letter-spacing:0.3em;margin-bottom:6px}
  .slide-caption .ttl{font-size:26px;line-height:1.05}
  .slider-controls{bottom:22px;right:50%;transform:translateX(50%);gap:36px}
  .slider-btn{width:38px;height:38px;font-size:18px}
  .slider-dots{bottom:74px;gap:6px}
  .slider-dots button{width:7px;height:7px}
  .slider-dots button.is-on{width:22px}

  /* Programme timeline */
  .programme{padding:56px 20px}
  .timeline::before{left:62px}
  .tl-item{grid-template-columns:54px 22px 1fr;gap:14px;padding:18px 0}
  .tl-time{font-size:20px}
  .tl-time .min{font-size:13px}
  .tl-dot{width:11px;height:11px}
  .tl-body h3{font-size:21px;margin-bottom:4px}
  .tl-body p{font-size:14px}

  /* Infos cards */
  .info-card{padding:40px 24px}
  .info-card .icon{width:36px;height:36px;margin-bottom:16px}
  .info-card .val{font-size:20px}
  .info-card .lbl{font-size:9px;letter-spacing:0.28em}

  /* Scrapbook */
  .scrapbook{padding:52px 18px}
  .scrap-head{margin-bottom:34px}
  .scrap-head .kicker{font-size:24px}
  .scrap-head h3{font-size:clamp(30px, 7.5vw, 44px)}
  .polaroids{gap:30px 14px}
  .polaroid{padding:10px 10px 42px}
  .polaroid img{width:200px;height:250px}
  .polaroid .cap{font-size:21px;bottom:10px}
  .polaroid:nth-child(1){transform:rotate(-3deg) translateY(0)}
  .polaroid:nth-child(2){transform:rotate(2deg) translateY(18px)}
  .polaroid:nth-child(3){transform:rotate(-2deg) translateY(-10px)}
  .polaroid:nth-child(4){transform:rotate(3deg) translateY(12px)}

  /* Section pictos — scale down to avoid crowding text */
  .sec-picto:not([style*="transform"]){transform:scale(0.78)}
  .sec-picto.pc-heart-arrow{transform:scale(0.7) rotate(-12deg) !important}

  /* RSVP */
  .rsvp-wrap{padding:46px 22px}
  .step-title{font-size:22px}
  .att-btn{padding:20px 12px}
  .att-btn .icn{width:32px;height:32px;margin-bottom:6px}
  .att-btn .lbl-big{font-size:19px}
  .att-btn .lbl-sm{font-size:9px}
  .counter{padding:14px 16px}
  .counter-label{font-size:19px}
  .counter-sub{font-size:9px;letter-spacing:0.24em}
  .counter-val{font-size:26px;min-width:30px}
  .counter-ctl button{width:32px;height:32px;font-size:20px}
  .next-btn, .prev-btn{font-size:10px;padding:13px 22px;letter-spacing:0.24em}
  .submit{padding:16px 36px;font-size:10px;width:100%;justify-content:center;text-align:center}
  .step-actions{flex-direction:column-reverse;gap:10px;align-items:stretch}
  .step-actions .prev-btn, .step-actions .next-btn, .step-actions .submit{width:100%;text-align:center;justify-content:center}
  .rsvp-deadline{font-size:14px;margin-top:28px}

  /* Footer */
  footer{padding:64px 24px 32px}
  .footer-logo{width:220px;margin-bottom:22px}
  footer .name{font-size:30px}
  footer .when{font-size:16px;margin:12px 0 30px}
  footer .fine{font-size:9px;letter-spacing:0.3em}
}

/* ============== MOBILE (≤520px) ============== */
@media (max-width:520px){
  .topbar{padding:16px 18px}
  .hero__copy{padding:74px 20px 50px}
  .title-wrap{padding:50px 0 38px}
  .hero__title{font-size:clamp(42px, 13vw, 64px)}
  .hero__meta{margin-top:26px;padding-top:20px}
  .hero__meta .val{font-size:15px}
  .hero__meta .lbl{font-size:9.5px;letter-spacing:0.15em;margin-bottom:12px}
  .hero__meta .sub{font-size:10px;margin-top:4px}
  .hero__meta .col{padding:4px 3px}

  /* Hide a couple of decorative title pictos to free space */
  .title-wrap .pc-sun{display:none !important}
  .title-wrap .pc-star:nth-of-type(n+10){display:none !important}

  /* Slider — even taller portrait-friendly */
  .slider{aspect-ratio:3/4}
  .slide-caption{left:18px;right:18px;text-align:center}
  .slide-caption .ttl{font-size:22px}
  .hero__cta{font-size:12px;letter-spacing:0.12em}

  /* Programme */
  .timeline::before{left:50px}
  .tl-item{grid-template-columns:44px 20px 1fr;gap:12px}
  .tl-time{font-size:18px}

  /* Polaroids: single column, no overlap */
  /* 2 polaroids par ligne sur mobile */
  .polaroids{gap:22px 12px;justify-content:center}
  .polaroid{padding:8px 8px 34px;flex:0 0 calc(50% - 14px);max-width:calc(50% - 14px)}
  .polaroid img{width:100%;height:auto;aspect-ratio:4/5}
  .polaroid .cap{font-size:18px;bottom:8px}
  .polaroid::before{width:54px;height:18px;top:-8px}
  .polaroid:nth-child(n){transform:rotate(0deg)}
  .polaroid:nth-child(odd){transform:rotate(-2deg)}
  .polaroid:nth-child(even){transform:rotate(2deg)}

  /* Section pictograms — keep only a few, hide the rest */
  .sec-picto:not([style*="transform"]){transform:scale(0.65)}
  section .sec-picto.pc-heart-arrow,
  section .sec-picto.pc-flower{display:none !important}

  /* RSVP form */
  .rsvp-wrap{padding:38px 18px}
  .att-choice{grid-template-columns:1fr;gap:12px}
  .field input, .field textarea{font-size:18px}

  /* Section padding */
  section{padding:48px 18px}
  .slider-section{padding:54px 14px}
  .scrapbook{padding:44px 14px}
  .programme{padding:48px 18px}
}

/* ============== SMALL MOBILE (≤380px) ============== */
@media (max-width:380px){
  .topbar{font-size:9px;letter-spacing:0.2em;padding:14px 14px}
  .topbar .right{font-size:11px}
  .hero__title{font-size:clamp(38px, 12.5vw, 54px)}
  .hero__photo{min-height:380px}
  .hero__date-badge .big{font-size:36px}

  /* If 3 cols too tight on very narrow screens, fall back to stacked */
  .hero__meta{flex-direction:column;align-items:center;gap:16px}
  .hero__meta .col{border-left:none;padding:0}
  .hero__meta .val{font-size:19px}
  .hero__meta .lbl{font-size:11px;letter-spacing:0.2em;margin-bottom:5px}
  .hero__meta .sub{font-size:12px;margin-top:5px}

  .section-head h2{font-size:30px}
  .section-head .sub{font-size:15px}

  /* ≤380px : 2 par ligne, juste un peu plus serré */
  .polaroids{gap:18px 8px}
  .polaroid{flex:0 0 calc(50% - 10px);max-width:calc(50% - 10px);padding:7px 7px 30px}
  .polaroid .cap{font-size:16px;bottom:6px}
  .info-card{padding:32px 18px}
  .info-card .val{font-size:18px}

  .att-btn .lbl-big{font-size:17px;white-space:normal}
  .counter{flex-direction:column;align-items:flex-start;gap:10px}
  .counter-ctl{align-self:flex-end}

  footer{padding:56px 20px 28px}
  .footer-logo{width:180px}
  footer .name{font-size:26px}
}

/* ============== TOUCH AFFORDANCE ============== */
@media (hover:none){
  /* On touch devices, give the hover state a soft permanent lift instead */
  .polaroid:hover, .float-photo:hover, .info-card:hover{transform:none}
  .hero__cta:hover{background:transparent;color:var(--gold)}
  .submit:hover{transform:none}
  /* Slider buttons need fingertip-friendly hit area */
  .slider-btn{width:44px;height:44px}
}

/* ============== LANDSCAPE PHONES ============== */
@media (max-height:520px) and (orientation:landscape){
  .hero{min-height:auto}
  .hero__photo{min-height:280px}
  .title-wrap{padding:36px 0 28px}
  .slider{aspect-ratio:16/9}
}
