/* =============================================================
   Parquet & Matières Création — styles.css
   Mobile-first · tokens centralisés · contraste AA+
   Aucun framework, aucune dépendance externe.
   ============================================================= */

/* ---------- 1. Polices auto-hébergées (variable, latin) ---------- */
@font-face {
  font-family: "Fraunces";
  src: url("/assets/fonts/Fraunces-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Fraunces";
  src: url("/assets/fonts/Fraunces-italic-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Hanken Grotesk";
  src: url("/assets/fonts/HankenGrotesk-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* ---------- 2. Tokens (centralisés, prêts pour la charte client) ---------- */
:root {
  /* Couleurs — issues du logo (vert olive) et de la façade (noir mat) du showroom */
  --color-bg: #F6F2EA;          /* crème chaud */
  --color-bg-deep: #EDE6D8;     /* crème profond, rythme alternance */
  --color-ink: #161513;         /* noir mat façade */
  --color-ink-soft: #2A2823;
  --color-ink-muted: #6B6358;
  --color-line: rgba(22, 21, 19, 0.12);
  --color-line-dark: rgba(246, 242, 234, 0.14);

  --color-green: #8FAE3C;       /* signature, du logo et du véhicule */
  --color-green-deep: #6E8B2E;
  --color-green-soft: rgba(143, 174, 60, 0.16);

  --color-wood: #9A6B3F;        /* accent secondaire, chaleur bois */
  --color-paper: #FFFFFF;

  /* Typographie */
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body: "Hanken Grotesk", "Hanken", "Helvetica Neue", sans-serif;

  /* Échelle typographique fluide (clamp) */
  --fs-100: clamp(0.78rem, 0.74rem + 0.18vw, 0.86rem);
  --fs-200: clamp(0.92rem, 0.88rem + 0.2vw, 1rem);
  --fs-300: clamp(1rem, 0.96rem + 0.22vw, 1.125rem);
  --fs-400: clamp(1.05rem, 0.99rem + 0.28vw, 1.18rem);
  --fs-500: clamp(1.18rem, 1.05rem + 0.6vw, 1.5rem);
  --fs-600: clamp(1.5rem, 1.2rem + 1.3vw, 2.1rem);
  --fs-700: clamp(1.9rem, 1.4rem + 2.2vw, 2.9rem);
  --fs-800: clamp(2.4rem, 1.6rem + 3.6vw, 4.2rem);
  --fs-900: clamp(3rem, 2rem + 5.2vw, 6.4rem);

  /* Rythme vertical */
  --space-3xs: clamp(0.25rem, 0.22rem + 0.15vw, 0.35rem);
  --space-2xs: clamp(0.4rem, 0.35rem + 0.25vw, 0.55rem);
  --space-xs: clamp(0.6rem, 0.5rem + 0.4vw, 0.85rem);
  --space-sm: clamp(0.9rem, 0.75rem + 0.6vw, 1.25rem);
  --space-md: clamp(1.3rem, 1rem + 1.2vw, 2rem);
  --space-lg: clamp(2rem, 1.4rem + 2.4vw, 3.5rem);
  --space-xl: clamp(3rem, 2rem + 4vw, 5.5rem);
  --space-section: clamp(4.5rem, 3rem + 6vw, 8.5rem);

  /* Layout */
  --container-max: 1280px;
  --container-pad: clamp(1.25rem, 1rem + 2vw, 2.5rem);

  /* Effets */
  --radius-sm: 4px;
  --radius-md: 12px;
  --radius-lg: 22px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --shadow-soft: 0 10px 30px -18px rgba(22, 21, 19, 0.25);
}

/* ---------- 3. Reset / bases ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--fs-300);
  line-height: 1.6;
  font-feature-settings: "ss01", "kern";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration-thickness: 1px; text-underline-offset: 3px; }
:focus-visible { outline: 2px solid var(--color-green); outline-offset: 3px; border-radius: 3px; }
::selection { background: var(--color-green); color: var(--color-ink); }

/* Utilitaires */
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.skip-link {
  position: absolute; left: -9999px; top: 8px;
  background: var(--color-ink); color: var(--color-bg);
  padding: .6em 1em; border-radius: 4px; z-index: 100;
}
.skip-link:focus { left: 12px; }

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

.display {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.02;
  font-variation-settings: "opsz" 96, "SOFT" 50;
}
.display em { font-style: italic; font-variation-settings: "opsz" 96; color: var(--color-wood); }

/* ---------- 4. Boutons & liens ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .65em;
  padding: 0.95em 1.5em;
  font-family: var(--font-body); font-weight: 500;
  font-size: var(--fs-200);
  letter-spacing: 0.01em;
  text-decoration: none;
  border-radius: 999px;
  transition: transform .25s var(--ease-out), background-color .25s, color .25s, border-color .25s;
  white-space: nowrap;
  min-height: 44px;
}
.btn--primary { background: var(--color-green); color: var(--color-ink); }
.btn--primary:hover, .btn--primary:focus-visible { background: var(--color-green-deep); color: var(--color-bg); transform: translateY(-1px); }

.btn--ghost { background: transparent; color: var(--color-ink); border: 1px solid var(--color-line); }
/* Hover : se remplit en vert signature */
.btn--ghost:hover, .btn--ghost:focus-visible {
  background: var(--color-green);
  color: var(--color-ink);
  border-color: var(--color-green);
  transform: translateY(-1px);
}

.section--dark .btn--ghost { color: var(--color-bg); border-color: var(--color-line-dark); }
.section--dark .btn--ghost:hover,
.section--dark .btn--ghost:focus-visible {
  background: var(--color-green);
  color: var(--color-ink);
  border-color: var(--color-green);
}

.btn--link {
  padding: .6em 0; border-radius: 0;
  background: transparent; color: inherit;
  border-bottom: 1px solid currentColor;
  border-radius: 0;
}
.btn--link:hover { color: var(--color-green-deep); }
.section--dark .btn--link:hover { color: var(--color-green); }
.btn__icon { display: inline-flex; }

/* ---------- 5. En-tête site & nav — pill flottante translucide (style « liquid glass ») ---------- */
.site-header {
  position: fixed;
  top: clamp(.65rem, .4rem + .8vw, 1.1rem);
  left: clamp(.65rem, .4rem + .8vw, 1.25rem);
  right: clamp(.65rem, .4rem + .8vw, 1.25rem);
  z-index: 50;
  border-radius: 999px;
  overflow: visible;
  /* NB : pas de backdrop-filter / filter / transform ICI.
     Sinon le header deviendrait le bloc conteneur de l'overlay de menu
     (.site-nav__list en position:fixed), qui se retrouverait confiné dans
     la pill au lieu de couvrir l'écran. L'effet « verre » est porté par
     le pseudo-élément ::before ci-dessous (sans descendant DOM, donc neutre). */
}
/* Fond « liquid glass » : isolé sur un pseudo-élément pour ne pas créer de
   containing-block sur les descendants fixed (cf. menu mobile plein écran). */
.site-header::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  /* Plus translucide qu'avant : 32 % au repos, 52 % sur scroll */
  background: color-mix(in srgb, var(--color-bg) 32%, transparent);
  backdrop-filter: saturate(200%) blur(30px);
  -webkit-backdrop-filter: saturate(200%) blur(30px);
  border: 1px solid color-mix(in srgb, var(--color-ink) 7%, transparent);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.3) inset,
    0 12px 36px -16px rgba(22,21,19,0.20),
    0 2px 6px -2px rgba(22,21,19,0.08);
  transition: background-color .3s, box-shadow .3s, border-color .3s;
  z-index: -1;
  pointer-events: none;
}
.site-header[data-scrolled="true"]::before {
  background: color-mix(in srgb, var(--color-bg) 52%, transparent);
  border-color: color-mix(in srgb, var(--color-ink) 10%, transparent);
}
.site-header__row {
  display: flex; align-items: center; gap: var(--space-md);
  height: clamp(56px, 50px + 1vw, 68px);
  padding-inline: clamp(.9rem, .6rem + 1vw, 1.6rem);
  max-width: var(--container-max);
  margin-inline: auto;
}
.site-header__brand { display: inline-flex; align-items: center; flex-shrink: 0; line-height: 0; }
/* Dimensionnement par la HAUTEUR pour que le logo reste toujours
   contenu dans la barre d'en-tête (qui fait 64–80 px). Largeur auto = aspect natif préservé. */
.site-header__brand img {
  height: clamp(40px, 32px + 1vw, 52px);
  width: auto; max-width: 100%;
  display: block;
}
.site-header__cta {
  margin-left: auto;
  /* Plus compact que .btn par défaut, dimensionné pour la pill ~60 px de haut */
  padding: .55em 1.15em;
  font-size: var(--fs-100);
  letter-spacing: 0.04em;
  min-height: 36px;
}

.site-nav { flex: 1; display: flex; justify-content: center; }
/* Desktop : le panneau est transparent (display:contents), seul le <ul> compte ;
   le logo et le pied de menu ne servent qu'à l'overlay mobile. */
.site-nav__panel { display: contents; }
.site-nav__brand-mini,
.site-nav__foot { display: none; }
.site-nav__list {
  display: flex; gap: clamp(.8rem, .5rem + 1vw, 1.6rem);
  list-style: none; margin: 0; padding: 0;
  font-size: var(--fs-200);
}
.site-nav__list a {
  position: relative;
  text-decoration: none;
  padding: .35em 0;
  color: var(--color-ink-soft);
  transition: color .25s;
}
.site-nav__list a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: currentColor;
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s var(--ease-out);
}
.site-nav__list a:hover, .site-nav__list a[aria-current="page"] {
  color: var(--color-ink);
}
.site-nav__list a:hover::after, .site-nav__list a[aria-current="page"]::after { transform: scaleX(1); }

.site-nav__toggle {
  display: none;
  width: 44px; height: 44px;
  align-items: center; justify-content: center;
  margin-left: auto;
}
.site-nav__toggle-bars,
.site-nav__toggle-bars::before,
.site-nav__toggle-bars::after {
  content: ""; display: block;
  width: 22px; height: 1.5px; background: currentColor;
  transition: transform .3s var(--ease-in-out), opacity .2s;
}
.site-nav__toggle-bars { position: relative; }
.site-nav__toggle-bars::before { position: absolute; top: -7px; left: 0; }
.site-nav__toggle-bars::after { position: absolute; top: 7px; left: 0; }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bars { background: transparent; }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bars::before { transform: translateY(7px) rotate(45deg); }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bars::after { transform: translateY(-7px) rotate(-45deg); }

/* ===== Mobile nav — overlay plein écran « éditorial » ===== */
@media (max-width: 899px) {
  .site-header__cta { display: none; }
  .site-nav { justify-content: flex-end; }
  .site-nav__toggle {
    display: inline-flex;
    /* Le bouton hamburger/X reste toujours au-dessus du panneau */
    position: relative;
    z-index: 2;
  }

  /* Le panneau devient l'overlay plein écran (logo + liens + contact) */
  .site-nav__panel {
    display: flex;
    flex-direction: column;
    position: fixed;
    inset: 0;
    z-index: 1;
    padding-inline: clamp(1.5rem, 6vw, 2.75rem);
    /* Fond crème premium : halo vert discret en haut + dégradé chaud + flou */
    background:
      radial-gradient(130% 70% at 100% 0%, var(--color-green-soft), transparent 58%),
      linear-gradient(180deg,
        color-mix(in srgb, var(--color-bg) 98%, transparent),
        color-mix(in srgb, var(--color-bg-deep) 99%, transparent));
    backdrop-filter: saturate(170%) blur(22px);
    -webkit-backdrop-filter: saturate(170%) blur(22px);
    /* Fermé : hors écran + invisible (zéro capture de tap fantôme) */
    transform: translateX(100%);
    opacity: 0;
    visibility: hidden;
    transition:
      transform .5s var(--ease-out),
      opacity .35s var(--ease-out),
      visibility 0s linear .5s;
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  .site-nav[data-open="true"] .site-nav__panel {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
    transition:
      transform .5s var(--ease-out),
      opacity .35s var(--ease-out),
      visibility 0s linear 0s;
  }

  /* Logo en tête de l'overlay (dégage la pill + le bouton X) */
  .site-nav__brand-mini {
    display: block;
    padding-top: max(env(safe-area-inset-top), clamp(4.5rem, 15vw, 6.5rem));
    padding-bottom: clamp(1.5rem, 5vw, 2.5rem);
    line-height: 0;
  }
  .site-nav__brand-mini img {
    height: clamp(42px, 12vw, 56px);
    width: auto;
  }

  /* Liste : grands liens serif, numérotés, séparateurs fins */
  .site-nav__list {
    display: flex;
    flex-direction: column;
    gap: 0;
    counter-reset: navitem;
    border-top: 1px solid var(--color-line);
    font-size: inherit;
  }
  .site-nav__list li {
    list-style: none;
    border-bottom: 1px solid var(--color-line);
  }
  .site-nav__list a {
    display: flex;
    align-items: center;
    gap: clamp(.8rem, 4vw, 1.25rem);
    width: 100%;
    padding: clamp(1rem, 4.2vw, 1.5rem) .15rem;
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(1.9rem, 9vw, 2.9rem);
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--color-ink);
  }
  /* Numéro éditorial 01 · 02 · 03… */
  .site-nav__list a::before {
    counter-increment: navitem;
    content: counter(navitem, decimal-leading-zero);
    font-family: var(--font-body);
    font-size: var(--fs-100);
    font-weight: 600;
    letter-spacing: 0.14em;
    color: var(--color-green-deep);
    min-width: 2.4ch;
  }
  /* Chevron « › » en bout de ligne, pur CSS */
  .site-nav__list a::after {
    content: "";
    margin-left: auto;
    width: .62rem; height: .62rem;
    border-top: 2px solid var(--color-ink-muted);
    border-right: 2px solid var(--color-ink-muted);
    transform: rotate(45deg);
    opacity: .55;
    transition: transform .3s var(--ease-out), border-color .3s, opacity .3s;
  }
  .site-nav__list a[aria-current="page"] { color: var(--color-green-deep); }
  .site-nav__list a[aria-current="page"]::after { border-color: var(--color-green-deep); opacity: 1; }
  .site-nav__list a:active {
    color: var(--color-green-deep);
  }
  .site-nav__list a:active::after {
    border-color: var(--color-green-deep);
    opacity: 1;
    transform: rotate(45deg) translate(2px, -2px);
  }

  /* Pied de menu : contact direct + devis, ancré en bas */
  .site-nav__foot {
    display: flex;
    flex-direction: column;
    gap: clamp(.7rem, 3vw, 1.1rem);
    margin-top: auto;
    padding-top: clamp(1.75rem, 7vw, 2.75rem);
    padding-bottom: max(env(safe-area-inset-bottom), clamp(1.5rem, 6vw, 2.5rem));
  }
  .site-nav__phone {
    display: inline-flex; align-items: center; gap: .6rem;
    font-family: var(--font-display);
    font-size: clamp(1.3rem, 6vw, 1.75rem);
    color: var(--color-ink);
    text-decoration: none;
  }
  .site-nav__phone svg { color: var(--color-green-deep); flex-shrink: 0; }
  .site-nav__addr {
    margin: 0;
    font-size: var(--fs-100);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
  }
  .site-nav__devis {
    align-self: flex-start;
    margin-top: .4rem;
  }

  /* --- Entrée en cascade des éléments quand le menu s'ouvre --- */
  .site-nav__brand-mini,
  .site-nav__list li,
  .site-nav__foot {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .5s var(--ease-out), transform .6s var(--ease-out);
  }
  .site-nav[data-open="true"] .site-nav__brand-mini { opacity: 1; transform: none; transition-delay: .1s; }
  .site-nav[data-open="true"] .site-nav__list li { opacity: 1; transform: none; }
  .site-nav[data-open="true"] .site-nav__list li:nth-child(1) { transition-delay: .16s; }
  .site-nav[data-open="true"] .site-nav__list li:nth-child(2) { transition-delay: .22s; }
  .site-nav[data-open="true"] .site-nav__list li:nth-child(3) { transition-delay: .28s; }
  .site-nav[data-open="true"] .site-nav__list li:nth-child(4) { transition-delay: .34s; }
  .site-nav[data-open="true"] .site-nav__list li:nth-child(5) { transition-delay: .40s; }
  .site-nav[data-open="true"] .site-nav__foot { opacity: 1; transform: none; transition-delay: .46s; }
}

/* Respect prefers-reduced-motion : pas de slide ni de cascade, fondu minimal.
   (l'état fermé reste géré par visibility/opacity, donc rien ne fuit.) */
@media (max-width: 899px) and (prefers-reduced-motion: reduce) {
  .site-nav__panel { transition: opacity .2s, visibility 0s linear .2s; }
  .site-nav[data-open="true"] .site-nav__panel { transition: opacity .2s, visibility 0s; }
  .site-nav__brand-mini,
  .site-nav__list li,
  .site-nav__foot {
    transform: none !important;
    transition: opacity .2s !important;
    transition-delay: 0s !important;
  }
}

/* Quand le menu est ouvert : on neutralise l'action-bar du bas
   pour qu'elle ne capture pas les taps sur les liens. */
body[data-nav-open="true"] .action-bar { display: none !important; }

/* Barre de progression : intégrée DANS la pill du header, en bas centrée,
   avec marges latérales pour ne pas dépasser les angles arrondis.
   Track transparent → seul le remplissage vert apparaît au scroll, plus de
   filet sombre au repos. */
.scroll-progress {
  position: absolute;
  left: clamp(1.5rem, 4vw, 3.5rem);
  right: clamp(1.5rem, 4vw, 3.5rem);
  bottom: 5px;
  height: 1.5px;
  border-radius: 999px;
  background: transparent;
  pointer-events: none;
  overflow: hidden;
}
.scroll-progress span {
  display: block; height: 100%;
  width: 0%;
  background: var(--color-green);
  border-radius: 999px;
  transform-origin: left;
  transition: width .1s linear;
}

/* ---------- 6. Sections génériques ---------- */
.section {
  padding-block: var(--space-section);
  position: relative;
}
.section--dark {
  background: var(--color-ink);
  color: var(--color-bg);
  /* Texture subtile (grain SVG inline data URI, ne pollue pas la CSP) */
  background-image:
    linear-gradient(var(--color-ink), var(--color-ink)),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.9  0 0 0 0 0.8  0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-blend-mode: normal, screen;
}
.section--dark .section__eyebrow,
.section--dark .section__lede { color: rgba(246, 242, 234, 0.78); }
.section--dark .display em { color: var(--color-green); }

.section--cream-deep { background: var(--color-bg-deep); }

.section__inner > * + * { margin-top: var(--space-md); }
.section__head { max-width: 56ch; margin-bottom: var(--space-lg); }
.section__eyebrow {
  display: inline-flex; align-items: center; gap: .65em;
  font-size: var(--fs-100); letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-ink-muted);
  margin: 0;
}
.section__title {
  font-size: var(--fs-800);
  margin: var(--space-sm) 0 0;
  max-width: 18ch;
}
.section__lede {
  font-size: var(--fs-400);
  max-width: 56ch;
  color: var(--color-ink-soft);
}
.section--dark .section__lede { color: rgba(246, 242, 234, 0.86); }

/* ---------- 7. Hero — full-screen image + logo overlay ---------- */
.hero {
  position: relative;
  min-height: 100vh;       /* fallback */
  min-height: 100svh;      /* mobile sans la barre URL */
  overflow: hidden;
  display: grid;
  /* center vertical, ancré à GAUCHE horizontalement */
  place-items: center start;
  padding: clamp(7rem, 5rem + 8vw, 9rem) var(--container-pad) clamp(5rem, 3rem + 5vw, 8rem);
  isolation: isolate;
  color: var(--color-bg);
}
/* Image de fond : <picture> en pleine couverture du hero */
.hero__bg {
  position: absolute; inset: 0;
  z-index: -2;
  display: block;
}
.hero__bg img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
}
/* Voile dégradé : assombrit haut et bas pour la lisibilité du header
   et des CTAs, le centre reste lumineux pour le logo. */
.hero__veil {
  position: absolute; inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(180deg,
      rgba(22,21,19,0.50) 0%,
      rgba(22,21,19,0.05) 22%,
      rgba(22,21,19,0.05) 62%,
      rgba(22,21,19,0.55) 100%);
}
.hero__inner {
  position: relative; z-index: 1;
  display: grid;
  gap: clamp(var(--space-md), 2.4vw, var(--space-lg));
  /* Tout aligné à gauche maintenant */
  justify-items: start;
  text-align: left;
  max-width: 560px;
  width: 100%;
}
/* Carte « Liquid Glass » qui porte le logo + l'accroche : lisibilité parfaite
   sur la photo, cohérente avec le verre du header et de la lightbox. */
.hero__card {
  display: grid;
  justify-items: start;
  gap: clamp(.9rem, 2vw, 1.4rem);
  padding: clamp(1.5rem, 4vw, 2.6rem) clamp(1.5rem, 4vw, 2.8rem);
  border-radius: clamp(20px, 3vw, 28px);
  background: color-mix(in srgb, var(--color-bg) 64%, transparent);
  -webkit-backdrop-filter: blur(22px) saturate(1.55);
  backdrop-filter: blur(22px) saturate(1.55);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.65),   /* reflet d'arête supérieur (lumière du haut) */
    0 20px 50px rgba(0, 0, 0, 0.30),            /* profondeur portée sur la photo */
    0 2px 8px rgba(0, 0, 0, 0.12);
}
/* Repli si backdrop-filter non supporté : fond cream quasi opaque (lisibilité garantie) */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .hero__card { background: color-mix(in srgb, var(--color-bg) 93%, transparent); }
}
.hero__logo {
  width: clamp(168px, 20vw, 238px);
  height: auto;
  filter: none; /* plus de halo : le logo repose sur le verre clair → net et contrasté */
}
.hero__tagline {
  margin: 0;
  display: grid;
  gap: .15rem;
  text-shadow: none;
}
.hero__tagline-main {
  font-family: var(--font-display);
  font-size: var(--fs-500);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  line-height: 1.1;
}
.hero__tagline-since {
  font-family: var(--font-body);
  font-size: var(--fs-200);
  letter-spacing: 0.01em;
  color: var(--color-ink-soft);
}
.hero__cta {
  display: flex; flex-wrap: wrap;
  gap: var(--space-sm) var(--space-md);
  align-items: center; justify-content: flex-start;
}
/* Variante claire du btn--link pour les fonds sombres / image hero */
.btn--light {
  color: var(--color-bg);
  border-bottom-color: rgba(246,242,234,0.55);
  text-shadow: 0 2px 12px rgba(0,0,0,0.65);
}
.btn--light:hover,
.btn--light:focus-visible {
  color: var(--color-green);
  border-bottom-color: var(--color-green);
}

/* Lisibilité du texte hero sur mobile : scrim localisé (radial derrière le
   contenu à gauche + assombrissement bas), sans ternir toute l'image, +
   tagline renforcée. Approche moderne « spotlight » plutôt qu'un voile uniforme. */
@media (max-width: 768px) {
  /* La carte glass porte désormais la lisibilité : voile allégé, juste un
     assombrissement bas pour les CTA (lien téléphone clair) sur la photo. */
  .hero__veil {
    background:
      linear-gradient(180deg,
        rgba(22,21,19,0.42) 0%,
        rgba(22,21,19,0.08) 26%,
        rgba(22,21,19,0.10) 50%,
        rgba(22,21,19,0.70) 100%);
  }
  /* Carte pleine largeur du conteneur sur mobile */
  .hero__card { width: 100%; justify-items: center; text-align: center; }
}

/* Bandeau distributeurs en bas du hero */
.hero__distri {
  position: absolute;
  left: 50%; bottom: clamp(1.25rem, 3vw, 2.25rem);
  transform: translateX(-50%);
  z-index: 1;
  width: min(96%, 1100px);
  text-align: center;
}
.hero__distri-label {
  margin: 0 0 clamp(.55rem, 1vw, .85rem);
  font-size: var(--fs-100);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-bg);
  text-shadow: 0 2px 14px rgba(0,0,0,0.65);
  font-family: var(--font-body);
}
.hero__distri-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap;
  gap: clamp(.4rem, .9vw, .75rem);
  align-items: center; justify-content: center;
}
.distri-chip {
  background: var(--color-bg);
  border: 1px solid color-mix(in srgb, var(--color-ink) 10%, transparent);
  border-radius: 8px;
  padding: clamp(.3rem, .6vw, .5rem) clamp(.55rem, 1.1vw, .9rem);
  display: inline-flex;
  align-items: center; justify-content: center;
  height: clamp(34px, 4.2vw, 46px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 6px 18px -10px rgba(0,0,0,0.4);
  /* En tant que lien : on retire la déco par défaut et on rend l'interactivité claire */
  text-decoration: none;
  cursor: pointer;
  transition: transform .25s var(--ease-out), box-shadow .25s, border-color .25s;
}
.distri-chip:hover,
.distri-chip:focus-visible {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--color-ink) 18%, transparent);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 12px 26px -10px rgba(0,0,0,0.5);
}
.distri-chip:focus-visible {
  outline: 2px solid var(--color-green);
  outline-offset: 2px;
}
.distri-chip img,
.distri-chip picture { height: 100%; width: auto; display: block; }
.distri-chip img { max-width: 160px; object-fit: contain; }

/* ---------- 8. Savoir-faire ---------- */
.savoir-faire .section__head {
  display: grid; gap: var(--space-sm);
}
.services {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: var(--space-md);
}
.service {
  position: relative;
  scroll-margin-top: clamp(5rem, 4rem + 4vw, 7rem); /* ancre du sommaire sous le header */
  padding: clamp(1.4rem, 1rem + 2vw, 2.4rem);
  border-top: 1px solid var(--color-line);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
}
.service:last-child { border-bottom: 1px solid var(--color-line); }
.service__num {
  font-family: var(--font-display);
  font-size: var(--fs-300);
  color: var(--color-ink-muted);
  letter-spacing: 0.1em;
  margin: 0;
}
.service__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-700);
  line-height: 1.04;
  margin: 0;
  letter-spacing: -0.01em;
}
.service__body { margin: 0; max-width: 60ch; color: var(--color-ink-soft); }
.service__tags {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: .5rem .75rem;
  font-size: var(--fs-100);
  color: var(--color-ink-muted);
  text-transform: uppercase; letter-spacing: 0.14em;
}
.service__tags li { display: inline-flex; align-items: center; gap: .5em; }
.service__tags li::before {
  content: ""; width: 6px; height: 6px;
  border-radius: 50%; background: var(--color-green);
  display: inline-block;
}
@media (min-width: 900px) {
  .service {
    grid-template-columns: 9rem 1fr 1.2fr;
    align-items: start;
    gap: var(--space-lg);
  }
  .service__num { font-size: var(--fs-400); }
  .service__title { grid-column: 2; }
  .service__body { grid-column: 3; }
  .service__tags { grid-column: 3; }
}

/* ---------- 10. Réalisations ---------- */
.tiles {
  display: grid; gap: var(--space-md);
  grid-template-columns: 1fr;
  margin-top: var(--space-lg);
}
@media (min-width: 600px) { .tiles { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .tiles { grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); } }

.tile {
  margin: 0;
  display: flex; flex-direction: column;
  gap: var(--space-sm);
}
.tile__media {
  aspect-ratio: 4 / 5;
  background:
    linear-gradient(135deg, rgba(143,174,60,0.06) 0%, rgba(154,107,63,0.08) 100%),
    var(--color-bg-deep);
  border-radius: var(--radius-md);
  overflow: hidden;
  /* L'image zoomée (scale) ignore sinon les coins arrondis du parent
     pendant la transition — clip-path + isolation forcent le détourage. */
  clip-path: inset(0 round var(--radius-md));
  isolation: isolate;
  position: relative;
  transition: transform .8s cubic-bezier(0.22, 1, 0.36, 1);
}
.tile__media picture { display: block; width: 100%; height: 100%; }
.tile__media img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  /* translateZ(0) : couche GPU créée AVANT le survol → zoom fluide dès la 1re frame */
  transform: translateZ(0);
  backface-visibility: hidden;
  transition: transform 1.1s cubic-bezier(0.22, 1, 0.36, 1);
}
@media (hover: hover) {
  .tile__media img { will-change: transform; }
}
.tile:hover .tile__media { transform: translateY(-4px); }
.tile:hover .tile__media img,
.tile:focus-within .tile__media img { transform: translateZ(0) scale(1.05); }

/* ---------- 11. Showroom ---------- */
.showroom__grid {
  display: grid; gap: var(--space-xl);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 900px) {
  .showroom__grid { grid-template-columns: 1fr 1fr; gap: var(--space-xl); }
}
.showroom__media {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}
.showroom__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: translateZ(0);
  will-change: transform;
}
.showroom__info {
  display: grid; gap: var(--space-sm);
  margin: var(--space-lg) 0;
}
.showroom__info div { display: grid; grid-template-columns: 8rem 1fr; gap: var(--space-sm); align-items: baseline; }
.showroom__info dt {
  font-size: var(--fs-100); letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(246,242,234,0.6);
}
.showroom__info dd { margin: 0; font-size: var(--fs-400); }
.showroom__info dd a { text-decoration: none; border-bottom: 1px solid rgba(246,242,234,0.3); padding-bottom: 1px; }
.showroom__info dd a:hover { border-color: var(--color-green); }

/* Horaires : grille 2 colonnes (jour / créneau), discrète mais lisible */
.hours {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: .35rem;
}
.hours li {
  display: grid;
  grid-template-columns: 7.5rem 1fr;
  gap: clamp(.75rem, 1.4vw, 1.25rem);
  align-items: baseline;
  font-size: var(--fs-300);
  line-height: 1.4;
}
.hours__day {
  color: rgba(246,242,234,0.55);
}
.hours__time { font-variant-numeric: tabular-nums; }
.hours__time--off { color: rgba(246,242,234,0.4); font-style: italic; }
/* Deux créneaux (matin/après-midi) : séparés par un point sur une ligne (desktop),
   empilés SANS point sur mobile (disposition différente). */
.hours__range + .hours__range::before {
  content: "·";
  margin: 0 .55ch;
  opacity: .5;
}
@media (max-width: 599px) {
  .hours__range { display: block; }
  .hours__range + .hours__range::before { content: none; }
}

.showroom__cta { display: flex; flex-wrap: wrap; gap: var(--space-sm) var(--space-md); }

/* ---------- 12. Zone d'intervention — carousel infini ---------- */
.zone__marquee {
  margin-top: var(--space-lg);
  position: relative;
  overflow: hidden;
  /* Fade des bords pour l'apparition/disparition des communes */
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%);
}
.zone__track {
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center;
  width: max-content;            /* nécessaire pour que la translation x soit fluide */
  font-family: var(--font-display);
  font-size: var(--fs-600);
  letter-spacing: -0.01em;
  line-height: 1.1;
  will-change: transform;
}
.zone__track li {
  position: relative;
  white-space: nowrap;
  padding-inline: 0 var(--space-md);
  margin-inline-end: var(--space-md);
}
.zone__track li::after {
  content: "·";
  position: absolute;
  right: -.15em; top: -.08em;
  color: var(--color-green);
  pointer-events: none;
}
/* Repli statique propre quand l'utilisateur préfère réduire les animations
   ou quand JS est désactivé (le track n'est alors pas cloné). */
@media (prefers-reduced-motion: reduce) {
  .zone__marquee {
    overflow: visible;
    -webkit-mask-image: none; mask-image: none;
    padding-inline: var(--container-pad);
  }
  .zone__track {
    flex-wrap: wrap;
    width: auto;
    gap: var(--space-sm) 0;
  }
}
html:not(.js) .zone__marquee {
  overflow: visible;
  -webkit-mask-image: none; mask-image: none;
  padding-inline: var(--container-pad);
}
html:not(.js) .zone__track { flex-wrap: wrap; width: auto; }

/* ---------- 13. Confiance ---------- */
.confiance__grid {
  list-style: none; margin: var(--space-lg) 0 0; padding: 0;
  display: grid; gap: var(--space-md);
  grid-template-columns: 1fr;
}
@media (min-width: 600px) { .confiance__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1000px) { .confiance__grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); } }
.trust {
  position: relative;
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: clamp(1.2rem, 1rem + 1.4vw, 1.8rem);
}
/* Itinéraire : carte cohérente, visible sur mobile uniquement */
@media (min-width: 600px) { .trust--map { display: none; } }
.map-card { display: grid; justify-items: center; text-align: center; gap: .45rem; }
.map-card__pin {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(143, 174, 60, 0.16);
  color: var(--color-green-deep);
  margin-bottom: .2rem;
}
.map-card__title { margin: 0; font-family: var(--font-display); font-size: var(--fs-400); color: var(--color-ink); }
.map-card__addr { margin: 0; font-size: var(--fs-200); color: var(--color-ink-muted); line-height: 1.5; }
.map-card__apps { display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; margin-top: .7rem; }
.map-card__app {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .55rem .85rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-bg-deep) 55%, transparent);
  -webkit-backdrop-filter: blur(8px) saturate(1.3);
  backdrop-filter: blur(8px) saturate(1.3);
  color: var(--color-ink);
  text-decoration: none;
  font-size: var(--fs-100); font-weight: 600; letter-spacing: .01em;
  transition: border-color .25s var(--ease-out), transform .25s var(--ease-out), color .25s, background .25s;
}
.map-card__app:hover,
.map-card__app:focus-visible {
  border-color: var(--color-green);
  color: var(--color-green-deep);
  transform: translateY(-2px);
}
.map-card__app svg { flex: none; }

/* Tuile-lien (avis Google) : hérite le style de la tuile, pas de décoration de lien */
.trust__link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: opacity .25s;
}
.trust__link:hover { opacity: .8; }
.trust__link:focus-visible {
  outline: 2px solid var(--color-green);
  outline-offset: 4px;
  border-radius: var(--radius-sm);
}
/* Lien-carte : toute la surface du carré devient cliquable, même si le texte
   ne remplit pas la hauteur (cartes étirées à la même hauteur dans la rangée). */
.trust__link::after { content: ""; position: absolute; inset: 0; border-radius: inherit; }
.trust__metric {
  margin: 0;
  font-size: var(--fs-800);
  line-height: 1;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.trust__unit {
  font-size: 0.5em;
  color: var(--color-ink-muted);
  margin-left: 0.15em;
}
.trust__label {
  margin: var(--space-sm) 0 0;
  font-size: var(--fs-200);
  color: var(--color-ink-muted);
}
/* Mention de droits sur les photos — discrète mais visible */
.realisations__rights {
  display: inline-flex; align-items: center; gap: .5rem;
  margin: var(--space-sm) 0 0;
  padding: .45rem .8rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-wood, var(--color-accent)) 8%, transparent);
  font-size: var(--fs-100);
  line-height: 1.35;
  color: var(--color-ink-muted);
}
.realisations__rights svg { flex: none; color: var(--color-accent); }
/* Desktop : une seule ligne, centrée sur l'écran */
@media (min-width: 1000px) {
  .realisations__rights {
    display: flex;
    width: fit-content;
    margin-inline: auto;
    white-space: nowrap;
  }
}

.confiance__values {
  margin-top: var(--space-lg);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-500);
  color: var(--color-ink-soft);
}

/* ---------- 13bis. Avis Google (renvoi honnête, aucun avis recopié) ---------- */
.confiance__reviews {
  margin-top: var(--space-lg);
  display: flex;
  justify-content: center;
}
.confiance__reviews-link {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  padding: .75rem 1.25rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: var(--color-bg);
  color: var(--color-ink);
  text-decoration: none;
  font-size: var(--fs-200);
  transition: border-color .25s var(--ease-out), transform .25s var(--ease-out), background .25s;
}
.confiance__reviews-link:hover,
.confiance__reviews-link:focus-visible {
  border-color: var(--color-ink);
  transform: translateY(-1px);
}
.confiance__reviews-stars {
  color: var(--color-green-deep);
  letter-spacing: .04em;
  line-height: 1;
  flex: none;
}
.confiance__reviews-text strong { font-weight: 700; }
.confiance__reviews-link svg { flex: none; opacity: .6; }

/* ---------- 14. Contact / formulaire ---------- */
.contact__grid {
  display: grid; gap: var(--space-xl);
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 1000px) {
  .contact__grid { grid-template-columns: 1fr 1fr; gap: var(--space-xl); }
}
.contact__channels {
  list-style: none; margin: var(--space-lg) 0 0; padding: 0;
  display: grid; gap: var(--space-md);
}
.contact__channels li { display: grid; gap: 0.2rem; }
.contact__label {
  font-size: var(--fs-100); letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(246,242,234,0.6);
}
.contact__link {
  font-family: var(--font-display);
  font-size: var(--fs-500);
  text-decoration: none;
  border-bottom: 1px solid rgba(246,242,234,0.25);
  padding-bottom: 2px;
  align-self: start;
}
.contact__link:hover { border-color: var(--color-green); color: var(--color-green); }

.form {
  background: var(--color-bg);
  color: var(--color-ink);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 1rem + 2.5vw, 2.5rem);
  display: grid; gap: var(--space-md);
}
.form__row { display: grid; gap: var(--space-md); }
.form__row--split { grid-template-columns: 1fr; }
@media (min-width: 640px) { .form__row--split { grid-template-columns: 1fr 1fr; } }

.field { display: grid; gap: 0.4rem; }
.field__label {
  font-size: var(--fs-100); letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--color-ink-muted);
}
.field__input {
  font: inherit; font-size: var(--fs-300);
  width: 100%;
  background: transparent;
  border: 0; border-bottom: 1px solid var(--color-line);
  padding: 0.75em 0;
  color: var(--color-ink);
  border-radius: 0;
  transition: border-color .25s;
  min-height: 44px;
}
textarea.field__input { resize: vertical; min-height: 8em; }
.field__input:focus { outline: none; border-bottom-color: var(--color-green); }
.field__input::placeholder { color: var(--color-ink-muted); opacity: .7; }
select.field__input { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--color-ink-muted) 50%), linear-gradient(135deg, var(--color-ink-muted) 50%, transparent 50%); background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%; background-size: 6px 6px; background-repeat: no-repeat; padding-right: 30px; }

.field--check { grid-template-columns: auto 1fr; align-items: start; gap: .8em; font-size: var(--fs-200); color: var(--color-ink-soft); }
.field--check input { margin-top: .3em; accent-color: var(--color-green); width: 18px; height: 18px; }
.field--check a { color: inherit; }

/* Honeypot — totalement masqué visuellement et a11y, mais soumis si rempli par bot */
.field--hp {
  position: absolute !important;
  width: 1px; height: 1px; overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap; border: 0; padding: 0; margin: -1px;
}

.form__actions {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-md);
  margin-top: var(--space-sm);
}
.form__status {
  margin: 0;
  min-height: 1.6em;
  font-size: var(--fs-200);
  color: var(--color-ink-soft);
}
.form__status[data-state="success"] { color: var(--color-green-deep); }
.form__status[data-state="error"] { color: #b14d3a; }

/* ---------- 15. Footer ---------- */
.site-footer {
  background: #0F0E0C;
  color: rgba(246,242,234,0.78);
  padding-block: var(--space-xl) var(--space-lg);
  font-size: var(--fs-200);
}
/* Couleurs footer liens → voir règles surspécifiées dans la section §20 légal */
.site-footer__row { display: grid; gap: var(--space-xl); grid-template-columns: 1fr; }
@media (min-width: 800px) { .site-footer__row { grid-template-columns: 1.2fr 2.4fr; gap: var(--space-xl); align-items: start; } }

.site-footer__brand { display: grid; gap: var(--space-sm); align-items: start; }
.site-footer__brand img { background: var(--color-bg); padding: .6rem .9rem; border-radius: var(--radius-md); width: clamp(110px, 100px + 1vw, 140px); height: auto; }
.site-footer__brand p { margin: 0; color: rgba(246,242,234,0.7); max-width: 34ch; }

.site-footer__cols { display: grid; gap: var(--space-lg); grid-template-columns: 1fr; }
@media (min-width: 600px) { .site-footer__cols { grid-template-columns: repeat(3, 1fr); } }
.site-footer__h {
  font-family: var(--font-display); font-size: var(--fs-300); font-weight: 500;
  letter-spacing: -0.01em; color: var(--color-bg);
  margin: 0 0 var(--space-sm);
}
.site-footer__links { list-style: none; margin: 0; padding: 0; display: grid; gap: .4rem; }
.site-footer address { font-style: normal; line-height: 1.7; }

.site-footer__bottom {
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid rgba(246,242,234,0.12);
  font-size: var(--fs-100); letter-spacing: 0.04em;
  color: rgba(246,242,234,0.55);
}

/* ---------- 16. Barre d'action mobile (clic-to-call + devis) ---------- */
.action-bar {
  position: fixed; left: 12px; right: 12px; bottom: 12px;
  z-index: 60;
  display: none;
  gap: 8px;
  padding: 8px;
  background: color-mix(in srgb, var(--color-ink) 92%, transparent);
  border: 1px solid var(--color-line-dark);
  border-radius: 999px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: var(--shadow-soft);
}
.action-bar__btn {
  flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  padding: 12px 16px;
  border-radius: 999px;
  text-decoration: none;
  font-size: var(--fs-200); font-weight: 500;
  min-height: 44px;
}
.action-bar__btn--call { background: rgba(246,242,234,0.08); color: var(--color-bg); }
.action-bar__btn--devis { background: var(--color-green); color: var(--color-ink); }
@media (max-width: 720px) {
  .action-bar { display: flex; }
  body { padding-bottom: 80px; }
}

/* ---------- 17. Helpers split-text (GSAP) ---------- */
.word {
  display: inline-block;
  vertical-align: top;
  white-space: nowrap;  /* garde le mot solidaire */
}
.word-inner {
  display: inline-block;
  will-change: transform;
}
/* État initial pré-GSAP : sans JS, on garde tout visible (progressive enhancement) */
html.js [data-reveal] { opacity: 0; }
html.js [data-split-words] { opacity: 0; }

@media (prefers-reduced-motion: reduce) {
  html.js [data-reveal],
  html.js [data-split-words] { opacity: 1 !important; }
  html.js .word-inner { opacity: 1 !important; transform: none !important; }
  .scroll-progress span { transition: none; }
}

/* ---------- 18. Carousel réalisations — auto-play + manuel, toutes tailles ---------- */
/* La largeur de tuile visible varie par breakpoint :
   mobile ≤599 : ~78 vw centré   |   600–999 : ~45 vw   |   ≥1000 : ~28 vw (3 tuiles visibles) */
/* Carrousel marquee infini — glisser-déposer fluide (accueil + réalisations) */
.tiles[data-carousel] {
  overflow: hidden;
  display: block;
  margin-inline: 0;
  margin-top: var(--space-md);
  cursor: grab;
  touch-action: pan-y;            /* le swipe horizontal va à notre moteur, le scroll vertical reste natif */
  -webkit-user-select: none;
  user-select: none;
}
/* Accueil : carrousel pleine largeur (edge-to-edge) */
#realisations .tiles[data-carousel] { margin-inline: calc(var(--container-pad) * -1); }
.tiles[data-carousel]:active { cursor: grabbing; }
.tiles-inner {
  --tile-w: clamp(240px, 72vw, 300px);
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
  will-change: transform;
  padding-inline: 1.25rem;
}
.tiles[data-carousel] .tile {
  flex: 0 0 var(--tile-w);
  gap: var(--space-xs);
  cursor: pointer;
}
.tiles[data-carousel] .tile img { -webkit-user-drag: none; user-drag: none; pointer-events: none; }
.tiles[data-carousel] .tile__media  { aspect-ratio: 3 / 4; }
@media (min-width: 600px) {
  .tiles-inner { --tile-w: clamp(280px, 42vw, 340px); gap: 1.25rem; }
}
@media (min-width: 1000px) {
  .tiles-inner { --tile-w: clamp(300px, 24vw, 360px); gap: 1.5rem; }
}

/* Lightbox */
.lb {
  position: fixed; inset: 0; z-index: 500;
  background: rgba(22,21,19,.95);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 1.5rem;
  gap: 1.25rem;
  outline: none;
}
.lb[hidden] { display: none; }
.lb__close {
  position: absolute; top: 1.25rem; right: 1.25rem;
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 50%;
  background: transparent;
  color: rgba(255,255,255,.8);
  cursor: pointer;
  transition: background .2s, color .2s;
}
.lb__close:hover { background: rgba(255,255,255,.12); color: #fff; }
.lb__figure {
  display: flex; flex-direction: column;
  align-items: center; gap: 1rem;
  max-width: 100%; max-height: 90vh;
  margin: 0;
}
.lb__img {
  max-width: 100%; max-height: 82vh;
  object-fit: contain;
  border-radius: var(--radius-sm);
  display: block;
}
/* Mention de droits affichée uniquement dans la lightbox (photo agrandie) */
.lb__rights {
  display: inline-flex; align-items: center; gap: .5rem;
  margin: 0; padding: .4rem .85rem;
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 999px;
  font-size: var(--fs-100);
  color: rgba(255,255,255,0.82);
  text-align: center;
  line-height: 1.3;
}
.lb__rights svg { flex: none; opacity: .8; }

/* ---------- 19. Pages légales & 404 ---------- */
.legal { background: var(--color-bg); }
.legal__main {
  padding-top: clamp(7rem, 5rem + 8vw, 10rem);
  padding-bottom: var(--space-xl);
}
.legal__article {
  max-width: 70ch;
  display: grid;
  gap: var(--space-md);
}
.legal__head { margin-bottom: var(--space-md); display: grid; gap: var(--space-xs); }
.legal__title {
  font-size: clamp(2.2rem, 1.5rem + 3vw, 3.6rem);
  margin: 0;
}
.legal__updated { color: var(--color-ink-muted); font-size: var(--fs-200); }
.legal section { display: grid; gap: var(--space-sm); }
.legal h2 {
  font-family: var(--font-display);
  font-size: var(--fs-600);
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: var(--space-md) 0 0;
}
.legal p, .legal address, .legal ul, .legal ol { margin: 0; }
/* .legal a s'applique aux liens du contenu (main), pas au footer ni au header */
.legal main a { color: var(--color-ink); }
.legal main a:hover { color: var(--color-green-deep); }
/* On surspécifie le footer pour s'assurer qu'il garde ses couleurs claires
   quelle que soit la classe du body (.legal, .real-page, etc.) */
.site-footer a,
.legal .site-footer a,
.real-page .site-footer a { color: rgba(246,242,234,0.78); text-decoration: none; border-bottom: 1px solid rgba(246,242,234,0.18); padding-bottom: 1px; }
.site-footer a:hover,
.legal .site-footer a:hover,
.real-page .site-footer a:hover { color: var(--color-green); border-color: var(--color-green); }

/* ---------- Réseaux sociaux (footer) — chips « Liquid Glass » iOS, teintés marque ---------- */
.footer-social { display: grid; gap: .85rem; margin-top: var(--space-sm); }
.footer-social__list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: .75rem;
}
/* Desktop : les deux chips côte à côte */
@media (min-width: 600px) {
  .footer-social__list { flex-wrap: nowrap; }
}
.footer-social__chip {
  display: inline-flex; align-items: center; gap: .7rem;
  border-radius: 999px;
  -webkit-backdrop-filter: blur(12px) saturate(1.5);
  backdrop-filter: blur(12px) saturate(1.5);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition: background .25s, border-color .25s, transform .25s var(--ease-out), box-shadow .25s, color .25s;
}
.footer-social__chip:hover,
.footer-social__chip:focus-visible { transform: translateY(-3px); }
.footer-social__icon { display: inline-flex; }
.footer-social__name { font-size: var(--fs-300); font-weight: 600; letter-spacing: .01em; }

/* Override (3 classes) des styles de lien du footer : pas de soulignement + teinte marque */
.site-footer .footer-social__list .footer-social__chip {
  color: #fff;
  border: 1px solid transparent;
  padding: .72rem 1.25rem; /* (re)posé ici pour battre .site-footer a { padding-bottom:1px } */
}
/* Facebook — bleu */
.site-footer .footer-social__list .footer-social__chip--fb {
  background: rgba(24, 119, 242, 0.18);
  border-color: rgba(24, 119, 242, 0.55);
}
.site-footer .footer-social__list .footer-social__chip--fb:hover,
.site-footer .footer-social__list .footer-social__chip--fb:focus-visible {
  background: rgba(24, 119, 242, 0.32);
  border-color: rgba(24, 119, 242, 0.85);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 8px 22px rgba(24, 119, 242, 0.28);
}
.footer-social__chip--fb .footer-social__icon svg { fill: #3b8bff; }
/* Instagram — magenta/dégradé */
.site-footer .footer-social__list .footer-social__chip--ig {
  background: rgba(221, 42, 123, 0.16);
  border-color: rgba(221, 42, 123, 0.5);
}
.site-footer .footer-social__list .footer-social__chip--ig:hover,
.site-footer .footer-social__list .footer-social__chip--ig:focus-visible {
  background: rgba(221, 42, 123, 0.30);
  border-color: rgba(245, 133, 41, 0.8);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 8px 22px rgba(221, 42, 123, 0.28);
}

.error-page {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: var(--space-xl) var(--container-pad);
  text-align: center;
}
.error-page__inner { max-width: 52ch; display: grid; gap: var(--space-md); }
.error-page__code {
  font-family: var(--font-display);
  font-size: clamp(5rem, 3rem + 12vw, 12rem);
  line-height: 0.9;
  font-variation-settings: "opsz" 144, "SOFT" 60;
  color: var(--color-green);
  margin: 0;
}
.error-page__title { font-family: var(--font-display); font-size: var(--fs-700); margin: 0; letter-spacing: -0.01em; }
.error-page__cta { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-sm) var(--space-md); margin-top: var(--space-md); }
.error-page__contact { margin-top: var(--space-md); color: var(--color-ink-muted); font-size: var(--fs-200); }
.error-page__contact a { color: inherit; }

/* ---------- 20. Savoir-faire — bento dynamique (home) ---------- */
.sf {
  list-style: none;
  margin: var(--space-xl) 0 0;
  padding: 0;
  display: grid;
  gap: clamp(.75rem, 1vw + .25rem, 1.25rem);
  grid-template-columns: 1fr;
}
/* Bento asymétrique : sur grand écran, la 1ère et la 4e cellules sont plus
   imposantes (cœur de métier + restauration), les 2 du milieu plus compactes. */
@media (min-width: 700px) {
  .sf { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1100px) {
  .sf {
    grid-template-columns: 1.25fr 1fr;
    grid-template-areas:
      "a b"
      "c d";
  }
  .sf__cell--01 { grid-area: a; }
  .sf__cell--02 { grid-area: b; }
  .sf__cell--03 { grid-area: c; }
  .sf__cell--04 { grid-area: d; }
  .sf__cell--01 .sf__card,
  .sf__cell--04 .sf__card { min-height: 320px; }
}

.sf__cell { display: contents; }
.sf__card {
  position: relative;
  display: flex; flex-direction: column;
  gap: var(--space-sm);
  padding: clamp(1.5rem, 1rem + 2.2vw, 2.6rem);
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  min-height: clamp(220px, 30vh, 280px);
  transition:
    transform .4s var(--ease-out),
    border-color .4s,
    box-shadow .4s,
    background-color .4s;
}
/* Faux halo discret au survol via une couche dégradée */
.sf__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(143,174,60,0) 0%, rgba(143,174,60,0.08) 100%);
  opacity: 0;
  transition: opacity .4s var(--ease-out);
  pointer-events: none;
}
.sf__card:hover,
.sf__card:focus-visible {
  transform: translateY(-6px);
  border-color: var(--color-green);
  box-shadow: 0 28px 56px -28px rgba(22,21,19,0.22);
}
.sf__card:hover::before,
.sf__card:focus-visible::before { opacity: 1; }
.sf__card:focus-visible {
  outline: 2px solid var(--color-green);
  outline-offset: 3px;
}
.sf__num {
  position: relative;
  font-family: var(--font-body);
  font-size: var(--fs-100);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-green-deep);
}
.sf__title {
  position: relative;
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.6rem, 1.1rem + 1.8vw, 2.4rem);
  line-height: 1.04;
  letter-spacing: -0.02em;
}
.sf__title em {
  font-style: italic;
  color: var(--color-wood);
}
.sf__body {
  position: relative;
  margin: 0;
  font-size: var(--fs-300);
  color: var(--color-ink-soft);
  max-width: 42ch;
  line-height: 1.55;
}
.sf__arrow {
  position: relative;
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: .75em;
  font-size: var(--fs-100);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-muted);
  transition: color .35s;
}
.sf__arrow-line {
  display: block;
  height: 1px;
  width: 28px;
  background: currentColor;
  transition: width .45s var(--ease-out);
}
.sf__arrow svg { transition: transform .45s var(--ease-out); }
.sf__card:hover .sf__arrow,
.sf__card:focus-visible .sf__arrow { color: var(--color-green-deep); }
.sf__card:hover .sf__arrow-line,
.sf__card:focus-visible .sf__arrow-line { width: 64px; }
.sf__card:hover .sf__arrow svg,
.sf__card:focus-visible .sf__arrow svg { transform: translateX(4px); }
.sf__cta { margin: var(--space-lg) 0 0; text-align: center; }

/* ---------- 20bis. Page Réalisations dédiée ---------- */
/* En-tête coloré (verre teinté bois + vert) pour un haut de page plus vivant */
.real-page .legal__head {
  margin-bottom: var(--space-xl);
  padding: clamp(1.75rem, 1.2rem + 3vw, 3rem) clamp(1.4rem, 1rem + 3vw, 3rem);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, #fff 30%, var(--color-line));
  /* Verre translucide « iOS » teinté bois × vert */
  background:
    radial-gradient(120% 150% at 0% 0%, rgba(143, 174, 60, 0.24), transparent 55%),
    radial-gradient(120% 150% at 100% 0%, rgba(154, 107, 63, 0.24), transparent 55%),
    color-mix(in srgb, var(--color-bg-deep) 66%, transparent);
  -webkit-backdrop-filter: blur(16px) saturate(1.5);
  backdrop-filter: blur(16px) saturate(1.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.55),   /* reflet d'arête (lumière du haut) */
    0 16px 38px rgba(0, 0, 0, 0.10);            /* profondeur douce */
}
/* Repli sans backdrop-filter : crème profond opaque (lisibilité garantie) */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .real-page .legal__head {
    background:
      radial-gradient(120% 150% at 0% 0%, rgba(143, 174, 60, 0.24), transparent 55%),
      radial-gradient(120% 150% at 100% 0%, rgba(154, 107, 63, 0.24), transparent 55%),
      var(--color-bg-deep);
  }
}
.real-page .legal__head .section__eyebrow { color: var(--color-green-deep); }
.real-page .legal__head .legal__lede { color: var(--color-ink-soft); }

/* Bardage : photo unique centrée */
.real-single {
  max-width: 560px;
  margin: var(--space-md) auto 0;
  cursor: pointer;
}
.real-single .tile__media { aspect-ratio: 4 / 3; }

/* Réparation : note sans photo */
.real-section__note {
  margin: 0 0 var(--space-md);
  max-width: 62ch;
  color: var(--color-ink-soft);
}
.real-toc {
  display: flex; flex-wrap: wrap;
  gap: .5rem .65rem;
  margin-top: var(--space-md);
}
.real-page .real-toc a {
  font-size: var(--fs-100);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: .55em 1.1em;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  text-decoration: none;
  color: var(--color-ink-soft);
  transition: background .25s, color .25s, border-color .25s, transform .25s var(--ease-out);
}
.real-page .real-toc a:hover,
.real-page .real-toc a:focus-visible {
  background: var(--color-green);
  color: var(--color-ink);
  border-color: var(--color-green);
  transform: translateY(-1px);
}
.real-section {
  margin-top: clamp(3rem, 2rem + 4vw, 5rem);
  scroll-margin-top: clamp(5rem, 4rem + 4vw, 7rem); /* offset pour ancre sous header */
}
/* Le panneau <details> est un grid-item : sans min-width:0 il refuse de passer
   sous la largeur intrinsèque du carrousel (rangée de tuiles) et s'étire, ce qui
   débordait horizontalement la page sur mobile. min-width:0 le laisse se réduire
   à sa colonne, le carrousel (overflow:hidden) reprend alors son rôle de clip. */
.real-section__panel { min-width: 0; }
.real-section__head {
  display: grid;
  gap: .35rem;
  border-top: 1px solid var(--color-line);
  padding-top: clamp(1.5rem, 1rem + 1.5vw, 2rem);
  margin-bottom: clamp(1.25rem, 1rem + 1vw, 1.75rem);
  position: relative;
}
.real-section__head::after {
  /* Petit accent vert au top à gauche, marqueur visuel par section */
  content: "";
  position: absolute;
  top: -1px; left: 0;
  height: 2px; width: 56px;
  background: var(--color-green);
}
.real-section__num {
  font-family: var(--font-body);
  font-size: var(--fs-100);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-green-deep);
  margin: 0;
}
.real-section__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 1.2rem + 2.2vw, 3rem);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
}
.real-section__lede {
  margin: .35rem 0 0;
  max-width: 62ch;
  color: var(--color-ink-soft);
  font-size: var(--fs-300);
}

/* ---------- 20quater. Accordéon savoir-faire (page Réalisations) ---------- */
/* Chaque section est un <details>/<summary> : tout est replié par défaut,
   on n'affiche que les intitulés de savoir-faire.
   Le <summary> joue le rôle du head : cliquable, rôle bouton natif,
   aria-expanded géré par le navigateur. */
.real-section__head {
  cursor: pointer;
  list-style: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  margin-bottom: 0;
  /* Réserve l'espace du pill en haut à droite */
  padding-right: clamp(3.25rem, 2.5rem + 1.5vw, 4rem);
  transition: color .25s var(--ease-out);
}
@media (min-width: 640px) {
  .real-section__head {
    padding-right: clamp(13rem, 11rem + 4vw, 16rem);
  }
}
.real-section__head::-webkit-details-marker { display: none; }
.real-section__head::marker { content: ""; }
.real-section__head:focus-visible {
  outline: 2px solid var(--color-green);
  outline-offset: 6px;
  border-radius: 2px;
}

/* Toggle = pill compact (label + chevron) en absolu, haut-droite, niveau du titre */
.real-section__toggle {
  position: absolute;
  top: clamp(2.4rem, 1.5rem + 2vw, 3.4rem);
  right: 0;
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  padding: .55rem .75rem .55rem 1.1rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: transparent;
  color: var(--color-ink-soft);
  white-space: nowrap;
  transition:
    background-color .3s var(--ease-out),
    color .3s var(--ease-out),
    border-color .3s var(--ease-out),
    transform .3s var(--ease-out);
}

/* Label : sans-serif, sentence case — propre et lisible dans le pill */
.real-section__toggle-label {
  font-family: var(--font-body);
  font-size: var(--fs-200);
  font-weight: 500;
  letter-spacing: -0.005em;
  color: inherit;
  line-height: 1;
}

/* Swap label fermé / ouvert (texte change quand <details open>) */
.real-section__toggle-label--open { display: none; }
.real-section__panel[open] .real-section__toggle-label--closed { display: none; }
.real-section__panel[open] .real-section__toggle-label--open { display: inline; }

/* Sur mobile (< 640 px) : le label texte disparaît, le pill devient un rond avec juste le chevron */
@media (max-width: 639px) {
  .real-section__toggle {
    padding: .55rem;
    gap: 0;
  }
  .real-section__toggle-label,
  .real-section__panel[open] .real-section__toggle-label--open { display: none; }
}

/* Chevron rond avec bordure, à l'intérieur du pill, pivote à l'ouverture */
.real-section__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  border: 1px solid currentColor;
  border-radius: 50%;
  color: inherit;
  background: transparent;
  flex-shrink: 0;
  transition: transform .5s var(--ease-out);
}
.real-section__chevron svg { display: block; width: 14px; height: 14px; }

/* Hover/focus : tout le pill prend l'accent vert + léger soulèvement */
.real-section__head:hover .real-section__toggle,
.real-section__head:focus-visible .real-section__toggle {
  background: var(--color-green);
  color: var(--color-ink);
  border-color: var(--color-green);
  transform: translateY(-1px);
}

/* État ouvert : le chevron pivote, le titre prend la couleur d'accent */
.real-section__panel[open] > .real-section__head .real-section__chevron {
  transform: rotate(180deg);
}
.real-section__panel[open] > .real-section__head .real-section__title {
  color: var(--color-green-deep);
}

/* Corps révélé : padding + fade-in léger à l'ouverture */
.real-section__body {
  padding-top: clamp(1rem, .5rem + 1.5vw, 1.75rem);
}
.real-section__panel[open] > .real-section__body {
  animation: realRevealFade .42s var(--ease-out) both;
}
@keyframes realRevealFade {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Reduced motion : pas d'animation d'apparition ni de rotation transitionnée */
@media (prefers-reduced-motion: reduce) {
  .real-section__chevron { transition: color .2s, background-color .2s, border-color .2s; }
  .real-section__panel[open] > .real-section__body { animation: none; }
}

/* CTA de bas de page */
.real-cta {
  margin-top: clamp(3rem, 2rem + 4vw, 5rem);
  padding: clamp(2rem, 1.4rem + 3vw, 3.5rem);
  background: var(--color-ink);
  color: var(--color-bg);
  border-radius: var(--radius-lg);
  text-align: center;
  display: grid;
  gap: var(--space-md);
  justify-items: center;
}
.real-cta h2 {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.2rem + 1.8vw, 2.6rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  margin: 0;
}
.real-cta p { margin: 0; }
.real-cta__btns {
  display: flex; flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm) var(--space-md);
}
.real-cta .btn--ghost {
  color: var(--color-bg);
  border-color: var(--color-line-dark);
}
/* Survol lisible sur le bloc sombre : texte blanc franc (fini le vert sur vert) */
.real-cta .btn--primary:hover,
.real-cta .btn--primary:focus-visible {
  background: var(--color-green-deep);
  color: #fff;
}
.real-cta .btn--ghost:hover,
.real-cta .btn--ghost:focus-visible {
  background: var(--color-green-deep);
  border-color: var(--color-green-deep);
  color: #fff;
}

/* ---------- 20ter. Slider avant/après (composant comparateur) ---------- */
.ba {
  --ba-pos: 50%;
  margin: 0 auto clamp(2rem, 1.5rem + 3vw, 3.5rem);
  max-width: 920px;
  display: grid;
  gap: clamp(.75rem, 1.5vw, 1.25rem);
}
.ba__stage {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: ew-resize;
  user-select: none;
  touch-action: none;
  background: var(--color-bg-deep);
  box-shadow: 0 24px 50px -28px rgba(22,21,19,0.3);
}
.ba__img { position: absolute; inset: 0; display: block; }
.ba__img img { width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none; }
.ba__before-clip {
  position: absolute; inset: 0;
  clip-path: inset(0 calc(100% - var(--ba-pos)) 0 0);
  -webkit-clip-path: inset(0 calc(100% - var(--ba-pos)) 0 0);
}
/* Range input invisible mais accessible (clavier / lecteurs d'écran) */
.ba__range {
  position: absolute; inset: 0;
  width: 100%; height: 100%; margin: 0;
  appearance: none; -webkit-appearance: none;
  background: transparent; cursor: ew-resize;
  opacity: 0; z-index: 3;
}
.ba__range::-webkit-slider-thumb { appearance: none; -webkit-appearance: none; width: 44px; height: 100%; cursor: ew-resize; }
.ba__range::-moz-range-thumb { width: 44px; height: 100%; border: 0; cursor: ew-resize; }
.ba__range:focus-visible + .ba__divider .ba__handle { box-shadow: 0 0 0 3px var(--color-green), 0 4px 16px -4px rgba(0,0,0,0.45); }
/* Labels Avant / Après */
.ba__tag {
  position: absolute;
  top: clamp(.75rem, 1.5vw, 1rem);
  z-index: 2;
  padding: .35em .9em;
  font-size: var(--fs-100);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: rgba(22,21,19,0.7);
  color: var(--color-bg);
  border-radius: 999px;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  pointer-events: none;
  font-family: var(--font-body);
}
.ba__tag--before { left: clamp(.75rem, 1.5vw, 1rem); }
.ba__tag--after  { right: clamp(.75rem, 1.5vw, 1rem); }
/* Diviseur vertical + handle central */
.ba__divider {
  position: absolute;
  top: 0; bottom: 0;
  left: var(--ba-pos);
  width: 2px;
  background: var(--color-bg);
  transform: translateX(-50%);
  z-index: 2;
  pointer-events: none;
}
.ba__handle {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: clamp(42px, 4.5vw, 54px);
  height: clamp(42px, 4.5vw, 54px);
  border-radius: 999px;
  background: var(--color-bg);
  color: var(--color-ink);
  display: inline-flex;
  align-items: center; justify-content: center;
  box-shadow:
    0 6px 18px -6px rgba(0,0,0,0.5),
    0 0 0 1px rgba(255,255,255,0.4) inset;
  transition: box-shadow .25s;
}
.ba__cap {
  text-align: center;
  display: grid;
  gap: .25em;
}
.ba__cap-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-400);
  color: var(--color-ink);
}
.ba__cap-meta {
  font-size: var(--fs-100);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-ink-muted);
}

/* Sous-groupe : un chantier, plusieurs vues */
.real-cluster {
  margin-top: clamp(2rem, 1.5rem + 2vw, 3rem);
  padding-top: clamp(1.25rem, 1rem + 1.5vw, 1.75rem);
  border-top: 1px dashed var(--color-line);
}
.real-cluster__num {
  font-family: var(--font-body);
  font-size: var(--fs-100);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-green-deep);
  margin: 0;
}
.real-cluster__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.4rem, 1rem + 1.4vw, 2rem);
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin: .25rem 0 var(--space-md);
}
.real-section__cta { margin-top: var(--space-lg); }

/* Clusters « un chantier, trois vues » : pile photo façon iOS sur téléphone.
   Gain de hauteur important — les 3 vues se chevauchent, chacune reste tactile
   (clic → lightbox), au lieu d'occuper 3 pleines hauteurs en colonne.
   Empilement déterministe : toutes les cotes dérivent de --cw (calc), pour ne
   pas dépendre d'un % de marge (peu fiable selon le conteneur). */
.real-cluster__hint { display: none; }
@media (max-width: 599px) {
  .tiles--cluster {
    --cw: min(74vw, 300px);            /* largeur d'une carte */
    --ch: calc(var(--cw) * 0.75);      /* hauteur média (ratio 4/3) */
    --peek: calc(var(--ch) * 0.42);    /* bande visible des cartes du dessous */
    position: relative;
    display: block;
    width: var(--cw);
    height: calc(var(--ch) + var(--peek) * 2 + 10px);
    margin: var(--space-sm) auto 0;
  }
  .tiles--cluster .tile {
    position: absolute;
    left: 0;
    width: var(--cw);
    margin: 0;
    cursor: pointer;
    transition: transform .4s var(--ease-out);
  }
  .tiles--cluster .tile:nth-child(1) { top: 0;                      transform: rotate(-2.5deg) translateX(-3%); z-index: 1; }
  .tiles--cluster .tile:nth-child(2) { top: var(--peek);           transform: rotate(1.8deg)  translateX(3%);  z-index: 2; }
  .tiles--cluster .tile:nth-child(3) { top: calc(var(--peek) * 2); transform: rotate(-1deg)   translateX(-1%); z-index: 3; }
  .tiles--cluster .tile:active { transform: scale(1.03); z-index: 4; }
  .tiles--cluster .tile__media {
    aspect-ratio: 4 / 3;
    border: 5px solid #fff;
    box-shadow: 0 14px 30px -12px rgba(0,0,0,.55), 0 2px 6px rgba(0,0,0,.12);
  }
  .real-cluster__hint {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin: 0 0 var(--space-sm);
    font-size: var(--fs-100);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
  }
}
@media (max-width: 599px) and (prefers-reduced-motion: reduce) {
  .tiles--cluster .tile { transition: none; }
  .tiles--cluster .tile:active { transform: none; }
}

/* ---------- 21. Navigation du carousel des réalisations (flèches + skip) ---------- */
.tiles-nav {
  display: flex; /* visible sur tous les breakpoints */
  margin-top: var(--space-md);
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}
.tiles-nav__row {
  display: flex; align-items: center; justify-content: center;
  gap: var(--space-md);
}
.tiles-nav__btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: var(--color-bg);
  color: var(--color-ink);
  cursor: pointer;
  transition: background .25s, color .25s, transform .25s var(--ease-out), border-color .25s, opacity .25s;
}
.tiles-nav__btn:hover {
  background: var(--color-ink);
  color: var(--color-bg);
  border-color: var(--color-ink);
  transform: translateY(-2px);
}
.tiles-nav__btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
  transform: none;
}

/* ---------- 21bis. Remplacement des styles inline (bloqués par la CSP stricte) ---------- */
/* Sous-pages : intro sous le H1 */
.legal__lede { max-width: 64ch; color: var(--color-ink-soft); font-size: var(--fs-400); }
/* Savoir-faire : liste des métiers (le CTA final réutilise .real-cta, partagé avec la page Réalisations) */
.legal__main .services { margin-top: var(--space-xl); }

/* ---------- 22. Impression (minimal) ---------- */
@media print {
  .site-header, .site-nav, .action-bar, .scroll-progress, .tiles-nav, .hero__distri { display: none !important; }
  body { background: #fff; color: #000; }
  .section--dark { background: #fff; color: #000; }
}
