
/* ===== 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; }











/* ===== 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: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) -->

/* === 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; }






/* ===== 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;
}





/* ===== 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 */





/* === 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;
  }
}





/* === 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;
  }
}





/* ===== 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; }
}





/* === 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;
}
