/* ===========================
   BASE / SHELL
   =========================== */

html{
  scroll-behavior:smooth;
}

body.wpz-wedding-page{
  margin:0;
  /* Fond + texte pilotés par les variables du design */
  background:var(--wpz-wedding-bg-soft);
  color:var(--wpz-wedding-text);

  /* Police par défaut (texte courant) */
  font-family:var(
    --wpz-font-family-body,
    system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif
  );


  --wpz-adminbar-offset:0px;
}

/* Offset admin bar (valeur CSS var) */
body.admin-bar.wpz-wedding-page{
  --wpz-adminbar-offset:32px;
}
@media (max-width:782px){
  body.admin-bar.wpz-wedding-page{
    --wpz-adminbar-offset:46px;
  }
}

.wpz-wedding-shell{
  min-height:100vh;
  /* Fond pris sur la variable globale */
  background:var(--wpz-wedding-bg-soft);
}

/* Racine du “design system” du site de mariage */
.wpz-wedding-root{
  /* Palette principale (fallback – sera surchargée par le template ou le panneau Design) */
  --wpz-wedding-primary:   #9C1657;
  --wpz-wedding-secondary: #5CA174;
  --wpz-wedding-accent:    #f59e0b;

  /* Surfaces & texte */
  --wpz-wedding-bg-soft:   #faf7f5;  /* fond global doux */
  --wpz-wedding-card-bg:   #ffffff;  /* cartes / sections */
  --wpz-wedding-text:      #111827;  /* texte principal */
  --wpz-wedding-muted:     #6b7280;  /* texte atténué / légendes */
  --wpz-wedding-surface-dark: #111827; /* surfaces foncées (drawer, FAB, etc.) */

  /* Typo (en rem) */
  --wpz-font-hero-title:     1.7rem;
  --wpz-font-section-title:  1.1rem;
  --wpz-font-body:           0.95rem;

  /* Layout (en px, stockés comme nombres) */
  --wpz-page-max-width:        1060;
  --wpz-page-padding-x:        16;
  --wpz-page-padding-top:      80;
  --wpz-page-padding-bottom:   64;
  --wpz-section-margin-bottom: 22;

  /* Aliases “brand” */
  --brand: var(--wpz-wedding-primary);
  --soft:  var(--wpz-wedding-secondary);
  --ink:   var(--wpz-wedding-text);
  --muted: var(--wpz-wedding-muted);

  /* Rôles de couleur (catégories visuelles) */
  --wpz-role-primary-bg:   var(--wpz-wedding-primary);
  --wpz-role-primary-fg:   #ffffff;

  --wpz-role-secondary-bg: color-mix(in srgb, var(--wpz-wedding-secondary) 14%, #ffffff 86%);
  --wpz-role-secondary-fg: var(--wpz-wedding-surface-dark);

  --wpz-role-accent-bg:    var(--wpz-wedding-accent);
  --wpz-role-accent-fg:    #ffffff;

/* === TYPO – valeurs par défaut écrasables par le panneau Design === */
--wpz-font-family-body:    system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
--wpz-font-family-hero:    var(--wpz-font-family-body);
--wpz-font-family-section: var(--wpz-font-family-body);

--wpz-font-hero-title:     2rem;
--wpz-font-section-title:  1.25rem;
--wpz-font-body:           1rem;


  /* Dérivées / utilitaires (tout reste lié au set ci-dessus) */
  --wpz-border-soft:   color-mix(in srgb, var(--wpz-wedding-text) 8%,  transparent);
  --wpz-border-strong: color-mix(in srgb, var(--wpz-wedding-text) 16%, transparent);

  /* Vignettes / chips / petits boutons */
  --wpz-chip-border:  color-mix(in srgb, var(--wpz-wedding-secondary) 30%, transparent);
  --wpz-chip-bg:      color-mix(in srgb, var(--wpz-wedding-secondary) 8%, var(--wpz-wedding-card-bg) 92%);

  --wpz-topbar-border:color-mix(in srgb, var(--wpz-wedding-primary) 10%, transparent);
  --wpz-topbar-bg-from:color-mix(in srgb, var(--wpz-wedding-bg-soft) 92%, #ffffff 8%);
  --wpz-topbar-bg-to:  color-mix(in srgb, var(--wpz-wedding-bg-soft) 96%, #ffffff 4%);

  --wpz-hero-overlay-from: color-mix(in srgb, var(--wpz-wedding-primary) 8%,  rgba(0,0,0,.35));
  --wpz-hero-overlay-to:   color-mix(in srgb, var(--wpz-wedding-surface-dark) 70%, rgba(0,0,0,.4));

  --wpz-drawer-bg:   var(--wpz-wedding-surface-dark);
  --wpz-drawer-text: #f9fafb;

  --wpz-fab-bg-main: var(--wpz-wedding-surface-dark);
  --wpz-fab-bg-design: linear-gradient(135deg,var(--wpz-wedding-primary),var(--wpz-wedding-secondary));
  --wpz-fab-text:    #ffffff;

  /* RSVP = rôle primaire */
  --wpz-rsvp-bg:     var(--wpz-role-primary-bg);
  --wpz-rsvp-text:   var(--wpz-role-primary-fg);
}

/* Appliquer le fond global à l’intérieur de la racine */
.wpz-wedding-root{
  background:var(--wpz-wedding-bg-soft);
}

/* Contenu principal */
.wpz-wedding-main{
  max-width: calc(var(--wpz-page-max-width, 1060) * 1px);
  margin:0 auto;
  padding:
    calc(
      var(--wpz-adminbar-offset, 0px)
      + (var(--wpz-page-padding-top, 80) * 1px)
    )
    calc(var(--wpz-page-padding-x, 16) * 1px)
    calc(var(--wpz-page-padding-bottom, 64) * 1px);

}

main.wpz-wedding-main
{
	padding-top:0px;
}

/* ===========================
   TOPBAR / NAV
   =========================== */

.wpz-wedding-topbar{
  position:fixed;
  inset-inline:0;
  top:var(--wpz-adminbar-offset, 0px);
  z-index:1000;
  backdrop-filter:blur(12px);
  background:linear-gradient(
    to right,
    var(--wpz-topbar-bg-from),
    var(--wpz-topbar-bg-to)
  );
  border-bottom:1px solid var(--wpz-topbar-border);
}

.wpz-wedding-topbar-inner{
  max-width: calc(var(--wpz-page-max-width, 1060) * 1px);
  margin:0 auto;
  padding:10px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.wpz-wedding-topbar-title{
  font-size:.9rem;
  font-weight:600;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:var(--wpz-wedding-text);
}
.wpz-wedding-topbar-title span.badge{
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--wpz-wedding-primary) 20%, transparent);
  margin-right:6px;
}

/* Liens de nav (desktop) */
.wpz-wedding-topnav{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.wpz-wedding-topnav a{
  font-size:.78rem;
  padding:4px 9px;
  border-radius:999px;
  text-decoration:none;
  color:var(--wpz-wedding-text);
  border:1px solid transparent;
  background:transparent;
  transition:
    background-color .15s ease,
    border-color .15s ease,
    color .15s ease;
}
.wpz-wedding-topnav a:hover{
  border-color:color-mix(in srgb, var(--wpz-wedding-primary) 18%, transparent);
  background:var(--wpz-wedding-card-bg);
}
.wpz-wedding-topnav a.wpz-rsvp{
  background:var(--wpz-rsvp-bg);
  color:var(--wpz-rsvp-text);
}

/* Onglet actif – topbar */
.wpz-wedding-topnav a.is-active{
  background:rgba(255,255,255,.12);
  color:var(--wpz-wedding-accent);
  font-weight:600;
}

/* Onglet actif – drawer mobile */
.wpz-wedding-drawer-menu a.is-active{
  background:rgba(15,23,42,.08);
  color:var(--wpz-wedding-accent);
  font-weight:600;
}




/* Burger mobile */
.wpz-wedding-burger{
  display:none;
  position:relative;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--wpz-wedding-primary) 15%, rgba(15,23,42,.12));
  background:var(--wpz-wedding-card-bg);
  padding:0;
  margin-left:6px;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px rgba(15,23,42,.08);
}
.wpz-wedding-icon{
  width:20px;
  height:20px;
  display:block;
  stroke:var(--wpz-wedding-text);
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  transition:
    opacity .18s ease,
    transform .18s ease,
    stroke .18s ease;
}
.wpz-wedding-icon--menu,
.wpz-wedding-icon--close{
  position:absolute;
}
.wpz-wedding-icon--menu{
  opacity:1;
  transform:scale(1);
}
.wpz-wedding-icon--close{
  opacity:0;
  transform:scale(0.9);
}
.wpz-wedding-burger.is-open .wpz-wedding-icon--menu{
  opacity:0;
  transform:scale(0.9);
}
.wpz-wedding-burger.is-open .wpz-wedding-icon--close{
  opacity:1;
  transform:scale(1);
}
.wpz-wedding-burger.is-open .wpz-wedding-icon{
  stroke:var(--wpz-wedding-primary);
}

@media (max-width:768px){
  .wpz-wedding-topnav{
    display:none;
  }
  .wpz-wedding-burger{
    display:flex !important; /* force l’affichage du burger en mobile */
  }
}


/* Drawer mobile */
.wpz-wedding-drawer{
  position:fixed;
  inset-block:var(--wpz-adminbar-offset, 0px) 0;
  inset-inline-end:0;
  width:260px;
  max-width:80vw;
  background:var(--wpz-drawer-bg);
  color:var(--wpz-drawer-text);
  transform:translateX(100%);
  transition:transform .22s ease-out;
  box-shadow:-18px 0 40px rgba(15,23,42,.55);
  z-index:998;
}
.wpz-wedding-drawer-inner{
  padding:16px 18px 20px;
  display:flex;
  flex-direction:column;
  height:100%;
}
.wpz-wedding-drawer-close{
  align-self:flex-end;
  border:none;
  background:transparent;
  color:#e5e7eb;
  font-size:1.4rem;
  cursor:pointer;
  margin:-4px 0 6px;
}
.wpz-wedding-drawer-menu{
  list-style:none;
  padding:10px 0 0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.wpz-wedding-drawer-menu a{
  display:block;
  padding:8px 10px;
  border-radius:10px;
  text-decoration:none;
  color:var(--wpz-drawer-text);
  font-size:.95rem;
}
.wpz-wedding-drawer-menu a:hover{
  background:rgba(249,250,251,.08);
}
.wpz-wedding-drawer-backdrop{
  position:fixed;
  inset:var(--wpz-adminbar-offset, 0px) 0 0 0;
  background:rgba(0,0,0,0.30);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease-out;
  z-index:997;
}

.wpz-panel-backdrop{
  position:fixed;
  inset:var(--wpz-adminbar-offset, 0px) 0 0 0;
  background:rgba(0,0,0,0.32);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease-out;
  z-index:10005;
}
.wpz-panel-backdrop.is-open{
  opacity:1;
  pointer-events:auto;
}

body.admin-bar .wpz-panel-backdrop{
  top:var(--wpz-adminbar-offset, 32px) !important;
}

.wpz-wedding-drawer.is-open{
  transform:translateX(0);
}
.wpz-wedding-drawer-backdrop.is-open{
  opacity:1;
  pointer-events:auto;
}
.body--wedding-drawer-open{
  overflow:hidden;
}

/* ===========================
   HERO PLEIN LARGEUR
   =========================== */

.wpz-wedding-hero{
  position:relative;
  /* pleine largeur par rapport au container, collé au header */
  margin:0 calc(-1 * var(--wpz-page-padding-x, 16) * 1px) 32px;
  border-radius:0;
  box-shadow:none;
  background:transparent;
  color:#fff;
}

.wpz-wedding-hero-bg{
  position:absolute;
  inset:0;
  background-position:center;
  background-size:cover;
  opacity:0.9;
}

.wpz-wedding-hero-inner{
  position:relative;
  padding:32px 24px 30px;
  backdrop-filter:blur(4px);
  background:linear-gradient(
    135deg,
    var(--wpz-hero-overlay-from),
    var(--wpz-hero-overlay-to)
  );
  }
  


/* Desktop : on reste en une seule colonne, juste un peu plus de padding */
@media (min-width:768px){
  .wpz-wedding-hero-inner{
    padding:40px 40px 34px;
  }
}

/* Bloc gauche : avatars + noms (tout le hero est une colonne, mais ici : photos à gauche, infos à droite) */
.wpz-wedding-hero-left{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:0;
  flex-wrap:wrap;
}

.wpz-wedding-avatars{
  display:flex;
  flex-direction:column;       /* les 2 photos l'une au-dessus de l'autre */
  gap:10px;
  align-items:flex-start;
}

.wpz-wedding-avatar{
  width:72px;
  height:72px;
  border-radius:999px;
  overflow:hidden;
  border:3px solid rgba(255,255,255,.85);
  box-shadow:0 12px 24px rgba(15,23,42,.35);
  background:rgba(15,23,42,.25);
}

.wpz-wedding-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* plus besoin de décalage horizontal entre les avatars */
.wpz-wedding-avatar + .wpz-wedding-avatar{
  margin-left:0;
}

.wpz-wedding-names{
  margin-left:12px;
}

.wpz-wedding-tagline{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  opacity:.85;
}

.wpz-wedding-title{
  font-size: var(--wpz-font-hero-title);
  font-family: var(--wpz-font-family-hero, var(--wpz-font-family-body));
  font-weight: 700;
}

@media (max-width:767px){
  .wpz-wedding-title{
    font-size: calc(var(--wpz-font-hero-title) - .25rem);
  }
}

.wpz-wedding-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.wpz-wedding-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:999px;
  font-size:.78rem;
  background:rgba(17,24,39,.65);
  backdrop-filter:blur(6px);
}

.wpz-wedding-pill-badge{
  background:var(--wpz-role-accent-bg);
  color:var(--wpz-role-accent-fg);
  padding:4px 10px;
  border-radius:999px;
  font-size:.8rem;
  font-weight:600;
}

/* Bloc droit : message + CTA – on garde la classe au cas où,
   mais le texte message est supprimé dans le HTML */
.wpz-wedding-hero-right{
  color:#f9fafb;
  margin-top:16px;
}

.wpz-wedding-hero-right p{
  margin:0;
  font-size:var(--wpz-font-body);
  line-height:1.6;
  max-width:38rem;
}

.wpz-wedding-hero-ctas{
  margin-top:16px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.wpz-wedding-btn{
  border-radius:999px;
  border:none;
  padding:8px 16px;
  font-size:.9rem;
  font-weight:500;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  text-decoration:none;
  transition:
    transform .15s ease,
    box-shadow .15s ease,
    background-color .15s ease,
    color .15s ease;
}

/* Bouton primaire = rôle primary */
.wpz-wedding-btn-primary{
  background:var(--wpz-role-primary-bg);
  color:var(--wpz-role-primary-fg);
  box-shadow:0 8px 18px rgba(15,23,42,.12);
}
.wpz-wedding-btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 26px rgba(15,23,42,.16);
}

/* Bouton ghost = rôle secondary (soft) */
.wpz-wedding-btn-ghost{
  background:var(--wpz-role-secondary-bg);
  color:var(--wpz-role-secondary-fg);
}
.wpz-wedding-btn-ghost:hover{
  transform:translateY(-1px);
}
/* ===========================
   SECTIONS / CARTES
   =========================== */

.wpz-wedding-sections{
  margin-top:28px;
}
.wpz-wedding-section{
  background:var(--wpz-wedding-card-bg);
  border-radius:20px;
  padding:20px 16px 18px;
  box-shadow:0 10px 20px rgba(15,23,42,.06);
  margin-bottom: calc(var(--wpz-section-margin-bottom, 22) * 1px);
}
@media (min-width:768px){
  .wpz-wedding-section{
    padding:22px 20px 20px;
  }
}
.wpz-wedding-section-header{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  margin-bottom:10px;
}
.wpz-wedding-section-title{
  font-size: var(--wpz-font-section-title);
  font-family: var(--wpz-font-family-section, var(--wpz-font-family-body));
}

.wpz-wedding-section-title span:last-child{
  font-family: var(--wpz-font-family-section, var(--wpz-font-family-body));
}

.wpz-wedding-section-title span.emoji{
  font-size:1.2rem;
}
.wpz-wedding-section-sub{
  font-size:.8rem;
  color:var(--wpz-wedding-muted);
}
.wpz-wedding-story{
  font-size:var(--wpz-font-body);
  color:var(--wpz-wedding-text);
  line-height:1.7;
}

/* =========================================
   Compte à rebours – version “wedding dreamy”
   ========================================= */

.wpz-wedding-countdown-shell{
  display:flex;
  justify-content:center;
  margin-top:4px;
}

.wpz-wedding-countdown-card{
  position:relative;
  max-width:520px;
  width:100%;
  padding:18px 20px 20px;
  border-radius:24px;
  background:var(--wpz-wedding-card-bg, rgba(255,255,255,0.9));
  box-shadow:0 18px 45px rgba(15,23,42,0.16);
  overflow:hidden;
}

/* Voile lumineux tout doux */
.wpz-wedding-countdown-card::before{
  content:"";
  position:absolute;
  inset:-35%;
  background:radial-gradient(circle at top left, rgba(255,255,255,0.55), transparent 60%);
  opacity:.75;
  pointer-events:none;
}

/* Label au-dessus du J-xx */
.wpz-wedding-countdown-label{
  position:relative;
  text-align:center;
  margin-bottom:10px;
  z-index:1;
}

.wpz-wedding-countdown-eyebrow{
  display:inline-block;
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--wpz-wedding-muted, rgba(15,23,42,.6));
}

.wpz-wedding-countdown-heading{
  margin:4px 0 2px;
  font-size:1.15rem;
  font-weight:600;
  color:var(--wpz-wedding-text, #111827);
}

.wpz-wedding-countdown-meta{
  margin:0;
  font-size:.85rem;
  color:var(--wpz-wedding-muted, rgba(15,23,42,.7));
  display:inline-flex;
  align-items:center;
  gap:4px;
}

.wpz-wedding-countdown-pin{
  font-size:.95rem;
}

/* Layout cercle + texte */
.wpz-wedding-countdown-layout{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

/* Cercle décoratif autour du J-xx */
.wpz-wedding-countdown-ring{
  width:128px;
  height:128px;
  border-radius:999px;
  border:1px dashed rgba(148,163,184,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

/* Petits points décoratifs */
.wpz-wedding-countdown-ring::before,
.wpz-wedding-countdown-ring::after{
  content:"";
  position:absolute;
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--wpz-wedding-accent, #e07a5f);
  opacity:.22;
}

.wpz-wedding-countdown-ring::before{
  top:10px;
  left:18px;
}

.wpz-wedding-countdown-ring::after{
  bottom:12px;
  right:20px;
}

/* Badge J-xx au centre */
.wpz-wedding-countdown-badge{
  font-size:1.9rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:10px 26px;
  border-radius:999px;
  background:var(--wpz-role-accent-bg, rgba(15,23,42,.09));
  color:var(--wpz-role-accent-fg, var(--wpz-wedding-accent, #b45309));
  box-shadow:0 0 0 1px rgba(255,255,255,.7);
}

/* Sous-texte romantique */
.wpz-wedding-countdown-subtitle{
  margin:2px 0 0;
  padding:0 12px;
  font-size:.86rem;
  line-height:1.5;
  text-align:center;
  color:var(--wpz-wedding-muted, rgba(15,23,42,.78));
}

/* Mobile : on laisse respirer */
@media (max-width:640px){
  .wpz-wedding-countdown-card{
    border-radius:20px;
    padding:14px 14px 16px;
  }
  .wpz-wedding-countdown-ring{
    width:118px;
    height:118px;
  }
  .wpz-wedding-countdown-badge{
    font-size:1.6rem;
    padding:8px 20px;
  }
  .wpz-wedding-countdown-subtitle{
    font-size:.83rem;
  }
}

/* ============================
   WPZ Wedding – Section "Notre histoire"
   ============================ */

#histoire .wpz-wedding-section-header {
  margin-bottom: 8px;
  display: block; /* important : on casse le flex global éventuel */
}

#histoire .wpz-wedding-section-title {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  width: 100%; /* le conteneur prend toute la largeur */
}

#histoire .wpz-wedding-section-title .emoji {
  font-size: 1.7rem;
  line-height: 1;
}

#histoire .wpz-wedding-section-title span:nth-child(2) {
  display: block;
  flex: 1;
  font-size: var(--wpz-font-section-title);
  color: color-mix(in oklab, var(--brand) 35%, var(--muted) 65%);
  letter-spacing: 0.01em;
}

/* Texte "histoire" façon citation manuscrite */
#histoire .wpz-wedding-story {
  margin-top: 10px;
  padding-left: 18px;
  border-left: 2px solid color-mix(in oklab, var(--brand) 70%, #ffffff 30%);
}

#histoire .wpz-wedding-story-text {
  margin: 0;
  font-family:
    "Segoe Script",
    "Lucida Handwriting",
    "Brush Script MT",
    "Comic Sans MS",
    cursive;
  font-size: 1.1rem;
  line-height: 1.7;
  color: var(--ink);
}

/* Un peu plus doux sur mobile */
@media (max-width: 640px) {
  #histoire .wpz-wedding-section-title span:nth-child(2) {
    font-size: 1.2rem;
  }
  #histoire .wpz-wedding-story-text {
    font-size: 1.02rem;
  }
}

/* ===========================
   Carrousel "Notre histoire"
   =========================== */

.wpz-story-carousel{
  margin: 12px 0 14px;
  position: relative;
  border-radius: 16px;
  background: color-mix(in srgb, var(--wpz-wedding-bg-soft) 80%, #ffffff 20%);
  padding: 10px 36px;
  overflow: hidden;
}

@media (max-width:640px){
  .wpz-story-carousel{
    padding: 10px 14px;
  }
}

.wpz-story-carousel-viewport{
  overflow: hidden;
}

.wpz-story-carousel-track{
  display: flex;
  gap: 10px;
  transition: transform .28s ease-out;
  touch-action: pan-y;
}

.wpz-story-slide{
  flex: 0 0 100%;
  max-width: 100%;
}

.wpz-story-photo{
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(15,23,42,.18);
}

.wpz-story-photo img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}

/* Flèches desktop */
.wpz-story-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:rgba(17,24,39,.82);
  color:#f9fafb;
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:1.2rem;
  box-shadow:0 8px 16px rgba(15,23,42,.35);
}

.wpz-story-arrow--prev{ left:8px; }
.wpz-story-arrow--next{ right:8px; }

@media (max-width:640px){
  .wpz-story-arrow{
    display:none;
  }
}

/* Dots */
.wpz-story-dots{
  display:flex;
  justify-content:center;
  gap:5px;
  margin-top:8px;
}

.wpz-story-dot{
  width:7px;
  height:7px;
  border-radius:999px;
  border:none;
  padding:0;
  background:rgba(148,163,184,.7);
  cursor:pointer;
}
.wpz-story-dot.is-active{
  width:18px;
  background:var(--wpz-wedding-accent);
}

/* Bouton "Ajouter une photo" pour admin */
.wpz-story-add{
  flex:0 0 100%;
  max-width:100%;
  border:1px dashed rgba(148,163,184,.8);
  border-radius:14px;
  background:rgba(15,23,42,.03);
  color:var(--wpz-wedding-muted);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  font-size:.82rem;
  padding:26px 12px;
  cursor:pointer;
}
.wpz-story-add span:first-child{
  font-size:1.4rem;
}

/* Stylo / croix sur la photo (admin uniquement) */
.wpz-story-photo-actions{
  position:absolute;
  top:6px;
  right:6px;
  display:flex;
  gap:4px;
}

.wpz-story-photo-actions button{
  border:none;
  width:24px;
  height:24px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.75rem;
  cursor:pointer;
  box-shadow:0 4px 10px rgba(15,23,42,.45);
}

.wpz-story-photo-edit{
  background:rgba(15,23,42,.84);
  color:#f9fafb;
}
.wpz-story-photo-delete{
  background:#fee2e2;
  color:#b91c1c;
}

/* ===========================
   Lightbox photos histoire
   =========================== */

.wpz-story-lightbox{
  position:fixed;
  inset:0;
  z-index:10020;
  display:flex;
  align-items:center;
  justify-content:center;
}

.wpz-story-lightbox[hidden]{
  display:none;
}

.wpz-story-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.7);
}

.wpz-story-lightbox-inner{
  position:relative;
  max-width:96vw;
  max-height:92vh;
  display:flex;
  align-items:center;
  justify-content:center;
}

.wpz-story-lightbox-figure{
  margin:0;
  max-width:100%;
  max-height:100%;
}

#wpzStoryLightboxImg{
  max-width:100%;
  max-height:92vh;
  display:block;
  border-radius:16px;
  box-shadow:0 20px 40px rgba(15,23,42,.6);
}

.wpz-story-lightbox-close{
  position:absolute;
  top:-36px;
  right:0;
  border:none;
  background:transparent;
  color:#e5e7eb;
  font-size:2rem;
  cursor:pointer;
}

.wpz-story-lightbox-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:rgba(15,23,42,.85);
  color:#f9fafb;
  width:34px;
  height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:1.4rem;
}
.wpz-story-lightbox-arrow--prev{ left:-42px; }
.wpz-story-lightbox-arrow--next{ right:-42px; }

@media (max-width:640px){
  .wpz-story-lightbox-arrow--prev{ left:4px; }
  .wpz-story-lightbox-arrow--next{ right:4px; }
  .wpz-story-lightbox-close{
    top:8px;
    right:8px;
  }
}

/* ===========================
   LIEUX
   =========================== */

.wpz-wedding-places{
  display:flex;
  flex-direction:column;
  gap:12px;
}
@media (min-width:768px){
  .wpz-wedding-places{
    flex-direction:row;
  }
}
.wpz-wedding-place-card{
  flex:1 1 0;
  background:linear-gradient(
    145deg,
    var(--wpz-wedding-card-bg),
    color-mix(in srgb, var(--wpz-wedding-bg-soft) 90%, #ffffff 10%)
  );
  border-radius:16px;
  padding:12px 12px 10px;
  border:1px solid var(--wpz-border-soft);
}
.wpz-wedding-place-media{
  border-radius:12px;
  overflow:hidden;
  margin-bottom:8px;
  max-height:180px;
}
.wpz-wedding-place-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.wpz-wedding-place-label{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--wpz-wedding-muted);
  margin-bottom:6px;
}
.wpz-wedding-place-title{
  font-size:.95rem;
  font-weight:600;
  margin-bottom:4px;
  color:var(--wpz-wedding-text);
}
.wpz-wedding-place-meta{
  font-size:.82rem;
  color:var(--wpz-wedding-muted);
  margin-bottom:6px;
}
.wpz-wedding-place-notes{
  font-size:.85rem;
  color:var(--wpz-wedding-text);
}
.wpz-wedding-place-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}
.wpz-wedding-chip{
  font-size:.78rem;
  border-radius:999px;
  padding:4px 9px;
  border:1px solid var(--wpz-chip-border);
  background:var(--wpz-chip-bg);
  display:inline-flex;
  align-items:center;
  gap:4px;
  text-decoration:none;
  color:var(--wpz-wedding-text);
}

/* ===========================
   PROGRAMME
   =========================== */

.wpz-wedding-timeline{
  margin-top:4px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.wpz-wedding-timeline-item{
  display:flex;
  gap:10px;
  padding:8px 10px;
  border-radius:999px;
  align-items:center;
  background:color-mix(
    in srgb,
    var(--wpz-wedding-card-bg) 82%,
    var(--wpz-wedding-bg-soft) 18%
  );
  border:1px solid var(--wpz-border-soft);
}

.wpz-wedding-timeline-item:last-child{
  margin-bottom:0;
}

.wpz-wedding-time{
  min-width:68px;
  display:flex;
  justify-content:flex-start;
}

.wpz-wedding-time-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 10px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.02em;
  background:var(--wpz-role-secondary-bg);
  color:var(--wpz-role-secondary-fg);
  border:1px solid color-mix(in srgb, var(--wpz-wedding-secondary) 40%, transparent);
}

.wpz-wedding-step{
  display:flex;
  flex-direction:column;
  gap:2px;
  font-size:.88rem;
  color:var(--wpz-wedding-text);
  flex:1 1 auto;
}

.wpz-wedding-step-title{
  display:flex;
  align-items:center;
  gap:6px;
  font-weight:500;
}

.wpz-wedding-step-icon{
  width:20px;
  height:20px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:.9rem;
  background:var(--wpz-role-secondary-bg);
  color:var(--wpz-role-secondary-fg);
}

.wpz-wedding-step-meta{
  font-size:.78rem;
  color:var(--wpz-wedding-muted);
}

/* ===========================
   MENU TRAITEUR
   =========================== */

.wpz-wedding-menu-cols{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}
.wpz-wedding-menu-block{
  flex:1 1 140px;
}
.wpz-wedding-menu-block h4{
  margin:0 0 6px;
  font-size:.92rem;
  color:var(--wpz-wedding-text);
}
.wpz-wedding-menu-block p{
  margin:0;
  font-size:.85rem;
  line-height:1.6;
  color:var(--wpz-wedding-text);
}

/* ===========================
   CONTACT / RSVP
   =========================== */

.wpz-wedding-contact-grid{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  align-items:flex-start;
}
.wpz-wedding-contact-block{
  flex:1 1 220px;
}

/* ===========================
   DRESS CODE / HEBERGEMENTS
   =========================== */

.wpz-wedding-dresscode-text{
  font-size:var(--wpz-font-body);
  line-height:1.7;
  color:var(--wpz-wedding-text);
}

.wpz-wedding-heberg-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.wpz-wedding-heberg-item{
  padding:10px 10px 8px;
  border-radius:14px;
  border:1px solid var(--wpz-border-soft);
  background:linear-gradient(
    145deg,
    var(--wpz-wedding-card-bg),
    color-mix(in srgb, var(--wpz-wedding-bg-soft) 85%, #ffffff 15%)
  );
}
.wpz-wedding-heberg-title{
  font-weight:600;
  font-size:.95rem;
  margin-bottom:4px;
  display:flex;
  align-items:center;
  gap:6px;
  color:var(--wpz-wedding-text);
}
.wpz-wedding-heberg-meta{
  font-size:.8rem;
  color:var(--wpz-wedding-muted);
  margin-bottom:4px;
}
.wpz-wedding-heberg-actions a{
  font-size:.8rem;
  text-decoration:none;
  padding:3px 7px;
  border-radius:999px;
  border:1px solid var(--wpz-chip-border);
  background:var(--wpz-chip-bg);
  display:inline-flex;
  align-items:center;
  gap:4px;
  color:var(--wpz-wedding-text);
}

/* ===========================
   FOOTER
   =========================== */

.wpz-wedding-footer{
  text-align:center;
  margin-top:20px;
  font-size:.8rem;
  color:var(--wpz-wedding-muted);
}
.wpz-wedding-footer a{
  color:var(--wpz-wedding-muted);
  text-decoration:none;
}
.wpz-wedding-footer a:hover{
  text-decoration:underline;
}
.wpz-wedding-socials{
  margin-top:6px;
  display:flex;
  justify-content:center;
  gap:10px;
}
.wpz-wedding-socials a{
  font-size:.85rem;
  text-decoration:none;
  color:var(--wpz-wedding-text);
}

/* ===========================
   FAB & PANNEAUX (META / DESIGN)
   =========================== */

/* Boutons flottants */
.wpz-design-fab,
.wpz-meta-fab{
  position:fixed;
  inset-inline-end:16px;
  width:52px;
  height:52px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 14px 30px rgba(15,23,42,.28);
  color:var(--wpz-fab-text);
  font-size:1.4rem;
  z-index:9999;
}
.wpz-design-fab{
  inset-block-end:16px;
  background:var(--wpz-fab-bg-design);
}
.wpz-meta-fab{
  inset-block-end:80px;
  width:46px;
  height:46px;
  box-shadow:0 10px 24px rgba(15,23,42,.26);
  background:var(--wpz-fab-bg-main);
}
.wpz-design-fab span,
.wpz-meta-fab span{
  transform:translateY(1px);
}
.wpz-design-fab:hover,
.wpz-meta-fab:hover{
  transform:translateY(-1px);
}

/* Panneaux latéraux de base */
.wpz-meta-panel,
.wpz-design-panel{
  position:fixed;
  inset-block:var(--wpz-adminbar-offset, 0px) 0;
  width:50%;
  max-width:86vw;
  z-index:9998;
  background:var(--wpz-wedding-card-bg);
  color:var(--wpz-wedding-text);
  border-left:1px solid var(--wpz-border-strong);
  box-shadow:-20px 0 40px rgba(15,23,42,.22);
  transform:translateX(100%);
  transition:transform .26s ease-out;
  display:flex;
  flex-direction:column;
}
.wpz-meta-panel{
  inset-inline-start:0;
  inset-inline-end:auto;
  border-left:none;
  border-right:1px solid var(--wpz-border-strong);
  transform:translateX(-100%);
}

/* Ouvert */
.wpz-meta-panel.is-open{
  transform:translateX(0);
}
.wpz-design-panel.is-open{
  transform:translateX(0);
}

/* Header / body / footer */
.wpz-meta-panel__header,
.wpz-design-panel__header{
  padding:14px 16px 10px;
  border-bottom:1px solid var(--wpz-border-soft);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  background:var(--wpz-wedding-card-bg);
}
.wpz-meta-panel__title,
.wpz-design-panel__title{
  font-size:.9rem;
  font-weight:600;
}
.wpz-meta-panel__subtitle,
.wpz-design-panel__subtitle{
  font-size:.75rem;
  opacity:.8;
}
.wpz-meta-panel__close,
.wpz-design-panel__close{
  border:none;
  background:transparent;
  color:#dc2626;
  cursor:pointer;
  font-size:1.2rem;
  line-height:1;
  font-weight:bold;
}

.wpz-meta-panel__body,
.wpz-design-panel__body{
  padding:10px 14px 14px;
  overflow:auto;
  font-size:.8rem;
  background:var(--wpz-wedding-card-bg);
  color:var(--wpz-wedding-text);
}

.wpz-meta-panel__footer,
.wpz-design-footer{
  padding:8px 14px 10px;
  border-top:1px solid var(--wpz-border-soft);
  font-size:.7rem;
  display:flex;
  justify-content:space-between;
  gap:6px;
  align-items:center;
  background:var(--wpz-wedding-card-bg);
  color:var(--wpz-wedding-text);
}

/* Groupes & champs (design panel + meta hébergements) */
.wpz-design-group,
.wpz-meta-heberg-row{
  margin-bottom:12px;
  padding:10px 10px 8px;
  border-radius:12px;
  background:var(--wpz-wedding-card-bg);
  border:1px solid rgba(0,0,0,0.10);
  color:var(--wpz-wedding-text);
}
.wpz-design-group__title{
  font-size:.8rem;
  font-weight:600;
  margin-bottom:4px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:6px;
}
.wpz-design-group__title span.badge{
  font-size:.65rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  padding:2px 6px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,0.20);
  opacity:.85;
}
.wpz-design-field{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-top:6px;
}
.wpz-design-label{
  font-size:.75rem;
  flex:1 1 auto;
  color:#374151;
}
.wpz-design-input{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:6px;
}
.wpz-design-input input[type="color"]{
  width:26px;
  height:26px;
  padding:0;
  border-radius:999px;
  border:none;
  background:transparent;
}
.wpz-design-input input[type="number"]{
  width:64px;
  padding:4px 6px;
  border-radius:8px;
  border:1px solid rgba(148,163,184,.6);
  background:#f9fafb;
  color:var(--wpz-wedding-text);
  font-size:.75rem;
}
.wpz-design-helper{
  font-size:.7rem;
  opacity:.75;
  margin-top:3px;
}

/* Boutons d’actions dans les footers = rôle primaire */
.wpz-meta-panel__footer button[type=submit],
.wpz-design-footer button{
  background:var(--wpz-role-primary-bg);
  color:var(--wpz-role-primary-fg);
  border:none;
  border-radius:999px;
  padding:6px 14px;
  font-weight:600;
  cursor:pointer;
}
.wpz-design-link{
  background:transparent !important;
  color:var(--wpz-wedding-primary) !important;
  text-decoration:underline;
  border:none;
  padding:0;
  font-size:.7rem;
  cursor:pointer;
}

/* Inputs internes (fallback si pas de style inline) */
.wpz-meta-panel input,
.wpz-meta-panel textarea,
.wpz-meta-panel select,
.wpz-design-panel input,
.wpz-design-panel textarea,
.wpz-design-panel select{
  background:#f3f4f6 !important;
  color:var(--wpz-wedding-text) !important;
  border:1px solid rgba(0,0,0,0.15) !important;
}

/* DT/DD dans meta panel */
.wpz-meta-panel__body dl{
  margin:0;
}
.wpz-meta-panel__body dt{
  font-weight:600;
  margin-top:8px;
}
.wpz-meta-panel__body dd{
  margin:2px 0 0;
  opacity:.9;
}

/* Message de status */
#wpzMetaMessage{
  font-size:.75rem;
  margin-top:4px;
}

/* Z-Index hiérarchisé */
/* PANNEAUX AU-DESSUS DES BOUTONS (y compris menu canvas / drawer) */
body.wpz-wedding-page .wpz-meta-panel,
body.wpz-wedding-page .wpz-design-panel,
body.wpz-wedding-page .wpz-wedding-drawer{
  z-index: 10010 !important; /* panneaux + drawer tout en haut */
}

body.wpz-wedding-page .wpz-wedding-drawer-backdrop{
  z-index: 10005 !important; /* overlay sous le panneau mais au-dessus du contenu */
}

body.wpz-wedding-page .wpz-meta-fab,
body.wpz-wedding-page .wpz-design-fab{
  z-index: 10000 !important; /* boutons en dessous des panneaux / drawer */
}

/* Quand un panneau est ouvert → FAB derrière (optionnel) */
.wpz-meta-panel.is-open ~ .wpz-meta-fab,
.wpz-design-panel.is-open ~ .wpz-design-fab{
  z-index:9000 !important;
}

/* ===========================
   PANNEAUX EN PLEINE PAGE MOBILE
   =========================== */

@media (max-width:900px){
  .wpz-meta-panel,
  .wpz-design-panel{
    inset-inline:0;
    width:100%;
    max-width:none;
    border-left:none;
    border-right:none;
    box-shadow:none;
  }
  .wpz-meta-panel__body,
  .wpz-design-panel__body{
    max-height:calc(100vh - var(--wpz-adminbar-offset, 0px) - 96px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .wpz-meta-panel__footer,
  .wpz-design-footer{
    position:sticky;
    bottom:0;
  }
}

/* Sécurité offset admin pour panneaux & drawer */
body.admin-bar .wpz-meta-panel,
body.admin-bar .wpz-design-panel,
body.admin-bar .wpz-wedding-drawer,
body.admin-bar .wpz-wedding-drawer-backdrop{
  top:var(--wpz-adminbar-offset, 32px) !important;
}

/* PANNEAUX AU-DESSUS DES BOUTONS (rappel) */
body.wpz-wedding-page .wpz-meta-panel,
body.wpz-wedding-page .wpz-design-panel{
  z-index: 10010 !important;
}

body.wpz-wedding-page .wpz-meta-fab,
body.wpz-wedding-page .wpz-design-fab{
  z-index: 10000 !important;
}

/* Placeholders un peu atténués mais visibles */
.wpz-meta-panel ::placeholder,
.wpz-design-panel ::placeholder{
  color:#6b7280 !important;
  opacity:1;
}

/* Icônes SVG des FAB – on neutralise tout style global .wpz-icon */
.wpz-fab-icon{
  width:22px;
  height:22px;
  display:block;
  background:none !important;
  border:none !important;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

/* Site de mariage – entêtes de sections : titre + sous-titre alignés */
.wpz-wedding-section-header{
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.8fr);
  gap: .25rem 1.25rem;
  align-items: flex-start;
}



.wpz-wedding-section-sub{
  margin: 0;
  font-size: .9rem;
  color: var(--muted);
}

/* Mobile : le sous-titre passe proprement en dessous */
@media (max-width: 640px){
  .wpz-wedding-section-header{
    grid-template-columns: 1fr;
  }
}

/* Panneau Infos du mariage – labels + champs en 2 colonnes cohérentes */
.wpz-design-field{
  display: grid;
  grid-template-columns: minmax(0, 38%) minmax(0, 62%);
  gap: 6px 10px;
  align-items: center;
  margin-bottom: 10px;
}

.wpz-design-field .wpz-design-label{
  font-size: .82rem;
  font-weight: 600;
  color: var(--muted);
}

.wpz-design-field .wpz-design-input{
  min-width: 0;
}

/* Textarea : un peu plus haut mais reste dans la grille */
.wpz-design-field textarea{
  min-height: 80px;
}

/* Mobile : label au-dessus du champ */
@media (max-width: 640px){
  .wpz-design-field{
    grid-template-columns: 1fr;
  }
}

/* =========== LIENS GLOBALS – COULEUR ACCENT =========== */

.wpz-wedding-main a,
.wpz-wedding-footer a,
.wpz-design-panel a,
.wpz-meta-panel a {
  color: var(--wpz-wedding-accent);
  text-decoration: none;
  transition: color .25s ease, opacity .25s ease;
}

.wpz-wedding-main a:hover,
.wpz-wedding-footer a:hover,
.wpz-design-panel a:hover,
.wpz-meta-panel a:hover {
  opacity: .75;
  color: var(--wpz-wedding-accent);
}

/* Exceptions : boutons / chips / éléments d’action */
.wpz-wedding-chip a,
.wpz-wedding-chip,
.wpz-wedding-time-badge,
.wpz-wedding-place-actions a {
  color: inherit !important;
}

/* === Palettes prédéfinies === */

.wpz-palette-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  margin:6px 0 10px;
}

.wpz-palette-choice{
  border:none;
  padding:4px;
  border-radius:12px;
  background:#ffffff;
  box-shadow:0 4px 10px rgba(15,23,42,.10);
  cursor:pointer;
  display:flex;
  gap:3px;
  transition:
    transform .15s ease,
    box-shadow .15s ease,
    outline-color .15s ease,
    outline-width .15s ease;
  outline:2px solid transparent;
  outline-offset:2px;
}

.wpz-palette-choice span{
  flex:1;
  height:22px;
  border-radius:8px;
}

/* 3 bandes = primaire / secondaire / accent */
.wpz-palette-choice span:nth-child(1){
  background: var(--wpz-wedding-primary);
}
.wpz-palette-choice span:nth-child(2){
  background: var(--wpz-wedding-secondary);
}
.wpz-palette-choice span:nth-child(3){
  background: var(--wpz-wedding-accent);
}


.wpz-palette-choice:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(15,23,42,.16);
}

.wpz-palette-choice.is-active{
  outline-color:var(--wpz-wedding-primary);
  outline-width:2px;
  box-shadow:0 0 0 1px rgba(15,23,42,.05);
}

/* Corrige les ancres masquées à cause du header sticky */
.wpz-wedding-section,
.wpz-wedding-hero,
.wpz-wedding-countdown {
  scroll-margin-top: calc(var(--wpz-adminbar-offset, 0px) + 70px);
}

@media (max-width:768px){
  .wpz-wedding-section,
  .wpz-wedding-hero,
  .wpz-wedding-countdown {
    scroll-margin-top: calc(var(--wpz-adminbar-offset, 0px) + 0px);
  }
}

/* Correction : ancrer le panneau de design à droite
   pour qu'il soit complètement hors écran tant qu'il n'est pas ouvert */
.wpz-design-panel{
  inset-inline-end: 0;
  transform: translateX(100%);
}

.wpz-design-panel.is-open{
  transform: translateX(0);
}




/*PATCHS*/
/* === FIX BURGER – look propre + seulement mobile === */

/* On neutralise les styles globaux sur le bouton hamburger */
body.wpz-wedding-page .wpz-wedding-topbar .wpz-wedding-burger{
  appearance:none;
  background:var(--wpz-wedding-card-bg) !important;
  border-radius:999px !important;
  border:1px solid color-mix(in srgb, var(--wpz-wedding-primary) 15%, rgba(15,23,42,.12)) !important;
  padding:0 !important;
  margin-left:6px;
  width:40px;
  height:40px;
  box-shadow:0 4px 10px rgba(15,23,42,.08);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--wpz-wedding-text);
}

/* Icônes SVG internes : pas de fond rose, suivent currentColor */
body.wpz-wedding-page .wpz-wedding-burger .wpz-wedding-icon{
  width:20px;
  height:20px;
  display:block;
  background:none !important;
  border:none !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

/* En mode ouvert, on colore en primaire */
body.wpz-wedding-page .wpz-wedding-burger.is-open .wpz-wedding-icon{
  color:var(--wpz-wedding-primary);
}

/* Desktop : burger toujours caché */
@media (min-width:769px){
  body.wpz-wedding-page .wpz-wedding-topbar .wpz-wedding-burger{
    display:none !important;
  }
}

/* Mobile : cacher la nav texte et afficher le burger */
@media (max-width:768px){
  .wpz-wedding-topnav{
    display:none !important;
  }
  body.wpz-wedding-page .wpz-wedding-topbar .wpz-wedding-burger{
    display:flex !important;
  }
}
/* === FIX PALETTES – respecter les inline background des spans === */

.wpz-design-panel .wpz-palette-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  margin:6px 0 10px;
}

/* Le bouton palette : petite carte blanche, pas de rose global */
.wpz-design-panel .wpz-palette-choice{
  border:none !important;
  padding:4px !important;
  border-radius:12px !important;
  background:#ffffff !important;
  box-shadow:0 4px 10px rgba(15,23,42,.10);
  cursor:pointer;
  display:flex;
  gap:3px;
  transition:
    transform .15s ease,
    box-shadow .15s ease,
    outline-color .15s ease,
    outline-width .15s ease;
  outline:2px solid transparent;
  outline-offset:2px;
}

/* Très important : on NE TOUCHE PAS AU background ici,
   on laisse les inline style="background:#xxxxxx" faire le job. */
.wpz-design-panel .wpz-palette-choice span{
  flex:1 1 0;
  height:22px;
  border-radius:8px;
  /* pas de background ici */
}

/* Hover + active comme avant */
.wpz-design-panel .wpz-palette-choice:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(15,23,42,.16);
}
.wpz-design-panel .wpz-palette-choice.is-active{
  outline-color:var(--wpz-wedding-primary);
  outline-width:2px;
  box-shadow:0 0 0 1px rgba(15,23,42,.05);
}





/*PATCH*/

/* --- Ordre de superposition global --- */
/* Topbar en haut du contenu, mais sous les FAB / panneaux */
.wpz-wedding-topbar{
  position:sticky;
  top:var(--wpz-adminbar-offset, 0px);
  z-index: 50;
}

/* Boutons flottants (Infos + Design) */
.wpz-meta-fab,
.wpz-design-fab{
  position:fixed;
  z-index: 1000;
}

/* Panneaux latéraux au-dessus des FAB */
.wpz-meta-panel,
.wpz-design-panel,
.wpz-panel-backdrop{
  z-index: 1200;
}

/* 🔥 Lightbox "Notre histoire" au-dessus de tout */
.wpz-story-lightbox,
.wpz-story-lightbox-backdrop{
  position:fixed;
  inset:0;
  z-index: 1300;
}





/* ================================
   BOUTONS DE FERMETURE – STYLE UNIFIÉ
   ================================ */

.wpz-wedding-drawer-close,
.wpz-design-panel__close,
.wpz-meta-panel__close,
.wpz-story-lightbox-close,
.wpz-meta-heberg-remove,
.wpz-story-photo-delete {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  color: #d90000 !important;  /* rouge vif propre */
  font-weight: 700 !important; /* en gras */
  font-size: 1.6rem !important;
  line-height: 1 !important;
  padding: 0 !important;
  cursor: pointer !important;
}

.wpz-meta-heberg-remove {
  font-size: 1.4rem !important;
}

.wpz-wedding-drawer-close {
  font-size: 2rem !important;
}

/* Option : au survol pour toi (admin uniquement) */
.wpz-wedding-drawer-close:hover,
.wpz-design-panel__close:hover,
.wpz-meta-panel__close:hover,
.wpz-story-lightbox-close:hover,
.wpz-story-photo-delete:hover,
.wpz-meta-heberg-remove:hover {
  color: #b30000 !important;
  transform: scale(1.06);
}

/*PATCHS */
/* PATCH AVATARS – toujours côte à côte, même sur mobile */
.wpz-wedding-avatars{
  display:flex;
  flex-direction:row;      /* plus de colonne */
  align-items:center;
  gap:0;
}

.wpz-wedding-avatar + .wpz-wedding-avatar{
  margin-left:-22px;       /* léger chevauchement comme avant */
}


/* Texte global contrôlé par le panneau Design */
.wpz-wedding-root,
.wpz-wedding-root p,
.wpz-wedding-root li{
  font-size: var(--wpz-font-body);
  font-family: var(--wpz-font-family-body, system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif);
}

