/*
Theme Name:  CertiPro
Theme URI:   https://certi-pro.ca
Author:      Propulsion numérique
Version:     1.0.0
License:     Proprietary
Text Domain: certipro-theme
*/
/* ==========================================================================
   MAIN SCSS — CERTIPRO
   Point d’entrée unique
   ========================================================================== */
/* Abstracts (tokens + forwards) */
/* ==========================================================================
   DESIGN TOKENS — CERTIPRO
   Source unique de vérité visuelle
   ========================================================================== */
/* ----------------------------------
   Couleurs officielles CertiPro
---------------------------------- */
:root {
  --color-grisGunmetal: #424242;
  --color-rougeBrickember: #C60000;
  /* Titres H2 dans le corps des articles blog */
  --color-rougeArticleH2: #8f0000;
  --color-rougePurered: #F91C1C;
  --color-bleuFond: #2B3550;
  --color-bleuTexte: #253C3F;
  --color-platinum: #F2F3F4;
  --color-blanc: #FFFFFF;
  --color-alabaster: #FAFAFA;
  --color-slateGrey: #6B7280;
  --color-vitrxpert: #47AA42;
  /* Liens visités dans le corps (blog, etc.) : même famille que bleuTexte, un peu plus clair sans virer flashy */
  --color-lienVisite: #367a93;
}

/* ----------------------------------
   Alias fonctionnels (Sass)
---------------------------------- */
/* ----------------------------------
   Typographie — familles & graisses (Sass)
---------------------------------- */
/* Alias pratique utilisé par base/_typography.scss */
/* ----------------------------------
   Espacements
---------------------------------- */
/* ----------------------------------
   Breakpoints
---------------------------------- */
/* ==========================================================================
   MIXIN — LIEN AVEC SOULIGNEMENT ANIMÉ
   Adapté du pattern .site-header__phone
   Utilisation : @include m.link-underline-animated;
   ========================================================================== */
/* ==========================================================================
   MIXIN — TEXTURE GRAIN
   Superpose un bruit fractal subtil sur un fond coloré via ::before.
   Le wrapper de contenu direct doit avoir position: relative; z-index: 1.
   Utilisation : @include m.grain-texture(0.05);
   ========================================================================== */
/* ==========================================================================
   404 — Page introuvable
   ========================================================================== */
/* ========================================================================== */
/* MOBILE (défaut — hors media query)                                         */
/* ========================================================================== */
.cp-404 {
  /* Le layout principal est déjà donné par cp-section / cp-container.
     Ici: contenu + rythme. */
}

.cp-404__content {
  text-align: center;
  max-width: 680px;
  margin-inline: auto;
  padding-block: 48px;
}

.cp-404__lead {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 28px;
  margin-bottom: 16px;
  color: var(--color-bleuTexte);
}

.cp-404__text {
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 32px;
  color: var(--color-bleuTexte);
}

.cp-404__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.cp-404__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.22em;
  color: var(--color-bleuTexte);
  transition: color 220ms ease, transform 160ms ease;
}

.cp-404__link:hover {
  color: var(--color-rougeBrickember);
}

.cp-404__link:active {
  transform: translateY(1px);
}

.cp-404__link:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.45);
  outline-offset: 3px;
}

/* ========================================================================== */
/* MD (>= 768px)                                                              */
/* ========================================================================== */
@media (min-width: 768px) {
  .cp-404__actions {
    flex-direction: row;
    justify-content: center;
    gap: 48px;
  }
  .cp-404__lead {
    font-size: 20px;
    line-height: 30px;
  }
  .cp-404__text {
    font-size: 16px;
    line-height: 28px;
  }
}
/* ========================================================================== */
/* LG (>= 1024px)                                                             */
/* ========================================================================== */
@media (min-width: 1024px) {
  .cp-404__content {
    max-width: 720px;
  }
  .cp-404__lead {
    font-size: 22px;
    line-height: 32px;
  }
}
/* Base */
.cp-visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* ==========================================================================
   MAIN SCSS — CERTIPRO
   Point d’entrée unique
   ========================================================================== */
/* Abstracts (tokens + forwards) */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

body {
  margin: 0;
  background: var(--color-alabaster);
  color: var(--color-bleuTexte);
  overflow-x: clip;
}

/* ==========================================================================
   GLOBAL IMAGE BEHAVIOR
   Règles de sécurité universelles pour les images
   - Empêche les débordements dans flex/grid
   - Respecte le ratio naturel des images
   - Élimine les espaces inline indésirables
   Aucune intention de cadrage ou de design ici
   ========================================================================== */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ==========================================================
   FONTS — CERTIPRO
   ----------------------------------------------------------
   Choix techniques documentés :

   - Barlow Semi Condensed :
     → fontes STATIQUES WOFF2
     → utilisées pour titres / UI / branding
     → contrôle strict des graisses

   - Source Sans 3 :
     → fonte VARIABLE en TTF (self-host)
     → police variable-first (conversion WOFF2 instable)
     → usage limité aux graisses définies dans les tokens

   Règle :
   - Pas de CDN
   - Pas de @import
   - Self-host uniquement
   ========================================================== */
/* ==========================================================
   Barlow Semi Condensed — statique (WOFF2)
   ========================================================== */
@font-face {
  font-family: "Barlow Semi Condensed";
  src: url("/wp-content/themes/certipro-theme/assets/fonts/Barlow_Semi_Condensed/barlow-semi-condensed-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Barlow Semi Condensed";
  src: url("/wp-content/themes/certipro-theme/assets/fonts/Barlow_Semi_Condensed/barlow-semi-condensed-500.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Barlow Semi Condensed";
  src: url("/wp-content/themes/certipro-theme/assets/fonts/Barlow_Semi_Condensed/barlow-semi-condensed-600.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Barlow Semi Condensed";
  src: url("/wp-content/themes/certipro-theme/assets/fonts/Barlow_Semi_Condensed/barlow-semi-condensed-700.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
/* ==========================================================
   Source Sans 3 — variable (TTF)
   ========================================================== */
@font-face {
  font-family: "Source Sans 3";
  src: url("/wp-content/themes/certipro-theme/assets/fonts/Source_Sans_3/SourceSans3-VariableFont_wght.ttf") format("truetype");
  font-weight: 200 900;
  font-style: normal;
  font-display: swap;
}
/* =========================
   BASE TYPOGRAPHY
   ========================= */
/* Base document */
html {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  line-height: 1.6;
}

p {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  margin: 0 0 16px 0;
}

/* Listes */
ul,
ol {
  margin: 0 0 16px 0;
  padding-left: 24px;
}

li {
  margin-bottom: 8px;
}

a {
  text-underline-offset: 0.15em;
}

dd {
  margin-bottom: 8px;
}

.small-text {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 12px;
  line-height: 18px;
}
@media (min-width: 768px) and (max-width: 1023px) {
  .small-text {
    font-size: 14px;
    line-height: 21px;
  }
}

/* =========================
   HEADINGS
   ========================= */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  margin: 0;
}

h1 {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) {
  h1 {
    font-size: 22px;
    line-height: 33px;
  }
}
@media (min-width: 1024px) {
  h1 {
    font-weight: 600;
    font-size: 24px;
    line-height: 45px;
  }
}

.cp-h1-sub {
  display: block;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-variant-caps: all-small-caps;
  font-weight: 600;
  font-size: 14px;
  line-height: 21px;
}
@media (min-width: 768px) {
  .cp-h1-sub {
    font-size: 18px;
    line-height: 27px;
  }
}
@media (min-width: 1024px) {
  .cp-h1-sub {
    font-size: 24px;
    line-height: 45px;
  }
}

h2 {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  margin: 0 0 16px 0;
  letter-spacing: 0.05em;
}
@media (min-width: 768px) {
  h2 {
    font-size: 24px;
    line-height: 36px;
    letter-spacing: 0.05em;
  }
}
@media (min-width: 1024px) {
  h2 {
    font-size: 30px;
    line-height: 51px;
    letter-spacing: 0.05em;
  }
}
@media (min-width: 1280px) {
  h2 {
    font-size: 34px;
    line-height: 51px;
    letter-spacing: 0.05em;
  }
}

h3 {
  font-weight: 600;
  font-size: 18px;
  line-height: 27px;
  font-variant-caps: all-small-caps;
  margin: 0 0 12px 0;
}
@media (min-width: 768px) {
  h3 {
    font-size: 18px;
    line-height: 27px;
  }
}
@media (min-width: 1024px) {
  h3 {
    font-size: 22px;
    line-height: 33px;
  }
}

h4 {
  font-weight: 400;
  font-size: 14px;
  line-height: 21px;
  margin: 0 0 8px 0;
}
@media (min-width: 768px) {
  h4 {
    font-weight: 500;
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 1024px) {
  h4 {
    font-weight: 500;
    font-size: 20px;
    line-height: 30px;
  }
}

h5,
h6 {
  font-weight: 600;
  line-height: 1.2;
  margin: 0 0 8px 0;
}

.cp-breadcrumb {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 21px;
}
@media (min-width: 768px) {
  .cp-breadcrumb {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 1024px) {
  .cp-breadcrumb {
    font-weight: 500;
    font-size: 16px;
    line-height: 24px;
  }
}

/* =========================
   CTA BUTTON TYPO 
   (typo seulement — styles visuels ailleurs)
   ========================= */
.cp-btn {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  text-decoration: none;
}

.cp-btn--lg {
  font-weight: 600;
  font-size: 20px;
  line-height: 36px;
}

.cp-btn--md {
  font-weight: 700;
  font-size: 18px;
  line-height: 30px;
}

.cp-btn--sm {
  font-weight: 600;
  font-size: 16px;
  line-height: 22px;
}

/* Components */
/* ==========================================================================
   ICONS — CERTIPRO
   Sprint 1 — Étape 4
   Mobile-first, scaffold complet par formats
   ========================================================================== */
/* ======================================================================
   MOBILE — BASE
   ====================================================================== */
.icon {
  display: inline-block;
}
.icon svg {
  display: block;
  width: 100%;
  height: auto;
}

.icon--brand {
  width: 225px;
  height: auto;
  display: inline-block;
}

/* ======================================================================
   TABLETTE — MD (≥ 768px)
   ====================================================================== */
@media (min-width: 768px) {
  .icon--brand {
    width: 275px;
  }
}
/* ======================================================================
   DESKTOP — LG (≥ 1024px)
   ====================================================================== */
@media (min-width: 1024px) {
  .icon--brand {
    width: 300px;
  }
}
/* ======================================================================
   XL — (≥ 1280px)
   ====================================================================== */
@media (min-width: 1280px) {
  .icon--brand {
    width: 325px;
  }
}
/* ==========================================================================
   FULL-BLEED UTILITY
   Permet à un élément de dépasser la largeur du container
   - Utilisé pour images héros ou sections immersives
   - À activer volontairement (opt-in)
   - Aucun impact sur le reste du layout
   ========================================================================== */
.bleed {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
}

/* Desktop+ : bleed actif */
@media (min-width: 1024px) {
  .bleed {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow-x: clip; /* coupe les micro débordements */
  }
  /* Amélioration moderne (si supportée) */
  @supports (width: 100dvw) {
    .bleed {
      width: 100dvw;
      margin-left: calc(50% - 50dvw);
      margin-right: calc(50% - 50dvw);
    }
  }
}
.cp-breadcrumb {
  display: none;
}
@media (min-width: 768px) {
  .cp-breadcrumb {
    display: block;
  }
}

.cp-breadcrumb {
  display: none;
}
.cp-breadcrumb a {
  display: inline-block;
  color: var(--color-grisGunmetal);
}
.cp-breadcrumb a:visited {
  color: var(--color-slateGrey);
}
.cp-breadcrumb a {
  position: relative;
  text-decoration: none;
  transition: color 220ms ease;
}
.cp-breadcrumb a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: left center;
  transition: opacity 220ms ease, transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) {
  .cp-breadcrumb a:hover {
    color: var(--color-rougeBrickember);
  }
  .cp-breadcrumb a:hover::after {
    opacity: 0.95;
    transform: scaleX(1);
  }
}
.cp-breadcrumb a:active {
  color: var(--color-rougeBrickember);
}
.cp-breadcrumb a:focus-visible {
  color: var(--color-rougeBrickember);
  outline-offset: 3px;
}
.cp-breadcrumb a:focus-visible::after {
  opacity: 0.95;
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .cp-breadcrumb a {
    transition: none;
  }
  .cp-breadcrumb a::after {
    transition: none;
  }
}
@media (min-width: 768px) {
  .cp-breadcrumb {
    display: block;
  }
  .cp-breadcrumb ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
  }
  .cp-breadcrumb li {
    display: inline-flex;
    align-items: center;
  }
  .cp-breadcrumb li + li::before {
    content: "›";
    margin: 0 8px;
  }
}

/* =========================
   INTERACTIONS — LINKS & BUTTONS
   ========================= */
a:not(.cp-btn) {
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.15em;
}

a:focus-visible,
button:focus-visible:not(.cp-btn),
[role=button]:focus-visible:not(.cp-btn),
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.45);
  outline-offset: 3px;
}

/* Hover/active — liens (hors boutons) */
a:not(.cp-btn):hover {
  text-decoration-thickness: 0.12em;
}

/* Active “push” — liens (hors boutons) */
a:not(.cp-btn):active {
  transform: translateY(1px);
}

/* ==========================================================================
   CTA BUTTONS (structure d’états)
   NOTE: la typo est déjà dans _typography.scss
   ========================================================================== */
.cp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
  text-decoration: none;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  text-transform: uppercase;
  white-space: nowrap;
  border: 0;
  border-radius: 5px;
  padding-inline: 24px;
  /* TAILLE RESPONSIVE — source unique */
  width: 275px;
  height: 40px;
  font-size: 16px;
  font-weight: 600;
  line-height: 22px;
  /* Rendu + transitions (base) */
  -webkit-tap-highlight-color: transparent;
  transition: background-color 240ms ease, color 240ms ease, border-color 240ms ease, box-shadow 240ms ease, transform 160ms ease, filter 240ms ease;
  /* Pas d’ombre portée au repos (hover / active / focus gèrent le relief). */
  box-shadow: none;
}

/* Tablette */
@media (min-width: 768px) {
  .cp-btn {
    width: 275px;
    height: 40px;
    font-size: 18px;
    line-height: 30px;
  }
  .cp-btn--cta-blue {
    width: 300px;
  }
}
/* Desktop */
@media (min-width: 1024px) {
  .cp-btn {
    width: 300px;
    height: 45px;
    font-size: 20px;
    line-height: 30px;
  }
}
/* Hover / Active — (remplace brightness-only) */
.cp-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.12);
  filter: none;
}

.cp-btn:active {
  transform: translateY(0);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.14), 0 2px 6px rgba(0, 0, 0, 0.1);
}

/* Focus clavier : contour seul (pas d’ombre portée hors hover). */
.cp-btn:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.45);
  outline-offset: 3px;
  box-shadow: none;
}

/* Disabled */
.cp-btn:disabled,
.cp-btn[aria-disabled=true] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Accessibilité : moins d’animation si demandé */
@media (prefers-reduced-motion: reduce) {
  .cp-btn {
    transition: none;
  }
  .cp-btn:hover,
  .cp-btn:active {
    transform: none;
  }
}
/* =========================
   VARIANTES (3 TYPES + secondary)
   ========================= */
/* CTA “blanc / platine” — pas de contour net au repos (relief via .cp-inset). */
.cp-btn--cta-white {
  background: var(--color-alabaster);
  color: var(--color-bleuTexte);
  border: 1px solid transparent;
}

.cp-btn--cta-white:hover {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border-color: transparent;
}

.cp-btn--cta-white:active {
  background: rgba(43, 53, 80, 0.92);
}

/* CTA vert — pas de contour net au repos (profondeur via .cp-inset). */
.cp-btn--cta-green {
  background: var(--color-vitrxpert);
  color: var(--color-blanc);
  border: 1px solid transparent;
}

.cp-btn--cta-green:hover {
  background: var(--color-alabaster);
  color: var(--color-vitrxpert);
  border-color: transparent;
}

.cp-btn--cta-green:active {
  background: var(--color-platinum);
}

/* CTA bleu */
.cp-btn--cta-blue {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border: 1px solid transparent;
}

.cp-btn--cta-blue:hover {
  background: var(--color-alabaster);
  color: var(--color-bleuFond);
  border-color: rgba(43, 53, 80, 0.35);
}

.cp-btn--cta-blue:active {
  background: var(--color-platinum);
}

/* CTA Rouge foncé */
.cp-btn--cta-rougeFonce {
  background: var(--color-rougeBrickember);
  color: var(--color-blanc);
  border: 1px solid transparent;
}

.cp-btn--cta-rougeFonce:hover {
  background: var(--color-alabaster);
  color: var(--color-rougeBrickember);
  border-color: transparent;
}

.cp-btn--cta-rougeFonce:active {
  background: var(--color-platinum);
}

/* Secondaire gris */
.cp-btn--secondary {
  background: var(--color-grisGunmetal);
  color: var(--color-blanc);
  border: 1px solid transparent;
}

.cp-btn--secondary:hover {
  background: var(--color-platinum);
  color: var(--color-grisGunmetal);
  border-color: rgba(66, 66, 66, 0.35);
}

.cp-btn--secondary:active {
  background: rgba(242, 243, 244, 0.92);
}

/* ==========================================================================
   NAVIGATION — HAMBURGER PANEL (drawer + menu custom)
      ========================================================================== */
/* ========================================================================== */
/* MOBILE (défaut — hors media query)                                         */
/* ========================================================================== */
/* Panel menu: caché */
.site-header__panel[hidden] {
  display: none;
}

/* =========================
   HEADER PANEL — drawer
   ========================= */
.site-header__panel {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  justify-content: flex-start;
  padding: 0;
  /* overlay */
  background: rgba(0, 0, 0, 0.35);
  /* =========================
     HAMBURGER — Animations open/close (overlay)
     - hidden géré par HTML/JS
     - .is-open déclenche la transition
     ========================= */
  opacity: 0;
  visibility: hidden;
  transition: opacity 220ms ease, visibility 0s linear 220ms;
}

/* grain */
.site-header__panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.site-header__panel-inner {
  position: relative;
  z-index: 1;
  height: 100dvh;
  width: 100vw;
  max-width: 100vw; /* desktop drawer */
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  padding: 32px 24px;
  overflow: auto;
  /* =========================
     HAMBURGER — Animations open/close (drawer)
     ========================= */
  transform: translateX(16px);
  opacity: 0;
  transition: transform 260ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 200ms ease;
  will-change: transform, opacity;
}

/* État ouvert (classe ajoutée par JS) */
.site-header__panel.is-open {
  opacity: 1;
  visibility: visible;
  transition: opacity 220ms ease, visibility 0s;
}

/* Drawer visible */
.site-header__panel.is-open .site-header__panel-inner {
  transform: translateX(0);
  opacity: 1;
}

/* Close button (X) */
.site-header__close {
  position: absolute;
  top: 22px;
  right: 16px;
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  color: var(--color-blanc);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

/* Logo dans le panel (ta classe actuelle) */
.site-header__panel-logo svg {
  width: 165px;
  height: auto;
}

.site-header__panel-brand {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 24px;
}

.site-header__panel-phone {
  color: var(--color-blanc);
  text-decoration: none;
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 14px;
  margin-top: -15px;
}

.site-header__panel-cta {
  margin-top: auto;
  padding-top: 16px;
  padding-bottom: 32px;
  display: flex;
  justify-content: center;
}

/* =========================
   MENU CUSTOM — hamburger
   ========================= */
.cp-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cp-nav__item {
  margin: 0;
  padding: 0;
}

.cp-nav__link,
.cp-nav__group-btn,
.cp-nav__info-title {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-blanc);
  display: flex;
  align-items: center;
  width: 100%;
  padding: 4px 0 4px 0;
}

.cp-nav__group-btn {
  background: transparent;
  border: 0;
  cursor: pointer;
  gap: 14px;
}

/* =========================
   CP NAV — Signature states
   - Barre rouge à gauche (hover + actif)
   - Micro-slide (hover)
   - Focus visible cohérent
   ========================= */
/* Base interactifs (liens + bouton group) */
.cp-nav__link,
.cp-nav__sub-link,
.cp-nav__group-btn {
  position: relative;
  text-decoration: none;
  transition: transform 140ms ease;
}

.cp-nav__link,
.cp-nav__sub-link {
  padding-left: 16px;
}

.cp-nav__sub-link::before {
  top: 10px;
  bottom: 2px;
  left: -8px;
  content: "";
  position: absolute;
  bottom: 8px;
  width: 3px;
  background: var(--color-rougeBrickember);
  transform: scaleY(0);
  transform-origin: center;
  transition: transform 160ms ease;
}

.cp-nav__link::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 6px;
  bottom: 7px;
  width: 3px;
  background: var(--color-rougeBrickember);
  transform: scaleY(0);
  transform-origin: center;
  transition: transform 160ms ease;
}

.cp-nav__group-btn {
  padding-left: 16px;
}

.cp-nav__group-btn::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 6px;
  bottom: 7px;
  width: 3px;
  background: var(--color-rougeBrickember);
  transform: scaleY(0);
  transform-origin: center;
  transition: transform 160ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .cp-nav__group-btn:hover {
    transform: translateX(4px);
  }
  .cp-nav__group-btn:hover::before {
    transform: scaleY(1);
  }
}
.cp-nav__group-btn:focus-visible {
  transform: translateX(2px);
}

.cp-nav__group-btn:focus-visible::before {
  transform: scaleY(1);
}

.cp-nav__link:hover,
.cp-nav__sub-link:hover {
  transform: translateX(4px);
}

.cp-nav__link:hover::before,
.cp-nav__sub-link:hover::before {
  transform: scaleY(1);
}

.cp-nav__item.is-active > .cp-nav__link,
.cp-nav__sub-item.is-active > .cp-nav__sub-link {
  transform: translateX(2px);
}

.cp-nav__item.is-active > .cp-nav__link::before,
.cp-nav__sub-item.is-active > .cp-nav__sub-link::before {
  transform: scaleY(1);
}

.cp-nav__link:focus-visible,
.cp-nav__sub-link:focus-visible {
  transform: translateX(2px);
}

.cp-nav__link:focus-visible::before,
.cp-nav__sub-link:focus-visible::before {
  transform: scaleY(1);
}

.cp-nav__sub-link {
  padding-left: 22px;
}

.icon--nav-arrow {
  width: 24px;
  height: 24px;
  margin-top: 1px;
  color: white;
  display: block;
  transform: rotate(0deg);
  transition: transform 160ms ease;
}

.cp-nav__group-btn[aria-expanded=true] .icon--nav-arrow {
  transform: rotate(90deg);
}

.cp-nav__sub {
  list-style: none;
  margin: 8px 0 16px 0;
  padding-left: 24px;
}

.cp-nav__sub-link {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 21px;
  text-transform: none;
  color: var(--color-blanc);
  text-decoration: none;
  display: block;
  padding: 8px 0;
}

.cp-nav__link[aria-disabled=true] {
  opacity: 0.7;
  cursor: default;
  text-decoration: none;
}

.cp-nav__info {
  margin-top: 16px;
}

.cp-nav__info-body {
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.cp-nav__info-line {
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 21px;
  color: rgba(255, 255, 255, 0.95);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  .cp-nav__link,
  .cp-nav__sub-link,
  .cp-nav__group-btn,
  .cp-nav__link::before,
  .cp-nav__sub-link::before {
    transition: none;
  }
  .cp-nav__link:hover,
  .cp-nav__sub-link:hover,
  .cp-nav__item.is-active > .cp-nav__link,
  .cp-nav__sub-item.is-active > .cp-nav__sub-link,
  .cp-nav__link:focus-visible,
  .cp-nav__sub-link:focus-visible {
    transform: none;
  }
  .site-header__panel,
  .site-header__panel-inner {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}
@media (max-width: 767px) {
  .site-header__panel-inner {
    max-width: none;
    transform: translateY(10px);
  }
  .site-header__panel.is-open .site-header__panel-inner {
    transform: translateY(0);
  }
}
/* =========================================================
   HAMBURGER PANEL CTA — Signature underline
   ========================================================= */
.site-header__panel-cta .cp-btn {
  position: relative;
  overflow: hidden;
}

/* Underline signature (invisible au repos) */
.site-header__panel-cta .cp-btn::after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: -3px;
  height: 6px;
  background: linear-gradient(110deg, transparent 0%, rgba(198, 0, 0, 0.4) 30%, rgb(198, 0, 0) 50%, rgba(198, 0, 0, 0.4) 70%, transparent 100%);
  border-radius: 100px;
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 280ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 220ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .site-header__panel-cta .cp-btn:hover {
    background: var(--color-bleuFond);
    color: var(--color-blanc);
    border-color: transparent;
    box-shadow: none;
  }
  .site-header__panel-cta .cp-btn:hover::after {
    opacity: 1;
    transform: scaleX(1);
  }
}
.site-header__panel-cta .cp-btn:focus-visible {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border-color: transparent;
}

.site-header__panel-cta .cp-btn:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
}

/* ========================================================================== */
/* TABLETTE — @media (min-width: $bp-md)                                      */
/* (ici : ton band actuel md → lg-1 est conservé tel quel)                    */
/* ========================================================================== */
@media (min-width: 768px) and (max-width: 1023px) {
  .site-header__panel-logo svg {
    width: 220px;
    height: auto;
  }
  .site-header__panel {
    justify-content: flex-end;
    padding: 0;
  }
  .site-header__panel-inner {
    max-width: 560px;
    border-radius: 0;
    box-shadow: -20px 0 60px rgba(0, 0, 0, 0.35);
    padding: 32px 64px;
  }
  .site-header__panel.is-open .site-header__panel-inner {
    padding: 32px 24px;
  }
  .site-header__panel-phone {
    margin-top: -10px;
  }
}
/* ========================================================================== */
/* DESKTOP — @media (min-width: $bp-lg)                                       */
/* ========================================================================== */
@media (min-width: 1024px) {
  .site-header__panel {
    justify-content: flex-end;
    padding: 0;
  }
  .site-header__panel-inner {
    width: 480px;
    max-width: 480px;
    height: 100vh;
    border-radius: 0;
    padding-left: 35px;
    box-shadow: -25px 0 60px rgba(0, 0, 0, 0.35);
  }
  .site-header__panel-logo svg {
    width: 220px;
    height: auto;
  }
  .site-header__panel-brand {
    margin-bottom: 32px;
  }
}
.accueil-hero__image {
  display: block;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  line-height: 0;
}
.accueil-hero__image picture,
.accueil-hero__image .accueil-hero__img {
  display: block;
  width: 100%;
  max-width: none;
  height: auto;
  margin: 0;
  padding: 0;
  vertical-align: top;
}

.accueil-hero__actionsWrap {
  background: var(--color-platinum);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 150px;
  margin-bottom: 24px;
}

@media (min-width: 768px) {
  .accueil-hero__actionsWrap {
    height: 80px;
    margin-bottom: 48px;
  }
}
@media (min-width: 1024px) {
  .accueil-hero__actionsWrap {
    height: 92px;
    margin-bottom: 48px;
  }
}
.accueil-hero__actions {
  display: grid;
  gap: 24px;
  justify-items: center;
  width: 100%;
}

@media (min-width: 768px) and (max-width: 1023px) {
  .accueil-hero__actions {
    grid-template-columns: repeat(2, 300px);
    column-gap: 32px;
    row-gap: 0;
    justify-content: center;
    justify-items: center;
  }
}
@media (min-width: 1024px) {
  .accueil-hero__actions {
    grid-template-columns: repeat(2, 410px);
    column-gap: 32px;
    justify-content: center;
    justify-items: center;
  }
}
@media (min-width: 1280px) {
  .accueil-hero__actions {
    column-gap: 64px;
  }
}
.accueil-hero__cta.cp-btn {
  border-radius: 5px;
  padding: 0;
  min-height: auto;
  background: var(--color-blanc);
  color: var(--color-rougePurered);
  box-shadow: none;
  width: 275px;
  height: 40px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 22px;
  transition: background-color 240ms ease, color 240ms ease, box-shadow 240ms ease, transform 160ms ease, border-color 240ms ease;
}

@media (min-width: 768px) {
  .accueil-hero__cta.cp-btn {
    font-size: 18px;
    line-height: 30px;
    width: 300px;
  }
}
@media (min-width: 1024px) {
  .accueil-hero__cta.cp-btn {
    width: 410px;
    height: 50px;
    font-size: 20px;
    line-height: 36px;
  }
}
.accueil-hero__cta.cp-btn:hover {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.accueil-hero__cta.cp-btn:active {
  transform: translateY(0);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.18);
}

.accueil-hero__cta.cp-btn:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.6);
  outline-offset: 3px;
  box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.95), 0 12px 24px rgba(0, 0, 0, 0.18);
}

.accueil-hero__ctaLabel {
  margin: 0;
  color: inherit;
}

/* =========================================================
   ACCUEIL — SERVICES (tuiles)
   - BLEED géré par la classe .bleed dans le HTML
   - 2 tuiles cliquables : Mécanique / Pare-brise
   ========================================================= */
/* =========================
   BASE (mobile-first)
   ========================= */
.accueil-services {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: center;
  gap: 24px;
}

/* Tuile cliquable */
.accueil-services__tile {
  position: relative;
  display: block;
  text-decoration: none;
  border-radius: 10px;
  overflow: hidden;
  background: var(--color-platinum);
  min-width: 280px;
  max-width: 450px;
  aspect-ratio: 250/109;
  /* Overlay system (base) */
  -webkit-tap-highlight-color: transparent;
}

.accueil-services__media {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--color-platinum);
}

.accueil-services__media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.accueil-services__label {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 24px;
  min-height: 18px;
  background: rgba(66, 66, 66, 0.75);
  border-radius: 0 0 5px 5px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 14px;
  line-height: 21px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: white;
  transition: opacity 220ms ease, transform 220ms ease;
}

.accueil-services__tile:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.accueil-services__tile::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: rgba(43, 53, 80, 0.78);
  opacity: 0;
  transition: opacity 240ms ease;
}

.accueil-services__tile::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  white-space: pre-line;
  display: grid;
  place-items: center;
  padding: 32px;
  text-align: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.2;
  color: #fff;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 240ms ease, transform 240ms ease;
}

a.accueil-services__tile.accueil-services__tile--mecanique::after {
  content: "Voir tous les\aservices offerts";
}

a.accueil-services__tile.accueil-services__tile--parebrise::after {
  content: "Voir la page\a Certi-Pro/VitrXpert";
}

@media (hover: hover) and (pointer: fine) {
  .accueil-services__tile:hover::before {
    opacity: 1;
  }
  .accueil-services__tile:hover::after {
    opacity: 1;
    transform: translateY(0);
  }
  .accueil-services__tile:hover .accueil-services__label {
    opacity: 0.18;
    transform: translateY(2px);
  }
}
.accueil-services__tile:focus-visible::before {
  opacity: 1;
}

.accueil-services__tile:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}

.accueil-services__tile:focus-visible .accueil-services__label {
  opacity: 0.18;
  transform: translateY(2px);
}

/* Accessibilité : réduire animations */
@media (prefers-reduced-motion: reduce) {
  .accueil-services__tile::before,
  .accueil-services__tile::after,
  .accueil-services__label {
    transition: none;
  }
  .accueil-services__tile::after {
    transform: none;
  }
}
/* =========================
   BP-MD (tablette)
   ========================= */
@media (min-width: 768px) {
  .accueil-services {
    grid-template-columns: repeat(2, 350px);
    justify-content: center;
    justify-items: stretch;
    gap: 32px;
    padding-inline: 1%;
  }
  .accueil-services__tile {
    width: 100%;
    min-width: 0;
    max-width: none;
    aspect-ratio: 490/325;
  }
  .accueil-services__label {
    height: 29px;
    min-height: 29px;
    font-size: 18px;
    line-height: 27px;
  }
  .accueil-services__tile::after {
    font-size: 18px;
  }
}
/* =========================
   BP-LG (desktop)
   ========================= */
@media (min-width: 1024px) {
  .accueil-services {
    padding-inline: 40px;
    gap: 48px;
    grid-template-columns: repeat(2, 410px);
    justify-content: center;
  }
  .accueil-services__tile {
    width: 100%;
    max-width: 410px;
    aspect-ratio: 490/325;
  }
  .accueil-services__label {
    min-height: 44px;
    font-size: 26px;
    line-height: 39px;
  }
  .accueil-services__tile::after {
    font-size: 20px;
  }
}
/* =========================
   BP-XL (large desktop)
   ========================= */
@media (min-width: 1280px) {
  .accueil-services {
    padding-inline: 0;
    gap: 64px;
    grid-template-columns: repeat(2, 490px);
    justify-content: center;
  }
  .accueil-services__tile {
    width: 490px;
    gap: 64px;
    max-width: none;
    aspect-ratio: 490/325;
  }
  .accueil-services__tile::after {
    font-size: 22px;
  }
}
/* =========================================================
   ACCUEIL — ÉQUIPE
   Bloc image + texte
   Mobile-first + scaffold canon
   ========================================================= */
/* =========================
   BASE (mobile)
   ========================= */
.accueil-equipe__content {
  display: grid;
  gap: 24px;
}

/* Strictement mobile (< bp-md) */
@media (max-width: 767px) {
  .accueil-equipe__content {
    max-width: 450px;
    margin-inline: auto;
  }
}
.accueil-equipe__media {
  width: 100%;
  aspect-ratio: 320/212;
  border-radius: 5px;
  overflow: hidden;
  background: var(--color-platinum);
}

.accueil-equipe__picture {
  display: block;
  width: 100%;
  height: 100%;
}

.accueil-equipe__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* =========================
   BP-MD (tablette)
   ========================= */
@media (min-width: 768px) {
  .accueil-equipe__content {
    grid-template-columns: auto 1fr;
    align-items: center;
    justify-content: center;
    margin-left: 25px; /* à valider plus tard */
    gap: 32px;
  }
  .accueil-equipe__media {
    width: 277px;
    aspect-ratio: 277/208;
  }
}
/* =========================
   BP-LG (desktop)
   ========================= */
@media (min-width: 1024px) {
  .accueil-equipe__content {
    margin-left: 0;
    padding-left: 24px;
    padding-right: 16px;
    gap: 48px;
  }
  .accueil-equipe__media {
    width: 410px;
    aspect-ratio: 490/325; /* ratio conservé */
  }
  .accueil-equipe__text {
    padding-top: 10px;
  }
  .accueil-equipe__text p {
    line-height: 30px;
  }
  .accueil-equipe__subtitle {
    margin-bottom: 24px;
  }
  .accueil-equipe__text p + p {
    margin-top: 16px;
  }
}
/* =========================
   BP-XL (large desktop)
   ========================= */
@media (min-width: 1280px) {
  .accueil-equipe__content {
    padding-left: 32px;
    gap: 48px;
  }
  .accueil-equipe__media {
    width: 490px;
    aspect-ratio: 490/325;
  }
  .accueil-equipe__text {
    padding-top: 10px;
  }
}
/* =========================
   ACCUEIL — VÉHICULES DE COURTOISIE
   Mobile : slider
   Tablette+ : galerie (1 grande + 2 petites)
   ========================= */
/* Empêche le slider (largeurs fixes) d'élargir la page */
.accueil-courtoisie__content,
.accueil-courtoisie__media,
.accueil-courtoisie__text {
  min-width: 0;
}

/* Le slider doit être contenu dans son parent */
.accueil-courtoisie__slider {
  max-width: 100%;
}

.accueil-courtoisie__content {
  display: grid;
  gap: 24px;
}

/* =========================
   MEDIA — MOBILE (slider)
   Par défaut : slider visible, galerie cachée
   ========================= */
.accueil-courtoisie__slider {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 12px;
}

.accueil-courtoisie__slide {
  flex: 0 0 265px;
  width: 265px;
  scroll-snap-align: start;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 5px;
  overflow: hidden;
  appearance: none;
}

.accueil-courtoisie__slidePicture {
  display: block;
  width: 100%;
  height: 100%;
}

.accueil-courtoisie__slideImg {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.accueil-courtoisie__gallery {
  display: none;
}

/* Strictement mobile (< bp-md) */
@media (max-width: 767px) {
  .accueil-courtoisie__text {
    max-width: 450px;
    margin-inline: auto;
  }
}
/* =========================
   MEDIA — TABLETTE+ (galerie)
   Slider caché, galerie visible
   ========================= */
@media (min-width: 768px) {
  .accueil-courtoisie__slider {
    display: none;
  }
  .accueil-courtoisie__content {
    grid-template-columns: 277px minmax(0, 1fr);
    column-gap: 32px;
    align-items: start;
    gap: 32px;
    margin-left: 25px;
  }
  .accueil-courtoisie__gallery {
    display: grid;
    gap: 16px;
    grid-template-columns: auto auto;
    grid-template-rows: auto auto;
    justify-content: start;
  }
  .accueil-courtoisie__img {
    background: var(--color-platinum);
    border-radius: 5px;
    overflow: hidden;
  }
  .accueil-courtoisie__img--main {
    grid-column: 1/-1;
    width: 277px;
    aspect-ratio: 277/208;
    justify-self: start;
  }
  .accueil-courtoisie__img--small1,
  .accueil-courtoisie__img--small2 {
    width: 128px;
    aspect-ratio: 128/72;
    justify-self: start;
  }
  .accueil-courtoisie__thumb {
    padding: 0;
    border: 0;
    background: transparent;
    appearance: none;
    display: block;
    line-height: 0;
  }
  .accueil-courtoisie__img {
    background: transparent;
    padding: 0;
  }
  .accueil-courtoisie__thumbPicture,
  .accueil-courtoisie__thumbImg,
  .accueil-courtoisie__mediaImg {
    display: block;
    width: 100%;
    height: 100%;
  }
  /* =========================
     VIGNETTES — feedback (hover/active/focus) + état actif
     ========================= */
  .accueil-courtoisie__thumb {
    padding: 0;
    border: 0;
    background: transparent;
    appearance: none;
    display: block;
    line-height: 0;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    outline: none;
  }
  /* =========================
     VIGNETTES — effets sur l'image 
     ========================= */
  .accueil-courtoisie__thumbImg {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 180ms ease, filter 220ms ease, box-shadow 240ms ease;
  }
}
@media (min-width: 768px) and (hover: hover) and (pointer: fine) {
  .accueil-courtoisie__thumb:hover .accueil-courtoisie__thumbImg {
    transform: scale(1.04);
    filter: brightness(1.05) contrast(1.05);
    box-shadow: inset 0 0 0 2px rgba(43, 53, 80, 0.55);
  }
}
@media (min-width: 768px) {
  .accueil-courtoisie__thumb:active .accueil-courtoisie__thumbImg {
    transform: scale(1.02);
    filter: brightness(1.02);
    box-shadow: inset 0 0 0 2px rgba(43, 53, 80, 0.55);
  }
  .accueil-courtoisie__thumb:focus-visible .accueil-courtoisie__thumbImg {
    box-shadow: inset 0 0 0 3px rgba(43, 53, 80, 0.65);
  }
  .accueil-courtoisie__thumb.is-active .accueil-courtoisie__thumbImg {
    box-shadow: inset 0 0 0 3px rgba(43, 53, 80, 0.75);
    filter: brightness(1.06);
  }
}
@media (min-width: 768px) {
  /* Hover (desktop/pointer) : lift + ring + shadow feutrée */
}
@media (min-width: 768px) and (hover: hover) and (pointer: fine) {
  .accueil-courtoisie__thumb:hover {
    transform: translateY(-2px);
    outline-color: rgba(43, 53, 80, 0.55);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.7), 0 14px 26px rgba(0, 0, 0, 0.14), 0 3px 10px rgba(0, 0, 0, 0.1);
  }
}
@media (min-width: 768px) {
  /* Active : press */
  .accueil-courtoisie__thumb:active {
    transform: translateY(0);
    box-shadow: 0 0 0 4px rgba(242, 243, 244, 0.55), 0 8px 16px rgba(0, 0, 0, 0.14), 0 2px 8px rgba(0, 0, 0, 0.1);
  }
  .accueil-courtoisie__thumb:focus-visible {
    outline-color: rgba(43, 53, 80, 0.7);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.9), 0 14px 26px rgba(0, 0, 0, 0.14), 0 3px 10px rgba(0, 0, 0, 0.1);
  }
  .accueil-courtoisie__thumb.is-active {
    outline-color: rgba(43, 53, 80, 0.75);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.85), inset 0 0 0 1.25px rgba(43, 53, 80, 0.55);
  }
  .accueil-courtoisie__thumbImg,
  .accueil-courtoisie__mediaImg {
    object-fit: cover;
  }
}
/* =========================
   LG (1024 → 1279) 
     ========================= */
@media (min-width: 1024px) {
  .accueil-courtoisie__content {
    grid-template-columns: 410px minmax(0, 1fr);
    column-gap: 32px;
    gap: 48px;
    align-items: start;
    padding-left: 24px;
    margin-left: 0;
  }
  .accueil-courtoisie__img--main {
    width: 410px;
    aspect-ratio: 490/325;
  }
  .accueil-courtoisie__img--small1,
  .accueil-courtoisie__img--small2 {
    width: 197px;
    aspect-ratio: 235/132;
  }
}
/* =========================
   XL (≥ 1280)
   ========================= */
@media (min-width: 1280px) {
  .accueil-courtoisie__content {
    grid-template-columns: 490px minmax(0, 1fr);
    column-gap: 48px;
    gap: 48px;
    align-items: start;
    padding-left: 32px;
  }
  .accueil-courtoisie__img--main {
    width: 490px;
    aspect-ratio: 490/325;
  }
  .accueil-courtoisie__img--small1,
  .accueil-courtoisie__img--small2 {
    width: 235px;
    aspect-ratio: 235/132;
  }
}
@media (min-width: 1024px) {
  .accueil-courtoisie__text {
    max-width: 466px;
    padding-top: 30px;
  }
}
@media (min-width: 1024px) {
  .accueil-courtoisie__text p {
    max-width: 466px;
    line-height: 30px;
    margin-top: 25px;
  }
  .accueil-courtoisie__text h3 {
    margin-bottom: 24px;
  }
  .accueil-courtoisie__text p:first-of-type {
    margin-bottom: 24px;
  }
}
/* =========================
   CARROUSEL MOBILE — confinement + scrollbar cachée
   ========================= */
.accueil-courtoisie__media {
  padding: 0;
  margin: 0;
  background: none;
}

.accueil-courtoisie__slider {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.accueil-courtoisie__slider::-webkit-scrollbar {
  display: none;
}

/* =========================================
   COURTOISIE — FIX OVERFLOW HORIZONTAL MOBILE
   ========================================= */
.accueil-courtoisie__content,
.accueil-courtoisie__media {
  max-width: 100%;
  overflow-x: hidden;
}

.accueil-courtoisie__slider {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.accueil-courtoisie__slider::-webkit-scrollbar {
  display: none;
}

.accueil-courtoisie__slide {
  max-width: 100%;
}

.accueil-courtoisie__heroPicture {
  display: block;
  width: 100%;
  height: 100%;
}

.accueil-courtoisie__heroPicture img,
.accueil-courtoisie__heroPicture source {
  width: 100%;
  height: 100%;
}

/* =========================================================
   ACCUEIL — PROPRIÉTAIRES
   Bloc texte + photo + caption
   ========================================================= */
/* =========================
   BASE (mobile)
   ========================= */
.accueil-proprietaires__content {
  display: grid;
  gap: 24px;
}

.accueil-proprietaires__mediaWrap {
  display: grid;
  gap: 12px;
}

.accueil-proprietaires__media {
  width: 100%;
  aspect-ratio: 240/300;
  overflow: hidden;
  background: var(--color-platinum);
  border-radius: 5px;
}

.accueil-proprietaires__picture {
  display: block;
  width: 100%;
  height: 100%;
}

.accueil-proprietaires__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 5px;
}

.accueil-proprietaires__caption {
  margin-top: 12px;
  margin-inline: auto;
  text-align: center;
}

/* =========================
   MOBILE-ONLY 
   ========================= */
@media (max-width: 767px) {
  .accueil-proprietaires__content {
    max-width: 450px;
    margin-inline: auto;
  }
  .accueil-proprietaires__mediaWrap {
    max-width: 450px;
    margin-inline: auto;
  }
}
/* =========================
   BP-MD (tablette)
   ========================= */
@media (min-width: 768px) {
  .accueil-proprietaires__content {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .accueil-proprietaires__content {
    grid-template-columns: minmax(0, 441px) 223px;
    column-gap: 32px;
    justify-content: center;
    align-items: start;
  }
  .accueil-proprietaires__mediaWrap {
    margin-top: 65px;
  }
  .accueil-proprietaires__text {
    margin-top: 60px;
  }
  .accueil-proprietaires__media {
    width: 223px;
    aspect-ratio: 223/279;
    justify-self: start;
  }
}
/* =========================
   BP-LG (desktop)
   ========================= */
@media (min-width: 1024px) {
  .accueil-proprietaires__content {
    grid-template-columns: minmax(0, 490px) 335px;
    column-gap: 48px;
    justify-content: center;
    align-items: start;
  }
  .accueil-proprietaires__media {
    width: 335px;
    aspect-ratio: 335/419;
    justify-self: start;
  }
  .accueil-proprietaires__text p {
    line-height: 30px;
  }
  .accueil-proprietaires__text h3 {
    margin-bottom: 36px;
  }
  .accueil-proprietaires__text p + p {
    margin-top: 16px;
  }
}
.accueil-avis {
  --avis-card-w: 255px;
  --avis-gap: 24px;
  position: relative;
}

/* Évite le flash « 4 lignes » (défaut CSS) puis recalcul JS. */
.accueil-avis:not(.is-avis-ready) .accueil-avis__text {
  visibility: hidden;
}

.accueil-avis.is-avis-ready .accueil-avis__text {
  visibility: visible;
}

/* =========================================================
   RETOUR HAUT DE PAGE — position verticale validée (section avis)
   - Garder les margin-top de .ctnBackToTop pour l’accueil hors .cp-backtotop-region.
   - Après médias sociaux : voir .cp-backtotop-region ci-dessous.
   ========================================================= */
.ctnBackToTop {
  display: flex;
  justify-content: flex-end;
  margin-top: 24px;
  padding: 24px 12px 24px 0;
}

/* Après médias sociaux : peu d’air au-dessus du lien (l’avis accueil n’utilise pas ce wrapper). */
.cp-backtotop-region {
  padding-top: 0;
}

.cp-backtotop-region .ctnBackToTop {
  margin-top: 0;
  padding: 0 12px 24px 0;
}
@media (min-width: 768px) {
  .cp-backtotop-region .ctnBackToTop {
    margin-top: 0;
    padding: 0 12px 32px 0;
  }
}
@media (min-width: 1024px) {
  .cp-backtotop-region .ctnBackToTop {
    margin-top: 0;
    padding: 0 48px 32px 0;
  }
}

/* Rapproche le lien de la fin de la bande médias (marge XL du dernier bloc). */
.cp-medias-sociaux + .cp-backtotop-region {
  margin-top: -24px;
  background: var(--color-platinum);
  max-width: none;
}

.accueil-avis__backtotop {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--color-bleuTexte);
  position: relative;
  /* ✅ neutralise les transforms globaux des liens */
  transform: none;
  transition: color 220ms ease, transform 160ms ease;
}

/* Mouvement vertical unique (hover/active) */
@media (hover: hover) and (pointer: fine) {
  .accueil-avis__backtotop:hover {
    transform: translateY(-2px);
  }
}
.accueil-avis__backtotop:active {
  transform: translateY(0);
}

.accueil-avis__backtotopIcon {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  transition: background-color 220ms ease, border-color 220ms ease, box-shadow 260ms ease;
}

.accueil-avis__backtotopIcon svg {
  display: block;
}

.accueil-avis__backtotopIcon svg :is(path, line, polyline, polygon, circle, rect, ellipse) {
  vector-effect: non-scaling-stroke;
  stroke-width: 2; /* repos */
}

@media (hover: hover) and (pointer: fine) {
  .accueil-avis__backtotop:hover .accueil-avis__backtotopIcon {
    background: transparent;
    border-color: var(--btt-ring);
    box-shadow: inset 0 0 0 1.25px var(--btt-ring), 0 0 0 6px rgba(43, 53, 80, 0.08), 0 14px 26px rgba(0, 0, 0, 0.14), 0 3px 10px rgba(0, 0, 0, 0.1);
  }
  .accueil-avis__backtotop:hover .accueil-avis__backtotopIcon svg :is(path, line, polyline, polygon, circle, rect, ellipse) {
    stroke-width: 2.75;
  }
}
.accueil-avis__backtotop:active .accueil-avis__backtotopIcon {
  box-shadow: inset 0 0 0 1.25px var(--btt-ring), 0 0 0 4px rgba(43, 53, 80, 0.06), 0 8px 16px rgba(0, 0, 0, 0.14), 0 2px 8px rgba(0, 0, 0, 0.1);
}

.accueil-avis__backtotop:focus-visible .accueil-avis__backtotopIcon {
  background: transparent;
  border-color: rgba(43, 53, 80, 0.7);
  box-shadow: inset 0 0 0 1.25px rgba(43, 53, 80, 0.7), 0 0 0 6px rgba(43, 53, 80, 0.1), 0 14px 26px rgba(0, 0, 0, 0.14), 0 3px 10px rgba(0, 0, 0, 0.1);
}

.accueil-avis__backtotop:focus-visible .accueil-avis__backtotopIcon svg :is(path, line, polyline, polygon, circle, rect, ellipse) {
  stroke-width: 2.75;
}

.accueil-avis__backtotopText {
  font-size: 14px;
  line-height: 1.2;
  display: inline-block;
  font-weight: 400;
  transform-origin: center top;
  transition: transform 160ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .accueil-avis__backtotop:hover .accueil-avis__backtotopText {
    transform: scale(1.06);
  }
}
/* =========================================================
   SECTION + TRACK (mobile swipe)
   ========================================================= */
.cp-section__avis {
  background-color: var(--color-platinum);
}

.accueil-avis__viewport {
  overflow: hidden;
}

.accueil-avis__track {
  display: flex;
  gap: var(--avis-gap);
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  touch-action: pan-x;
  padding-bottom: 12px;
  scrollbar-width: none;
}

.accueil-avis__track::-webkit-scrollbar {
  display: none;
}

.accueil-avis__card {
  width: 255px;
  height: 480px;
  scroll-snap-align: start;
  background: var(--color-alabaster);
  border-radius: 12px;
  padding: 24px;
  flex: 0 0 255px;
  display: flex;
  flex-direction: column;
}

.accueil-avis__stars {
  margin: 12px 0 24px 0;
  display: flex;
  justify-content: flex-end;
}

.accueil-avis__starsIcon {
  height: 20px;
  width: auto;
  display: block;
}

.accueil-avis__who {
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.accueil-avis__initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  width: 45px;
  height: 45px;
  border-radius: 999px;
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
}

.accueil-avis__name {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
}

.accueil-avis__title {
  margin: 0 0 16px;
  padding-top: 12px;
  font-variant-caps: normal;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  line-height: 1.3;
  font-size: 18px;
}

.accueil-avis__text {
  --avis-text-line-h: 30px;
  margin: 0;
  padding-top: 8px;
  font-size: 15px;
  line-height: var(--avis-text-line-h);
  margin-bottom: auto;
  flex-shrink: 0;
  /* + padding-top : sinon 3 lignes × 30px = 90px mais seulement ~2 lignes visibles. */
  min-height: calc(var(--avis-text-lines, 5) * var(--avis-text-line-h) + 8px);
  max-height: calc(var(--avis-text-lines, 5) * var(--avis-text-line-h) + 8px);
  overflow: hidden;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.accueil-avis__readmore {
  margin-top: -16px;
  margin-left: auto;
  margin-right: 8px;
  width: 100px;
  font-size: 11px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 25px;
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border: 1px solid transparent;
  border-radius: 10px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition: background-color 220ms ease, color 220ms ease, border-color 220ms ease, box-shadow 220ms ease, transform 160ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .accueil-avis__readmore:hover {
    background: var(--color-alabaster);
    color: var(--color-bleuFond);
    border-color: rgba(43, 53, 80, 0.35);
    transform: translateY(-1px);
    box-shadow: 0 10px 18px rgba(0, 0, 0, 0.1), 0 2px 0 rgba(0, 0, 0, 0.06);
  }
}
/* =========================================================
   Controls (flèches + dots) + Modal
   ========================================================= */
/* CTA Google (même markup que « Nous joindre ») — largeur alignée sur les 3 cartes desktop */
.accueil-avis__googleWrap {
  box-sizing: border-box;
  margin-top: 32px;
  margin-inline: auto;
  width: min(100%, 3 * var(--avis-card-w) + 2 * var(--avis-gap));
}
.accueil-avis__googleWrap .cp-contact__googleCard {
  margin-bottom: 0;
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.accueil-avis__controls {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 24px;
}

.accueil-avis__arrow {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-bleuTexte);
  background: transparent;
  cursor: pointer;
}

.accueil-avis__arrow-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.accueil-avis__arrow-icon svg {
  width: 20px;
  height: 20px;
  display: block;
}

.accueil-avis__arrow-icon-left svg {
  transform: rotate(180deg);
}

.accueil-avis__dots {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.accueil-avis__dot {
  width: 26px;
  height: 26px;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.accueil-avis__dot-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.accueil-avis__dot-icon svg {
  width: 14px;
  height: 14px;
  display: block;
}

.accueil-avis__dot-icon--filled {
  display: none;
}

.accueil-avis__dot.is-active .accueil-avis__dot-icon--outline {
  display: none;
}

.accueil-avis__dot.is-active .accueil-avis__dot-icon--filled {
  display: inline-flex;
}

.accueil-avis-modal[hidden] {
  display: none;
}

.accueil-avis-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.accueil-avis-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}

.accueil-avis-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(720px, 100% - 48px);
  max-height: 80vh;
  overflow: auto;
  background: var(--color-platinum);
  border-radius: 5px;
  padding: 32px;
}

.accueil-avis-modal__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}

.accueil-avis-modal__closeIcon {
  width: 20px;
  height: 20px;
  display: block;
}

.accueil-avis-modal__title {
  margin: 0 0 16px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
}

.accueil-avis-modal__body {
  white-space: pre-wrap;
  line-height: 1.6;
}

/* =========================================================
   TABLETTE
   ========================================================= */
@media (min-width: 768px) {
  .accueil-avis__track {
    gap: 32px;
  }
  .ctnBackToTop {
    display: flex;
    justify-content: flex-end;
    margin-top: 32px;
    padding: 24px 12px 32px 0;
  }
  .accueil-avis__bleed {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: 24px;
    padding-right: 24px;
  }
  .accueil-avis__viewport {
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }
  .accueil-avis__track {
    overflow: visible;
    scroll-snap-type: none;
  }
  .accueil-avis__viewport::-webkit-scrollbar {
    display: none;
  }
}
/* =========================================================
   DESKTOP
   ========================================================= */
@media (min-width: 1024px) {
  .accueil-avis__viewport {
    overflow: hidden;
    max-width: calc(3 * var(--avis-card-w) + 2 * var(--avis-gap));
    margin-inline: auto;
  }
  .ctnBackToTop {
    display: flex;
    justify-content: flex-end;
    margin-top: 26px;
    padding: 0 48px 32px 0;
  }
  .accueil-avis__track {
    overflow-x: auto;
    scroll-snap-type: none;
    -webkit-overflow-scrolling: auto;
    padding-bottom: 0;
    scrollbar-width: none;
    gap: 24px;
  }
  .accueil-avis__card {
    width: var(--avis-card-w);
    flex: 0 0 var(--avis-card-w);
  }
  .accueil-avis__spacer {
    flex: 0 0 auto;
    pointer-events: none;
  }
  .accueil-avis__googleWrap {
    margin-top: 48px;
  }
  .accueil-avis__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin-top: 24px;
  }
  .accueil-avis__arrow,
  .accueil-avis__dot {
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    transition: transform 0.12s ease-out, opacity 0.12s ease-out;
  }
  .accueil-avis__arrow,
  .accueil-avis__dot {
    position: relative;
    transition: background-color 220ms ease, box-shadow 260ms ease, transform 180ms ease, opacity 160ms ease;
  }
}
@media (min-width: 1024px) and (hover: hover) and (pointer: fine) {
  .accueil-avis__arrow:hover,
  .accueil-avis__dot:hover {
    background: rgba(242, 243, 244, 0.92);
    transform: translateY(-1px);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.7), 0 14px 26px rgba(0, 0, 0, 0.16), 0 3px 10px rgba(0, 0, 0, 0.1);
    opacity: 1;
  }
}
@media (min-width: 1024px) {
  .accueil-avis__arrow:active,
  .accueil-avis__dot:active {
    transform: translateY(0);
    box-shadow: 0 0 0 4px rgba(242, 243, 244, 0.55), 0 8px 16px rgba(0, 0, 0, 0.16), 0 2px 8px rgba(0, 0, 0, 0.1);
  }
  .accueil-avis__arrow:focus-visible,
  .accueil-avis__dot:focus-visible {
    outline: 2px solid rgba(43, 53, 80, 0.6);
    outline-offset: 3px;
    background: rgba(242, 243, 244, 0.95);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.85), 0 14px 26px rgba(0, 0, 0, 0.16), 0 3px 10px rgba(0, 0, 0, 0.1);
  }
  .accueil-avis__arrow-icon svg {
    width: 30px;
    height: 30px;
    display: block;
  }
  .accueil-avis__arrow-icon svg path {
    fill: var(--color-grisGunmetal);
    opacity: 0.8;
  }
  .accueil-avis__arrow-icon-left svg {
    transform: rotate(180deg);
  }
  .accueil-avis__dots {
    display: flex;
    gap: 32px;
  }
  .accueil-avis__dot-icon {
    width: 24px;
    height: 24px;
    display: inline-block;
  }
  .accueil-avis__dot-icon svg {
    width: 100%;
    height: 100%;
    display: block;
  }
  .accueil-avis__dot-icon--outline svg :is(path, circle, rect, polygon, line, polyline, ellipse) {
    fill: var(--color-grisGunmetal);
    stroke: var(--color-grisGunmetal);
    opacity: 0.8;
  }
  .accueil-avis__dot-icon--filled svg :is(path, circle, rect, polygon, line, polyline, ellipse) {
    fill: var(--color-grisGunmetal);
    stroke: var(--color-grisGunmetal);
    opacity: 0.8;
  }
  .accueil-avis__dot-icon--filled svg {
    overflow: visible;
  }
  .accueil-avis__dot-icon--filled {
    display: none;
  }
  .accueil-avis__dot.is-active .accueil-avis__dot-icon--outline {
    display: none;
  }
  .accueil-avis__dot.is-active .accueil-avis__dot-icon--filled {
    display: inline-block;
  }
}
@media (min-width: 1280px) {
  .accueil-avis__viewport {
    max-width: calc(3 * var(--avis-card-w) + 2 * var(--avis-gap));
  }
}
/* =========================================================
   PAGE PNEUS — page principale (mobile-first)
   ========================================================= */
/* Annule le margin-bottom du hero-top sur cette page seulement */
.cp-page-pneus .cp-hero-top {
  margin-bottom: 0;
}

.cp-pneus-hero {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 0;
}

/* Même principe que pare-brise : ratio sur <picture>, img en cover plein cadre */
.cp-pneus-hero__media {
  overflow: clip;
  line-height: 0;
}
.cp-pneus-hero__media picture {
  display: block;
  width: 100%;
  aspect-ratio: 640/178;
}
.cp-pneus-hero__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom;
}

/* =========================
   SECTION NOS SERVICES
   ========================= */
.cp-pneus-services {
  background: var(--color-platinum);
  padding-block: 48px;
  border-top: 3px solid var(--color-rougeBrickember);
  margin-top: 0;
}

.cp-pneus-services__title {
  text-align: center;
  margin: 0 0 24px;
}

.cp-pneus-services__title::after {
  content: "";
  display: block;
  height: 3px;
  width: 52px;
  background: linear-gradient(90deg, transparent, var(--color-rougeBrickember) 30%, var(--color-rougeBrickember) 70%, transparent);
  margin: 10px auto 0;
}

.cp-pneus-services__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

/* =========================
   CARTE
   ========================= */
.cp-pneus-service {
  display: block;
  text-align: center;
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1), 0 0 0 1px rgba(43, 53, 80, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  padding: 0 0 14px;
}

.cp-pneus-service__media {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.cp-pneus-service__media picture,
.cp-pneus-service__media img {
  display: block;
  width: 100%;
  height: 100%;
}
.cp-pneus-service__media img {
  object-fit: cover;
}

.cp-pneus-service__title {
  margin: 10px 0 4px;
  padding: 0 10px;
  color: var(--color-bleuTexte);
  letter-spacing: 0.05em;
}

.cp-pneus-service__text {
  margin: 0;
  padding: 0 10px;
  font-size: 13px;
  text-transform: uppercase;
  color: #6B7280;
  line-height: 1.5;
}

/* =========================
   CTA
   ========================= */
.cp-pneus-services__cta {
  margin-top: 32px;
  margin-bottom: 24px;
  display: grid;
  justify-items: center;
  gap: 16px;
}

.cp-pneus-services__note {
  text-align: center;
  margin: 0;
  font-size: 14px;
  line-height: 24px;
}

/* =========================================================
   TABLETTE (bp-md)
   ========================================================= */
@media (min-width: 768px) {
  .cp-pneus-hero__media picture {
    aspect-ratio: 1488/331;
  }
  .cp-pneus-services__title::after {
    width: 80px;
    margin-top: 12px;
  }
  .cp-pneus-services__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    padding-inline: 2%;
  }
  .cp-pneus-service__media {
    aspect-ratio: 260/183;
  }
  .cp-pneus-service__text {
    font-size: 12px;
  }
  .cp-pneus-services__cta {
    margin-bottom: 32px;
  }
}
/* =========================================================
   LARGE (bp-lg)
   ========================================================= */
@media (min-width: 1024px) {
  .cp-pneus-hero__media picture {
    aspect-ratio: 1440/320;
  }
  .cp-pneus-services__title::after {
    width: 120px;
    margin-top: 14px;
  }
  .cp-pneus-service__title {
    font-weight: 600;
  }
  .cp-pneus-services__cta {
    margin-bottom: 48px;
  }
}
/* ==========================================================================
   BLOG ARTICLE — SINGLE POST
   Pattern Problème
   ========================================================================== */
.cp-blog-single {
  padding-top: 24px;
  padding-bottom: 48px;
}

.cp-blog-single__title {
  margin: 0 0 16px;
  color: var(--color-bleuTexte);
  font-size: 20px;
  line-height: 30px;
}

.cp-blog-single__header {
  margin-bottom: 12px;
}

.cp-blog-single__header-tools {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
}

@media (min-width: 768px) {
  .cp-blog-single__header-tools {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
  }
}
.cp-blog-single__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
  color: var(--color-bleuFond);
  text-decoration: none;
  white-space: nowrap;
}

.cp-blog-single__back-arr {
  font-size: 16px;
  line-height: 1;
}

@media (hover: hover) and (pointer: fine) {
  .cp-blog-single__back:hover {
    text-decoration: underline;
    text-underline-offset: 2px;
  }
}
@media (min-width: 768px) {
  .cp-blog-single__back {
    display: none;
  }
}
/* Fil d’Ariane : masqué sous md (comme le reste du site) — retour mobile via .cp-blog-single__back */
.cp-blog-single__breadcrumb-nav.cp-breadcrumb {
  display: none;
  max-width: 100%;
}

@media (min-width: 768px) {
  .cp-blog-single__breadcrumb-nav.cp-breadcrumb {
    display: block;
  }
}
.cp-blog-single__breadcrumb-nav .cp-breadcrumb__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.cp-blog-single__breadcrumb-nav .cp-breadcrumb__item {
  display: inline-flex;
  align-items: center;
}

.cp-blog-single__breadcrumb-nav .cp-breadcrumb__item + .cp-breadcrumb__item::before {
  content: "›";
  margin: 0 8px;
}

.cp-blog-single__breadcrumb-nav .cp-breadcrumb__link {
  color: var(--color-grisGunmetal);
  text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
  .cp-blog-single__breadcrumb-nav .cp-breadcrumb__link:hover {
    text-decoration: underline;
    text-underline-offset: 2px;
  }
}
.cp-blog-single__breadcrumb-current {
  font-weight: 500;
  color: var(--color-bleuTexte);
}

/* Sous le titre : dates, temps de lecture, rubrique / repère (sans encadré) */
.cp-blog-single__head-cluster {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 0;
  margin-bottom: 16px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

@media (min-width: 768px) {
  .cp-blog-single__head-cluster {
    margin-bottom: 24px;
  }
  .cp-blog-single__title {
    margin-bottom: 24px;
  }
}
.cp-blog-single__cluster-top {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-end;
  gap: 10px;
  min-width: 0;
}

.cp-blog-single__cluster-dates {
  display: flex;
  flex-flow: row wrap;
  align-items: flex-end;
  gap: 8px 18px;
  flex: 1 1 auto;
  min-width: 0;
}

.cp-blog-single__cluster-slot {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  min-width: 0;
}

.cp-blog-single__cluster-kicker {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 10px;
  line-height: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-rougeBrickember);
}

.cp-blog-single__cluster-kicker--muted {
  color: var(--color-grisGunmetal);
  font-weight: 500;
  letter-spacing: 0.06em;
}

.cp-blog-single__cluster-date {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
  color: var(--color-bleuTexte);
  overflow-wrap: anywhere;
}

.cp-blog-single__cluster-date--muted {
  font-size: 13px;
  line-height: 18px;
  font-weight: 500;
  color: var(--color-grisGunmetal);
  overflow-wrap: anywhere;
}

.cp-blog-single__cluster-bottom {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.cp-blog-single__cluster-chips-label {
  margin: 0 0 6px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-grisGunmetal);
}

.cp-blog-single__tags-row.cp-tutos-card__tags {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 10px;
  row-gap: 8px;
  min-height: 0;
}

.cp-blog-single__tags-join {
  flex-shrink: 0;
  padding: 0 4px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 17px;
  font-weight: 700;
  line-height: 1;
  color: var(--color-bleuFond);
}

.cp-blog-single__tags-row .cp-blog-single__pill.cp-tutos-card__tag {
  position: relative;
  padding: 4px 10px 4px 26px;
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
  color: var(--color-bleuTexte);
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

.cp-blog-single__tags-row .cp-blog-single__pill::before {
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  border-width: 2px;
}

a.cp-blog-single__chip.cp-tutos-card__tag {
  cursor: pointer;
  text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
  a.cp-blog-single__pill.cp-tutos-card__tag:hover {
    color: var(--color-bleuFond);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    text-decoration-color: rgba(var(--color-bleuFond), 0.45);
    background: transparent;
    text-decoration-skip-ink: auto;
  }
}
/* Rapproche le héros du bloc d’intro (héros = premier enfant du .cp-container du pattern) */
.cp-blog-single__content > .cp-blog-article .cp-container > .cp-blog-article__hero:first-child {
  margin-top: 0;
}

.cp-blog-single__reading-pill {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 2px;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.cp-blog-single__cluster-top .cp-blog-single__reading-pill--bar {
  margin-left: auto;
  align-self: flex-end;
}

.cp-blog-single__reading-pill-label {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 10px;
  line-height: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-grisGunmetal);
}

.cp-blog-single__reading-pill--bar .cp-blog-single__reading-pill-label {
  font-size: 9px;
  letter-spacing: 0.08em;
}

.cp-blog-single__reading-pill-value {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.35;
  font-weight: 600;
  color: var(--color-bleuTexte);
  letter-spacing: normal;
}

.cp-blog-single__reading-pill--bar .cp-blog-single__reading-pill-value {
  font-size: 15px;
  line-height: 1.35;
}

@media (min-width: 768px) {
  .cp-blog-single__reading-pill--bar .cp-blog-single__reading-pill-value {
    font-size: 16px;
  }
}
.cp-blog-single__footer-wrap {
  margin-top: 48px;
}

.cp-blog-single__end {
  padding: 32px 0 0;
  border-top: 1px solid rgba(var(--color-bleuTexte), 0.12);
}

.cp-blog-single__end-lead {
  margin: 0 0 24px;
  max-width: 56ch;
  color: var(--color-bleuTexte);
  font-size: 16px;
  line-height: 24px;
}

.cp-blog-single__end-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 16px;
}

/* Même gabarit que le CTA « Prendre rendez-vous » (cp-btn--cta-blue) ; typo −2 px vs .cp-btn--lg. */
.cp-blog-single__end-btn-all.cp-btn.cp-btn--cta-white {
  font-size: 18px;
  line-height: 32px;
}

@media (min-width: 768px) {
  .cp-blog-single__end-btn-all.cp-btn.cp-btn--cta-white {
    width: 300px;
  }
}
@media (min-width: 768px) {
  .cp-blog-single__end-actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 24px;
  }
}
.cp-blog-single__end-link-topic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 12px 16px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 15px;
  line-height: 22px;
  color: var(--color-bleuFond);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 2px;
  text-decoration-color: rgba(37, 60, 63, 0.5);
  text-align: center;
  transition: color 200ms ease, text-decoration-color 200ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .cp-blog-single__end-link-topic:hover {
    color: var(--color-rougeBrickember);
    text-decoration-color: var(--color-rougeBrickember);
  }
}
.cp-blog-single__end-link-topic:active {
  color: var(--color-rougeBrickember);
  text-decoration-color: var(--color-rougeBrickember);
}

.cp-blog-article {
  color: var(--color-bleuTexte);
}

/* Liens inline dans le corps de l'article (ajoutés manuellement dans le contenu) */
.cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link) {
  color: var(--color-bleuTexte);
  position: relative;
  text-decoration: none;
  transition: color 220ms ease;
}
.cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link)::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: left center;
  transition: opacity 220ms ease, transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) {
  .cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link):hover {
    color: var(--color-rougeBrickember);
  }
  .cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link):hover::after {
    opacity: 0.95;
    transform: scaleX(1);
  }
}
.cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link):active {
  color: var(--color-rougeBrickember);
}
.cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link):focus-visible {
  color: var(--color-rougeBrickember);
  outline-offset: 3px;
}
.cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link):focus-visible::after {
  opacity: 0.95;
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link) {
    transition: none;
  }
  .cp-blog-single__content a:not(.cp-btn):not(.cp-blog-article__related-link)::after {
    transition: none;
  }
}

.cp-blog-article__hero {
  width: 100%;
  max-width: 100%;
  margin-right: auto;
  margin-bottom: 24px;
  margin-left: auto;
  border-radius: 6px;
  overflow: hidden;
}

.cp-blog-article__hero-image {
  display: block;
  width: 100%;
  height: auto;
}

.cp-blog-article__section {
  margin-bottom: 32px;
}

.cp-blog-article__intro {
  max-width: 70ch;
}

.cp-blog-article__heading {
  margin: 0 0 24px;
  color: var(--color-rougeArticleH2);
  font-size: 20px;
  line-height: 1.3;
  font-weight: 600;
}

.cp-blog-article__causes-list {
  max-width: 70ch;
}

.cp-blog-article__causes-item {
  color: var(--color-bleuTexte);
}

.cp-blog-article__segment {
  margin-bottom: 24px;
}

.cp-blog-article__segment:last-child {
  margin-bottom: 0;
}

.cp-blog-article__segment-title--h2,
.cp-blog-article__segment-title--h3 {
  color: var(--color-bleuTexte);
}

.cp-blog-article__segment-title--h3 {
  font-size: 20px;
  line-height: 30px;
}

.cp-blog-article__segment-title--h4 {
  font-size: 14px;
  line-height: 21px;
  text-transform: uppercase;
  font-weight: 500;
}

.cp-blog-article__segment-media {
  width: 300px;
  max-width: 100%;
  margin-bottom: 16px;
  border-radius: 6px;
  overflow: hidden;
}

.cp-blog-article__segment-image {
  display: block;
  width: 100%;
  height: auto;
}

.cp-blog-article__segment-content {
  max-width: 70ch;
}

.cp-blog-article__cta-wrap {
  display: flex;
  justify-content: flex-start;
}

/* CTA ACF dans le corps d’article : le bouton prend la largeur du texte jusqu’à 100 % du conteneur (pas de largeur fixe ni une seule ligne). */
.cp-blog-article__cta-wrap .cp-btn {
  width: auto;
  max-width: 100%;
  box-sizing: border-box;
  height: auto;
  min-height: 40px;
  padding-block: 8px;
  white-space: normal;
  overflow-wrap: break-word;
  text-align: center;
}

@media (min-width: 768px) {
  .cp-blog-article__cta-wrap .cp-btn {
    min-height: 40px;
    padding-block: 6px;
  }
}
@media (min-width: 1024px) {
  .cp-blog-article__cta-wrap .cp-btn {
    min-height: 45px;
    padding-block: 8px;
  }
}
.cp-blog-article__section--related-links {
  border-top: 1px solid rgba(var(--color-bleuTexte), 0.12);
  padding-top: 24px;
}

.cp-blog-article__related {
  max-width: 70ch;
}

.cp-blog-article__related-group {
  margin-bottom: 24px;
}

.cp-blog-article__related-group:last-child {
  margin-bottom: 0;
}

.cp-blog-article__related-heading {
  margin: 0 0 16px;
  color: var(--color-bleuTexte);
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
}

.cp-blog-article__related-list {
  margin: 0;
  padding-left: 1.25rem;
  list-style: disc;
}

.cp-blog-article__related-item {
  margin-bottom: 12px;
  color: var(--color-bleuTexte);
}

.cp-blog-article__related-item:last-child {
  margin-bottom: 0;
}

.cp-blog-article__related-link {
  font-weight: 400;
  /* États couleur en premier (le hover du mixin les écrase au survol — LVHA) */
}
.cp-blog-article__related-link:link, .cp-blog-article__related-link:visited {
  color: var(--color-bleuTexte);
}
.cp-blog-article__related-link.cp-blog-article__related-link--session {
  color: var(--color-lienVisite);
  font-weight: 500;
}
.cp-blog-article__related-link {
  position: relative;
  text-decoration: none;
  transition: color 220ms ease;
}
.cp-blog-article__related-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: left center;
  transition: opacity 220ms ease, transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) {
  .cp-blog-article__related-link:hover {
    color: var(--color-rougeBrickember);
  }
  .cp-blog-article__related-link:hover::after {
    opacity: 0.95;
    transform: scaleX(1);
  }
}
.cp-blog-article__related-link:active {
  color: var(--color-rougeBrickember);
}
.cp-blog-article__related-link:focus-visible {
  color: var(--color-rougeBrickember);
  outline-offset: 3px;
}
.cp-blog-article__related-link:focus-visible::after {
  opacity: 0.95;
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .cp-blog-article__related-link {
    transition: none;
  }
  .cp-blog-article__related-link::after {
    transition: none;
  }
}

@media (min-width: 768px) {
  .cp-blog-single {
    padding-top: 32px;
    padding-bottom: 48px;
  }
  .cp-blog-single__title {
    font-size: 28px;
    line-height: 42px;
  }
  .cp-blog-single__header {
    margin-bottom: 24px;
  }
  .cp-blog-article__hero {
    max-width: 400px;
    margin-right: auto;
    margin-bottom: 32px;
    margin-left: 0;
  }
  .cp-blog-article__section {
    margin-bottom: 48px;
  }
  .cp-blog-article__heading {
    font-size: 28px;
    line-height: 1.3;
    margin-bottom: 24px;
  }
  .cp-blog-article__segment-title--h3 {
    font-size: 22px;
    line-height: 33px;
  }
  .cp-blog-article__segment-title--h4 {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 1024px) {
  .cp-blog-single {
    padding-bottom: 64px;
  }
  .cp-blog-article__hero {
    max-width: 450px;
    margin-right: auto;
    margin-left: 0;
  }
  .cp-blog-article__section {
    margin-bottom: 64px;
  }
  .cp-blog-article__heading {
    font-size: 28px;
    line-height: 1.3;
    margin-bottom: 32px;
  }
  .cp-blog-article__segment-title--h3 {
    font-size: 26px;
    line-height: 43px;
  }
  .cp-blog-article__segment-title--h4 {
    font-size: 18px;
    line-height: 27px;
  }
}
/* Couleurs littérales — évite rgba(var(--token), …) invalide en CSS */
/* ==========================================================================
   BLOG ARTICLE — Mises en page visuelles
   Racines : .cp-blog-article--layout-* | .cp-blog-single__article--layout-* | body.cp-blog--layout-*
   ========================================================================== */
/* --------------------------------------------------------------------------
   Classique — légèrement poli (baseline)
   -------------------------------------------------------------------------- */
.cp-blog-article--layout-classique .cp-blog-article__intro p:first-child,
.cp-blog-single__article--layout-classique .cp-blog-article__intro p:first-child,
.cp-blog--layout-classique .cp-blog-article__intro p:first-child {
  font-size: 17px;
  line-height: 1.65;
}
@media (min-width: 768px) {
  .cp-blog-article--layout-classique .cp-blog-article__intro p:first-child,
  .cp-blog-single__article--layout-classique .cp-blog-article__intro p:first-child,
  .cp-blog--layout-classique .cp-blog-article__intro p:first-child {
    font-size: 18px;
    line-height: 1.7;
  }
}

/* --------------------------------------------------------------------------
   Éditorial — encadrés premium et cartes
   -------------------------------------------------------------------------- */
.cp-blog-article--layout-editorial .cp-blog-article__section--intro,
.cp-blog-single__article--layout-editorial .cp-blog-article__section--intro,
.cp-blog--layout-editorial .cp-blog-article__section--intro {
  padding: 0;
  margin-bottom: 24px;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.cp-blog-article--layout-editorial .cp-blog-article__section--intro .cp-blog-article__intro,
.cp-blog-single__article--layout-editorial .cp-blog-article__section--intro .cp-blog-article__intro,
.cp-blog--layout-editorial .cp-blog-article__section--intro .cp-blog-article__intro {
  background: var(--color-alabaster);
  border: 1px solid rgba(37, 60, 63, 0.12);
  border-radius: 8px;
  box-shadow: 0 4px 18px rgba(43, 53, 80, 0.08);
  max-width: none;
  padding: 24px;
  border-left: 4px solid var(--color-rougeBrickember);
}
.cp-blog-article--layout-editorial .cp-blog-article__section:not(.cp-blog-article__section--intro):not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links),
.cp-blog-single__article--layout-editorial .cp-blog-article__section:not(.cp-blog-article__section--intro):not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links),
.cp-blog--layout-editorial .cp-blog-article__section:not(.cp-blog-article__section--intro):not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links) {
  background: var(--color-alabaster);
  border: 1px solid rgba(37, 60, 63, 0.12);
  border-radius: 8px;
  box-shadow: 0 4px 18px rgba(43, 53, 80, 0.08);
  padding: 24px;
  margin-bottom: 24px;
}
.cp-blog-article--layout-editorial .cp-blog-article__heading,
.cp-blog-single__article--layout-editorial .cp-blog-article__heading,
.cp-blog--layout-editorial .cp-blog-article__heading {
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(37, 60, 63, 0.1);
}
.cp-blog-article--layout-editorial .cp-blog-article__causes-list,
.cp-blog-single__article--layout-editorial .cp-blog-article__causes-list,
.cp-blog--layout-editorial .cp-blog-article__causes-list {
  max-width: none;
  margin: 0;
  padding: 16px 24px 16px 2rem;
  list-style: disc;
  background: var(--color-platinum);
  border-radius: 6px;
  border: 1px solid rgba(37, 60, 63, 0.08);
}
.cp-blog-article--layout-editorial .cp-blog-article__segment--h3,
.cp-blog-single__article--layout-editorial .cp-blog-article__segment--h3,
.cp-blog--layout-editorial .cp-blog-article__segment--h3 {
  padding: 16px 24px;
  margin-bottom: 16px;
  background: var(--color-platinum);
  border-radius: 6px;
  border: 1px solid rgba(37, 60, 63, 0.06);
}
.cp-blog-article--layout-editorial .cp-blog-article__segment--h3:last-child,
.cp-blog-single__article--layout-editorial .cp-blog-article__segment--h3:last-child,
.cp-blog--layout-editorial .cp-blog-article__segment--h3:last-child {
  margin-bottom: 0;
}
.cp-blog-article--layout-editorial .cp-blog-article__segment--h4,
.cp-blog-single__article--layout-editorial .cp-blog-article__segment--h4,
.cp-blog--layout-editorial .cp-blog-article__segment--h4 {
  margin-left: 16px;
  padding-left: 16px;
  border-left: 2px solid rgba(37, 60, 63, 0.2);
}
.cp-blog-article--layout-editorial .cp-blog-article__segment-content,
.cp-blog-article--layout-editorial .cp-blog-article__intro,
.cp-blog-single__article--layout-editorial .cp-blog-article__segment-content,
.cp-blog-single__article--layout-editorial .cp-blog-article__intro,
.cp-blog--layout-editorial .cp-blog-article__segment-content,
.cp-blog--layout-editorial .cp-blog-article__intro {
  max-width: none;
}
.cp-blog-article--layout-editorial .cp-blog-article__section--cta,
.cp-blog-single__article--layout-editorial .cp-blog-article__section--cta,
.cp-blog--layout-editorial .cp-blog-article__section--cta {
  background: var(--color-alabaster);
  border: 1px solid rgba(37, 60, 63, 0.12);
  border-radius: 8px;
  box-shadow: 0 4px 18px rgba(43, 53, 80, 0.08);
  padding: 24px;
  background: linear-gradient(135deg, rgba(43, 53, 80, 0.06) 0%, #fafafa 100%);
  border-color: rgba(43, 53, 80, 0.14);
}
.cp-blog-article--layout-editorial .cp-blog-article__cta-wrap,
.cp-blog-single__article--layout-editorial .cp-blog-article__cta-wrap,
.cp-blog--layout-editorial .cp-blog-article__cta-wrap {
  justify-content: center;
}
.cp-blog-article--layout-editorial .cp-blog-article__section--related-links,
.cp-blog-single__article--layout-editorial .cp-blog-article__section--related-links,
.cp-blog--layout-editorial .cp-blog-article__section--related-links {
  border-top: 0;
  padding-top: 0;
}
.cp-blog-article--layout-editorial .cp-blog-article__related,
.cp-blog-single__article--layout-editorial .cp-blog-article__related,
.cp-blog--layout-editorial .cp-blog-article__related {
  max-width: none;
  background: var(--color-alabaster);
  border: 1px solid rgba(37, 60, 63, 0.12);
  border-radius: 8px;
  box-shadow: 0 4px 18px rgba(43, 53, 80, 0.08);
  padding: 24px;
}

/* --------------------------------------------------------------------------
   Magazine — hero large, grille image/texte, rythme alterné
   -------------------------------------------------------------------------- */
.cp-blog-article--layout-magazine .cp-blog-article__hero,
.cp-blog-single__article--layout-magazine .cp-blog-article__hero,
.cp-blog--layout-magazine .cp-blog-article__hero {
  width: 100%;
  max-width: 100%;
  margin-right: auto;
  margin-bottom: 32px;
  margin-left: auto;
  border-radius: 10px;
  box-shadow: 0 10px 32px rgba(43, 53, 80, 0.12);
}
.cp-blog-article--layout-magazine .cp-blog-article__intro,
.cp-blog-single__article--layout-magazine .cp-blog-article__intro,
.cp-blog--layout-magazine .cp-blog-article__intro {
  max-width: 85ch;
}
.cp-blog-article--layout-magazine .cp-blog-article__intro p:first-child,
.cp-blog-single__article--layout-magazine .cp-blog-article__intro p:first-child,
.cp-blog--layout-magazine .cp-blog-article__intro p:first-child {
  font-size: 18px;
  line-height: 1.7;
  font-weight: 500;
  color: var(--color-bleuTexte);
}
.cp-blog-article--layout-magazine .cp-blog-article__heading,
.cp-blog-single__article--layout-magazine .cp-blog-article__heading,
.cp-blog--layout-magazine .cp-blog-article__heading {
  padding-bottom: 12px;
}
.cp-blog-article--layout-magazine .cp-blog-article__heading::after,
.cp-blog-single__article--layout-magazine .cp-blog-article__heading::after,
.cp-blog--layout-magazine .cp-blog-article__heading::after {
  content: "";
  display: block;
  width: 52px;
  height: 3px;
  margin-top: 12px;
  border-radius: 2px;
  background: var(--color-rougeBrickember);
}
.cp-blog-article--layout-magazine .cp-blog-article__section:not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links),
.cp-blog-single__article--layout-magazine .cp-blog-article__section:not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links),
.cp-blog--layout-magazine .cp-blog-article__section:not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links) {
  padding: 24px;
  border-radius: 10px;
}
.cp-blog-article--layout-magazine .cp-blog-article__section:nth-of-type(even):not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links),
.cp-blog-single__article--layout-magazine .cp-blog-article__section:nth-of-type(even):not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links),
.cp-blog--layout-magazine .cp-blog-article__section:nth-of-type(even):not(.cp-blog-article__section--cta):not(.cp-blog-article__section--related-links) {
  background: var(--color-platinum);
}
.cp-blog-article--layout-magazine .cp-blog-article__causes-list,
.cp-blog-single__article--layout-magazine .cp-blog-article__causes-list,
.cp-blog--layout-magazine .cp-blog-article__causes-list {
  max-width: none;
  columns: 1;
  column-gap: 32px;
}
.cp-blog-article--layout-magazine .cp-blog-article__segment--h3,
.cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3,
.cp-blog--layout-magazine .cp-blog-article__segment--h3 {
  margin-bottom: 24px;
}
.cp-blog-article--layout-magazine .cp-blog-article__segment-content,
.cp-blog-article--layout-magazine .cp-blog-article__intro,
.cp-blog-single__article--layout-magazine .cp-blog-article__segment-content,
.cp-blog-single__article--layout-magazine .cp-blog-article__intro,
.cp-blog--layout-magazine .cp-blog-article__segment-content,
.cp-blog--layout-magazine .cp-blog-article__intro {
  max-width: none;
}
.cp-blog-article--layout-magazine .cp-blog-article__section--cta,
.cp-blog-single__article--layout-magazine .cp-blog-article__section--cta,
.cp-blog--layout-magazine .cp-blog-article__section--cta {
  padding: 32px 24px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(43, 53, 80, 0.07) 0%, rgba(43, 53, 80, 0.02) 100%);
  text-align: center;
}
.cp-blog-article--layout-magazine .cp-blog-article__cta-wrap,
.cp-blog-single__article--layout-magazine .cp-blog-article__cta-wrap,
.cp-blog--layout-magazine .cp-blog-article__cta-wrap {
  justify-content: center;
}
.cp-blog-article--layout-magazine .cp-blog-article__section--related-links,
.cp-blog-single__article--layout-magazine .cp-blog-article__section--related-links,
.cp-blog--layout-magazine .cp-blog-article__section--related-links {
  border-top: 0;
  padding-top: 0;
  background: transparent;
}
@media (min-width: 768px) {
  .cp-blog-article--layout-magazine .cp-blog-article__hero,
  .cp-blog-single__article--layout-magazine .cp-blog-article__hero,
  .cp-blog--layout-magazine .cp-blog-article__hero {
    max-width: 100%;
    margin-bottom: 48px;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__intro p:first-child,
  .cp-blog-single__article--layout-magazine .cp-blog-article__intro p:first-child,
  .cp-blog--layout-magazine .cp-blog-article__intro p:first-child {
    font-size: 20px;
    line-height: 1.65;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__causes-list,
  .cp-blog-single__article--layout-magazine .cp-blog-article__causes-list,
  .cp-blog--layout-magazine .cp-blog-article__causes-list {
    columns: 2;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3,
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3,
  .cp-blog--layout-magazine .cp-blog-article__segment--h3 {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
    align-items: start;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3 .cp-blog-article__segment-media + .cp-blog-article__segment-content,
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media),
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3 .cp-blog-article__segment-media + .cp-blog-article__segment-content,
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media),
  .cp-blog--layout-magazine .cp-blog-article__segment--h3 .cp-blog-article__segment-media + .cp-blog-article__segment-content,
  .cp-blog--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) {
    grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
    gap: 24px;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) .cp-blog-article__segment-title--h3,
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) .cp-blog-article__segment-title--h3,
  .cp-blog--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) .cp-blog-article__segment-title--h3 {
    grid-column: 1/-1;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) .cp-blog-article__segment-media,
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) .cp-blog-article__segment-media,
  .cp-blog--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) .cp-blog-article__segment-media {
    width: 100%;
    max-width: none;
    margin-bottom: 0;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3:nth-of-type(even):has(.cp-blog-article__segment-media) .cp-blog-article__segment-media,
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3:nth-of-type(even):has(.cp-blog-article__segment-media) .cp-blog-article__segment-media,
  .cp-blog--layout-magazine .cp-blog-article__segment--h3:nth-of-type(even):has(.cp-blog-article__segment-media) .cp-blog-article__segment-media {
    order: 2;
  }
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3:nth-of-type(even):has(.cp-blog-article__segment-media) .cp-blog-article__segment-content,
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3:nth-of-type(even):has(.cp-blog-article__segment-media) .cp-blog-article__segment-content,
  .cp-blog--layout-magazine .cp-blog-article__segment--h3:nth-of-type(even):has(.cp-blog-article__segment-media) .cp-blog-article__segment-content {
    order: 3;
  }
}
@media (min-width: 1024px) {
  .cp-blog-article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media),
  .cp-blog-single__article--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media),
  .cp-blog--layout-magazine .cp-blog-article__segment--h3:has(.cp-blog-article__segment-media) {
    grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
    gap: 32px;
  }
}

/* Hero magazine : annule le rétrécissement desktop du layout de base */
@media (min-width: 768px) {
  .cp-blog-article--layout-magazine .cp-blog-article__hero,
  .cp-blog-single__article--layout-magazine .cp-blog-article__hero,
  .cp-blog--layout-magazine .cp-blog-article__hero {
    max-width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (min-width: 1024px) {
  .cp-blog-article--layout-magazine .cp-blog-article__hero,
  .cp-blog-single__article--layout-magazine .cp-blog-article__hero,
  .cp-blog--layout-magazine .cp-blog-article__hero {
    max-width: 100%;
  }
}
/* ==========================================================================
   TUTOS & INFOS — HUB
   ========================================================================== */
/* ==========================================================================
   Base
   ========================================================================== */
.cp-tutos-infos-page {
  background: var(--color-alabaster);
}

.cp-tutos-hub {
  padding-bottom: 56px;
}

.cp-tutos-hub__top {
  display: grid;
  gap: 16px;
  margin-top: 22px;
}

.cp-tutos-hub__news-column {
  display: grid;
  gap: 14px;
}

.cp-tutos-hub__feature-media {
  display: none;
  margin: 0;
  border-radius: 6px;
  aspect-ratio: 16/9;
  overflow: hidden;
}

.cp-tutos-hub__feature-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
   Intro
   ========================================================================== */
.cp-tutos-hub__intro {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.cp-tutos-hub__eyebrow {
  background: var(--color-bleuFond);
  position: relative;
}

/* grain */
.cp-tutos-hub__eyebrow::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-tutos-hub__h2 {
  margin: 0;
  padding: 16px 0;
  text-align: center;
  color: var(--color-blanc);
  position: relative;
  z-index: 1;
}

.cp-tutos-hub__break {
  display: inline;
}

@media (max-width: 400px) {
  .cp-tutos-hub__break {
    display: block;
  }
}
@media (min-width: 768px) {
  .cp-tutos-hub__h2 {
    padding: 8px;
    font-size: 24px;
  }
}
/* ==========================================================================
   Accordion
   ========================================================================== */
.cp-tutos-hub__accordion {
  width: fit-content;
  min-width: 0;
}

.cp-tutos-hub__accordion-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: clamp(160px, 45vw, 200px);
  min-height: 36px;
  padding: 7px 12px;
  border-radius: 5px;
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 16px;
  cursor: pointer;
  list-style: none;
  border: 1px solid transparent;
  transition: border-radius 180ms ease, box-shadow 220ms ease, background-color 220ms ease, border-color 220ms ease, transform 160ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .cp-tutos-hub__accordion:not([open]) .cp-tutos-hub__accordion-trigger:hover {
    background: var(--color-alabaster);
    color: var(--color-bleuFond);
    border-color: transparent;
    font-weight: 700;
  }
}
.cp-tutos-hub__accordion-trigger:active {
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
}

.cp-tutos-hub__accordion-trigger::-webkit-details-marker {
  display: none;
}

.cp-tutos-hub__accordion-trigger::marker {
  content: "";
}

.cp-tutos-hub__accordion-arrow {
  width: 18px;
  height: auto;
  flex-shrink: 0;
  filter: brightness(0) invert(1);
  transform: rotate(0deg);
  transition: transform 180ms ease;
}

.cp-tutos-hub__accordion[open] .cp-tutos-hub__accordion-arrow {
  transform: rotate(90deg);
}

.cp-tutos-hub__accordion[open] .cp-tutos-hub__accordion-trigger {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-color: rgba(8, 62, 125, 0.18);
  background: linear-gradient(180deg, rgba(43, 53, 80, 0.98), rgba(43, 53, 80, 0.92));
  font-weight: 700;
}

.cp-tutos-hub__accordion-panel {
  display: grid;
  gap: 0;
  margin-top: 0;
  padding: 8px 10px;
  border-radius: 5px;
  border: 1px solid rgba(8, 62, 125, 0.18);
  border-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(250, 250, 250, 0.96));
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.08), 0 2px 6px rgba(0, 0, 0, 0.04);
}

.cp-tutos-hub__accordion-panel a {
  display: block;
  padding: 9px 8px;
  color: var(--color-bleuTexte);
  font-size: 14px;
  font-weight: 600;
  line-height: 20px;
  text-decoration: none;
  border-radius: 4px;
  transition: background-color 180ms ease, color 180ms ease;
}

.cp-tutos-hub__accordion-panel a + a {
  border-top: 1px solid rgba(8, 62, 125, 0.18);
}

@media (hover: hover) and (pointer: fine) {
  .cp-tutos-hub__accordion-panel a:not(.is-active):not([aria-current=true]):hover {
    background: rgba(43, 53, 80, 0.06);
    color: var(--color-bleuFond);
  }
}
.cp-tutos-hub__accordion-panel a.is-active,
.cp-tutos-hub__accordion-panel a[aria-current=true] {
  pointer-events: none;
  cursor: default;
}

.cp-tutos-hub__filters-row {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: clamp(8px, 3vw, 12px);
}

@media (min-width: 400px) {
  .cp-tutos-hub__filters-row {
    gap: 12px;
  }
}
.cp-tutos-hub__filters-left {
  display: grid;
  gap: 8px;
}

.cp-tutos-hub__filters-offset {
  margin-top: 12px;
}

@media (min-width: 400px) {
  .cp-tutos-hub__filters-offset {
    margin-top: 16px;
  }
}
.cp-tutos-hub__reset {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(160px, 45vw, 200px);
  min-height: 36px;
  padding: 6px 12px;
  margin: 0;
  border: 1px solid transparent;
  border-radius: 5px;
  background: var(--color-alabaster);
  color: var(--color-bleuFond);
  font: inherit;
  font-size: 14px;
  text-decoration: none;
  cursor: pointer;
  appearance: none;
  transition: background-color 240ms ease, color 240ms ease, border-color 240ms ease, box-shadow 240ms ease, transform 160ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .cp-tutos-hub__reset:hover {
    background: var(--color-bleuFond);
    color: var(--color-blanc);
    border-color: transparent;
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.14), 0 2px 6px rgba(0, 0, 0, 0.08);
  }
}
.cp-tutos-hub__reset:active {
  background: rgba(43, 53, 80, 0.92);
  color: var(--color-blanc);
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
}

.cp-tutos-hub__radios {
  margin: 0;
  padding: 2px 6px 0 0;
  border: 0;
  display: grid;
  gap: 7px;
}

.cp-tutos-hub__radio-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--color-bleuTexte);
  font-size: 14px;
  line-height: 16px;
  font-variant: small-caps;
  white-space: nowrap;
}

.cp-tutos-hub__radio-item input {
  margin: 0;
}

/* ==========================================================================
   News
   ========================================================================== */
.cp-tutos-news {
  margin-top: 0;
}

.cp-tutos-news__title {
  margin-left: 4px;
  margin-bottom: 10px;
  color: var(--color-bleuTexte);
  font-size: 14px;
  line-height: 20px;
}

.cp-tutos-news__cards {
  display: grid;
  gap: 10px;
}

.cp-tutos-news-card {
  padding: 12px;
  border-radius: 5px;
  background: var(--color-alabaster);
  transition: transform 220ms ease, box-shadow 240ms ease, background-color 240ms ease;
}

.cp-tutos-news-card__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  cursor: pointer;
  list-style: none;
}

.cp-tutos-news-card__trigger::-webkit-details-marker {
  display: none;
}

.cp-tutos-news-card__trigger::marker {
  content: "";
}

.cp-tutos-news-card__trigger h3 {
  margin: 0;
}

.cp-tutos-news-card__arrow {
  width: 16px;
  height: auto;
  flex-shrink: 0;
  transform: rotate(0deg);
  transition: transform 180ms ease;
}

.cp-tutos-news-card[open] .cp-tutos-news-card__arrow {
  transform: rotate(90deg);
}

.cp-tutos-news-card__content {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  margin-top: 8px;
}

.cp-tutos-news-card__rdv {
  margin-top: 20px; /* un peu plus d'espace au-dessus du bouton d'action */
  margin-bottom: 0;
  align-self: flex-end;
}

/* Compact : surcharge les tailles fixes .cp-btn (y compris >=768px) */
.cp-tutos-news-card__rdv-btn.cp-btn {
  width: auto;
  min-width: 0;
  max-width: none;
  height: auto;
  min-height: 0;
  justify-content: center;
  padding-block: 5px;
  padding-inline: 20px;
  font-size: 11px;
  line-height: 14px;
  font-weight: 600;
  box-shadow: none;
}

.cp-tutos-news-card__rdv-btn.cp-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.08);
}

.cp-tutos-news-card__rdv-btn.cp-btn:active {
  transform: translateY(0);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.08);
}

@media (min-width: 768px) {
  .cp-tutos-news-card__rdv-btn.cp-btn {
    width: auto;
    height: auto;
    padding-block: 5px;
    padding-inline: 20px;
    font-size: 11px;
    line-height: 14px;
  }
}
@media (min-width: 1024px) {
  .cp-tutos-news-card__rdv-btn.cp-btn {
    width: auto;
    height: auto;
    padding-block: 6px;
    padding-inline: 22px;
    font-size: 11px;
    line-height: 14px;
  }
}
.cp-tutos-news-card h3 {
  margin-bottom: 4px;
  color: var(--color-bleuTexte);
  font-size: 14px;
  line-height: 20px;
}

.cp-tutos-news-card p {
  margin: 0;
  color: var(--color-grisGunmetal);
  font-size: 14px;
  line-height: 20px;
}

@media (hover: hover) and (pointer: fine) {
  .cp-tutos-news-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.14), 0 2px 6px rgba(0, 0, 0, 0.08);
  }
}
.cp-tutos-news-card:active {
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
}

.cp-tutos-news-card[open]:focus-within {
  box-shadow: 0 0 0 3px rgba(43, 53, 80, 0.22), 0 8px 16px rgba(0, 0, 0, 0.12);
}

.cp-tutos-news-card__trigger:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.45);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ==========================================================================
   Radio CTA
   ========================================================================== */
.cp-tutos-hub__radio {
  display: flex;
  justify-content: flex-start;
  margin-top: 8px;
}

.cp-tutos-hub__radio .cp-btn {
  width: 100%;
  max-width: 275px;
  font-weight: 700;
  font-size: 13px;
  line-height: 16px;
}

/* ==========================================================================
   Articles
   ========================================================================== */
.cp-tutos-articles {
  margin-top: 20px;
}

.cp-tutos-articles__pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 14px;
  color: var(--color-bleuTexte);
  font-size: 12px;
  line-height: 16px;
}

.cp-tutos-articles__grid {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  padding-bottom: 8px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.cp-tutos-articles__grid::-webkit-scrollbar {
  display: none;
}

.cp-tutos-card {
  display: flex;
  flex-direction: column;
  flex: 0 0 min(86vw, 320px);
  width: min(86vw, 320px);
  min-height: 480px;
  scroll-snap-align: start;
  overflow: hidden;
  border-radius: 5px;
  background: var(--color-blanc);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
}

.cp-tutos-card__media {
  position: relative;
  margin: 10px 10px 0;
  border-radius: 5px;
  height: 0;
  padding-top: 56.25%; /* 16:9 strict ratio */
  overflow: hidden;
  background: linear-gradient(45deg, rgba(220, 220, 220, 0.45) 25%, transparent 25%), linear-gradient(-45deg, rgba(220, 220, 220, 0.45) 25%, transparent 25%), linear-gradient(45deg, transparent 75%, rgba(220, 220, 220, 0.45) 75%), linear-gradient(-45deg, transparent 75%, rgba(220, 220, 220, 0.45) 75%);
  background-size: 18px 18px;
  background-position: 0 0, 0 9px, 9px -9px, -9px 0;
  background-color: var(--color-alabaster);
}

.cp-tutos-card__media-frame {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: 5px;
}

.cp-tutos-card__media-image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  object-position: center;
}

.cp-tutos-card__media--placeholder {
  position: relative;
  display: block;
  background: linear-gradient(180deg, rgba(242, 243, 244, 0.95), rgba(250, 250, 250, 0.98));
}

/* Zone 16:9 réelle créée par padding-top du parent ; on centre le logo CP dans cet espace sur tous formats. */
.cp-tutos-card__media-placeholder-graphic {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.cp-tutos-card__media-placeholder-icon {
  display: block;
  width: 68px;
  height: auto;
  max-width: clamp(52px, 18vw, 68px);
  opacity: 0.22;
  filter: grayscale(100%);
}

.cp-tutos-card__media-placeholder-label {
  position: absolute;
  left: 10px;
  bottom: 8px;
  color: rgba(37, 60, 63, 0.72);
  font-size: 11px;
  line-height: 14px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.cp-tutos-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 10px;
  padding: 16px 14px 18px;
}

.cp-tutos-card__meta {
  margin-bottom: 0;
  color: var(--color-bleuTexte);
  font-size: 11px;
  font-weight: 700;
  line-height: 16px;
  text-transform: uppercase;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 48px;
}

.cp-tutos-card__tags {
  display: grid;
  gap: 6px;
  margin-bottom: 0;
  min-height: 38px;
}

.cp-tutos-card__tag {
  position: relative;
  padding-left: 18px;
  color: var(--color-bleuTexte);
  font-size: 12px;
  line-height: 16px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cp-tutos-card__tag::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  width: 9px;
  height: 9px;
  border: 2px solid var(--color-rougePurered);
  border-radius: 50%;
  background: transparent;
}

.cp-tutos-card__tag--cat-mecanique::before {
  border-color: #2B3550;
}

.cp-tutos-card__tag--cat-finances::before {
  border-color: #007A8A;
}

.cp-tutos-card__tag--cat-pneus::before {
  border-color: #8A6D1D;
}

.cp-tutos-card__tag--cat-marques::before {
  border-color: #5A3E8C;
}

.cp-tutos-card__tag--cat-vitrxpert::before {
  border-color: #47AA42;
}

.cp-tutos-card__tag--cat-certipro::before {
  border-color: var(--color-rougeBrickember);
}

.cp-tutos-card__tag--tag-populaire::before {
  border-color: #C60000;
}

.cp-tutos-card__tag--tag-utile::before {
  border-color: #1F6FB2;
}

.cp-tutos-card__tag--tag-chris::before {
  border-color: #E67E22;
}

.cp-tutos-card__body p:not(.cp-tutos-card__meta) {
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 100px;
  margin-top: 0;
  margin-bottom: 0;
  color: var(--color-grisGunmetal);
  font-size: 13px;
  line-height: 20px;
}

.cp-tutos-card__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  margin-top: auto;
}

.cp-tutos-card__video-btn {
  margin: 0;
}

.cp-tutos-card__link {
  width: 140px;
  height: 34px;
  margin-top: 0;
  margin-left: 0;
  font-size: 11px;
  line-height: 14px;
}

.cp-tutos-card__link:hover,
.cp-tutos-card__link:active {
  transform: none;
  box-shadow: none;
}

.cp-tutos-card__link:hover {
  background: var(--color-alabaster);
  color: var(--color-bleuFond);
  border-color: rgba(43, 53, 80, 0.35);
}

.cp-tutos-card__link:active {
  background: var(--color-platinum);
}

.cp-tutos-hub__accordion-trigger:focus-visible,
.cp-tutos-hub__reset:focus-visible,
.cp-tutos-card__link:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.45);
  outline-offset: 3px;
}

.cp-tutos-articles__empty {
  margin: 0;
  color: var(--color-bleuTexte);
}

.cp-tutos-articles__pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.cp-tutos-articles__pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 10px;
  border-radius: 5px;
  border: 1px solid rgba(43, 53, 80, 0.3);
  color: var(--color-bleuFond);
  background: var(--color-alabaster);
  text-decoration: none;
}

.cp-tutos-articles__pagination .page-numbers.current {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border-color: transparent;
}

@media (max-width: 1023px) {
  .cp-tutos-card__body p:not(.cp-tutos-card__meta) {
    margin-top: 14px;
  }
}
/* ==========================================================================
   Responsive
   ========================================================================== */
@media (min-width: 768px) {
  .cp-tutos-hub__accordion-trigger,
  .cp-tutos-hub__reset {
    width: 238px;
  }
  .cp-tutos-hub__accordion-trigger span {
    white-space: nowrap;
  }
  .cp-tutos-hub__top {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: start;
    gap: 20px;
  }
  .cp-tutos-hub__feature-media {
    display: block;
  }
  .cp-tutos-hub__intro {
    margin-top: 20px;
  }
  .cp-tutos-hub__radio {
    justify-content: flex-start;
    margin-top: 10px;
  }
  .cp-tutos-hub__radio .cp-btn {
    max-width: 100%;
  }
  .cp-tutos-articles__pager {
    display: none;
  }
  .cp-tutos-articles__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    overflow: visible;
    padding-bottom: 0;
    scroll-snap-type: none;
  }
  .cp-tutos-card {
    min-height: 480px;
    flex: initial;
    width: auto;
    flex-direction: column;
    scroll-snap-align: unset;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .cp-tutos-card {
    min-height: 450px;
  }
}
@media (min-width: 1024px) {
  .cp-tutos-hub__feature-media {
    margin-top: 12px;
  }
  .cp-tutos-hub__news-column {
    margin-top: 16px;
  }
  .cp-tutos-hub__top {
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.94fr);
  }
  .cp-tutos-hub__news-column {
    gap: 10px;
  }
  .cp-tutos-hub__radio {
    margin-top: 10px;
  }
  .cp-tutos-card__body p:not(.cp-tutos-card__meta) {
    margin-top: 8px;
  }
  .cp-tutos-card__meta {
    font-size: 13px;
    line-height: 18px;
    min-height: 54px;
  }
}
/* =========================
   UI — BANDE (cp-band)
   Toujours bleed
   Taille/hauteur immuables (pixel-perfect)
   ========================= */
.cp-band {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 40px;
  height: auto;
  position: relative;
}

/* grain */
.cp-band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

/* Tablette */
@media (min-width: 768px) {
  .cp-band {
    min-height: 50px;
  }
}
/* Table / desktop */
@media (min-width: 1024px) {
  .cp-band {
    min-height: 60px;
  }
}
.cp-band__title {
  margin: 0;
  padding-inline: 24px;
  color: inherit;
  position: relative;
  z-index: 1;
}

@media (max-width: 340px) {
  .cp-band__title {
    padding-top: 8px;
    padding-bottom: 8px;
  }
}
.cp-band.cp-band--courtoisie {
  height: 65px; /* mobile */
}

/* Tablette + Large */
@media (min-width: 768px) {
  .cp-band.cp-band--courtoisie {
    height: 110px;
    padding-inline: 15px;
  }
}
/* Très large */
@media (min-width: 1280px) {
  .cp-band.cp-band--courtoisie {
    height: 60px;
    padding-inline: 0;
  }
}
/* ========================================================================== */
/* =========================
   UI — BANDE GABARIT (cp-band--gabarit)
   DUPLICATION 1:1 DE CP-BAND (mêmes règles, mêmes comportements)
   + marges gabarit (mobile 40 / tablette 64 / desktop 120)
   ========================= */
.cp-band--gabarit {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 40px;
  height: auto;
  margin-bottom: 40px;
  position: relative;
}

/* grain */
.cp-band--gabarit::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

/* Tablette */
@media (min-width: 768px) {
  .cp-band--gabarit {
    min-height: 50px;
  }
}
/* Table / desktop */
@media (min-width: 1024px) {
  .cp-band--gabarit {
    min-height: 60px;
  }
}
.cp-band--gabarit__title {
  margin: 0;
  padding-inline: 24px;
  color: inherit;
  position: relative;
  z-index: 1;
}

@media (max-width: 340px) {
  .cp-band--gabarit__title {
    padding-top: 8px;
    padding-bottom: 8px;
  }
}
/* =========================
   Marges spécifiques — Gabarit
   Mobile : 40 (déjà dans la base)
   Tablette : 64
   Desktop : 120
   ========================= */
@media (min-width: 768px) and (max-width: 1023px) {
  .cp-band--gabarit {
    margin-bottom: 64px;
  }
}
@media (min-width: 1024px) {
  .cp-band--gabarit {
    margin-bottom: 120px;
  }
}
/* =========================================================
   THEMES — Accents contextuels (CertiPro / Vitrexpert)
   Rôle : fournir --cp-accent selon le wrapper de page/section
   ========================================================= */
.cp-theme--meca {
  --cp-accent: var(--color-rougePurered);
}

.cp-theme--vitre {
  --cp-accent: var(--color-vitrxpert);
}

/* Defaults (sécurité) : si un composant utilise --cp-accent
   sans wrapper de thème, on retombe sur rouge CertiPro. */
:root {
  --cp-accent: var(--color-rougePurered);
}

/* =========================
   ACCUEIL — POSITIONNEMENT
   H1 SEO principal (EXCEPTION contrôlée)
   - Typo différente des H1 globaux
   ========================= */
.accueil-positionnement {
  margin: 0;
  text-align: center;
  color: var(--color-grisGunmetal);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  /* Mobile */
  font-size: 14px;
  line-height: 21px;
  letter-spacing: 0;
  margin-bottom: 10px;
  /* Tablette */
}
@media (min-width: 768px) {
  .accueil-positionnement {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 20px;
  }
}
.accueil-positionnement {
  /* Desktop (si tu veux autre chose, dis-moi la valeur exacte) */
}
@media (min-width: 1024px) {
  .accueil-positionnement {
    font-size: 24px;
    line-height: 45px;
    margin-bottom: 33px;
  }
}

.accueil-positionnement__sub {
  display: block;
  margin-top: 16px;
  font-family: inherit;
  font-weight: 600;
  color: inherit;
  font-variant: small-caps;
  letter-spacing: 0;
  font-size: 12px;
  line-height: 18px;
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .accueil-positionnement__sub {
    font-size: 14px;
    line-height: 21px;
    margin-bottom: 48px;
  }
}
@media (min-width: 1024px) {
  .accueil-positionnement__sub {
    font-size: 20px;
    line-height: 30px;
    margin-bottom: 60px;
  }
}

@media (max-width: 1023px) {
  .accueil-positionnement__sub {
    margin-bottom: 25px; /* 40 - 15 */
  }
}
.services-hero {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 24px;
  margin-left: 6px;
}
@media (min-width: 768px) {
  .services-hero {
    gap: 24px;
    margin-bottom: 32px;
  }
}
@media (min-width: 1024px) {
  .services-hero {
    gap: 32px;
    margin-bottom: 48px;
  }
}

.services-hero__icon {
  flex: 0 0 auto;
  width: 45px;
  height: 45px;
  margin-top: 2px;
}
@media (min-width: 768px) {
  .services-hero__icon {
    width: 70px;
    height: 70px;
  }
}
@media (min-width: 1024px) {
  .services-hero__icon {
    width: 84px;
    height: 84px;
  }
}

.services-hero-stack {
  display: flex;
  flex-direction: column;
  margin-top: 16px;
}
@media (min-width: 768px) {
  .services-hero-stack {
    margin-top: 24px;
  }
}
@media (min-width: 1024px) {
  .services-hero-stack {
    margin-top: 32px;
  }
}

@media (min-width: 768px) {
  .services-hero .cp-breadcrumb {
    margin-top: -15px;
  }
}
@media (min-width: 1024px) {
  .services-hero .cp-breadcrumb {
    margin-top: -20px;
  }
}

@media (min-width: 1024px) {
  .services-hero .cp-h1-sub {
    margin-top: -5px;
  }
}

@media (min-width: 1024px) {
  .services-hero__icon {
    margin-top: 10px;
  }
}

/* ==========================================================================
   SERVICES — GRILLE (HUB)
   ========================================================================== */
/* =========================
   SECTION — fond platinum
   ========================= */
.servicesGrille {
  background: var(--color-platinum);
  padding-block: 48px;
  border-top: 3px solid var(--color-rougeBrickember);
  position: relative;
}
.servicesGrille::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.06;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.servicesGrille__content {
  position: relative;
  z-index: 1;
}

@media (min-width: 1024px) {
  .servicesGrille {
    padding-block: 64px;
  }
}
/* =========================
   TITRE
   ========================= */
.servicesGrille__h2 {
  text-align: center;
  margin: 0 0 24px;
}

.servicesGrille__h2::after {
  content: "";
  display: block;
  height: 3px;
  width: 52px;
  background: linear-gradient(90deg, transparent, var(--color-rougeBrickember) 30%, var(--color-rougeBrickember) 70%, transparent);
  margin: 10px auto 0;
}

@media (min-width: 768px) {
  .servicesGrille__h2::after {
    width: 80px;
    margin-top: 12px;
  }
}
@media (min-width: 1024px) {
  .servicesGrille__h2::after {
    width: 120px;
    margin-top: 14px;
  }
}
.servicesGrille__intro {
  font-size: 15px;
  line-height: 1.65;
  color: var(--color-bleuTexte);
  text-align: center;
  max-width: 560px;
  margin: 0 auto 32px;
}
.servicesGrille__intro a {
  color: var(--color-bleuTexte);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  text-decoration-color: rgba(37, 60, 63, 0.4);
  transition: color 200ms ease, text-decoration-color 200ms ease;
}
@media (hover: hover) and (pointer: fine) {
  .servicesGrille__intro a:hover {
    color: var(--color-rougeBrickember);
    text-decoration-color: var(--color-rougeBrickember);
  }
}
.servicesGrille__intro a:active {
  color: var(--color-rougeBrickember);
  text-decoration-color: var(--color-rougeBrickember);
}
.servicesGrille__intro a:focus-visible {
  color: var(--color-rougeBrickember);
  outline: 2px solid rgba(198, 0, 0, 0.5);
  outline-offset: 2px;
  border-radius: 2px;
}
@media (prefers-reduced-motion: reduce) {
  .servicesGrille__intro a {
    transition: none;
  }
}

/* Wrapper centré sur la largeur de la grille */
.servicesGrille__align {
  width: 100%;
  margin: 0 auto;
}

/* =========================
   GRILLE
   ========================= */
.servicesGrille__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  padding-inline: 10px;
}

/* =========================
   CARTE (lien)
   ========================= */
.servicesGrilleCard {
  display: block;
  text-decoration: none;
  color: inherit;
  text-align: center;
  background: #fff;
  border-radius: 10px;
  padding: 0 0 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1), 0 0 0 1px rgba(43, 53, 80, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  transition: box-shadow 240ms ease;
}

/* =========================
   MEDIA (porte la taille)
   + effets demandés (image only)
   ========================= */
.servicesGrilleCard__media {
  width: 100%;
  height: auto;
  aspect-ratio: 260/183;
  margin: 0;
  overflow: hidden;
  border-radius: 0;
  position: relative;
  /* état repos */
  transform: translateY(0);
  box-shadow: none;
  transition: transform 220ms ease, box-shadow 240ms ease;
}

/* Voile léger (overlay) — aucun carré derrière */
.servicesGrilleCard__media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  /* voile TRÈS subtil (bleuFond dilué, pas noir) */
  background: rgba(43, 53, 80, 0.05);
  opacity: 0;
  transition: opacity 220ms ease;
}

.servicesGrilleCard__picture,
.servicesGrilleCard__img {
  display: block;
  width: 100%;
  height: 100%;
}

.servicesGrilleCard__img {
  object-fit: cover;
}

@media (hover: hover) {
  .servicesGrilleCard:hover .servicesGrilleCard__media {
    transform: translateY(-1px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.14), 0 2px 6px rgba(0, 0, 0, 0.08);
  }
}
.servicesGrilleCard:hover .servicesGrilleCard__media::after {
  opacity: 0.45;
}

.servicesGrilleCard:focus-visible .servicesGrilleCard__media {
  transform: translateY(-1px);
  box-shadow: 0 0 0 3px rgba(43, 53, 80, 0.22), 0 8px 16px rgba(0, 0, 0, 0.14), 0 2px 6px rgba(0, 0, 0, 0.08);
}

.servicesGrilleCard:focus-visible .servicesGrilleCard__media::after {
  opacity: 0.45;
}

/* =========================
   TITRE H3
   ========================= */
.servicesGrilleCard__title {
  display: inline-block;
  margin: 0;
  padding: 10px 10px 0;
  color: var(--color-bleuTexte);
  letter-spacing: 0.05em;
}

/* =========================
   TOGGLE MOBILE (6 visibles)
   ========================= */
/* Mobile: cache à partir de la 7e carte */
.servicesGrille__grid .servicesGrilleCard:nth-child(n+7) {
  display: none;
}

/* Mobile: quand expanded, tout visible */
.servicesGrille__grid.is-expanded .servicesGrilleCard {
  display: block;
}

/* Bouton toggle */
.servicesGrille__toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 16px auto 24px;
  padding: 10px 14px;
  border: 0;
  border-radius: 5px;
  font-weight: 500;
  cursor: pointer;
  transition: filter 220ms ease;
}

/* =========================================================
   SERVICES — Toggle "Voir plus" (branché cp-btn)
   Objectif : opposé gris au hover (inversion)
   États : hover (fine), active (tap), focus-visible (clavier)
   ========================================================= */
.servicesGrille .servicesGrille__toggle.cp-btn {
  margin: 24px auto 0;
  /* Taille contrôlée (comme avant) */
  padding: 8px 20px;
  font-size: 14px;
  line-height: 1.2;
  width: fit-content;
}

@media (hover: hover) and (pointer: fine) {
  .servicesGrille .servicesGrille__toggle.cp-btn:hover {
    background: var(--color-alabaster);
    color: var(--color-grisGunmetal);
    box-shadow: 0 0 0 1px rgba(66, 66, 66, 0.35), 0 10px 18px rgba(0, 0, 0, 0.1), 0 2px 0 rgba(0, 0, 0, 0.06);
    transform: translateY(-2px);
  }
}
/* Tap tactile */
.servicesGrille .servicesGrille__toggle.cp-btn:active {
  transform: translateY(0);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.1), 0 1px 0 rgba(0, 0, 0, 0.06);
}

/* Focus clavier */
.servicesGrille .servicesGrille__toggle.cp-btn:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.6);
  outline-offset: 3px;
  box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.85), 0 10px 18px rgba(0, 0, 0, 0.1);
}

@media (prefers-reduced-motion: reduce) {
  .servicesGrille .servicesGrille__toggle.cp-btn {
    transition: none;
    filter: none;
  }
  .servicesGrille .servicesGrille__toggle.cp-btn:hover,
  .servicesGrille .servicesGrille__toggle.cp-btn:active {
    transform: none;
  }
}
@media (hover: hover) {
  .servicesGrille__toggle:hover {
    filter: brightness(1.05);
  }
}
.servicesGrille .servicesGrille__toggle.cp-btn {
  transition: background-color 260ms ease, color 260ms ease, box-shadow 260ms ease, transform 180ms ease, filter 220ms ease;
}

/* =========================
   HELPER
   ========================= */
.servicesGrille__helper {
  margin-top: 20px;
  padding: 12px 16px;
  border-left: 3px solid var(--color-rougeBrickember);
  background: #fff;
  border-radius: 0 4px 4px 0;
}

.servicesGrille__helperText {
  font-variant-caps: all-small-caps;
}

.servicesGrille__helperLink {
  color: var(--color-bleuTexte);
  font-weight: 500;
  position: relative;
  text-decoration: none;
  transition: color 220ms ease;
}
.servicesGrille__helperLink::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: left center;
  transition: opacity 220ms ease, transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) {
  .servicesGrille__helperLink:hover {
    color: var(--color-rougeBrickember);
  }
  .servicesGrille__helperLink:hover::after {
    opacity: 0.95;
    transform: scaleX(1);
  }
}
.servicesGrille__helperLink:active {
  color: var(--color-rougeBrickember);
}
.servicesGrille__helperLink:focus-visible {
  color: var(--color-rougeBrickember);
  outline-offset: 3px;
}
.servicesGrille__helperLink:focus-visible::after {
  opacity: 0.95;
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .servicesGrille__helperLink {
    transition: none;
  }
  .servicesGrille__helperLink::after {
    transition: none;
  }
}

/* =========================
   TABLETTE (>= bp-md)
   - 3 colonnes
   - tout visible, pas de toggle
   ========================= */
@media (min-width: 768px) {
  .servicesGrille__content {
    max-width: 744px;
    margin-inline: auto;
  }
  .servicesGrille__h2 {
    margin-bottom: 32px;
  }
  .servicesGrille__intro {
    font-size: 16px;
    margin-bottom: 48px;
  }
  .servicesGrille__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: 22px;
    row-gap: 22px;
    padding-inline: 2%;
  }
  .servicesGrilleCard__media {
    width: 100%;
    max-width: none;
    height: auto;
    aspect-ratio: 260/183;
    margin: 0;
  }
  /* En tablette+ : on montre toutes les cartes */
  .servicesGrille__grid .servicesGrilleCard:nth-child(n+7) {
    display: block;
  }
  /* En tablette+ : bouton caché */
  .servicesGrille__toggle {
    display: none;
  }
}
/* =========================
   DESKTOP (>= bp-lg)
   - 4 colonnes
   ========================= */
@media (min-width: 1024px) {
  .servicesGrille__content {
    max-width: 1000px;
  }
  .servicesGrille__h2 {
    margin-bottom: 48px;
  }
  .servicesGrille__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
  }
  .servicesGrilleCard__media {
    width: 100%;
    height: auto;
    aspect-ratio: 260/183;
  }
  .servicesGrilleCard__title {
    font-weight: 600;
  }
}
/* ==========================================================================
   SERVICES — EFFETS (tous formats, tactile inclus)
   - pas de scale
   - hover (fine pointer) + tap (active) + focus-visible
   ========================================================================== */
.servicesGrille .servicesGrilleCard__media {
  position: relative;
  transform: translateY(0);
  box-shadow: none;
  transition: box-shadow 240ms ease, transform 220ms ease;
}

.servicesGrille .servicesGrilleCard__media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background: rgba(0, 0, 0, 0.05);
  opacity: 0;
  transition: opacity 220ms ease;
}

.servicesGrille .servicesGrilleCard__title {
  transition: font-weight 220ms ease, letter-spacing 220ms ease;
}

/* Hover (desktop / hover réel seulement) */
@media (hover: hover) and (pointer: fine) {
  .servicesGrille .servicesGrilleCard:hover {
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.13), 0 0 0 1px rgba(0, 0, 0, 0.05);
  }
  .servicesGrille .servicesGrilleCard:hover .servicesGrilleCard__media {
    transform: translateY(-2px);
    box-shadow: 0 0 0 3px rgba(220, 220, 220, 0.75), 0 4px 8px rgba(0, 0, 0, 0.12); /* ombre courte */
  }
  .servicesGrille .servicesGrilleCard:hover .servicesGrilleCard__media::after {
    opacity: 0.15; /* voile léger */
  }
  .servicesGrille .servicesGrilleCard:hover .servicesGrilleCard__title {
    letter-spacing: 0.3px;
  }
}
/* Tap (tactile) — MOBILE + TABLETTE */
.servicesGrille .servicesGrilleCard:active .servicesGrilleCard__media {
  transform: translateY(-1px);
  box-shadow: 0 0 0 3px rgba(220, 220, 220, 0.65), 0 3px 6px rgba(0, 0, 0, 0.1); /* encore plus court */
}

.servicesGrille .servicesGrilleCard:active .servicesGrilleCard__media::after {
  opacity: 0.12;
}

.servicesGrille .servicesGrilleCard:active .servicesGrilleCard__title {
  letter-spacing: 0.3px;
}

/* Focus clavier */
.servicesGrille .servicesGrilleCard:focus-visible .servicesGrilleCard__media {
  transform: translateY(-2px);
  box-shadow: 0 0 0 3px rgba(43, 53, 80, 0.22), 0 0 0 6px rgba(220, 220, 220, 0.55), 0 4px 8px rgba(0, 0, 0, 0.12);
}

.servicesGrille .servicesGrilleCard:focus-visible .servicesGrilleCard__media::after {
  opacity: 0.15;
}

.servicesGrille .servicesGrilleCard:focus-visible .servicesGrilleCard__title {
  letter-spacing: 0.3px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .servicesGrille .servicesGrilleCard__media,
  .servicesGrille .servicesGrilleCard__media::after,
  .servicesGrille .servicesGrilleCard__title {
    transition: none;
  }
  .servicesGrille .servicesGrilleCard:hover .servicesGrilleCard__media,
  .servicesGrille .servicesGrilleCard:active .servicesGrilleCard__media,
  .servicesGrille .servicesGrilleCard:focus-visible .servicesGrilleCard__media {
    transform: none;
  }
}
/* =========================
   SERVICES — PROMO HIVER (carte)
   ========================= */
.servicesPromo__content {
  display: flex;
  justify-content: center;
}

.servicesPromoCard {
  max-width: 320px;
  text-align: center;
}

.servicesPromoCard__head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  margin: 14px 0 10px;
}

.servicesPromoCard__title {
  margin: 0;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
}

.servicesPromoCard__icon {
  display: block;
  width: 38px;
  height: 38px;
}

.servicesPromoCard__p {
  margin: 10px 0;
  color: var(--color-bleuTexte);
  text-align: left;
}

.servicesPromoCard__accent {
  margin: 12px 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.servicesPromoCard__chevrons {
  display: block;
  width: 30px;
  height: 12px;
}

.servicesPromoCard__accentText {
  font-style: italic;
  font-weight: 600;
  font-size: 14px;
  line-height: 24px;
  color: var(--color-rougeBrickember);
  font-family: "Barlow Semi Condensed", sans-serif;
}

.servicesPromoCard .ligne_top.promo {
  border: 0;
  height: 1px;
  width: 200px; /* mobile */
  margin-top: 24px;
  margin-bottom: 24px;
  background-color: rgba(209, 213, 219, 0.6);
}

.servicesPromoCard__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 48px;
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border-radius: 5px;
  text-decoration: none;
}

/* =========================
   TABLETTE (>= bp-md)
   ========================= */
@media (min-width: 768px) {
  .servicesPromoCard {
    max-width: 574px;
    padding: 0 0 28px 0;
  }
  .servicesPromoCard__head {
    display: flex;
    justify-content: left;
    gap: 8px;
    margin: 14px 0 10px;
  }
  .servicesPromoCard__chevrons {
    width: 35px;
    height: 14px;
  }
  .servicesPromoCard__accentText {
    font-size: 18px;
    line-height: 30px;
  }
  .servicesPromoCard .ligne_top.promo {
    width: 360px;
    margin-top: 32px;
    margin-bottom: 32px;
  }
}
/* =========================
   DESKTOP (>= bp-lg)
   ========================= */
@media (min-width: 1024px) {
  .servicesPromoCard {
    max-width: 700px;
  }
  .servicesPromoCard__chevrons {
    width: 48px;
    height: 20px;
  }
  .servicesPromoCard__accentText {
    font-size: 18px;
    line-height: 30px;
  }
  .servicesPromoCard .ligne_top.promo {
    width: 600px;
  }
  .servicesPromoCard__cta {
    width: 300px;
    height: 40px;
  }
}
/* =========================================================
   PAGE — NOUS JOINDRE
   ========================================================= */
/* =========================
   BASE (mobile)
========================= */
.cp-contact__formSplit,
.cp-contact__formPane,
.cp-contact__field {
  min-width: 0;
}

.cp-contact__input,
.cp-contact__select,
.cp-contact__textarea {
  min-width: 0;
}

.cp-contact__grid {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.cp-contact__infoCard {
  width: 280px;
  max-width: 100%;
  margin: 0 auto;
  padding: 24px;
  border-radius: 5px;
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  overflow: hidden;
  position: relative;
  height: clamp(235px, 235px + (100vw - 768px) * 0.0196078431, 240px);
}

/* grain */
.cp-contact__infoCard::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-contact__infoCard > * {
  position: relative;
  z-index: 1;
}

.ctnMessageInsatisfaction {
  max-width: 500px;
  margin: 0 auto;
  padding-left: 5px;
}

.cp-contact__infoH3 {
  position: relative;
  margin: 0 0 16px 0;
  padding-bottom: 12px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.cp-contact__infoH3::after {
  content: "";
  position: absolute;
  left: 0;
  right: 1rem;
  bottom: 0;
  height: 1px;
  background: rgba(198, 0, 0, 0.85);
  border-radius: 2px;
  opacity: 0.75;
}

.cp-contact__infoP {
  margin: 0 0 12px 0;
  font-weight: 600;
  font-size: 14px;
}

.cp-contact__hours {
  margin: 0;
  display: grid;
  gap: 8px;
  font-size: 14px;
}

.cp-contact__hoursRow {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.cp-contact__hoursRow dt,
.cp-contact__hoursRow dd {
  font-weight: 600;
}

.cp-contact__hoursRow dd {
  margin: 0;
}

.cp-contact__infoLink {
  color: var(--color-blanc);
  position: relative;
  text-decoration: none;
  transition: color 220ms ease;
}
.cp-contact__infoLink::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: left center;
  transition: opacity 220ms ease, transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) {
  .cp-contact__infoLink:hover {
    color: var(--color-rougePurered);
  }
  .cp-contact__infoLink:hover::after {
    opacity: 0.95;
    transform: scaleX(1);
  }
}
.cp-contact__infoLink:active {
  color: var(--color-rougePurered);
}
.cp-contact__infoLink:focus-visible {
  color: var(--color-rougePurered);
  outline-offset: 3px;
}
.cp-contact__infoLink:focus-visible::after {
  opacity: 0.95;
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .cp-contact__infoLink {
    transition: none;
  }
  .cp-contact__infoLink::after {
    transition: none;
  }
}

.cp-contact__infoLink--phone {
  display: inline-block;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  letter-spacing: 0.02em;
}

.cp-contact__rdvCta {
  margin-top: 24px;
  margin-bottom: 55px;
  display: flex;
  justify-content: center;
}

/* =========================================================
   DONNEZ VOTRE AVIS
   Mobile : stack (form puis Google)
   ========================================================= */
.cp-contact__avisGrid {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.cp-contact__avisH3 {
  margin: 0 0 12px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
}

.messageInsatisfaction {
  padding: 16px 0;
}

.messageInsatisfaction p {
  line-height: 24px;
}

.cp-contact-textAccent {
  margin-left: 0;
  font-size: 16px;
}

/* Texte rouge « Si quelque chose ne vous a pas plu » : sans italique, aligné à gauche.
   Sélecteur à 2 classes pour battre .servicesPromoCard__accentText (italique partagé). */
.servicesPromoCard__accentText.cp-contact-textAccent {
  font-style: normal;
  text-align: left;
}

.cp-contact__formPane--left {
  padding-bottom: 5px;
}

.cp-contact__form {
  display: grid;
  gap: 16px;
}

.cp-contact__formSplit {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  width: min(100%, 500px);
  margin-inline: auto;
}

.cp-contact__formPane {
  padding: 32px 16px;
  border-radius: 12px;
  background: var(--color-alabaster);
}

.cp-contact__field {
  display: grid;
  gap: 8px;
}

.cp-contact__field + .cp-contact__field {
  margin-top: 16px;
}

.cp-contact__field .cp-form-rdv__error-msg {
  margin-left: 4px;
}

.cp-contact__label {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  margin-left: 4px;
}

.cp-contact__input,
.cp-contact__select,
.cp-contact__textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border: 0;
  background: var(--color-blanc);
  border-radius: 10px;
  padding: 8px 10px;
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18);
  transition: box-shadow 220ms ease;
}

.cp-contact__textarea {
  min-height: 140px;
  resize: vertical;
}

.cp-contact__input:focus,
.cp-contact__select:focus,
.cp-contact__textarea:focus {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18), 0 0 0 2px rgba(43, 53, 80, 0.15);
}

/* Actions (bouton dans la colonne droite) */
.cp-contact__actions {
  margin-top: 24px;
  display: flex;
  justify-content: center;
}

.cp-contact__selectWrap {
  position: relative;
  display: block;
}

.cp-contact__select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 3rem;
}

.cp-contact__selectIcon {
  position: absolute;
  top: 50%;
  right: 12px;
  width: 18px;
  height: 18px;
  transform: translateY(-50%);
  pointer-events: none;
  opacity: 0.9;
  transition: transform 220ms ease;
}

.cp-contact__selectWrap.is-open .cp-contact__selectIcon {
  transform: translateY(-50%) rotate(90deg);
}

/* =========================================================
   GOOGLE — card avec G “clean”
   ========================================================= */
.cp-contact__googleCard {
  width: min(100%, 500px);
  margin-inline: auto;
  position: relative;
  padding: 24px 16px;
  border-radius: 12px;
  background: var(--color-alabaster);
  margin-bottom: 32px;
}

.cp-contact__googleCard::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}

.cp-contact__googleHead {
  display: flex;
  gap: 16px;
  align-items: center;
  margin-bottom: 24px;
}

.cp-contact__googleG {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
}

.cp-contact__googleText {
  margin: 0;
}

.cp-contact__googleCta {
  display: flex;
  justify-content: center;
}

.cp-contact__vosCoordonnees {
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  text-transform: uppercase;
}

.cp-contact-message-coordonnees {
  margin-top: 16px;
}

.cp-contact__problematique {
  margin-top: 16px;
}

/* HR — séparateur Form -> Google (Nous joindre) */
.cp-contact .ligne_top.promo {
  border: 0;
  height: 1px;
  width: min(70%, 500px);
  margin: 32px auto;
  background: rgba(43, 53, 80, 0.18);
  border-radius: 2px;
}

.cp-contact__problematique {
  margin-top: 32px;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-contact__grid {
    flex-direction: row;
    justify-content: center;
    align-items: stretch;
    gap: 24px;
    flex-wrap: nowrap;
  }
  .cp-section.cp-section--chapter > .cp-band.cp-bleed-contact {
    margin-bottom: 65px;
  }
  .ctnMessageInsatisfaction {
    max-width: 100%;
    margin: 0 auto;
    padding-left: 5px;
  }
  .cp-contact-textAccent {
    margin-left: 0;
  }
  .cp-contact__problematique {
    margin-top: 32px;
  }
  .cp-contact__avisH3 {
    font-size: 20px;
    line-height: 30px;
  }
  .cp-contact__formPane--left {
    padding-bottom: 115px;
  }
  .cp-contact__formPane--right {
    padding-bottom: 25px;
  }
  .cp-contact__infoH3 {
    font-size: 18px;
  }
  .cp-contact__infoH3::after {
    right: 0;
  }
  .cp-contact__infoCard {
    padding: 24px 24px 0;
    height: 220px;
    margin: 0;
  }
  .cp-contact__rdvCta {
    margin-top: 48px;
  }
  .cp-hero-top.cp-hero-top--contact .cp-hero-top__icon {
    width: 54px;
    height: 54px;
  }
  .cp-contact__formSplit {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
    width: 100%;
  }
  .cp-contact__googleG {
    width: 52px;
    height: 52px;
  }
  .cp-contact-message-coordonnees {
    margin-top: 48px;
    margin-bottom: 14px;
  }
  .cp-contact__googleCard {
    width: 100%;
    margin-inline: auto;
    position: relative;
    padding: 32px 48px;
    border-radius: 12px;
    background: var(--color-alabaster);
    margin-bottom: 48px;
  }
  .cp-contact .ligne_top.promo {
    border: 0;
    height: 1px;
    width: min(100%, 500px);
    margin: 32px auto;
    background: rgba(43, 53, 80, 0.18);
    border-radius: 2px;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-contact__grid {
    gap: 32px;
  }
  .cp-contact__formPane--left {
    padding-bottom: 148px;
  }
  .cp-contact__formPane--right {
    padding-bottom: 28px;
  }
  .cp-contact__infoCard {
    width: 305px;
    height: 240px;
    padding: 32px;
  }
  .cp-contact-textAccent {
    margin-left: 0;
  }
  .cp-contact__infoH3 {
    font-size: 20px;
  }
  .cp-hero-top.cp-hero-top--contact .cp-hero-top__icon {
    margin-top: 0;
    width: 60px;
    height: 60px;
  }
  .cp-contact-message-coordonnees {
    margin-top: 48px;
  }
  .cp-contact__avisH3 {
    font-size: 22px;
    line-height: 33px;
  }
}
/* =========================================================
   HERO TOP — NIVEAU 2 / 3
   Mobile-first scaffold canon
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-hero-top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 24px;
  width: 100%;
  margin-inline: 0; /* même largeur que preuve sociale */
  margin-left: 6px;
}

.gabarit-preuvecta__proofBlock {
  padding-inline: 5px;
}

/* Dès 430px : on annule l’offset gauche */
@media (min-width: 430px) {
  .cp-hero-top {
    margin-left: 6px;
  }
}
.cp-hero-top__title {
  font-size: 20px;
  line-height: 28px;
}

.cp-hero-top__icon {
  flex: 0 0 auto;
  width: 50px;
  height: 50px;
  margin-top: 2px;
}

.cp-hero-top--freins {
  width: 60px;
  height: 60px;
  margin-top: -4px;
}

.cp-hero-top--batterie {
  width: 45px;
  height: 45px;
  margin-top: 4px;
}

.cp-hero-top--inspection {
  margin-top: 8px;
}

.cp-hero-top--tutos-infos {
  width: 63px;
  height: 63px;
}

@media (min-width: 430px) and (max-width: 767px) {
  .cp-hero-top-stack {
    margin-top: 16px;
    width: 100%;
    max-width: 430px;
    margin-inline: auto;
  }
}
.cp-hero-top .cp-h1-sub {
  font-size: 14px;
  line-height: 21px;
}

.cp-break-mobile {
  display: block;
  height: 0;
}

/* =========================
   TABLETTE (>= t.$bp-md)
========================= */
@media (min-width: 768px) {
  .cp-hero-top {
    margin-bottom: 32px;
    margin-left: 70px;
  }
  .cp-hero-top__icon {
    width: 70px;
    height: 70px;
  }
  .cp-hero-top--tutos-infos {
    width: 88px;
    height: 88px;
  }
  .cp-hero-top-stack {
    margin-top: 24px;
  }
  .cp-hero-top .cp-breadcrumb {
    margin-top: -15px;
  }
  .cp-hero-top__title {
    font-size: 22px;
    line-height: 31px;
  }
  .cp-hero-top .cp-h1-sub {
    font-size: 16px;
    line-height: 24px;
  }
  .cp-break-mobile {
    display: none;
  }
}
/* =========================
   DESKTOP (>= t.$bp-lg)
========================= */
@media (min-width: 1024px) {
  .cp-hero-top {
    gap: 32px;
  }
  .cp-hero-top__icon {
    width: 84px;
    height: 84px;
    margin-top: 10px;
  }
  .cp-hero-top--tutos-infos {
    width: 105px;
    height: 105px;
  }
  .cp-hero-top--inspection {
    margin-top: 4px;
  }
  .cp-hero-top-stack {
    margin-top: 32px;
  }
  .cp-hero-top .cp-breadcrumb {
    margin-top: -20px;
  }
  .cp-hero-top__title {
    font-size: 24px;
    line-height: 36px;
  }
  .cp-hero-top .cp-h1-sub {
    margin-top: -5px;
    font-size: 18px;
    line-height: 27px;
  }
}
/* =========================================================
   PREUVE SOCIALE + CTA — shared
   ========================================================= */
/* =========================
   SECTION — fond platinum
   ========================= */
.cp-sectionGabarit {
  background-color: var(--color-platinum);
  padding-block-start: 32px;
}

@media (min-width: 768px) {
  .cp-sectionGabarit {
    padding-block-start: 48px;
  }
}
/* =========================
   MOBILE (base)
========================= */
.gabarit-preuvecta {
  display: grid;
  gap: 14px;
  margin: 0 auto;
}

.gabarit-preuvecta__texte {
  margin: 0;
  font-style: italic;
  font-weight: 500;
  line-height: 30px;
}

.gabarit-preuvecta__proofBlock {
  width: 100%;
  max-width: none;
  margin-inline: 0;
  display: grid;
  gap: 10px;
  justify-items: start;
}

@media (min-width: 430px) {
  .gabarit-preuvecta__proofBlock {
    max-width: 430px;
    margin-inline: auto;
  }
}
.gabarit-preuvecta__proof {
  display: grid;
  gap: 6px;
  border-left: 3px solid var(--color-rougeBrickember);
  padding-left: 16px;
}

.gabarit-preuvecta__stars {
  width: 120px;
  height: auto;
  margin-top: -10px;
  margin-left: 19px;
}

.gabarit-preuvecta__actions-ctn {
  width: 100%;
  display: flex;
  justify-content: center;
}

.gabarit-preuvecta__actions {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 24px;
  margin-bottom: 48px;
}

.gabarit-preuvecta__btn_inspection {
  width: 275px;
}

/* =========================
   TABLETTE (>= t.$bp-md)
========================= */
@media (min-width: 768px) {
  .gabarit-preuvecta {
    margin-inline: 74px;
  }
  .gabarit-preuvecta__proof-ctn {
    justify-content: flex-start;
  }
  .gabarit-preuvecta__proof {
    text-align: left;
  }
  .gabarit-preuvecta__proofBlock {
    max-width: none;
    margin-inline: 0;
  }
  .gabarit-preuvecta__texte {
    font-size: 20px;
  }
  .gabarit-preuvecta__btn_inspection {
    width: 290px;
  }
  .gabarit-preuvecta__actions-ctn {
    justify-content: flex-end;
  }
  .gabarit-preuvecta__actions {
    justify-content: flex-end;
    margin-top: 24px;
    margin-bottom: 48px;
  }
}
/* =========================
   DESKTOP (>= t.$bp-lg)
========================= */
@media (min-width: 1024px) {
  .gabarit-preuvecta__btn_inspection {
    width: 320px;
  }
  .gabarit-preuvecta__texte {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  }
  .gabarit-preuvecta__actions {
    margin-top: -60px;
  }
}
/* ==========================================================================
   SHARED — SERVICES OFFERTS
   ========================================================================== */
/* ========================================================================== */
/* MOBILE (défaut — hors media query)                                         */
/* ========================================================================== */
.gabarit-servicesofferts {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding-inline: 10px;
}

.gabarit-servicesofferts__list {
  margin-bottom: 16px;
  padding: 0;
  list-style: none;
  gap: 24px;
}

.gabarit-servicesofferts__list--mobile {
  display: grid;
}

.gabarit-servicesofferts__list--full {
  display: none;
}

.gabarit-servicesofferts__item {
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  line-height: 1.35;
  padding-bottom: 12px;
}

.gabarit-servicesofferts__item:not(:last-child) {
  border-bottom: 1px solid rgba(43, 53, 80, 0.08);
}

.gabarit-servicesofferts__bullet {
  flex: 0 0 auto;
  width: 15px;
  height: 11px;
  margin-top: 6px;
}

.gabarit-servicesofferts__bulletImg {
  width: 100%;
  height: 100%;
  display: block;
}

.gabarit-servicesofferts__itemText {
  flex: 1 1 auto;
  font-weight: 500;
}

.gabarit-servicesofferts__media {
  border-radius: 0;
  overflow: hidden;
}

.gabarit-servicesofferts__media {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 0;
}

@media (min-width: 450px) {
  .gabarit-servicesofferts__media {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow: hidden;
    padding-bottom: 20px;
  }
}
.gabarit-servicesofferts__mediaInner {
  width: 100%;
}

@media (min-width: 450px) {
  .gabarit-servicesofferts__mediaInner {
    max-width: 450px;
    margin-inline: auto;
    border-radius: 5px;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.12);
    overflow: hidden;
  }
  .gabarit-servicesofferts__mediaInner img {
    border-radius: 0;
  }
}
.gabarit-servicesofferts__img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.gabaritCol__servicesPuces {
  max-width: 450px;
  margin-left: -7px;
}

/* ========================================================================== */
/* TABLETTE — (bp-md → bp-lg-1)                                               */
/* Un seul groupe tablette (switch listes + styles tablette)                  */
/* ========================================================================== */
@media (min-width: 768px) and (max-width: 1023px) {
  .gabarit-servicesofferts {
    max-width: 450px;
    margin-inline: auto;
  }
  .gabarit-servicesofferts__list {
    margin-left: -2px;
  }
  .gabarit-servicesofferts__list--mobile {
    display: none;
  }
  .gabarit-servicesofferts__list--full {
    display: grid;
  }
  .gabarit-servicesofferts__bullet {
    margin-left: -20px;
    margin-top: 9px;
  }
  .gabarit-servicesofferts__itemText {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 27px;
  }
  .gabarit-servicesofferts__media {
    width: 100%;
    max-width: 450px;
    margin-inline: 0;
    margin-bottom: 0;
  }
  .gabarit-servicesofferts__img {
    height: auto;
    border-radius: 5px;
  }
}
/* ========================================================================== */
/* LARGE — (≥ bp-lg)                                                          */
/* Un seul groupe large (2 colonnes)                                          */
/* ========================================================================== */
@media (min-width: 1024px) {
  .gabarit-servicesofferts {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 48px;
    margin-left: 5px;
    padding-inline: 20px;
  }
  .gabarit-servicesofferts__list {
    margin-left: 0;
    max-width: 560px;
  }
  .gabarit-servicesofferts__list--mobile {
    display: none;
  }
  .gabarit-servicesofferts__list--full {
    display: grid;
  }
  .gabarit-servicesofferts__bullet {
    margin-left: -16px;
    margin-top: 15px;
  }
  .gabarit-servicesofferts__itemText {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 36px;
  }
  .gabarit-servicesofferts__media {
    width: auto;
    max-width: 460px;
    margin-inline: 0;
    margin-bottom: 0;
    border-radius: 5px;
  }
  .gabarit-servicesofferts__img {
    height: auto;
  }
}
/* ========================================================================== */
/* XL — (≥ bp-xl)                                                             */
/* Un seul groupe XL                                                          */
/* ========================================================================== */
@media (min-width: 1280px) {
  .gabarit-servicesofferts__media {
    max-width: 460px;
  }
}
.gabarit-benefval-section {
  background-color: var(--color-bleuFond);
  color: var(--color-blanc);
  margin-top: -55px;
  padding: 32px 0 24px 0;
  position: relative;
}
.gabarit-benefval-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.gabarit-benefval {
  display: grid;
  gap: 18px;
  position: relative;
  z-index: 1;
}

.gabarit-benefval__grid {
  display: grid;
  gap: 22px;
  align-items: start;
}

.gabarit-benefval__col {
  min-width: 0;
}

/* Séparateur blanc horizontal entre Bénéfices et Valeur ajoutée — mobile seulement
   (les colonnes s'empilent ; désactivé dès >=768px où elles sont côte à côte). */
.gabarit-benefval__col:nth-child(2)::before {
  content: "";
  display: block;
  height: 1px;
  width: 80%;
  max-width: 320px;
  margin: 0 auto 16px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.9) 25%, rgba(255, 255, 255, 0.9) 75%, transparent);
}

.gabarit-benefval__title {
  margin: 0;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 18px;
  padding: 24px 0 16px 0;
}

.gabarit-benefval__title::after {
  content: "";
  display: block;
  height: 1px;
  width: 72px;
  background: linear-gradient(90deg, transparent, rgba(220, 40, 40, 0.85) 25%, rgba(220, 40, 40, 0.85) 75%, transparent);
  margin: 8px auto 0;
}

@media (min-width: 768px) {
  .gabarit-benefval__title::after {
    width: 110px;
    margin-top: 10px;
  }
}
@media (min-width: 1024px) {
  .gabarit-benefval__title::after {
    width: 150px;
    margin-top: 12px;
  }
}
.gabarit-benefval__list {
  margin: 0;
  margin-top: 24px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.gabarit-benefval__item {
  margin-left: 4px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  line-height: 35px;
}

.gabarit-benefval__bullet {
  width: 17px;
  height: 17px;
  flex: 0 0 auto;
  margin-top: 8px;
}

.gabarit-benefval__text {
  min-width: 0;
}

.gabarit-benefval__col:nth-child(2) .gabarit-benefval__list {
  padding-bottom: 24px;
}

.gabarit-benefval__cta {
  display: flex;
  justify-content: center;
  margin-bottom: 48px;
}

.gabarit-benefval-section .gabarit-benefval__cta .cp-btn,
.gabarit-benefval-section .gabarit-benefval__cta a,
.gabarit-benefval-section .gabarit-benefval__cta button {
  position: relative;
  overflow: hidden;
}

/* Underline signature (invisible au repos) */
.gabarit-benefval-section .gabarit-benefval__cta .cp-btn::after,
.gabarit-benefval-section .gabarit-benefval__cta a::after,
.gabarit-benefval-section .gabarit-benefval__cta button::after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  top: auto;
  bottom: -3px;
  height: 6px;
  background: linear-gradient(110deg, transparent 0%, rgba(198, 0, 0, 0.4) 30%, rgb(198, 0, 0) 50%, rgba(198, 0, 0, 0.4) 70%, transparent 100%);
  border-radius: 100px;
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 280ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 220ms ease;
  pointer-events: none;
}

/* Hover desktop seulement */
@media (hover: hover) and (pointer: fine) {
  .gabarit-benefval-section .gabarit-benefval__cta .cp-btn:hover {
    box-shadow: none;
  }
  .gabarit-benefval-section .gabarit-benefval__cta .cp-btn:hover::after,
  .gabarit-benefval-section .gabarit-benefval__cta a:hover::after,
  .gabarit-benefval-section .gabarit-benefval__cta button:hover::after {
    opacity: 1;
    transform: scaleX(1);
  }
}
/* Focus clavier */
.gabarit-benefval-section .gabarit-benefval__cta .cp-btn:focus-visible::after,
.gabarit-benefval-section .gabarit-benefval__cta a:focus-visible::after,
.gabarit-benefval-section .gabarit-benefval__cta button:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
}

/* Tap mobile/tablette */
.gabarit-benefval-section .gabarit-benefval__cta .cp-btn:active::after,
.gabarit-benefval-section .gabarit-benefval__cta a:active::after,
.gabarit-benefval-section .gabarit-benefval__cta button:active::after {
  opacity: 1;
  transform: scaleX(1);
}

/* Note (texte du bas) */
.gabarit-benefval__note {
  margin: 0;
  text-align: center;
  opacity: 0.85;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: -20px;
}

/* =========================
   TABLETTE — MD
   ========================= */
@media (min-width: 768px) {
  .gabarit-benefval-section {
    padding: 48px;
  }
  /* Séparateur mobile uniquement — masqué quand les colonnes sont côte à côte */
  .gabarit-benefval__col:nth-child(2)::before {
    display: none;
  }
  .gabarit-benefval__grid {
    grid-template-columns: 1fr 1fr;
    display: flex;
    justify-content: center;
    gap: 24px;
  }
  .gabarit-benefval__col {
    min-width: 300px;
    padding-bottom: 15px;
  }
  .gabarit-benefval__col1 {
    padding-bottom: 24px;
  }
  .gabarit-benefval__title {
    text-align: center;
  }
  .gabarit-benefval__col:first-child .gabarit-benefval__title {
    font-size: 20px;
  }
  .gabarit-benefval__col:nth-child(2) .gabarit-benefval__title {
    font-size: 20px;
  }
  .gabarit-benefval__item {
    margin-left: 0;
  }
  .gabarit-benefval__bullet {
    width: 20px;
    height: 20px;
  }
  .gabarit-benefval__cta {
    justify-content: center;
  }
}
/* =========================
   DESKTOP — LG
   ========================= */
@media (min-width: 1024px) {
  .gabarit-benefval__col {
    max-width: 475px;
    padding-bottom: 35px;
    padding-inline: 25px;
  }
  .gabarit-benefval__col1 {
    padding-bottom: 32px;
  }
  .gabarit-benefval__title {
    font-size: 22px;
  }
  .gabarit-benefval__col:first-child .gabarit-benefval__title {
    margin-bottom: 32px;
  }
  .gabarit-benefval__col:nth-child(2) .gabarit-benefval__title {
    margin-bottom: 32px;
  }
  .gabarit-benefval__list {
    gap: 12px;
  }
  .gabarit-benefval__bullet {
    width: 25px;
    height: 25px;
    margin-top: 3.7px;
  }
  .gabarit-benefval__text {
    font-size: 18px;
  }
  .gabarit-benefval__cta {
    margin-top: 24px;
  }
}
/* =========================
   TRÈS GRAND — XL
   ========================= */
@media (min-width: 1280px) {
  .gabarit-benefval__grid {
    gap: 64px;
  }
  .gabarit-benefval__col {
    max-width: 500px;
  }
}
/* =========================================================
   FORFAITS — Section assembleur 
   ========================================================= */
.cp-forfaits {
  padding-bottom: 48px;
}
.cp-forfaits .cp-forfaits__band {
  margin-bottom: 16px;
  background: var(--color-platinum);
}
.cp-forfaits {
  /* Pneus : bande bleue (alignée sur médias sociaux) */
}
.cp-forfaits.cp-forfaits--band-bleu .cp-forfaits__band {
  background: var(--color-bleuFond);
  position: relative;
}
.cp-forfaits.cp-forfaits--band-bleu .cp-forfaits__band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}
.cp-forfaits.cp-forfaits--band-bleu .cp-forfaits__band-inner {
  position: relative;
  z-index: 1;
}
.cp-forfaits.cp-forfaits--band-bleu .cp-forfaits__band-title {
  color: var(--color-blanc);
}
.cp-forfaits .cp-forfaits__band-inner {
  padding: 8px 16px;
  display: block;
  width: 100%;
  min-width: 0;
}
.cp-forfaits .cp-forfaits__band-title {
  margin: 0;
  min-width: 0;
  text-align: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  /* Thème via variable */
  color: var(--cp-accent);
}
.cp-forfaits {
  /* <br> injecté après le premier + (visible <=375px) */
}
.cp-forfaits .cp-forfaits__band-br {
  display: inline;
}
@media (min-width: 376px) {
  .cp-forfaits .cp-forfaits__band-br {
    display: none;
  }
}
.cp-forfaits .cp-forfaits__swipe-hint {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 16px;
  opacity: 0.8;
  color: var(--color-grisGunmetal);
}
.cp-forfaits .cp-forfaits__swipe-icon {
  width: 18px;
  height: 18px;
  display: block;
}
.cp-forfaits .cp-forfaits__swipe-text {
  margin: 0;
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 21px;
}
.cp-forfaits .cp-forfaits__viewport {
  position: relative;
}
.cp-forfaits {
  /* =======================================================
     CONTRÔLES (tablette+)
     ======================================================= */
}
.cp-forfaits .cp-forfaits__controls {
  display: none;
}
.cp-forfaits .cp-forfaits__arrow,
.cp-forfaits .cp-forfaits__dot {
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.cp-forfaits {
  /* =======================================================
     ICONS — hooks dédiés (global + individuel)
     ======================================================= */
}
.cp-forfaits .cp-forfaits__arrow-icon,
.cp-forfaits .cp-forfaits__dot-icon {
  display: block;
  opacity: 0.8;
}
.cp-forfaits .cp-forfaits__arrow-icon {
  width: 30px;
  height: 30px;
}
.cp-forfaits .cp-forfaits__dot-icon {
  width: 16px;
  height: 16px;
}
.cp-forfaits .cp-forfaits__arrow-icon--next {
  transform: rotate(180deg);
}

.cp-forfaits__carousel .cp-carousel__track {
  padding-bottom: 8px;
}

/* =========================================================
   TABLETTE (>=768)
   ========================================================= */
@media (min-width: 768px) {
  .cp-forfaits .cp-forfaits__arrow,
  .cp-forfaits .cp-forfaits__dot {
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    /* EXACT comme Avis */
  }
  .cp-forfaits .cp-forfaits__arrow .cp-forfaits__arrow,
  .cp-forfaits .cp-forfaits__dot .cp-forfaits__arrow {
    width: 44px;
    height: 44px;
  }
  .cp-forfaits .cp-forfaits__arrow,
  .cp-forfaits .cp-forfaits__dot {
    /* EXACT comme Avis */
  }
  .cp-forfaits .cp-forfaits__arrow .cp-forfaits__dot,
  .cp-forfaits .cp-forfaits__dot .cp-forfaits__dot {
    width: 26px;
    height: 26px;
  }
  .cp-forfaits .cp-forfaits__arrow,
  .cp-forfaits .cp-forfaits__dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    position: relative;
    transition: background-color 220ms ease, box-shadow 260ms ease, transform 180ms ease, opacity 160ms ease;
  }
  .cp-forfaits {
    /* =========================================================
       FIX GEOMETRIE CONTROLS — pour matcher AVIS
       - Arrow: 44x44
       - Dot: 26x26
       - Le bouton ne doit pas shrink-wrap sur le SVG 30x30
       ========================================================= */
  }
}
@media (min-width: 768px) and (hover: hover) and (pointer: fine) {
  .cp-forfaits .cp-forfaits__arrow:hover,
  .cp-forfaits .cp-forfaits__dot:hover {
    background: rgba(242, 243, 244, 0.92);
    transform: translateY(-1px);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.7), 0 14px 26px rgba(0, 0, 0, 0.16), 0 3px 10px rgba(0, 0, 0, 0.1);
    opacity: 1;
  }
}
@media (min-width: 768px) {
  .cp-forfaits .cp-forfaits__arrow:active,
  .cp-forfaits .cp-forfaits__dot:active {
    transform: translateY(0);
    box-shadow: 0 0 0 4px rgba(242, 243, 244, 0.55), 0 8px 16px rgba(0, 0, 0, 0.16), 0 2px 8px rgba(0, 0, 0, 0.1);
  }
  .cp-forfaits .cp-forfaits__arrow:focus-visible,
  .cp-forfaits .cp-forfaits__dot:focus-visible {
    outline: 2px solid rgba(43, 53, 80, 0.6);
    outline-offset: 3px;
    background: rgba(242, 243, 244, 0.95);
    box-shadow: 0 0 0 6px rgba(242, 243, 244, 0.85), 0 14px 26px rgba(0, 0, 0, 0.16), 0 3px 10px rgba(0, 0, 0, 0.1);
  }
  .cp-forfaits .cp-forfaits__band {
    margin-bottom: 48px;
  }
  .cp-forfaits .cp-forfaits__band-inner {
    padding: 12px 16px;
  }
  .cp-forfaits .cp-forfaits__band-title {
    font-size: 18px;
    line-height: 27px;
  }
  .cp-forfaits .cp-forfaits__swipe-hint {
    display: none;
  }
  .cp-forfaits .cp-forfaits__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 12px 0 48px 0;
  }
  .cp-forfaits .cp-forfaits__arrow-icon-left svg {
    transform: rotate(180deg);
  }
  .cp-forfaits .cp-forfaits__arrow-icon svg {
    width: 30px;
    height: 30px;
  }
  .cp-forfaits .cp-forfaits__arrow-icon svg path {
    fill: var(--color-grisGunmetal);
    opacity: 0.8;
  }
  .cp-forfaits .cp-forfaits__dots {
    display: flex;
    gap: 32px;
  }
  .cp-forfaits .cp-forfaits__dot-icon {
    width: 24px;
    height: 24px;
    display: inline-block;
  }
  .cp-forfaits .cp-forfaits__dot-icon svg {
    width: 100%;
    height: 100%;
    display: block;
  }
  .cp-forfaits .cp-forfaits__dot-icon--outline svg :is(path, circle, rect, polygon, line, polyline, ellipse) {
    fill: var(--color-grisGunmetal);
    stroke: var(--color-grisGunmetal);
    opacity: 0.8;
  }
  .cp-forfaits .cp-forfaits__dot-icon--filled svg :is(path, circle, rect, polygon, line, polyline, ellipse) {
    fill: var(--color-grisGunmetal);
    stroke: var(--color-grisGunmetal);
    opacity: 0.8;
  }
  .cp-forfaits .cp-forfaits__dot-icon--filled svg {
    overflow: visible;
  }
  .cp-forfaits .cp-forfaits__dot-icon--filled {
    display: none;
  }
  .cp-forfaits .cp-forfaits__dot.is-active .cp-forfaits__dot-icon--outline {
    display: none;
  }
  .cp-forfaits .cp-forfaits__dot.is-active .cp-forfaits__dot-icon--filled {
    display: inline-block;
  }
  .cp-forfaits .cp-forfaits__arrow {
    width: 44px;
    height: 44px;
  }
  .cp-forfaits .cp-forfaits__dot {
    width: 26px;
    height: 26px;
  }
}
/* =========================================================
   DESKTOP LG (>=1024)
   ========================================================= */
@media (min-width: 1024px) {
  .cp-forfaits .cp-forfaits__band {
    margin-bottom: 64px;
  }
  .cp-forfaits .cp-forfaits__band-inner {
    padding: 16px 24px;
  }
  .cp-forfaits .cp-forfaits__band-title {
    font-size: 24px;
    line-height: 27px;
  }
  .cp-forfaits {
    /* Icons — desktop */
  }
  .cp-forfaits .cp-forfaits__arrow-icon {
    width: 30px;
    height: 30px;
  }
  .cp-forfaits .cp-forfaits__dot-icon {
    width: 20px;
    height: 20px;
  }
  .cp-forfaits .cp-forfaits__controls {
    gap: 48px;
  }
  .cp-forfaits .cp-forfaits__dots {
    gap: 48px;
  }
}
/* =========================================================
   XL (>=1280)
   ========================================================= */
@media (min-width: 1280px) {
  .cp-forfaits .cp-forfaits__band-title {
    font-size: 24px;
    line-height: 33px;
  }
  .cp-forfaits {
    /* Icons — xl */
  }
  .cp-forfaits .cp-forfaits__arrow-icon {
    width: 30px;
    height: 30px;
  }
  .cp-forfaits .cp-forfaits__dot-icon {
    width: 22px;
    height: 22px;
  }
}
/* =========================================================
   FORFAIT CARD — carte indépendante 
   ========================================================= */
.cp-forfait-card {
  border-radius: 5px;
  background: var(--color-alabaster);
}

.cp-forfait-card__inner {
  padding: 16px;
  background-color: var(--color-platinum);
  border-radius: 8px;
  max-width: 260px;
  margin: 0 auto;
}

.cp-forfait-card__title {
  margin: 12px 0 16px 0;
  text-align: center;
  font-size: 20px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* Accordéons */
.cp-forfait-card__sections {
  display: grid;
  gap: 12px;
  margin-bottom: 8px;
}

.cp-forfait-card__section {
  overflow: hidden;
}

.cp-forfait-card__section-summary {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 5px;
  margin-left: 0.3em;
  list-style: none;
  cursor: pointer;
  padding: 8px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  min-width: 0;
}

.cp-forfait-card__section summary::-webkit-details-marker {
  display: none;
}

.cp-forfait-card__section-title {
  text-align: center;
  min-width: 0;
  font-size: 12px;
  text-transform: uppercase;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
}

.cp-forfait-card__section-arrow {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  display: block;
  margin-top: 0.1rem;
  opacity: 0.8;
}

.cp-forfait-card__section-text p {
  font-size: 14px;
  padding-top: 5px;
  padding-bottom: 0;
  margin-bottom: 0;
}

.cp-forfait-card__section-body {
  padding: 0 12px 0 12px;
}

.cp-forfait-card__section-text {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 21px;
  color: var(--color-bleuTexte);
}

.cp-forfait-card__bottom {
  display: grid;
}

.cp-forfait-card__social-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--color-grisGunmetal);
  opacity: 0.8;
  display: block;
}

.cp-forfait-card__popular {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.cp-forfait-card__popular-title {
  margin: 0 auto;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 12px;
  line-height: 21px;
  text-align: center;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
}

.cp-forfait-card__popular-sub {
  margin: 0;
  margin-bottom: 6px;
  text-align: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  color: var(--cp-accent);
}

/* =========================================================
   CTA — base neutre (tous formats)
   ========================================================= */
.cp-forfait-card__cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border-radius: 5px;
  overflow: hidden;
  filter: none;
  animation: none;
  transform: none;
  transition: none;
}

.cp-forfait-card__cta-bg {
  display: block;
  width: 150px;
  height: auto;
  transform-origin: center;
  transform: rotate(0deg) scale(1);
  transition: none;
}

.cp-forfait-card__cta-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 11px; /* mobile au repos — 2px de moins (tablette/desktop redéclarent 13px) */
  line-height: 18px;
  text-transform: uppercase;
  text-align: center;
  color: var(--cp-accent);
  padding: 8px;
  transform: scale(1);
  transform-origin: center;
  transition: none;
  pointer-events: none;
}

/* =========================================================
   Animations / interactions : inchangées
   ========================================================= */
@keyframes cp-cta-pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.03);
  }
  100% {
    transform: scale(1);
  }
}
@media (hover: none) and (pointer: coarse) {
  .cp-forfait-card__cta {
    filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.18));
    animation: none;
    transform-origin: center;
    transition: transform 0.12s ease-out, filter 0.12s ease-out;
  }
  .cp-forfait-card__cta:active {
    transform: translateY(2px) scale(0.98);
    filter: drop-shadow(0 3px 8px rgba(0, 0, 0, 0.25));
  }
}
@media (hover: none) and (pointer: coarse) and (max-width: 767px) {
  .cp-forfait-card__cta {
    animation: cp-cta-pulse 4s ease-in-out infinite;
  }
}
@media (prefers-reduced-motion: reduce) {
  .cp-forfait-card__cta {
    animation: none !important;
    transition: none !important;
  }
  .cp-forfait-card__cta-bg,
  .cp-forfait-card__cta-text {
    transition: none !important;
    transform: none !important;
  }
}
@media (hover: hover) and (pointer: fine) {
  .cp-forfait-card__cta {
    filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.18));
    animation: none;
    transition: transform 0.12s ease-out, filter 0.12s ease-out;
  }
  .cp-forfait-card__cta:active {
    transform: translateY(2px) scale(0.98);
    filter: drop-shadow(0 3px 8px rgba(0, 0, 0, 0.25));
  }
  .cp-forfait-card__cta-bg {
    transition: transform 0.18s ease-out;
    will-change: transform;
  }
  .cp-forfait-card__cta:has(.cp-forfait-card__cta-bg:hover) .cp-forfait-card__cta-bg {
    transform: rotate(170deg) scale(1.03);
    transition: transform 0.6s ease;
  }
  .cp-forfait-card__cta-text {
    transition: transform 0.2s ease-out;
    will-change: transform;
  }
  .cp-forfait-card__cta:has(.cp-forfait-card__cta-bg:hover) .cp-forfait-card__cta-text {
    transform: scale(1.08);
    transition: transform 0.25s ease;
  }
  .cp-forfait-card__cta:focus-visible {
    outline: 3px solid var(--cp-accent);
    outline-offset: 3px;
  }
}
.cp-forfait-card__meta {
  display: flex;
  gap: 24px;
  justify-content: center;
}

.cp-forfait-card__meta-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  gap: 0;
  min-width: 44px;
  min-height: 44px;
  padding: 0;
  background: none;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  color: var(--color-bleuTexte);
  transition: box-shadow 0.2s ease;
}

.cp-forfait-card__meta-btn img {
  height: 30px;
  width: 30px;
  display: block;
  opacity: 0.8;
  transition: transform 0.2s ease, opacity 0.2s ease, filter 0.2s ease;
}

.cp-forfait-card__meta-btn:hover {
  box-shadow: 0 2px 12px rgba(43, 53, 80, 0.16);
}

.cp-forfait-card__meta-btn:hover img {
  opacity: 1;
  transform: scale(1.06);
  filter: brightness(1.05);
}

.cp-forfait-card__meta-btn:active img {
  transform: scale(0.96);
  opacity: 0.92;
}

.cp-forfait-card__meta-btn:focus-visible {
  outline: 3px solid var(--cp-accent, #1f6fb2);
  outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  .cp-forfait-card__meta-btn,
  .cp-forfait-card__meta-btn img {
    transition: none;
  }
  .cp-forfait-card__meta-btn:hover img,
  .cp-forfait-card__meta-btn:active img {
    transform: none;
  }
}
/* =========================================================
   TABLETTE (>=768)
   ========================================================= */
@media (min-width: 768px) {
  .cp-forfait-card__layout {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    padding: 16px 30px 28px 24px;
    flex-wrap: nowrap;
  }
  .cp-forfait-card__main {
    flex: 0 1 55%;
    max-width: 55%;
    min-width: 0;
  }
  .cp-forfait-card__bottom {
    flex: 0 1 40%;
    min-width: 0;
  }
  .cp-forfait-card__bottom {
    display: flex;
    flex-direction: column-reverse;
    justify-content: center;
    align-items: center;
    margin-top: 20px;
  }
  .cp-forfait-card__inner {
    max-width: 700px;
  }
  .cp-forfait-card__title {
    margin: 12px 0 16px 0;
    font-size: 24px;
  }
  .cp-forfait-card__sections {
    gap: 16px;
  }
  .cp-forfait-card--accordion-count-2 .cp-forfait-card__sections {
    margin-top: 40px;
  }
  .cp-forfait-card__section-title {
    font-size: 14px;
    line-height: 21px;
  }
  .cp-forfait-card__section-arrow {
    width: 20px;
    height: 20px;
  }
  .cp-forfait-card__section-text {
    text-align: center;
    margin-top: 8px;
    line-height: 24px;
  }
  .cp-forfait-card__aside {
    margin-top: -5px;
  }
  .cp-forfait-card__popular {
    gap: 0;
    margin-top: 40px;
  }
  .cp-forfait-card__popular-title {
    font-size: 14px;
  }
  .cp-forfait-card__popular-sub {
    margin: 8px 0 14px 0;
    font-size: 16px;
  }
  .cp-forfait-card__cta {
    justify-self: center;
    width: fit-content;
    margin-top: -20px;
  }
  .cp-forfait-card__cta-bg {
    width: 160px;
  }
  .cp-forfait-card__cta-text {
    font-size: 13px;
  }
  .cp-forfait-card__meta {
    margin-top: 24px;
  }
}
/* =========================================================
   DESKTOP LG (>=1024)
   ========================================================= */
@media (min-width: 1024px) {
  .cp-forfait-card__layout {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    padding: 16px 30px 28px 24px;
    flex-wrap: nowrap;
  }
  .cp-forfait-card__main {
    flex: 0 1 55%;
    max-width: 55%;
    min-width: 0;
  }
  .cp-forfait-card__bottom {
    flex: 0 1 40%;
    min-width: 0;
  }
  .cp-forfait-card__bottom {
    display: flex;
    flex-direction: column-reverse;
    justify-content: center;
    align-items: center;
    margin-top: 20px;
  }
  .cp-forfait-card__inner {
    max-width: 700px;
  }
  .cp-forfait-card__title {
    margin: 12px 0 16px 0;
    font-size: 24px;
  }
  .cp-forfait-card__sections {
    gap: 16px;
  }
  .cp-forfait-card--accordion-count-2 .cp-forfait-card__sections {
    margin-top: 40px;
  }
  .cp-forfait-card__section-title {
    font-size: 14px;
    line-height: 21px;
  }
  .cp-forfait-card__section-arrow {
    width: 20px;
    height: 20px;
  }
  .cp-forfait-card__section-text {
    text-align: center;
    margin-top: 8px;
    line-height: 24px;
  }
  .cp-forfait-card__aside {
    margin-top: -5px;
  }
  .cp-forfait-card__popular {
    gap: 0;
    margin-top: 40px;
  }
  .cp-forfait-card__popular-title {
    font-size: 14px;
  }
  .cp-forfait-card__popular-sub {
    margin: 8px 0 14px 0;
    font-size: 16px;
  }
  .cp-forfait-card__cta {
    justify-self: center;
    width: fit-content;
    margin-top: -20px;
  }
  .cp-forfait-card__cta-bg {
    width: 160px;
  }
  .cp-forfait-card__cta-text {
    font-size: 13px;
  }
  .cp-forfait-card__meta {
    margin-top: 24px;
  }
}
/* =========================================================
   XL (>=1280)
   ========================================================= */
@media (min-width: 1280px) {
  .cp-forfait-card__layout {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    padding: 16px 30px 28px 24px;
    flex-wrap: nowrap;
  }
  .cp-forfait-card__main {
    flex: 0 1 55%;
    max-width: 55%;
    min-width: 0;
  }
  .cp-forfait-card__bottom {
    flex: 0 1 40%;
    min-width: 0;
  }
  .cp-forfait-card__bottom {
    display: flex;
    flex-direction: column-reverse;
    justify-content: center;
    align-items: center;
    margin-top: 20px;
  }
  .cp-forfait-card__inner {
    max-width: 700px;
  }
  .cp-forfait-card__title {
    margin: 12px 0 16px 0;
    font-size: 24px;
  }
  .cp-forfait-card__sections {
    gap: 16px;
  }
  .cp-forfait-card--accordion-count-2 .cp-forfait-card__sections {
    margin-top: 40px;
  }
  .cp-forfait-card__section-title {
    font-size: 14px;
    line-height: 21px;
  }
  .cp-forfait-card__section-arrow {
    width: 20px;
    height: 20px;
  }
  .cp-forfait-card__section-text {
    text-align: center;
    margin-top: 8px;
    line-height: 24px;
  }
  .cp-forfait-card__aside {
    margin-top: -5px;
  }
  .cp-forfait-card__popular {
    gap: 0;
    margin-top: 40px;
  }
  .cp-forfait-card__popular-title {
    font-size: 14px;
  }
  .cp-forfait-card__popular-sub {
    margin: 8px 0 14px 0;
    font-size: 16px;
  }
  .cp-forfait-card__cta {
    justify-self: center;
    width: fit-content;
    margin-top: -20px;
  }
  .cp-forfait-card__cta-bg {
    width: 160px;
  }
  .cp-forfait-card__cta-text {
    font-size: 13px;
  }
  .cp-forfait-card__meta {
    margin-top: 24px;
  }
}
/* =========================================================
   CP CAROUSEL — moteur commun (neutre)
   Fichier: components/shared/carousel/carousel.scss
   ========================================================= */
.cp-carousel .cp-carousel__viewport {
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.cp-carousel {
  /* ✅ Cache le scrollbar (Chrome/Safari) */
}
.cp-carousel .cp-carousel__viewport::-webkit-scrollbar {
  height: 0;
}
.cp-carousel .cp-carousel__viewport::-webkit-scrollbar-thumb {
  background: transparent;
}
.cp-carousel .cp-carousel__viewport::-webkit-scrollbar-track {
  background: transparent;
}
.cp-carousel .cp-carousel__track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  gap: 24px;
  overflow: visible; /* ✅ plus scroll ici */
}
.cp-carousel .cp-carousel__slide {
  scroll-snap-align: start;
  margin-bottom: 10px;
}

/* =========================================================
   MÉDIAS SOCIAUX — composante réutilisable (mobile-first)
   ========================================================= */
.cp-medias-sociaux {
  background: var(--color-platinum);
  padding-bottom: 48px;
  /* =========================
     BANDE (BLEED)
     ========================= */
}
.cp-medias-sociaux .cp-medias-sociaux__head-title-main {
  display: block;
}
.cp-medias-sociaux .cp-medias-sociaux__head-title-sub {
  display: block;
  font-weight: 600;
  opacity: 0.85;
  letter-spacing: 1px;
}
.cp-medias-sociaux .cp-medias-sociaux__band {
  width: 100%;
  background: var(--color-bleuFond);
  margin-bottom: 24px;
  position: relative;
  /* grain */
}
.cp-medias-sociaux .cp-medias-sociaux__band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}
.cp-medias-sociaux .cp-medias-sociaux__band-title {
  margin: 0;
  padding: 16px 0;
  text-align: center;
  letter-spacing: 0.05em;
  position: relative;
  z-index: 1;
  color: var(--color-blanc);
}
.cp-medias-sociaux {
  /* =========================
     INTRO H3
     ========================= */
}
.cp-medias-sociaux .cp-medias-sociaux__intro {
  margin-bottom: 48px;
  padding-top: 12px;
}
.cp-medias-sociaux .cp-medias-sociaux__intro-title {
  text-align: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 21px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-bleuTexte);
  margin: 0;
}
.cp-medias-sociaux .cp-medias-sociaux__intro-title::after {
  content: "";
  display: block;
  height: 2px;
  width: 110px;
  background: linear-gradient(90deg, transparent, rgba(180, 20, 20, 0.65) 25%, rgba(180, 20, 20, 0.65) 75%, transparent);
  margin: 10px auto 0;
}
.cp-medias-sociaux .cp-medias-sociaux__intro-br {
  display: inline;
}
@media (min-width: 400px) {
  .cp-medias-sociaux .cp-medias-sociaux__intro-br {
    display: none;
  }
}
.cp-medias-sociaux .cp-medias-sociaux__block {
  margin-bottom: 48px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  min-width: 0;
}
.cp-medias-sociaux .cp-medias-sociaux__head,
.cp-medias-sociaux .cp-medias-sociaux__articles,
.cp-medias-sociaux .cp-medias-sociaux__tiktok-grid {
  width: 100%;
  min-width: 0;
}
.cp-medias-sociaux .cp-medias-sociaux__head {
  display: flex;
  align-items: center;
  gap: 8px;
  max-width: 500px;
  width: 100%;
  margin-inline: auto;
  justify-content: flex-start;
  margin-bottom: 24px;
}
.cp-medias-sociaux .cp-medias-sociaux__head-icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background: rgba(43, 53, 80, 0.07);
  border-radius: 10px;
  padding: 4px;
}
.cp-medias-sociaux .cp-medias-sociaux__head-icon svg {
  width: 34px;
  height: 34px;
  display: block;
}
.cp-medias-sociaux .cp-medias-sociaux__head-title {
  margin: 0;
  letter-spacing: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 17px;
  font-weight: 600;
  line-height: 1.3;
}
.cp-medias-sociaux {
  /* =========================
     ARTICLES (YouTube / Tout sur)
     - base: pile verticale, colonne centrée
     ========================= */
}
.cp-medias-sociaux .cp-medias-sociaux__articles {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 32px;
  max-width: 500px;
  margin-inline: auto;
  justify-items: center;
}
.cp-medias-sociaux .cp-medias-sociaux__article {
  width: 100%;
  max-width: 500px;
  min-width: 0;
}
.cp-medias-sociaux .cp-medias-sociaux__article-title {
  margin: 0 0 6px 0;
  padding-left: 0;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.cp-medias-sociaux .cp-medias-sociaux__thumb-link {
  display: block;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  border-radius: 8px;
  text-decoration: none;
  background: transparent;
}
.cp-medias-sociaux .cp-medias-sociaux__thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cp-medias-sociaux .cp-medias-sociaux__meta {
  padding-left: 5px;
  padding-top: 12px;
  min-height: 92.2px;
}
.cp-medias-sociaux .cp-medias-sociaux__desc {
  margin-top: 0;
  max-width: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.6;
  max-height: 3.2em;
  /* Hooks JS */
}
.cp-medias-sociaux .cp-medias-sociaux__desc.is-expanded {
  -webkit-line-clamp: unset;
  max-height: none;
  overflow: visible;
  display: block;
}
.cp-medias-sociaux .cp-medias-sociaux__more {
  margin-top: 8px;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  color: var(--color-rougePurered);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.cp-medias-sociaux .cp-medias-sociaux__more.is-hidden {
  display: none;
}
.cp-medias-sociaux {
  /* Focus visible */
}
.cp-medias-sociaux .cp-medias-sociaux__thumb-link:focus-visible,
.cp-medias-sociaux .cp-medias-sociaux__more:focus-visible,
.cp-medias-sociaux .cp-medias-sociaux__tiktok-card:focus-visible {
  outline: 2px solid var(--color-grisGunmetal);
  outline-offset: 3px;
}
.cp-medias-sociaux {
  /* =========================================================
   EFFECTS — TILES 
   ========================================================= */
}
.cp-medias-sociaux .cp-medias-sociaux__thumb-link,
.cp-medias-sociaux .cp-medias-sociaux__tiktok-card {
  transition: transform 160ms ease, box-shadow 240ms ease, filter 220ms ease;
  -webkit-tap-highlight-color: transparent;
  will-change: transform, box-shadow;
}
.cp-medias-sociaux .cp-medias-sociaux__thumb-link,
.cp-medias-sociaux .cp-medias-sociaux__tiktok-card {
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.06);
}
.cp-medias-sociaux {
  /* Active (tous formats) — feedback tactile */
}
.cp-medias-sociaux .cp-medias-sociaux__thumb-link:active,
.cp-medias-sociaux .cp-medias-sociaux__tiktok-card:active {
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12), 0 1px 0 rgba(0, 0, 0, 0.06);
}
.cp-medias-sociaux {
  /* Hover (desktop) — lift + shadow feutrée */
}
@media (hover: hover) and (pointer: fine) {
  .cp-medias-sociaux .cp-medias-sociaux__thumb-link:hover,
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.12);
  }
}
.cp-medias-sociaux {
  /* =========================================
   FEEDBACK TACTILE 
   ========================================= */
}
@media (hover: none) {
  .cp-medias-sociaux .cp-medias-sociaux__thumb-link,
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-card {
    transition: transform 120ms ease, box-shadow 180ms ease, filter 160ms ease;
  }
  .cp-medias-sociaux .cp-medias-sociaux__thumb-link:active,
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-card:active {
    transform: scale(0.98);
    filter: brightness(0.98);
  }
}
.cp-medias-sociaux {
  /* =========================
     TIKTOK GRID   
     ========================= */
}
.cp-medias-sociaux .cp-medias-sociaux__tiktok-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 24px;
  justify-items: center;
  max-width: 500px;
  margin-inline: auto;
}
.cp-medias-sociaux .cp-medias-sociaux__tiktok-card {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
}
.cp-medias-sociaux .cp-medias-sociaux__tiktok-item .cp-medias-sociaux__article-title {
  width: 100%;
  min-width: 0;
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cp-medias-sociaux .cp-medias-sociaux__tiktok-item {
  width: 100%;
  max-width: 240px;
  display: flex;
  flex-direction: column;
}
.cp-medias-sociaux .cp-medias-sociaux__tiktok-thumb {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cp-medias-sociaux .cp-medias-sociaux__tiktok-overlay {
  position: absolute;
  inset: 0;
  display: block;
  background: linear-gradient(to top, rgba(43, 53, 80, 0.35) 0%, rgba(43, 53, 80, 0.1) 45%, rgba(43, 53, 80, 0) 75%);
  opacity: 0.9;
  transition: opacity 220ms ease;
}
.cp-medias-sociaux {
  /* Hover desktop : overlay un peu plus présent (premium) */
}
@media (hover: hover) and (pointer: fine) {
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-card:hover .cp-medias-sociaux__tiktok-overlay {
    opacity: 1;
  }
}

/* =========================================================
   TABLETTE (>=768)
   ========================================================= */
@media (min-width: 768px) {
  .cp-medias-sociaux .cp-medias-sociaux__band-title {
    font-size: 18px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__intro-title {
    font-size: 26px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__intro-title::after {
    width: 160px;
    margin-top: 12px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-overlay {
    pointer-events: none;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head {
    gap: 12px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    padding: 5px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head,
  .cp-medias-sociaux .cp-medias-sociaux__articles,
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-grid {
    max-width: 740px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__meta {
    min-height: 97.2px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__articles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 48px;
    justify-items: stretch;
    align-items: start;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head-icon svg {
    width: 40px;
    height: 40px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__thumb-link,
  .cp-medias-sociaux .cp-medias-sociaux__meta {
    max-width: 360px;
    margin-inline: auto;
  }
  .cp-medias-sociaux .cp-medias-sociaux__article-title,
  .cp-medias-sociaux .cp-medias-sociaux__desc {
    font-size: 16px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head-title {
    font-size: 20px;
    line-height: 30px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
    justify-items: center;
  }
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-item {
    max-width: 170px;
  }
}
/* =========================================================
   DESKTOP LG (>=1024)
   ========================================================= */
@media (min-width: 1024px) {
  .cp-medias-sociaux .cp-medias-sociaux__band-title {
    font-size: 24px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__intro-title {
    font-size: 30px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__intro-title::after {
    width: 210px;
    margin-top: 14px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head-icon {
    width: 54px;
    height: 54px;
    border-radius: 13px;
    padding: 6px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head-icon svg {
    width: 42px;
    height: 42px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head-title {
    font-size: 22px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__head,
  .cp-medias-sociaux .cp-medias-sociaux__articles,
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-grid {
    max-width: 1040px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__articles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 48px;
    justify-items: stretch;
    align-items: start;
  }
  .cp-medias-sociaux .cp-medias-sociaux__article {
    width: 100%;
    max-width: none;
    min-width: 0;
  }
  .cp-medias-sociaux .cp-medias-sociaux__thumb-link,
  .cp-medias-sociaux .cp-medias-sociaux__meta {
    width: 100%;
    max-width: 450px;
    margin-inline: auto;
  }
  .cp-medias-sociaux .cp-medias-sociaux__meta {
    min-height: 97.2px;
  }
  .cp-medias-sociaux .cp-medias-sociaux__tiktok-item {
    max-width: 239px;
  }
}
/* ==========================================================================
   VALEURS — SECTION RÉUTILISABLE
   ========================================================================== */
/* ======================================================================
   MOBILE — BASE
   ====================================================================== */
.cp-valeurs {
  /* tout en police de titre */
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--color-blanc);
}

.cp-valeurs__band {
  background: var(--color-grisGunmetal);
  padding: 48px 0 48px 0;
  position: relative;
}

/* grain */
.cp-valeurs__band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-valeurs__band > .cp-container {
  position: relative;
  z-index: 1;
}

.cp-valeurs__header {
  display: grid;
  justify-items: center;
  gap: 16px;
  margin-bottom: 32px;
}

.cp-valeurs__title {
  margin: 0;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 18px;
  padding-bottom: 8px;
}

.cp-valeurs__icon {
  width: 64px;
  height: 64px;
  display: block;
}

.cp-valeurs__grid {
  display: grid;
  gap: 48px;
  text-align: center;
  padding-inline: 5px;
}

.cp-valeurs__subtitle {
  margin: 0 0 16px 0;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.cp-valeurs__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.cp-valeurs__item {
  font-size: 16px;
  line-height: 30px;
  margin: 0;
}

.cp-valeurs__text {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 16px;
  line-height: 30px;
  margin: 0 auto;
  max-width: 360px;
}

/* Fine ligne rouge entre « Garantie et engagement » et « Relation avec nos clients »
   — mobile seulement (colonnes empilées ; masquée dès 768px où elles sont côte à côte). */
.cp-valeurs__col:nth-child(2)::before {
  content: "";
  display: block;
  height: 1px;
  width: 80%;
  max-width: 320px;
  margin: 0 auto 32px;
  background: linear-gradient(90deg, transparent, rgba(198, 0, 0, 0.9) 25%, rgba(198, 0, 0, 0.9) 75%, transparent);
}

/* ======================================================================
   TABLETTE — MD (>= 768px)
   ====================================================================== */
@media (min-width: 768px) {
  .cp-valeurs {
    /* vide */
  }
  /* Séparateur rouge mobile uniquement — masqué quand les colonnes sont côte à côte */
  .cp-valeurs__col:nth-child(2)::before {
    display: none;
  }
  .cp-valeurs__band {
    padding: 48px 0 64px 0;
  }
  .cp-valeurs__header {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 24px;
    margin-bottom: 48px;
  }
  .cp-valeurs__icon {
    width: 80px;
    height: 80px;
  }
  .cp-valeurs__grid {
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    text-align: center;
    padding-inline: 5px 20px;
  }
}
/* ======================================================================
   DESKTOP — LG (>= 1024px)
   ====================================================================== */
@media (min-width: 1024px) {
  .cp-valeurs__band {
    padding: 48px 0 64px 0;
  }
  .cp-valeurs__title {
    font-size: 20px;
  }
  .cp-valeurs__icon {
    width: 82px;
    height: 82px;
  }
  .cp-valeurs__grid {
    gap: 0;
    padding-inline: 3%;
  }
}
/* ======================================================================
   XL — (>= 1280px)
   ====================================================================== */
@media (min-width: 1280px) {
  .cp-valeurs__title {
    font-size: 22px;
  }
}
/* =========================================================
   MODALES — principes visuels partagés
   Avis + Forfaits
   ========================================================= */
.accueil-avis-modal[hidden],
.cp-forfait-modal[hidden] {
  display: none;
}

.accueil-avis-modal,
.cp-forfait-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.accueil-avis-modal__backdrop,
.cp-forfait-modal__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(18, 24, 38, 0.68) 0%, rgba(9, 12, 20, 0.78) 100%);
  backdrop-filter: blur(4px);
}

.accueil-avis-modal__dialog,
.cp-forfait-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(760px, 100%);
  max-height: min(86vh, 920px);
  overflow: auto;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 250, 250, 0.96) 100%);
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28), 0 10px 24px rgba(15, 23, 42, 0.14);
  animation: cp-modal-enter 180ms ease-out;
}

.accueil-avis-modal__dialog,
.cp-forfait-modal__dialog {
  padding: 0;
}

.accueil-avis-modal__close,
.cp-forfait-modal__close {
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  z-index: 2;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  cursor: pointer;
  transition: background-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.accueil-avis-modal__close:hover,
.cp-forfait-modal__close:hover {
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}

.accueil-avis-modal__close:focus-visible,
.cp-forfait-modal__close:focus-visible {
  outline: 2px solid #C60000;
  outline-offset: 2px;
}

.accueil-avis-modal__closeIcon,
.cp-forfait-modal__closeIcon {
  width: 18px;
  height: 18px;
  display: block;
}

.accueil-avis-modal__title,
.cp-forfait-modal__title {
  margin: 0;
  padding: 1.4rem 4rem 1rem 1.4rem;
  font-size: clamp(1.3rem, 1.1rem + 0.7vw, 1.7rem);
  line-height: 1.2;
  font-weight: 700;
  color: #253C3F;
  border-bottom: 1px solid rgba(37, 60, 63, 0.08);
}

.accueil-avis-modal__body,
.cp-forfait-modal__content {
  padding: 1.35rem 1.4rem 1.5rem;
}

.accueil-avis-modal__body p,
.cp-forfait-modal__content p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(37, 60, 63, 0.88);
}

.accueil-avis-modal__body > * + *,
.cp-forfait-modal__content > * + * {
  margin-top: 1rem;
}

.cp-forfait-modal__video {
  position: relative;
  width: 100%;
  max-width: 920px;
  margin-inline: auto;
  aspect-ratio: 16/9;
}

.cp-forfait-modal__video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  border-radius: 8px;
}

@keyframes cp-modal-enter {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@media (max-width: 767px) {
  .accueil-avis-modal,
  .cp-forfait-modal {
    padding: 0.75rem;
  }
  .accueil-avis-modal__dialog,
  .cp-forfait-modal__dialog {
    width: 100%;
    max-height: 88vh;
    border-radius: 8px;
  }
  .accueil-avis-modal__title,
  .cp-forfait-modal__title {
    padding: 1.15rem 3.5rem 0.9rem 1rem;
  }
  .accueil-avis-modal__body,
  .cp-forfait-modal__content {
    padding: 1rem 1rem 1.15rem;
  }
  .accueil-avis-modal__close,
  .cp-forfait-modal__close {
    top: 0.7rem;
    right: 0.7rem;
  }
}
.cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__dialog {
  width: min(1320px, 100vw - 1.5rem);
  max-height: min(92vh, 920px);
}

.cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__video {
  max-width: none;
  width: 100%;
}

@media (max-width: 767px) {
  .cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__dialog {
    width: calc(100vw - 1rem);
  }
}
/* ==========================================================================
   BANDE FEEDBACK — lancement du nouveau site (temporaire)
   À retirer 3 à 4 semaines après la mise en ligne.
   ========================================================================== */
.cp-feedback {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* --------------------------------------------------------------------------
   Bande d'annonce (haut de page, flux normal)
   -------------------------------------------------------------------------- */
.cp-feedback__bar {
  position: relative;
  z-index: 60;
  color: var(--color-blanc);
  background: var(--color-bleuFond);
  border-bottom: 2px solid var(--color-rougeBrickember);
}

.cp-feedback__bar-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 16px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 9px 16px;
  text-align: center;
}

.cp-feedback__msg {
  margin: 0;
  font-size: 14px;
  line-height: 1.4;
}

.cp-feedback__spark {
  margin-right: 4px;
}

.cp-feedback__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cp-feedback__open {
  appearance: none;
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--color-bleuTexte);
  background: var(--color-blanc);
  border: 0;
  border-radius: 999px;
  padding: 7px 16px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.cp-feedback__open:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.cp-feedback__dismiss {
  appearance: none;
  cursor: pointer;
  background: transparent;
  border: 0;
  color: var(--color-blanc);
  font-size: 22px;
  line-height: 1;
  padding: 0 4px;
  opacity: 0.8;
  transition: opacity 0.15s ease;
}

.cp-feedback__dismiss:hover {
  opacity: 1;
}

/* --------------------------------------------------------------------------
   Lanceur persistant (coin bas-droite, après réduction)
   -------------------------------------------------------------------------- */
.cp-feedback__launcher {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 70;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.02em;
  color: var(--color-blanc);
  background: var(--color-bleuFond);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  padding: 9px 16px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.cp-feedback__launcher:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.3);
}

.cp-feedback__launcher-icon {
  font-size: 15px;
}

/* --------------------------------------------------------------------------
   Popover formulaire (coin bas-droite)
   -------------------------------------------------------------------------- */
.cp-feedback__popover {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 75;
  width: min(380px, 100vw - 32px);
  max-height: calc(100vh - 32px);
  overflow-y: auto;
  background: var(--color-blanc);
  color: var(--color-bleuTexte);
  border-radius: 12px;
  border-top: 3px solid var(--color-rougeBrickember);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.3);
}

.cp-feedback__popover-close {
  position: absolute;
  top: 8px;
  right: 10px;
  appearance: none;
  cursor: pointer;
  background: transparent;
  border: 0;
  color: var(--color-bleuTexte);
  font-size: 22px;
  line-height: 1;
  opacity: 0.6;
  transition: opacity 0.15s ease;
}

.cp-feedback__popover-close:hover {
  opacity: 1;
}

.cp-feedback__form {
  display: grid;
  gap: 12px;
  padding: 22px 18px 20px;
}

.cp-feedback__intro {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
}

.cp-feedback__field {
  display: grid;
  gap: 5px;
}

.cp-feedback__label {
  font-size: 13px;
  font-weight: 700;
}

.cp-feedback__label em {
  font-weight: 400;
  font-style: normal;
  opacity: 0.7;
}

.cp-feedback__hint {
  font-size: 12px;
  line-height: 1.4;
  opacity: 0.7;
}

.cp-feedback__form textarea,
.cp-feedback__form select,
.cp-feedback__form input[type=text] {
  width: 100%;
  font-family: inherit;
  font-size: 14px;
  color: var(--color-bleuTexte);
  padding: 9px 11px;
  border: 1px solid #cdd2dc;
  border-radius: 6px;
  background: #fff;
}

.cp-feedback__form textarea {
  resize: vertical;
  min-height: 90px;
}

.cp-feedback__form textarea:focus,
.cp-feedback__form select:focus,
.cp-feedback__form input[type=text]:focus {
  outline: 2px solid var(--cp-accent, #1f6fb2);
  outline-offset: 1px;
  border-color: transparent;
}

/* Honeypot anti-spam */
.cp-feedback__hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.cp-feedback__footer {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.cp-feedback__submit {
  appearance: none;
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--color-blanc);
  background: var(--color-rougeBrickember);
  border: 0;
  border-radius: 999px;
  padding: 9px 22px;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}

.cp-feedback__submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.18);
}

.cp-feedback__submit:disabled {
  opacity: 0.6;
  cursor: default;
  transform: none;
  box-shadow: none;
}

.cp-feedback__status {
  margin: 0;
  font-size: 13px;
}

.cp-feedback__status.is-error {
  color: var(--color-rougeBrickember);
  font-weight: 700;
}

.cp-feedback__thanks {
  margin: 0;
  padding: 8px 0;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
}

@media (max-width: 600px) {
  .cp-feedback__bar-inner {
    padding: 8px 12px;
  }
  .cp-feedback__msg {
    font-size: 13px;
  }
  .cp-feedback__launcher,
  .cp-feedback__popover {
    right: 10px;
    bottom: 10px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .cp-feedback__open,
  .cp-feedback__submit,
  .cp-feedback__dismiss,
  .cp-feedback__launcher,
  .cp-feedback__popover-close {
    transition: none;
  }
}
/* =========================================
   FORFAITS — STEP 1
========================================= */
/* =========================
   MOBILE — BASE
========================= */
.cp-forfaits__selectedItem {
  padding: 8px;
}

.cp-form-rdvForfaits__hint {
  max-width: 475px;
  margin: 0 auto;
  padding-left: 15px;
}

.cp-hero-top--forfaits {
  width: 65px;
  height: 65px;
  margin-top: -2px;
}

.cp-hero-top {
  gap: 12px;
}

.cp-form-rdvForfait__h2_bienvenue {
  text-align: center;
}

.cp-forfaits__fieldset--selected {
  color: var(--color-grisGunmetal);
}

.cp-forfaits__check {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.cp-form__h3ChoixForfaits {
  margin-bottom: 12px;
}

.cp-forfaits__fieldset {
  max-width: 460px;
  margin-inline: auto;
  margin-top: 8px;
  margin-bottom: 48px;
  padding-top: 24px;
  padding-bottom: 32px;
  border: 0;
  border-radius: 5px;
  overflow: hidden;
  background: var(--color-alabaster);
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.cp-forfaits__list {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cp-forfaits__item {
  width: 100%;
}

.cp-forfaits__row {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  width: 100%;
}

.cp-forfaits__name {
  width: 100%;
}

.cp-forfaits__title {
  display: block;
  width: 100%;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cp-forfaits__actions {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-start;
  gap: 12px;
  width: 100%;
}

.cp-forfaits__addBtn,
.cp-forfaits__infoBtn,
.cp-forfaits__removeBtn {
  width: 100%;
  max-width: 160px;
  padding: 6px 10px;
  font-size: 13px;
  line-height: 16px;
  height: 30px;
  transition: background-color 0.28s cubic-bezier(0.4, 0, 0.2, 1), color 0.28s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.28s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1), transform 0.18s cubic-bezier(0.4, 0, 0.2, 1);
}

.cp-forfaits__addBtn.cp-btn,
.cp-forfaits__removeBtn.cp-btn {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 24px;
  justify-content: center;
  padding: 3px 8px;
}

.cp-forfaits__infoBtn.cp-btn {
  flex: 0 1 40%;
  max-width: 75px;
  width: 100%;
  padding-inline: 7px;
}

.cp-forfaits__addBtn.cp-btn,
.cp-forfaits__infoBtn.cp-btn {
  font-size: 12px;
  line-height: 14px;
}

.cp-forfaits__addBtn {
  font-weight: 700;
}

.cp-forfaits__selectedName {
  display: block;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-weight: 500;
}

.cp-forfaits__selectedList {
  list-style-type: none;
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0;
  padding-left: 0;
}

.cp-forfaits__selectedList li {
  width: 100%;
}

.cp-forfaits__item.is-selected .cp-forfaits__addBtn {
  position: relative;
  background: var(--color-platinum);
  color: var(--color-bleuTexte);
  border-color: var(--color-bleuFond);
  transition: background-color 0.28s cubic-bezier(0.4, 0, 0.2, 1), color 0.28s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.28s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1), transform 0.18s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.12s linear;
}

.cp-forfaits__item.is-selected .cp-forfaits__addBtn::after {
  content: "RETIRER";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-bleuTexte);
  opacity: 0;
  font-weight: 700;
  transition: opacity 0.12s linear;
}

.cp-forfaits__item.is-selected .cp-forfaits__addBtn:hover,
.cp-forfaits__item.is-selected .cp-forfaits__addBtn:focus-visible {
  color: transparent;
}

.cp-forfaits__item.is-selected .cp-forfaits__addBtn:hover::after,
.cp-forfaits__item.is-selected .cp-forfaits__addBtn:focus-visible::after {
  opacity: 1;
}

.cp-forfaits__item:not(.is-selected) .cp-forfaits__addBtn:hover,
.cp-forfaits__item:not(.is-selected) .cp-forfaits__addBtn:focus-visible {
  background: var(--color-platinum);
  color: var(--color-rougeBrickember);
  border-color: var(--color-rougeBrickember);
}

.cp-forfaits__item.is-selected .cp-forfaits__addBtn:hover,
.cp-forfaits__item.is-selected .cp-forfaits__addBtn:focus-visible {
  background: var(--color-alabaster);
  color: transparent;
  border-color: var(--color-rougeBrickember);
}

.cp-forfaits__removeBtn.cp-btn {
  background: var(--color-alabaster);
  color: var(--color-bleuTexte);
  border-color: var(--color-bleuFond);
}

.cp-forfaits__removeBtn.cp-btn:hover {
  background: var(--color-alabaster);
  color: var(--color-rougeBrickember);
  border-color: var(--color-rougeBrickember);
}

.cp-forfaits__info {
  width: 100%;
}

[data-answers-hidden-step1=forfaits] {
  display: none;
}

.cp-forfait-modal__closeIcon {
  width: 18px;
  height: 18px;
  display: block;
}

/* =========================================================
   MODALE FORFAIT
   (copie exacte de la modale avis avec nouvelles classes)
   ========================================================= */
.cp-forfait-modal[hidden] {
  display: none;
}

.cp-forfait-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cp-forfait-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}

.cp-forfait-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(720px, 100% - 48px);
  max-height: 80vh;
  overflow: auto;
  background: var(--color-platinum);
  border-radius: 5px;
  padding: 32px;
}

.cp-forfait-modal__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}

.cp-forfait-modal__title {
  margin: 0 0 16px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
}

.cp-forfait-modal__content {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  white-space: pre-wrap;
  line-height: 1.6;
}

.cp-forfait-modal__video {
  position: relative;
  width: 100%;
  max-width: 860px;
  aspect-ratio: 16/9;
  margin-inline: auto;
}

.cp-forfait-modal__video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 767px) {
  .cp-forfait-modal {
    padding-inline: 0;
  }
  .cp-forfait-modal__dialog {
    width: calc(100% - 20px);
    padding: 24px;
  }
  .cp-forfait-modal__title {
    padding-right: 2.5rem;
  }
}
body.has-forfait-modal-open {
  overflow: hidden;
}

.cp-forfait-modal.cp-forfait-modal--video {
  padding: 0.75rem;
}

.cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__dialog {
  width: min(1320px, 100vw - 1.5rem);
  max-height: min(92vh, 920px);
  padding: 0;
}

.cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__content {
  padding: 0.75rem 1rem 1rem;
}

.cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__video {
  max-width: none;
  width: 100%;
}

@media (max-width: 767px) {
  .cp-forfait-modal.cp-forfait-modal--video {
    padding: 0.5rem;
  }
  .cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__dialog {
    width: calc(100vw - 1rem);
  }
  .cp-forfait-modal.cp-forfait-modal--video .cp-forfait-modal__content {
    padding: 0.5rem 0.5rem 0.65rem;
  }
}
.cp-form-rdv__priseEnChargeHeader {
  text-transform: uppercase;
  font-weight: 500;
}

/* =========================
   TABLETTE
========================= */
@media (min-width: 768px) {
  .cp-forfaits__selectedItem {
    padding: 0;
    margin-top: 16px;
  }
  .cp-forfaits__fieldset {
    max-width: 650px;
    padding-inline: 24px;
  }
  .cp-form-rdvForfait__h2_bienvenue {
    font-size: 20px;
    line-height: 30px;
    margin-bottom: 24px;
  }
  .cp-hero-top--forfaits {
    width: 70px;
    height: 70px;
    margin-top: -2px;
  }
  .cp-hero-top {
    gap: 24px;
  }
  .cp-form-rdvForfaits__hint {
    width: 100%;
    max-width: 650px;
    margin: 0 auto;
    padding-left: 3px;
  }
  .cp-form__h3ChoixForfaits {
    margin-bottom: 24px;
  }
  .cp-forfaits__list {
    gap: 24px;
  }
  .cp-forfaits__row {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: 100%;
  }
  .cp-forfaits__name {
    flex: 1 1 auto;
    min-width: 0;
    padding-right: 16px;
  }
  .cp-forfaits__title {
    display: block;
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .cp-forfaits__actions {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
    gap: 12px;
    padding-right: 16px;
  }
  .cp-forfaits__addBtn.cp-btn,
  .cp-forfaits__removeBtn.cp-btn {
    flex: 0 0 175px;
    width: 175px;
    min-width: 175px;
    max-width: 175px;
  }
  .cp-forfaits__infoBtn.cp-btn {
    flex: 0 0 75px;
    width: 75px;
    min-width: 75px;
    max-width: 75px;
  }
  .cp-form-rdv__priseEnChargeForfait {
    margin-inline: 47px;
    margin-bottom: 24px;
  }
}
/* =========================
   DESKTOP
========================= */
@media (min-width: 1024px) {
  .cp-forfaits__fieldset {
    max-width: 720px;
    margin-bottom: 64px;
    padding-inline: 32px;
  }
  .cp-form-rdvForfaits__hint {
    max-width: 720px;
  }
  .cp-forfaits__title {
    font-size: 16px;
    line-height: 24px;
  }
  .cp-forfaits__list {
    gap: 32px;
  }
  .cp-forfaits__selectedName {
    font-size: 16px;
    margin-bottom: 8px;
  }
  .cp-hero-top--forfaits {
    width: 75px;
    height: 75px;
    margin-top: 4px;
  }
  .cp-hero-top {
    gap: 24px;
  }
  .cp-form-rdv__priseEnChargeForfait {
    margin-inline: 78px;
    margin-bottom: 24px;
  }
}
/* =========================================================
   FORM RDV — Step-by-step 
   ========================================================= */
/* =========================
   Hors cp-form-rdv
========================= */
.cp-rdv-scope__mw {
  width: 100%;
}

/* 420–767 : colonne centrée max 480 */
@media (min-width: 420px) and (max-width: 767px) {
  .cp-rdv-scope__mw {
    max-width: 520px;
    margin-inline: auto;
  }
}
html:not(.js) .cp-form-rdv__service-panel[hidden] {
  display: block !important; /* override du hidden natif, tablette+ seulement */
}

html.js .cp-form-rdv__service-panel:not([hidden]) {
  display: block !important;
  position: static !important;
  height: auto !important;
  overflow: visible !important;
}

/* “Autre” — garantit l’affichage du bloc révélé */
.cp-form-rdv [data-rdv-autre-field]:not([hidden]),
.cp-form-rdv [data-promo-autre-field]:not([hidden]) {
  display: block !important;
  height: auto !important;
  overflow: visible !important;
  margin: 24px 0;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
}

/* Le textarea ne doit jamais être écrasé */
.cp-form-rdv [data-rdv-autre-field] .cp-form-rdv__textarea,
.cp-form-rdv [data-promo-autre-field] .cp-form-rdv__input {
  width: 100%;
  max-width: 100%;
}

/* Accordéon ouvert : ne doit pas clipper les champs conditionnels */
.cp-form-rdv__acc-panel:not([hidden]) {
  height: auto !important;
  overflow: visible !important;
}

.cp-form-rdv .cp-form-confirmation-spam-hint {
  margin: 16px 24px 12px;
  text-align: left;
  color: var(--color-bleuTexte);
  opacity: 0.88;
}

/* =========================
   MOBILE (base)
========================= */
.cp-form-rdv {
  /* Safety: hidden doit toujours gagner */
}
.cp-form-rdv [hidden] {
  display: none !important;
}
.cp-form-rdv .cp-form-rdv__actions--stack {
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.cp-form-rdv .cp-form-rdv__confirm-title {
  margin-left: 5px;
}
.cp-form-rdv {
  /* -------------------------------------------------
     Service title disparaît quand panel ouvert
  ------------------------------------------------- */
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true] .cp-form-rdv__service-title {
  display: none;
}
.cp-form-rdv .cp-form-rdv__mobile-480 {
  /* en dessous de 420px : prend toute la largeur (mobile serré) */
  width: 100%;
}
@media (min-width: 420px) and (max-width: 767px) {
  .cp-form-rdv .cp-form-rdv__mobile-480 {
    max-width: 520px;
    margin-inline: auto;
  }
}
.cp-form-rdv {
  /* Mobile étroit : on force le retour à la ligne */
}
@media (max-width: 420px) {
  .cp-form-rdv .cp-break-420 {
    display: block;
  }
}
.cp-form-rdv {
  /* Au-dessus de 420px : une seule ligne */
}
@media (min-width: 421px) {
  .cp-form-rdv .cp-break-420 {
    display: inline;
  }
}
.cp-form-rdv {
  /* 1) Assure la contrainte du conteneur */
}
.cp-form-rdv .cp-form-rdv__declare,
.cp-form-rdv .cp-form-rdv__field {
  max-width: 100%;
}
.cp-form-rdv .cp-form-rdv__textarea {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
}
.cp-form-rdv .cp-form-rdv__field {
  min-width: 0;
}
.cp-form-rdv .cp-form-rdv__field--flush {
  margin-top: 0;
}
.cp-form-rdv .cp-form-rdv__vosReponseEtape1 {
  padding: 12px;
}
.cp-form-rdv .cp-form-rdv__answers-empty {
  padding-left: 8px;
  padding-bottom: 24px;
  font-size: 0.95rem;
  opacity: 0.8;
}
.cp-form-rdv .cp-form-rdv__answers-item-main {
  display: block;
}
.cp-form-rdv .cp-form-rdv__answers-item-sub {
  margin-top: 4px;
  padding-left: 16px;
}
.cp-form-rdv {
  /* =========================
     STEP 3 — cohérence Logistique
  ========================= */
  /* Petits séparateurs entre sections de la boîte (pas une bulle) */
}
.cp-form-rdv .cp-form-rdv__fieldset .cp-form-rdv__group + .cp-form-rdv__field--flush,
.cp-form-rdv .cp-form-rdv__fieldset .cp-form-rdv__field--flush + .cp-form-rdv__field {
  padding-top: 24px;
  margin-top: 24px;
  border-top: 1px solid rgba(43, 53, 80, 0.12);
}
.cp-form-rdv .cp-form-rdv__fieldset .cp-form-rdv__field--flush + .cp-form-rdv__field--flush {
  padding-top: 24px;
  margin-top: 24px;
  border-top: 1px solid rgba(43, 53, 80, 0.12);
}
.cp-form-rdv .cp-form-rdv__fieldsetEtape3 {
  margin-top: 0 !important;
}
.cp-form-rdv .cp-form-rdv__group-title [data-horaire-star] {
  margin-left: 8px;
  opacity: 0.7;
}
.cp-form-rdv .cp-form-rdv__fieldset [data-date-rdv] .cp-form-rdv__field-label {
  margin-bottom: 8px;
  margin-left: 3px;
  font-size: 14px;
}
.cp-form-rdv .cp-form-rdv__fieldset [data-rappel-prix] .cp-form-rdv__field-label {
  margin: 0 0 12px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
}
.cp-form-rdv .cp-form-rdv__fieldset [hidden] {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: 0 !important;
}
.cp-form-rdv .cp-form-rdv__assurance-details {
  padding-bottom: 16px;
}
.cp-form-rdv {
  /* =========================
     STEP 3 — layout + boîtes
  ========================= */
}
.cp-form-rdv .cp-form-rdv__step3-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.cp-form-rdv {
  /* Boîte fieldset (Step 3) */
}
.cp-form-rdv .cp-form-rdv__fieldset {
  padding: 12px;
  border: 0;
  border-radius: 12px;
  background: var(--color-alabaster);
  margin: 0;
}
.cp-form-rdv {
  /* Legend = titre de boîte */
}
.cp-form-rdv .cp-form-rdv__legend {
  margin: 0 0 16px 0;
  padding: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-bleuTexte);
}
.cp-form-rdv .cp-form-rdv__h2_bienvenue {
  text-align: center;
}
.cp-form-rdv .cp-form-rdv__group + .cp-form-rdv__group {
  margin-top: 24px;
}
.cp-form-rdv .cp-form-rdv__group-title {
  margin: 0 0 12px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
}
.cp-form-rdv .cp-form-rdv__field--flush {
  margin-top: 24px;
  padding: 0;
  background: transparent;
  border-radius: 0;
}
.cp-form-rdv fieldset.cp-form-rdv__field--flush {
  border: 0;
  margin-top: 24px;
  padding: 0;
}
.cp-form-rdv .cp-form-rdv__notice-soft {
  margin-top: 16px;
  padding: 16px;
  border-radius: 10px;
  background: rgba(43, 53, 80, 0.06);
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
.cp-form-rdv {
  /* =========================
     Animation blocs conditionnels
  ========================= */
}
.cp-form-rdv .cp-form-rdv__field,
.cp-form-rdv .cp-form-rdv__group {
  transition: opacity 220ms ease, transform 220ms ease;
}
.cp-form-rdv .cp-form-rdv__field[hidden],
.cp-form-rdv .cp-form-rdv__group[hidden] {
  display: block;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  height: 0;
  overflow: hidden;
  margin-top: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.cp-form-rdv {
  /* =========================
     Fieldsets “boîtes” (inset via .cp-inset)
  ========================= */
}
.cp-form-rdv .cp-form-rdv__fieldset {
  border: 0;
  border-radius: 12px;
  background: var(--color-alabaster);
  padding: 24px 16px 16px 16px;
  margin: 24px 0;
}
.cp-form-rdv .cp-form-rdv__legend {
  margin: 0 0 16px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cp-form-rdv {
  /* =========================
     Checks & Radios — style sobre
  ========================= */
}
.cp-form-rdv .cp-form-rdv__check,
.cp-form-rdv .cp-form-rdv__radio {
  align-items: flex-start;
}
.cp-form-rdv .cp-form-rdv__check input,
.cp-form-rdv .cp-form-rdv__radio input {
  flex: 0 0 18px;
  min-width: 18px;
  min-height: 18px;
  width: 18px;
  height: 18px;
  margin: 0;
  margin-top: 2px;
  accent-color: var(--color-bleuFond);
}
.cp-form-rdv .cp-form-rdv__check input[type=checkbox],
.cp-form-rdv .cp-form-rdv__check input[type=radio],
.cp-form-rdv .cp-form-rdv__radio input[type=radio] {
  -webkit-appearance: auto !important;
  appearance: auto !important;
  inline-size: 18px;
  block-size: 18px;
  flex: 0 0 18px;
  background: revert !important;
  border: revert !important;
  box-shadow: revert !important;
  padding: revert !important;
  border-radius: revert !important;
}
.cp-form-rdv .cp-form-rdv__check span,
.cp-form-rdv .cp-form-rdv__radio span {
  flex: 1 1 auto;
  min-width: 0;
  line-height: 22px;
}
.cp-form-rdv .cp-form-rdv__notice {
  margin-top: 24px;
  padding: 16px;
  border-radius: 10px;
  background: rgba(249, 28, 28, 0.08); /* rouge très doux */
  border: 1px solid rgba(198, 0, 0, 0.25);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
.cp-form-rdv .cp-form-rdv__intro {
  padding-top: 24px;
  padding-bottom: 24px;
}
.cp-form-rdv .cp-form-rdv__intro-head {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
.cp-form-rdv .cp-form-rdv__intro-icon {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
}
.cp-form-rdv .cp-form-rdv__h1 {
  margin: 0 0 8px 0;
}
.cp-form-rdv .cp-form-rdv__priseEnCharge {
  text-align: left;
  margin-bottom: 24px;
}
.cp-form-rdv .cp-form-rdv__priseEnCharge-lead {
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 16px;
}
.cp-form-rdv .cp-form-rdv__lead {
  text-align: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cp-form-rdv .cp-form-rdv__steps {
  margin-top: 24px;
}
.cp-form-rdv .cp-form-rdv__steps-mobile {
  display: block;
  width: 100%;
  max-width: 160px;
  margin-inline: auto;
}
.cp-form-rdv .cp-form-rdv__steps-wide {
  display: none;
}
.cp-form-rdv .cp-form-rdv__step-label {
  margin-top: 12px;
  margin-bottom: 24px;
  text-align: center;
}
.cp-form-rdv .cp-form-rdv__panel-body {
  padding-bottom: 48px;
}
.cp-form-rdv .cp-form-rdv__hint {
  text-align: left;
  margin-inline: 24px;
}
.cp-form-rdv .cp-form-rdv__hint--success {
  color: var(--color-vitrxpert);
  font-weight: 500;
}
.cp-form-rdv {
  /* Service grid */
}
.cp-form-rdv .cp-form-rdv__service-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 24px;
  margin-bottom: 32px;
  justify-items: center;
}
.cp-form-rdv .cp-form-rdv__service-btn {
  max-width: 360px;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  width: 100%;
  margin-inline: auto;
}
.cp-form-rdv .cp-form-rdv__service-media {
  position: relative;
  display: block;
  border-radius: 10px;
  overflow: hidden;
}
.cp-form-rdv .cp-form-rdv__service-img {
  display: block;
  width: 100%;
  height: auto;
}
.cp-form-rdv .cp-form-rdv__service-toggle {
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: transparent;
}
.cp-form-rdv .cp-form-rdv__service-toggle-icon {
  width: 34px;
  height: 34px;
  display: block;
}
.cp-form-rdv .cp-form-rdv__service-title {
  display: block;
  margin-top: 12px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-align: center;
}
.cp-form-rdv {
  /* =========================================================
     EFFETS SERVICES (Step 1) — OVERLAY + TEXTE (comme les tuiles accueil)
     - overlay couvre 100% de l’image (.cp-form-rdv__service-media)
     - texte blanc centré AU-DESSUS du masque
     - titre + icône +/- se font discrets
     - mobile: :active + aria-expanded
     ========================================================= */
  /* Couche overlay */
}
.cp-form-rdv .cp-form-rdv__service-media::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: rgba(43, 53, 80, 0.78);
  opacity: 0;
  transition: opacity 240ms ease;
}
.cp-form-rdv {
  /* Texte overlay */
}
.cp-form-rdv .cp-form-rdv__service-media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  white-space: pre-line;
  display: grid;
  place-items: center;
  padding: 32px;
  text-align: center;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 22px;
  color: #fff;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 240ms ease, transform 240ms ease;
}
.cp-form-rdv {
  /* Texte spécifique par service — basé sur aria-controls (zéro HTML à changer) */
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-controls=cp-rdv-meca] .cp-form-rdv__service-media::after {
  content: "Ouvrir la section\amécanique générale";
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-controls=cp-rdv-pneus] .cp-form-rdv__service-media::after {
  content: "Ouvrir la section\a des pneus";
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-controls=cp-rdv-pb] .cp-form-rdv__service-media::after {
  content: "Ouvrir la section\apare-brise vitrxpert";
}
.cp-form-rdv {
  /* Hover (desktop / pointer fine) */
}
@media (hover: hover) and (pointer: fine) {
  .cp-form-rdv .cp-form-rdv__service-btn:hover .cp-form-rdv__service-media::before {
    opacity: 1;
  }
  .cp-form-rdv .cp-form-rdv__service-btn:hover .cp-form-rdv__service-media::after {
    opacity: 1;
    transform: translateY(0);
  }
  .cp-form-rdv .cp-form-rdv__service-btn:hover .cp-form-rdv__service-title {
    opacity: 0.18;
    transform: translateY(2px);
    transition: opacity 220ms ease, transform 220ms ease;
  }
  .cp-form-rdv .cp-form-rdv__service-btn:hover .cp-form-rdv__service-toggle {
    opacity: 0.22;
    transition: opacity 220ms ease;
  }
}
.cp-form-rdv .cp-form-rdv__service-btn:focus-visible .cp-form-rdv__service-media::before {
  opacity: 1;
}
.cp-form-rdv .cp-form-rdv__service-btn:focus-visible .cp-form-rdv__service-media::after {
  opacity: 1;
  transform: translateY(0);
}
.cp-form-rdv .cp-form-rdv__service-btn:focus-visible .cp-form-rdv__service-title {
  opacity: 0.18;
  transform: translateY(2px);
}
.cp-form-rdv .cp-form-rdv__service-btn:focus-visible .cp-form-rdv__service-toggle {
  opacity: 0.22;
}
.cp-form-rdv {
  /* Mobile/tactile : feedback au tap */
}
.cp-form-rdv .cp-form-rdv__service-btn:active .cp-form-rdv__service-media::before {
  opacity: 1;
}
.cp-form-rdv .cp-form-rdv__service-btn:active .cp-form-rdv__service-media::after {
  opacity: 1;
  transform: translateY(0);
}
.cp-form-rdv {
  /* État OUVERT : overlay présent même sans hover */
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true] .cp-form-rdv__service-media::before {
  opacity: 1;
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true] .cp-form-rdv__service-media::after {
  opacity: 1;
  transform: translateY(0);
  font-size: 12px;
  opacity: 0.95; /* un peu moins fort visuellement */
}
.cp-form-rdv {
  /* État OUVERT — texte spécifique par section */
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true][aria-controls=cp-rdv-meca] .cp-form-rdv__service-media::after {
  content: "Section Mécanique ouverte\a appuyez pour fermer";
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true][aria-controls=cp-rdv-pneus] .cp-form-rdv__service-media::after {
  content: "Section Pneus ouverte\a appuyez pour fermer";
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true][aria-controls=cp-rdv-pb] .cp-form-rdv__service-media::after {
  content: "Section Pare-brise ouverte\a appuyez pour fermer";
}
.cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true] .cp-form-rdv__service-toggle {
  opacity: 0.22;
}
.cp-form-rdv {
  /* Accessibilité : réduire animations */
}
@media (prefers-reduced-motion: reduce) {
  .cp-form-rdv .cp-form-rdv__service-media::before,
  .cp-form-rdv .cp-form-rdv__service-media::after,
  .cp-form-rdv .cp-form-rdv__service-title,
  .cp-form-rdv .cp-form-rdv__service-toggle {
    transition: none;
  }
  .cp-form-rdv .cp-form-rdv__service-media::after {
    transform: none;
  }
}
.cp-form-rdv {
  /* Service panel */
}
.cp-form-rdv .cp-form-rdv__service-panel {
  margin-top: 16px;
  justify-self: stretch; /* override du center du grid pour éviter le split par colonne */
  width: 100%;
}
.cp-form-rdv {
  /* Bande H2 bleed (sans container) */
}
.cp-form-rdv .cp-form-rdv__band {
  width: 100%;
  background: var(--color-platinum);
  margin-bottom: 24px;
}
.cp-form-rdv {
  /* Band */
}
.cp-form-rdv .cp-form-rdv__band {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
}
.cp-form-rdv .cp-form-rdv__band-title {
  margin: 0;
  padding: 8px 0;
  text-align: center;
  color: var(--color-bleuTexte);
}
.cp-form-rdv {
  /* Accordéons internes */
}
.cp-form-rdv .cp-form-rdv__acc {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 16px;
  border: 0;
  background: var(--color-blanc);
}
.cp-form-rdv .cp-form-rdv__acc::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}
.cp-form-rdv .cp-form-rdv__acc-btn {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: left;
  gap: 16px;
  padding: 16px;
  background: var(--color-alabaster);
  border: 0;
  cursor: pointer;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  text-transform: uppercase;
}
.cp-form-rdv .cp-form-rdv__acc-arrow {
  width: 18px;
  height: 18px;
  display: block;
  transition: transform 0.15s ease;
}
.cp-form-rdv .cp-form-rdv__acc-btn[aria-expanded=true] .cp-form-rdv__acc-arrow {
  transform: rotate(90deg);
}
.cp-form-rdv .cp-form-rdv__acc-panel {
  padding: 16px;
  background: var(--color-blanc);
}
.cp-form-rdv {
  /* Inputs */
}
.cp-form-rdv .cp-form-rdv__check,
.cp-form-rdv .cp-form-rdv__radio {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.cp-form-rdv .cp-form-rdv__field {
  display: block;
  margin-top: 24px;
}
.cp-form-rdv .cp-form-rdv__field-label {
  display: block;
  margin-bottom: 8px;
  margin-left: 5px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
}
.cp-form-rdv .cp-form-rdv__textarea {
  width: 100%;
  min-height: 120px;
  padding: 4px;
  border-radius: 10px;
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
.cp-form-rdv .cp-form-rdv__input,
.cp-form-rdv .cp-form-rdv__textarea {
  border: 0;
  background: var(--color-blanc);
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18);
}
.cp-form-rdv .cp-form-rdv__input:focus,
.cp-form-rdv .cp-form-rdv__textarea:focus {
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18), 0 0 0 2px rgba(43, 53, 80, 0.15);
}
.cp-form-rdv .cp-form-rdv__answers {
  position: relative;
  padding: 12px;
  margin-top: 8px;
  border-radius: 12px;
  background: var(--color-alabaster);
  border: 0;
}
.cp-form-rdv .cp-form-rdv__confirm-repairs {
  padding: 32px;
}
.cp-form-rdv .cp-form-rdv__confirm-repairs-titleAnterieur {
  font-weight: 600;
}
.cp-form-rdv .cp-form-rdv__confirm-repairs-text {
  font-size: 16px;
  text-transform: none;
  padding: 8px;
}
.cp-form-rdv .cp-form-rdv__answers::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}
.cp-form-rdv .cp-form-rdv__answers-list {
  list-style: none;
  padding-left: 0;
  padding-bottom: 16px;
  margin: 0;
}
.cp-form-rdv .cp-form-rdv__answers-service {
  margin-bottom: 16px;
}
.cp-form-rdv .cp-form-rdv__answers-service-title {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 8px;
  margin-bottom: 8px;
}
.cp-form-rdv .cp-form-rdv__answers-items {
  list-style-type: none;
  padding-left: 8px;
  margin: 0;
}
.cp-form-rdv .cp-form-rdv__answers-acc {
  margin-top: 12px;
}
.cp-form-rdv .cp-form-rdv__answers-acc-title {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-variant-caps: all-small-caps;
  margin-bottom: 8px;
}
.cp-form-rdv .cp-form-rdv__answers-subitems {
  list-style-type: none;
  padding-left: 24px;
  margin: 0;
}
.cp-form-rdv .cp-form-rdv__actions {
  margin-top: 32px;
  display: flex;
  justify-content: center;
}
.cp-form-rdv .cp-form-rdv__input {
  width: 100%;
  padding: 6px 8px;
  font-size: 14px;
  border-radius: 10px;
  border: 1px solid rgba(43, 53, 80, 0.25);
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
.cp-form-rdv .cp-form-rdv__step2-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 24px;
}
.cp-form-rdv .cp-form-rdv__step2-col {
  position: relative;
  padding: 20px;
  padding-bottom: 30px;
  border-radius: 12px;
  background: var(--color-alabaster);
  border: 0;
}
.cp-form-rdv .cp-form-rdv__step2-col::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}
.cp-form-rdv .cp-form-rdv__step2-title {
  margin-top: 0;
}
.cp-form-rdv sup {
  font-variant-caps: normal;
}
.cp-form-rdv [data-col-spacer] {
  display: none;
}
.cp-form-rdv .cp-form-rdv__actions--between {
  justify-content: space-between;
  gap: 16px;
}
.cp-form-rdv {
  /* NIV */
}
.cp-form-rdv .cp-form-rdv__optional {
  font-size: 12px;
  font-weight: 400;
  margin-left: 8px;
  opacity: 0.6;
}
.cp-form-rdv .cp-form-rdv__niv {
  margin-top: 32px;
}
.cp-form-rdv .cp-form-rdv__niv-row {
  display: flex;
  gap: 12px;
  align-items: center;
}
.cp-form-rdv .cp-form-rdv__niv-info-btn {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  border-radius: 50%;
  border: 0;
  background: var(--color-blanc);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: var(--color-bleuTexte);
  cursor: pointer;
  /* contour sobre */
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18);
  transition: box-shadow 0.2s ease, transform 0.15s ease, background-color 0.2s ease, color 0.2s ease;
}
.cp-form-rdv {
  /* =========================
     HOVER (plus défini)
  ========================= */
}
@media (hover: hover) and (pointer: fine) {
  .cp-form-rdv .cp-form-rdv__niv-info-btn:hover {
    transform: translateY(-2px);
    background: var(--color-bleuFond);
    color: var(--color-blanc);
    box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18), 0 4px 10px rgba(0, 0, 0, 0.15);
  }
}
.cp-form-rdv {
  /* =========================
     ACTIVE (press tactile)
  ========================= */
}
.cp-form-rdv .cp-form-rdv__niv-info-btn:active {
  transform: translateY(0);
  color: var(--color-blanc);
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.25), inset 0 3px 6px rgba(0, 0, 0, 0.18);
}
.cp-form-rdv {
  /* =========================
     FOCUS clavier (accessibilité)
  ========================= */
}
.cp-form-rdv .cp-form-rdv__niv-info-btn:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(43, 53, 80, 0.18), 0 0 0 3px rgba(43, 53, 80, 0.25);
}
.cp-form-rdv .cp-form-rdv__niv-meta {
  margin-top: 8px;
  text-align: right;
}
.cp-form-rdv .cp-form-rdv__niv-counter {
  font-size: 12px;
  opacity: 0.7;
  font-weight: 600;
}
.cp-form-rdv {
  /* Popover NIV lié au bouton i */
}
.cp-form-rdv .cp-form-rdv__niv {
  position: relative;
  padding-left: 5px;
}
.cp-form-rdv .cp-form-rdv__niv-popover {
  position: relative; /* requis pour inset */
  margin-top: 12px;
  padding: 16px;
  border-radius: 10px;
  background: var(--color-alabaster);
  border: 0;
}
.cp-form-rdv .cp-form-rdv__niv-popover::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}
.cp-form-rdv {
  /* Petite flèche qui “pointe” vers le bouton i avec la bulle */
}
.cp-form-rdv .cp-form-rdv__niv-popover::before {
  content: "";
  position: absolute;
  top: -8px;
  right: 12px;
  width: 14px;
  height: 14px;
  background: var(--color-alabaster);
  border-left: 1px solid rgba(43, 53, 80, 0.2);
  border-top: 1px solid rgba(43, 53, 80, 0.2);
  transform: rotate(45deg);
}
.cp-form-rdv .cp-form-rdv__niv-popover-title {
  margin: 0 0 8px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cp-form-rdv .cp-form-rdv__niv-popover-list {
  margin: 0 0 12px 0;
  padding-left: 24px;
}
.cp-form-rdv {
  /* NIV counter states */
}
.cp-form-rdv .cp-form-rdv__niv-counter {
  font-size: 12px;
  opacity: 0.7;
  transition: color 0.2s ease;
}
.cp-form-rdv .cp-form-rdv__niv-counter.is-invalid {
  color: var(--color-rougeBrickember);
  opacity: 1;
}
.cp-form-rdv .cp-form-rdv__niv-counter.is-valid {
  color: #1f7a3f;
  opacity: 1;
}
.cp-form-rdv {
  /* =========================
     Step 3 — layout + sous-groupes
  ========================= */
}
.cp-form-rdv .cp-form-rdv__step3-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.cp-form-rdv .cp-form-rdv__group {
  margin-bottom: 24px;
}
.cp-form-rdv .cp-form-rdv__group:last-child {
  margin-bottom: 0;
}
.cp-form-rdv .cp-form-rdv__group-title {
  margin: 0 0 12px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.85;
}
.cp-form-rdv .cp-form-rdv__notice-soft {
  margin-top: 16px;
  padding: 16px;
  border-radius: 10px;
  background: rgba(43, 53, 80, 0.06);
}
.cp-form-rdv {
  /* Step 4 — normaliser l’alignement interne des contenus */
}
.cp-form-rdv .cp-form-rdv__confirm-card ul {
  list-style-type: none;
  padding-left: 8px;
}
.cp-form-rdv .cp-form-rdv__confirm-row dt {
  font-weight: 600;
}
.cp-form-rdv {
  /* Step 4 — éviter que le small-text ait un look "inset" dans la card */
}
.cp-form-rdv .cp-form-rdv__confirm-card {
  position: relative;
  margin-top: 8px;
  padding: 16px 8px 12px 8px;
  border-radius: 12px;
  background: var(--color-alabaster);
  border: 0;
}
.cp-form-rdv .cp-form-rdv__confirm-cardReponses {
  position: relative;
  border-radius: 12px;
  background: var(--color-alabaster);
  border: 0;
}
.cp-form-rdv .cp-form-rdv__vosReponses {
  padding: 8px;
  list-style-type: none;
}
.cp-form-rdv .cp-form-rdv__confirm-card .small-text {
  background: transparent;
  padding: 0;
  border: 0;
  margin: 0.75rem 0 0;
}
.cp-form-rdv .cp-form-rdv__confirm-card > :first-child {
  margin-top: 0;
}
.cp-form-rdv .cp-form-rdv__confirm-card > :last-child {
  margin-bottom: 0;
}
.cp-form-rdv .cp-form-rdv__confirm-dl {
  margin: 0;
  padding-left: 1.1rem;
}
.cp-form-rdv .cp-form-rdv__confirm-block {
  margin: 16px 0 24px 0;
}
.cp-form-rdv .cp-form-rdv__nouvelleDemande {
  margin-top: 8px;
  text-align: center;
}

.cp-form-rdv[data-current-step="4"] .cp-form-rdv__mobile-480 .cp-form-rdv__priseEnCharge {
  display: none;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-form-rdv__step2-title {
    margin-left: 4px;
  }
  .cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true] .cp-form-rdv__service-media::after {
    font-size: 12px;
    line-height: 27px;
    padding: 0;
  }
  .cp-form-rdv .cp-form-rdv__confirm-card {
    margin-top: 8px;
    padding: 24px 12px 16px 12px;
  }
  .cp-form-rdv .cp-form-rdv__actions--stack {
    flex-direction: row;
    align-items: center;
    gap: 24px;
  }
  .cp-form-rdv .cp-form-rdv__priseEnCharge-lead {
    margin-bottom: 24px;
    margin-inline: 45px;
  }
  .cp-form-rdv .cp-form-rdv__confirm-title {
    margin-left: 5px;
  }
  .cp-form-rdv .cp-form-rdv__vosInfos {
    margin-left: 12px;
  }
  .cp-form-rdv .cp-form-rdv__priseEnCharge {
    margin-inline: 45px;
  }
  .cp-form-rdv {
    /* Step 2 : 2 colonnes tablette+ */
  }
  .cp-form-rdv .cp-form-rdv__step2-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }
  .cp-form-rdv .cp-form-rdv__step3-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }
  .cp-form-rdv .cp-form-rdv__step2-col {
    position: relative;
    padding: 24px 16px 48px 16px;
    border-radius: 12px;
    background: var(--color-alabaster);
    border: 0;
  }
  .cp-form-rdv [data-col-spacer] {
    display: block;
    visibility: hidden;
    pointer-events: none;
    user-select: none;
  }
  .cp-form-rdv .cp-form-rdv__lead {
    font-size: 20px;
    line-height: 30px;
  }
  .cp-form-rdv .cp-form-rdv__steps-mobile {
    display: none;
  }
  .cp-form-rdv .cp-form-rdv__steps-wide {
    display: block;
    margin: 24px 32px;
    margin-inline: auto;
    width: 550px;
  }
  .cp-form-rdv .cp-form-rdv__h2Contact {
    text-align: center;
  }
  .cp-form-rdv .cp-form-rdv__step-label {
    display: none;
  }
  .cp-form-rdv .cp-form-rdv__hint {
    text-align: left;
  }
  .cp-form-rdv .cp-form-rdv__hint-etape3 {
    margin-left: 30px;
    margin-top: -1rem;
    margin-bottom: 24px;
    text-align: center;
    font-size: 14px;
    opacity: 0.85;
  }
  .cp-form-rdv .cp-form-rdv__service-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
    padding-inline: 24px;
  }
  .cp-form-rdv .cp-form-rdv__service {
    display: contents;
  }
  .cp-form-rdv .cp-form-rdv__service-btn {
    width: 100%;
  }
  .cp-form-rdv .cp-form-rdv__service-title {
    font-size: 18px;
  }
  .cp-form-rdv .cp-form-rdv__service-media::after {
    font-size: 14px;
    line-height: 21px;
  }
  .cp-form-rdv .cp-form-rdv__service-panel {
    grid-column: 1/-1;
  }
  .cp-form-rdv .cp-form-rdv__band-title {
    padding: 12px 0;
  }
  .cp-form-rdv .cp-form-rdv__field-label {
    margin-left: 8px;
  }
  .cp-form-rdv .cp-form-rdv__answers {
    padding: 1.5rem;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-form-rdv .cp-form-rdv__service-btn[aria-expanded=true] .cp-form-rdv__service-media::after {
    font-size: 16px;
    line-height: 30px;
    opacity: 0.95;
  }
  .cp-form-rdv .cp-form-rdv__intro-icon {
    width: 52px;
    height: 52px;
  }
  .cp-form-rdv .cp-form-rdv__priseEnCharge {
    margin-inline: 78px;
  }
  .cp-form-rdv .cp-form-rdv__priseEnCharge-lead {
    margin-bottom: 24px;
    margin-inline: 78px;
  }
  .cp-form-rdv .cp-form-rdv__lead {
    font-size: 24px;
    line-height: 36px;
  }
  .cp-form-rdv .cp-form-rdv__service-media::after {
    font-size: 20px;
    line-height: 30px;
  }
  .cp-form-rdv .cp-form-rdv__steps-wide {
    margin: 24px auto 48px auto;
  }
  .cp-form-rdv {
    /* NIV counter states */
  }
  .cp-form-rdv .cp-form-rdv__niv {
    width: 70%;
    margin: 0 auto;
    margin-top: 12px;
  }
}
/* =========================
   XL (>= 1280px)
========================= */
@media (min-width: 1280px) {
  .cp-form-rdv {
    /* Lead : style H2 XL */
  }
  .cp-form-rdv .cp-form-rdv__lead {
    font-size: 24px;
    line-height: 36px;
  }
  .cp-form-rdv.is-submitting {
    opacity: 0.98;
  }
  .cp-form-rdv.is-submitting button[type=submit] {
    cursor: progress;
  }
}
/* ==========================================================================
   RDV — validation inline (step 2)
   ========================================================================== */
.cp-form-rdv input:not([type=radio]):not([type=checkbox]).is-invalid,
.cp-form-rdv textarea.is-invalid,
.cp-form-rdv select.is-invalid {
  border-color: var(--color-rougeBrickember);
  box-shadow: 0 0 0 1px var(--color-rougeBrickember);
  background-color: rgba(198, 0, 0, 0.04);
}
.cp-form-rdv input:not([type=radio]):not([type=checkbox]).is-valid,
.cp-form-rdv textarea.is-valid,
.cp-form-rdv select.is-valid {
  border-color: #47aa42;
  box-shadow: 0 0 0 1px #47aa42;
  background-color: rgba(71, 170, 66, 0.04);
}
.cp-form-rdv .cp-form-rdv__check input[type=radio].is-invalid,
.cp-form-rdv .cp-form-rdv__radio input[type=radio].is-invalid {
  -webkit-appearance: none !important;
  appearance: none !important;
  border: 2px solid var(--color-rougeBrickember) !important;
  border-radius: 50% !important;
  background-color: #fff !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0 !important;
}
.cp-form-rdv .cp-form-rdv__check input[type=radio].is-invalid:checked,
.cp-form-rdv .cp-form-rdv__radio input[type=radio].is-invalid:checked {
  background-color: #fff !important;
  background-image: radial-gradient(circle, var(--color-rougeBrickember) 0, var(--color-rougeBrickember) 38%, transparent 40%) !important;
}
.cp-form-rdv .cp-form-rdv__check input[type=checkbox].is-invalid,
.cp-form-rdv .cp-form-rdv__radio input[type=checkbox].is-invalid {
  -webkit-appearance: none !important;
  appearance: none !important;
  border: 2px solid var(--color-rougeBrickember) !important;
  border-radius: 4px !important;
  background-color: #fff !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0 !important;
}
.cp-form-rdv .cp-form-rdv__error-msg {
  margin-top: 0.45rem;
  font-size: 0.875rem;
  line-height: 1.35;
  color: var(--color-rougeBrickember);
}

.cp-form-rdv .cp-form-rdv__group.is-invalid-group {
  padding: 0.65rem 0.75rem 0.75rem;
  border: 1px solid rgba(198, 0, 0, 0.28);
  border-radius: 10px;
  background-color: rgba(198, 0, 0, 0.04);
}
.cp-form-rdv .cp-form-rdv__group.is-invalid-group .cp-form-rdv__group-title {
  color: var(--color-rougeBrickember);
}

/* =========================================================
   CARRIÈRE — Formulaire 
   - Réutilise les classes visuelles du form RDV
   - Ajoute seulement le layout/rythme propre à la page
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-career__form {
  width: 100%;
}

.cp-career__fieldsets {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

/* Fieldsets : max 440px en mobile */
.cp-career__fieldsets .cp-form-rdv__fieldset {
  width: 100%;
  max-width: 440px;
  margin: 0;
}

.cp-career__hint {
  margin-top: 32px;
  margin-bottom: 24px;
  margin-left: 10px;
  text-align: left;
  color: var(--color-bleuTexte);
  opacity: 0.85;
}

.cp-career__titre {
  text-transform: uppercase;
}

.cp-career__sous-titre {
  margin-bottom: 15px;
}

.cp-career__lead {
  font-size: 18px;
  line-height: 27px;
  margin-left: 2%;
  font-weight: 500;
}

.cp-career__fieldset {
  margin: 0;
}

.cp-career__actions {
  margin-top: 32px;
}

.cp-career__notice {
  width: min(100%, 440px);
  max-width: 440px;
  margin: 0 auto 24px;
  padding: 16px 24px;
  box-sizing: border-box;
  border-radius: 10px;
  border: 1px solid rgba(71, 170, 66, 0.35);
  background: rgba(71, 170, 66, 0.08);
  color: var(--color-vitrxpert);
  font-size: 16px;
  line-height: 1.45;
  font-weight: 600;
}

.cp-career__notice > p:first-child {
  margin: 0;
}

.cp-career__notice .cp-form-confirmation-spam-hint {
  margin: 0.75em 0 0;
  font-weight: 400;
  opacity: 0.92;
}

.cp-career__notice strong {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
}

.cp-career__notice--error {
  border-color: rgba(198, 0, 0, 0.3);
  background: rgba(198, 0, 0, 0.08);
  color: var(--color-rougeBrickember);
}

.cp-career__optional {
  font-size: 12px;
  font-weight: 400;
  margin-left: 8px;
  opacity: 0.6;
}

.cp-career__filehint {
  display: inline-block;
  margin-top: 0;
  margin-left: 5px;
  font-size: 12px;
  opacity: 0.75;
  color: var(--color-bleuTexte);
}

.cp-career__file {
  padding: 6px 8px;
  font-size: 11px;
}

.cp-career .cp-form-rdv .cp-career__file::-webkit-file-upload-button {
  margin-right: 16px;
  padding: 8px 12px;
  font-size: 10px;
  border: 1px solid rgba(43, 53, 80, 0.28);
  border-radius: 8px;
  background: var(--color-alabaster);
  color: var(--color-bleuTexte);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background-color 220ms ease, color 220ms ease, border-color 220ms ease, transform 160ms ease, box-shadow 220ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .cp-career .cp-form-rdv .cp-career__file::file-selector-button:hover {
    background: var(--color-bleuFond);
    color: var(--color-blanc);
    border-color: transparent;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.14);
  }
}
/* Active tactile */
.cp-career__file::file-selector-button:active {
  transform: translateY(0);
  box-shadow: inset 0 3px 6px rgba(0, 0, 0, 0.16);
}

/* Focus clavier : on reste cohérent avec ton système */
.cp-career__file:focus-visible {
  outline: 2px solid rgba(43, 53, 80, 0.45);
  outline-offset: 3px;
}

/* Fallback Safari/anciens WebKit */
.cp-career__file::-webkit-file-upload-button {
  margin-right: 16px;
  padding: 8px 12px;
  border: 1px solid rgba(43, 53, 80, 0.28);
  border-radius: 8px;
  background: var(--color-alabaster);
  color: var(--color-bleuTexte);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 12px;
  cursor: pointer;
  transition: background-color 220ms ease, color 220ms ease, border-color 220ms ease, transform 160ms ease, box-shadow 220ms ease;
}

.cp-career__fieldset .cp-form-rdv__field-label {
  margin-bottom: 4px;
}

.cp-career__fieldset .cp-career__filehint {
  margin-top: 2px;
  display: block;
  line-height: 18px;
}

.cp-career__filelist {
  margin-top: 0.75rem;
  display: grid;
  gap: 0.5rem;
}

.cp-career__fileitem {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 1rem;
  border: 1px solid rgba(var(--color-grisGunmetal), 0.15);
  border-radius: 0.5rem;
  background: var(--color-blanc);
}

.cp-career__filename {
  min-width: 0;
  overflow-wrap: anywhere;
  color: var(--color-bleuTexte);
}

.cp-career__fileremove {
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--color-rougeBrickember);
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
}

.cp-career__fileremove:hover,
.cp-career__fileremove:focus-visible {
  color: var(--color-rougePurered);
}

.cp-career__filehint--error {
  display: block;
  margin-top: 0.5rem;
  color: var(--color-rougeBrickember);
  font-weight: 600;
  opacity: 1;
}

@media (max-width: 767px) {
  #cp-career-files-trigger {
    font-size: 14px;
  }
}
#cp-career-files-trigger {
  margin-top: 3.5px;
  margin-bottom: 2px;
}

.cp-btn--ajoutFichiers {
  padding: 5px 20px;
  border-radius: 5px;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-career__notice {
    width: min(100%, 872px);
    max-width: 872px;
    margin-inline: auto;
    font-size: 17px;
  }
  .cp-career__hint {
    margin-left: 10px;
  }
  .cp-career__sous-titre {
    margin-bottom: 48px;
  }
  #cp-career-files-trigger {
    font-size: 16px;
  }
  .cp-career__lead {
    font-size: 20px;
    line-height: 20px;
    margin-left: 10px;
    font-weight: 500;
  }
  .cp-career__fieldsets {
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
    gap: 32px;
  }
  .cp-career__fieldsets .cp-form-rdv__fieldset {
    max-width: none;
    width: min(420px, 100%);
  }
  .cp-career__fieldsets > fieldset.cp-career__fieldset.cp-form-rdv__fieldset:first-of-type {
    padding-bottom: 88px;
  }
  .cp-career__fieldsets > fieldset.cp-career__fieldset:nth-of-type(2) {
    padding-bottom: 30px;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-career__notice {
    width: min(100%, 952px);
    max-width: 952px;
    margin-inline: auto;
    font-size: 18px;
  }
  .cp-career__fieldsets .cp-form-rdv__fieldset {
    width: min(460px, 100%);
  }
  .cp-career__hint {
    margin-left: 30px;
  }
  .cp-career__lead {
    font-size: 20px;
    line-height: 20px;
    margin-left: 30px;
    font-weight: 500;
  }
}
/* ==========================================================================
   Consentement marketing — case à cocher commune à tous les formulaires
   ========================================================================== */
.cp-form__consent-wrap {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(43, 53, 80, 0.12);
}

.cp-form__consent-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
}

.cp-form__consent-check {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--color-bleuTexte);
  cursor: pointer;
}

.cp-form__consent-text {
  font-size: 13px;
  line-height: 1.55;
  color: var(--color-bleuTexte);
}
.cp-form__consent-text a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
.cp-form__consent-text a:hover {
  color: var(--color-rougeBrickember);
}

/* Components — Pare-brise */
/* =========================================================
   PARE-BRISE — HERO IMAGE (bleed) + CTA
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
/* --- HERO IMAGE (bleed) --- */
.cp-pb-hero__bleed {
  margin-left: calc(50% - 50vw);
  /* Empêche les artefacts de scroll à cause du bleed */
  overflow: clip;
}

.cp-pb-hero__media {
  display: block;
  width: 100%;
  min-height: 170px;
}

.cp-pb-hero__img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 170px;
  object-fit: cover;
}

/* =========================
   FOND SOUS LES CTAs (platinum)
   ========================= */
.cp-pb-cta {
  background: var(--color-platinum);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 150px;
  margin-bottom: 24px;
}

@media (min-width: 768px) {
  .cp-pb-cta {
    height: 80px;
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  .cp-pb-cta {
    height: 92px;
  }
}
.cp-pb-cta__actions {
  display: grid;
  gap: 24px;
  justify-items: center;
}

.cp-btn--cta-green-row {
  width: 275px;
}

.cp-pb-rr__text {
  margin-top: 1px;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-pb-hero__media {
    aspect-ratio: 744/271;
  }
  .cp-pb-cta__actions {
    grid-template-columns: repeat(2, max-content);
    justify-content: center;
    gap: 64px;
  }
  .cp-pb-cta .cp-btn--cta-white {
    width: 300px;
  }
  .cp-pb-cta .cp-btn--cta-green-row {
    width: 300px;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-pb-hero__media {
    aspect-ratio: 1440/515;
  }
  .cp-pb-cta__actions {
    gap: 96px;
  }
  .cp-pb-cta .cp-btn {
    width: 325px;
  }
}
/* =========================
   XL (>= 1280px)
========================= */
@media (min-width: 1280px) {
  .cp-pb-cta__actions {
    gap: 128px;
  }
  .cp-pb-cta .cp-btn {
    width: 375px;
  }
}
/* =========================================================
   PARE-BRISE — ASSURANCES (mobile-first)
  ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-pb-assu {
  background: var(--color-blanc);
}

.cp-pb-assu__band {
  margin-left: calc(50% - 50vw);
  background: var(--color-platinum);
}

.cp-pb-assu__h2 {
  margin: 0;
  padding: 16px 0;
  text-align: center;
  color: var(--color-bleuFond);
}

.cp-pb-assu__break {
  display: block;
}

@media (min-width: 361px) {
  .cp-pb-assu__break {
    display: inline;
  }
}
.cp-pb-assu__panel {
  background: var(--color-bleuFond);
  position: relative;
}

/* grain */
.cp-pb-assu__panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-pb-assu__inner {
  padding: 48px 0;
  position: relative;
  z-index: 1;
}

.cp-pb-assu__panel,
.cp-pb-assu__panel p,
.cp-pb-assu__panel li,
.cp-pb-assu__panel span {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

.cp-pb-assu__stack {
  display: flex;
  flex-direction: column;
  gap: 48px;
  color: var(--color-blanc);
}

.cp-pb-assu__intro {
  display: grid;
  text-align: center;
  gap: 8px;
}

.cp-pb-assu__intro-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.cp-pb-assu__intro-title {
  order: 1;
}

.cp-pb-assu__chevrons {
  order: 2;
}

.cp-pb-assu__chevrons {
  display: block;
  width: 30px;
  height: auto;
  margin: 0 auto;
}

.cp-pb-assu__intro-title {
  font-style: italic;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--color-blanc);
}

.cp-pb-assu__intro-text {
  margin: 0;
  margin-top: 20px;
  font-weight: 600;
  font-size: 14px;
  line-height: 24px;
  max-width: 497px;
  margin-inline: auto;
}

/* Grille 9 cases (mobile = stack simple) */
.cp-pb-assu__grid9 {
  display: grid;
  gap: 32px;
}

/* Blocs */
.cp-pb-assu__block {
  display: grid;
  justify-items: start;
}

.cp-pb-assu__block--assureurs {
  margin: 0;
  padding: 0;
}

/* Titre + chevron */
.cp-pb-assu__block-head {
  display: inline-flex;
  gap: 8px;
}

.cp-pb-assu__chevron {
  display: block;
  width: 12px;
  height: auto;
}

.cp-pb-assu__block-title {
  margin: 0;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 14px;
  line-height: 33px;
  color: var(--color-blanc);
}

.cp-pb-assu__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16px;
}

.cp-pb-assu__item {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  margin-left: 25px;
}

.cp-pb-assu__bullet {
  width: 17px;
  height: 17px;
  margin-top: 3px;
  flex: 0 0 16px;
  display: block;
}

.cp-pb-assu__text {
  display: block;
  font-weight: 600;
  font-size: 14px;
  line-height: 24px;
  color: var(--color-blanc);
}

/* Assureurs */
.cp-pb-assu__assureurs {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 32px;
}

.cp-pb-assu__assureurs-col {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}

.cp-pb-assu__assureurs-all {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-left: 25px;
}

/* Logo */
.cp-pb-assu__logoWrap {
  display: grid;
  justify-items: center;
}

.cp-pb-assu__logo {
  display: block;
  width: 180px;
  height: auto;
}

/* CTA */
.cp-pb-assu__ctaWrap {
  display: grid;
  justify-items: center;
}

.ctnSections {
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 32px;
}

.cp-btn-assur {
  width: 275px;
}

.cp-pb-assu .cp-btn-assur {
  position: relative;
  overflow: hidden;
}

/* Fond bleu — pas de halo blanc inset (même rendu que nav/footer) */
.cp-pb-assu__panel .cp-btn.cp-btn--cta-white.cp-inset::after {
  box-shadow: none;
}

/* Underline signature (invisible au repos) */
.cp-pb-assu .cp-btn-assur::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  top: auto;
  bottom: -3px;
  height: 6px;
  background: linear-gradient(110deg, transparent 0%, rgba(198, 0, 0, 0.4) 30%, rgb(198, 0, 0) 50%, rgba(198, 0, 0, 0.4) 70%, transparent 100%);
  border-radius: 100px;
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 280ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 220ms ease;
  pointer-events: none;
}

/* Hover desktop seulement */
@media (hover: hover) and (pointer: fine) {
  .cp-pb-assu .cp-btn-assur:hover::before {
    opacity: 1;
    transform: scaleX(1);
  }
}
/* Focus clavier */
.cp-pb-assu .cp-btn-assur:focus-visible::before {
  opacity: 1;
  transform: scaleX(1);
}

/* (Optionnel) Tap mobile/tablette */
.cp-pb-assu .cp-btn-assur:active::before {
  opacity: 1;
  transform: scaleX(1);
}

/* Hover desktop seulement */
@media (hover: hover) and (pointer: fine) {
  .cp-pb-assu .cp-btn-assur:hover::after {
    opacity: 1;
    transform: scaleX(1);
  }
}
/* Focus clavier */
.cp-pb-assu .cp-btn-assur:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
}

.cp-pb-assu .cp-btn-assur:active::after {
  opacity: 1;
  transform: scaleX(1);
}

/* =========================
   MD (>= 768px)
   - Intro alignée à droite
   - Grid 9 cases active
========================= */
@media (min-width: 768px) {
  .ctnSections {
    display: contents; /* ✅ crucial */
  }
  body .cp-pb-assu__inner {
    padding: 64px 32px;
  }
  .cp-pb-assu__stack {
    gap: 32px;
  }
  /* Intro à droite */
  .cp-pb-assu__intro {
    text-align: left;
    max-width: 520px;
    align-self: flex-end;
  }
  .cp-pb-assu__intro-title {
    margin: 0;
    margin-top: -4px;
    font-size: 20px;
    line-height: 33px;
    order: 2;
    letter-spacing: 0.5px;
  }
  .cp-pb-assu__intro-head {
    flex-direction: row;
    align-items: center;
    gap: 16px;
    margin-left: -45px;
    justify-content: flex-start;
  }
  .cp-pb-assu__chevrons {
    order: 1;
    margin: 0;
    flex-shrink: 0;
  }
  .cp-pb-assu__intro-text {
    font-size: 16px;
    line-height: 24px;
    margin-inline: 0;
    max-width: 300px;
    margin-top: 5px;
    font-weight: 400;
  }
  .cp-pb-assu__block-title {
    font-size: 18px;
    line-height: 33px;
    font-weight: 500;
    letter-spacing: 0.5px;
  }
  .cp-pb-assu__text {
    font-size: 16px;
    line-height: 24px;
    font-weight: 400;
  }
  .cp-pb-assu__item {
    margin-left: 25px;
  }
  /* ✅ Grid 9 cases */
  .cp-pb-assu__grid9 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, auto);
    gap: 48px;
    width: 100%;
  }
  .cp-pb-assu__block--verif {
    grid-column: 1/span 2;
    grid-row: 1;
    margin-left: -32px;
  }
  .cp-pb-assu__block--reclam {
    grid-column: 2/span 3;
    grid-row: 2;
    margin-left: -35px;
  }
  .cp-pb-assu__logoWrap {
    grid-column: 1;
    grid-row: 3;
    justify-items: end;
    align-self: end;
  }
  .cp-pb-assu__logo {
    width: 160px;
  }
  .cp-pb-assu__assureurs {
    margin-top: 5px;
  }
  .cp-btn-assur {
    width: 300px;
  }
  .cp-pb-assu__block--assureurs {
    grid-column: 2/span 3;
    grid-row: 3;
    justify-self: end;
    margin-right: -30px;
  }
  /* CTA sous la grille */
  .cp-pb-assu__ctaWrap {
    justify-items: center;
    margin-top: 35px;
  }
}
/* =========================
   LG (>= 1024px)
   - Même système
   - Plus aéré
========================= */
@media (min-width: 1024px) {
  .cp-pb-assu__h2 {
    font-size: 24px;
  }
  .cp-pb-assu__inner {
    padding: 90px 0;
  }
  .cp-pb-assu__stack {
    gap: 48px;
  }
  .cp-pb-assu__intro-title {
    font-size: 28px;
    line-height: 33px;
  }
  .cp-pb-assu__block-title {
    margin-bottom: 3px;
  }
  .cp-pb-assu__block-title-assur {
    margin-top: 7px;
  }
  .cp-pb-assu__text {
    font-size: 16px;
    line-height: 24px;
  }
  .cp-pb-assu__intro-text {
    font-size: 16px;
    line-height: 24px;
    max-width: 520px;
  }
  .cp-pb-assu__grid9 {
    gap: 64px;
  }
  .cp-pb-assu__logo {
    width: 220px;
  }
  .cp-pb-assu__ctaWrap {
    margin-top: 0;
  }
  .cp-btn-assur {
    width: 325px;
  }
}
/* =========================
   XL (>= 1280px)
========================= */
@media (min-width: 1280px) {
  .cp-pb-assu__block--verif {
    margin-left: -3rem;
  }
  .cp-pb-assu__block--assureurs {
    margin-right: -3rem;
    margin-top: -5px;
  }
  .cp-btn-assur {
    width: 350px;
    margin-top: 24px;
  }
}
/* =========================================================
   PARE-BRISE — MANUFACTURIERS

   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-pb-manu__band {
  margin-left: calc(50% - 50vw);
  background: var(--color-bleuFond);
  position: relative;
}

/* grain */
.cp-pb-manu__band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-pb-manu__h2 {
  margin: 0;
  padding: 16px 12px;
  text-align: center;
  color: var(--color-blanc);
  position: relative;
  z-index: 1;
}

.cp-pb-manu__inner {
  padding: 48px 0;
  display: grid;
  justify-items: center;
  text-align: center;
}

.cp-pb-manu__lead {
  margin: 0 0 32px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
  display: block;
}

.cp-pb-manu__lead-break {
  display: block;
}

.cp-pb-manu__grid {
  width: 100%;
  display: grid;
  gap: 20px;
  justify-items: center;
}

.cp-pb-manu__card {
  width: 275px;
  height: 275px;
  border-radius: 5px;
  overflow: hidden;
  background: var(--color-platinum);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  display: grid;
  grid-template-rows: auto 1fr;
}

.cp-pb-manu__card--brand {
  background: var(--color-bleuFond);
  position: relative;
}

/* grain */
.cp-pb-manu__card--brand::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-pb-manu__card-head {
  background: var(--color-platinum);
  height: 40px;
  border-radius: 5px 5px 0 0;
  display: grid;
  place-items: center;
  padding: 0 16px;
}

.cp-pb-manu__card-head--dark {
  background: var(--color-grisGunmetal);
}

.cp-pb-manu__card-title {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-grisGunmetal);
  font-size: 18px;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.cp-pb-manu__card-title--light {
  color: var(--color-platinum);
}

.cp-pb-manu__media {
  background: var(--color-platinum);
  height: 100%;
}

.cp-pb-manu__picture {
  display: block;
  width: 100%;
  height: 100%;
}

.cp-pb-manu__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cp-pb-manu__card-body {
  padding: 8px;
  height: 100%;
  display: grid;
  align-content: center;
  gap: 24px;
}

.cp-pb-manu__card-body-ahp {
  margin-top: -10px;
  gap: 24px;
}

.cp-pb-manu__p {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: 13px;
  line-height: 21px;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
}

.cp-pb-manu__brand-inner {
  height: 100%;
  padding: 48px 8px;
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 24px;
  text-align: center;
}

.cp-pb-manu__brand-title {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-style: italic;
  font-size: 20px;
  line-height: 1.2;
  color: var(--color-blanc);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.cp-pb-manu__brand-text {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 30px;
  color: var(--color-blanc);
  text-transform: uppercase;
}

.cp-pb-manu__brand-mark {
  display: block;
  width: 100px;
  height: auto;
}

.cp-pb-manu__card-title-tec {
  font-size: 18px;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-pb-manu__h2 {
    padding: 16px 16px;
    font-size: 20px;
  }
  .cp-pb-manu__grid {
    grid-template-columns: repeat(2, 275px);
    justify-content: center;
    align-items: start;
    gap: 45px;
  }
  .cp-pb-manu__card {
    width: 275px;
    height: 275px;
  }
  .cp-pb-manu__p {
    font-size: 13px;
    line-height: 21px;
  }
  .cp-pb-manu__brand-inner {
    padding: 48px 8px;
    gap: 24px;
  }
  .cp-pb-manu__brand-title {
    font-size: 20px;
  }
  .cp-pb-manu__brand-text {
    font-size: 16px;
    line-height: 30px;
  }
  .cp-pb-manu__lead-break {
    display: inline;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-pb-manu__h2 {
    padding: 16px 16px;
    font-size: 24px;
  }
  .cp-pb-manu__grid {
    grid-template-columns: repeat(2, 275px);
    justify-content: center;
    align-items: start;
    gap: 65px;
  }
  .cp-pb-manu__card {
    width: 275px;
    height: 275px;
  }
  .cp-pb-manu__card-head {
    height: 40px;
    padding: 0 16px;
  }
  .cp-pb-manu__card-title {
    font-size: 18px;
  }
  .cp-pb-manu__p {
    font-size: 13px;
    line-height: 21px;
  }
  .cp-pb-manu__brand-inner {
    padding: 48px 8px;
    gap: 24px;
  }
  .cp-pb-manu__brand-title {
    font-size: 20px;
  }
  .cp-pb-manu__brand-text {
    font-size: 16px;
    line-height: 30px;
  }
  .cp-pb-manu__card-title-tec {
    font-size: 18px;
  }
  .cp-pb-manu__lead-break {
    display: inline;
  }
}
/* =========================
   XL (>= 1280px)
========================= */
@media (min-width: 1280px) {
  .cp-pb-manu__h2 {
    padding: 16px 16px;
    font-size: 24px;
  }
  .cp-pb-manu__card-body-ahp {
    margin-top: -10px;
    gap: 32px;
  }
  .cp-pb-manu__grid {
    grid-template-columns: repeat(2, 400px);
    justify-content: center;
    align-items: start;
    gap: 65px;
  }
  .cp-pb-manu__card {
    width: 400px;
    height: 400px;
  }
  .cp-pb-manu__card-head {
    height: 60px;
    padding: 0 24px;
  }
  .cp-pb-manu__card-title {
    font-size: 20px;
  }
  .cp-pb-manu__p {
    font-size: 18px;
    line-height: 27px;
  }
  .cp-pb-manu__brand-inner {
    padding: 64px 12px;
    gap: 48px;
  }
  .cp-pb-manu__brand-title {
    font-size: 28px;
  }
  .cp-pb-manu__brand-text {
    font-size: 20px;
    line-height: 30px;
  }
  .cp-pb-manu__brand-mark {
    width: 120px;
  }
  .cp-pb-manu__card-title-tec {
    font-size: 20px;
  }
}
/* =========================================================
   PARE-BRISE — MEMBRES
   ========================================================= */
.cp-pb-membres {
  padding: 32px 0;
}

.cp-pb-membres__inner {
  display: grid;
  gap: 24px;
  justify-items: center;
  text-align: center;
}

.cp-pb-membres__lead {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 18px;
  color: var(--color-bleuTexte);
}

.cp-pb-membres__lead-break {
  display: inline;
}

@media (max-width: 400px) {
  .cp-pb-membres__lead-break {
    display: block;
  }
}
.cp-pb-membres__row {
  display: grid;
  align-items: center;
  justify-items: center;
  row-gap: 16px;
  grid-template-columns: auto auto;
  grid-template-areas: "logo-left logo-right" "title      title";
}

.cp-pb-membres__logo--vx {
  grid-area: logo-left;
  width: 80px;
}

.cp-pb-membres__logo--cp {
  grid-area: logo-right;
  width: 80px;
}

.cp-pb-membres__title {
  grid-area: title;
  text-align: center;
  font-weight: 600;
  margin-top: 12px;
}

.cp-pb-membres__logo {
  display: block;
  height: auto;
}

@media (min-width: 768px) {
  .cp-pb-membres__row {
    column-gap: 32px;
    max-width: 860px;
  }
  .cp-pb-membres__lead {
    font-size: 22px;
  }
  .cp-pb-membres__title {
    font-size: 24px;
  }
  .cp-pb-membres__logo--vx,
  .cp-pb-membres__logo--cp {
    width: 80px;
  }
}
@media (min-width: 1024px) {
  .cp-pb-membres__row {
    column-gap: 48px;
    max-width: 980px;
  }
  .cp-pb-membres__lead {
    font-size: 22px;
  }
  .cp-pb-membres__title {
    font-size: 24px;
    margin-top: 1rem;
    letter-spacing: 1px;
  }
  .cp-pb-membres__logo--vx,
  .cp-pb-membres__logo--cp {
    width: 110px;
    margin: 16px 0;
  }
}
@media (min-width: 1280px) {
  .cp-pb-membres__inner {
    margin-top: 32px;
  }
  .cp-pb-membres__row {
    grid-template-columns: auto 1fr auto;
    grid-template-areas: "logo-left title logo-right";
    align-items: center;
    column-gap: 48px;
    margin-top: 12px;
    max-width: 980px;
  }
  .cp-pb-membres__lead {
    font-size: 24px;
  }
  .cp-pb-membres__title {
    font-size: 28px;
    text-align: center;
  }
  .cp-pb-membres__logo--vx,
  .cp-pb-membres__logo--cp {
    width: 110px;
  }
}
/* =========================================================
   PARE-BRISE - Proximité
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-pb-proximite {
  padding: 64px 16px;
}

.cp-pb-proximite__inner {
  display: grid;
  justify-items: center;
  text-align: center;
}

.ligne_h2 {
  border: 0;
  height: 1px;
  width: 200px;
  margin-bottom: 24px;
  background-color: rgba(209, 213, 219, 0.6);
}

.cp-pb-proximite__head {
  display: grid;
  gap: 16px;
  justify-items: center;
}

.cp-pb-proximite__title {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 27px;
  text-transform: uppercase;
}

.cp-pb-proximite__rule {
  width: min(520px, 100%);
  height: 1px;
  border: 0;
  background: var(--color-platinum);
  margin: 0;
}

.cp-pb-proximite__body {
  display: grid;
  gap: 16px;
  width: 100%;
  max-width: 46ch;
}

.cp-pb-proximite__p {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 36px;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-pb-proximite__title {
    font-size: 22px;
    line-height: 30px;
  }
  .ligne_h2 {
    border: 0;
    height: 1px;
    width: 400px;
    margin-bottom: 24px;
    background-color: rgba(209, 213, 219, 0.6);
  }
  .cp-pb-proximite__rule {
    width: min(760px, 100%);
  }
  .cp-pb-proximite__body {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    max-width: 980px;
  }
  .cp-pb-proximite__p {
    font-size: 18px;
    line-height: 36px;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-pb-proximite {
    padding: 96px 16px;
  }
  .cp-pb-proximite__title {
    font-size: 24px;
    line-height: 33px;
  }
  .ligne_h2 {
    border: 0;
    height: 1px;
    width: 425px;
    margin-bottom: 24px;
    background-color: rgba(209, 213, 219, 0.6);
  }
  .cp-pb-proximite__p {
    font-size: 20px;
    line-height: 40px;
  }
}
/* =========================
   XL (>= 1280px)
========================= */
@media (min-width: 1280px) {
  .ligne_h2 {
    border: 0;
    height: 1px;
    width: 475px;
    margin-bottom: 24px;
    background-color: rgba(209, 213, 219, 0.6);
  }
  .cp-pb-proximite__title {
    font-size: 28px;
    line-height: 36px;
  }
  .cp-pb-proximite__p {
    font-size: 20px;
    line-height: 44px;
  }
}
/* =========================================================
   PARE-BRISE — DUO (mobile-first)
   Fond: bleu (t.$bleuFond)
   Tous textes: heading
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-pb-duo {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  padding: 64px 10px;
  position: relative;
}

/* grain */
.cp-pb-duo::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-pb-duo__inner {
  display: grid;
  text-align: center;
  position: relative;
  z-index: 1;
}

.cp-pb-duo__brand {
  display: grid;
  justify-items: center;
}

.cp-pb-duo__brand-mark {
  display: block;
  width: 190px;
  height: auto;
}

.cp-pb-duo__content {
  display: grid;
  gap: 24px;
  justify-items: center;
}

.cp-pb-duo__slash {
  display: block;
  width: 72px;
  height: auto;
  margin-top: 24px;
}

.cp-pb-duo__title {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 28px;
  text-transform: uppercase;
}

.cp-pb-duo__text {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: 16px;
  line-height: 30px;
  max-width: 42ch;
}

/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-pb-duo {
    padding: 48px 0 84px 0;
    padding-inline: 45px;
  }
  .cp-pb-duo__inner {
    gap: 48px;
  }
  .cp-pb-duo__brand {
    justify-items: end;
  }
  .cp-pb-duo__brand-mark {
    width: 240px;
  }
  .cp-pb-duo__content {
    gap: 32px;
  }
  .cp-pb-duo__slash {
    width: 96px;
    margin-top: 0;
  }
  .cp-pb-duo__title {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
  }
  .cp-pb-duo__text {
    font-weight: 500;
    font-size: 16px;
    line-height: 35px;
    max-width: 90ch;
    margin-top: -15px;
  }
  .cp-pb-duo__content {
    grid-template-columns: auto 1fr;
    align-items: start;
    column-gap: 24px;
    justify-items: start;
    text-align: left;
    gap: 0;
  }
  .cp-pb-duo__slash {
    grid-column: 1;
    margin-top: 2px;
  }
  .cp-pb-duo__title,
  .cp-pb-duo__text {
    grid-column: 2;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-pb-duo {
    padding: 48px 55px 84px 45px;
  }
  .cp-pb-duo__brand {
    justify-items: end;
    align-content: start;
  }
  .cp-pb-duo__brand-mark {
    width: 260px;
  }
  .cp-pb-duo__content {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    column-gap: 24px;
    justify-items: start;
    text-align: left;
    gap: 0;
  }
  .cp-pb-duo__slash {
    width: 110px;
    grid-column: 1;
    margin-top: 2px;
  }
  .cp-pb-duo__title {
    font-weight: 600;
    font-size: 22px;
    line-height: 33px;
    grid-column: 2;
  }
  .cp-pb-duo__text {
    font-weight: 400;
    font-size: 18px;
    line-height: 40px;
    max-width: 62ch;
    grid-column: 2;
    margin-top: -25px;
  }
  .cp-pb-duo__content p {
    margin-left: 25px;
  }
}
/* =========================
   XL (>= 1280px) 
========================= */
@media (min-width: 1280px) {
  .cp-pb-duo {
    padding: 64px 55px 104px 45px;
  }
}
/* =========================================================
   PARE-BRISE — GARANTIE À VIE 
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-pb-gav__band {
  margin-left: calc(50% - 50vw);
  background: var(--color-vitrxpert);
}

.cp-pb-gav__h2 {
  margin: 0;
  padding: 12px 10px;
  text-align: center;
  color: var(--color-blanc);
}

.cp-pb-gav__inner {
  padding: 48px 0;
}

.cp-pb-gav__grid {
  display: grid;
  gap: 24px;
  justify-items: center;
  text-align: center;
}

.cp-pb-gav__left,
.cp-pb-gav__right {
  max-width: 520px;
}

.cp-pb-gav__h3 {
  margin: 0 0 24px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
  font-size: 18px;
  line-height: 28px;
}

.cp-pb-gav__lead {
  margin: 0 0 32px 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--color-bleuTexte);
  text-align: center;
  max-width: 447px;
  font-size: 16px;
  line-height: 26px;
}

.cp-pb-gav__list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  display: grid;
  gap: 8px;
  justify-content: center;
}

.cp-pb-gav__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  text-align: left;
  width: fit-content;
  max-width: 520px;
}

.cp-pb-gav__bullet {
  width: 17px;
  height: 17px;
  margin-top: 6px;
  flex: 0 0 17px;
  display: block;
}

.cp-pb-gav__text {
  display: block;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
  margin-top: -3px;
  font-size: 16px;
  line-height: 28px;
}

.cp-pb-gav__right {
  display: grid;
  justify-items: center;
  gap: 32px;
}

.cp-pb-gav__badge {
  display: block;
  width: 180px;
  height: auto;
}

.cp-pb-gav__program {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--color-bleuTexte);
  font-size: 16px;
  line-height: 26px;
}

.cp-pb-gav__break {
  display: block;
}

@media (min-width: 451px) {
  .cp-pb-gav__break {
    display: inline;
  }
}
/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-pb-gav__h2 {
    padding: 16px 10px;
  }
  body .cp-pb-gav__inner {
    padding: 64px 24px;
  }
  .cp-pb-gav__grid {
    grid-template-columns: 1fr 1fr;
    align-items: start;
    justify-items: stretch;
    text-align: left;
    gap: 32px;
  }
  .cp-pb-gav__left,
  .cp-pb-gav__right {
    max-width: none;
  }
  .cp-pb-gav__h3 {
    font-size: 18px;
    line-height: 30px;
  }
  .cp-pb-gav__lead {
    font-size: 16px;
    line-height: 24px;
    text-align: left;
  }
  .cp-pb-gav__list {
    justify-items: start;
    gap: 4px;
    margin: 40px 0 0 -5px;
    justify-content: start;
  }
  .cp-pb-gav__text {
    font-size: 15px;
    line-height: 22px;
    margin-top: 0;
  }
  .cp-pb-gav__right {
    justify-items: center;
    text-align: center;
    margin-top: 15px;
  }
  .cp-pb-gav__badge {
    width: 180px;
  }
  .cp-pb-gav__program {
    font-size: 14px;
    line-height: 28px;
    min-width: 340px;
  }
}
.cp-pb-gav__bullet {
  width: 19px;
  height: 19px;
  margin-top: 2px;
  flex: 0 0 17px;
  display: block;
}

/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-pb-gav__h2 {
    font-size: 24px;
  }
  body .cp-pb-gav__inner {
    padding: 64px 64px;
  }
  .cp-pb-gav__grid {
    grid-template-columns: 1.15fr 0.85fr;
    gap: 65px;
  }
  .cp-pb-gav__h3 {
    font-size: 20px;
    line-height: 33px;
  }
  .cp-pb-gav__lead {
    font-size: 18px;
    line-height: 27px;
  }
  .cp-pb-gav__text {
    font-size: 16px;
    line-height: 24px;
  }
  .cp-pb-gav__badge {
    width: 180px;
  }
  .cp-pb-gav__program {
    font-size: 18px;
    line-height: 27px;
    min-width: 450px;
  }
}
/* =========================
   XL (>= 1280px)
========================= */
@media (min-width: 1280px) {
  body .cp-pb-gav__inner {
    padding: 64px 0;
  }
  .cp-pb-gav__grid {
    gap: 65px;
  }
  .cp-pb-gav__right {
    gap: 32px;
  }
  .cp-pb-gav__h3 {
    font-size: 22px;
  }
  .cp-pb-gav__lead {
    font-size: 20px;
    line-height: 30px;
    margin-bottom: 48px;
  }
  .cp-pb-gav__text {
    font-size: 18px;
    line-height: 27px;
  }
  .cp-pb-gav__program {
    font-size: 20px;
    line-height: 30px;
    min-width: 500px;
  }
  .cp-pb-gav__bullet {
    width: 21px;
    height: 21px;
    margin-top: 3px;
    flex: 0 0 17px;
    display: block;
  }
}
/* =========================================================
   PARE-BRISE — RÉPARER / REMPLACER 
   ========================================================= */
/* =========================
   MOBILE (base)
========================= */
.cp-pb-rr__band {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  background: var(--color-vitrxpert);
}

.cp-pb-rr__h2 {
  margin: 0;
  padding: 16px 0;
  text-align: center;
  color: var(--color-blanc);
}

.cp-pb-rr__break {
  display: inline;
}

@media (max-width: 380px) {
  .cp-pb-rr__break {
    display: block;
  }
}
.cp-pb-rr__inner {
  padding: 48px 0;
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 32px;
}

.cp-pb-rr__logoWrap {
  display: grid;
  justify-items: center;
}

.cp-pb-rr__logo {
  display: block;
  width: 210px;
  height: auto;
}

.cp-pb-rr__h3 {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
}

.cp-pb-rr__cols {
  display: grid;
  gap: 24px;
  width: 100%;
  max-width: 520px;
}

.cp-pb-rr__col {
  display: grid;
  gap: 0;
  justify-items: center;
  width: 100%;
}

.cp-pb-rr__h4 {
  margin-left: 58px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-bleuTexte);
  width: 100%;
  text-align: left;
  letter-spacing: 2px;
}

.cp-pb-rr__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  color: var(--color-bleuTexte);
}

.cp-pb-rr__bullet {
  width: 17px;
  height: 17px;
  margin-top: 6px;
  flex: 0 0 14px;
  display: block;
}

.cp-pb-rr__line {
  display: block;
}

.cp-pb-rr__text {
  display: block;
  font-weight: 400;
}

.cp-pb-rr__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16px;
  width: 100%;
  text-align: left;
}

.cp-pb-rr__li {
  position: relative;
  padding-left: 26px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  color: var(--color-bleuTexte);
}

.cp-pb-rr__li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 14px;
  height: 14px;
  background: url("../../img/puce_benefices_gabarit.svg") no-repeat center/contain;
}

.cp-pb-rr .cp-btn--blanc,
.cp-pb-rr .cp-btn--cta-green {
  width: 275px;
}

/* =========================
   Accordéon — mobile seulement (< 768px)
   Fond platinum : .cp-pb-rr__col
========================= */
@media (max-width: 767px) {
  .cp-pb-rr__col {
    border-radius: 4px;
    overflow: hidden;
    background: var(--color-platinum);
  }
  .cp-pb-rr__acc-btn {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    background: var(--color-platinum);
    border: none;
    cursor: pointer;
    padding: 16px 12px;
    text-align: left;
    gap: 16px;
    transition: background-color 180ms ease;
  }
  .cp-pb-rr__acc-btn .cp-pb-rr__h4 {
    margin-left: 0;
    margin-bottom: 0;
    color: var(--color-bleuTexte);
    letter-spacing: 2px;
  }
  .cp-pb-rr__acc-btn:focus-visible {
    outline: 2px solid var(--color-vitrxpert);
    outline-offset: -2px;
  }
}
@media (max-width: 767px) and (hover: hover) and (pointer: fine) {
  .cp-pb-rr__acc-btn:hover {
    background: var(--color-alabaster);
  }
}
@media (max-width: 767px) {
  .cp-pb-rr__acc-btn[aria-expanded=true] {
    background: var(--color-alabaster);
  }
  .cp-pb-rr__acc-icon {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .cp-pb-rr__acc-icon::before {
    content: "";
    display: block;
    width: 9px;
    height: 9px;
    border-right: 2px solid var(--color-bleuTexte);
    border-bottom: 2px solid var(--color-bleuTexte);
    transform: rotate(-45deg);
    transition: transform 0.22s ease;
  }
  .cp-pb-rr__acc-btn[aria-expanded=true] .cp-pb-rr__acc-icon::before {
    transform: rotate(45deg);
  }
  .cp-pb-rr__acc-panel {
    display: grid;
    gap: 16px;
    justify-items: center;
    width: 100%;
    background: var(--color-platinum);
    padding: 16px 12px 24px;
  }
  .cp-pb-rr__acc-panel[hidden] {
    display: none !important;
  }
}
/* =========================
   MD (>= 768px)
========================= */
@media (min-width: 768px) {
  .cp-pb-rr__col {
    gap: 16px;
    border-radius: 8px; /* pour que cp-inset arrondisse l'ombre */
    padding: 32px 24px; /* tablette : air vertical généreux */
  }
  .cp-pb-rr__acc-btn {
    display: block;
    width: 100%;
    background: none;
    border: none;
    padding: 8px 0;
    cursor: default;
    pointer-events: none;
    text-align: left;
  }
  .cp-pb-rr__acc-icon {
    display: none;
  }
  .cp-pb-rr__acc-panel {
    display: grid !important;
    gap: 16px;
    justify-items: center;
    width: 100%;
    border-top: none;
    padding: 0;
  }
  .cp-pb-rr__acc-panel[hidden] {
    display: grid !important;
  }
  .cp-pb-rr__acc-btn .cp-pb-rr__h4 {
    margin-left: 0; /* le padding du col gère l'indent : titre aligné avec les icônes */
    color: var(--color-bleuTexte);
  }
  .cp-pb-rr__h2 {
    padding: 8px;
    font-size: 24px;
  }
  .cp-pb-rr__inner {
    gap: 12px;
  }
  .cp-pb-rr__logoWrap {
    justify-items: start;
    width: 100%;
    margin-left: 5%;
  }
  .cp-pb-rr__logo {
    width: 260px;
  }
  .cp-pb-rr__h3 {
    font-size: 20px;
  }
  .cp-pb-rr__bullet {
    width: 19px;
    height: 19px;
    margin-top: 6px;
  }
  .cp-pb-rr__text {
    font-size: 18px;
  }
  .cp-pb-rr__cols {
    max-width: 640px; /* tablette : colonnes empilées, centrées, sans débordement */
    gap: 48px;
    margin: 0 auto;
    padding-inline: 24px;
    box-sizing: border-box;
  }
  .cp-btn--blanc {
    color: var(--color-bleuTexte);
    width: 325px;
  }
  .cp-pb-rr .cp-btn--blanc,
  .cp-pb-rr .cp-btn--cta-green {
    width: 300px;
  }
}
/* =========================
   LG (>= 1024px)
========================= */
@media (min-width: 1024px) {
  .cp-pb-rr__inner {
    text-align: center;
  }
  .cp-pb-rr__logoWrap {
    margin-top: -10px;
  }
  .cp-pb-rr__line {
    display: inline;
  }
  .cp-pb-rr__cols {
    grid-template-columns: 1fr 1fr;
    align-items: stretch; /* les deux colonnes prennent la meme hauteur */
    max-width: 980px;
    padding: 32px 16px;
  }
  .cp-pb-rr__col {
    display: flex;
    flex-direction: column;
    margin-top: -15px;
    gap: 16px;
    padding: 24px 48px; /* desktop : plus de padding horizontal */
  }
  /* Le panneau grandit pour remplir la hauteur ; le bouton est pousse au bas
     -> les boutons des deux cartes s'alignent a la meme hauteur. */
  .cp-pb-rr__acc-panel,
  .cp-pb-rr__acc-panel[hidden] {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    flex: 1 1 auto;
    gap: 16px;
  }
  .cp-pb-rr__cta {
    margin-top: auto;
  }
}
/* Layout */
.cp-skip-link {
  position: absolute;
  left: 1rem;
  top: -100%;
  z-index: 10000;
  padding: 0.7rem 1rem;
  background: var(--color-bleuTexte);
  color: #fff;
  text-decoration: none;
  border-radius: 0 0 8px 8px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  transition: top 0.2s ease;
}

.cp-skip-link:focus-visible {
  top: 0;
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* ==========================================================================
   HEADER — TOP BAR (barre du haut uniquement)
   ========================================================================== */
/* ======================================================================
   MOBILE — BASE
   ====================================================================== */
.site-header {
  box-shadow: inset -1px -2px 4px 1px rgba(0, 0, 0, 0.06);
  background-color: var(--color-alabaster);
}

.site-header__ctn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.2rem;
  padding: 20px 0 5px 15px;
}

.site-header__brand {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  font-size: 14px;
}

.site-header__logo {
  display: inline-block;
  line-height: 0;
}

.site-header__icon {
  display: inline-block;
  width: 35px;
  height: 35px;
}

.site-header__icon--burger {
  width: 42px;
  height: 42px;
  display: inline-block;
  transform: translateY(-3px);
}

.site-header__actions {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin-top: -25px;
  padding: 0 10px;
}

.site-header__action--sms {
  margin-left: 12px;
}

.site-header__toggle {
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  border: none;
  background: transparent;
  margin-bottom: -7px;
}

/* Logos — variantes */
.site-header__logoSvg--mobile {
  display: inline-block;
}

.site-header__logoSvg--tablet {
  display: none;
}

.site-header__logoSvg--table {
  display: none;
}

/* Téléphone (barre du haut) */
.site-header__phone {
  display: inline-block;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.1;
  margin-top: 0.2rem;
  text-decoration: none;
  color: var(--color-bleuTexte);
  font-weight: 500;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.site-header__phone:hover {
  color: var(--color-rougeBrickember);
}

/* Ajustements mobile intermédiaires */
@media (min-width: 450px) and (max-width: 767px) {
  .site-header__ctn {
    padding: 30px 2% 5px 7%;
  }
  .site-header__actions {
    margin-top: -42px;
    padding: 0 25px 0 0;
  }
}
@media (min-width: 500px) and (max-width: 767px) {
  .site-header__actions {
    margin-top: -70px;
    margin-bottom: 15px;
    padding: 0 4% 5px 7%;
  }
}
/* ======================================================================
   TABLETTE — MD (≥ $bp-md)
   ====================================================================== */
@media (min-width: 768px) {
  .site-header__ctn {
    padding: 30px 7% 20px 8%;
    flex-direction: row;
    align-items: center;
    gap: 0;
    margin-inline: auto;
  }
  .site-header__brand {
    flex-direction: row;
    align-items: center;
    gap: 4px;
  }
  .site-header__icon {
    width: 38px;
    height: 38px;
  }
  .site-header__icon--burger {
    width: 43px;
    height: 43px;
  }
  .site-header__actions {
    width: auto;
    margin-top: 3px;
    padding: 0;
    align-items: center;
    gap: 12px;
  }
  .site-header__action--sms {
    margin-left: 18px;
    margin-top: 2px;
  }
  .site-header__toggle {
    width: 53px;
    height: 53px;
  }
  .site-header__logoSvg--mobile {
    display: none;
  }
  .site-header__logoSvg--tablet {
    display: inline-block;
  }
  .site-header__logoSvg--table {
    display: none;
  }
  .site-header__phone {
    font-size: 18px;
    line-height: 24px;
    font-weight: 600;
    margin: 4px 0 2px 5px;
  }
}
/* ======================================================================
   DESKTOP — LG (≥ $bp-lg)
   ====================================================================== */
@media (min-width: 1024px) {
  .site-header__ctn {
    padding: 30px 7% 20px 7%;
  }
  .site-header__icon {
    width: 40px;
    height: 40px;
  }
  .site-header__icon--burger {
    width: 50px;
    height: 50px;
  }
  .site-header__toggle {
    width: 58px;
    height: 58px;
  }
  .site-header__logoSvg--mobile {
    display: none;
  }
  .site-header__logoSvg--tablet {
    display: none;
  }
  .site-header__logoSvg--table {
    display: inline-block;
  }
  .site-header__phone {
    margin: 5px 0 2px 5px;
  }
}
/* ======================================================================
   DESKTOP LARGE — XL (≥ $bp-xl)
   ====================================================================== */
@media (min-width: 1280px) {
  .site-header__ctn {
    padding: 30px 7% 20px 8%;
  }
  .site-header__brand {
    flex-direction: row;
    align-items: center;
    gap: 12px;
  }
  .site-header__icon {
    width: 45px;
    height: 45px;
  }
  .site-header__icon--burger {
    width: 50px;
    height: 50px;
  }
  .site-header__toggle {
    width: 75px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
  }
  .site-header__logoSvg--mobile {
    display: none;
  }
  .site-header__logoSvg--tablet {
    display: none;
  }
  .site-header__logoSvg--table {
    display: inline-block;
  }
  .site-header__phone {
    margin: 7px 0 2px 5px;
  }
}
/* ==========================================================================
   HEADER — Interactive states 
   - Applique UNIQUEMENT aux éléments cliquables
   ========================================================================== */
.site-header {
  --hdr-ease: cubic-bezier(.2,.8,.2,1);
  --hdr-dur-fast: 140ms;
  --hdr-dur: 220ms;
  --hdr-focus: rgba(198, 0, 0, 0.55); /* rouge focus léger */
}

.site-header a,
.site-header button {
  -webkit-tap-highlight-color: transparent;
}

.site-header__logo,
.site-header__action,
.site-header__toggle,
.site-header__phone {
  position: relative;
  text-decoration: none;
  outline: none;
}

.site-header__logo:focus-visible,
.site-header__action:focus-visible,
.site-header__toggle:focus-visible,
.site-header__phone:focus-visible {
  outline: 2px solid var(--hdr-focus);
  outline-offset: 4px;
  border-radius: 8px;
}

.site-header__logo,
.site-header__action,
.site-header__toggle {
  transition: transform var(--hdr-dur-fast) var(--hdr-ease), opacity var(--hdr-dur) ease;
}

.site-header__phone {
  transition: color var(--hdr-dur) ease;
}

/* Active (clic) : micro press */
.site-header__logo:active,
.site-header__action:active {
  transform: translateY(1px);
}

/* Icônes : micro “lift” + légère opacité (subtil) */
@media (hover: hover) and (pointer: fine) {
  .site-header__logo:hover,
  .site-header__action:hover,
  .site-header__toggle:hover {
    transform: translateY(-1px);
  }
  .site-header__logo:hover .site-header__icon,
  .site-header__action:hover .site-header__icon,
  .site-header__toggle:hover .site-header__icon {
    opacity: 0.92;
  }
}
/* =========================
   Téléphone — underline moderne (pseudo-élément)
   - plus fin, plus “signature”
   - animable (scale/opacity)
   ========================= */
.site-header__phone {
  position: relative;
  text-decoration: none;
  transition: color var(--hdr-dur) ease;
  align-self: flex-start;
}

/* Ligne fine (invisible au repos) */
.site-header__phone::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  /* plus moderne : petite distance et ligne très fine */
  bottom: -3px;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: left center;
  transition: opacity var(--hdr-dur) ease, transform var(--hdr-dur) var(--hdr-ease);
}

@media (hover: hover) and (pointer: fine) {
  .site-header__phone:hover {
    color: var(--color-rougeBrickember);
  }
  .site-header__phone:hover::after {
    opacity: 0.95;
    transform: scaleX(1);
  }
}
.site-header__phone:focus-visible {
  color: var(--color-rougeBrickember);
}

.site-header__phone:focus-visible::after {
  opacity: 0.95;
  transform: scaleX(1);
}

.site-header__action,
.site-header__toggle {
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Disabled (SMS) : pas d’effet, pas de confusion */
.site-header__action[aria-disabled=true] {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
}

/* ==========================================================================
   FOOTER — Custom
   Mobile-first — Scaffold canon (Mobile → MD → LG → XL)
   IMPORTANT: effets/typos des liens = réutilise cp-nav__* (navigation.scss)
   ========================================================================== */
/* ========================================================================== */
/* MOBILE (défaut — hors media query)                                         */
/* ========================================================================== */
.site-footer {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  position: relative;
}

/* grain */
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.site-footer__tel {
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.5px;
}

.site-footer__info {
  position: relative;
  margin-top: 0;
  padding-top: 5px;
}

.site-footer__info::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: min(90%, 255px);
  height: 0.1px;
  opacity: 0.5;
  background-color: var(--color-rougeBrickember);
}

.site-footer__inner {
  padding-inline: 24px;
  position: relative;
  z-index: 1;
}

.cp-footer__info-title {
  font-size: 18px;
  margin-bottom: 4px;
}

.site-footer__col--services {
  margin-top: -60px;
}

.site-footer__col--info {
  margin-top: -60px;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  margin-left: 14px;
}

.site-footer__tiktok .site-footer__social-icon {
  width: 25px;
}

.site-footer__youtube .site-footer__social-icon {
  width: 35px;
}

.site-footer__facebook .site-footer__social-icon {
  width: 30px;
}

.site-footer__linkedin .site-footer__social-icon {
  width: 30px;
}

.site-footer__instagram .site-footer__social-icon {
  width: 30px;
}

.site-footer__block {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 32px;
}

.site-footer__col {
  padding: 32px 8px 0 8px;
}

/* List wrappers */
.site-footer__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
  padding-top: 16px;
}

.site-footer__list li {
  margin-bottom: 0;
}

.site-footer__list .site-footer__sub-link {
  margin-bottom: 1px;
}

.site-footer__link {
  font-size: 14px;
}

.site-footer__navLink {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-blanc);
  display: flex;
  align-items: center;
  width: 100%;
  padding: 4px 0 4px 0;
}

.site-footer__list--services {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-left: 12px;
}

.site-footer__social {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}

.site-footer__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  /* on laisse les effets “signature” à navigation.scss;
     ici juste une surface cliquable stable */
}

.site-footer__social-icon {
  display: block;
}

/* CTA */
.site-footer__cta {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.site-footer__bottom {
  margin-top: 32px;
  padding: 48px 0 64px 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  text-align: center;
}

.site-footer__brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.site-footer__logo {
  display: block;
  width: 220px;
  height: auto;
}

.site-footer__baseline {
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 13px;
  line-height: 18px;
  color: rgba(255, 255, 255, 0.85);
}

.site-footer__legal {
  font-family: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 12px;
  line-height: 18px;
  color: rgba(255, 255, 255, 0.75);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* ============================
   Footer — Social interactions
   ============================ */
.site-footer__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: background-color 160ms ease, transform 140ms ease;
}

.site-footer__social-icon {
  width: 24px;
  height: 24px;
  transition: transform 140ms ease;
}

/* Hover */
.site-footer__social-link:hover {
  background-color: rgba(255, 255, 255, 0.08);
  transform: translateY(-2px);
}

/* Active */
.site-footer__social-link:active {
  transform: translateY(1px);
}

.site-footer__btnCtn {
  width: 100%;
  margin-left: -14px;
  display: flex;
  justify-content: center;
}

body .site-footer__btn {
  width: 250px;
}

/* ========================================================================== */
/* TABLETTE — @media (min-width: $bp-md)                                      */
/* ========================================================================== */
@media (min-width: 768px) {
  .site-footer__inner {
    padding-inline: 32px;
  }
  .site-footer__col {
    padding-left: 24px;
  }
  .site-footer__grid {
    grid-template-columns: 1fr 1fr;
    column-gap: 32px;
    row-gap: 48px;
    align-items: start;
    padding-top: 32px;
    margin-left: 5%;
  }
  .site-footer__list--services {
    margin-top: -6px;
  }
  .site-footer__info {
    position: relative;
    margin-top: 0;
    padding-top: 8px;
  }
  .site-footer__info::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: min(90%, 255px);
    height: 0.1px;
    opacity: 0.4;
    background-color: var(--color-rougeBrickember);
  }
  .site-footer__tel {
    font-size: 16px;
  }
  .site-footer__col--nav {
    grid-column: 1;
  }
  .site-footer__col--services {
    grid-column: 2;
    margin-top: 0;
  }
  .site-footer__block-carriere {
    margin-top: 64px;
  }
  .site-footer__btnCtn {
    width: 100%;
    margin-left: 0;
    display: flex;
    justify-content: left;
  }
  .site-footer_btnTablette {
    width: 250px;
  }
  .site-footer__col--info {
    grid-column: 1;
  }
  .site-footer__cta {
    justify-content: center;
    margin-left: 24px;
  }
  .site-footer__bottom {
    align-items: center;
    text-align: center;
    margin: 0;
  }
  .site-footer__tiktok .site-footer__social-icon {
    width: 30px;
  }
  .site-footer__youtube .site-footer__social-icon {
    width: 40px;
  }
  .site-footer__facebook .site-footer__social-icon {
    width: 35px;
  }
  .site-footer__linkedin .site-footer__social-icon {
    width: 35px;
  }
  .site-footer__instagram .site-footer__social-icon {
    width: 35px;
  }
}
/* ========================================================================== */
/* DESKTOP — @media (min-width: $bp-lg)                                       */
/* ========================================================================== */
@media (min-width: 1024px) {
  .site-footer__grid {
    grid-template-columns: 1fr 1fr 1fr;
    column-gap: 0;
    row-gap: 48px;
    align-items: start;
    padding-top: 32px;
    margin-left: 2.5%;
  }
  .site-footer__list--services {
    margin-top: -6px;
  }
  /* Place le CTA dans la colonne INFO (col 3) */
  .site-footer__cta {
    grid-column: 3;
    grid-row: 2;
    justify-self: start;
    margin-left: 0;
    padding-left: 24px;
    margin-top: -230px;
  }
  .site-footer__block-carriere {
    margin-top: 80px;
  }
  .site-footer__col--nav {
    grid-column: 1;
  }
  .site-footer__col--services {
    grid-column: 2;
    margin-left: 2%;
  }
  .site-footer__col--info {
    grid-column: 3;
    margin-top: 0;
  }
  .site-footer__info::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: min(90%, 225px);
    height: 0.1px;
    opacity: 0.4;
    background-color: var(--color-rougeBrickember);
  }
  .site-footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    text-align: left;
    padding: 0 48px 64px 48px;
    margin-top: 0;
  }
  .site-footer__brand {
    align-items: flex-start;
    text-align: left;
  }
  .site-footer__legal {
    align-items: flex-end;
    text-align: right;
  }
}
/* =========================================================
   FOOTER — CTA SIGNATURE (identique nav)
   ========================================================= */
.site-footer__btn {
  position: relative;
  overflow: hidden; /* identique nav */
}

/* Underline signature (invisible au repos) */
.site-footer__btn::after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: -3px; /* identique nav */
  height: 6px; /* identique nav */
  background: linear-gradient(110deg, transparent 0%, rgba(198, 0, 0, 0.4) 30%, rgb(198, 0, 0) 50%, rgba(198, 0, 0, 0.4) 70%, transparent 100%);
  border-radius: 100px;
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 280ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 220ms ease;
  pointer-events: none;
}

/* Hover */
@media (hover: hover) and (pointer: fine) {
  .site-footer__btn:hover {
    background: var(--color-bleuFond);
    color: var(--color-blanc);
    border-color: transparent;
    box-shadow: none;
  }
  .site-footer__btn:hover::after {
    opacity: 1;
    transform: scaleX(1);
  }
}
/* Focus clavier (identique nav : même comportement, sans “look” additionnel) */
.site-footer__btn:focus-visible {
  background: var(--color-bleuFond);
  color: var(--color-blanc);
  border-color: transparent;
  box-shadow: none;
}

.site-footer__btn:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
}

.cp-container {
  width: 100%;
  margin-inline: auto;
  /* Mobile seulement : petite marge de sécurité */
  padding-inline: 10px;
}
@media (min-width: 768px) {
  .cp-container {
    max-width: 744px;
    padding-inline: 0; /* contenu = 744 réel */
  }
}
@media (min-width: 1024px) {
  .cp-container {
    max-width: 1000px;
    padding-inline: 0; /* contenu = 1000 réel */
  }
}
@media (min-width: 1280px) {
  .cp-container {
    max-width: 1000px;
    padding-inline: 0; /* contenu = 1000 réel */
  }
}

.cp-section {
  /* volontairement vide :
     cp-section = wrapper sémantique / structurel
     (pas de padding vertical automatique) */
}

/* =========================
   SECTION — CHAPTER RHYTHM
   Bande H2 bleed + respiration forte
   ========================= */
.cp-section.cp-section--chapter {
  padding-block: 0;
}

.cp-section.cp-section--chapter > .cp-band {
  margin-bottom: 45px;
}

.cp-section.cp-section--chapter > .cp-container.cp-section__content {
  margin-bottom: 55px;
}

/* Tablette */
@media (min-width: 768px) {
  .cp-section.cp-section--chapter > .cp-band {
    margin-bottom: 100px;
  }
  .cp-section.cp-section--chapter > .cp-container.cp-section__content {
    margin-bottom: 120px;
  }
}
/* Desktop / table */
@media (min-width: 1024px) {
  .cp-section.cp-section--chapter > .cp-band {
    margin-bottom: 120px;
  }
  .cp-section.cp-section--chapter > .cp-container.cp-section__content {
    margin-bottom: 140px;
  }
}
/* =========================
   SECTION — TILES (CTA, grilles visuelles)
   Spacer explicite, pas de padding implicite
   ========================= */
.cp-section--tiles {
  margin-bottom: 48px;
}

@media (min-width: 768px) {
  .cp-section--tiles {
    margin-bottom: 64px;
  }
}
@media (min-width: 1024px) {
  .cp-section--tiles {
    margin-bottom: 80px;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .cp-section.cp-section--chapter.cp-section--proprietaires > .cp-band {
    margin-bottom: 25px;
  }
}
/* Utilities */
/* ==========================================================================
   Inset — blocs divers (pas les boutons blancs CTA ; voir règle .cp-btn--cta-white).
   Ombre légère « bas-droite » (sans contour sur les quatre côtés).
   ========================================================================== */
.cp-inset {
  position: relative;
}

.cp-inset::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}

/*
 * Boutons blancs — pas de contour net ; léger enfoncement depuis les quatre côtés,
 * léger halo haut pour garder une lecture « surélevée » sans stroke.
 */
.cp-btn.cp-btn--cta-white.cp-inset::after,
.cp-btn.accueil-hero__cta.cp-inset::after,
.cp-tutos-hub__reset.cp-inset::after {
  box-shadow: inset 0 2px 5px rgba(255, 255, 255, 0.9), inset 0 -4px 8px rgba(43, 53, 80, 0.135), inset 3px 0 7px rgba(0, 0, 0, 0.082), inset -3px 0 7px rgba(0, 0, 0, 0.082), inset 0 0 11px rgba(43, 53, 80, 0.062);
}

/*
 * Blanc au hover — relief surtout au pourtour ; pas de gros halo 0/0 qui pâlit le bleu au centre,
 * aucun blur 0 (toujours un rayon ≥ 3px pour éviter tout effet ligne / stroke).
 */
.cp-btn.cp-btn--cta-white.cp-inset:hover::after,
.cp-btn.accueil-hero__cta.cp-inset:hover::after,
.cp-tutos-hub__reset.cp-inset:hover::after {
  box-shadow: inset 0 10px 9px rgba(255, 255, 255, 0.14), inset 0 5px 12px rgba(255, 255, 255, 0.045), inset 0 -10px 13px rgba(34, 42, 72, 0.24), inset 0 -5px 16px rgba(26, 32, 58, 0.11), inset 11px 0 8px rgba(255, 255, 255, 0.08), inset -11px 0 8px rgba(255, 255, 255, 0.08), inset 13px 0 11px rgba(52, 64, 102, 0.1), inset -13px 0 11px rgba(52, 64, 102, 0.1);
}

/* Ombres intérieures foncées (hors sélecteurs bouton blanc ci-dessus) */
.cp-inset.cp-inset--bleu-fonce::after {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), inset 0 -2px 4px rgba(7, 10, 24, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.085);
}

/* Vert — jamais de blur 0 sur un filet (cause « stroke ») ; côtés très doux sans halo 0/0 façon cadre */
.cp-inset.cp-inset--vert-fonce::after {
  box-shadow: inset 0 3px 5px rgba(255, 255, 255, 0.24), inset 0 -4px 8px rgba(22, 95, 32, 0.2), inset 5px 0 8px rgba(0, 0, 0, 0.048), inset -5px 0 8px rgba(0, 0, 0, 0.048), inset 0 3px 8px rgba(52, 150, 58, 0.15);
}

.cp-inset.cp-inset--rouge-fonce::after {
  box-shadow: inset 0 2px 4px rgba(52, 0, 0, 0.13), inset 0 -2px 5px rgba(52, 0, 0, 0.18), inset 0 2px 5px rgba(255, 240, 240, 0.075);
}

.cp-inset.cp-inset--gris-fonce::after {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.14), inset 0 -2px 4px rgba(20, 20, 20, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.078);
}

.cp-btn.cp-btn--cta-blue.cp-inset::after,
.cp-tutos-hub__accordion-trigger.cp-inset::after {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), inset 0 -2px 4px rgba(7, 10, 24, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.085);
}

/* Hub catégories : au survol (fermé) surface claire — aligné hover summary (_hub.scss) */
@media (hover: hover) and (pointer: fine) {
  .cp-tutos-hub__accordion:not([open]) .cp-tutos-hub__accordion-trigger.cp-inset:hover::after {
    box-shadow: inset 0 2px 5px rgba(255, 255, 255, 0.9), inset 0 -4px 8px rgba(43, 53, 80, 0.135), inset 3px 0 7px rgba(0, 0, 0, 0.082), inset -3px 0 7px rgba(0, 0, 0, 0.082), inset 0 0 11px rgba(43, 53, 80, 0.062);
  }
}
.cp-btn.cp-btn--cta-green.cp-inset::after {
  box-shadow: inset 0 3px 5px rgba(255, 255, 255, 0.24), inset 0 -4px 8px rgba(22, 95, 32, 0.2), inset 5px 0 8px rgba(0, 0, 0, 0.048), inset -5px 0 8px rgba(0, 0, 0, 0.048), inset 0 3px 8px rgba(52, 150, 58, 0.15);
}

.cp-btn.cp-btn--cta-rougeFonce.cp-inset::after {
  box-shadow: inset 0 2px 4px rgba(52, 0, 0, 0.13), inset 0 -2px 5px rgba(52, 0, 0, 0.18), inset 0 2px 5px rgba(255, 240, 240, 0.075);
}

/* Rouge au hover : même logique repos ; volume modéré sur surface claire */
.cp-btn.cp-btn--cta-rougeFonce.cp-inset:hover::after {
  box-shadow: inset 0 3px 5px rgba(255, 245, 245, 0.28), inset 0 -3px 7px rgba(130, 0, 8, 0.16), inset 5px 0 7px rgba(160, 10, 12, 0.05), inset -5px 0 7px rgba(160, 10, 12, 0.05), inset 0 3px 8px rgba(198, 0, 0, 0.1), inset 0 0 6px rgba(220, 40, 40, 0.05);
}

.cp-btn.cp-btn--secondary.cp-inset::after {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.14), inset 0 -2px 4px rgba(20, 20, 20, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.078);
}

/* Forcer le rendu bloc « diagonal » ou pâle sur un bouton (override). */
.cp-btn.cp-btn--cta-blue.cp-inset.cp-inset--light-surface-only::after,
.cp-btn.cp-btn--cta-green.cp-inset.cp-inset--light-surface-only::after,
.cp-btn.cp-btn--cta-rougeFonce.cp-inset.cp-inset--light-surface-only::after,
.cp-btn.cp-btn--secondary.cp-inset.cp-inset--light-surface-only::after,
.cp-btn.cp-btn--cta-white.cp-inset.cp-inset--light-surface-only::after,
.cp-btn.accueil-hero__cta.cp-inset.cp-inset--light-surface-only::after {
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}

.cp-inset.cp-inset--light-surface-only::after {
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.12);
}

.cp-inset-reponses {
  position: relative;
}

.cp-inset-reponses::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset -2px -2px 4px 1px rgba(0, 0, 0, 0.08);
}

.cp-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: rgba(250, 250, 250, 0.92);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.22s ease, visibility 0.22s ease;
}

.cp-loader.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.cp-loader__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.875rem;
}

.cp-loader__gear {
  position: relative;
  width: 68px;
  height: 68px;
  border: 4px solid #DCDCDC;
  border-top-color: #C60000;
  border-right-color: #F91C1C;
  border-radius: 50%;
  animation: cp-loader-spin 0.85s linear infinite;
  box-shadow: 0 0 0 1px rgba(43, 53, 80, 0.04);
}

.cp-loader__gear::before,
.cp-loader__gear::after {
  content: "";
  position: absolute;
  inset: -6px;
  border-radius: 50%;
}

.cp-loader__gear::before {
  border: 2px dashed rgba(66, 66, 66, 0.22);
}

.cp-loader__gear::after {
  inset: 10px;
  border: 2px solid rgba(43, 53, 80, 0.12);
}

.cp-loader__gear-core {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 16px;
  background: #2B3550;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.cp-loader__text {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #253C3F;
}

@keyframes cp-loader-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .cp-loader,
  .cp-loader__gear {
    transition: none;
    animation: none;
  }
}
/* ==========================================================================
   Bannière de consentement cookies
   ========================================================================== */
.cp-cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9000;
  background: var(--color-bleuTexte);
  color: #fff;
  padding: 14px 20px;
  box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.18);
}

/* grain */
.cp-cookie-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

.cp-cookie-banner__inner {
  max-width: 960px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  position: relative;
  z-index: 1;
}

.cp-cookie-banner__copy {
  flex: 1 1 300px;
  min-width: 0;
}

.cp-cookie-banner__status {
  margin: 0 0 6px;
  font-size: 13px;
  line-height: 1.4;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.92);
}

.cp-cookie-banner__text {
  font-size: 14px;
  line-height: 1.5;
  margin: 0;
}

.cp-cookie-banner__link {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  white-space: nowrap;
}
.cp-cookie-banner__link:hover {
  opacity: 0.8;
}

.cp-cookie-banner__actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}
@media (max-width: 575px) {
  .cp-cookie-banner__actions {
    flex-direction: column;
    width: 100%;
  }
  .cp-cookie-banner__actions .cp-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ==========================================================================
   Page politique de confidentialité
   ========================================================================== */
.cp-page-legal .cp-legal__content {
  max-width: 800px;
  padding-block: 48px;
}
.cp-page-legal .cp-legal__content h2 {
  margin-top: 2em;
  margin-bottom: 0.5em;
  font-size: 18px;
}
.cp-page-legal .cp-legal__content p, .cp-page-legal .cp-legal__content li {
  font-size: 15px;
  line-height: 1.7;
  color: var(--color-bleuTexte);
}
.cp-page-legal .cp-legal__content ul {
  margin: 0.5em 0 1em 1.5em;
  list-style: disc;
}
.cp-page-legal .cp-legal__content a {
  color: var(--color-bleuTexte);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
.cp-page-legal .cp-legal__content a:hover {
  color: var(--color-rougeBrickember);
}
.cp-page-legal .cp-legal__update {
  font-size: 13px;
  color: #6B7280;
  margin-bottom: 1.5em;
}
.cp-page-legal .cp-legal__address {
  font-style: normal;
  line-height: 1.8;
  margin-top: 0.5em;
}
