
/*
Theme Name: qi-blocks
Theme URI: https://exemple.com/qi-blocks
Author: Votre Nom
Author URI: https://exemple.com
Description: Thème WordPress minimal orienté “no core CSS” (contrôle total du rendu).
Version: 1.0.0
Requires at least: 6.3
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: qi-blocks
Tags: minimal, clean, blocks
*/

/* ======================================================
   CROISSANCE NUMÉRIQUE — CSS
   ====================================================== */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Manrope:wght@400;600;700;800&family=Playfair+Display:wght@600;700;800&display=swap');

/* ---------- Design tokens ---------- */
:root{
  /* Couleurs */
  --cn-bg:#FFFDF6;
  --cn-surface:#FFFFFF;
  --cn-border:#0B0F1A;
  --cn-text:#0B0F1A;
  --cn-muted:#5D6573;

  --cn-primary:#0B0F1A;
  --cn-accent:#FFD400;
  --cn-accent-ink:#0B0F1A;

  --cn-success:#137D39;
  --cn-success-50:#E8F6EC;
  --cn-accent-50:#FFF7CC;
  --cn-accent-100:#FFE784;

  /* Rayons, ombres, espaces */
  --radius-1:6px; --radius-2:10px; --radius-3:14px; --radius-pill:999px;
  --shadow-1:6px 6px 0 var(--cn-border);
  --shadow-2:10px 10px 0 var(--cn-border);

  /* Layout & spacing */
  --container-max: 1240px;
  --container-pad: clamp(16px, 4vw, 20px);
  --space-1:8px; --space-2:12px; --space-3:16px; --space-4:22px; --space-5:28px; --space-6:36px; --space-7:52px; --space-8:80px;

  --gap-lg: clamp(18px, 4vw, 44px);
  --gap-xl: clamp(24px, 6vw, 80px);
}

/* ---------- Reset de base ---------- */
*,*::before,*::after{ box-sizing:border-box }
html{ scroll-behavior:smooth; color-scheme: light }
body{
  margin:0;
  font-family:"Manrope","Inter","system-ui",-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--cn-text);
  background:var(--cn-bg);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
main{ overflow-wrap:anywhere; word-wrap:break-word }

a{ color:var(--cn-primary); text-decoration:underline; text-decoration-thickness:2px; text-underline-offset:3px }
a:hover{ background:var(--cn-accent); color:var(--cn-accent-ink); text-decoration:none }

/* ---------- Titres / hiérarchie ---------- */
h1{
  font-weight:900; text-transform:uppercase; letter-spacing:.01em; line-height:1.02;
  font-size:clamp(2.6rem, 1.3rem + 4.2vw, 4rem);
  margin-block:var(--space-7) var(--space-4);
}
h2{
  font-weight:900; text-transform:uppercase; letter-spacing:.02em; line-height:1.08;
  font-size:clamp(1.8rem, 1rem + 2.4vw, 2.6rem);
  margin-block:var(--space-6) var(--space-3);
}
h3{
  font-weight:900; text-transform:uppercase; letter-spacing:.02em; line-height:1.15;
  font-size:clamp(1.22rem, .9rem + .9vw, 1.5rem);
  margin-block:var(--space-4) var(--space-2);
}
h4{
  font-weight:800; text-transform:uppercase; letter-spacing:.03em;
  font-size:clamp(.98rem, .9rem + .25vw, 1.08rem);
  color:var(--cn-primary);
  margin-block:var(--space-3) var(--space-2);
}
p{ margin-block:.75rem 1rem }

/* ---------- Utilitaires ---------- */
.container{ max-width:var(--container-max); margin-inline:auto; padding-inline:var(--container-pad) }
.section{ margin-block:var(--space-8) }
.text-center{ text-align:center }
.u-underline{ display:inline; background:linear-gradient(transparent 60%, var(--cn-accent) 60%); text-decoration:none; box-decoration-break:clone; padding:2px 6px 0 6px }
.cn-small{ font-size:.92rem; line-height:1.6 }
.cn-muted{ color:var(--cn-muted) }

/* Padding VERTICAL uniquement (pas de L/R) */
.pad-lg{ padding-block:70px 60px }
.pad-xl{ padding-block:90px }

/* ---------- Boutons ---------- */
.btn{
  display:inline-block;
  border-radius:var(--radius-1);
  padding:14px 20px;
  font-weight:900; text-transform:uppercase; letter-spacing:.03em;
  border:3px solid var(--cn-border);
  box-shadow:var(--shadow-1);
  transform:translate(0,0);
  transition:transform .1s ease, box-shadow .1s ease, background .15s ease, color .15s ease, border-color .15s ease;
  background:var(--cn-accent); color:var(--cn-accent-ink);
}
.btn:hover{ transform:translate(-3px,-3px); box-shadow:var(--shadow-2) }
.btn:focus-visible{ outline:4px solid var(--cn-accent-100); outline-offset:2px }
.btn--primary{ background:var(--cn-accent); color:var(--cn-accent-ink) }
.btn--outline{ background:#fff; color:var(--cn-primary) }
.btn--outline:hover{ background:var(--cn-primary); color:#fff }
.btn-row{ display:flex; gap:12px; justify-content:center; align-items:center; flex-wrap:wrap }

/* ---------- Chips ---------- */
.cn-chip{ display:inline-block; background:#fff; color:var(--cn-primary); border:3px solid var(--cn-border); border-radius:6px; padding:6px 10px; font-weight:800; text-transform:uppercase; letter-spacing:.03em; margin:4px 6px 0 0; box-shadow:2px 2px 0 var(--cn-border); white-space:nowrap }
.cn-chip--accent{ background:var(--cn-accent); border-color:var(--cn-border); color:var(--cn-accent-ink) }

/* ---------- Cartes / blocs ---------- */
.cn-card, .cn-service{
  background:var(--cn-surface);
  border:3px solid var(--cn-border);
  border-radius:var(--radius-2);
  box-shadow:var(--shadow-1);
  padding:22px;
  transition:transform .1s ease, box-shadow .1s ease;
}
.cn-card:hover, .cn-service:hover{ box-shadow:var(--shadow-2); transform:translate(-2px,-2px) }

.cn-service__top{ display:flex; align-items:center; gap:12px }
.cn-service__icon{
  background:var(--cn-accent); border:3px solid var(--cn-border); border-radius:8px; padding:10px;
  box-shadow:3px 3px 0 var(--cn-border); width:62px; height:62px; display:flex; align-items:center; justify-content:center
}
.cn-service__icon svg path, .cn-service__icon svg rect, .cn-service__icon svg line{ stroke:var(--cn-primary); fill:none }
.cn-service .cn-lead{ font-size:15px; line-height:1.6; margin:6px 0 10px; color:var(--cn-text) }
.cn-service .cn-checklist li{ margin:.25rem 0 }
.cn-service details{ margin-top:10px }
.cn-service details summary{ cursor:pointer; font-weight:900; text-transform:uppercase; letter-spacing:.02em }

/* ---------- Listes ---------- */
.cn-checklist{ list-style:none; padding-left:0; margin:.5rem 0 }
.cn-checklist li{ position:relative; padding-left:34px; margin:.55rem 0; font-weight:700; letter-spacing:.01em }
.cn-checklist li::before{
  content:""; width:18px; height:18px; border:3px solid var(--cn-border); background:var(--cn-accent); border-radius:3px; position:absolute; left:4px; top:.25rem; box-shadow:1px 1px 0 var(--cn-border)
}

/* ---------- Modules de contenu ---------- */
.cn-lead{ font-size:18px; line-height:1.75; margin-top:.25rem; color:var(--cn-text) }
.cn-pull{ background:#FFF7E0; border:3px solid var(--cn-border); padding:10px 14px; border-radius:10px; margin:14px 0 }
.cn-quote{ font-size:18px; font-weight:800; margin:0; text-transform:uppercase; letter-spacing:.02em }
.cn-caption{ font-size:12px; color:var(--cn-muted); margin-top:4px }
.cn-aside{ background:#FFFFFF; border:3px solid var(--cn-border); border-radius:12px; padding:16px 18px; margin:14px 0 }
.cn-aside--accent{ background:var(--cn-accent-50); border-left:6px solid var(--cn-accent) }
.cn-aside--safe{ background:var(--cn-success-50); border-left:6px solid var(--cn-success) }
.cn-case{ background:#ffffff; border:3px dashed var(--cn-border); border-radius:12px; padding:14px }
.cn-badges .cn-chip{ background:#fff; border:3px solid var(--cn-border) }
.cn-label{ font-size:.8rem; font-weight:900; text-transform:uppercase; letter-spacing:.02em; color:var(--cn-muted); margin:0 0 6px 0 }

/* ---------- Grilles ---------- */
.services{ display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:18px; align-items:stretch }
.cn-grid-2{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:18px }
/* Empêche l'overflow des items de la grille des formulaires */
.cn-grid-2 > * { min-width: 0; }
.cn-kpis{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:14px; margin:18px 0 }
.cn-kpi{ background:#ffffff; border:3px solid var(--cn-border); border-radius:12px; text-align:center; padding:14px; box-shadow:2px 2px 0 var(--cn-border) }
.cn-kpi b{ display:block; font-size:22px; line-height:1.1 }
.cn-steps{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:14px; margin-top:12px }
.cn-step{ background:#FFFFFF; border:3px solid var(--cn-border); border-radius:10px; padding:12px; box-shadow:2px 2px 0 var(--cn-border) }
.cn-step b{ display:inline-block; margin-right:6px }

/* Deux colonnes types */
.cols-2{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,420px);
  gap:var(--gap-xl);
  align-items:start;
}
.cols-2 > *{ min-width:0 }
@media (max-width:1100px){ .cols-2{ grid-template-columns:1fr } }

.cols-70-30{
  display:grid;
  grid-template-columns:minmax(0,7fr) minmax(0,3fr);
  gap:var(--gap-lg);
  align-items:start;
}
.cols-70-30 > *{ min-width:0 }
@media (max-width:900px){ .cols-70-30{ grid-template-columns:1fr } }

/* marge verticale entre les blocs de la colonne droite (Engagements) */
#sec-engagements .cols-70-30 aside > * + *{ margin-top:var(--space-4) }

/* ---------- Images ---------- */
.figure-rounded img{ display:block; width:100%; max-width:357px; height:auto; aspect-ratio:1; object-fit:cover; border:3px solid var(--cn-border); border-radius:18px; margin-inline:auto }

/* ---------- Séparateur ---------- */
.separator-wide{ height:3px; background:var(--cn-border); border:0; margin:22px 0 }
/* supprimer le séparateur immédiatement après la section CTA */
.cta-accel + .separator-wide{ display:none }

/* ---------- Sections / fonds ---------- */
.bg-hero{
  background:
    repeating-linear-gradient(-8deg, var(--cn-accent-50), var(--cn-accent-50) 10px, transparent 10px, transparent 22px),
    linear-gradient(180deg, #FFFDF6 0%, #FFF9E8 100%);
  border:3px solid var(--cn-border);
  border-radius:18px;
  box-shadow:var(--shadow-1);
}
/* 1ʳᵉ section : pas d'espace au-dessus et pas de padding top hérité */
#sec-hero.section{ margin-block-start:0 }           /* retire la marge-top de .section ici seulement */
#sec-hero.pad-xl{ padding-block-start:0 }           /* colle le bandeau au bord supérieur de l'écran */
#sec-hero.bg-hero{ border-radius:0 }                /* bords supérieurs droits/gauches rectilignes */
#sec-hero .hero-content{ padding-top:clamp(70px, 10vw, 90px) } /* espace interne sous le bandeau uniquement */

/* H1 du HERO — espace latéral ≥ gouttières extérieures de la section */
#sec-hero .hero-content > h1{
  /* Choisit la plus grande valeur entre :
     - le padding latéral standard du container
     - la “gouttière extérieure” ( (100vw - (max container + 2×padding container)) / 2 ) */
  padding-inline: max(
    var(--container-pad),
    calc((100vw - (var(--container-max) + (2 * var(--container-pad)))) / 2)
  );
}

.bg-dark-signal{
  background:
    radial-gradient(1200px 400px at 90% -10%, rgba(255,212,0,.08) 0%, rgba(255,212,0,0) 60%),
    linear-gradient(180deg, #0B0F1A 0%, #0B0F1A 100%);
  color:#fff;
  border:3px solid #fff;
  box-shadow:var(--shadow-1);
}
.bg-sunny-panel{
  background:linear-gradient(180deg,#FFF7CC 0%, #FFF1A6 100%);
  border:3px solid var(--cn-border);
  box-shadow:var(--shadow-1);
}

/* ---------- HERO — bandeau & panneau mobile ---------- */
#sec-hero .hero-bandeau{
  position:relative;
  display:flex; align-items:center; justify-content:flex-end;
  min-height:54px;
  border-bottom:0;            /* (demande) suppression de la bordure noire sous le bandeau */
  padding-block:10px;
}
#sec-hero .header-nav__list{
  display:flex; align-items:center; gap:clamp(12px,2.4vw,26px);
  list-style:none; margin:0; padding:0;
}
#sec-hero .header-nav__list li{ margin:0; padding:0 }

/* Bouton hamburger (masqué desktop) */
#sec-hero .hero-menu__toggle{
  display:none; align-items:center; justify-content:center;
  width:44px; height:44px;
  border:3px solid var(--cn-border); border-radius:8px;
  background:#fff; box-shadow:var(--shadow-1);
  margin-left:auto;
}
#sec-hero .hero-menu__toggle:focus-visible{ outline:4px solid var(--cn-accent-100); outline-offset:2px }
#sec-hero .hero-menu__toggle .icon-burger,
#sec-hero .hero-menu__toggle .icon-burger::before,
#sec-hero .hero-menu__toggle .icon-burger::after{
  content:""; display:block; width:20px; height:2px; background:var(--cn-border); position:relative;
}
#sec-hero .hero-menu__toggle .icon-burger::before{ position:absolute; left:0; top:-6px }
#sec-hero .hero-menu__toggle .icon-burger::after{ position:absolute; left:0; top:6px }

/* État par défaut (desktop) */
#sec-hero .hero-menu{ position:static }
#sec-hero .hero-menu__close{ display:none }

/* État ouvert (mobile) — panneau plein écran */
body.hero-nav-open{ overflow:hidden }
body.hero-nav-open #sec-hero .hero-menu{
  position:fixed; z-index:1100;
  top:0; left:0; right:0; bottom:0;
  background:var(--cn-surface);
  border-bottom:3px solid var(--cn-border);
  box-shadow:0 100vh 0 rgba(0,0,0,.16) inset, var(--shadow-1);
  padding:clamp(18px,5vw,32px);
}
body.hero-nav-open #sec-hero .hero-menu .header-nav__list{
  display:flex; flex-direction:column; align-items:stretch; gap:12px; padding-top:54px;
}
body.hero-nav-open #sec-hero .hero-menu .header-nav__list a{
  display:block; text-decoration:none;
  text-transform:uppercase; letter-spacing:.02em; font-weight:900;
  padding:14px 12px; border:3px solid var(--cn-border); border-radius:10px; box-shadow:var(--shadow-1);
}
body.hero-nav-open #sec-hero .hero-menu .header-nav__list a:hover{
  transform:translate(-2px,-2px); box-shadow:var(--shadow-2);
  background:var(--cn-accent); color:var(--cn-accent-ink);
}
body.hero-nav-open #sec-hero .hero-menu__close{
  display:inline-flex; position:absolute; top:16px; right:16px;
  width:44px; height:44px; align-items:center; justify-content:center;
  border:3px solid var(--cn-border); border-radius:8px; background:#fff; box-shadow:var(--shadow-1);
}
#sec-hero .icon-close{ position:relative; width:18px; height:18px; display:block }
#sec-hero .icon-close::before, #sec-hero .icon-close::after{
  content:""; position:absolute; left:0; top:50%; width:18px; height:2px; background:var(--cn-border);
}
#sec-hero .icon-close::before{ transform:translateY(-50%) rotate(45deg) }
#sec-hero .icon-close::after{ transform:translateY(-50%) rotate(-45deg) }

/* Points de rupture — menu */
@media (max-width:1024px){
  #sec-hero .hero-menu__toggle{ display:inline-flex }
  #sec-hero .header-nav__list{ display:none }
}
@media (max-width:1024px){
  body.hero-nav-open #sec-hero .hero-menu .header-nav__list{ display:flex }
}

/* ---------- FOOTER ---------- */
.site-footer{
  margin-top:var(--space-8);
  background:#0B0F1A;
  color:#fff;
  border-top:3px solid #fff;
  box-shadow:var(--shadow-1);
}
.site-footer a{ color:#fff }
.site-footer a:hover{ background:var(--cn-accent); color:var(--cn-accent-ink) }
.site-footer .footer-inner{
  max-width:var(--container-max); margin-inline:auto;
  padding-inline:var(--container-pad);
  padding-block:clamp(36px,6vw,56px);
}
.site-footer .footer-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(16px,2.8vw,26px);
  align-items:start;
}
@media (min-width:900px){
  .site-footer .footer-layout{ grid-template-columns:2fr 1fr 1fr }
}
.footer-logo{
  display:flex; align-items:center; gap:10px;
  font-weight:900; letter-spacing:.02em; text-transform:uppercase; text-decoration:none;
}
.footer-logo__mark{
  width:30px; height:30px;
  border:3px solid #fff; background:var(--cn-accent); border-radius:8px;
  box-shadow:2px 2px 0 #fff;
  display:inline-flex; align-items:center; justify-content:center;
  font-weight:900; color:var(--cn-accent-ink);
}
.footer-tagline{ margin:.35rem 0 0 0; color:#DDE1E8; font-size:.92rem }
.footer-menu, .footer-legal-menu{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:10px;
}
.footer-menu a, .footer-legal-menu a{
  display:block; text-decoration:none;
  text-transform:uppercase; letter-spacing:.02em; font-weight:900;
  padding:14px 12px;
  border:3px solid #fff; border-radius:10px;
  box-shadow:2px 2px 0 #fff;
}
.footer-menu a:hover, .footer-legal-menu a:hover{ transform:translate(-2px,-2px); box-shadow:var(--shadow-2) }
.footer-bottom{
  border-top:3px solid #fff;
  margin-top:clamp(18px,3.4vw,28px);
  padding-top:12px;
  display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap;
}
.footer-bottom .cn-small{ margin:0 }
.footer-bottom a{ text-decoration:underline; text-decoration-thickness:2px; text-underline-offset:3px }
.site-footer a:focus-visible{ outline:4px solid var(--cn-accent-100); outline-offset:2px }

/* ---------- Responsive paddings ---------- */
@media (max-width:1024px){
  .pad-lg{ padding-block:56px 46px }
  .pad-xl{ padding-block:70px 60px }
}
@media (max-width:782px){
  .pad-lg{ padding-block:48px 40px }
  .pad-xl{ padding-block:60px 50px }
  .cn-grid-2, .cn-kpis, .cn-steps{ grid-template-columns:1fr }
}

/* Section “Prestations fréquentes” : pas de padding-top interne (évite l’espace injustifié au-dessus du titre) */
#sec-prestations.pad-lg{ padding-block-start:0 }



/* ---------- Accessibilité ---------- */
@media (prefers-reduced-motion: reduce){
  *{ animation:none!important; transition:none!important }
}



/* Utilitaire d'invisibilité accessible — sans débordement horizontal */
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:0;              /* <- était -1px : cause du scroll */
  overflow:hidden;
  clip:rect(0,0,0,0);
  clip-path: inset(50%);            /* double sécurité moderne */
  white-space:nowrap;
  border:0;
  left:0; top:0;                    /* ancré dans le coin du .cn-form */
}






/* ---------- Formulaires (composant) ---------- */
.cn-form .cn-field{ margin-block: var(--space-2) var(--space-3) }

.cn-form label{
  display:block;
  font-weight:900; text-transform:uppercase; letter-spacing:.02em;
  margin-bottom:6px;
}

.cn-form input[type="text"],
.cn-form input[type="email"],
.cn-form input[type="tel"],
.cn-form input[type="url"],
.cn-form input[type="number"],
.cn-form input[type="file"],
.cn-form select,
.cn-form textarea{
  width:100%;
  background:var(--cn-surface);
  color:var(--cn-text);
  border:3px solid var(--cn-border);
  border-radius:var(--radius-1);
  padding:12px 14px;
  font:inherit; line-height:1.4;
  box-shadow:2px 2px 0 var(--cn-border);
}

.cn-form textarea{ min-height:160px; resize:vertical }

.cn-form input::placeholder,
.cn-form textarea::placeholder{ color:var(--cn-muted); opacity:1 }

.cn-form input:focus,
.cn-form select:focus,
.cn-form textarea:focus{
  outline:4px solid var(--cn-accent-100);
  outline-offset:2px;
}

.cn-form .cn-hint{ margin-top:6px; font-size:.92rem; color:var(--cn-muted) }
.cn-form .cn-legal{ margin-top:10px }
.cn-form .cn-submit{ margin-top: var(--space-3) }

.cn-notice{
  border:3px solid var(--cn-border);
  border-radius:var(--radius-1);
  padding:12px 14px;
  box-shadow:var(--shadow-1);
  margin:14px 0;
}
.cn-notice.cn-success{ background:var(--cn-success-50) }
.cn-notice.cn-error{ background:var(--cn-accent-50) }

/* Les champs et leurs wrappers doivent pouvoir rétrécir en grid */
.cn-form .cn-field { min-width: 0; }

.cn-form input,
.cn-form select,
.cn-form textarea {
  min-width: 0;   /* évite les min-content width bloquantes (file, select…) */
  max-width: 100%;
}

/* Le formulaire devient le conteneur de positionnement des éléments invisibles */
.cn-form{ position:relative }





/* ===========================
   PATCH — Gutenberg bridge
   =========================== */
/* Contexte : mapping entre l’HTML “pur” → Gutenberg, appliqué sur la base CSS.
   Réfs : accueil_epure_step2_perso.html :contentReference[oaicite:0]{index=0} •
          accueil_epure_step2_perso.wpblocks.html :contentReference[oaicite:1]{index=1} •
          accueil_perso.css :contentReference[oaicite:2]{index=2} */

/* 0) Ancrage global (le <main> devient un <div id="page-top"> avec Gutenberg) */
#page-top{ overflow-wrap:anywhere; word-wrap:break-word }

/* 1) Boutons Gutenberg = style .btn (équivalence .wp-element-button) */
.wp-element-button{
  display:inline-block;
  border-radius:var(--radius-1);
  padding:14px 20px;
  font-weight:900; text-transform:uppercase; letter-spacing:.03em;
  border:3px solid var(--cn-border);
  box-shadow:var(--shadow-1);
  transform:translate(0,0);
  transition:transform .1s ease, box-shadow .1s ease, background .15s ease, color .15s ease, border-color .15s ease;
  background:var(--cn-accent); color:var(--cn-accent-ink);
  text-decoration:none; /* neutralise le soulignement hérité des <a> */
}
.wp-element-button:hover{ transform:translate(-3px,-3px); box-shadow:var(--shadow-2) }
.wp-element-button:focus-visible{ outline:4px solid var(--cn-accent-100); outline-offset:2px }

/* Variante "outline" portée par le wrapper Gutenberg */
.wp-block-button.is-style-outline .wp-element-button{
  background:#fff; color:var(--cn-primary); border:3px solid var(--cn-border);
}
.wp-block-button.is-style-outline .wp-element-button:hover{
  background:var(--cn-primary); color:#fff;
}

/* 2) Groupes de boutons — compat avec wrappers et <p> auto‑insérés */
.wp-block-buttons.btn-row,
.wp-block-buttons.buttons{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center; justify-content:center;
}
.btn-row > p{
  display:flex; gap:12px; justify-content:center; align-items:center; flex-wrap:wrap;
  margin:0;
}
.btn-row .wp-block-button{ margin:0 } /* supprime les marges parasites des wrappers */

/* 3) Images utilitaires — compat .wp-block-image + arrondi conservé */
.wp-block-image.figure-rounded img{ border-radius:18px; display:block }

/* 4) KPI / Steps — Gutenberg injecte des <p> à l’intérieur des blocs */
.cn-kpi p,
.cn-step p{ margin:0 }

/* 5) Colonne droite (Engagements) — cibler la structure plutôt que la balise <aside> */
#sec-engagements .cols-70-30 aside > * + *,
#sec-engagements .cols-70-30 > :nth-child(2) > * + *{
  margin-top:var(--space-4);
}

/* 6) H1 du Héro — double <br> ajouté par Gutenberg */
#sec-hero .hero-content h1 br + br{ display:none }

/* 7) Séparateurs — prioriser l’utilitaire quand WP ajoute .wp-block-separator */
.wp-block-separator.separator-wide{
  height:3px; background:var(--cn-border); border:0; margin:22px 0; opacity:1;
}
/* idem pour le séparateur placé juste après la CTA */
.cta-accel + .wp-block-separator.separator-wide{ display:none }

/* 8) Footer — <p> auto‑inséré autour du logo */
.footer-brand > p{ margin:0 }
