/* ═══════════════════════════════════════════════════
   ShinNO · Template-06 · Nomination Princesse Lina
   Rose Nacré + Or Champagne + Mauve + Blanc Ivoire
   ═══════════════════════════════════════════════════ */

/* ── Variables ────────────────────────────────────── */
:root {
  --rose:   #f0c4de;
  --rose2:  #f7d9ee;
  --rose3:  #fdeef8;
  --rose4:  #fff5fc;
  --mauve:  #b987c4;
  --mauve2: #d4a8e0;
  --mauve3: #ede0f5;
  --or:     #d4a853;
  --or2:    #e8c678;
  --or3:    #a07830;
  --blanc:  #fffcff;
  --blanc2: #faf7ff;
  --ink:    #2e1a38;
  --gris:   #7a6080;

  --serif:  'Cormorant Garamond', Georgia, serif;
  --sc:     'Cormorant SC', Georgia, serif;
  --script: 'Great Vibes', cursive;
  --sans:   'Jost', system-ui, sans-serif;

  --ease:   cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,.55,.45,1);

  --shadow-sm: 0 2px 16px rgba(46,26,56,.1);
  --shadow-md: 0 6px 32px rgba(46,26,56,.15);
  --shadow-lg: 0 16px 60px rgba(46,26,56,.2);
  --rose-glow: 0 0 40px rgba(212,168,83,.2);
  --mauve-glow: 0 0 40px rgba(185,135,196,.2);
}

/* ── Reset ────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--sans);
  background:var(--rose4);
  color:var(--ink);
  overflow-x:hidden;
  cursor:none;
}
img{display:block;width:100%;height:100%;object-fit:cover;object-position:center}
a{text-decoration:none;color:inherit}
button{cursor:none;background:none;border:none;font:inherit}
fieldset{border:none;padding:0}
ul{list-style:none}
:focus-visible{outline:2px solid var(--mauve);outline-offset:3px;border-radius:3px}

/* ── Grain (très subtil) ──────────────────────────── */
.grain{
  pointer-events:none;
  position:fixed;inset:0;z-index:9999;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.022'/%3E%3C/svg%3E");
  animation:grain-shift 8s steps(1) infinite;
}
@keyframes grain-shift{
  0%{transform:translate(0,0)}
  25%{transform:translate(-1%,-1%)}
  50%{transform:translate(1%,1%)}
  75%{transform:translate(-1%,1%)}
  100%{transform:translate(1%,-1%)}
}

/* ── Custom Cursor ────────────────────────────────── */
.cursor-d{
  position:fixed;width:8px;height:8px;
  background:var(--mauve);border-radius:50%;
  pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
}
.cursor-r{
  position:fixed;width:30px;height:30px;
  border:1px solid rgba(185,135,196,.5);
  border-radius:50%;pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease);
}
.cursor-r.hov{width:48px;height:48px;border-color:var(--or)}
@media(hover:none){.cursor-d,.cursor-r{display:none}}

/* ── sr-only ──────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ══════════════════════════════════════════════════
   INTRO
══════════════════════════════════════════════════ */
.intro{
  position:fixed;inset:0;z-index:5000;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, #1a0828 0%, #2e1a38 50%, #1a0828 100%);
  overflow:hidden;
}
.intro canvas{position:absolute;inset:0;width:100%;height:100%}

.intro-content{
  position:relative;z-index:2;
  text-align:center;padding:24px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}

/* Crown */
.intro-crown{margin-bottom:8px}
.crown-svg{
  width:clamp(80px,14vw,120px);height:auto;
  filter:drop-shadow(0 0 20px rgba(212,168,83,.4));
  animation:crown-float 4s ease-in-out infinite;
}
@keyframes crown-float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-8px) rotate(1deg)}
}

.intro-label{
  font-family:var(--sc);
  font-size:clamp(10px,2vw,12px);
  letter-spacing:.4em;text-transform:uppercase;
  color:rgba(244,196,222,.5);
}

.intro-name{
  font-family:var(--script);
  font-size:clamp(80px,16vw,140px);
  line-height:.85;
  color:var(--blanc);
  text-shadow:0 0 60px rgba(212,168,83,.3),0 4px 40px rgba(185,135,196,.2);
}
.intro-surname{
  font-family:var(--sc);
  font-size:clamp(14px,2.5vw,18px);
  letter-spacing:.45em;text-transform:uppercase;
  color:rgba(244,196,222,.6);
  margin-top:-4px;
}
.intro-event{
  font-family:var(--serif);
  font-size:clamp(13px,2.2vw,16px);
  font-style:italic;
  color:var(--or2);
  letter-spacing:.1em;
}
.intro-rule{
  display:flex;align-items:center;gap:12px;
  width:min(200px,55vw);margin:4px 0;
}
.intro-rule-line{flex:1;height:1px;background:linear-gradient(to right,transparent,rgba(212,168,83,.5),transparent)}
.intro-gem{color:var(--or);font-size:9px;opacity:.8}

.intro-date{
  font-family:var(--sans);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(244,196,222,.35);
}

.reveal-btn{
  pointer-events:all;
  display:inline-flex;align-items:center;gap:10px;
  margin-top:10px;
  padding:14px 36px;border-radius:50px;
  font-family:var(--sc);font-size:11px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--or2);
  border:1px solid rgba(212,168,83,.4);
  background:rgba(212,168,83,.08);
  backdrop-filter:blur(10px);
  transition:all .35s var(--ease);
}
.reveal-btn:hover{
  background:rgba(212,168,83,.18);
  border-color:var(--or);
  box-shadow:var(--rose-glow);
  transform:translateY(-2px);
}
.reveal-btn svg{stroke:var(--or2);transition:transform .35s}
.reveal-btn:hover svg{transform:translateY(3px)}

/* Rose wipe */
.intro-wipe{
  position:absolute;inset:0;z-index:10;
  background:linear-gradient(135deg, var(--rose), var(--rose2), var(--blanc2), var(--rose3));
  clip-path:polygon(0 0,0 0,0 100%,0 100%);
  transition:clip-path .8s cubic-bezier(.76,0,.24,1);
}
.intro-wipe.active{clip-path:polygon(0 0,110% 0,110% 100%,0 100%)}

/* ══════════════════════════════════════════════════
   MAIN
══════════════════════════════════════════════════ */
.main{transition:opacity .6s}

/* Audio */
.audio-btn{
  position:fixed;bottom:28px;right:24px;z-index:200;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,252,255,.85);
  border:1px solid rgba(185,135,196,.3);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(12px);
  box-shadow:var(--shadow-sm);
  transition:all .3s;
}
.audio-btn:hover{border-color:var(--mauve);box-shadow:var(--mauve-glow)}
.audio-btn svg{stroke:var(--mauve)}

/* ══════════════════════════════════════════════════
   NAV
══════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;height:68px;
  background:rgba(255,252,255,0);
  border-bottom:1px solid transparent;
  transition:background .4s,border-color .4s,height .3s;
}
.nav.scrolled{
  background:rgba(255,252,255,.9);
  border-bottom-color:rgba(185,135,196,.18);
  backdrop-filter:blur(16px);
  height:58px;
  box-shadow:var(--shadow-sm);
}
.nav-logo{
  font-family:var(--script);font-size:28px;
  color:var(--mauve);
  text-shadow:0 0 20px rgba(185,135,196,.2);
}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-link{
  font-family:var(--sc);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(46,26,56,.5);
  transition:color .25s;
}
.nav-link:hover{color:var(--mauve)}
.nav-cta{
  font-family:var(--sc);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  padding:9px 22px;border-radius:50px;
  border:1px solid rgba(185,135,196,.45);
  color:var(--mauve);
  transition:all .3s;
}
.nav-cta:hover{background:rgba(185,135,196,.12);border-color:var(--mauve)}
.nav-burger{display:none;flex-direction:column;gap:5px;width:36px;height:36px;align-items:center;justify-content:center}
.nav-burger span{width:22px;height:1px;background:var(--ink);transition:transform .3s,opacity .3s;transform-origin:center}
.nav-burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:680px){.nav-links{display:none}.nav-burger{display:flex}}

/* Drawer */
.nav-drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(300px,85vw);z-index:300;
  background:var(--blanc2);
  border-left:1px solid rgba(185,135,196,.2);
  padding:80px 28px 40px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateX(100%);
  transition:transform .45s var(--ease);
  box-shadow:var(--shadow-lg);
}
.nav-drawer.open{transform:translateX(0)}
.drawer-close{
  position:absolute;top:20px;right:20px;
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  color:var(--ink);opacity:.4;transition:opacity .2s;
}
.drawer-close:hover{opacity:.9}
.drawer-crown{font-size:28px;margin-bottom:8px}
.drawer-name{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--ink);margin-bottom:16px;line-height:1.3}
.drawer-name strong{color:var(--mauve)}
.drawer-link{
  font-family:var(--sc);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(46,26,56,.55);padding:13px 0;
  border-bottom:1px solid rgba(185,135,196,.15);
  transition:color .25s;
}
.drawer-link:hover{color:var(--mauve)}
.drawer-cta{
  margin-top:14px;text-align:center;
  border:1px solid rgba(185,135,196,.4);border-radius:50px;padding:13px;
  color:var(--mauve);
}
.drawer-cta:hover{background:rgba(185,135,196,.08)}
.drawer-date{margin-top:auto;font-family:var(--sc);font-size:10px;letter-spacing:.2em;color:rgba(46,26,56,.25)}
.drawer-overlay{display:none;position:fixed;inset:0;z-index:250;background:rgba(46,26,56,.4);backdrop-filter:blur(4px)}
.drawer-overlay.open{display:block}

/* ══════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;padding-bottom:80px;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;will-change:transform}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,
    rgba(46,26,56,.2) 0%,
    rgba(46,26,56,.5) 50%,
    rgba(28,8,42,.85) 100%
  );
}
.hero-sparkles{position:absolute;inset:0;pointer-events:none}
.hero-content{
  position:relative;z-index:2;
  width:100%;max-width:960px;margin:0 auto;
  padding:0 clamp(20px,5vw,60px);
}
.hero-eyebrow{
  display:flex;align-items:center;gap:10px;
  font-family:var(--sc);font-size:11px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--or2);margin-bottom:14px;
}
.gem-small{font-size:8px;color:var(--or);opacity:.8}

.hero-name{
  font-family:var(--script);
  font-size:clamp(80px,14vw,150px);
  line-height:.85;
  color:var(--blanc);
  text-shadow:0 4px 40px rgba(212,168,83,.25),0 0 80px rgba(185,135,196,.15);
}
.hero-script{
  font-family:var(--sc);
  font-size:clamp(14px,2.5vw,20px);
  letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,252,255,.5);
  margin-top:8px;
}
.hero-family{
  font-family:var(--serif);font-size:clamp(14px,2.2vw,18px);
  font-style:italic;color:rgba(255,252,255,.55);
  margin-top:14px;
}
.hero-family em{color:rgba(255,252,255,.75)}

/* Countdown */
.hero-countdown{
  display:flex;align-items:center;
  margin:28px 0 32px;
  background:rgba(28,8,42,.55);
  border:1px solid rgba(212,168,83,.2);
  backdrop-filter:blur(14px);
  border-radius:14px;padding:18px 24px;width:fit-content;
}
.cd-b{display:flex;flex-direction:column;align-items:center;min-width:60px}
.cd-n{
  font-family:var(--serif);
  font-size:clamp(26px,5vw,40px);
  font-weight:300;color:var(--or2);line-height:1;
}
.cd-l{font-family:var(--sc);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,252,255,.35);margin-top:5px}
.cd-sep{font-size:10px;color:rgba(212,168,83,.45);padding:0 4px;margin-bottom:14px}

.hero-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 40px;border-radius:50px;
  font-family:var(--sc);font-size:12px;
  letter-spacing:.3em;text-transform:uppercase;
  background:linear-gradient(135deg,var(--mauve),var(--or));
  color:#fff;font-weight:500;
  box-shadow:var(--shadow-md),var(--rose-glow);
  transition:all .35s var(--ease);
}
.hero-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg),0 0 48px rgba(185,135,196,.35)}

/* Scroll */
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%)}
.hs-track{width:1px;height:56px;background:rgba(212,168,83,.15);overflow:hidden;position:relative}
.hs-dot{width:1px;height:20px;background:var(--or);position:absolute;top:-20px;animation:scroll-drop 2.2s ease-in-out infinite}
@keyframes scroll-drop{0%{top:-20px}80%,100%{top:56px}}

/* ══════════════════════════════════════════════════
   ANNONCE
══════════════════════════════════════════════════ */
.annonce{
  background:var(--blanc);
  padding:clamp(60px,10vw,100px) clamp(20px,5vw,60px);
  text-align:center;
  position:relative;
}
.annonce-deco-top,.annonce-deco-bot{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:0 clamp(20px,5vw,60px);
}
.annonce-deco-top{padding-top:clamp(48px,8vw,80px);margin-bottom:40px}
.annonce-deco-bot{margin-top:40px;padding-bottom:clamp(48px,8vw,80px)}
.deco-gem{font-size:8px;color:var(--or);opacity:.6}
.deco-line{flex:1;max-width:120px;height:1px;background:linear-gradient(to right,transparent,rgba(212,168,83,.35),transparent)}
.deco-crown{font-size:20px}

/* remove default padding/margin from annonce for the deco system */
.annonce{padding:0}

.annonce-wrap{max-width:620px;margin:0 auto;text-align:center}
.annonce .section-label{color:var(--mauve)}
.annonce-fam{font-family:var(--serif);font-size:clamp(16px,2.5vw,20px);color:var(--ink);line-height:1.7;margin-top:16px}
.annonce-fam em{color:var(--mauve);font-style:italic}
.annonce-corps{font-family:var(--serif);font-size:clamp(14px,2vw,17px);color:var(--gris);font-style:italic;line-height:1.8;margin-top:12px}
.annonce-name-block{margin:20px 0 14px}
.annonce-script{
  font-family:var(--script);
  font-size:clamp(64px,12vw,100px);
  color:var(--mauve);
  text-shadow:0 2px 20px rgba(185,135,196,.2);
  line-height:1;
}
.annonce-quand{font-family:var(--sc);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gris)}
.annonce-verse{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  margin-top:24px;
  padding:20px 28px;
  background:linear-gradient(135deg,rgba(185,135,196,.06),rgba(212,168,83,.04));
  border-radius:12px;
  border:1px solid rgba(212,168,83,.15);
}
.verse-gem{font-size:10px;color:var(--or);opacity:.6}
.annonce-verse blockquote{
  font-family:var(--serif);font-size:clamp(15px,2.3vw,18px);
  font-style:italic;color:var(--ink);line-height:1.75;
}
.annonce-verse blockquote cite{
  display:block;margin-top:10px;
  font-size:12px;letter-spacing:.15em;
  color:var(--gris);font-style:normal;font-family:var(--sc);
}

/* ══════════════════════════════════════════════════
   PROGRAMME
══════════════════════════════════════════════════ */
.programme{
  background:linear-gradient(135deg, var(--mauve3) 0%, var(--rose3) 100%);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
}
.section-header{text-align:center;margin-bottom:clamp(40px,7vw,64px)}
.section-label{
  font-family:var(--sc);font-size:11px;letter-spacing:.4em;
  text-transform:uppercase;color:var(--gris);display:block;margin-bottom:10px;
}
.section-title{
  font-family:var(--script);font-size:clamp(40px,7vw,72px);
  color:var(--ink);line-height:1.1;
}

/* Steps */
.prog-steps{
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;gap:0;
}
.prog-step{
  display:grid;
  grid-template-columns:56px 32px 1fr;
  align-items:start;gap:0;
  position:relative;
}
.step-bubble{
  width:56px;height:56px;border-radius:50%;
  background:rgba(255,252,255,.9);
  border:2px solid rgba(185,135,196,.35);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-sm);
  font-size:22px;
  flex-shrink:0;
  position:relative;z-index:1;
}
.step-bubble-or{border-color:rgba(212,168,83,.45)}
.step-bubble-mauve{border-color:rgba(185,135,196,.6);background:rgba(185,135,196,.1)}
.step-connector{
  width:2px;background:linear-gradient(to bottom,rgba(185,135,196,.3),rgba(212,168,83,.2));
  margin:0 auto;height:100%;min-height:48px;
}
.step-card{
  margin-left:16px;
  background:rgba(255,252,255,.8);
  border:1px solid rgba(185,135,196,.2);
  border-radius:14px;
  padding:clamp(18px,3vw,28px);
  margin-bottom:24px;
  box-shadow:var(--shadow-sm);
  backdrop-filter:blur(8px);
}
.step-card-or{border-color:rgba(212,168,83,.28);background:rgba(255,250,240,.8)}
.step-card-mauve{border-color:rgba(185,135,196,.35);background:rgba(245,235,255,.8)}
.step-time{
  font-family:var(--serif);
  font-size:clamp(26px,4.5vw,38px);
  font-weight:300;color:var(--mauve);
  line-height:1;margin-bottom:8px;
}
.step-card-or .step-time{color:var(--or3)}
.step-card-mauve .step-time{color:var(--mauve)}
.step-title{font-family:var(--serif);font-size:clamp(18px,3vw,24px);color:var(--ink);margin-bottom:10px}
.step-where{
  display:flex;align-items:center;gap:7px;
  font-family:var(--sans);font-size:12px;color:var(--gris);
  margin-bottom:8px;
}
.step-where svg{stroke:var(--mauve);flex-shrink:0}
.step-desc{font-family:var(--serif);font-size:14px;font-style:italic;color:rgba(46,26,56,.6);line-height:1.6;margin-bottom:10px}
.step-map{
  font-family:var(--sc);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(46,26,56,.35);transition:color .25s;
}
.step-map:hover{color:var(--mauve)}
.step-badge{
  display:inline-block;
  padding:4px 14px;border-radius:50px;
  font-family:var(--sc);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  background:rgba(185,135,196,.15);border:1px solid rgba(185,135,196,.35);
  color:var(--mauve);margin-top:8px;
}

/* ══════════════════════════════════════════════════
   GALERIE
══════════════════════════════════════════════════ */
.galerie{
  background:var(--blanc2);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
}
.galerie .section-title{color:var(--mauve)}
.gal-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  max-width:1100px;margin:0 auto;
  grid-auto-rows:240px;
}
.gal-tall{grid-row:span 2}
.gal-wide{grid-column:span 2}
.gal-item{
  position:relative;overflow:hidden;
  border-radius:14px;
  border:1px solid rgba(185,135,196,.18);
}
.gal-item img{
  transition:transform .7s var(--ease),filter .5s;
  filter:brightness(.92) saturate(.9);
}
.gal-item:hover img{transform:scale(1.06);filter:brightness(1) saturate(1.05)}
.gal-over{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(46,26,56,.3) 0%,transparent 55%);
  transition:opacity .4s;
}
.gal-item:hover .gal-over{opacity:.6}
.gal-gem{
  position:absolute;bottom:12px;right:12px;
  font-size:12px;color:var(--or);opacity:.7;
  text-shadow:0 0 12px rgba(212,168,83,.5);
}

@media(max-width:680px){
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .gal-tall{grid-row:span 2}.gal-wide{grid-column:span 2}
}
@media(max-width:440px){
  .gal-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gal-tall,.gal-wide{grid-row:auto;grid-column:auto}
}

/* ══════════════════════════════════════════════════
   RSVP
══════════════════════════════════════════════════ */
.rsvp{
  background:var(--rose3);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
  border-top:1px solid rgba(185,135,196,.15);
  text-align:center;
  position:relative;
}
.rsvp-crown{font-size:clamp(40px,7vw,64px);margin-bottom:16px;display:block;filter:drop-shadow(0 4px 16px rgba(212,168,83,.25))}

.rsvp-wrap{
  max-width:1040px;margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:clamp(40px,7vw,80px);
  align-items:start;
  text-align:left;
}
.rsvp .section-label{color:var(--mauve)}
.rsvp-title{
  font-family:var(--script);
  font-size:clamp(36px,6vw,60px);
  color:var(--ink);line-height:1.1;
  margin:10px 0 14px;
}
.rsvp-sub{font-family:var(--sans);font-size:13px;color:var(--gris);line-height:1.6}
.rsvp-sub strong{color:var(--or3)}
.rsvp-script{
  font-family:var(--script);font-size:clamp(24px,4vw,36px);
  color:rgba(185,135,196,.45);
  margin-top:16px;
}
.rsvp-info{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.rsvp-info li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gris)}
.rsvp-info svg{stroke:var(--mauve);flex-shrink:0}

@media(max-width:760px){.rsvp-wrap{grid-template-columns:1fr}}

/* Form */
.rsvp-form{display:flex;flex-direction:column;gap:14px}

/* Presence */
.pres-field{display:flex;flex-direction:column;gap:10px}
.pres-legend{font-family:var(--serif);font-size:16px;font-style:italic;color:var(--ink)}
.pres-btns{display:flex;gap:10px;flex-wrap:wrap}
.pres-btn{
  flex:1;min-width:140px;
  display:flex;align-items:center;gap:8px;
  border:1px solid rgba(185,135,196,.25);
  border-radius:12px;padding:12px 16px;
  font-family:var(--sans);font-size:13px;
  color:rgba(46,26,56,.55);
  background:rgba(255,252,255,.6);
  cursor:none;
  transition:all .25s var(--ease);
}
.pres-btn input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.pres-btn:has(input:checked){
  border-color:var(--mauve);
  color:var(--mauve);
  background:rgba(185,135,196,.1);
  box-shadow:var(--mauve-glow);
}
.pres-btn:hover{border-color:rgba(185,135,196,.5);color:rgba(46,26,56,.8)}
.pres-icon{font-size:18px}

/* Fields */
.field{position:relative}
.field input,.field textarea,.field select{
  width:100%;
  background:rgba(255,252,255,.8);
  border:none;
  border-bottom:1px solid rgba(185,135,196,.25);
  border-radius:8px 8px 0 0;
  padding:22px 14px 8px;
  font-family:var(--sans);font-size:14px;
  color:var(--ink);outline:none;
  transition:background .25s,border-color .25s;
  appearance:none;-webkit-appearance:none;
}
.field input:focus,.field textarea:focus,.field select:focus{
  background:rgba(185,135,196,.07);
  border-bottom-color:var(--mauve);
}
.field label,.field .select-lbl{
  position:absolute;top:14px;left:14px;
  font-family:var(--sans);font-size:13px;
  color:rgba(46,26,56,.4);
  pointer-events:none;
  transition:all .22s var(--ease);
  transform-origin:left;
}
.field input:focus ~ label,
.field input:not(:placeholder-shown) ~ label,
.field textarea:focus ~ label,
.field textarea:not(:placeholder-shown) ~ label,
.field select:focus ~ .select-lbl{top:6px;font-size:10px;letter-spacing:.12em;color:var(--mauve);transform:scale(.95)}
.field select ~ .select-lbl{top:6px;font-size:10px;letter-spacing:.12em;color:var(--mauve)}
.fbar{position:absolute;bottom:0;left:0;width:0;height:1px;background:linear-gradient(to right,var(--mauve),var(--or));transition:width .35s var(--ease)}
.field:focus-within .fbar{width:100%}
.fields-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-ta textarea{min-height:90px;resize:none}
.field select option{background:var(--blanc2);color:var(--ink)}

/* Captcha */
.captcha-row{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  background:rgba(255,252,255,.7);
  border:1px solid rgba(185,135,196,.18);
  border-radius:10px;padding:12px 14px;
}
.captcha-q{font-family:var(--serif);font-size:16px;color:rgba(46,26,56,.65);white-space:nowrap}
.captcha-q strong{color:var(--mauve)}
.field-captcha{flex:1;min-width:100px}

/* Submit */
.rsvp-submit{
  width:100%;
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:18px;border-radius:50px;
  background:linear-gradient(135deg,var(--mauve),var(--or));
  font-family:var(--sc);font-size:13px;letter-spacing:.3em;text-transform:uppercase;
  color:#fff;font-weight:500;
  box-shadow:var(--shadow-md),var(--mauve-glow);
  transition:all .35s var(--ease);
}
.rsvp-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 48px rgba(185,135,196,.4)}
.rsvp-submit:disabled{opacity:.5;transform:none;cursor:not-allowed}

/* Feedback */
.rsvp-feedback{font-family:var(--sans);font-size:13px;border-radius:10px;overflow:hidden;max-height:0;transition:max-height .4s,padding .4s;text-align:center}
.rsvp-feedback.ok{max-height:80px;padding:14px;background:rgba(100,200,140,.15);border:1px solid rgba(100,200,140,.3);color:#2e6642}
.rsvp-feedback.err{max-height:80px;padding:14px;background:rgba(200,80,80,.1);border:1px solid rgba(200,80,80,.25);color:#8c2020}

/* hp */
.hp{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}

/* ══════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════ */
.footer{
  background:linear-gradient(135deg,#1a0828,#2e1a38);
  padding:clamp(48px,8vw,80px) 24px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.footer-crown{font-size:clamp(32px,6vw,48px);filter:drop-shadow(0 0 20px rgba(212,168,83,.35))}
.footer-name{font-family:var(--script);font-size:clamp(36px,6vw,56px);color:var(--blanc);line-height:1}
.footer-date{font-family:var(--sc);font-size:11px;letter-spacing:.3em;color:rgba(255,252,255,.35)}
.footer-lieu{font-family:var(--sc);font-size:10px;letter-spacing:.25em;color:rgba(255,252,255,.2)}
.footer-gems{font-size:9px;color:rgba(212,168,83,.35);letter-spacing:8px;margin:6px 0}
.footer-credit{font-family:var(--sans);font-size:11px;color:rgba(255,252,255,.2)}
.footer-credit span{color:rgba(212,168,83,.45);letter-spacing:.1em}

/* ══════════════════════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════ */
@media(max-width:600px){
  .hero-countdown{padding:12px 16px}
  .cd-b{min-width:48px}.cd-n{font-size:24px}
  .prog-step{grid-template-columns:44px 20px 1fr}
  .step-bubble{width:44px;height:44px;font-size:18px}
  .step-card{margin-left:10px}
  .pres-btns{flex-direction:column}
  .fields-row{grid-template-columns:1fr}
  .rsvp-wrap{gap:28px}
}
@media(max-width:380px){
  .hero-countdown{flex-wrap:wrap;justify-content:center}
  .cd-sep{display:none}
}
