/* ═══════════════════════════════════════════════════
   ShinNO · Template-05 · Bar Mitsva Noah
   Midnight Blue + Royal Gold + Étoile de David
   ═══════════════════════════════════════════════════ */

/* ── Variables ────────────────────────────────────── */
:root {
  --nuit:   #0c1a3a;
  --nuit2:  #0a1630;
  --nuit3:  #111f45;
  --bleu:   #1a3d8c;
  --bleu2:  #234db0;
  --or:     #c8a96e;
  --or2:    #e4d49c;
  --or3:    #9a7542;
  --nacre:  #faf9f7;
  --nacre2: #f0ece4;
  --ink:    #1a1710;
  --gris:   #6b6355;

  --serif:  'Cormorant', Georgia, serif;
  --sc:     'Cormorant SC', Georgia, serif;
  --sans:   'Inter', system-ui, sans-serif;

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

  --shadow-sm: 0 2px 12px rgba(10,20,48,.18);
  --shadow-md: 0 6px 32px rgba(10,20,48,.28);
  --shadow-lg: 0 16px 60px rgba(10,20,48,.38);
  --gold-glow: 0 0 32px rgba(200,169,110,.18);
}

/* ── 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(--nuit);
  color:var(--nacre);
  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}
ul{list-style:none}
:focus-visible{outline:2px solid var(--or);outline-offset:3px;border-radius:3px}

/* ── Grain ────────────────────────────────────────── */
.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.035'/%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:7px;height:7px;
  background:var(--or);border-radius:50%;
  pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:opacity .2s;
}
.cursor-r{
  position:fixed;width:28px;height:28px;
  border:1px solid rgba(200,169,110,.55);
  border-radius:50%;pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease),opacity .2s;
}
.cursor-r.hov{width:46px;height:46px;border-color:rgba(200,169,110,.9)}
@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:var(--nuit2);
  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:12px;
  pointer-events:none;
}

.intro-heb{
  font-family:var(--sc);
  font-size:clamp(12px,2.5vw,15px);
  letter-spacing:.35em;
  color:var(--or);
  opacity:.75;
  text-transform:uppercase;
}

.intro-names{
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.intro-name{
  font-family:var(--serif);
  font-size:clamp(64px,14vw,110px);
  font-weight:300;font-style:italic;
  line-height:1;
  color:var(--nacre);
  text-shadow:0 0 60px rgba(200,169,110,.25);
}
.intro-heb-name{
  font-family:var(--serif);
  font-size:clamp(22px,4vw,32px);
  font-weight:300;
  color:var(--or);
  letter-spacing:.1em;
}

.intro-event{
  font-family:var(--sc);
  font-size:clamp(11px,2vw,13px);
  letter-spacing:.5em;
  text-transform:uppercase;
  color:rgba(250,249,247,.55);
}

.intro-rule{
  display:flex;align-items:center;gap:12px;
  width:min(220px,60vw);
  margin:4px 0;
}
.intro-rule-line{flex:1;height:1px;background:linear-gradient(to right,transparent,var(--or),transparent)}
.intro-star-icon{color:var(--or);font-size:10px;opacity:.8}

.intro-date{
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.2em;
  color:rgba(250,249,247,.45);
  text-transform:uppercase;
}

.reveal-btn{
  pointer-events:all;
  display:inline-flex;align-items:center;gap:10px;
  margin-top:8px;
  padding:14px 36px;
  border:1px solid rgba(200,169,110,.45);
  border-radius:50px;
  font-family:var(--sc);
  font-size:12px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--or);
  background:rgba(200,169,110,.06);
  backdrop-filter:blur(8px);
  transition:all .35s var(--ease);
}
.reveal-btn:hover{
  background:rgba(200,169,110,.15);
  border-color:var(--or);
  box-shadow:var(--gold-glow);
  transform:translateY(-2px);
}
.reveal-btn svg{stroke:var(--or);transition:transform .35s var(--ease)}
.reveal-btn:hover svg{transform:translateY(3px)}

/* Gold wipe reveal */
.intro-wipe{
  position:absolute;inset:0;z-index:10;
  background:linear-gradient(135deg, var(--or3), var(--or), var(--or2), var(--nuit3));
  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 var(--ease)}

/* ── Audio button ────────────────────────────────── */
.audio-btn{
  position:fixed;bottom:28px;right:24px;z-index:200;
  width:44px;height:44px;border-radius:50%;
  background:rgba(10,22,48,.75);
  border:1px solid rgba(200,169,110,.3);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(12px);
  transition:all .3s var(--ease);
}
.audio-btn:hover{border-color:var(--or);box-shadow:var(--gold-glow)}
.audio-btn svg{stroke:var(--or)}

/* ══════════════════════════════════════════════════
   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(10,22,48,0);
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease),border-color .4s var(--ease),height .3s;
}
.nav.scrolled{
  background:rgba(10,22,48,.92);
  border-bottom-color:rgba(200,169,110,.12);
  backdrop-filter:blur(16px);
  height:58px;
}
.nav-logo{
  font-family:var(--serif);
  font-size:22px;font-weight:400;font-style:italic;
  color:var(--or);
  letter-spacing:.05em;
}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-link{
  font-family:var(--sc);font-size:11px;
  letter-spacing:.25em;text-transform:uppercase;
  color:rgba(250,249,247,.65);
  transition:color .25s;
}
.nav-link:hover{color:var(--or)}
.nav-cta{
  font-family:var(--sc);font-size:11px;
  letter-spacing:.25em;text-transform:uppercase;
  padding:9px 22px;border-radius:50px;
  border:1px solid rgba(200,169,110,.5);
  color:var(--or);
  transition:all .3s var(--ease);
}
.nav-cta:hover{background:rgba(200,169,110,.12);border-color:var(--or)}
.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(--nacre);
  transition:transform .3s var(--ease),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(320px,85vw);z-index:300;
  background:var(--nuit2);
  border-left:1px solid rgba(200,169,110,.12);
  padding:80px 32px 40px;
  display:flex;flex-direction:column;gap:6px;
  transform:translateX(100%);
  transition:transform .45s var(--ease);
}
.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(--nacre);opacity:.6;transition:opacity .2s;
}
.drawer-close:hover{opacity:1}
.drawer-name{
  font-family:var(--serif);
  font-size:22px;font-weight:300;color:var(--nacre);
  margin-bottom:20px;line-height:1.3;
}
.drawer-name strong{color:var(--or)}
.drawer-link{
  font-family:var(--sc);font-size:13px;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(250,249,247,.6);
  padding:14px 0;
  border-bottom:1px solid rgba(200,169,110,.1);
  transition:color .25s;
}
.drawer-link:hover{color:var(--or)}
.drawer-cta{
  margin-top:16px;text-align:center;
  border:1px solid rgba(200,169,110,.4);
  border-radius:50px;padding:14px;
  color:var(--or);border-bottom:1px solid rgba(200,169,110,.4);
}
.drawer-cta:hover{background:rgba(200,169,110,.1)}
.drawer-date{
  margin-top:auto;
  font-family:var(--sc);font-size:11px;
  letter-spacing:.2em;color:rgba(250,249,247,.25);
}
.drawer-overlay{
  display:none;
  position:fixed;inset:0;z-index:250;
  background:rgba(10,22,48,.7);
  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(12,26,58,.3) 0%,
    rgba(12,26,58,.55) 50%,
    rgba(10,22,48,.92) 100%
  );
}
.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:12px;
  font-family:var(--sc);font-size:11px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--or);margin-bottom:16px;
}
.hero-heb-small{font-family:var(--serif);letter-spacing:.1em;font-size:13px}
.eyebrow-sep{color:var(--or);opacity:.6}

.hero-name{
  font-family:var(--serif);
  font-size:clamp(72px,13vw,130px);
  font-weight:300;line-height:.9;
  color:var(--nacre);
  text-shadow:0 4px 40px rgba(200,169,110,.18);
}
.hero-heb{
  font-family:var(--serif);
  font-size:clamp(24px,4.5vw,42px);
  font-weight:300;
  color:var(--or);
  margin-top:8px;letter-spacing:.08em;
}
.hero-family{
  font-family:var(--serif);
  font-size:clamp(14px,2.2vw,18px);
  font-style:italic;
  color:rgba(250,249,247,.55);
  margin-top:16px;
}

/* Countdown */
.hero-countdown{
  display:flex;align-items:center;gap:0;
  margin:28px 0 32px;
  background:rgba(10,22,48,.55);
  border:1px solid rgba(200,169,110,.18);
  backdrop-filter:blur(12px);
  border-radius:12px;
  padding:20px 24px;
  width:fit-content;
}
.cd-b{display:flex;flex-direction:column;align-items:center;min-width:64px}
.cd-n{
  font-family:var(--serif);
  font-size:clamp(28px,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(250,249,247,.4);margin-top:6px;
}
.cd-sep{
  font-size:28px;color:rgba(200,169,110,.3);
  padding:0 4px;line-height:1;margin-bottom:16px;
}

.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(--or3),var(--or));
  color:var(--nuit2);font-weight:500;
  box-shadow:var(--shadow-md),var(--gold-glow);
  transition:all .35s var(--ease);
}
.hero-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg),0 0 48px rgba(200,169,110,.3)}

/* Scroll indicator */
.hero-scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;justify-content:center;
}
.hs-track{
  width:1px;height:56px;
  background:rgba(200,169,110,.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(--nacre);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
  text-align:center;
}
.annonce-wrap{max-width:640px;margin:0 auto}
.annonce-heb-deco{
  font-size:clamp(32px,6vw,52px);
  color:var(--bleu);
  margin-bottom:24px;
  animation:star-spin 20s linear infinite;
}
@keyframes star-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.annonce .section-label{color:var(--bleu2)}

.annonce-fam{
  font-family:var(--serif);
  font-size:clamp(17px,2.8vw,22px);
  font-weight:400;
  color:var(--ink);
  line-height:1.7;margin-top:16px;
}
.annonce-fam em{color:var(--bleu);font-style:italic}
.annonce-corps{
  font-family:var(--serif);
  font-size:clamp(14px,2.2vw,17px);
  color:var(--gris);
  font-style:italic;
  line-height:1.75;margin-top:14px;
}
.annonce-name-block{
  display:flex;align-items:center;justify-content:center;gap:20px;
  margin:24px 0 18px;
}
.annonce-name-fr{
  font-family:var(--serif);
  font-size:clamp(48px,9vw,80px);
  font-weight:300;font-style:italic;
  color:var(--bleu);
  line-height:1;
}
.annonce-name-heb{
  font-family:var(--serif);
  font-size:clamp(22px,4vw,34px);
  color:var(--or3);
  border-left:1px solid rgba(26,61,140,.25);
  padding-left:20px;
}
.annonce-quand{
  font-family:var(--sc);font-size:12px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gris);
}
.annonce-quote{
  margin-top:28px;
  padding:20px 28px;
  border-left:2px solid var(--or);
  background:rgba(26,61,140,.04);
  border-radius:0 8px 8px 0;
  text-align:left;
  font-family:var(--serif);
  font-size:clamp(15px,2.4vw,18px);
  font-style:italic;
  color:var(--ink);
  line-height:1.7;
}
.annonce-quote 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:var(--nuit3);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
}
.section-header{text-align:center;margin-bottom:clamp(40px,7vw,72px)}
.section-label{
  font-family:var(--sc);font-size:11px;
  letter-spacing:.4em;text-transform:uppercase;
  color:rgba(250,249,247,.45);
  display:block;margin-bottom:10px;
}
.section-title{
  font-family:var(--serif);
  font-size:clamp(32px,6vw,56px);
  font-weight:300;font-style:italic;
  color:var(--nacre);
  line-height:1.15;
}

.prog-timeline{
  max-width:720px;margin:0 auto;
  display:flex;flex-direction:column;
  align-items:center;gap:0;
}

.prog-event{
  width:100%;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(200,169,110,.12);
  border-radius:16px;
  padding:clamp(24px,4vw,40px);
  display:grid;
  grid-template-columns:48px auto 1fr;
  gap:0 clamp(16px,3vw,28px);
  align-items:start;
  transition:border-color .3s,box-shadow .3s;
}
.prog-event:hover{
  border-color:rgba(200,169,110,.3);
  box-shadow:var(--gold-glow);
}

.prog-event-num{
  font-family:var(--sc);
  font-size:11px;letter-spacing:.2em;
  color:rgba(250,249,247,.2);
  text-align:right;
  padding-top:4px;
}
.prog-event-num-gold{color:rgba(200,169,110,.5)}

.prog-event-time{
  display:flex;flex-direction:column;align-items:flex-end;
  border-right:1px solid rgba(200,169,110,.2);
  padding-right:clamp(16px,3vw,28px);
  padding-top:2px;
}
.prog-day{
  font-family:var(--serif);
  font-size:clamp(42px,7vw,60px);
  font-weight:300;line-height:1;
  color:rgba(250,249,247,.2);
}
.prog-day-gold{color:rgba(200,169,110,.55)}
.prog-monthyr{
  font-family:var(--sc);font-size:11px;
  letter-spacing:.15em;
  color:rgba(250,249,247,.35);
  white-space:nowrap;
}

.prog-event-content{padding-top:2px}

.prog-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(26,61,140,.35);
  border:1px solid rgba(26,61,140,.5);
  color:var(--nacre2);
  margin-bottom:10px;
}
.prog-badge-gold{
  background:rgba(200,169,110,.12);
  border-color:rgba(200,169,110,.3);
  color:var(--or2);
}
.prog-title{
  font-family:var(--serif);
  font-size:clamp(20px,3.5vw,28px);
  font-weight:400;color:var(--nacre);
  margin-bottom:14px;line-height:1.2;
}
.prog-details{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.prog-details li{
  display:flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:13px;
  color:rgba(250,249,247,.6);
}
.prog-details svg{flex-shrink:0;stroke:var(--or);opacity:.7}
.prog-map{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--sc);font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(250,249,247,.4);
  transition:color .25s;
}
.prog-map:hover{color:var(--or)}
.prog-map-gold:hover{color:var(--or)}

/* Connector */
.prog-connector{
  display:flex;flex-direction:column;align-items:center;gap:0;
  padding:4px 0;
}
.prog-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(200,169,110,.2),rgba(200,169,110,.05))}
.prog-star{
  font-size:18px;color:var(--or);
  padding:8px 0;opacity:.7;
  animation:star-spin 30s linear infinite;
}

/* ══════════════════════════════════════════════════
   GALERIE
══════════════════════════════════════════════════ */
.galerie{
  background:var(--nuit2);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
}
.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:10px;
  border:1px solid rgba(200,169,110,.1);
}
.gal-item img{
  transition:transform .7s var(--ease),filter .5s;
  filter:brightness(.85) saturate(.9);
}
.gal-item:hover img{transform:scale(1.06);filter:brightness(.95) saturate(1.05)}
.gal-over{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,22,48,.45) 0%,transparent 50%);
  transition:opacity .4s;
}
.gal-item:hover .gal-over{opacity:.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(--nuit);
  padding:clamp(72px,12vw,120px) clamp(20px,5vw,60px);
  border-top:1px solid rgba(200,169,110,.1);
}
.rsvp-wrap{
  max-width:1060px;margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1.5fr;
  gap:clamp(40px,7vw,80px);
  align-items:start;
}
.rsvp-title{
  font-family:var(--serif);
  font-size:clamp(32px,5vw,50px);
  font-weight:300;font-style:italic;
  color:var(--nacre);
  line-height:1.15;margin:10px 0 14px;
}
.rsvp-sub{
  font-family:var(--sans);font-size:13px;
  color:rgba(250,249,247,.5);
  line-height:1.6;
}
.rsvp-sub strong{color:var(--or)}
.rsvp-heb{
  font-family:var(--serif);
  font-size:clamp(28px,5vw,48px);
  font-weight:300;
  color:rgba(200,169,110,.2);
  letter-spacing:.05em;
  margin-top:20px;
  line-height:1.2;
}
.rsvp-info{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.rsvp-info li{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:rgba(250,249,247,.5);
}
.rsvp-info svg{stroke:var(--or);flex-shrink:0}

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

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

/* Event blocks */
.event-block{
  border:1px solid rgba(200,169,110,.15);
  border-radius:12px;
  padding:20px;
  display:flex;flex-direction:column;gap:14px;
  background:rgba(255,255,255,.025);
}
.event-block-main{
  border-color:rgba(200,169,110,.28);
  background:rgba(200,169,110,.03);
}
.event-block-header{
  display:flex;align-items:center;gap:14px;
}
.event-num{
  font-family:var(--sc);font-size:10px;
  letter-spacing:.2em;
  color:rgba(250,249,247,.25);
  border:1px solid rgba(250,249,247,.1);
  border-radius:50%;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.event-num-gold{
  color:rgba(200,169,110,.7);
  border-color:rgba(200,169,110,.3);
}
.event-name{
  font-family:var(--serif);font-size:16px;
  color:var(--nacre);font-weight:400;
}
.event-info{
  font-family:var(--sans);font-size:11px;
  color:rgba(250,249,247,.4);
  letter-spacing:.05em;
  margin-top:2px;
}

/* Presence buttons */
.pres-field{}
.pres-btns{display:flex;gap:10px}
.pres-btn{
  flex:1;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(200,169,110,.18);
  border-radius:8px;padding:10px;
  font-family:var(--sc);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(250,249,247,.5);
  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(--or);
  color:var(--or);
  background:rgba(200,169,110,.1);
}
.pres-btn:hover{border-color:rgba(200,169,110,.4);color:rgba(250,249,247,.8)}

/* Floating label fields */
.field{position:relative}
.field input,
.field textarea,
.field select{
  width:100%;
  background:rgba(255,255,255,.04);
  border:none;
  border-bottom:1px solid rgba(200,169,110,.2);
  border-radius:6px 6px 0 0;
  padding:22px 14px 8px;
  font-family:var(--sans);font-size:14px;
  color:var(--nacre);
  outline:none;
  transition:background .25s,border-color .25s;
  appearance:none;
  -webkit-appearance:none;
}
.field input:focus,
.field textarea:focus,
.field select:focus{
  background:rgba(200,169,110,.06);
  border-bottom-color:var(--or);
}
.field label,
.field .select-lbl{
  position:absolute;top:14px;left:14px;
  font-family:var(--sans);font-size:13px;
  color:rgba(250,249,247,.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(--or);transform:scale(.95);
}
.field select ~ .select-lbl{top:6px;font-size:10px;letter-spacing:.12em;color:var(--or)}
.fbar{
  position:absolute;bottom:0;left:0;
  width:0;height:1px;background: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}

/* Select option colors (dark background) */
.field select option{background:var(--nuit3);color:var(--nacre)}

/* Captcha row */
.captcha-row{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(200,169,110,.1);
  border-radius:10px;
  padding:14px 16px;
}
.captcha-q{
  font-family:var(--serif);font-size:16px;
  color:rgba(250,249,247,.7);
  white-space:nowrap;
}
.captcha-q strong{color:var(--or)}
.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:10px;
  background:linear-gradient(135deg,var(--or3),var(--or));
  font-family:var(--sc);font-size:13px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--nuit2);font-weight:500;
  box-shadow:var(--shadow-md);
  transition:all .35s var(--ease);
  margin-top:4px;
}
.rsvp-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--gold-glow)}
.rsvp-submit:disabled{opacity:.5;transform:none;cursor:not-allowed}
.rsvp-submit svg{stroke:var(--nuit2)}

/* Feedback */
.rsvp-feedback{
  font-family:var(--sans);font-size:13px;
  border-radius:8px;
  overflow:hidden;max-height:0;
  transition:max-height .4s var(--ease),padding .4s;
  text-align:center;
}
.rsvp-feedback.ok{
  max-height:80px;padding:14px;
  background:rgba(30,100,60,.25);
  border:1px solid rgba(30,200,100,.25);
  color:#5de0a0;
}
.rsvp-feedback.err{
  max-height:80px;padding:14px;
  background:rgba(160,30,30,.2);
  border:1px solid rgba(255,80,80,.2);
  color:#ff9494;
}

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

/* ══════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════ */
.footer{
  background:var(--nuit2);
  border-top:1px solid rgba(200,169,110,.1);
  padding:clamp(48px,8vw,80px) 24px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.footer-heb{
  font-family:var(--serif);
  font-size:clamp(28px,5vw,44px);
  font-weight:300;
  color:var(--or);
  letter-spacing:.1em;
  margin-bottom:8px;
}
.footer-name{
  font-family:var(--serif);
  font-size:clamp(20px,3.5vw,28px);
  font-weight:300;font-style:italic;
  color:var(--nacre);
}
.footer-date{
  font-family:var(--sc);font-size:11px;
  letter-spacing:.3em;color:rgba(250,249,247,.35);
}
.footer-lieu{
  font-family:var(--sc);font-size:10px;
  letter-spacing:.25em;color:rgba(250,249,247,.25);
}
.footer-sep{font-size:18px;color:rgba(200,169,110,.3);margin:8px 0}
.footer-credit{
  font-family:var(--sans);font-size:11px;
  color:rgba(250,249,247,.2);
}
.footer-credit span{color:rgba(200,169,110,.5);letter-spacing:.1em}

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

/* ══════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════ */
@media(max-width:600px){
  .hero-countdown{padding:14px 16px}
  .cd-b{min-width:48px}
  .cd-n{font-size:26px}
  .prog-event{grid-template-columns:32px auto 1fr;gap:0 12px}
  .prog-event-num{font-size:9px}
  .prog-day{font-size:32px}
  .rsvp-wrap{gap:32px}
  .pres-btns{flex-direction:column}
  .fields-row{grid-template-columns:1fr}
}
@media(max-width:380px){
  .hero-countdown{flex-wrap:wrap;justify-content:center}
  .cd-sep{display:none}
}
