/* ====================================================
   PAGE CONTACT v3 — full-bleed navy + pattern mesh silos
   Repris du pattern /demande-devis pour cohérence B2B premium.
   Une seule section, form en carte blanche, pas de FAQ, pas
   de section CTA bas — la page est focalisée sur la conversion.
   ==================================================== */

/* Body full-bleed : pas de padding-top (le padding interne de la
   section suffit pour laisser place au header fixe) + fond navy
   pour que la page déborde sans liseret si le contenu est court */
body:has(.contact-bleed){padding-top:0;background:var(--bleu-principal)}

.contact-bleed{
  min-height:100vh;
  position:relative;
  background:var(--bleu-principal);
  /* Dot grid 32px + 4 mesh gradients silos (même pattern que /demande-devis) */
  background-image:
    radial-gradient(circle,rgba(255,255,255,.09) 1px,transparent 1.5px),
    radial-gradient(ellipse 60% 50% at 80% 20%,rgba(255,255,255,.07) 0%,transparent 70%),
    radial-gradient(ellipse 55% 60% at 20% 70%,rgba(17,159,174,.16) 0%,transparent 70%),
    radial-gradient(ellipse 50% 45% at 65% 85%,rgba(60,149,210,.13) 0%,transparent 70%),
    radial-gradient(ellipse 45% 40% at 10% 15%,rgba(38,69,188,.12) 0%,transparent 70%);
  background-size:32px 32px,100% 100%,100% 100%,100% 100%,100% 100%;
}

.contact-bleed__inner{padding:calc(var(--header-height,70px) + var(--s-7)) 0 var(--s-8);position:relative;z-index:1}

/* Breadcrumb top */
.contact-bleed__breadcrumb{font-size:var(--fs-small);color:color-mix(in srgb,var(--blanc) 65%,transparent);margin-bottom:var(--s-6);letter-spacing:.01em}
.contact-bleed__breadcrumb a{color:inherit;text-decoration:none;opacity:.85;transition:opacity .2s ease,color .2s ease}
.contact-bleed__breadcrumb a:hover{opacity:1;color:var(--jaune)}
.contact-bleed__breadcrumb .breadcrumbs-separator,.contact-bleed__breadcrumb span{opacity:.5;margin-inline:.4em}

/* Grid principal : contenu / form card */
.contact-bleed__grid{align-items:start;gap:var(--s-8)}

/* ====================================================
   COL GAUCHE : intro + contacts + métriques
   ==================================================== */
.contact-bleed__intro{color:var(--blanc);display:flex;flex-direction:column;gap:var(--s-6);padding-top:var(--s-3)}

.contact-bleed__intro h1{font-size:clamp(2.25rem,4.5vw,3.25rem);line-height:1.05;color:var(--blanc);margin:0}
.contact-bleed__subtitle{font-size:var(--fs-h5);line-height:1.55;color:color-mix(in srgb,var(--blanc) 82%,transparent);max-width:540px;margin:0}
.contact-bleed__subtitle strong{color:var(--blanc);font-weight:500}

/* Contacts directs : grid 2 cols (tel | email), pictos outline */
.contact-bleed__contacts{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4)}

.contact-bleed__contact-line{display:inline-flex;align-items:center;gap:var(--s-3);padding:var(--s-2) 0;text-decoration:none;color:var(--blanc);transition:transform .25s ease,color .25s ease;min-width:0}
.contact-bleed__contact-line:hover{transform:translateX(3px);color:var(--jaune)}
.contact-bleed__contact-line i{font-size:22px;color:var(--jaune);flex-shrink:0;transition:transform .25s ease}
.contact-bleed__contact-line:hover i{transform:scale(1.1)}
.contact-bleed__contact-line span{display:flex;flex-direction:column;gap:2px;min-width:0}
.contact-bleed__contact-line strong{font-family:'Satoshi',sans-serif;font-weight:600;font-size:var(--fs-body);letter-spacing:-.01em;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contact-bleed__contact-line small{font-size:var(--fs-small);color:color-mix(in srgb,var(--blanc) 55%,transparent);font-weight:400;letter-spacing:.01em}

/* Métriques compactes en ligne sous les contacts */
.contact-bleed__metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);list-style:none;padding:var(--s-5) 0 0;margin:0;border-top:1px solid color-mix(in srgb,var(--blanc) 15%,transparent)}
.contact-bleed__metrics li{display:flex;flex-direction:column;gap:var(--s-1)}
.contact-bleed__metric-num{font-family:'Satoshi',sans-serif;font-weight:800;font-size:clamp(1.4rem,2.4vw,1.9rem);line-height:1;color:var(--blanc);letter-spacing:-.02em}
.contact-bleed__metric-num span{color:var(--jaune);margin-left:2px}
.contact-bleed__metric-lbl{font-size:var(--fs-small);color:color-mix(in srgb,var(--blanc) 65%,transparent);line-height:1.35}

/* Signed by : 3 avatars photos 48px + badge "+3" en 4e position (pattern cluster B2B premium)
   Chevauchement -14px pour imbrication noble, séparation navy via box-shadow (pas un border qui rognerait l'image) */
.contact-bleed__signed{display:flex;align-items:center;gap:var(--s-4);padding-top:var(--s-5);margin-top:var(--s-1);border-top:1px solid color-mix(in srgb,var(--blanc) 10%,transparent)}
.contact-bleed__avatars{display:flex;list-style:none;padding:0;margin:0;flex-shrink:0}
.contact-bleed__avatars li{width:48px;height:48px;border-radius:50%;overflow:hidden;margin-left:-14px;position:relative;box-shadow:0 0 0 .5px var(--bleu-principal)}
.contact-bleed__avatars li:first-child{margin-left:0}
.contact-bleed__avatars li:nth-child(1){z-index:4}
.contact-bleed__avatars li:nth-child(2){z-index:3}
.contact-bleed__avatars li:nth-child(3){z-index:2}
.contact-bleed__avatars li:nth-child(4){z-index:1}
.contact-bleed__avatars li img{width:100%;height:100%;object-fit:cover;display:block}

/* Badge "+3" : 4e cercle dans le cluster, fond navy + texte blanc, style discret mais lisible */
.contact-bleed__avatars li.contact-bleed__avatars-more{display:flex;align-items:center;justify-content:center;font-family:'Satoshi',sans-serif;font-weight:600;font-size:13px;color:var(--blanc);background:var(--bleu-principal);cursor:help}

.contact-bleed__signed-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.contact-bleed__signed-text strong{font-family:'Satoshi',sans-serif;font-weight:500;font-size:var(--fs-body);color:var(--blanc);letter-spacing:-.005em}
.contact-bleed__signed-text small{font-size:var(--fs-small);color:color-mix(in srgb,var(--blanc) 60%,transparent);line-height:1.4}

/* ====================================================
   COL DROITE : FORM CARD blanc (raffinée)
   - Shadow en couches (ambient + key + inset edge light top)
   - Bord 1px blanc à 6% pour pop sur le pattern navy
   - Trait jaune signature 48px 3px en haut à gauche
   ==================================================== */
.contact-bleed__form-card{background:var(--blanc);border-radius:var(--r-md);padding:var(--s-7) var(--s-6) var(--s-6);position:relative;z-index:1;box-shadow:0 0 0 1px color-mix(in srgb,var(--blanc) 6%,transparent),0 32px 80px rgba(0,0,0,.32),0 14px 36px rgba(0,0,0,.14),inset 0 1px 0 rgba(255,255,255,.85)}

/* Trait jaune signature en haut à gauche : rappel du slash Etiq'Azur sans être redondant */
.contact-bleed__form-card::before{content:'';position:absolute;top:0;left:var(--s-6);width:48px;height:3px;background:var(--jaune);border-radius:0 0 var(--r-sm) var(--r-sm)}

.contact-bleed__form-head{margin-bottom:var(--s-5)}
.contact-bleed__form-head h2{font-size:var(--fs-h3);margin:0 0 var(--s-2);color:var(--text);font-weight:600}
.contact-bleed__form-head p{color:var(--muted);margin:0;font-size:var(--fs-body);line-height:1.5}

/* Override : dans la card blanche, pas de padding-top form */
.contact-bleed__form-card #form-contact{padding-top:0}

/* Bannière contextuelle (JS-driven) : liseré gauche jaune, sobre, picto variable
   selon contexte (produit → package, secteur → briefcase, zone → map-pin) */
.contact-context-banner{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);margin-bottom:var(--s-5);background:color-mix(in srgb,var(--jaune) 5%,var(--blanc));border-left:3px solid var(--jaune);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:var(--fs-small);color:var(--muted);line-height:1.5;animation:contactBannerIn .35s cubic-bezier(.4,0,.2,1) both}
.contact-context-banner[hidden]{display:none}
.contact-context-banner i{font-size:18px;color:var(--jaune);flex-shrink:0}
.contact-context-banner strong{color:var(--text);font-weight:600}
@keyframes contactBannerIn{from{opacity:0;transform:translateX(-4px)}to{opacity:1;transform:translateX(0)}}

/* Submit enrichi : texte principal + hint séparé */
.contact-bleed__form-card .btn-submit{display:inline-flex;align-items:baseline;gap:var(--s-3);flex-wrap:wrap;justify-content:center;min-width:240px}
.contact-bleed__form-card .btn-submit .btn-submit__hint{font-family:'Satoshi',sans-serif;font-weight:400;font-size:var(--fs-small);opacity:.78;position:relative;padding-left:var(--s-3);border-left:1px solid color-mix(in srgb,var(--blanc) 30%,transparent);letter-spacing:0;text-transform:none;color:var(--blanc)}

.contact-bleed__form-card .form-navigation{display:flex;flex-direction:column;gap:var(--s-3);align-items:flex-start;margin-top:var(--s-4)}

/* ====================================================
   MAILLAGE : autres points de contact (sous le grid)
   Grid 2 cols : chat IA card premium + liens devis/RDV
   ==================================================== */
.contact-bleed__alt{margin-top:var(--s-8);padding-top:var(--s-7);border-top:1px solid color-mix(in srgb,var(--blanc) 12%,transparent);display:grid;grid-template-columns:1fr 1fr;gap:var(--s-6);color:var(--blanc)}

.contact-bleed__alt-kicker{font-size:var(--fs-small);color:color-mix(in srgb,var(--blanc) 60%,transparent);text-transform:uppercase;letter-spacing:.08em;font-weight:500;margin:0 0 var(--s-2)}

/* Card chat IA */
.contact-bleed__alt-chat{display:flex;flex-direction:column;gap:var(--s-4);padding:var(--s-5) var(--s-5);background:color-mix(in srgb,var(--blanc) 4%,transparent);border:1px solid color-mix(in srgb,var(--blanc) 10%,transparent);border-radius:var(--r-md);justify-content:space-between;align-items:flex-start;transition:background .25s ease,border-color .25s ease}
.contact-bleed__alt-chat:hover{background:color-mix(in srgb,var(--blanc) 6%,transparent);border-color:color-mix(in srgb,var(--blanc) 18%,transparent)}
.contact-bleed__alt-title{font-family:'Satoshi',sans-serif;font-weight:500;font-size:var(--fs-h5);color:var(--blanc);line-height:1.35;margin:0;max-width:40ch}
.contact-bleed__alt-chat .bouton-blanc{display:inline-flex;align-items:center;gap:var(--s-2);flex-shrink:0}
.contact-bleed__alt-chat .bouton-blanc i{font-size:18px;z-index:2;color:var(--bleu-principal)}

/* Liens devis / RDV en liste discrète */
.contact-bleed__alt-links ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:var(--s-2) var(--s-4)}
.contact-bleed__alt-links li{display:flex}
.contact-bleed__alt-links a{display:inline-flex;align-items:center;gap:var(--s-2);color:color-mix(in srgb,var(--blanc) 88%,transparent);text-decoration:none;font-size:var(--fs-body);padding:var(--s-2) 0;transition:color .25s ease,transform .25s ease;width:100%}
.contact-bleed__alt-links a:hover{color:var(--jaune);transform:translateX(2px)}
.contact-bleed__alt-links a i{font-size:18px;color:color-mix(in srgb,var(--jaune) 85%,transparent);flex-shrink:0;transition:color .25s ease}
.contact-bleed__alt-links a:hover i{color:var(--jaune)}
.contact-bleed__alt-links a span{position:relative;padding-bottom:1px;background-image:linear-gradient(var(--jaune),var(--jaune));background-size:0 1px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .35s cubic-bezier(.4,0,.2,1)}
.contact-bleed__alt-links a:hover span{background-size:100% 1px}

/* ====================================================
   STICKY MOBILE TEL (visible <1024px uniquement)
   ==================================================== */
.contact-mobile-sticky{display:none}

/* ====================================================
   RESPONSIVE
   ==================================================== */
@media (max-width:1024px){
  .contact-bleed__inner{padding:calc(var(--header-height-mobile,60px) + var(--s-5)) 0 var(--s-6)}

  /* Grid : stack vertical, intro en haut, form en bas */
  .contact-bleed__grid{gap:var(--s-6)}

  .contact-bleed__intro{gap:var(--s-5);padding-top:0}
  .contact-bleed__intro h1{font-size:clamp(2rem,7vw,2.5rem)}
  .contact-bleed__subtitle{font-size:var(--fs-body)}

  .contact-bleed__contact-line i{font-size:20px}
  .contact-bleed__contact-line strong{font-size:var(--fs-body)}

  .contact-bleed__metrics{gap:var(--s-3);padding-top:var(--s-4)}
  .contact-bleed__metric-num{font-size:clamp(1.2rem,5.5vw,1.6rem)}
  .contact-bleed__metric-lbl{font-size:11px;line-height:1.3}

  /* Contacts 2 cols → stack sur mobile */
  .contact-bleed__contacts{grid-template-columns:1fr;gap:var(--s-3)}
  .contact-bleed__contact-line strong{font-size:var(--fs-body)}

  /* Signed by : plus compact mobile */
  .contact-bleed__signed{padding-top:var(--s-4);gap:var(--s-3)}
  .contact-bleed__avatars li{width:42px;height:42px;margin-left:-12px}
  .contact-bleed__avatars li:first-child{margin-left:0}
  .contact-bleed__avatars-more{font-size:12px}
  .contact-bleed__signed-text strong{font-size:var(--fs-small)}
  .contact-bleed__signed-text small{font-size:11px}

  /* Card : décaler le trait jaune avec le nouveau padding */
  .contact-bleed__form-card::before{left:var(--s-4)}

  /* Form card : moins de padding, full width */
  .contact-bleed__form-card{padding:var(--s-5) var(--s-4) var(--s-5)}
  .contact-bleed__form-head{margin-bottom:var(--s-4)}
  .contact-bleed__form-head h2{font-size:var(--fs-h4)}

  /* Submit full-width + hint en dessous */
  .contact-bleed__form-card .btn-submit{min-width:0;width:100%;padding:14px 24px}
  .contact-bleed__form-card .btn-submit__hint{display:block;font-size:var(--fs-small);margin-top:2px;border-left:none;padding-left:0;opacity:.78}
  .contact-bleed__form-card .form-navigation{align-items:stretch;width:100%}

  /* Sticky mobile tel — VISIBLE */
  .contact-mobile-sticky{display:flex;position:fixed;left:var(--s-3);right:calc(var(--s-3) + 72px);bottom:var(--s-3);z-index:90;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);background:var(--bleu-principal);color:var(--blanc);border-radius:var(--r-md);text-decoration:none;box-shadow:0 10px 32px color-mix(in srgb,var(--bleu-principal) 40%,transparent),0 4px 12px rgba(0,0,0,.15);backdrop-filter:blur(8px);transition:transform .25s ease,box-shadow .25s ease;border:1px solid color-mix(in srgb,var(--blanc) 12%,transparent)}
  .contact-mobile-sticky:hover,.contact-mobile-sticky:active{transform:translateY(-1px);box-shadow:0 14px 36px color-mix(in srgb,var(--bleu-principal) 50%,transparent),0 4px 12px rgba(0,0,0,.2)}
  .contact-mobile-sticky i{font-size:22px;color:var(--jaune);flex-shrink:0}
  .contact-mobile-sticky span{display:flex;flex-direction:column;gap:2px;min-width:0}
  .contact-mobile-sticky strong{font-family:'Satoshi',sans-serif;font-weight:600;font-size:var(--fs-body);color:var(--blanc);letter-spacing:-.01em}
  .contact-mobile-sticky small{font-size:11px;color:color-mix(in srgb,var(--blanc) 75%,transparent);font-weight:400}

  /* Padding bottom page pour laisser place au sticky */
  main.contact-page{padding-bottom:88px}

  /* Maillage alternatif : stack vertical + liens 1 col */
  .contact-bleed__alt{grid-template-columns:1fr;gap:var(--s-5);margin-top:var(--s-7);padding-top:var(--s-6)}

  .contact-bleed__alt-chat{padding:var(--s-4);gap:var(--s-3)}
  .contact-bleed__alt-chat .bouton-blanc{width:100%;justify-content:center}
  .contact-bleed__alt-title{font-size:var(--fs-h6)}
  .contact-bleed__alt-links ul{grid-template-columns:1fr}
}

@media (max-width:640px){
  .contact-bleed__form-card{padding:var(--s-4)}
  .contact-bleed__metrics{gap:var(--s-2)}
  .contact-bleed__metric-lbl{font-size:10px}
}
