/* =========================
   /assets/css/style.css
   ========================= */
:root{
  --midnight:#004C54;
  --silver:#A5ACAF;
  --black:#000000;
  --white:#FFFFFF;
  --prime:#1399FF;

  --bg: #F7F9FB;
  --card:#FFFFFF;
  --fg: #0B0B0B;
  --muted:#3D4A50;

  --radius: 20px;
  --radius2: 26px;
  --border: 1.5px solid rgba(0,0,0,.12);
  --shadow: 0 14px 34px rgba(0,0,0,.08);

  --font: "Lato", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background: var(--bg);
  color: var(--fg);
}

a{color:inherit;text-decoration:none}

.wrap{
  max-width: 1080px;
  margin: 0 auto;
  padding: 18px;
}

/* ========= HEADER ========= */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 12px 0 18px;
  background: transparent !important;
  min-height: auto;
  flex-wrap: nowrap;
}

.brand{
  display:flex;
  align-items:center;
  flex: 0 0 auto;
}
.brand img{
  height: 70px;          /* Desktop = 70px */
  width: auto;
  display:block;
}

.topcenter{
  flex: 1;
  display:flex;
  justify-content:center;
  align-items:center;
  min-width: 0;
}

/* pilule WhatsApp */
.waLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: var(--border);
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(8px);
  color: var(--midnight);
  font-weight: 700;
  white-space: nowrap;
  max-width: 100%;
}

.waIcon{ width: 18px; height: 18px; flex: 0 0 18px; }
.waText{ font-size: 14px; font-weight: 800; white-space: nowrap; }
.waSep{ opacity: .55; font-weight: 800; white-space: nowrap; }
.waNum{ font-size: 14px; font-weight: 800; white-space: nowrap; }

.topcta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 14px;
  border-radius: 14px;
  color: #fff;
  background: linear-gradient(135deg, var(--midnight), #0A6D78);
  box-shadow: 0 14px 26px rgba(0,76,84,.18);
  font-weight: 800;
  font-size: 14px;
  white-space: nowrap;
  border: 0;
  cursor: pointer;
  transition: transform .12s ease, filter .12s ease;
  flex: 0 0 auto;
}
.topcta:hover{transform: translateY(-1px); filter: brightness(1.02)}
.topcta:active{transform: translateY(0px)}

/* ✅ Couleur du bouton header selon l'état */
.topcta[data-mode="estimate"]{
  background: linear-gradient(135deg, var(--midnight), #0A6D78);
  box-shadow: 0 14px 26px rgba(0,76,84,.18);
}
.topcta[data-mode="booking"]{
  background: linear-gradient(135deg, var(--prime), #0F2B46);
  box-shadow: 0 18px 30px rgba(19,153,255,.18);
}

/* MOBILE header */
@media (max-width: 640px){
  .topbar{
    display:grid;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto auto;
    align-items:center;
    column-gap: 10px;
    row-gap: 10px;
    padding: 10px 0 14px;

    /* ✅ Sticky uniquement en mobile */
    position: sticky;
    top: 0;
    z-index: 999;
    background: rgba(247,249,251,.92) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  .brand{ grid-column: 1; grid-row: 1; }
  .topcta{ grid-column: 3; grid-row: 1; }

  .topcenter{
    grid-column: 1 / 4;
    grid-row: 2;
    width: 100%;
    justify-content: stretch;
  }
  .waLink{
    width: 100%;
    justify-content: center;
    padding: 10px 12px;
  }
  .waText,
  .waNum{ font-size: clamp(12px, 3.2vw, 14px); }
  .brand img{ height: 60px; } /* Mobile = 60px */

  /* iOS Safari: éviter le zoom sur inputs numériques */
  input.input[type="number"]{font-size:16px;}
}

/* HERO */
.hero{ padding: 10px 0 14px; }
.h1{
  margin: 12px 0 10px;
  font-size: 36px;
  line-height: 1.06;
  letter-spacing: -.4px;
  font-weight: 750;
}
@media (max-width: 900px){
  .h1{font-size: 30px}
}

/* GRID */
.grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items:start;
  margin-top: 12px;
}
@media (max-width: 900px){
  .grid{grid-template-columns: 1fr}
}

/* CARD */
.card{
  background: var(--card);
  border: var(--border);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding: 16px;
}

.card--accent{
  position:relative;
  overflow:hidden;
}
.card--accent::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(900px 240px at 0% 0%, rgba(165,172,175,.30), transparent 58%),
    radial-gradient(760px 260px at 100% 0%, rgba(0,0,0,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(165,172,175,.10));
  pointer-events:none;
}

.cardHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 12px;
  position:relative;
  z-index:1;
}
.cardTitle{
  font-size: 16px;
  font-weight: 700;
  color: var(--black);
}

.form{
  display:grid;
  gap: 12px;
  position:relative;
  z-index:1;
}

.label{
  display:block;
  font-size: 12px;
  font-weight: 600;
  color: rgba(0,0,0,.70);
  margin-bottom: 6px;
}

.input{
  width:100%;
  border: 1.5px solid rgba(0,0,0,.14);
  border-radius: 16px;
  padding: 12px 12px;
  font-size: 15px;
  outline: none;
  background: rgba(255,255,255,.95);
  transition: border-color .12s ease, box-shadow .12s ease;
}
.input:focus{
  border-color: rgba(19,153,255,.55);
  box-shadow: 0 0 0 4px rgba(19,153,255,.14);
}
.select{appearance:none}

.row2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 560px){
  .row2{grid-template-columns: 1fr}
}

.withUnit{
  display:flex;
  align-items:stretch;
  gap:8px;
}
.unit{
  min-width: 46px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1.5px solid rgba(0,0,0,.14);
  border-radius: 16px;
  padding: 0 10px;
  background: rgba(0,0,0,.04);
  font-size: 12px;
  font-weight: 600;
  color: rgba(0,0,0,.60);
  user-select:none;
}

.btn{
  width:100%;
  border: 0;
  border-radius: 18px;
  padding: 13px 14px;
  font-size: 15px;
  font-weight: 650;
  cursor:pointer;
  color: #fff;
  background: linear-gradient(135deg, var(--midnight), #0A6D78);
  box-shadow: 0 14px 26px rgba(0,76,84,.18);
  transition: transform .12s ease, filter .12s ease;
  text-align: center;         /* ✅ texte centré */
}
.btn:hover{transform: translateY(-1px); filter: brightness(1.02)}
.btn:active{transform: translateY(0px)}

/* ✅ NOUVEAU CTA (après estimation) */
.btn--cta2{
  padding: 15px 16px;
  font-size: 16px;
  font-weight: 800;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--prime), #0F2B46);
  box-shadow: 0 18px 30px rgba(19,153,255,.18);
}

/* RESULT */
.result{
  border: 1.5px solid rgba(19,153,255,.35);
  background: rgba(19,153,255,.08);
  border-radius: 18px;
  padding: 12px;
}
.resultLabel{
  font-size: 12px;
  font-weight: 600;
  color: rgba(0,0,0,.65);
  margin-bottom: 6px;
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: baseline;
}
.resultLabelMain{ font-weight: 700; }
.resultNote{ font-weight: 600; color: rgba(0,0,0,.55); }
.resultValue{
  font-size: 22px;
  font-weight: 750;
  letter-spacing: -.2px;
  color: var(--black);
  text-align: center;          /* ✅ prix centré */
}

/* ERROR */
.error{
  border: 1.5px solid rgba(220,38,38,.28);
  background: rgba(220,38,38,.06);
  border-radius: 18px;
  padding: 10px 12px;
  color: rgba(0,0,0,.75);
  font-size: 13px;
}

/* SIDE */
.sideTitle{ font-weight: 750; font-size: 16px; margin-bottom: 8px; }
.sideText{ margin: 0 0 12px 0; color: var(--muted); line-height: 1.45; font-size: 14px; }
.sideBadges{ display:flex; flex-wrap:wrap; gap:10px; }
.badge2{
  border: var(--border);
  border-radius: 999px;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 600;
  background: rgba(255,255,255,.8);
}

/* ✅ BOOKING (même page) */
.booking{
  margin-top: 16px;
}
.bookingTitle{
  margin: 0 0 6px 0;
  font-size: 18px;
  font-weight: 800;
}
.bookingText{
  margin: 0 0 12px 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}
.bookingRow{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 700px){
  .bookingRow{ grid-template-columns: 1fr; }
}
.bookingBox{
  border: var(--border);
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,.85);
  box-shadow: 0 10px 18px rgba(0,0,0,.06);
  font-weight: 700;
}

/* FOOTER */
.footer{
  margin-top: 16px;
  padding: 18px 0 26px;
  text-align:center;
  color: rgba(0,0,0,.45);
  font-size: 12px;
}
.footerLangs{
  display:flex;
  justify-content:center;
  align-items:center;
  gap: 10px;
  margin-bottom: 10px;
}
.flagLink{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1.5px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.85);
  box-shadow: 0 10px 18px rgba(0,0,0,.06);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.flagLink img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  border-radius: 999px;
}
.flagLink:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(0,0,0,.08);
}
.flagLink.isActive{
  border-color: rgba(0,76,84,.55);
  box-shadow: 0 0 0 4px rgba(0,76,84,.10), 0 12px 22px rgba(0,0,0,.08);
}
.footerCopy{ line-height: 1.2; }

/* =========================================================
   AJOUT À LA FIN — BOOKING INLINE (calendrier + slots)
   ========================================================= */
.booking[data-booking-inline]{
  margin-top: 14px;
  border: var(--border);
  border-radius: var(--radius2);
  padding: 14px;
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 28px rgba(0,0,0,.06);
}

.bookingKicker{
  font-weight: 900;
  letter-spacing: .2px;
  color: rgba(0,0,0,.85);
  margin-bottom: 6px;
}

.bookingFine{
  margin: 10px 0 12px 0;
  color: rgba(0,0,0,.60);
  font-size: 13px;
  font-weight: 700;
}

.bookingGrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 12px;
  align-items: start;
}
@media (max-width: 900px){
  .bookingGrid{ grid-template-columns: 1fr; }
}

/* Calendrier */
.cal{
  border: var(--border);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,.9);
  box-shadow: 0 10px 18px rgba(0,0,0,.06);
}

.calTop{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.calTitle{
  font-weight: 900;
  letter-spacing: .2px;
}

.calNav{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1.5px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.9);
  cursor:pointer;
  font-weight: 900;
  transition: transform .12s ease, filter .12s ease;
}
.calNav:hover{ transform: translateY(-1px); filter: brightness(1.02); }

.calDow{
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-bottom: 6px;
  color: rgba(0,0,0,.55);
  font-size: 12px;
  font-weight: 800;
  text-align: center;
}

.calGrid{
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}

.calDay{
  height: 40px;
  border-radius: 14px;
  border: 1.5px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.92);
  cursor:pointer;
  font-weight: 800;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.calDay:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 16px rgba(0,0,0,.06);
}
.calDay.isEmpty{
  border-color: transparent;
  background: transparent;
  cursor: default;
}
.calDay.isDisabled{
  opacity: .35;
  cursor: not-allowed;
}
.calDay.isSelected{
  border-color: rgba(19,153,255,.55);
  box-shadow: 0 0 0 4px rgba(19,153,255,.14);
  background: rgba(19,153,255,.08);
}

/* Slots */
.slot{
  border: var(--border);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,.9);
  box-shadow: 0 10px 18px rgba(0,0,0,.06);
}
.slotTitle{
  font-weight: 900;
  margin-bottom: 10px;
}

.slotRow{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
@media (max-width: 520px){
  .slotRow{ grid-template-columns: 1fr; }
}

.slotBtn{
  text-align:left;
  border-radius: 16px;
  border: 1.5px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.95);
  padding: 12px;
  cursor:pointer;
  font-weight: 900;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.slotBtn:hover{ transform: translateY(-1px); box-shadow: 0 12px 18px rgba(0,0,0,.06); }
.slotBtn.isSelected{
  border-color: rgba(19,153,255,.55);
  box-shadow: 0 0 0 4px rgba(19,153,255,.14);
  background: rgba(19,153,255,.08);
}

.slotHint{
  display:block;
  margin-top: 4px;
  font-weight: 800;
  color: rgba(0,0,0,.55);
  font-size: 12px;
}

.bookingConfirm{
  width: 100%;
}

.bookingMsg{
  margin-top: 10px;
  border-radius: 16px;
  padding: 10px 12px;
  font-weight: 800;
  font-size: 13px;
}
.bookingMsg.isOk{
  border: 1.5px solid rgba(16,185,129,.28);
  background: rgba(16,185,129,.10);
}
.bookingMsg.isErr{
  border: 1.5px solid rgba(220,38,38,.28);
  background: rgba(220,38,38,.08);
}

/* =========================================================
   AJOUT À LA FIN — LEAD FORM (Vos coordonnées)
   (injecté par app.js)
   ========================================================= */
.lead{
  margin-top: 12px;
  border: 1.5px solid rgba(19,153,255,.22);
  background: rgba(255,255,255,.88);
  border-radius: 20px;
  padding: 14px;
  box-shadow: 0 14px 26px rgba(0,0,0,.05);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.leadTitle{
  font-weight: 900;
  letter-spacing: .2px;
  margin: 6px 0 10px 0;
  color: rgba(0,0,0,.85);
}

.leadGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items:start;
}

/* ✅ FIX DESKTOP: dans la colonne droite (.slot) c'est trop étroit -> 1 colonne */
.slot .leadGrid{
  grid-template-columns: 1fr;
}

@media (max-width: 700px){
  .leadGrid{ grid-template-columns: 1fr; }
}

.leadField{ min-width: 0; }

.leadHelp{
  margin-top: 6px;
  font-size: 12px;
  font-weight: 700;
  color: rgba(0,0,0,.55);
}

.leadPhoneRow{
  display:grid;
  grid-template-columns: minmax(140px, 1fr) 1.2fr;
  gap: 10px;
  align-items: stretch;
}

/* ✅ FIX DESKTOP: dans .slot, pareil -> empile proprement */
.slot .leadPhoneRow{
  grid-template-columns: 1fr;
}

@media (max-width: 520px){
  .leadPhoneRow{
    grid-template-columns: 1fr;
  }
}

.lead .input.select{
  background-image: linear-gradient(45deg, transparent 50%, rgba(0,0,0,.55) 50%),
                    linear-gradient(135deg, rgba(0,0,0,.55) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 3px), calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px;
}

/* ✅ FIX FLAGS PC (Windows): forcer une police emoji sur le select */
.lead .input.select,
.lead .input.select option{
  font-family: var(--font), "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

/* Bouton final du lead (cohérent + un peu plus "prime") */
.lead [data-lead-confirm]{
  margin-top: 12px;
  background: linear-gradient(135deg, var(--prime), #0F2B46);
  box-shadow: 0 18px 30px rgba(19,153,255,.18);
  font-weight: 850;
}
.lead [data-lead-confirm]:hover{ transform: translateY(-1px); filter: brightness(1.02); }
.lead [data-lead-confirm]:active{ transform: translateY(0px); }

/* Petits ajustements mobile pour garder le rythme visuel */
@media (max-width: 520px){
  .lead{ padding: 12px; border-radius: 18px; }
  .leadTitle{ margin-top: 4px; }
}
/* =========================================================
   AJOUT À LA FIN — LEAD (Vos coordonnées) + erreurs sous bouton
   ========================================================= */

/* Conteneur lead */
.lead{
  margin-top: 12px;
  border: 1.5px solid rgba(19,153,255,.24);
  background: rgba(19,153,255,.06);
  border-radius: 20px;
  padding: 14px;
}

.leadTitle{
  font-weight: 900;
  font-size: 16px;
  margin: 2px 0 10px 0;
  letter-spacing: -.2px;
}

/* Grille des champs */
.leadGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start;
}

@media (max-width: 720px){
  .leadGrid{ grid-template-columns: 1fr; }
}

.leadField{
  min-width: 0;
}

/* Aide adresse */
.leadHelp{
  margin-top: 6px;
  font-size: 12px;
  font-weight: 700;
  color: rgba(0,0,0,.55);
  line-height: 1.35;
}

/* Téléphone : 2 sous-champs (Indicatif / Numéro) */
.leadPhoneRow{
  display:grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 10px;
  align-items: start;
}

@media (max-width: 520px){
  .leadPhoneRow{ grid-template-columns: 1fr; }
}

.leadPhoneCol{
  min-width: 0;
}

/* Le select pays : rendu plus stable (emoji/flags) + caret */
.leadPhoneRow select.input{
  font-weight: 800;
  padding-right: 40px;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(0,0,0,.55) 50%),
    linear-gradient(135deg, rgba(0,0,0,.55) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(1em + 4px),
    calc(100% - 12px) calc(1em + 4px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

/* Emoji fonts pour desktop (Chrome/Windows) */
.leadPhoneRow select.input,
.leadPhoneRow select.input option{
  font-family: var(--font), "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

/* Bouton final */
.lead [data-lead-confirm].btn{
  margin-top: 12px;
}

/* Message erreur/succès sous le bouton final */
.lead .bookingMsg[data-lead-msg]{
  margin-top: 10px;
}

/* Petite amélioration : champs ne “s’écrasent” pas en desktop */
.lead .input{
  min-width: 0;
}

/* Optionnel (propre) : scroll anchors si jamais tu ajoutes des ancres plus tard */
.booking[data-booking-inline],
.lead{
  scroll-margin-top: 90px;
}
/* Google Places Autocomplete dropdown */
.pac-container{
  width: min(96vw, 720px) !important;   /* plus large que le champ */
  max-width: 96vw !important;
  left: 2vw !important;                /* marge écran */
  right: 2vw !important;
  box-sizing: border-box !important;
  z-index: 999999 !important;          /* au-dessus de tout */
}

/* Autoriser le retour à la ligne */
.pac-item{
  white-space: normal !important;
  line-height: 1.25 !important;
  padding: 10px 12px !important;
}

/* Mettre en valeur la partie “principale” et permettre wrap */
.pac-item-query{
  white-space: normal !important;
  display: inline !important;
}

/* Optionnel : texte secondaire un peu plus lisible */
.pac-matched{
  font-weight: 700 !important;
}
/* =========================================================
   CTA BLINK — continu jusqu'au clic (CSS only)
   Stop = focus / active (quand l'utilisateur clique)
   ========================================================= */

@keyframes nmBlinkCtaInf {
  0%   { transform: translateY(0) scale(1);   filter: brightness(1); }
  30%  { transform: translateY(-1px) scale(1.03); filter: brightness(1.18); }
  60%  { transform: translateY(0) scale(1);   filter: brightness(1); }
  100% { transform: translateY(0) scale(1);   filter: brightness(1); }
}

/* Blink infini */
.topcta[data-mode="booking"],
[data-booking-cta]:not([hidden]){
  animation: nmBlinkCtaInf .75s ease-in-out infinite;
  will-change: transform, filter;
}

/* Stop dès clic (active) */
.topcta[data-mode="booking"]:active,
[data-booking-cta]:not([hidden]):active{
  animation: none !important;
}

/* Stop après clic (focus) — reste arrêté tant que la page reste ouverte */
.topcta[data-mode="booking"]:focus,
.topcta[data-mode="booking"]:focus-visible,
[data-booking-cta]:not([hidden]):focus,
[data-booking-cta]:not([hidden]):focus-visible{
  animation: none !important;
  outline: none;
}

@media (prefers-reduced-motion: reduce){
  .topcta[data-mode="booking"],
  [data-booking-cta]:not([hidden]){
    animation: none !important;
  }
}
/* Stop blink définitivement après clic */
body.nmCtaStopped .topcta[data-mode="booking"],
body.nmCtaStopped [data-booking-cta]:not([hidden]){
  animation: none !important;
}
/* =========================================================
   MOBILE OVERRIDE — blink plus visible et plus compatible
   (ne remplace pas le desktop, ne touche qu'au mobile)
   ========================================================= */
@media (max-width: 768px){

  @keyframes nmBlinkCtaMobile {
    0%   { opacity: 1;   transform: translate3d(0,0,0) scale(1); }
    40%  { opacity: .75; transform: translate3d(0,-1px,0) scale(1.03); }
    80%  { opacity: 1;   transform: translate3d(0,0,0) scale(1); }
    100% { opacity: 1;   transform: translate3d(0,0,0) scale(1); }
  }

  /* assure que transform s'applique bien sur iOS
     ⚠️ IMPORTANT: on ne touche le booking CTA QUE quand il est visible */
  .topcta,
  [data-booking-cta]:not([hidden]){
    display: inline-flex;
    align-items: center;
    justify-content: center;
    -webkit-transform: translate3d(0,0,0);
    backface-visibility: hidden;
  }

  /* Blink mobile : plus robuste (sans filter) */
  .topcta[data-mode="booking"],
  [data-booking-cta]:not([hidden]){
    animation: nmBlinkCtaMobile .75s ease-in-out infinite !important;
    will-change: transform, opacity;
  }

  /* garde ton stop définitif après clic */
  body.nmCtaStopped .topcta[data-mode="booking"],
  body.nmCtaStopped [data-booking-cta]:not([hidden]){
    animation: none !important;
  }
}


