*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{ background:#061b45;
font-family: "Libre Caslon Text", Georgia, serif; }
/* Titres / Boutons */
@import url("https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&display=swap");

/* Texte – fallback si Adobe Caslon n'est pas chargé */
@import url("https://fonts.googleapis.com/css2?family=Libre+Caslon+Text:wght@400;700&display=swap");


body:not(.is-started) .invitePage{
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

body.is-started .invitePage{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity .35s ease;
}

/* background en plein écran (ne bouge pas) */
.bg{
  position: fixed;
  inset: 0;
  background: url("assets/background.png") center / contain no-repeat;
  background-color:#061b45;
  z-index:-1;
}

/* écran */
.screen{
  min-height: 100vh;
  display:grid;
  place-items:center;
  padding: 16px;
}

/* ✅ REPÈRE RESPONSIVE : même ratio que ton background (3/5) */
.frame{
  position: relative;
  width: min(520px, 92vw);
  aspect-ratio: 3 / 5;
  max-height: calc(100vh - 32px);
}

/* ===== Positionnement RELATIF AU FRAME (c’est ça le responsive) ===== */
.logo{
  position:absolute;
  left:50%;
  top: 25%;
  transform: translate(-50%, -50%);
  width: min(320px, 60%);
  height:auto;
}


.btns{
  position:absolute;
  left:50%;
  top: 52%;
  transform: translate(-50%, -50%);
  display:flex;
  flex-direction:column;
  align-items:center;

  width: 78%;

  /* ✅ PAS de % ici */
  gap: clamp(12px, 2.2vh, 18px);
}


.btn{
  position:relative;
  width: 100%;
  height: clamp(58px, 7.2vh, 72px);
  display:block;
  text-decoration:none;
}


.btn-img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  border-radius: 999px;
}

.btn-text{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  transform: translateY(-4px);
  color:#111;
  font-weight:600;
  letter-spacing:.0em;
  font-size: clamp(12px, 1.6vw, 15px);
  text-transform: uppercase;
  text-align:center;
  padding: 0 14px;
  text-shadow: 0 1px 0 rgba(255,255,255,.35);
  font-family: "Adobe Caslon Pro", "Adobe Caslon", "Libre Caslon Text", Georgia, serif;
}

.btn-text-he{
  text-transform:none;
  letter-spacing:0;
  font-size: clamp(14px, 2.2vw, 20px);
  font-weight:600;
  transform: translateY(-2px);
}

.titles{
  position:absolute;
  left:50%;
  bottom: 12%;
  transform: translateX(-50%);
  text-align:center;
  width: 90%;
}


.t1{
  color:#d9b86a;
  font-size: clamp(25px, 2.2vw, 20px);
  letter-spacing: .14em;
  margin-bottom: 10px;
  font-family: "Adobe Caslon Pro", "Adobe Caslon", "Libre Caslon Text", Georgia, serif;
}

.t2{
  font-family: "Cinzel Decorative", serif !important;
  color:#d9b86a;
  font-size: clamp(28px, 4.2vw, 42px);
  letter-spacing: .08em;
  font-weight: 400;
}

/* ===== Topbar ===== */
.topbar{
  position: sticky;
  top: 0;
  z-index: 30;
  height: 64px;
  display: grid;
  grid-template-columns: 64px 1fr 64px;
  align-items: center;
  padding: 0 10px;
  background: rgba(6,27,69,.88);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(214,183,95,.30);
}
.topbar__logo{ width: 34px; height:auto; display:block; margin: 0 auto; }
.topbar__title{
  text-align:center;
  font-family: "Cinzel Decorative", serif;
  font-weight: 700;
  letter-spacing: .08em;
  color:#d9b86a;
  font-size: 20px;
}
.burger{
  justify-self:end;
  width: 44px; height: 44px;
  border:none; background:transparent;
  display:grid; gap:6px; padding:10px;
  cursor:pointer;
}
.burger span{ height:2px; width:100%; background:#d9b86a; border-radius:2px; }

/* Menu */
.menu{
  position: absolute;
  right: 10px;
  top: 64px;
  width: min(240px, 78vw);
  background: rgba(6,27,69,.96);
  border: 1px solid rgba(214,183,95,.30);
  border-radius: 14px;
  padding: 10px;
  display: none;
  z-index: 40;
}
.menu.is-open{ display:grid; gap:8px; }
.menu__link{
  color:#fff;
  text-decoration:none;
  padding: 10px 12px;
  border-radius: 10px;
}
.menu__link:hover{ background: rgba(214,183,95,.12); }

/* ===== Hero ===== */
.hero{
  position: relative;
  width: 100%;
  height: 56vh;
  min-height: 360px;
  max-height: 520px;
  overflow: hidden;
  background:#000;
}
.hero__img{ width:100%; height:100%; object-fit:cover; display:block; }
.hero__overlay{ position:absolute; inset:0; display:grid; place-items:center; }

.countdown{ width: min(520px, 92vw); text-align:center; margin-top: 190px;}
.countdown__label{
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size: 18px;
  text-shadow: 0 18px 40px rgba(0,0,0,.55);
  margin-bottom: 10px;
}
.countdown__grid{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap: 10px;
}
.cd{
  background: rgba(6,27,69,.60);
  border: 1px solid rgba(214,183,95,.35);
  border-radius: 14px;
  padding: 10px 8px;
  backdrop-filter: blur(6px);
}
.cd__n{ font-family:"Cinzel Decorative", serif; color:#d9b86a; font-size:22px; }
.cd__t{ opacity:.9; font-size:12px; color:#e7dfcf }

/* Photos */
.photo__img{
  width:100%;
  height: 46vh;
  min-height: 320px;
  max-height: 520px;
  object-fit: cover;
  display:block;
}

/* ===== Invite blocks ===== */
.invite{
  background: url("assets/background-2.png") center / cover no-repeat;
  padding: 34px 14px;
  display:grid;
  place-items:center;
}
.invite__frame{
  width: min(520px, 92vw);
  background: rgba(6,27,69,.92);
  border: 2px solid rgba(214,183,95,.95);
  border-radius: 26px;
  padding: 28px 18px 20px;
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
  position: relative;
}
.invite__mono{
  position: absolute;
  top: -66px;               /* ajuste verticalement */
  left: 50%;
  transform: translateX(-50%);

  width: 170px;            /* augmente librement */
  height: auto;

  margin: 0;               /* 🔥 supprime toute marge */
  pointer-events: none;
}

.invite__title{
  text-align:center;
  font-family: "Cinzel Decorative", serif;
  color:#d9b86a;
  letter-spacing: .06em;
  margin: 6px 0 14px;
  font-size: 22px;
  margin-top: 140px;
}
.text-invite{
  color: #fff;
}
.text-invite-footer{
  color: #d9b86a;
}
.invite__text{ text-align:center; line-height:1.45; font-size:16px; overflow:visible; min-height:0; }
.invite__frame{ overflow:visible; }
.invite__name{
  font-family:"Cinzel Decorative", serif;
  color:#d9b86a;
  font-weight:700;
  letter-spacing:.05em;
  font-size:20px;
  margin: 8px 0;
}
.invite__date{
  font-family:"Cinzel Decorative", serif;
  color:#d9b86a;
  font-weight:700;
  letter-spacing:.05em;
  margin: 10px 0;
}
.invite__time{ color:#fff; font-weight:700; }

/* Gold links */
.goldLink{
  position: relative;
  display:block;
  width: min(220px, 60vw);
  height: 54px;
  margin: 18px auto 0;
  text-decoration:none;
}
.goldLink__bg{ width:100%; height:100%; object-fit:cover; display:block; border-radius:999px; }
.goldLink__txt{
  position:absolute; inset:0;
  display:grid; place-items:center;
  letter-spacing:.12em;
  font-weight:700;
  color:#061b45eb;
}

/* RSVP */
.rsvp{
  background: url("assets/background-2.png") center / cover no-repeat;
  padding: 38px 14px 60px;
}
.rsvp__title{
  text-align:center;
  font-family:"Cinzel Decorative", serif;
  color:#d9b86a;
  letter-spacing:.06em;
  margin: 0 0 18px;
  font-size: 24px;
}
.form{
  width: min(520px, 92vw);
  margin: 0 auto;
  background: rgba(6,27,69,.92);
  border: 1px solid rgba(214,183,95,.35);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
}
.form__row{ display:grid; gap:8px; margin-bottom:14px; }
.form__label{ color:#e7dfcf; }
.form__input, .form__textarea{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border: 1px solid rgba(214,183,95,.35);
  background: rgba(2,10,30,.55);
  color:#fff;
  outline:none;
}
.form__input:focus, .form__textarea:focus{ border-color: rgba(214,183,95,.75); }
.form__grid{ display:grid; gap:10px; margin: 8px 0 14px; }
.check{ display:flex; gap:10px; align-items:center; }
.check input{ accent-color: #d9b86a; }

.submit{
  position: relative;
  display:block;
  width: min(240px, 70vw);
  height: 56px;
  margin: 10px auto 0;
  border:none;
  background: transparent;
  cursor:pointer;
}
.submit__bg{ width:100%; height:100%; object-fit:cover; display:block; border-radius:999px; }
.submit__txt{
  position:absolute; inset:0;
  display:grid; place-items:center;
  letter-spacing:.12em;
  font-weight:700;
  color:#111;
}
.form__hint{ margin: 12px 0 0; opacity:.85; font-size:12px; text-align:center; }

/* ===== Intro overlay ===== */
.intro{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;

  /* ✅ fond plein écran */
  background: url("assets/background.png") center / cover no-repeat;

  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity .55s ease, visibility .55s ease;
}

/* repère central pour caler logo/boutons/titres */
.intro__frame{
  width: min(520px, 92vw);
  aspect-ratio: 3 / 5;
  max-height: calc(100vh - 32px);

  position: relative;
  display: grid;
  place-items: center;

  background: transparent; /* ✅ plus d’image ici */
  transform: scale(1);
  transition: transform .55s ease;
}

.intro.is-leaving{
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.intro.is-leaving .intro__frame{
  transform: scale(.985);
}


.intro__logo{
  width: min(300px, 56%);
  height:auto;
  margin-top: -20%;
}

.intro__btns{
  display:flex;
  flex-direction:column;
  gap: 16px;
  width: min(380px, 72vw);

  /* ✅ remonte les boutons */
  margin-top: -40%;
}


.introBtn{
  position: relative;
  width: 100%;
  height: 64px;
  border:none;
  background: transparent;
  cursor:pointer;
}
.introBtn__bg{ width:100%; height:100%; object-fit:cover; border-radius:999px; display:block; }
.introBtn__txt{
  position:absolute; inset:0;
  display:grid; place-items:center;
  font-family: "Adobe Caslon Pro", "Adobe Caslon", "Libre Caslon Text", Georgia, serif;
  font-weight:400;
  letter-spacing:.0em;
  color:#111;
  text-transform: uppercase;
}

/* overlay titles */
.intro__titles{
  text-align:center;
  margin-top: -2%;
}
.intro__titles .t1{
  font-family: "Adobe Caslon Pro", "Adobe Caslon", "Libre Caslon Text", Georgia, serif;
  color:#d9b86a;
  font-size: 20px;
  letter-spacing: .14em;
  margin-bottom: 30px;
  font-weight: 900;
}
.intro__titles .t2{
  font-family: "Cinzel Decorative", serif;
  font-weight: 400;
  color:#d9b86a;
  font-size: 30px;
  letter-spacing: .08em;
  margin-bottom: 60px;
}

/* hidden state */
.intro.is-hidden{
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.checkbox-text{
  color: #fff;
  }

/* ===== Typographie hébreu (Frank Ruhl Libre) ===== */
body.is-rtl,
body.is-rtl .invite__text,
body.is-rtl .invite__text p,
body.is-rtl .text-invite,
body.is-rtl .text-invite-footer,
body.is-rtl .invite__name,
body.is-rtl .invite__date,
body.is-rtl .invite__title,
body.is-rtl .menu,
body.is-rtl .menu__link,
body.is-rtl .rsvp,
body.is-rtl .form,
body.is-rtl .form__label,
body.is-rtl .form__input,
body.is-rtl .form__textarea,
body.is-rtl .eventRow__title,
body.is-rtl .countBox__label,
body.is-rtl .presenceBtn,
body.is-rtl .backBtn,
body.is-rtl .toast {
  font-family: "Frank Ruhl Libre", David, "Times New Roman", serif !important;
}

body.is-rtl .invite__text,
body.is-rtl .invite__text p,
body.is-rtl .text-invite {
  line-height: 1.6;
  letter-spacing: 0.02em;
  font-weight: 500;
}

body.is-rtl .invite__title,
body.is-rtl .invite__name,
body.is-rtl .invite__date {
  font-weight: 600;
}

body.is-rtl .invite__text,
body.is-rtl .rsvp,
body.is-rtl .menu{
  text-align: right;
}

body.is-rtl .menu{
  left: 10px;
  right: auto;
}

body.is-rtl .form__grid{
  text-align: right;
}

body.is-rtl .check{
  flex-direction: row-reverse;
  justify-content: flex-end;
}

body.is-rtl .checkbox-text{
  margin-right: 8px;
  margin-left: 0;
}

/* ===== Toast ===== */
.toast{
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%) translateY(20px);
  z-index: 99999;
  color: #ffffff;

  width: min(520px, 92vw);
  padding: 12px 14px;
  border-radius: 14px;

  background: rgba(6,27,69,.92);
  border: 1px solid rgba(214,183,95,.35);
  backdrop-filter: blur(8px);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);

  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  text-align: center;
  font-family: "Libre Caslon Text", Georgia, serif;
}

.toast.is-show{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.toast.is-success{
  border-color: rgba(214,183,95,.70);
}

.toast.is-error{
  border-color: rgba(255,120,120,.65);
}

/* ===== Submit loading ===== */
.submit[disabled]{
  cursor: not-allowed;
  opacity: .85;
}

.submit__loader{
  position: absolute;
  inset: 0;
  display: none;
  place-items: center;
}

.submit.is-loading .submit__txt{ opacity: 0; }
.submit.is-loading .submit__loader{ display: grid; }

.spinner{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,.25);
  border-top-color: rgba(0,0,0,.85);
  animation: spin .9s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* Centre les textes même en hébreu */
body.is-rtl .invite__text,
body.is-rtl .invite__text p,
body.is-rtl .invite__name,
body.is-rtl .invite__date,
body.is-rtl .text-invite,
body.is-rtl .text-invite-footer{
  text-align: center;
}

/* RSVP events layout */
.rsvpEvents{
  display: grid;
  gap: 14px;
  margin: 14px 0 18px;
}

.eventRow{
  border: 1px solid rgba(214,183,95,.28);
  background: rgba(2,10,30,.28);
  border-radius: 16px;
  padding: 14px;
}

.eventRow__head{
  display: grid;
  gap: 10px;
  justify-items: center;
  margin-bottom: 12px;
}

.eventRow__title{
  font-family: "Cinzel Decorative", serif;
  color: #d9b86a;
  letter-spacing: .05em;
  text-align: center;
  font-size: 18px;
}

/* Présent / Absent */
.presenceToggle{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  width: min(420px, 100%);
}

.presenceBtn{
  border: 1px solid rgba(214,183,95,.35);
  background: rgba(6,27,69,.35);
  color: #fff;
  border-radius: 999px;
  padding: 10px 12px;
  cursor: pointer;
  font-family: "Libre Caslon Text", Georgia, serif;
}

.presenceBtn.is-active{
  background: rgba(214,183,95,.18);
  border-color: rgba(214,183,95,.70);
}

/* Adultes / Enfants */
.eventRow__counts{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.countBox{
  border: 1px solid rgba(214,183,95,.18);
  border-radius: 14px;
  padding: 12px;
  text-align: center;
}

.countBox__label{
  font-family: "Libre Caslon Text", Georgia, serif;
  opacity: .95;
  margin-bottom: 10px;
  color: #fff;
}

.stepper{
  display: grid;
  grid-template-columns: 44px 1fr 44px;
  align-items: center;
  gap: 8px;
}

.stepper__btn{
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(214,183,95,.28);
  background: rgba(6,27,69,.35);
  color: #fff;
  font-size: 20px;
  cursor: pointer;
}

.stepper__value{
  font-family: "Cinzel Decorative", serif;
  color: #d9b86a;
  font-size: 22px;
}

/* Quand absent : on grise et on bloque */
.eventRow.is-absent{
  opacity: .70;
}
.eventRow.is-absent .stepper__btn{
  opacity: .45;
  cursor: not-allowed;
}

.backBtn{
  margin: 12px auto 0;
  display: block;

  background: transparent;
  border: none;
  color: #d9b86a;

  font-family: "Libre Caslon Text", Georgia, serif;
  font-size: 15px;
  letter-spacing: .08em;

  cursor: pointer;
  opacity: .85;
}

.backBtn:hover{
  opacity: 1;
  text-decoration: underline;
}

/* Force typo hébreu en fin de fichier pour écraser toute règle suivante */
body.is-rtl .invite__title,
body.is-rtl .invite__name,
body.is-rtl .invite__date,
body.is-rtl .invite__text,
body.is-rtl .invite__text p,
body.is-rtl .text-invite,
body.is-rtl .text-invite-footer,
body.is-rtl .eventRow__title,
body.is-rtl .topbar__title {
  font-family: "Frank Ruhl Libre", David, "Times New Roman", serif !important;
}
