/*
Theme Name: QF Custom — v30 (Contact: logo 180px + align)
Author: Mathieu + ChatGPT
Description: Page Contact avec logo 180px (glow doux) et alignement vertical affiné. Accueil inchangé (logo 340px).
Version: 30.0.0
Text Domain: qf-custom-theme-v30
*/

/* ===== Base ===== */
html { font-size: 110%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { margin: 0; color: #fff; }

/* Gradient background */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -1;
  background:
    radial-gradient(80% 60% at 20% 0%, rgba(139,57,122,0.35) 0%, rgba(139,57,122,0.10) 60%, transparent 100%),
    radial-gradient(70% 50% at 80% 0%, rgba(190,43,72,0.35) 0%, rgba(190,43,72,0.10) 60%, transparent 100%),
    linear-gradient(180deg, #0D0F13 0%, #12151D 100%);
  background-attachment: fixed;
}

/* Space for fixed header */
.wp-site-blocks { max-width: 1280px; margin: 0 auto; padding: 92px 24px 0; }

/* ===== Header (fixed, frosted) ===== */
.site-header {
  position: fixed; top:0; left:0; right:0; z-index:50; display:flex; justify-content:center;
  background: rgba(8,10,14,.35); -webkit-backdrop-filter: blur(12px) saturate(150%); backdrop-filter: blur(12px) saturate(150%);
  border-bottom: 1px solid rgba(255,255,255,0.06); box-shadow: 0 6px 22px rgba(0,0,0,0.28);
}
.header-inner { width:100%; max-width:1280px; padding:12px 24px; position:relative; display:flex; align-items:center; justify-content:center; }
.header-inner .wp-block-navigation { margin:0 auto; }
.wp-block-navigation__container { gap:18px; }
.wp-block-navigation a { font-size:1.125rem; line-height:1.2; color:#fff; }
.phone-chip {
  position:absolute; right:24px; top:50%; transform:translateY(-50%); display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:999px; background:linear-gradient(90deg, #8B397A, #BE2B48); color:#fff; text-decoration:none; font-weight:700;
  letter-spacing:.2px; box-shadow:0 8px 20px rgba(190,43,72,0.25); transition:transform .15s, box-shadow .15s, filter .2s; white-space:nowrap;
}
.phone-chip:hover { transform: translateY(-50%) translateY(-1px); box-shadow:0 12px 30px rgba(190,43,72,0.34); filter:brightness(1.04); }
.phone-chip .icon {
  width:16px; height:16px; display:inline-block; background: currentColor;
  mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="%23fff" d="M6.62 10.79a15.05 15.05 0 006.59 6.59l2.2-2.2a1 1 0 011.01-.24c1.12.37 2.33.57 3.58.57a1 1 0 011 1V20a1 1 0 01-1 1C11.85 21 3 12.15 3 1a1 1 0 011-1h3.5a1 1 0 011 1c0 1.25.2 2.46.57 3.58a1 1 0 01-.24 1.01l-2.2 2.2z"/></svg>') center / contain no-repeat;
}

/* ===== Sections / cards ===== */
.section { margin:52px 0; }
.lift-top { margin-top: 28px; }

.card {
  position:relative;
  background: rgba(18,21,29,.88);
  border:2px solid transparent;
  border-image: linear-gradient(90deg, #8B397A, #BE2B48) 1;
  border-radius:26px;
  padding:40px;
  min-height:240px;
  box-shadow:0 26px 52px rgba(0,0,0,.33);
  text-align:center;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items: stretch;          /* étire les enfants sur la largeur */
  gap:8px;
  transition: transform .2s, box-shadow .2s, border-image-source .2s;
}
.card h3 { margin:0; font-size:1.5625rem; }
.card p  { margin:0; font-size:1.125rem; }
.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 34px 70px rgba(190,43,72,.22), 0 12px 34px rgba(0,0,0,.45);
  border-image: linear-gradient(90deg, #BE2B48, #FF6A6A) 1;
}

/* ===== Hero (Accueil inchangé) ===== */
.hero-wrap {
  border-radius:32px; padding:56px 28px; min-height:52vh;
  background: radial-gradient(90% 120% at 50% 0%, rgba(190,43,72,.16) 0%, rgba(139,57,122,.10) 50%, transparent 100%);
  box-shadow: 0 20px 50px rgba(0,0,0,.22);
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:28px;
}
.hero-logo { height:340px; width:auto; display:block; margin:0; filter: drop-shadow(0 10px 26px rgba(190,43,72,.22)); }
@media (max-width:1024px){ .hero-logo{ height:220px; } }
@media (max-width:720px){  .hero-logo{ height:150px; } }
.hero-subtitle { font-size:1.375rem; line-height:1.45; max-width:960px; margin:0; }
.btn-primary { display:inline-block; border-radius:999px; padding:14px 26px; font-weight:700; background:#BE2B48; color:#fff; text-decoration:none; font-size:1.125rem; line-height:1.1; }
.btn-primary:hover { opacity:.96; transform: translateY(-1px); }

/* ===== Contact page logo + intro ===== */
.contact-logo-wrap { text-align:center; margin-bottom: 18px; }
.contact-logo { height: 180px; width:auto; filter: drop-shadow(0 10px 26px rgba(190,43,72,.22)); }
.contact-intro { text-align:center; margin: 10px 0 26px; color: #e8e8e8; opacity: .96; }
.contact-wrap { margin-top: 14px; }

/* ===== Form ===== */
.form-card{ background: rgba(18,21,29,0.75); border-radius: 24px; padding: 28px; border:1px solid rgba(255,255,255,0.06); box-shadow:0 24px 60px rgba(0,0,0,0.35); backdrop-filter: blur(6px); }
.qf-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:16px; } .qf-grid .full{ grid-column:1 / -1; }
.qf-field{ display:flex; flex-direction:column; gap:8px; }
.qf-label{ font-weight:600; color:#eaeaea; }
.qf-input, .qf-textarea{
  background: rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12); color:#fff;
  border-radius:14px; padding:12px 14px; font-size:1rem; outline:none;
  transition:border-color .15s, box-shadow .15s, background .15s;
}
.qf-input::placeholder, .qf-textarea::placeholder{ color: rgba(255,255,255,0.5); }
.qf-input:focus, .qf-textarea:focus{
  border-color:#BE2B48; box-shadow:0 0 0 3px rgba(190,43,72,0.25), 0 10px 30px rgba(190,43,72,0.18);
  background: rgba(255,255,255,0.08);
}
.qf-submit{
  display:inline-block; border-radius:999px; padding:14px 26px; font-weight:700;
  background:linear-gradient(90deg,#8B397A,#BE2B48); color:#fff; border:none; cursor:pointer; font-size:1.0625rem;
  transition: transform .15s, box-shadow .15s, filter .15s;
}
.qf-submit:hover{ transform: translateY(-1px); box-shadow: 0 18px 38px rgba(190,43,72,0.28); filter: brightness(1.04); }
.alert-success{ background: rgba(46,164,79,0.15); border:1px solid rgba(46,164,79,0.35); color:#d8ffd8; padding:12px 14px; border-radius:12px; margin-bottom:18px; }

/* ===== Responsive ===== */
@media (max-width: 920px) {
  .header-inner { padding-right: 96px; }
  .qf-grid { grid-template-columns: 1fr; }
  .contact-logo { height: 160px; }
}
@media (max-width: 720px) {
  .phone-chip { position: static; transform: none; margin-top: 8px; align-self: center; }
  .header-inner { flex-direction: column; gap: 8px; }
  .contact-logo { height: 130px; }
}

/* ===== Images génériques dans les cartes (fallback) ===== */
.card-image { margin-top: 6px; }
.card-image img { width: 100%; height: auto; border-radius: 8px; display: block; }

/* Réduit l'espace par défaut dans toutes les cartes */
.wp-block-group.card p { margin-bottom: 6px; }

/* ===================================================================== */
/* ===================   ACCUEIL – 3 CARTES (UNIFIÉ)   ================== */
/* ===================================================================== */

/* Réglage : espace visible entre la photo et la bordure interne de la carte.
   La carte a padding:40px → on laisse un petit liseré homogène. */
:root { --card-gutter: 20px; } /* ajuste: 16px (plus large) / 22px (plus d’air) */

/* Rien ne doit dépasser visuellement des coins arrondis */
.section .wp-block-columns.alignwide > .wp-block-column .wp-block-group.card {
  overflow: hidden;
}

/* Figure : pleine largeur “interne” + remontée identique aux 3 blocs */
.section .wp-block-columns.alignwide > .wp-block-column .wp-block-group.card figure.wp-block-image {
  display: block !important;
  max-width: none !important;

  /* largeur = 100% + 2*(padding - gutter)  =>  100% + 2*(40px - var) */
  width: calc(100% + 80px - (2 * var(--card-gutter))) !important;

  /* centrage = -(padding - gutter) de chaque côté */
  margin-left: calc(-40px + var(--card-gutter)) !important;
  margin-right: calc(-40px + var(--card-gutter)) !important;

  /* remontée validée */
  margin-top: -55px !important;
  margin-bottom: 10px !important;

  padding: 0 !important;
  box-sizing: border-box;
  border: 0 !important;
}

/* Image : 100% du conteneur + coins comme validé (haut gauche droit) */
.section .wp-block-columns.alignwide > .wp-block-column .wp-block-group.card figure.wp-block-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;

  border-top-left-radius: 0 !important;      /* coin haut gauche droit */
  border-top-right-radius: 12px !important;
  border-bottom-left-radius: 12px !important;
  border-bottom-right-radius: 12px !important;
}
/* === Fix Covering : pas d'arrondi en haut + anti-jour côté droit === */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image,
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image img {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;   /* coin haut droit bien droit */
}

/* Anti-seam (micro-jour subpixel) : on élargit de 1px et on recentre */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image img {
  width: calc(100% + 2px) !important;
  margin-left: -1px !important;
  margin-right: -1px !important;
  display: block !important;
}
/* === Ajustement final Covering : largeur et bas parfaits === */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image img {
  width: calc(100% + 36px) !important;  /* élargit légèrement vers les bords internes */
  margin-left: -18px !important;        /* compense au centre */
  margin-right: -18px !important;
  margin-bottom: -6px !important;       /* descend un peu pour coller le bas */
  height: auto !important;
  object-fit: cover !important;
}
/* === RESET propre du bloc 3 (Covering) === */
/* 1) Figure : pleine largeur INTERNE de la carte, pas de débordement, haut droit */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: -55px 0 6px 0 !important;   /* même remontée que le 1er bloc, petit air en bas */
  padding: 0 !important;
  box-sizing: border-box;
  border-radius: 0 0 12px 12px !important; /* haut 100% droit, bas arrondi */
  overflow: hidden; /* sécurité anti-débordement */
}

/* 2) Image : occupe 100% du conteneur (pas de calc, pas de marges négatives) */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image img {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  border-radius: 0 0 12px 12px !important; /* même arrondi que la figure */
  margin: 0 !important;                    /* annule nos anciens -1/-18px */
}

/* 3) Sécurité : annule toute ancienne règle agressive qu’on a testée */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image img {
  /* annule les anciennes surcharges si encore en cache */
  transform: none !important;
}
/* === Covering : ajuste largeur pile au bord interne === */
.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image {
  width: calc(100% + 40px) !important;   /* 40px = padding de .card */
  margin-left: -20px !important;         /* moitié de 40px → centré */
  margin-right: -20px !important;
  margin-top: -55px !important;
  margin-bottom: 6px !important;
  border-radius: 0 0 12px 12px !important;
  overflow: hidden;
}

.section .wp-block-columns.alignwide > .wp-block-column:last-child .card figure.wp-block-image img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
  object-fit: cover !important;
  border-radius: 0 0 12px 12px !important;
}
/* === Covering (3e bloc) : élargir bord à bord sans dépasser === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card {
  overflow: hidden; /* garde les coins nets */
}

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card figure.wp-block-image {
  display: block !important;
  width: calc(100% + 40px) !important;   /* élargit pile au bord interne (padding = 40px) */
  max-width: none !important;
  margin-left: -20px !important;         /* moitié de la valeur ci-dessus pour centrer */
  margin-right: -20px !important;
  margin-top: -55px !important;          /* garde ta hauteur parfaite */
  margin-bottom: 8px !important;
  padding: 0 !important;
  box-sizing: border-box;
}

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card figure.wp-block-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  border-radius: 0 0 12px 12px !important; /* haut droit/gauche droits, bas arrondi */
}
/* === Covering (3e bloc) : étire légèrement la photo sans changer la position === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) 
.wp-block-group.card figure.wp-block-image img {
  transform: scale(1.02); /* agrandit très légèrement (1.00 = normal) */
  transform-origin: center; /* garde le centrage parfait */
}
/* === Covering (3e bloc) : étirement léger, sans dépasser la carte === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) 
.wp-block-group.card figure.wp-block-image img {
  width: 100% !important;       /* étire légèrement la largeur */
  height: 102% !important;      /* étire un peu aussi la hauteur */
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important; /* garde le cadrage propre */
  margin: 0 !important;
  transform: translate(-1%, -1%); /* recentre l’image étirée */
}
/* === Correction : supprime l’arrondi haut droit des images (blocs 1 et 2) === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(-n+2) .wp-block-group.card figure.wp-block-image img {
  border-top-right-radius: 0 !important;  /* plus d’arrondi haut droit */
  border-top-left-radius: 0 !important;   /* garde l’équilibre visuel */
  border-bottom-left-radius: 12px !important;
  border-bottom-right-radius: 12px !important;
}
/* === Accueil : 3 colonnes même largeur & même hauteur === */
.wp-block-columns.alignwide{
  display:flex;
  align-items: stretch;              /* étire toutes les colonnes à la même hauteur */
}

.wp-block-columns.alignwide > .wp-block-column{
  flex: 1 1 0%;                      /* mêmes largeurs */
  display: flex;                     /* pour que la carte remplisse la colonne */
}

.wp-block-columns.alignwide > .wp-block-column > .wp-block-group.card{
  display:flex;
  flex-direction: column;
  flex:1 1 auto;                     /* la carte prend toute la hauteur dispo */
  height: 100%;
}

/* Sécurité : l'image ne casse pas la mise en page */
.wp-block-columns.alignwide > .wp-block-column .wp-block-group.card figure.wp-block-image{
  width:100% !important;
  max-width:100% !important;
}
.wp-block-columns.alignwide > .wp-block-column .wp-block-group.card figure.wp-block-image img{
  display:block;
  width:100%;
  height:auto;
  object-fit: cover;
}
/* === Accueil : 3 cartes uniformes === */
.section .wp-block-columns.alignwide > .wp-block-column .card {
  overflow: hidden;
}

.section .wp-block-columns.alignwide > .wp-block-column .card .card-image {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  margin-top: -55px !important;
  margin-bottom: 10px !important;
  padding: 0 !important;
  box-sizing: border-box;
}

.section .wp-block-columns.alignwide > .wp-block-column .card .card-image img {
  display: block;
  width: 100% !important;
  height: auto !important;
  object-fit: cover;
  border-top-left-radius: 0 !important;  /* supprime le petit vide haut gauche */
  border-top-right-radius: 0 !important; /* même chose à droite */
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}
/* === Fix final Covering : garde la position parfaite et supprime le micro-trait === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card figure.wp-block-image {
  margin-top: -55px !important; /* ta hauteur exacte */
  margin-bottom: 10px !important;
  line-height: 0 !important;
}

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) 
.wp-block-group.card figure.wp-block-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  border-radius: 0 0 12px 12px !important; /* garde les coins bas arrondis uniquement */
  object-fit: cover !important;
  transform: translateY(-0.5px); /* masque juste le micro-trait sans déplacer visiblement */
}
/* === Fix Covering : supprime le trait blanc au-dessus de la photo === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card figure.wp-block-image {
  position: relative !important;
  margin-top: -55px !important; /* garde ta hauteur parfaite */
  margin-bottom: 10px !important;
  line-height: 0 !important; /* supprime les artefacts de texte */
}

/* Masque un éventuel “cheveu blanc” avec une fine bande couleur fond */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card figure.wp-block-image::before {
  content: "";
  position: absolute;
  top: 0px; /* remonte de 1px pour recouvrir le bord */
  left: 0;
  right: 0;
  height: 2px;
  background: rgba(18,21,29,.88); /* même couleur que la carte */
  pointer-events: none;
}
/* === Fix Covering : supprime le micro-trait sans changer la taille ni déplacer l'image === */
.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3)
.wp-block-group.card figure.wp-block-image {
  line-height: 0 !important;
}

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3)
.wp-block-group.card figure.wp-block-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  border-radius: 0 0 12px 12px !important;
  object-fit: cover !important;
  margin-top: -0.5px !important;   /* colle le haut sans bouger visiblement */
  margin-bottom: -0.5px !important;/* colle le bas sans agrandir */
}
/* === Covering (bloc 3) : micro-bleed pour combler le fin bord noir en bas/gauche/droite === */
:root { --cover-bleed: 2px; } /* ajuste : 1px si trop, 3px si encore un cheveu */

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card { 
  overflow: hidden; /* on reste bien à l'intérieur du cadre arrondi */
}

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) .wp-block-group.card figure.wp-block-image {
  position: relative;
  margin-top: -55px !important;  /* ta hauteur validée */
  margin-bottom: 10px !important;
}

.section .wp-block-columns.alignwide > .wp-block-column:nth-of-type(3) 
.wp-block-group.card figure.wp-block-image img {
  display: block !important;
  width: calc(100% + (2 * var(--cover-bleed))) !important; /* léger élargissement interne */
  margin-left: calc(-1 * var(--cover-bleed)) !important;
  margin-right: calc(-1 * var(--cover-bleed)) !important;
  margin-bottom: calc(-1 * var(--cover-bleed)) !important;  /* colle le bas */
  height: auto !important;
  object-fit: cover !important;
  border-radius: 0 0 12px 12px !important; /* garde l’arrondi bas */
}
/* Accueil — uniformiser la taille des photos des 3 cartes */
body.home .wp-block-columns .wp-block-column .wp-block-image img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;   /* même ratio partout */
  object-fit: cover;       /* recadre sans déformer */
  object-position: center; /* centre le sujet */
}

/* Optionnel : pour que l’image suive les arrondis/cadre de la carte */
body.home .wp-block-columns .wp-block-image {
  overflow: hidden;
  border-radius: 12px;     /* ajuste si tes cartes ont un autre rayon */
}

/* Si tu préfères une hauteur fixe (au lieu du ratio), commente le bloc ci-dessus et décommente ceci :
body.home .wp-block-columns .wp-block-column .wp-block-image img {
  height: 240px;
  width: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
*/
/* Supprime les arrondis visibles sur les images (photos droites) */
body.home .wp-block-columns .wp-block-column .wp-block-image img {
  border-radius: 0 !important; /* bords droits */
}
/* === Fix image Film Solaire : bords droits === */
body.home .wp-block-columns .wp-block-column .wp-block-image,
body.home .wp-block-columns .wp-block-column .wp-block-image figure,
body.home .wp-block-columns .wp-block-column .wp-block-image img {
  border-radius: 0 !important; /* enlève les arrondis à tous les niveaux */
  overflow: hidden !important; /* empêche les dépassements */
}
/* Nos services — centrer verticalement les photos dans leur colonne */
.page .wp-block-columns .wp-block-column:has(> .wp-block-image) {
  display: flex;            /* fait de la colonne un conteneur flex */
  align-items: center;      /* centre VERTICALEMENT l'image */
  justify-content: center;  /* centre HORIZONTALEMENT (au cas où) */
}

/* Sécurité : s'assurer que l'image ne dépasse pas */
.page .wp-block-columns .wp-block-column:has(> .wp-block-image) img {
  max-width: 100%;
  height: auto;
  display: block;
}
/* — Nos services : centrer verticalement le contenu de chaque colonne — */
/* Variante 1 — si le <body> a une classe liée à la page nos services */
.page-nos-services .wp-block-columns > .wp-block-column {
  display: grid;
  align-content: center;   /* centre verticalement le contenu de la colonne */
}

/* Variante 2 — si la classe body est différente mais contient "nos-services" */
body[class*="nos-services"] .wp-block-columns > .wp-block-column {
  display: grid;
  align-content: center;
}

/* Variante 3 — dernier recours : cible juste le 1er et le 3e “row” de colonnes */
.page .wp-block-columns:nth-of-type(1) > .wp-block-column,
.page .wp-block-columns:nth-of-type(3) > .wp-block-column {
  display: grid;
  align-content: center;
}

/* Sécurité images (pas obligatoire mais propre) */
.page .wp-block-image img {
  display: block;
  max-width: 100%;
  height: auto;
}
/* Nos services (page post-14) — centrage vertical des 3 blocs */
.post-14 .service-block { display: flex !important; align-items: center !important; }

/* Assure que l’image se centre dans l’axe vertical, sans changer sa largeur */
.post-14 .service-block > img { align-self: center !important; }
/* === Correction centrage vertical Covering Automobile === */
.service-block:nth-of-type(3) {
  display: flex !important;
  flex-direction: row !important;   /* garde image à gauche et texte à droite */
  align-items: center !important;   /* centre verticalement */
  justify-content: flex-start !important;
  gap: 40px;                        /* espace horizontal entre image et texte */
}

.service-block:nth-of-type(3) img {
  display: block !important;
  height: auto !important;
  max-width: 45% !important;
  margin: 0 !important;
}

.service-block:nth-of-type(3) .service-text {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important; /* centre le texte dans la hauteur */
}
/* === Fix Covering Automobile : centrage vertical image + texte === */
.service-block:nth-of-type(3) {
  display: flex !important;
  align-items: center !important; /* centrage vertical */
  justify-content: flex-start !important; /* image à gauche, texte à droite */
  gap: 40px !important;
}

.service-block:nth-of-type(3) img {
  display: block !important;
  max-width: 45% !important;
  height: auto !important;
  border-radius: 12px !important;
}

.service-block:nth-of-type(3) .service-text {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important; /* texte centré verticalement */
}
/* Texte bouton Facebook en blanc */
.qf-fb span {
  color: #ffffff !important;
}

/* Icône Facebook en blanc */
.qf-fb svg path {
  fill: #ffffff !important;
  stroke: #ffffff !important;
}
