.elementor-kit-7{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-color-3da874b:#FFFFFF;--e-global-color-93efcaf:#F4F2E9;--e-global-color-b45e91c:#F2F4F8;--e-global-color-ebc31cb:#000000;--e-global-color-41ae393:#EB8A22;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-7 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS */CSS martinsteamclean sauvegarde :  /* ===========================
   VARIABLES GLOBALES
   =========================== */
:root {
  --bg-page: #F8F6F3;            /* beige clair type carnet propre */
  --bg-card: #FFFFFF;            /* cartes blanches */
  --text-main: #1E1E1E;          /* texte principal presque noir */
  --text-soft: #4A4A4A;          /* texte secondaire gris doux */
  --border-soft: rgba(0,0,0,.07);/* bordure fine gris clair */
  --accent-main: #3A6EA5;        /* bleu sérieux pour action / Calendly */
  --radius-card: 16px;
  --radius-inner: 12px;
  --shadow-card: 0 20px 40px rgba(0,0,0,.08);
  --font-stack: -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif;
}

/* ===========================
   BASE PAGE
   =========================== */

body {
  background-color: var(--bg-page);
  color: var(--text-main);
  font-family: var(--font-stack);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-stack);
  color: var(--text-main);
  line-height: 1.2;
  margin-top: 0;
  font-weight: 600;
}

p {
  color: var(--text-soft);
  font-size: 1rem;
  line-height: 1.5;
  margin: 0 0 1rem;
}

section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 16px;
}

/* ===========================
   TITRES DE SECTION
   =========================== */

.msc-section-head {
  text-align: center;
  margin-bottom: 32px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.msc-section-head h2 {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: 8px;
}

.msc-section-head p {
  font-size: 1rem;
  color: var(--text-soft);
  line-height: 1.4;
}

/* ===========================
   GRILLE TARIFS
   (les 3 cartes GOLD / QUICK / OPTIONS)
   =========================== */

.msc-pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .msc-pricing-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ===========================
   CARTE TARIF
   =========================== */

.msc-card {
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  position: relative;
}

.msc-card-header {
  margin-bottom: 16px;
}

.msc-card-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-main);
  margin: 0 0 4px;
  line-height: 1.3;
}

.msc-card-tagline {
  font-size: .9rem;
  color: var(--text-soft);
  margin: 0;
  line-height: 1.3;
  font-weight: 400;
}

.msc-card-price {
  margin-bottom: 16px;
  color: var(--text-main);
}

.msc-price-from {
  display: block;
  font-size: .75rem;
  font-weight: 500;
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: .03em;
  line-height: 1.2;
}

.msc-price-value {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--text-main);
}

/* liste de prestations dans chaque carte */
.msc-card-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  font-size: .9rem;
  color: var(--text-main);
  line-height: 1.45;
}

.msc-card-list li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
  color: var(--text-main);
}

.msc-card-list li:before {
  content: "✔";
  color: #11823b;
  font-size: .8rem;
  font-weight: 600;
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1.2;
}

/* note légale en bas de carte */
.msc-legal-note {
  font-size: .75rem;
  line-height: 1.4;
  color: var(--text-soft);
  margin-top: auto;
}

/* ===========================
   BOUTONS DANS LES CARTES
   =========================== */

.msc-btn-primary,
.msc-btn-secondary,
.msc-btn-outline {
  display: inline-block;
  width: 100%;
  text-align: center;
  text-decoration: none;
  font-family: var(--font-stack);
  border-radius: var(--radius-inner);
  font-weight: 600;
Afficher le panneau (⌘ + P)

  line-height: 1.2;
  padding: 14px 16px;
  font-size: .95rem;
  cursor: pointer;
  border: 2px solid transparent;
  margin-bottom: 16px;
  transition: all .15s ease-in-out;
}

/* bouton principal : réserver */
.msc-btn-primary {
  background: var(--accent-main);
  border-color: var(--accent-main);
  color: #fff;
  box-shadow: 0 20px 40px rgba(58,110,165,.35);
}

.msc-btn-primary:hover {
  filter: brightness(1.07);
}

/* bouton secondaire : je suis déjà client / etc */
.msc-btn-secondary {
  background: #fff;
  border-color: var(--border-soft);
  color: var(--text-main);
  box-shadow: 0 15px 30px rgba(0,0,0,.07);
  font-weight: 500;
}

.msc-btn-secondary:hover {
  background: #F8F6F3;
  box-shadow: 0 20px 40px rgba(0,0,0,.1);
}

/* bouton contour pour "Demander un devis pro" */
.msc-btn-outline {
  background: transparent;
  border-color: var(--text-main);
  color: var(--text-main);
  box-shadow: 0 20px 40px rgba(0,0,0,.07);
}

.msc-btn-outline:hover {
  background: var(--text-main);
  color: #fff;
  box-shadow: 0 25px 45px rgba(0,0,0,.2);
}

/* ===========================
   SECTION CONTACT RAPIDE (si tu l'utilises en section normale)
   =========================== */

.msc-quick-contact {
  max-width: 1200px;
  margin: 60px auto;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 24px 20px;
}

.msc-quick-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

@media(min-width:768px){
  .msc-quick-inner {
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }
}

.msc-quick-title {
  margin: 0 0 10px;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text-main);
  font-family: var(--font-stack);
}

.msc-quick-sub {
  margin: 0;
  font-size: .95rem;
  color: var(--text-soft);
  line-height: 1.4;
}

.msc-quick-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.msc-action-btn {
  display: block;
  width: 100%;
  text-align: center;
  text-decoration: none;
  font-size: .95rem;
  font-family: var(--font-stack);
  font-weight: 500;
  line-height: 1.2;
  padding: 14px 16px;
  border-radius: 10px;
  border: 2px solid transparent;
  cursor: pointer;
}

/* variantes boutons dans le bloc contact rapide */
.call-btn {
  background:#fff;
  border-color:var(--border-soft);
  color:var(--text-main);
  box-shadow:0 10px 20px rgba(0,0,0,.04);
}
.call-btn:hover {
  background:#fdfdfd;
  box-shadow:0 16px 32px rgba(0,0,0,.07);
}
.rdv-btn {
  background:var(--accent-main);
  border-color:var(--accent-main);
  color:#fff;
  font-weight:600;
  box-shadow:0 16px 32px rgba(58,110,165,.4);
}
.rdv-btn:hover {
  filter:brightness(1.07);
}
.wa-btn {
  background:#25D366;
  border-color:#25D366;
  color:#fff;
  font-weight:600;
  box-shadow:0 16px 32px rgba(37,211,102,.4);
}
.wa-btn:hover {
  filter:brightness(1.07);
}

/* ===========================
   BLOC AVANT / APRÈS (si tu en mets un plus tard)
   =========================== */

.msc-before-after {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 1200px;
  margin: 40px auto;
}

@media(min-width:768px){
  .msc-before-after {
    grid-template-columns: repeat(2,1fr);
  }
}

.msc-before-after .msc-box {
  background:#fff;
  border:1px solid var(--border-soft);
  border-radius:var(--radius-card);
  box-shadow:var(--shadow-card);
  padding:16px;
}

.msc-before-after img {
  width:100%;
  border-radius:var(--radius-inner);
  display:block;
  border:1px solid var(--border-soft);
  box-shadow:0 15px 30px rgba(0,0,0,.08);
}

.msc-ba-label {
  font-size:.8rem;
  font-weight:600;
  margin:0 0 8px;
  color:var(--text-main);
  text-transform:uppercase;
  letter-spacing:.03em;
}

/* ===========================
   MEDIA DANS LES CARTES TARIFS (image en haut de carte)
   =========================== */

.msc-card-media {
  width: 100%;
  border-radius: var(--radius-inner);
  overflow: hidden;
  margin: -8px 0 16px;
  box-shadow: 0 16px 32px rgba(0,0,0,.08);
  border: 1px solid var(--border-soft);
}

.msc-card-media img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

@media(min-width:768px){
  .msc-card-media img {
    height: 160px;
  }
}

/* FIN STYLE GLOBAL */
/* =================================================== */


/* ===================================================
   2. BOUTONS FLOTTANTS (📞 / 📅 / WhatsApp)
   =================================================== */

/* conteneur des bulles */
.msc-floating-icons {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  font-family: var(--font-stack);
}

/* bulle commune */
.msc-icon-btn {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  font-size: 1.2rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow: 0 15px 30px rgba(0,0,0,.25);
  border: 2px solid transparent;
  cursor: pointer;
  background: #fff;
  color: #1E1E1E;
  transition: all .15s ease-in-out;
  border-color: rgba(0,0,0,.1);
}

.msc-icon-btn:hover {
  transform: scale(1.08);
  filter: brightness(1.1);
}

/* bulle téléphone */
.msc-call {
  background:#fff;
  color:#1E1E1E;
  border-color:rgba(0,0,0,.15);
}

/* bulle réservation */
.msc-book {
  background: var(--accent-main);
  border-color: var(--accent-main);
  color:#fff;
  box-shadow:0 20px 40px rgba(58,110,165,.35);
  font-size:1.25rem;
}

/* bulle WhatsApp */
.msc-wa {
  background:#25D366;
  border-color:#25D366;
  box-shadow:0 20px 40px rgba(37,211,102,.4);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  position:relative;
  animation: msc-wa-pulse 2.5s infinite; /* halo doux */
}

/* image du logo WhatsApp */
.msc-wa-img {
  width:60%;
  height:60%;
  object-fit:contain;
  filter:brightness(0) invert(1); /* logo blanc sur fond vert */
  transition:transform .15s ease;
}
.msc-wa:hover .msc-wa-img {
  transform:scale(1.1);
}

/* halo pulsant autour du bouton WhatsApp */
@keyframes msc-wa-pulse {
  0%   { box-shadow:0 0 0 0 rgba(37,211,102,.4); }
  70%  { box-shadow:0 0 0 10px rgba(37,211,102,0); }
  100% { box-shadow:0 0 0 0 rgba(37,211,102,0); }
}

/* responsive desktop = bulles un peu plus grandes et un poil décalées */
@media(min-width:768px){
  .msc-floating-icons {
    right:24px;
    bottom:24px;
    gap:12px;
  }
  .msc-icon-btn {
    width:55px;
    height:55px;
    font-size:1.3rem;
  }
  .msc-wa-img {
    width:62%;
    height:62%;
  }
}
/* Forcer les bulles flottantes à passer au-dessus de tout et accepter les clics */
.msc-floating-icons,
.msc-floating-icons * {
  position: relative;
  z-index: 999999 !important;
  pointer-events: auto !important;
  cursor: pointer;
}

/* Et au cas où un overlay du thème aurait un z-index malade type 999999 aussi,
   on met encore plus haut sur WhatsApp en particulier */
.msc-wa {
  z-index: 1000000 !important;
}

/* On re-précise le style WhatsApp pour éviter les effets bizarres */
.msc-wa {
  background:#25D366;
  border-color:#25D366;
  box-shadow:0 20px 40px rgba(37,211,102,.4);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  animation: msc-wa-pulse 2.5s infinite;
}

.msc-wa-img {
  width:60%;
  height:60%;
  object-fit:contain;
  filter:brightness(0) invert(1); /* logo blanc */
  transition:transform .15s ease;
}

.msc-wa:hover .msc-wa-img {
  transform:scale(1.1);
}
/* FORCE le module d'icônes à redevenir flottant en bas à droite de l'écran */
.msc-floating-icons {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  z-index: 1000000 !important;

  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
  pointer-events: auto;
}

/* Chaque bulle */
.msc-icon-btn {
  width: 55px;
  height: 55px;
  border-radius: 50%;
  background: #fff;
  color: #1E1E1E;
  border: 2px solid rgba(0,0,0,.1);
  box-shadow: 0 15px 30px rgba(0,0,0,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: all .15s ease-in-out;
  pointer-events: auto;
  z-index: 1000001;
}

/* Téléphone (fond blanc) */
.msc-call {
  background:#fff;
  color:#1E1E1E;
  border-color:rgba(0,0,0,.15);
}

/* Réservation (fond bleu) */
.msc-book {
  background:#3A6EA5;
  border-color:#3A6EA5;
  color:#fff;
  box-shadow:0 20px 40px rgba(58,110,165,.35);
  font-size:1.3rem;
}

/* WhatsApp (fond vert) */
.msc-wa {
  background:#25D366;
  border-color:#25D366;
  box-shadow:0 20px 40px rgba(37,211,102,.4);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  animation: msc-wa-pulse 2.5s infinite;
}

/* Icône WhatsApp (logo) */
.msc-wa-img {
  width:60%;
  height:60%;
  object-fit:contain;
  filter:brightness(0) invert(1); /* logo blanc */
  transition:transform .15s ease;
}

/* Hover desktop = petit zoom */
.msc-icon-btn:hover {
  transform: scale(1.08);
  filter: brightness(1.1);
}
.msc-wa:hover .msc-wa-img {
  transform: scale(1.1);
}

/* Halo doux WhatsApp */
@keyframes msc-wa-pulse {
  0%   { box-shadow:0 0 0 0 rgba(37,211,102,.4); }
  70%  { box-shadow:0 0 0 10px rgba(37,211,102,0); }
  100% { box-shadow:0 0 0 0 rgba(37,211,102,0); }
}

/* Version bureau : légère remontée et espacement un peu plus grand */
@media(min-width:768px){
  .msc-floating-icons {
    right:24px !important;
    bottom:24px !important;
    gap:12px;
  }
  .msc-icon-btn {
    width:58px;
    height:58px;
    font-size:1.35rem;
  }
  .msc-wa-img {
    width:62%;
    height:62%;
  }
}
/* ===========================
   HERO (bandeau d'accueil)
   =========================== */

.msc-hero {
  position: relative;
  min-height: 70vh;
  width: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 40px 16px 80px;
  box-sizing: border-box;

  /* IMAGE DE FOND TEMPORAIRE
     -> remplace l'URL par une de tes photos propres quand tu veux
  */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  color: #fff;
  overflow: hidden;
  border-bottom: 1px solid rgba(0,0,0,.15);
}

/* voile foncé pour lire le texte sur la photo */
.msc-hero-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 30% 30%,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.55) 60%,
    rgba(0,0,0,0.75) 100%
  );
  pointer-events: none;
  z-index: 0;
}

/* logo en haut gauche */
.msc-hero-brand {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 8px;
}

.msc-hero-logo {
  height: 64px;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.6));
}

/* bloc texte principal */
.msc-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 600px;
  text-align: center;
  color: #fff;
}

.msc-hero-title {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 16px;
  text-shadow: 0 25px 40px rgba(0,0,0,.8);
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
}

.msc-hero-sub {
  font-size: 1rem;
  line-height: 1.5;
  color: rgba(255,255,255,.9);
  margin: 0 0 24px;
  text-shadow: 0 20px 30px rgba(0,0,0,.8);
  font-weight: 400;
}

/* CTA buttons */
.msc-hero-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.msc-hero-btn {
  display: inline-block;
  min-width: 220px;
  text-align: center;
  font-size: .95rem;
  font-weight: 600;
  line-height: 1.2;
  padding: 14px 16px;
  border-radius: 10px;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  box-shadow: 0 20px 40px rgba(0,0,0,.5);
  transition: all .15s ease-in-out;
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
}

.msc-hero-btn-main {
  background: var(--accent-main, #3A6EA5);
  border-color: var(--accent-main, #3A6EA5);
  color: #fff;
}
.msc-hero-btn-main:hover {
  filter: brightness(1.07);
  box-shadow: 0 25px 45px rgba(0,0,0,.6);
}

.msc-hero-btn-alt {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.4);
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.msc-hero-btn-alt:hover {
  background: rgba(255,255,255,.12);
  box-shadow: 0 25px 45px rgba(0,0,0,.6);
}

/* zone d'intervention */
.msc-hero-zone {
  font-size: .8rem;
  line-height: 1.4;
  color: rgba(255,255,255,.8);
  text-shadow: 0 20px 30px rgba(0,0,0,.8);
  margin: 0;
}

/* version desktop */
@media(min-width:768px){
  .msc-hero {
    min-height: 80vh;
    padding-bottom: 120px;
  }

  .msc-hero-brand {
    top: 24px;
    left: 24px;
  }

  .msc-hero-logo {
    height: 72px;
    max-width: 220px;
  }

  .msc-hero-inner {
    text-align: left;
    margin-left: 0;
  }

  .msc-hero-title {
    font-size: 2.4rem;
  }

  .msc-hero-sub {
    font-size: 1rem;
    max-width: 480px;
  }

  .msc-hero-cta {
    flex-direction: row;
    justify-content: flex-start;
  }

  .msc-hero-btn {
    min-width: auto;
  }
}
/* ===========================
   HERO VIDÉO
   =========================== */

.msc-hero {
  position: relative;
  min-height: 70vh;
  width: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 40px 16px 80px;
  box-sizing: border-box;
  color: #fff;
  overflow: hidden;
  border-bottom: 1px solid rgba(0,0,0,.15);
  background-color: #000; /* sécurité si la vidéo charge pas */
}

/* fond vidéo plein écran */
.msc-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;      /* recouvre sans distorsion */
  object-position: center;
  z-index: 0;
  filter: brightness(.8) contrast(1.1) saturate(1.1);
}

/* voile foncé pour lisibilité du texte */
.msc-hero-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 30% 30%,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.55) 60%,
    rgba(0,0,0,0.75) 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* logo en haut gauche */
.msc-hero-brand {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 8px;
}

.msc-hero-logo {
  height: 64px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.7));
}

/* bloc texte */
.msc-hero-inner {
  position: relative;
  z-index: 3;
  max-width: 600px;
  text-align: center;
  color: #fff;
}

.msc-hero-title {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 16px;
  text-shadow: 0 25px 40px rgba(0,0,0,.8);
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
}

.msc-hero-sub {
  font-size: 1rem;
  line-height: 1.5;
  color: rgba(255,255,255,.9);
  margin: 0 0 24px;
  text-shadow: 0 20px 30px rgba(0,0,0,.8);
  font-weight: 400;
}

/* CTA buttons */
.msc-hero-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.msc-hero-btn {
  display: inline-block;
  min-width: 220px;
  text-align: center;
  font-size: .95rem;
  font-weight: 600;
  line-height: 1.2;
  padding: 14px 16px;
  border-radius: 10px;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  box-shadow: 0 20px 40px rgba(0,0,0,.6);
  transition: all .15s ease-in-out;
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
}

.msc-hero-btn-main {
  background: var(--accent-main, #3A6EA5);
  border-color: var(--accent-main, #3A6EA5);
  color: #fff;
}
.msc-hero-btn-main:hover {
  filter: brightness(1.07);
  box-shadow: 0 25px 45px rgba(0,0,0,.7);
}

.msc-hero-btn-alt {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.4);
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.msc-hero-btn-alt:hover {
  background: rgba(255,255,255,.12);
  box-shadow: 0 25px 45px rgba(0,0,0,.7);
}

/* zone d'intervention */
.msc-hero-zone {
  font-size: .8rem;
  line-height: 1.4;
  color: rgba(255,255,255,.8);
  text-shadow: 0 20px 30px rgba(0,0,0,.9);
  margin: 0;
}

/* Desktop */
@media(min-width:768px){
  .msc-hero {
    min-height: 80vh;
    padding-bottom: 120px;
  }

  .msc-hero-brand {
    top: 24px;
    left: 24px;
  }

  .msc-hero-logo {
    height: 72px;
    max-width: 240px;
  }

  .msc-hero-inner {
    text-align: left;
    margin-left: 0;
  }

  .msc-hero-title {
    font-size: 2.4rem;
  }

  .msc-hero-sub {
    font-size: 1rem;
    max-width: 480px;
  }

  .msc-hero-cta {
    flex-direction: row;
    justify-content: flex-start;
  }

  .msc-hero-btn {
    min-width: auto;
  }
}
/* ===========================
   LOGO HERO (bas droite + effet)
   =========================== */

.msc-hero-brand {
  position: absolute;
  bottom: 30px; /* distance du bas */
  right: 40px;  /* distance du bord droit */
  z-index: 3;
  animation: fadeInLogo 1.5s ease-in-out forwards;
}

.msc-hero-logo {
  height: 90px;       /* taille du logo, ajuste si besoin */
  width: auto;
  max-width: 260px;
  object-fit: contain;
  opacity: 0;         /* pour l'animation */
  filter: drop-shadow(0 0 18px rgba(255, 255, 255, 0.65)) drop-shadow(0 6px 14px rgba(0, 0, 0, 0.4));
  animation: fadeInLogo 1.5s ease-in-out 0.2s forwards;
}

/* Animation douce du logo */
@keyframes fadeInLogo {
  from {
    opacity: 0;
    transform: translateY(15px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Version mobile (logo un peu plus petit et remonté pour ne pas cacher le texte) */
@media (max-width: 768px) {
  .msc-hero-brand {
    bottom: 20px;
    right: 20px;
  }

  .msc-hero-logo {
    height: 70px;
    max-width: 200px;
  }
}
/* HERO container */
.msc-hero {
  position: relative;
  min-height: 70vh;
  width: 100%;
  display: block;
  box-sizing: border-box;
  color: #fff;
  overflow: hidden;
  border-bottom: 1px solid rgba(0,0,0,.15);
  background-color: #000; /* si la vidéo charge pas */
  padding: 0; /* pas de padding ici, on gère via le contenu */
}

/* Vidéo plein fond */
.msc-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  filter: brightness(.8) contrast(1.1) saturate(1.1);
}

/* voile sombre par-dessus la vidéo */
.msc-hero-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 30% 30%,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.55) 60%,
    rgba(0,0,0,0.75) 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* Bloc global (logo + texte) positionné dans la vidéo */
.msc-hero-content {
  position: absolute;
  left: 50%;
  top: 65%; /* <-- règle la hauteur du bloc dans la vidéo. Plus grand = plus bas */
  transform: translate(-50%, -50%);
  z-index: 3;

  width: 90%;
  max-width: 1100px;

  display: flex;
  flex-direction: column; /* mobile par défaut */
  align-items: center;
  text-align: center;

  color: #fff;
}

/* Partie logo */
.msc-hero-topline {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  animation: heroFadeUp 1.2s ease forwards;
}

.msc-hero-logo {
  height: 80px;
  width: auto;
  max-width: 260px;
  object-fit: contain;
  opacity: 0;
  filter:
    drop-shadow(0 0 18px rgba(255,255,255,0.7))
    drop-shadow(0 8px 20px rgba(0,0,0,0.6));
  animation: heroFadeUp 1.2s ease .1s forwards;
}

/* Partie texte + CTA */
.msc-hero-textblock {
  max-width: 600px;
  animation: heroFadeUp 1.2s ease .2s forwards;
  opacity: 0;
  text-shadow: 0 25px 40px rgba(0,0,0,.8);
}

.msc-hero-title {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 16px;
  text-shadow: 0 25px 40px rgba(0,0,0,.9);
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
}

.msc-hero-sub {
  font-size: 1rem;
  line-height: 1.5;
  color: rgba(255,255,255,.9);
  margin: 0 0 24px;
  font-weight: 400;
  text-shadow: 0 20px 30px rgba(0,0,0,.9);
}

/* Boutons CTA */
.msc-hero-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.msc-hero-btn {
  display: inline-block;
  min-width: 220px;
  text-align: center;
  font-size: .95rem;
  font-weight: 600;
  line-height: 1.2;
  padding: 14px 16px;
  border-radius: 10px;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  box-shadow: 0 20px 40px rgba(0,0,0,.6);
  transition: all .15s ease-in-out;
  font-family: var(--font-stack, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif);
}

.msc-hero-btn-main {
  background: var(--accent-main, #3A6EA5);
  border-color: var(--accent-main, #3A6EA5);
  color: #fff;
}
.msc-hero-btn-main:hover {
  filter: brightness(1.07);
  box-shadow: 0 25px 45px rgba(0,0,0,.7);
}

.msc-hero-btn-alt {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.4);
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.msc-hero-btn-alt:hover {
  background: rgba(255,255,255,.12);
  box-shadow: 0 25px 45px rgba(0,0,0,.7);
}

/* Zone d'intervention */
.msc-hero-zone {
  font-size: .8rem;
  line-height: 1.4;
  color: rgba(255,255,255,.8);
  margin: 0;
  text-shadow: 0 20px 30px rgba(0,0,0,.9);
}

/* Animation d'apparition */
@keyframes heroFadeUp {
  from {
    opacity: 0;
    transform: translateY(20px) scale(.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* =============== TABLETTE / DESKTOP =============== */
@media(min-width:768px){
  .msc-hero-content {
    flex-direction: row;         /* logo + texte côte à côte */
    align-items: flex-start;
    text-align: left;
    top: 60%;                    /* un poil plus haut sur desktop */
    transform: translate(-50%, -50%);
    gap: 24px;
    max-width: 1100px;
  }

  .msc-hero-topline {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .msc-hero-logo {
    height: 90px;
    max-width: 260px;
  }

  .msc-hero-textblock {
    max-width: 480px;
  }

  .msc-hero-title {
    font-size: 2.2rem;
  }

  .msc-hero-sub {
    font-size: 1rem;
    max-width: 440px;
  }

  .msc-hero-cta {
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .msc-hero-btn {
    min-width: auto;
  }
}

/* =============== GRAND ÉCRAN =============== */
@media(min-width:1024px){
  .msc-hero-content {
    top: 62%;
    gap: 32px;
  }

  .msc-hero-logo {
    height: 100px;
    max-width: 300px;
  }

  .msc-hero-title {
    font-size: 2.4rem;
  }
}
/* HERO base */
.msc-hero {
  position: relative;
  min-height: 90vh;
  width: 100%;
  background-color: #000;
  color: #fff;
  overflow: hidden;
  border-bottom: 1px solid rgba(0,0,0,.15);
}

/* Vidéo fond */
.msc-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  filter: brightness(.8) contrast(1.1) saturate(1.1);
}

/* Voile sombre lisibilité */
.msc-hero-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 30% 30%,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.55) 60%,
    rgba(0,0,0,0.75) 100%
  );
  z-index: 1;
  pointer-events: none;
}

/* Contenu hero */
.msc-hero-content {
  position: absolute;
  left: 50%;
  top: 60%;
  transform: translate(-50%, -50%);
  z-index: 3;

  width: 90%;
  max-width: 500px;

  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;

  color: #fff;
  line-height: 1.4;
}

/* Logo */
.msc-hero-topline {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  animation: heroFadeUp 1.2s ease forwards;
}

.msc-hero-logo {
  height: 70px;
  max-width: 230px;
  width: auto;
  object-fit: contain;
  opacity: 0;
  filter:
    drop-shadow(0 0 18px rgba(255,255,255,0.7))
    drop-shadow(0 8px 20px rgba(0,0,0,0.6));
  animation: heroFadeUp 1.2s ease .1s forwards;
}

/* Bloc texte */
.msc-hero-textblock {
  max-width: 600px;
  opacity: 0;
  animation: heroFadeUp 1.2s ease .2s forwards;
  text-shadow: 0 25px 40px rgba(0,0,0,.8);
}

.msc-hero-title {
  font-size: 1.9rem;
  font-weight: 600;
  line-height: 1.2;
  color: #fff;
  margin: 0 0 16px;
  text-shadow: 0 25px 40px rgba(0,0,0,.9);
  word-break: normal;
}

.msc-hero-sub {
  font-size: .95rem;
  line-height: 1.5;
  color: rgba(255,255,255,.9);
  margin: 0 0 16px;
  font-weight: 400;
  text-shadow: 0 20px 30px rgba(0,0,0,.9);
}

.msc-hero-zone {
  font-size: .8rem;
  line-height: 1.4;
  color: rgba(255,255,255,.8);
  margin: 0;
  text-shadow: 0 20px 30px rgba(0,0,0,.9);
}

/* Animation apparition douce */
@keyframes heroFadeUp {
  from {
    opacity: 0;
    transform: translateY(20px) scale(.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* TABLETTE */
@media(min-width:768px){

  .msc-hero {
    min-height: 80vh;
  }

  .msc-hero-content {
    top: 60%;
    transform: translate(-50%, -50%);
    max-width: 90%;
    flex-direction: row;          /* logo à gauche, texte à droite */
    align-items: flex-start;
    justify-content: center;
    text-align: left;
    gap: 24px;
  }

  .msc-hero-topline {
    margin-bottom: 0;
    justify-content: flex-start;
    flex-shrink: 0;
  }

  .msc-hero-logo {
    height: 80px;
    max-width: 240px;
  }

  .msc-hero-textblock {
    max-width: 440px;
    text-align: left;
  }

  .msc-hero-title {
    font-size: 2rem;
    margin-bottom: 16px;
    text-align: left;
  }

  .msc-hero-sub {
    font-size: 1rem;
    max-width: 440px;
    margin-bottom: 12px;
    text-align: left;
  }

  .msc-hero-zone {
    max-width: 440px;
    text-align: left;
  }
}

/* DESKTOP LARGE */
@media(min-width:1024px){

  .msc-hero-content {
    top: 62%;
    max-width: 1100px;
    gap: 32px;
  }

  .msc-hero-logo {
    height: 95px;
    max-width: 300px;
  }

  .msc-hero-textblock {
    max-width: 500px;
  }

  .msc-hero-title {
    font-size: 2.2rem;
  }

  .msc-hero-sub {
    font-size: 1rem;
    max-width: 460px;
  }
}
/* Boutons flottants contact / action */
.msc-float-actions {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 12px;
  pointer-events: none; /* on réactive au niveau des boutons */
}

.msc-float-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;

  min-height: 44px;
  min-width: 44px;
  padding: 10px 14px;
  border-radius: 12px;

  font-size: .9rem;
  font-weight: 600;
  line-height: 1.2;
  color: #fff;
  text-decoration: none;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Inter", "Roboto", sans-serif;

  box-shadow: 0 18px 30px rgba(0,0,0,.4);
  border: 1px solid rgba(255,255,255,.2);

  pointer-events: auto;
}

/* Icône dans les bulles */
.msc-float-icon {
  font-size: 1.1rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.msc-float-label {
  white-space: nowrap;
  line-height: 1.2;
}

/* Style téléphone */
.msc-call {
  background: linear-gradient(#1f1f1f, #000);
  border-color: rgba(255,255,255,.25);
}

/* Style réservation */
.msc-book {
  background: #2f61a9;
  border-color: rgba(255,255,255,.25);
}

/* Style WhatsApp */
.msc-wa {
  background: #25D366;
  border-color: rgba(0,0,0,.2);
  color: #000;
  font-weight: 600;
}

/* effet hover desktop */
@media(min-width:768px){
  .msc-float-btn:hover {
    filter: brightness(1.08);
    box-shadow: 0 24px 40px rgba(0,0,0,.5);
  }
}

/* version mobile : bouton résa garde le texte "Réserver", les autres restent icône seule = nickel */
@media(max-width:480px){
  .msc-float-btn {
    padding: 10px 12px;
    min-height: 44px;
    min-width: 44px;
    border-radius: 12px;
  }

  .msc-call .msc-float-label,
  .msc-wa .msc-float-label {
    display: none;
  }
}
/* === Boutons flottants téléphone / réservation / WhatsApp === */
.floating-buttons {
  position: fixed;
  right: 15px;
  bottom: 15px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  z-index: 9999;
}

/* Styles de base pour les bulles */
.floating-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 6px 20px rgba(0,0,0,0.3);
  transition: all 0.25s ease;
  z-index: 10000;
}

.floating-btn i {
  font-size: 22px;
  line-height: 1;
}

/* Couleurs spécifiques */
.floating-btn.phone {
  background-color: #2c2c2c;
}

.floating-btn.booking {
  background-color: #3a6ea5;
}

.floating-btn.whatsapp {
  background-color: #25D366;
}

/* Effet hover sur desktop */
@media (hover:hover) {
  .floating-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 10px 25px rgba(0,0,0,0.4);
  }
}

/* Espacement mobile */
@media (max-width: 600px) {
  .floating-buttons {
    right: 10px;
    bottom: 10px;
    gap: 8px;
  }

  .floating-btn {
    width: 46px;
    height: 46px;
  }

  .floating-btn i {
    font-size: 20px;
  }
}
/* SECTION TITRE TARIFS */
.msc-pricing-section {
  background: var(--bg-page, #F8F6F3);
  padding: 40px 16px 60px;
}

.msc-section-head {
  text-align: center;
  margin: 0 auto 32px;
  max-width: 800px;
  color: var(--text-main, #1E1E1E);
}

.msc-section-head h2 {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--text-main, #1E1E1E);
  margin: 0 0 8px;
  line-height: 1.2;
}

.msc-section-head p {
  font-size: .95rem;
  line-height: 1.4;
  color: var(--text-soft, #4A4A4A);
  margin: 0;
}

/* GRILLE DES CARTES TARIFS */
.msc-pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}

@media(min-width:768px){
  .msc-pricing-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* CARTE TARIF */
.msc-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 16px;
  box-shadow: 0 20px 40px rgba(0,0,0,.08);
  padding: 24px 20px;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

/* image en haut de carte */
.msc-card-media {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  margin: -4px 0 16px;
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: 0 15px 30px rgba(0,0,0,.08);
}
.msc-card-media img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
}

/* header de la carte */
.msc-card-header {
  margin-bottom: 16px;
}

.msc-card-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-main, #1E1E1E);
  margin: 0 0 4px;
  line-height: 1.3;
}

.msc-card-tagline {
  font-size: .9rem;
  color: var(--text-soft, #4A4A4A);
  margin: 0;
  line-height: 1.3;
  font-weight: 400;
}

/* prix */
.msc-card-price {
  margin-bottom: 16px;
  color: var(--text-main, #1E1E1E);
}
.msc-price-from {
  display: block;
  font-size: .75rem;
  font-weight: 500;
  color: var(--text-soft, #4A4A4A);
  text-transform: uppercase;
  letter-spacing: .03em;
  line-height: 1.2;
}
.msc-price-value {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--text-main, #1E1E1E);
}

/* liste prestations */
.msc-card-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  font-size: .9rem;
  color: var(--text-main, #1E1E1E);
  line-height: 1.45;
}
.msc-card-list li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
}
.msc-card-list li:before {
  content: "✔";
  color: #11823b;
  font-size: .8rem;
  font-weight: 600;
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1.2;
}

/* note bas de carte */
.msc-legal-note {
  font-size: .75rem;
  line-height: 1.4;
  color: var(--text-soft, #4A4A4A);
  margin-top: auto;
}
/* Galerie visuelle pro / flottes */
.msc-pro-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  margin: 0 0 24px;
}

@media(max-width:600px){
  .msc-pro-gallery {
    grid-template-columns: 1fr 1fr;
  }
}

@media(max-width:400px){
  .msc-pro-gallery {
    grid-template-columns: 1fr;
  }
}

.msc-pro-gallery-item {
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 12px;
  box-shadow: 0 16px 32px rgba(0,0,0,.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.msc-pro-gallery-item img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  display: block;
}

@media(min-width:768px){
  .msc-pro-gallery-item img {
    height: 140px;
  }
}

.msc-pro-gallery-label {
  font-size: .8rem;
  line-height: 1.4;
  font-weight: 500;
  color: #1E1E1E;
  padding: 8px 10px 10px;
  background: #F8F6F3;
  border-top: 1px solid rgba(0,0,0,.05);
}
/* ===============================
   STYLE GÉNÉRAL DES SECTIONS BAS DE PAGE
   ("Solutions pro & flottes" + "Demande de devis / Entreprises")
   =============================== */

/* gros conteneurs : fond clair, bord arrondi, ombre douce */
.msc-block {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 16px;
  box-shadow: 0 24px 48px rgba(0,0,0,.08);
  padding: 24px 20px;
  margin-bottom: 64px;
}

@media(min-width:900px){
  .msc-block {
    padding: 32px 28px;
  }
}

/* titres de section type "Solutions pro & flottes", "Demande de devis / Entreprises" */
.msc-sec-title {
  font-size: 1.25rem;
  line-height: 1.2;
  font-weight: 600;
  color: #1E1E1E;
  margin: 0 0 12px;
  letter-spacing: -0.02em;
}

/* sous-texte introductif sous le titre */
.msc-sec-intro {
  font-size: .95rem;
  line-height: 1.4;
  color: #4A4A4A;
  margin: 0 0 24px;
  max-width: 900px;
}

/* grille galerie flottes (les 3 cartes avec images) */
.msc-pro-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  margin: 0 0 24px;
}

@media(max-width:800px){
  .msc-pro-gallery {
    grid-template-columns: 1fr 1fr;
  }
}
@media(max-width:480px){
  .msc-pro-gallery {
    grid-template-columns: 1fr;
  }
}

.msc-pro-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 12px;
  box-shadow: 0 16px 32px rgba(0,0,0,.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.msc-pro-card img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  display: block;
}

.msc-pro-card-label {
  background: #F8F6F3;
  border-top: 1px solid rgba(0,0,0,.05);
  font-size: .8rem;
  line-height: 1.4;
  font-weight: 500;
  color: #1E1E1E;
  padding: 8px 10px 10px;
}

/* bloc liste "Pour qui ?" / "Tarifs dégressifs" */
.msc-pro-lists {
  font-size: .9rem;
  line-height: 1.5;
  color: #1E1E1E;
}

.msc-pro-lists h3 {
  font-size: 1rem;
  font-weight: 600;
  margin: 24px 0 8px;
  color: #1E1E1E;
}

.msc-pro-lists ul {
  margin: 0 0 16px 1.2em;
  padding: 0;
}
.msc-pro-lists li {
  margin-bottom: 6px;
}

/* ===============================
   BLOC CONTACT / FORMULAIRE ENTREPRISES
   =============================== */

/* le conteneur global (on va te demander de lui mettre la classe msc-block dans Elementor) */
.msc-contact-wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

@media(min-width:900px){
  .msc-contact-wrapper {
    grid-template-columns: 1fr 1fr; /* gauche: contact direct / droite: formulaire */
    gap: 32px;
  }
}

/* colonne gauche (contact direct) */
.msc-contact-left {
  font-size: .9rem;
  line-height: 1.5;
  color: #1E1E1E;
  max-width: 480px;
}

.msc-contact-left .msc-contact-block-title {
  font-size: 1rem;
  font-weight: 600;
  color: #1E1E1E;
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.msc-contact-left .msc-contact-block-title::before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 4px;
  background: #1E1E1E;
  box-shadow: 0 8px 20px rgba(0,0,0,.3);
}

/* petites lignes téléphone / whatsapp / calendrier */
.msc-contact-line {
  margin-bottom: 16px;
}
.msc-contact-label {
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: #1E1E1E;
  margin-bottom: 4px;
  line-height: 1.2;
}
.msc-contact-value {
  color: #1E1E1E;
  text-decoration: none;
  font-size: .9rem;
  line-height: 1.4;
  word-break: break-word;
}
.msc-contact-value:hover {
  text-decoration: underline;
}
.msc-contact-note {
  font-size: .8rem;
  line-height: 1.4;
  color: #4A4A4A;
  margin-top: 12px;
  margin-bottom: 20px;
  max-width: 360px;
}

/* mini “pills” rassurantes */
.msc-contact-badges {
  display: grid;
  gap: 8px;
  max-width: 320px;
}
.msc-badge {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  background: #F8F6F3;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 10px;
  padding: 8px 10px;
  box-shadow: 0 16px 32px rgba(0,0,0,.06);
  font-size: .8rem;
  line-height: 1.3;
  color: #1E1E1E;
  font-weight: 500;
}
.msc-badge .msc-badge-emoji {
  font-size: .8rem;
  font-weight: 600;
  color: #11823b;
}

/* colonne droite (formulaire) */
.msc-contact-form {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 12px;
  box-shadow: 0 20px 40px rgba(0,0,0,.05);
  padding: 16px 16px 20px;
}
@media(min-width:900px){
  .msc-contact-form {
    padding: 20px 20px 24px;
  }
}
.msc-contact-form .msc-contact-block-title {
  font-size: 1rem;
  font-weight: 600;
  color: #1E1E1E;
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.msc-contact-form .msc-contact-block-title::before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 4px;
  background: #1E1E1E;
  box-shadow: 0 8px 20px rgba(0,0,0,.3);
}

/* améliore légèrement les champs Elementor/WPForms à l'intérieur */
.msc-contact-form input,
.msc-contact-form select,
.msc-contact-form textarea {
  width: 100% !important;
  border-radius: 6px !important;
  border: 1px solid rgba(0,0,0,.2) !important;
  font-size: .9rem !important;
  line-height: 1.4 !important;
  padding: 10px 12px !important;
  color: #1E1E1E !important;
  font-family: inherit !important;
}

.msc-contact-form textarea {
  min-height: 110px;
  resize: vertical;
}

.msc-contact-form button,
.msc-contact-form input[type="submit"] {
  display: inline-block;
  width: 100%;
  background: #2f5fa1 !important; /* même bleu que ton bouton de réservation */
  border: 0 !important;
  border-radius: 8px !important;
  color: #fff !important;
  font-weight: 600 !important;
  font-size: .9rem !important;
  line-height: 1.2 !important;
  padding: 12px 16px !important;
  box-shadow: 0 20px 40px rgba(0,0,0,.25) !important;
  cursor: pointer !important;
  transition: all .15s ease-in-out !important;
}
.msc-contact-form button:hover,
.msc-contact-form input[type="submit"]:hover {
  background: #1f4480 !important;
  box-shadow: 0 24px 44px rgba(0,0,0,.35) !important;
}
/* bloc prix interne dans chaque carte */
.msc-prices {
  background: #F8F6F3;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 8px;
  padding: 12px 16px;
  margin: 0 0 16px;
  box-shadow: 0 16px 32px rgba(0,0,0,.04);
  font-size: .9rem;
  line-height: 1.4;
  color: #1E1E1E;
}

.msc-price-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.msc-price-row:last-child {
  border-bottom: 0;
}

.msc-price-label {
  font-weight: 500;
  color: #1E1E1E;
  max-width: 70%;
}

.msc-price-value {
  font-weight: 600;
  color: #1E1E1E;
  white-space: nowrap;
}

/* Bouton principal (réservation GOLD = Calendly) */
.msc-btn-primary {
  display: inline-block;
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  font-size: .9rem;
  line-height: 1.2;
  padding: 12px 16px;
  border-radius: 8px;
  box-shadow: 0 20px 40px rgba(0,0,0,.25);
  transition: all .15s ease-in-out;
  text-align: center;
  width: 100%;
}
.msc-btn-primary:hover {
  background: #1f4480;
  box-shadow: 0 24px 44px rgba(0,0,0,.35);
}

/* Bouton secondaire (Quick / Options -> contact) */
.msc-btn-secondary {
  display: inline-block;
  background: #1E1E1E;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  font-size: .9rem;
  line-height: 1.2;
  padding: 12px 16px;
  border-radius: 8px;
  box-shadow: 0 20px 40px rgba(0,0,0,.25);
  transition: all .15s ease-in-out;
  text-align: center;
  width: 100%;
  border: 2px solid #1E1E1E;
}
.msc-btn-secondary:hover {
  background: #000;
  box-shadow: 0 24px 44px rgba(0,0,0,.35);
}
/* ====== SECTION GLOBALE ====== */
.msc-pricing-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 20px;
}
.msc-section-head {
  text-align: center;
  margin-bottom: 32px;
}
.msc-section-head h2 {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 8px;
}
.msc-section-head p {
  color: #666;
  font-size: 1rem;
}

/* ====== GRID ====== */
.msc-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 24px;
}

/* ====== CARTE (une offre) ====== */
.msc-offer-card {
  background: #fffdf9;
  border-radius: 16px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.07),
    0 2px 4px rgba(0, 0, 0, 0.04);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: #1e1e1e;
  font-size: 0.95rem;
  line-height: 1.45;
  transition: transform 0.2s ease, box-shadow 0.3s ease;
}
.msc-offer-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 28px 68px rgba(0, 0, 0, 0.12),
    0 4px 8px rgba(0, 0, 0, 0.05);
}

/* ====== NOUVEAU : header image ====== */
.msc-offer-media {
  width: 100%;
  height: 170px;
  background: #000;
  overflow: hidden;
  position: relative;
}
.msc-offer-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* petit overlay sombre léger sur l'image pour l'ambiance premium */
.msc-offer-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 20% 20%,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0) 60%
  );
  pointer-events: none;
}

/* ====== HEAD (titre + pricing) ====== */
.msc-offer-head {
  background: radial-gradient(
    circle at 0% 0%,
    rgba(47, 95, 161, 0.08) 0%,
    rgba(0, 0, 0, 0) 70%
  );
  padding: 20px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
@media (min-width: 640px) {
  .msc-offer-head {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }
}
.msc-offer-titlezone {
  max-width: 60%;
}
.msc-offer-title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: #1e1e1e;
}
.msc-offer-sub {
  margin: 4px 0 0;
  font-size: 0.9rem;
  color: #4a4a4a;
}

/* ====== PRICING BOX ====== */
.msc-offer-pricing {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 10px;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.05);
  padding: 12px 16px;
  min-width: 200px;
  max-width: 240px;
  font-size: 0.9rem;
  line-height: 1.4;
}
.msc-offer-line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.msc-offer-line:last-child {
  border-bottom: 0;
}
.msc-offer-veh {
  font-weight: 500;
  color: #1e1e1e;
  max-width: 65%;
}
.msc-offer-price {
  font-weight: 600;
  color: #1e1e1e;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
  font-size: 0.95rem;
}

/* ====== BODY ====== */
.msc-offer-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Liste à puces custom "✔" vert */
.msc-offer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.msc-offer-list li {
  position: relative;
  padding-left: 24px;
  margin-bottom: 8px;
  color: #1e1e1e;
  font-size: 0.9rem;
  line-height: 1.45;
}
.msc-offer-list li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 0;
  color: #178a2f;
  font-weight: 600;
  font-size: 0.8rem;
  line-height: 1.4;
}

/* Note en bas de carte */
.msc-offer-note {
  font-size: 0.8rem;
  line-height: 1.4;
  color: #555;
  background: #f8f6f3;
  border-left: 3px solid #2f5fa1;
  padding: 8px 10px;
  border-radius: 6px;
}

/* Boutons */
.msc-offer-cta {
  text-align: center;
  display: block;
  border-radius: 10px;
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.2;
  padding: 12px 16px;
  text-decoration: none;
  box-shadow: 0 24px 44px rgba(0, 0, 0, 0.25);
  transition: all 0.15s ease-in-out;
  border: 2px solid transparent;
  cursor: pointer;
}
.msc-offer-cta-main {
  background: #2f5fa1;
  color: #fff;
  border-color: #2f5fa1;
}
.msc-offer-cta-main:hover {
  background: #1f4480;
  border-color: #1f4480;
  box-shadow: 0 28px 48px rgba(0, 0, 0, 0.3);
}
.msc-offer-cta-alt {
  background: #1e1e1e;
  color: #fff;
  border-color: #1e1e1e;
}
.msc-offer-cta-alt:hover {
  background: #000;
  border-color: #000;
  box-shadow: 0 28px 48px rgba(0, 0, 0, 0.3);
}

/* ====== RESPONSIVE ====== */
@media (max-width: 480px) {
  .msc-offer-titlezone {
    max-width: 100%;
  }
  .msc-offer-pricing {
    max-width: 100%;
    width: 100%;
  }
  .msc-offer-media {
    height: 150px;
  }
}
/* ===== Boutons flottants (bas/droite) ===== */
.msc-float-wrap {
  position: fixed;
  right: 16px;
  bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 9999;
}

/* Bouton rond générique */
.msc-float-btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1e1e1e;
  border: 2px solid rgba(255,255,255,.9);
  box-shadow: 0 20px 40px rgba(0,0,0,0.45);
  text-decoration: none;
  line-height: 1;
  transition: all .15s ease;
}

.msc-float-btn:hover {
  transform: translateY(-2px) scale(1.07);
  box-shadow: 0 28px 50px rgba(0,0,0,0.55);
}

/* Icônes par défaut : stroke ET fill blancs */
.msc-icon {
  width: 26px;
  height: 26px;
  display: block;
  fill: #ffffff;
  stroke: #ffffff;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Icône WhatsApp : full blanc mais sans stroke épais dégueu */
.msc-icon-wa {
  width: 26px;
  height: 26px;
  display: block;
  fill: #ffffff;
  stroke: none;
}

/* Couleurs de fond par action */
.msc-float-call {
  background: #2f80ed;   /* bleu vif tel */
}

.msc-float-book {
  background: #1f4480;   /* bleu foncé rdv */
}

.msc-float-wa {
  background: #25d366;   /* vert WhatsApp */
  border-color: rgba(255,255,255,.9);
}
/* === AVIS GOOGLE (avec Trustindex) === */
.msc-reviews {
  background: #ffffff;
  padding: clamp(2rem, 2vw, 3rem) 1rem;
  border-top: 1px solid #eee;
  border-bottom: 1px solid #eee;
}
.msc-reviews-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.msc-reviews-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 1rem 2rem;
  margin-bottom: 1.5rem;
}

.msc-reviews-stars {
  font-size: 1.4rem;
  line-height: 1;
  flex-shrink: 0;
  color: #f5c518; /* jaune "étoiles Google" */
}

.msc-reviews-title h2 {
  margin: 0;
  font-size: clamp(1.25rem, 0.4vw, 1.4rem);
  font-weight: 600;
  color: #111;
}
.msc-reviews-title p {
  margin: .25rem 0 0;
  color: #555;
  font-size: .95rem;
  line-height: 1.4;
}

/* zone Trustindex */
.msc-reviews-widget {
  background: #fafafa;
  border: 1px solid #eee;
  border-radius: .75rem;
  box-shadow: 0 12px 32px rgba(0,0,0,.04);
  padding: 1rem 1.25rem;
  overflow: hidden;
}

/* On évite que Trustindex parte full largeur moche */
.msc-reviews-widget > * {
  max-width: 100%;
}
/* === RÉSEAUX SOCIAUX FOOTER === */
.msc-social {
  background: #111;
  color: #fff;
  padding: 2rem 1rem;
  border-top: 1px solid rgba(255,255,255,.08);
}
.msc-social-inner {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}
.msc-social-text {
  color: #ccc;
  font-size: .95rem;
  margin: 0 0 1rem;
}
.msc-social-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1rem;
  justify-content: center;
}

.msc-social-btn {
  display: flex;
  align-items: center;
  gap: .5rem;
  background: #1e1e1e;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: .6rem;
  padding: .6rem .9rem;
  font-size: .9rem;
  font-weight: 500;
  text-decoration: none;
  line-height: 1.2;
  color: #fff;
  box-shadow: 0 16px 32px rgba(0,0,0,.6);
  transition: all .15s ease;
  min-width: 140px;
  justify-content: center;
}
.msc-social-btn:hover {
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 24px 40px rgba(0,0,0,.8);
}
.msc-social-ico {
  width: 20px;
  height: 20px;
  fill: currentColor;
  display: block;
}
.msc-social-btn.insta:hover {
  background: radial-gradient(circle at 30% 30%, #ffdf70 0%, #ff5d5d 40%, #c837ab 70%, #5156ff 100%);
  color: #fff;
  border-color: rgba(255,255,255,.4);
}
.msc-social-btn.fb:hover {
  background: #1877f2;
  color: #fff;
  border-color: rgba(255,255,255,.4);
}
.msc-social-btn.yt:hover {
  background: #ff0000;
  color: #fff;
  border-color: rgba(255,255,255,.4);
}
/* ===== HEADER STICKY ===== */
.msc-header {
  position: sticky;
  top: 0;
  z-index: 9998;
  background: rgba(17,17,17,.8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  color: #fff;
  font-family: inherit;
}
.msc-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: .75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem 1rem;
}

/* logo */
.msc-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  min-width: 0;
}
.msc-logo-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  display: block;
}
.msc-logo-text {
  line-height: 1.2;
  color: #fff;
}
.msc-brand-name {
  font-size: .9rem;
  font-weight: 600;
  color: #fff;
}
.msc-brand-loc {
  color: #999;
  font-size: .7rem;
  font-weight: 400;
  white-space: nowrap;
}

/* nav desktop */
.msc-nav {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.msc-nav-link {
  color: #fff;
  font-size: .8rem;
  font-weight: 500;
  text-decoration: none;
  line-height: 1.2;
  padding: .4rem .5rem;
  border-radius: .4rem;
  transition: all .15s ease;
}
.msc-nav-link:hover {
  background: rgba(255,255,255,.08);
}

/* CTA Réserver (desktop) */
.msc-cta-wrap {
  display: flex;
}
.msc-cta-book {
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  font-size: .8rem;
  font-weight: 600;
  line-height: 1.2;
  padding: .6rem .8rem;
  border-radius: .5rem;
  box-shadow: 0 20px 40px rgba(0,0,0,.6);
  border: 1px solid rgba(255,255,255,.18);
  transition: all .15s ease;
}
.msc-cta-book:hover {
  background: #1f4480;
  box-shadow: 0 28px 50px rgba(0,0,0,.8);
}

/* burger (mobile only) */
.msc-burger {
  display: none;
  flex-direction: column;
  gap: 4px;
  background: transparent;
  border: 0;
  padding: .5rem;
  border-radius: .5rem;
}
.msc-burger span {
  width: 22px;
  height: 2px;
  background: #fff;
  display: block;
  border-radius: 1px;
}

/* menu mobile caché par défaut */
.msc-mobile-menu {
  display: none;
  flex-direction: column;
  background: #111;
  border-top: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 30px 60px rgba(0,0,0,.8);
}
.msc-mobile-link {
  color: #fff;
  text-decoration: none;
  font-size: .9rem;
  padding: 1rem;
  border-bottom: 1px solid rgba(255,255,255,.05);
  line-height: 1.2;
}
.msc-mobile-link:active,
.msc-mobile-link:hover {
  background: rgba(255,255,255,.06);
}
.msc-mobile-cta {
  display: block;
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  text-align: center;
  font-weight: 600;
  font-size: .9rem;
  line-height: 1.2;
  padding: 1rem;
}

/* RESPONSIVE  */
@media(max-width: 800px){
  .msc-nav {
    display: none;
  }
  .msc-cta-wrap {
    display: none;
  }
  .msc-burger {
    display: flex;
  }
}

/* état "menu ouvert" sur mobile */
.msc-header.mobile-open + .msc-mobile-menu {
  display: flex;
}
/* HEADER GLOBAL */
.msc-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99999;
  background: rgba(15,15,15,0.6);              /* fond sombre translucide */
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);                  /* flou derrière */
  border-bottom: 1px solid rgba(255,255,255,.07);
  font-family: inherit;
  color: #fff;
}

.msc-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: .75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem 1rem;
}

/* LOGO + texte */
.msc-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  min-width: 0;
}
.msc-logo-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.8));
}
.msc-logo-text {
  line-height: 1.2;
  color: #fff;
}
.msc-brand-name {
  font-size: .9rem;
  font-weight: 600;
  color: #fff;
}
.msc-brand-loc {
  color: #b5b5b5;
  font-size: .7rem;
  font-weight: 400;
  white-space: nowrap;
}

/* NAV DESKTOP */
.msc-nav {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.msc-nav-link {
  color: #fff;
  font-size: .8rem;
  font-weight: 500;
  text-decoration: none;
  line-height: 1.2;
  padding: .5rem .6rem;
  border-radius: .5rem;
  transition: all .15s ease;
  background: rgba(255,255,255,0); /* transparent par défaut */
  border: 1px solid rgba(255,255,255,0);
}
.msc-nav-link:hover {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 20px 40px rgba(0,0,0,.7);
}

/* CTA "Réserver" DESKTOP */
.msc-cta-book {
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  font-size: .8rem;
  font-weight: 600;
  line-height: 1.2;
  padding: .6rem .8rem;
  border-radius: .55rem;
  display: inline-block;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 24px 40px rgba(0,0,0,.8);
  transition: all .15s ease;
}
.msc-cta-book:hover {
  background: #1f3f75;
  box-shadow: 0 32px 48px rgba(0,0,0,.9);
}

/* BURGER MOBILE */
.msc-burger {
  display: none;
  flex-direction: column;
  gap: 4px;
  background: transparent;
  border: 0;
  padding: .6rem .5rem;
  border-radius: .5rem;
}
.msc-burger span {
  width: 24px;
  height: 2px;
  background: #fff;
  display: block;
  border-radius: 2px;
  box-shadow: 0 2px 4px rgba(0,0,0,.8);
}

/* MOBILE MENU (caché par défaut) */
.msc-mobile-menu {
  position: fixed;
  top: 56px; /* hauteur header approx */
  left: 0;
  right: 0;
  background: rgba(15,15,15,.95);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 40px 60px rgba(0,0,0,.9);
  display: none;
  flex-direction: column;
  z-index: 99998;
}

.msc-mobile-menu.msc-show {
  display: flex;
}

.msc-mobile-link {
  color: #fff;
  text-decoration: none;
  font-size: .9rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
  line-height: 1.2;
}
.msc-mobile-link:active,
.msc-mobile-link:hover {
  background: rgba(255,255,255,.07);
}

.msc-mobile-cta {
  display: block;
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  text-align: center;
  font-weight: 600;
  font-size: .9rem;
  line-height: 1.2;
  padding: 1rem 1.25rem;
  box-shadow: 0 30px 60px rgba(0,0,0,.8);
}

/* RESPONSIVE */
@media(max-width: 900px){
  .msc-nav,
  .msc-cta-book {
    display: none;
  }
  .msc-burger {
    display: flex;
  }

  .msc-header-inner {
    padding: .6rem 1rem;
  }

  .msc-logo-img {
    width: 38px;
    height: 38px;
  }
  .msc-brand-name {
    font-size: .8rem;
  }
  .msc-brand-loc {
    font-size: .65rem;
  }
}

/* ===== HERO OFFSET =====
Le header est en position:fixed donc il flotte au-dessus.
On pousse le HERO vers le bas pour qu'il ne passe pas sous le header.
Adapte la marge si besoin. 
*/
.msc-hero-offset {
  padding-top: 80px; /* ~hauteur du header */
}
@media(max-width:900px){
  .msc-hero-offset {
    padding-top: 70px;
  }
}
/* HEADER FIXE PREMIUM */
.msc-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99999;
  background: rgba(15,15,15,0.6);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 30px 60px rgba(0,0,0,.8);
  color: #fff;
  font-family: inherit;
}

.msc-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: .75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem 1rem;
}

/* bloc logo gauche */
.msc-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  min-width: 0;
}
.msc-logo-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.8));
}
.msc-logo-text {
  line-height: 1.2;
  color: #fff;
}
.msc-brand-name {
  font-size: .9rem;
  font-weight: 600;
  color: #fff;
}
.msc-brand-loc {
  color: #b5b5b5;
  font-size: .7rem;
  font-weight: 400;
  white-space: nowrap;
}

/* nav desktop */
.msc-nav {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.msc-nav-link {
  color: #fff;
  font-size: .8rem;
  font-weight: 500;
  text-decoration: none;
  line-height: 1.2;
  padding: .5rem .6rem;
  border-radius: .5rem;
  transition: all .15s ease;
  background: rgba(255,255,255,0);
  border: 1px solid rgba(255,255,255,0);
}
.msc-nav-link:hover {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 20px 40px rgba(0,0,0,.7);
}

/* bouton réserver desktop */
.msc-cta-book {
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  font-size: .8rem;
  font-weight: 600;
  line-height: 1.2;
  padding: .6rem .8rem;
  border-radius: .55rem;
  display: inline-block;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 24px 40px rgba(0,0,0,.8);
  transition: all .15s ease;
}
.msc-cta-book:hover {
  background: #1f3f75;
  box-shadow: 0 32px 48px rgba(0,0,0,.9);
}

/* burger mobile (caché desktop) */
.msc-burger {
  display: none;
  flex-direction: column;
  gap: 4px;
  background: transparent;
  border: 0;
  padding: .6rem .5rem;
  border-radius: .5rem;
}
.msc-burger span {
  width: 24px;
  height: 2px;
  background: #fff;
  display: block;
  border-radius: 2px;
  box-shadow: 0 2px 4px rgba(0,0,0,.8);
}

/* menu mobile coulissant */
.msc-mobile-menu {
  position: fixed;
  top: 56px; /* hauteur header approx */
  left: 0;
  right: 0;
  background: rgba(15,15,15,.95);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 40px 60px rgba(0,0,0,.9);
  display: none;
  flex-direction: column;
  z-index: 99998;
}
.msc-mobile-menu.msc-show {
  display: flex;
}

.msc-mobile-link {
  color: #fff;
  text-decoration: none;
  font-size: .9rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
  line-height: 1.2;
}
.msc-mobile-link:hover,
.msc-mobile-link:active {
  background: rgba(255,255,255,.07);
}
.msc-mobile-cta {
  display: block;
  background: #2f5fa1;
  color: #fff;
  text-decoration: none;
  text-align: center;
  font-weight: 600;
  font-size: .9rem;
  line-height: 1.2;
  padding: 1rem 1.25rem;
  box-shadow: 0 30px 60px rgba(0,0,0,.8);
}

/* responsive : en mobile on cache les liens classiques et on montre le burger */
@media(max-width: 900px){
  .msc-nav,
  .msc-cta-book {
    display: none;
  }
  .msc-burger {
    display: flex;
  }

  .msc-header-inner {
    padding: .6rem 1rem;
  }

  .msc-logo-img {
    width: 38px;
    height: 38px;
  }
  .msc-brand-name {
    font-size: .8rem;
  }
  .msc-brand-loc {
    font-size: .65rem;
  }
}

/* pousse le hero vers le bas pour ne pas qu'il passe SOUS le header fixe */
.msc-hero-offset {
  padding-top: 80px;
}
@media(max-width:900px){
  .msc-hero-offset {
    padding-top: 70px;
  }
}
.msc-pro-box {
  max-width: 1100px;
  margin: 2rem auto;
  padding: 1.5rem 1.5rem 2rem;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 24px 40px rgba(0,0,0,.06);
  font-family: inherit;
}
.msc-pro-headline {
  font-size: 1rem;
  font-weight: 600;
  color: #111;
  margin-bottom: .75rem;
}
.msc-pro-lines p {
  margin: 0 0 .5rem 0;
  font-size: .9rem;
  line-height: 1.5;
  color: #444;
}
.msc-pro-cta {
  margin-top: 1rem;
}
.msc-pro-btn {
  display: inline-block;
  background: #1e40af;
  color: #fff;
  font-size: .9rem;
  font-weight: 500;
  line-height: 1.2;
  padding: .7rem 1rem;
  border-radius: .5rem;
  text-decoration: none;
  box-shadow: 0 20px 30px rgba(30,64,175,.4);
  transition: all .15s ease;
}
.msc-pro-btn:hover {
  background:#1b3a9d;
  box-shadow:0 30px 40px rgba(0,0,0,.25);
}
@media(max-width:600px){
  .msc-pro-box {
    border-radius:10px;
    padding:1rem 1rem 1.5rem;
  }
  .msc-pro-btn {
    width:100%;
    text-align:center;
  }
}
/* ====== BLOC PRO / FLOTTES ====== */

.msc-pro-card {
  background: #fff;
  border-radius: 12px;
  box-shadow:
    0 30px 60px rgba(0,0,0,0.06),
    0 6px 20px rgba(0,0,0,0.04);
  padding: 24px 24px 32px;
  max-width: 1200px;
  margin: 40px auto;
  border: 1px solid rgba(0,0,0,0.05);
  font-family: inherit;
  color: #1a1a1a;
}

/* top zone */
.msc-pro-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: 16px;
  column-gap: 24px;
  margin-bottom: 24px;
}

.msc-pro-top {
  flex: 1 1 300px;
  min-width: 260px;
}

.msc-pro-title {
  font-size: 1.25rem;        /* ~20px */
  font-weight: 600;
  margin: 0 0 8px;
  color: #1a1a1a;
}

.msc-pro-sub {
  font-size: 0.95rem;
  line-height: 1.5rem;
  color: #444;
  margin: 0;
}

.msc-cta-wrap {
  flex: 0 0 auto;
  align-self: flex-start;
  min-width: 200px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.msc-btn {
  display: inline-block;
  font-size: 0.95rem;
  line-height: 1.2rem;
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  padding: 12px 16px;
  cursor: pointer;
  text-align: center;
  border: 1px solid transparent;
  transition: all .18s ease;
}
.msc-btn-primary {
  background-color: #1a4a8a;    /* bleu foncé premium */
  color: #fff;
  box-shadow:
    0 12px 24px rgba(26,74,138,0.32),
    0 3px 8px rgba(0,0,0,0.15);
}
.msc-btn-primary:hover {
  background-color: #163b6c;
  box-shadow:
    0 16px 32px rgba(26,74,138,0.4),
    0 4px 10px rgba(0,0,0,0.2);
}

/* gallery */
.msc-pro-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(min(260px,100%),1fr));
  gap: 16px;
  margin-bottom: 32px;
}

.msc-pro-thumb {
  background: #fafafa;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 10px 20px rgba(0,0,0,0.04);
  display: flex;
  flex-direction: column;
}

.msc-pro-thumb-img {
  width: 100%;
  height: 150px;
  background: #ddd;
  overflow: hidden;
}
.msc-pro-thumb-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

.msc-pro-thumb-label {
  background: #fff;
  font-size: 0.9rem;
  font-weight: 500;
  color: #1a1a1a;
  padding: 10px 12px;
  border-top: 1px solid rgba(0,0,0,0.07);
}

/* details cols */
.msc-pro-details {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(min(300px,100%),1fr));
  gap: 24px;
  margin-bottom: 32px;
}

.msc-pro-col-title {
  font-size: 1rem;
  font-weight: 600;
  color: #1a1a1a;
  margin: 0 0 8px;
}

.msc-pro-list {
  margin: 0;
  padding-left: 20px; /* puces classiques, propre */
  color: #333;
  font-size: 0.95rem;
  line-height: 1.5rem;
}

/* contact footer */
.msc-pro-contact {
  border-top: 1px solid rgba(0,0,0,0.06);
  padding-top: 24px;
}

.msc-pro-contact-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
}

.msc-pro-contact-block {
  flex: 1 1 300px;
  min-width: 260px;
  font-size: 0.95rem;
  line-height: 1.5rem;
  color: #1a1a1a;
}

.msc-pro-contact-line {
  margin-bottom: 8px;
}

.msc-contact-link {
  color: #1a4a8a;
  text-decoration: none;
  font-weight: 500;
}
.msc-contact-link:hover {
  text-decoration: underline;
}

.msc-pro-contact-cta {
  flex: 0 0 260px;
  min-width: 240px;
  max-width: 320px;
  background: #f9fafb;
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 8px;
  box-shadow:
    0 12px 24px rgba(0,0,0,0.05),
    0 2px 4px rgba(0,0,0,0.05);
  padding: 16px;
  text-align: left;
}

.msc-pro-contact-cta .msc-btn-primary {
  width: 100%;
  display: block;
  text-align: center;
  font-size: 0.95rem;
  line-height: 1.3rem;
  margin-bottom: 10px;
}

.msc-pro-hint {
  font-size: 0.8rem;
  line-height: 1.3rem;
  color: #444;
  margin: 0;
}

/* responsive tweaks */
@media (max-width: 768px) {
  .msc-pro-header {
    flex-direction: column;
  }
  .msc-cta-wrap {
    width: 100%;
  }
  .msc-cta-wrap .msc-btn-primary {
    width: 100%;
    text-align: center;
  }

  .msc-pro-contact-inner {
    flex-direction: column;
  }

  .msc-pro-contact-cta {
    max-width: 100%;
  }
}
html {
  scroll-behavior: smooth;
}
/* Supprime tout l'espace au-dessus du hero (Astra/WordPress) */
body.home .site-content,
body.home .entry-content,
body.home .ast-container { padding-top:0 !important; margin-top:0 !important; }
header.site-header { margin-bottom:0 !important; }
body.home .entry-content > *:first-child { margin-top:0 !important; }

/* Hero plein écran, centré */
.hero {
  min-height: calc(100vh - var(--header-height, 80px));
  display:flex; align-items:center; justify-content:center;
  padding: clamp(16px, 4vw, 48px);
}

/* Header collant (reste visible) */
.main-header-bar { position: sticky; top: 0; z-index: 999; }

/* Barre d'action mobile */
.cta-sticky{
  position:fixed; left:0; right:0; bottom:0;
  display:flex; gap:8px; justify-content:space-between;
  padding:10px; background:#fffffff2; backdrop-filter:saturate(140%) blur(8px);
  box-shadow:0 -6px 20px rgba(0,0,0,.08);
}
.cta-sticky a{ flex:1; text-align:center; padding:10px 8px; border-radius:10px; border:1px solid #e5e7eb; font-weight:600; text-decoration:none;}
@media(min-width:992px){ .cta-sticky{ display:none; } }
/* === Mise en page de la section Contact / Devis === */
.msc-row{
  max-width:1100px; margin:0 auto; padding:0 12px;
  display:flex; gap:40px; align-items:flex-start; justify-content:space-between;
}
.msc-col{ flex:1 1 0; }

/* Carte gauche */
.msc-box{
  background:#fff; border:1px solid #eee; border-radius:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.06); padding:22px 24px;
}
.msc-left-title{
  position:relative; margin:0 0 12px 0; font-size:1.1rem; font-weight:700;
  color:#111; padding-left:26px;
}
.msc-left-title::before{ content:""; position:absolute; left:0; top:4px;
  width:14px; height:14px; background:#111; border-radius:4px; }
.msc-left-text{ margin:0 0 14px 0; color:#333; line-height:1.6; font-size:.96rem; }
.msc-left-block{ margin:12px 0; }
.msc-left-label{ font-weight:700; font-size:.92rem; color:#111; letter-spacing:.02em; }
.msc-left-value a{ color:#0f172a; text-decoration:none; border-bottom:1px solid rgba(15,23,42,.2); }
.msc-left-value a:hover{ border-bottom-color:transparent; color:#2563eb; }
.msc-left-note{ margin:14px 0 18px; color:#475569; font-size:.95rem; line-height:1.55; }
.msc-pills{ display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }
.msc-pill{ display:inline-block; padding:8px 12px; border-radius:999px;
  font-weight:600; font-size:.9rem; border:1px solid #e6e6e6; background:#fbfbfb; }
.msc-pill-red{ background:#fff5f5; border-color:#f3d1d1; }
.msc-pill-blue{ background:#f1f6ff; border-color:#d2defa; }
.msc-pill-yellow{ background:#fff8db; border-color:#f3e6a6; }

/* Carte droite (formulaire) */
.msc-card{
  background:#fff; border:1px solid #eee; border-radius:16px;
  box-shadow:0 18px 30px rgba(0,0,0,.08), 0 2px 0 rgba(255,255,255,.9) inset;
  padding:22px;
}
.msc-card-title{
  position:relative; margin:0 0 14px 0; font-size:1.1rem; font-weight:700;
  color:#111; padding-left:26px; line-height:1.2;
}
.msc-card-title::before{ content:""; position:absolute; left:0; top:4px;
  width:14px; height:14px; background:#111; border-radius:4px; }

/* WPForms harmonisé (labels masqués comme avant) */
.msc-card .wpforms-field-label,
.msc-card .wpforms-field-sublabel,
.msc-card .wpforms-required-label{ display:none !important; }
.msc-card .wpforms-field{ margin-bottom:12px !important; }

.msc-card input,
.msc-card select,
.msc-card textarea{
  width:100% !important; border:1px solid #e5e7eb !important;
  background:#fff !important; border-radius:8px !important;
  padding:10px 12px !important; font-size:16px !important; color:#111 !important;
  transition:border-color .15s, box-shadow .15s;
}
.msc-card textarea{ min-height:110px !important; resize:vertical !important; }
.msc-card input:focus, .msc-card select:focus, .msc-card textarea:focus{
  border-color:#2563eb !important; box-shadow:0 0 0 3px rgba(37,99,235,.12) !important; outline:none !important;
}
.msc-card .wpforms-submit-container{ position:relative; margin-top:8px !important; }
.msc-card .wpforms-submit{
  width:100% !important; background:#2563eb !important; color:#fff !important;
  font-weight:700 !important; border:none !important; border-radius:8px !important;
  padding:14px !important; cursor:pointer !important;
  transition:transform .12s, box-shadow .12s, background .12s !important;
  box-shadow:0 10px 18px rgba(37,99,235,.22) !important;
}
.msc-card .wpforms-submit:hover{ background:#1d4ed8 !important; transform:translateY(-2px) !important; }
.msc-card .wpforms-submit-container::after{
  content:""; position:absolute; left:12px; right:12px; bottom:-8px; height:16px; border-radius:12px;
  box-shadow:0 12px 18px rgba(0,0,0,.12); pointer-events:none;
}
.msc-card ::placeholder{ color:#9aa3af !important; }

/* Avis / Reviews : recentrage & respiration (wrappe ton widget dans une section/colonne avec la classe msc-reviews) */
.msc-reviews{ max-width:1100px; margin:24px auto; padding:0 12px; }
.msc-reviews > *{ border-radius:16px; box-shadow:0 6px 20px rgba(0,0,0,.05); }

/* Icônes flottantes à droite : on les rend plus propres ou on les masque sur desktop si c’est trop “bruyant” */
@media (min-width: 992px){
  .chaty-widget, .joinchat, .floating-wpp, .callnowbutton { right:16px !important; bottom:24px !important; }
}
@media (max-width: 768px){
  body{ padding-bottom:80px; } /* pour éviter que la barre flottante recouvre le bouton du formulaire */
}

/* Responsive colonnes */
@media (max-width: 768px){
  .msc-row{ flex-direction:column; gap:24px; }
  .msc-card, .msc-box{ padding:20px; }
  .msc-card-title, .msc-left-title{ font-size:1.05rem; }
}
/* =========================
   POLICE PREMIUM – Plus Jakarta Sans
   ========================= */
@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap");

:root{
  --hauteur-header: 68px;
}

html, body,
.ast-container,
.entry-content,
h1,h2,h3,h4,h5,h6,
button, input, select, textarea {
  font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,h2,h3 {
  font-weight: 700;
  letter-spacing: -0.015em;
}

/* =========================
   HEADER PREMIUM (Astra)
   ========================= */
.site-header, .main-header-bar, .ast-primary-header-bar{
  position: sticky;
  top: 0;
  z-index: 9999;
  background: rgba(15,15,15,.7) !important;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 20px 40px rgba(0,0,0,.25);
}

/* Logo bien visible */
.site-branding img,
.custom-logo-link img,
.ast-site-identity .site-logo-img img {
  max-height: 44px !important;
  height: 44px !important;
  width: auto !important;
  filter: drop-shadow(0 4px 10px rgba(0,0,0,.6));
}

/* Menu principal */
.main-header-menu > .menu-item > a {
  color:#fff !important;
  font-weight:600;
  font-size:.9rem;
  padding: .55rem .75rem !important;
  border-radius: .5rem;
  transition: background .2s ease, box-shadow .2s ease;
}
.main-header-menu > .menu-item > a:hover,
.main-header-menu > .menu-item.current-menu-item > a{
  background: rgba(255,255,255,.10);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}

/* Bouton Réserver */
.main-header-menu .menu-item a[href*="calendly"],
.main-header-menu .menu-item-has-cta > a {
  background: #2f5fa1 !important;
  border: 1px solid rgba(255,255,255,.18);
  color:#fff !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.45);
}
.main-header-menu .menu-item a[href*="calendly"]:hover,
.main-header-menu .menu-item-has-cta > a:hover {
  background:#1f4480 !important;
}

/* =========================
   VERSION MOBILE
   ========================= */
.ast-mobile-header-wrap, .ast-header-break-point .main-header-bar{
  background: rgba(15,15,15,.85) !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* Icône burger */
.ast-button-wrap .menu-toggle .ast-button {
  color:#fff !important;
}

/* Menu déroulant mobile */
.ast-header-break-point .ast-mobile-popup-drawer.active .ast-mobile-popup-inner{
  background: rgba(16,16,16,.96) !important;
  backdrop-filter: blur(8px);
  border-left: 1px solid rgba(255,255,255,.08);
}
.ast-header-break-point .main-header-menu .menu-item a{
  color:#fff !important;
  padding: 14px 18px !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
  font-weight:600;
}
.ast-header-break-point .site-branding img{ max-height: 40px !important; }

/* =========================
   HERO SANS ESPACE BLANC
   ========================= */
body .site-content,
body .entry-content,
.ast-container { padding-top: 0 !important; margin-top: 0 !important; }
.entry-content > *:first-child { margin-top: 0 !important; }

.elementor-section-wrap > .elementor-section:first-child{
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.msc-hero, .hero{
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* =========================
   ICÔNE INSTAGRAM VISIBLE
   ========================= */
.msc-social-btn .msc-social-ico { fill: currentColor !important; color:#fff; }
.msc-social-btn.insta { background:#1e1e1e; }
.msc-social-btn.insta .msc-social-ico { color:#fff; }
.msc-social-btn.insta:hover{
  background: radial-gradient(circle at 30% 30%, #ffdf70 0%, #ff5d5d 40%, #c837ab 70%, #5156ff 100%);
  border-color: rgba(255,255,255,.4);
}
.msc-social-btn.insta svg path { fill:#fff !important; }

/* =========================
   DÉTAILS GLOBAUX
   ========================= */
a { text-underline-offset: 2px; }
button, .button, .wp-block-button__link {
  font-weight:600;
  border-radius:.55rem;
}
/****************************
  1) HERO collé sous le header
*****************************/
body .site-content,
body .entry-content,
.ast-container { padding-top:0 !important; margin-top:0 !important; }
.main-header-bar { margin-bottom:0 !important; }
.ast-separate-container .site-content .ast-container { padding-top:0 !important; }
.ast-plain-container.ast-no-sidebar #primary { margin-top:0 !important; padding-top:0 !important; }
.elementor-section-wrap > .elementor-section:first-child,
.elementor-top-section:first-of-type { margin-top:0 !important; padding-top:0 !important; }

/****************************
  2) Header premium + MOBILE FIX
*****************************/
/* Desktop */
.site-header, .main-header-bar, .ast-primary-header-bar{
  position: sticky; top:0; z-index: 99998;
  background: rgba(15,15,15,.72) !important;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 16px 38px rgba(0,0,0,.28);
}
.site-branding img,
.custom-logo-link img { max-height:44px !important; height:44px !important; width:auto !important; }

/* Mobile : header fixé + logo visible + espace réservé sous le header */
.ast-header-break-point .main-header-bar{
  position: fixed; top:0; left:0; right:0;
  background: rgba(15,15,15,.9) !important;
  z-index: 99998;
}
.ast-header-break-point .site-branding img{ max-height:40px !important; height:auto !important; }
.ast-header-break-point .site-content{ padding-top:72px !important; } /* réserve la place du header */
.ast-header-break-point .ast-mobile-header-wrap{ border-bottom:1px solid rgba(255,255,255,.08); }

/* Menu mobile déroulant au-dessus de tout */
.ast-header-break-point .ast-mobile-popup-drawer.active .ast-mobile-popup-inner{
  background: rgba(16,16,16,.96) !important;
  backdrop-filter: blur(8px);
  z-index: 99998;
}

/****************************
  3) Masquer le copyright Astra
*****************************/
.site-footer .site-info,
#colophon .ast-footer-copyright,
.ast-small-footer { display:none !important; }

/****************************
  4) Bulles flottantes – forcer l’affichage au-dessus de tout
*****************************/
.floating-buttons,
.msc-floating-icons,
.msc-float-wrap,
.msc-float-actions{
  position: fixed !important;
  right: 16px !important;
  bottom: 16px !important;
  display: flex !important;
  flex-direction: column;
  gap: 10px;
  z-index: 999999 !important;   /* plus haut que le reste */
  pointer-events: auto !important;
}

/* Les boutons eux-mêmes (peu importe la variante utilisée) */
.floating-buttons a,
.msc-icon-btn,
.msc-float-btn{
  display:flex !important; align-items:center; justify-content:center;
  width:54px; height:54px; border-radius:50%;
  box-shadow:0 18px 36px rgba(0,0,0,.35);
  border:2px solid rgba(255,255,255,.18);
  color:#fff; text-decoration:none;
}

/* Couleurs rapides si besoin */
.floating-btn.phone, .msc-call{ background:#1f1f1f; }
.floating-btn.booking, .msc-book{ background:#2f5fa1; }
.floating-btn.whatsapp, .msc-wa{ background:#25D366; }

/****************************
  5) Logo Instagram contrasté (si bouton sombre)
*****************************/
.msc-social-btn .msc-social-ico { color:#fff; fill:currentColor !important; }
.msc-social-btn.insta svg path { fill:#fff !important; }
/******** HERO PLEIN ÉCRAN, SANS BORDURES ********/
/* casse la mise en page "boxée" d'Astra pour le tout 1er bloc (Elementor) */
.home .elementor-section:first-of-type{
  margin:0 !important; padding:0 !important;
  width:100vw !important;
  margin-left:calc(50% - 50vw) !important;
  margin-right:calc(50% - 50vw) !important;
  border:0 !important;
}
.home .elementor-section:first-of-type > .elementor-container{
  max-width:none !important; padding:0 !important;
}

/* hero 100% hauteur viewport, compatible mobiles (svh/dvh) */
.msc-hero{ min-height:100vh; }
@supports(height:100svh){ .msc-hero{ min-height:100svh; } }
@supports(height:100dvh){ .msc-hero{ min-height:100dvh; } }

/* voile + lisibilité */
.msc-hero-overlay{
  background:radial-gradient(circle at 30% 30%,rgba(0,0,0,.15) 0%,rgba(0,0,0,.55) 60%,rgba(0,0,0,.75) 100%) !important;
}

/* variante “fond fixe” (image) */
.msc-hero.is-image{
  background-attachment: fixed;
  background-size: cover; background-position:center;
}

/* variante “vidéo” : fixe la vidéo au viewport sur desktop */
@media(min-width:1024px){
  .msc-hero.video .msc-hero-bg{ position:fixed !important; inset:0; }
}

/******** SUPPRIME TOUT ESPACE ENTRE HEADER & HERO ********/
body .site-content, body .entry-content, .ast-container{ padding-top:0 !important; margin-top:0 !important; }
.main-header-bar{ margin-bottom:0 !important; }
.ast-separate-container .site-content .ast-container{ padding-top:0 !important; }
.elementor-section-wrap > .elementor-section:first-child,
.elementor-top-section:first-of-type{ margin-top:0 !important; padding-top:0 !important; }

/******** HEADER MOBILE – LOGO TOUJOURS VISIBLE ********/
.ast-header-break-point .main-header-bar{
  position:fixed; top:0; left:0; right:0;
  background:rgba(15,15,15,.9) !important;
  backdrop-filter:blur(10px);
  z-index:99998;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.ast-header-break-point .site-branding img{ max-height:40px !important; height:auto !important; }
.ast-header-break-point .site-content{ padding-top:72px !important; } /* réserve la place du header */

/******** MASQUER LE COPYRIGHT ASTRA ********/
.site-footer .site-info, #colophon .ast-footer-copyright, .ast-small-footer{
  display:none !important;
}

/******** BULLES FLOTTANTES – TOUJOURS PAR-DESSUS ********/
.floating-buttons, .msc-floating-icons, .msc-float-wrap, .msc-float-actions{
  position:fixed !important; right:16px !important; bottom:16px !important;
  display:flex !important; flex-direction:column; gap:10px;
  z-index:2147483647 !important; pointer-events:auto !important;
}
.floating-buttons a, .msc-icon-btn, .msc-float-btn{
  display:flex !important; align-items:center; justify-content:center;
  width:54px; height:54px; border-radius:50%;
  color:#fff; text-decoration:none;
  border:2px solid rgba(255,255,255,.18);
  box-shadow:0 18px 36px rgba(0,0,0,.35);
}
.floating-btn.phone, .msc-call{ background:#1f1f1f; }
.floating-btn.booking, .msc-book{ background:#2f5fa1; }
.floating-btn.whatsapp, .msc-wa{ background:#25D366; }

/* petit ajustement mobile */
@media(max-width:480px){
  .floating-buttons, .msc-floating-icons, .msc-float-wrap, .msc-float-actions{
    right:12px !important; bottom:12px !important; gap:8px;
  }
}
:root{ --font-stack: "Inter", system-ui, -apple-system, "Roboto", "Helvetica Neue", Arial, sans-serif; }
body, .entry-content, h1,h2,h3,h4,h5{ font-family:var(--font-stack) !important; }
/* FAB container */
.msc-fab{
  position:fixed; right:16px; bottom:16px;
  display:flex; flex-direction:column; gap:10px;
  z-index:2147483647;
}
.msc-fab__btn{
  display:flex; align-items:center; justify-content:center; gap:8px;
  min-width:52px; min-height:52px; padding:10px 14px;
  border-radius:14px; text-decoration:none; color:#fff; font-weight:700; font-size:.9rem;
  box-shadow:0 18px 36px rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.2);
}
.msc-fab__btn .ico{ width:22px; height:22px; fill:currentColor; display:block; }
.msc-fab__btn .ico.wa{ width:20px; height:20px; }

/* Couleurs */
.msc-fab__btn.phone{ background:#ffffff; color:#111; }      /* >> tél clair pour ressortir */
.msc-fab__btn.booking{ background:#2f5fa1; color:#fff; }
.msc-fab__btn.whatsapp{ background:#25D366; color:#fff; }

/* Mobile : compacter et masquer le texte sauf sur "Réserver" */
@media(max-width:480px){
  .msc-fab{ right:12px; bottom:12px; gap:8px; }
  .msc-fab__btn{ min-width:48px; min-height:48px; padding:10px 12px; }
  .msc-fab__btn.phone .lbl, .msc-fab__btn.whatsapp .lbl{ display:none; }
}
/* (1) supprime tout fond image quand on est en mode vidéo */
.msc-hero.video{ background-image:none !important; }

/* (2) vidéo fixée en fond sur desktop, pour l’effet "le fond reste" */
@media(min-width:1024px){
  .msc-hero.video .msc-hero-bg{
    position:fixed !important; inset:0; width:100%; height:100%;
    object-fit:cover; object-position:center; z-index:0;
  }
}

/* (3) hero plein écran, bord à bord */
.msc-hero{ min-height:100vh; }
@supports(height:100svh){ .msc-hero{ min-height:100svh; } }
@supports(height:100dvh){ .msc-hero{ min-height:100dvh; } }

/* (4) supprimer toute bordure/marge du premier bloc Elementor */
.home .elementor-section:first-of-type{
  margin:0 !important; padding:0 !important; width:100vw !important;
  margin-left:calc(50% - 50vw) !important; margin-right:calc(50% - 50vw) !important; border:0 !important;
}
.home .elementor-section:first-of-type > .elementor-container{ max-width:none !important; padding:0 !important; }

/* (5) pas d’espace entre header & hero */
body .site-content, body .entry-content, .ast-container{ padding-top:0 !important; margin-top:0 !important; }
.main-header-bar{ margin-bottom:0 !important; }

/* (6) voile plus lisible */
.msc-hero-overlay{
  background:radial-gradient(circle at 30% 30%,rgba(0,0,0,.15) 0%,rgba(0,0,0,.55) 60%,rgba(0,0,0,.78) 100%) !important;
}
/* Décalage auto des ancres sous header fixe */
:target { scroll-margin-top: 90px; }
@media (max-width: 900px){ :target { scroll-margin-top: 72px; } }
/* Boutons flottants (s'affichent aussi en navigation privée) */
.msc-float-wrap{
  position:fixed; right:16px; bottom:16px; z-index:100000;
  display:flex; flex-direction:column; gap:12px; pointer-events:none;
}
.msc-float-btn{
  pointer-events:auto;
  display:flex; align-items:center; gap:8px; justify-content:center;
  min-width:48px; min-height:48px; padding:10px 14px; border-radius:12px;
  text-decoration:none; color:#fff; font-weight:700; font-size:.92rem;
  box-shadow:0 18px 36px rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.2);
}
.msc-icon{ width:22px; height:22px; fill:#fff; stroke:#fff; stroke-width:1.2; }
.msc-icon-wa{ width:22px; height:22px; filter:invert(1) brightness(10); }

.msc-float-call{ background:#111; }       /* fond clair sur noir : lisible */
.msc-float-book{ background:#2f61a9; }
.msc-float-wa{ background:#25D366; color:#000; font-weight:700; }

@media(hover:hover){ .msc-float-btn:hover{ transform:translateY(-2px) scale(1.04); } }

@media(max-width:480px){
  .msc-float-label{ display:none; }       /* bulles icône seule sur mobile */
  .msc-float-btn{ min-width:48px; min-height:48px; padding:10px; }
}
/* Supprime tout espace entre header et hero */
header.site-header, .elementor-location-header { margin-bottom:0 !important; }
.ast-container, .site-content, .entry-content { padding-top:0 !important; margin-top:0 !important; }
body.home .entry-content > *:first-child{ margin-top:0 !important; }

/* Hero full-bleed */
.msc-hero, .elementor-section.msc-hero { margin:0 !important; border:0 !important; }
.elementor-section-wrap > .elementor-section:first-child { margin-top:0 !important; }
/* === Floating actions v2 === */
.msc-f2 {position:fixed; right:18px; bottom:18px; z-index:1000000;
  display:flex; flex-direction:column; align-items:flex-end; gap:12px; pointer-events:none;}
.msc-f2 a {pointer-events:auto; text-decoration:none; font-family:-apple-system,BlinkMacSystemFont,"Inter","Roboto",Arial,sans-serif}

/* Bouton "Réserver en ligne" : très visible */
.msc-f2-btn {display:flex; align-items:center; gap:10px; padding:12px 14px;
  background:#2f61a9; color:#fff; border-radius:14px;
  box-shadow:0 18px 40px rgba(47,97,169,.35);
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:saturate(140%) blur(4px);
  transition:transform .15s ease, filter .15s ease; max-width:260px;}
.msc-f2-btn:hover {transform:translateY(-2px); filter:brightness(1.06);}
.msc-f2-btn .msc-f2-text {display:flex; flex-direction:column; line-height:1.1}
.msc-f2-btn strong {font-size:.95rem; font-weight:700;}
.msc-f2-btn em {font-size:.78rem; opacity:.9; font-style:normal}

/* Icône (SVG) */
.msc-f2-ico svg, .msc-f2-round svg {width:22px; height:22px; display:block; fill:none; stroke:#fff; stroke-width:2; stroke-linecap:round; stroke-linejoin:round}
.msc-f2-round svg.wa {fill:#fff; stroke:none}

/* Bulles rondes : appel & WhatsApp */
.msc-f2-round {width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 18px 32px rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.2); transition:transform .15s ease}
.msc-f2-round:hover {transform:translateY(-2px) scale(1.05)}
.msc-f2-call {background:#111; color:#fff}          /* téléphone : noir lisible sur fond sombre */
.msc-f2-wa   {background:#25D366; color:#000}       /* WhatsApp vert officiel */

/* Pulsation légère sur Réserver */
@keyframes mscPulse{0%{box-shadow:0 0 0 0 rgba(47,97,169,.45)}70%{box-shadow:0 0 0 12px rgba(47,97,169,0)}100%{box-shadow:0 0 0 0 rgba(47,97,169,0)}}
.msc-f2-book{animation:mscPulse 2.8s infinite}

/* Mobile : le bouton Réserver reste lisible, on masque le sous-texte si trop petit */
@media (max-width:480px){
  .msc-f2 {right:14px; bottom:14px; gap:10px}
  .msc-f2-btn {padding:11px 12px; border-radius:12px; max-width:220px}
  .msc-f2-btn em {display:none}
  .msc-f2-round {width:50px; height:50px}
}

/* Force l’affichage par-dessus d’éventuels widgets/theme */
.msc-f2, .msc-f2 * {z-index:1000000 !important; pointer-events:auto}
/* HERO — correctif mobile : hauteur, overflow, titres, marge basse */
@media (max-width: 767px){
  .home .elementor-section:first-of-type{
    min-height: 100svh !important;   /* plein écran mobile moderne */
    overflow: visible !important;     /* évite le texte coupé */
    padding-bottom: 18vh !important;  /* espace pour le bouton flottant */
  }
  .home .elementor-section:first-of-type .elementor-container,
  .home .elementor-section:first-of-type .elementor-widget-wrap{
    overflow: visible !important;
  }
  .home .elementor-section:first-of-type .elementor-heading-title{
    font-size: clamp(22px, 6.2vw, 28px) !important;
    line-height: 1.22 !important;
    word-break: normal !important;
  }
}
/* WPForms — réafficher les libellés des champs */
.wpforms-field-label,
.wpforms-field-sublabel{
  display: block !important;
  opacity: 1 !important;
  height: auto !important;
  margin: 0 0 6px !important;
  color: #111 !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
}
.wpforms-required-label{ display: inline !important; }
/* === HERO ciblé par ID (mobile) ================== */
/* Remplace #hero par #hero-top si tu as choisi cet ID */
@media (max-width: 767px){
  #hero {
    min-height: 100svh !important;   /* plein écran mobile réel */
    overflow: visible !important;     /* ne coupe rien */
  }
  #hero > .elementor-container,
  #hero .elementor-widget-wrap {
    overflow: visible !important;
  }

  /* Si un overlay/bande décorative masque le texte, on la rend neutre aux clics */
  #hero .elementor-background-overlay {
    pointer-events: none !important;
  }

  /* Un peu d’air sous le texte si tu as des boutons flottants à droite */
  #hero .elementor-widget-wrap {
    padding-bottom: 14vh !important;
  }

  /* Titre + sous-titre plus souples */
  #hero .elementor-heading-title {
    font-size: clamp(22px, 6.2vw, 28px) !important;
    line-height: 1.22 !important;
    word-break: normal !important;
    white-space: normal !important;
  }
  #hero .elementor-widget-text-editor,
  #hero p {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.5 !important;
  }
}
/* === WPForms — afficher les libellés, même si quelque chose les masque === */
div.wpforms-container form .wpforms-field-label,
div.wpforms-container form .wpforms-field-sublabel {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  height: auto !important;
  margin: 0 0 6px !important;
  color: #111 !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
  line-height: 1.3 !important;
}
div.wpforms-container form .wpforms-required-label { display: inline !important; }
/* === HERO mobile — cible le tout 1er bloc Elementor de la home === */
@media (max-width: 767px){

  /* le hero : plein écran, pas de coupe */
  .home .elementor-section:first-of-type{
    margin:0 !important; padding:0 !important; border:0 !important;
    min-height:100svh !important;          /* plein écran réel iOS/Android */
    overflow:visible !important;
    position:relative;
  }

  /* conteneur interne : on place le contenu, pas de coupe */
  .home .elementor-section:first-of-type > .elementor-container{
    min-height:100svh !important;
    align-items:center !important;        /* le texte descend un peu, change en center si tu préfères */
    overflow:visible !important;
  }

  /* colonnes & wrap : laissent dépasser le texte/boutons */
  .home .elementor-section:first-of-type .elementor-column,
  .home .elementor-section:first-of-type .elementor-widget-wrap{
    overflow:visible !important;
  }

  /* overlay du hero : ne bloque pas les clics */
  .home .elementor-section:first-of-type .elementor-background-overlay{
    pointer-events:none !important;
  }

  /* tailles fluides = plus de coupure */
  .home .elementor-section:first-of-type h1,
  .home .elementor-section:first-of-type .elementor-heading-title{
    font-size:clamp(22px,6.5vw,28px) !important;
    line-height:1.22 !important;
    white-space:normal !important;
    word-break:normal !important;
  }
  .home .elementor-section:first-of-type p{
    font-size:clamp(14px,3.8vw,16px) !important;
    line-height:1.5 !important;
  }

  /* un peu d’air en bas si tu as des bulles flottantes à droite */
  .home .elementor-section:first-of-type .elementor-widget-wrap{
    padding:0 16px 14vh !important;
  }

  /* si le header recouvre le haut, pousse légèrement */
  .ast-header-break-point .home .elementor-section:first-of-type{
    padding-top:10vh !important;
  }
}
/* === HERO mobile — cible le tout 1er bloc Elementor de la home === */
@media (max-width: 767px){

  /* le hero : plein écran, pas de coupe */
  .home .elementor-section:first-of-type{
    margin:0 !important; padding:0 !important; border:0 !important;
    min-height:100svh !important;          /* plein écran réel iOS/Android */
    overflow:visible !important;
    position:relative;
  }

  /* conteneur interne : on place le contenu, pas de coupe */
  .home .elementor-section:first-of-type > .elementor-container{
    min-height:100svh !important;
    align-items:flex-end !important;        /* le texte descend un peu, change en center si tu préfères */
    overflow:visible !important;
  }

  /* colonnes & wrap : laissent dépasser le texte/boutons */
  .home .elementor-section:first-of-type .elementor-column,
  .home .elementor-section:first-of-type .elementor-widget-wrap{
    overflow:visible !important;
  }

  /* overlay du hero : ne bloque pas les clics */
  .home .elementor-section:first-of-type .elementor-background-overlay{
    pointer-events:none !important;
  }

  /* tailles fluides = plus de coupure */
  .home .elementor-section:first-of-type h1,
  .home .elementor-section:first-of-type .elementor-heading-title{
    font-size:clamp(22px,6.5vw,28px) !important;
    line-height:1.22 !important;
    white-space:normal !important;
    word-break:normal !important;
  }
  .home .elementor-section:first-of-type p{
    font-size:clamp(14px,3.8vw,16px) !important;
    line-height:1.5 !important;
  }

  /* un peu d’air en bas si tu as des bulles flottantes à droite */
  .home .elementor-section:first-of-type .elementor-widget-wrap{
    padding:0 16px 14vh !important;
  }

  /* si le header recouvre le haut, pousse légèrement */
  .ast-header-break-point .home .elementor-section:first-of-type{
    padding-top:10vh !important;
  }
}/* === Fix Hero mobile masqué ou coupé sous le header === */
@media (max-width: 767px){

  /* Forcer le hero (première section Elementor) à s'afficher entièrement */
  .home .elementor-section:first-of-type {
    position: relative !important;
    min-height: 100vh !important;
    margin-top: 0 !important;
    padding-top: 50px !important;   /* décale sous le header Astra */
    overflow: visible !important;
  }

  /* Ajuster le conteneur intérieur */
  .home .elementor-section:first-of-type > .elementor-container {
    min-height: calc(100vh - 80px) !important; /* moins la hauteur du header */
    display: flex !important;
    flex-direction: column;
    justify-content: flex-end; /* ou center si tu veux centrer verticalement */
    overflow: visible !important;
  }

  /* Rendre le texte fluide */
  .home .elementor-section:first-of-type h1,
  .home .elementor-section:first-of-type .elementor-heading-title {
    font-size: clamp(22px, 6.2vw, 28px) !important;
    line-height: 1.25 !important;
    white-space: normal !important;
  }

  .home .elementor-section:first-of-type p {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.45 !important;
  }

  /* Si overlay = masque, on le neutralise */
  .home .elementor-section:first-of-type .elementor-background-overlay {
    pointer-events: none !important;
  }
}
.msc-before-after-section {
  padding: 60px 0;
}

.msc-before-after-grid {
  display: grid;
  gap: 24px;
}

@media (min-width: 900px) {
  .msc-before-after-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.msc-ba-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.msc-ba-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}

.msc-ba-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  user-select: none;
  pointer-events: none;
}

.msc-ba-before {
  filter: grayscale(0.3);
}

.msc-ba-after {
  position: absolute;
  top: 0;
  left: 0;
  width: 50%; /* valeur initiale, sera mise à jour en JS */
  height: 100%;
  object-fit: cover;
  overflow: hidden;
}

.msc-ba-overlay {
  position: absolute;
  top: 0;
  left: 50%;
  width: 50%;
  height: 100%;
  pointer-events: none;
  backdrop-filter: none;
}

.msc-ba-handle {
  position: absolute;
  top: 0;
  left: 50%;
  width: 3px;
  height: 100%;
  transform: translateX(-50%);
  background: rgba(255,255,255,0.9);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.15);
}

.msc-ba-range {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  height: 40px;
  cursor: ew-resize;
}

/* Style basique du slider (optionnel) */
.msc-ba-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid #fff;
  background: #007bff;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.15);
}

.msc-ba-range::-moz-range-thumb {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid #fff;
  background: #007bff;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.15);
}

.msc-ba-labels {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  opacity: 0.8;
}/* End custom CSS */