/* =====================================================================
   mockup.css — réorganisé (blocs + repères)
   Date: 2026-02-03
   Objectif:
   - Regrouper le code en blocs lisibles avec indicateurs "Correspondance"
   - Aérer (espacements) pour une maintenance plus simple
   - Nettoyage SAFE: espaces, doublons de lignes vides, indentation légère
     (aucun changement volontaire de logique)

   BLOCS (repères rapides)
   - BLOC 0 — Variables / reset
   - BLOC 1 — Layout (grids)
   - BLOC 2 — Sections spécifiques (contact, map, etc.)
   - BLOC 3 — Utilitaires & responsive
   Correspondance: Styles de mise en page spécifiques (contact / zone / pages).
===================================================================== */

/*
  mockup-contact.css
  Organisation (repère):
  1) Variables / reset
  2) Layout (page-width, grid)
  3) Header
  4) Navigation / drawer / search
  5) Sections & composants
  6) Footer
  7) Pages spécifiques (products, contact, reservation...)
*/

/*
================================================================================
 mockup.css — organisation interne
--------------------------------------------------------------------------------
 SOMMAIRE (repères rapides)
  1) Variables / reset / layout
  2) Header & navigation
  3) Sections (homepage / pages)
  4) Cards / products
  5) Forms / buttons
  6) Footer
  7) Utilitaires / animations
  8) Media queries
--------------------------------------------------------------------------------
 NOTE: organisation = commentaires + espacements (pas de changement visuel voulu)
================================================================================
*/

/* ---------------------------------------------------------------------
   BLOC — Contact: 2-col layout + map + info blocks
--------------------------------------------------------------------- */

#contact .contact-grid{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(20px, 4vw, 40px);
  align-items:start;
  max-width: 1100px;
  margin: 0 auto;
}
#contact .contact-left > .h1{ margin-bottom: 24px; text-align:left !important; }
#contact .contact-left form{ box-shadow: 0 8px 24px rgba(0,0,0,.08); }
#contact .contact-right .map-card{
  position:relative;
  border-radius: 20px;
  overflow: hidden;
  background:#fff;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
#contact .contact-right .accent-rect{
  position:absolute;
  top:-16px; right:-16px;
  width: 90px; height: 140px;
  background:#4f57e1; border-radius: 10px;
  z-index:0; opacity:.9;
}
#contact .contact-map{
  display:block; position:relative; z-index:1;
  width:100%; height:420px; border:0;
  border-radius: 20px;
}
@media (max-width: 989px){
  #contact .contact-grid{ grid-template-columns: 1fr; }
  #contact .contact-map{ height: 320px; }
}

/* Info blocks row */

#contact .contact-infos{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 3vw, 28px);
  margin-top: clamp(28px, 4vw, 40px);
  max-width: 1100px;
  padding: 0 12px;
}
#contact .ci-item{
  display:flex; align-items:flex-start; gap:14px;
  background:#fff; border-radius:16px; padding:18px 18px;
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
}
#contact .ci-icon{ font-size:28px; line-height:1; }
#contact .ci-title{ font-weight:800; margin-bottom:4px; }
#contact .ci-sub{ opacity:.7; font-size:14px; }
#contact .ci-sub a{ text-decoration:none; color:inherit; }
@media (max-width: 749px){
  #contact .contact-infos{ grid-template-columns: 1fr; }
}

/* Harmonise existing form container width */

#contact .page-width{ max-width: none !important; }
#contact .contact-left > .page-width{ padding:0; }

/* ---------------------------------------------------------------------
   BLOC — FULLY SCOPED: ONLY under #reprog-mockup
--------------------------------------------------------------------- */

#reprog-mockup{
  --rp-shell:#0e1116; --rp-screen:#0b0f14; --rp-header:#1c1c1e; --rp-text:#ffffff;
  --rp-notch-w:150px; --rp-notch-h:22px;
  display:block; width:100%; max-width:320px; margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
}
#reprog-mockup *{ box-sizing:border-box; }

/* Cadre du téléphone */

#reprog-mockup .rp-shell{
  position:relative; width:100%; height:640px; padding:14px;
  border-radius:46px; background:var(--rp-shell);
  box-shadow: var(--rp-shell-shadow, 0 34px 70px rgba(0,0,0,.28));
  overflow:visible; /* pour laisser dépasser les boutons */

}

/* Boutons latéraux (gauche x3, droite x1) */

#reprog-mockup .rp-btn{
  position:absolute; width:7px; border-radius:4px;
  background:#0b0f14; pointer-events:none;
  box-shadow:
    inset 0 -1px 0 rgba(255,255,255,.08),
    inset 0 1px 0 rgba(0,0,0,.25),
    0 2px 2px rgba(0,0,0,.25);
}
/* côté gauche (volume/mute) */

#reprog-mockup .rp-btn-left{ left:-4px; }
#reprog-mockup .rp-btn1{ top:140px; height:42px; }
#reprog-mockup .rp-btn2{ top:196px; height:54px; }
#reprog-mockup .rp-btn3{ top:262px; height:42px; }
/* côté droit (power) */

#reprog-mockup .rp-btn-right{ right:-4px; }
#reprog-mockup .rp-btn-power{ top:220px; height:70px; }

/* Écran */

#reprog-mockup .rp-screen{
  position:relative; width:100%; height:100%;
  border-radius:36px; overflow:hidden; background:var(--rp-screen); color:var(--rp-text);
}
#reprog-mockup iframe.rp-map{
  width:100%; height:100%; border:0; display:block;
  filter:invert(1) hue-rotate(180deg) brightness(.9) contrast(.85);
}

/* Indicateur home */

#reprog-mockup .rp-home{
  position:absolute; left:50%; bottom:10px; transform:translateX(-50%);
  width:120px; height:4px; border-radius:999px; background:rgba(255,255,255,.35);
  box-shadow:0 1px 0 rgba(0,0,0,.35), inset 0 1px 1px rgba(255,255,255,.25); z-index:12;
}

/* Notch */

#reprog-mockup .rp-notch{
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:var(--rp-notch-w); height:var(--rp-notch-h);
  background:var(--rp-shell); border-bottom-left-radius:14px; border-bottom-right-radius:14px;
  box-shadow:0 2px 8px rgba(0,0,0,.35); z-index:20;
}

/* Overlay UI */

#reprog-mockup .rp-overlay{ position:absolute; inset:0; z-index:18; pointer-events:none; }
#reprog-mockup .rp-header{
  position:absolute; top:0; left:0; right:0; height:64px; background:var(--rp-header);
  display:flex; flex-direction:column; align-items:center; gap:2px;
  box-shadow:0 2px 0 rgba(0,0,0,.25); border-bottom:1px solid rgba(255,255,255,.08);
}
#reprog-mockup .rp-status{
  width:100%; height:22px; padding:0 12px;
  display:grid; grid-template-columns:1fr var(--rp-notch-w) 1fr; align-items:center;
  font-size:12px; font-weight:600; color:var(--rp-text); text-shadow:0 1px 2px rgba(0,0,0,.25);
}
#reprog-mockup .rp-left, #reprog-mockup .rp-right{ display:flex; align-items:center; }
#reprog-mockup .rp-left{ justify-content:flex-start; gap:4px; padding-left:16px; }
#reprog-mockup .rp-right{ justify-content:flex-end; gap:6px; padding-right:20px; }
#reprog-mockup .rp-time{ letter-spacing:.2px; }

#reprog-mockup .rp-loc{ width:13px; height:13px; display:inline-block; }
#reprog-mockup .rp-loc svg{ width:100%; height:100%; display:block; }

#reprog-mockup .rp-battery{ position:relative; width:20px; height:9px; border:2px solid #fff; border-radius:2px; }
#reprog-mockup .rp-battery::after{ content:""; position:absolute; right:-3px; top:2px; width:2px; height:5px; background:#fff; border-radius:1px; }
#reprog-mockup .rp-battery .rp-level{ position:absolute; left:1px; top:1px; bottom:1px; right:1px; background:#fff; border-radius:1px; }

#reprog-mockup .rp-signal{ display:flex; align-items:flex-end; gap:2px; height:10px; }
#reprog-mockup .rp-signal span{ width:2px; background:#fff; border-radius:1px; }
#reprog-mockup .rp-signal span:nth-child(1){ height:4px; opacity:.6; }
#reprog-mockup .rp-signal span:nth-child(2){ height:6px; opacity:.75; }
#reprog-mockup .rp-signal span:nth-child(3){ height:8px; opacity:.9; }
#reprog-mockup .rp-signal span:nth-child(4){ height:10px; opacity:1; }

#reprog-mockup .rp-title{ font-size:18px; font-weight:700; letter-spacing:.2px; margin-top:0; }
#reprog-mockup .rp-subtitle{ font-size:12.5px; font-weight:500; opacity:.95; margin-top:-2px; }

/* === Réglages mockup (taille + alignement vertical) ===
   - --mockup-w : largeur du téléphone
   - --mockup-offset : décalage vers le bas pour aligner le haut du mockup
     sur le haut du premier champ "Votre nom"                        */

#contact{
  --mockup-w: 285px;     /* <- ajuste ici (ex. 290 / 310) */

  --mockup-offset: 150px; /* <- ajuste ici jusqu’à l’alignement parfait */

  --mockup-shift-x: 20px; /* essaie 12px, 20px, 24px… */

}

/* Taille : on garde le ratio 1:2 (hauteur = 2 × largeur) */

#contact .contact-left #reprog-mockup{ max-width: var(--mockup-w); }
#contact .contact-left #reprog-mockup .rp-shell{ height: calc(var(--mockup-w) * 2); }

/* Alignement vertical du mockup par rapport au champ "Votre nom" */

#contact .contact-left{ margin-top: var(--mockup-offset); }

/* / iPhone Mockup (Isolated + Side Buttons) */

/* ---------------------------------------------------------------------
   BLOC — Décaler le bloc contact (colonne droite) un peu vers la GAUCHE
--------------------------------------------------------------------- */

/* On rend la colonne droite un peu plus large, ce qui déplace sa bordure vers la gauche,
   et on ajoute un léger translateX pour affiner l'alignement. */

@media (min-width: 990px){
  #contact .contact-grid{
    grid-template-columns: 0.9fr 1.1fr !important; /* droite un peu plus large */

  }
  #contact .contact-right{
    transform: translateX(-10px); /* décale finement vers la gauche */

  }
}
/* On évite tout décalage sur mobile */

@media (max-width: 989px){
  #contact .contact-right{ transform: none; }
}

@media (min-width: 990px){
  #contact .contact-grid{
    grid-template-columns: 0.8fr 1.2fr !important;  /* encore plus centré (form + large) */

    justify-content: center !important;
  }
  #contact .contact-right{
    transform: translateX(-24px); /* décalage supplémentaire vers la gauche */

  }
}
@media (max-width: 989px){
  #contact .contact-right{ transform: none; }
}

@media (min-width: 990px){
  #contact .contact-grid{
    grid-template-columns: 0.7fr 1.3fr !important;  /* formulaire plus large encore */

    justify-content: center !important;
  }
  #contact .contact-right{
    transform: translateX(-36px); /* décale davantage vers la gauche */

  }
}
@media (max-width: 989px){
  #contact .contact-right{ transform: none; }
}

/* Réduction légère du mockup (uniforme) */

@media (min-width: 990px){
  #contact .contact-left #reprog-mockup{
    transform: scale(0.94);
    transform-origin: top center;
  }
}

/* 1) Neutraliser les décalages qui peuvent pousser le contenu hors écran */

#contact .contact-right,
#contact .contact-left #reprog-mockup{
  transform: none !important;
  margin-left: 0 !important;
}

/* 2) Recentrer proprement par la grille, sans transform */

@media (min-width: 990px){
  #contact .contact-grid{
    grid-template-columns: 0.7fr 1.3fr;  /* ajuste si besoin */

    justify-content: center;
    gap: 12px;                            /* espace entre mockup et formulaire */

    max-width: 100vw;                     /* ne dépasse pas l’écran */

  }
}

/* 3) Empêcher le scroll horizontal globalement */

html, body{
  overflow-x: hidden;
}
@supports (overflow: clip){
  html, body{ overflow-x: clip; }  /* plus propre si supporté */

}

/* 4) Sécurité : aucun enfant ne doit dépasser */

#contact, #contact .page-width, #contact .contact-grid{
  max-width: 100vw;
}
#contact iframe, #contact img{
  max-width: 100%;
}

/* Décale les icônes réseau + batterie un peu plus vers la droite dans le mockup */

#reprog-mockup .rp-right{
  padding-right: 6px !important;   /* était ~20px */

  transform: translateX(6px);      /* petit boost vers la droite */

}

/* Élargir la barre sombre du haut (descend plus bas) */

#reprog-mockup .rp-header{
  height: 92px !important;      /* était ~64px */

}
/* Ajuste légèrement l'espacement du titre/sous-titre si besoin */

#reprog-mockup .rp-title{ margin-top: 4px; }
#reprog-mockup .rp-subtitle{ margin-top: 2px; }

/* ---------------------------------------------------------------------
   BLOC — Réactivation et mise en avant du notch
--------------------------------------------------------------------- */

#reprog-mockup .rp-notch{
  display: block !important;
  position: absolute;
  top: 10px;                     /* légère marge depuis le bord haut */

  left: 50%;
  transform: translateX(-50%);
  width: var(--rp-notch-w, 150px);
  height: var(--rp-notch-h, 26px); /* notch un peu plus visible */

  background: var(--rp-shell, #0e1116);
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,.35);
  z-index: 30;                   /* au-dessus de l'entête */

}

/* S'assure que la status bar réserve bien la place du notch */

#reprog-mockup .rp-status{
  grid-template-columns: 1fr var(--rp-notch-w,150px) 1fr !important;
}

/* Réduction de la longueur (largeur) du notch tout en restant centré */

#reprog-mockup{ --rp-notch-w: 120px; }  /* ajuste : 110px / 130px si besoin */

/* Placer réseau + batterie juste à DROITE du notch (bord interne de la colonne droite) */

#reprog-mockup .rp-right{
  justify-content: flex-start !important;  /* aligne vers le notch */

  padding-left: 10px !important;           /* petit espace depuis le notch */

  padding-right: 0 !important;
  transform: none !important;              /* annule l'ancien décalage */

}

/* Place RÉSEAU + BATTERIE collés au bord DROIT (symétrique à l'heure à gauche) */

#reprog-mockup .rp-right{
  justify-content: flex-end !important; /* aligne à l'extrême droite */

  padding-right: 16px !important;       /* marge de bord symétrique à la gauche */

  padding-left: 0 !important;
  transform: none !important;           /* supprime tout décalage précédent */

  gap: 6px;
}

/* Optionnel : s'assure que la zone gauche reste bien au bord gauche */

#reprog-mockup .rp-left{
  justify-content: flex-start !important;
  padding-left: 16px !important;
}

/* ---------------------------------------------------------------------
   BLOC — Placement ABSOLU pour rendre les icônes visibles à coup sûr
--------------------------------------------------------------------- */

#reprog-mockup .rp-status{
  position: relative;              /* référentiel pour les positions absolues */

}

#reprog-mockup .rp-left,
#reprog-mockup .rp-right{
  position: absolute !important;
  top: 0;
  height: 22px;                    /* même hauteur que la status bar */

  display: flex !important;
  align-items: center !important;
  gap: 6px;
  padding: 0 !important;
  transform: none !important;
}

#reprog-mockup .rp-left{  left: 16px;  justify-content: flex-start !important; }
#reprog-mockup .rp-right{ right: 16px; justify-content: flex-end   !important; }

/* s'assure que rien ne les masque */

#reprog-mockup .rp-header{ z-index: 28; }
#reprog-mockup .rp-notch{  z-index: 30; } /* notch au-dessus mais centré, ne cache pas les coins */

/* ---------------------------------------------------------------------
   BLOC — Centrer le MOCKUP uniquement sur mobile (≤ 989px)
--------------------------------------------------------------------- */

@media (max-width: 989px){
  #contact .contact-grid{ grid-template-columns: 1fr !important; }
  #contact .contact-left{
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
    margin-top: 16px !important;       /* enlève l'offset desktop */

  }
  #contact .contact-left #reprog-mockup{
    margin: 0 auto !important;
  }
}

/* ---------------------------------------------------------------------
   BLOC — Mobile: placer le MOCKUP sous le FORMULAIRE
--------------------------------------------------------------------- */

@media (max-width: 989px){
  #contact .contact-grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "form"
      "mockup";
    gap: 16px !important;
  }
  #contact .contact-right{ grid-area: form; }   /* formulaire en premier */

  #contact .contact-left{  grid-area: mockup; } /* mockup en dessous */

  /* Conserver le centrage du mockup sous le form */

  #contact .contact-left{
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
    margin-top: 0 !important;
  }
  #contact .contact-left #reprog-mockup{
    margin: 0 auto !important;
  }
}

/* ---------------------------------------------------------------------
   BLOC — Modern Info Cards (scoped)
--------------------------------------------------------------------- */

#contact .ci--modern{
  --ci-bg: #ffffff;
  --ci-border: rgba(0,0,0,.06);
  --ci-shadow: 0 10px 30px rgba(0,0,0,.08);
  --ci-shadow-hover: 0 16px 40px rgba(0,0,0,.12);
  --ci-radius: 18px;
  --ci-grad1: #4f57e1;  /* indigo (assorti à ta page) */

  --ci-grad2: #7aa6ff;  /* bleu clair */

  --ci-text: #0f172a;
  --ci-muted: #6b7280;
  display: grid;
  grid-template-columns: repeat(3, minmax(260px,1fr));
  gap: clamp(16px, 2.5vw, 28px);
  margin-top: clamp(28px, 4vw, 44px);
  align-items: stretch;
}
#contact .ci-card{
  position: relative;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 14px;
  padding: 20px 20px;
  background: var(--ci-bg);
  border: 1px solid var(--ci-border);
  border-radius: var(--ci-radius);
  box-shadow: var(--ci-shadow);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
#contact .ci-card::before{
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(79,87,225,.25), rgba(122,166,255,.15));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: .9;
  pointer-events: none;
}
#contact .ci-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--ci-shadow-hover);
  border-color: rgba(79,87,225,.25);
}
#contact .ci-icon{
  height: 56px; width: 56px; border-radius: 14px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--ci-grad1), var(--ci-grad2));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 8px 20px rgba(79,87,225,.35);
}
#contact .ci-icon svg{
  width: 26px; height: 26px; fill: #fff;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.25));
}
#contact .ci-content{ align-self:center; }
#contact .ci-title{
  font-size: 15px; letter-spacing:.3px; font-weight: 800; color: var(--ci-text);
}
#contact .ci-value{
  font-size: 16px; font-weight: 700; margin-top: 3px; color: var(--ci-text);
}
#contact .ci-sub{
  font-size: 13px; color: var(--ci-muted); margin-top: 2px;
}
#contact .ci-value a{
  color: var(--ci-text); text-decoration: none; border-bottom: 1px dashed rgba(15,23,42,.25);
}
#contact .ci-value a:hover{ border-bottom-color: transparent; }

/* Responsive: 2 colonnes tablette, 1 colonne mobile */

@media (max-width: 1024px){
  #contact .ci--modern{ grid-template-columns: repeat(2, minmax(240px,1fr)); }
}
@media (max-width: 749px){
  #contact .ci--modern{ grid-template-columns: 1fr; }
}

/* ---------------------------------------------------------------------
   BLOC — Accent icons -> Bleu #2C7BFE
--------------------------------------------------------------------- */

#contact .ci--modern{
  --ci-grad1: #2C7BFE;
  --ci-grad2: #2C7BFE; /* uni (peut rester dégradé si tu mets une autre 2e teinte) */

}
/* Retouche de la bordure lumineuse pour matcher le bleu demandé */

#contact .ci-card::before{
  background: linear-gradient(135deg, rgba(44,123,254,.28), rgba(44,123,254,.14)) !important;
}
/* Optionnel : ombre harmonisée */

#contact .ci-icon{
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 8px 20px rgba(44,123,254,.35) !important;
}

/* =========================================================
   ZONE MAP MOCKUP – TABLET + LEAFLET
   Fichier dédié : zone-map-mockup.css
========================================================= */

/* ---------------------------------------------------------------------
   BLOC — CONTAINER
--------------------------------------------------------------------- */

.zone-map-wrapper{
  margin:80px auto;
  display:flex;
  justify-content:center;
  overflow:visible;
}

/* ---------------------------------------------------------------------
   BLOC — TABLET (VISIBLE, SANS HALO)
--------------------------------------------------------------------- */

.zone-map-wrapper .tablet{
  width:min(980px,92vw);
  aspect-ratio:1.48/1;
  position:relative;
  border-radius:64px;
  background:#0f1115 !important; /* tablette conservée */

  box-shadow:none !important;    /* SUPPRESSION DU HALO */

  overflow:visible;
}

/* ---------------------------------------------------------------------
   BLOC — BOUTONS MOCKUP
--------------------------------------------------------------------- */

.zone-map-wrapper .top-buttons{
  position:absolute;
  top:-6px;
  left:90px;
  display:flex;
  gap:10px;
  z-index:1000;
}
.zone-map-wrapper .top-buttons span{
  width:64px;
  height:12px;
  background:#0f1115 !important;
  border-radius:8px;
}

.zone-map-wrapper .side-button{
  position:absolute;
  left:-6px;
  top:140px;
  width:12px;
  height:70px;
  background:#0f1115 !important;
  border-radius:10px;
  z-index:1000;
}

.zone-map-wrapper .side-dot{
  position:absolute;
  left:18px;
  top:50%;
  transform:translateY(-50%);
  width:6px;
  height:6px;
  background:#cfcfcf !important;
  border-radius:50%;
  z-index:1000;
}

/* ---------------------------------------------------------------------
   BLOC — ÉCRAN
--------------------------------------------------------------------- */

.zone-map-wrapper .screen-wrap{
  position:absolute;
  inset:24px;
  border-radius:40px;
  overflow:hidden;
  background:#0f1115 !important;
}
.zone-map-wrapper .screen{
  position:absolute;
  inset:0;
  border-radius:40px;
  overflow:hidden;
}
.zone-map-wrapper #map{
  width:100%;
  height:100%;
}

/* ---------------------------------------------------------------------
   BLOC — LEAFLET — FORCÉ
--------------------------------------------------------------------- */

.zone-map-wrapper .leaflet-container{
  background:#0f1115 !important;
}

.zone-map-wrapper .leaflet-control-attribution{
  display:none !important;
}

/* Marker */

.zone-map-wrapper .leaflet-marker-icon{
  border-radius:50% !important;
  background:#0f1115 !important;
  box-shadow:
    0 0 0 6px rgba(88,230,223,.25),
    0 6px 18px rgba(0,0,0,.75) !important;
}

/* Popup sombre */

.zone-map-wrapper .leaflet-popup-content-wrapper,
.zone-map-wrapper .leaflet-popup-tip{
  background:#0f1115 !important;
  color:#ffffff !important;
  border-radius:10px !important;
  box-shadow:0 10px 26px rgba(0,0,0,.6) !important;
}
.zone-map-wrapper .leaflet-popup-content{
  margin:0 !important;
  padding:12px 16px !important;
  font-size:14px !important;
  line-height:1.35 !important;
}
.zone-map-wrapper .leaflet-popup-close-button{
  color:#9aa0a6 !important;
}
.zone-map-wrapper .leaflet-popup-close-button:hover{
  color:#ffffff !important;
}

/* Label */

.zone-map-wrapper .zone-label{
  background:rgba(15,17,21,.95) !important;
  border:1px solid rgba(255,255,255,.15) !important;
  color:#fff !important;
  border-radius:6px !important;
  padding:6px 10px !important;
  font-size:12px !important;
}

/* Zoom + / - verrouillé */

.zone-map-wrapper .leaflet-control-zoom a{
  background:#ffffff !important;
  color:#000000 !important;
  font-weight:700 !important;
  filter:none !important;
}

/* ---------------------------------------------------------------------
   BLOC — VERROUILLAGE HARD des boutons zoom (+ / -) anti-thème
--------------------------------------------------------------------- */

.zone-map-wrapper .leaflet-control-zoom,
.zone-map-wrapper .leaflet-bar {
  filter: none !important;
  mix-blend-mode: normal !important;
}

.zone-map-wrapper .leaflet-control-zoom a,
.zone-map-wrapper .leaflet-bar a,
.zone-map-wrapper .leaflet-control-zoom a:link,
.zone-map-wrapper .leaflet-control-zoom a:visited,
.zone-map-wrapper .leaflet-control-zoom a:hover,
.zone-map-wrapper .leaflet-control-zoom a:active,
.zone-map-wrapper .leaflet-control-zoom a:focus {
  background: #ffffff !important;     /* fond fixe */

  color: #000000 !important;          /* + / - FIXE */

  border: none !important;
  text-decoration: none !important;
  filter: none !important;
  -webkit-filter: none !important;
  mix-blend-mode: normal !important;
  opacity: 1 !important;
}

/* Leaflet met parfois le symbole dans un <span> selon versions/thèmes */

.zone-map-wrapper .leaflet-control-zoom a span {
  color: #000000 !important;
  filter: none !important;
  -webkit-filter: none !important;
}

/* Séparation entre + et - (au cas où le thème la retire/change) */

.zone-map-wrapper .leaflet-control-zoom a:first-child {
  border-bottom: 1px solid #d0d0d0 !important;
}

/* Focus ring propre (si le thème met un outline bizarre) */

.zone-map-wrapper .leaflet-control-zoom a:focus {
  outline: 2px solid rgba(91,140,255,.6) !important;
  outline-offset: -2px !important;
}

/* ---------------------------------------------------------------------
   BLOC — MOBILE
--------------------------------------------------------------------- */

@media (max-width:768px){
  .zone-map-wrapper .screen-wrap{
  position:absolute;
  inset:10px;            /* AVANT : 24px */

  border-radius:2px;    /* AVANT : 40px */

  overflow:hidden;
  background:#0f1115 !important;
}

  .zone-map-wrapper .tablet{
  width:min(980px,92vw);
  aspect-ratio:1.6 / 1;   /* AVANT : 1.48/1 */

  position:relative;
  border-radius:36px;     /* AVANT : 64px */

  background:#0f1115 !important;
  box-shadow:none !important;
}
  .zone-map-wrapper .leaflet-control-zoom{
	display:none !important;
    transform:scale(.85);
    transform-origin:top left;
  }
}

#reprog-mockup .rp-screen{
  position:relative;
}

#reprog-mockup .rp-map-intercept{
  position:absolute;
  inset:0;
  z-index:20;
  background:transparent;
}

/* ✅ DEST MARKER : supprimer le rond/halo imposé par les styles Leaflet globaux */
.zone-map-wrapper .leaflet-marker-icon.dest-pin-modern,
.zone-map-wrapper .leaflet-div-icon.dest-pin-modern{
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;
}

/* sécurité : certains thèmes mettent aussi un pseudo-fond */
.zone-map-wrapper .leaflet-marker-icon.dest-pin-modern::before,
.zone-map-wrapper .leaflet-marker-icon.dest-pin-modern::after,
.zone-map-wrapper .leaflet-div-icon.dest-pin-modern::before,
.zone-map-wrapper .leaflet-div-icon.dest-pin-modern::after{
  content: none !important;
}
