/* =========================================================================
   SOS Toiture Martinique — Design System + Layout Public
   Editorial premium. Inter variable. No purple, no emoji, no framework.
   ========================================================================= */

/* -------------------------------------------------------------------------
   0. Fonts — Inter variable (body) + Fraunces variable (display serif)
      Self-hosted depuis public/assets/fonts/, aucune dépendance CDN runtime.
   ------------------------------------------------------------------------- */
@font-face {
  font-family: 'InterVar';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/InterVariable.woff2') format('woff2-variations'),
       url('/assets/fonts/InterVariable.woff2') format('woff2');
  font-named-instance: 'Regular';
}
@font-face {
  font-family: 'InterVar';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/InterVariable-Italic.woff2') format('woff2-variations'),
       url('/assets/fonts/InterVariable-Italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/fraunces-latin-wght-normal.woff2') format('woff2-variations'),
       url('/assets/fonts/fraunces-latin-wght-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/fraunces-latin-wght-italic.woff2') format('woff2-variations'),
       url('/assets/fonts/fraunces-latin-wght-italic.woff2') format('woff2');
}

/* =========================================================================
   1. Custom Properties (tokens)
   ========================================================================= */
:root {
  /* Palette tricolore française — bleu marine, blanc, rouge SOS */
  --color-white: #ffffff;
  --color-paper: #FFFFFF;            /* canvas pur */
  --color-paper-soft: #F8F9FB;       /* off-white bleuté très léger */
  --color-bg-soft: #F1F3F7;          /* gris bleuté section alternée */
  --color-bg-mute: #E4E8EF;          /* gris bleuté séparateur */
  --color-line: #DFE3EA;             /* bord neutre */
  --color-line-strong: #C7CFDB;
  --color-ink-soft: #5A6478;         /* gris bleuté secondaire */
  --color-ink: #1B2233;              /* texte principal — bleu nuit */
  --color-ink-strong: #0A1428;       /* titres — bleu nuit profond */

  /* Tricolore */
  --color-accent: #002F6C;           /* bleu marine français — trust */
  --color-accent-hover: #001F4A;
  --color-accent-soft: #E6ECF5;
  --color-highlight: #DC2626;        /* rouge SOS — CTA primaire + brand */
  --color-highlight-hover: #B91C1C;
  --color-highlight-soft: #FEE5E5;
  --color-success: #16A34A;
  --color-success-soft: #E8F5EE;
  --color-warning: #D97706;
  --color-warning-soft: #FEF3C7;
  --color-urgence: #DC2626;          /* RÉSERVÉ — identique à highlight, c'est l'ADN SOS */
  --color-urgence-hover: #B91C1C;
  --color-urgence-soft: #FEE5E5;

  /* Surfaces */
  --surface-card: #FFFFFF;
  --surface-elevated: #FFFFFF;

  /* Espace */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 32px;
  --space-8: 40px;
  --space-9: 56px;
  --space-10: 72px;
  --space-11: 96px;
  --space-12: 128px;

  /* Rayons */
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-btn: 8px;
  --radius-card: 12px;
  --radius-modal: 16px;
  --radius-full: 999px;

  /* Ombres — teintées bleu nuit pour cohésion tricolore */
  --shadow-sm: 0 1px 2px rgba(10,20,40,0.06), 0 4px 12px rgba(10,20,40,0.06);
  --shadow-md: 0 4px 8px rgba(10,20,40,0.08), 0 12px 28px rgba(10,20,40,0.10);
  --shadow-lg: 0 10px 20px rgba(10,20,40,0.10), 0 28px 56px rgba(10,20,40,0.14);
  --shadow-urgence: 0 10px 28px rgba(220,38,38,0.32);
  --shadow-accent: 0 10px 28px rgba(0,47,108,0.20);
  --shadow-red: 0 10px 28px rgba(220,38,38,0.22);

  /* Typo — Fraunces (display serif variable) + Inter (body) */
  --font-display: 'Fraunces', 'Iowan Old Style', 'Apple Garamond', Georgia, 'Times New Roman', serif;
  --font-sans: 'InterVar', Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, system-ui, sans-serif;
  --font-mono: ui-monospace, 'SF Mono', SFMono-Regular, Menlo, Consolas, monospace;

  --fs-xs:  0.78rem;
  --fs-sm:  0.875rem;
  --fs-base: 1rem;
  --fs-md:  1.125rem;
  --fs-lg:  1.25rem;
  --fs-xl:  1.5rem;
  --fs-h6:  clamp(1.05rem, 0.5vw + 0.9rem, 1.2rem);
  --fs-h5:  clamp(1.15rem, 0.6vw + 1rem, 1.35rem);
  --fs-h4:  clamp(1.35rem, 1vw + 1rem, 1.75rem);
  --fs-h3:  clamp(1.65rem, 1.6vw + 1rem, 2.35rem);
  --fs-h2:  clamp(2rem, 2.6vw + 1rem, 3.25rem);
  --fs-h1:  clamp(2.5rem, 5vw + 1rem, 4.75rem);
  --fs-display: clamp(3rem, 6vw + 1rem, 5.75rem);

  /* Layout */
  --container-max: 1200px;
  --container-narrow: 880px;
  --container-px: clamp(16px, 4vw, 40px);
  --section-y: clamp(64px, 8vw, 128px);

  /* Animation */
  --ease-out:  cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in:   cubic-bezier(0.55, 0, 0.45, 0);
  --ease-io:   cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 150ms;
  --duration-base: 220ms;
  --duration-slow: 400ms;

  /* Header */
  --header-h: 76px;
  --header-h-compact: 60px;

  /* Z layers */
  --z-base: 1;
  --z-sticky: 60;
  --z-floating: 70;
  --z-header: 80;
  --z-drawer: 90;
  --z-modal: 100;
  --z-toast: 110;
}

/* =========================================================================
   2. Reset moderne
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; tab-size: 4; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--color-ink);
  background: var(--color-paper);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, picture, video, canvas, svg { display: block; max-width: 100%; }
img { height: auto; }
button, input, optgroup, select, textarea { font: inherit; color: inherit; }
button { background: none; border: 0; padding: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
hr { border: 0; border-top: 1px solid var(--color-line); margin: var(--space-7) 0; }
::selection { background: var(--color-accent-soft); color: var(--color-ink-strong); }

/* =========================================================================
   3. Typographie — Inter dominant. Fraunces réservé aux italiques d'accent.
   ========================================================================= */
h1, .h1, .display {
  font-family: var(--font-sans);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 0.98;
  color: var(--color-ink-strong);
  font-feature-settings: 'cv11' on, 'ss01' on;
}
h2, .h2 {
  font-family: var(--font-sans);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--color-ink-strong);
}
h3, .h3, h4, .h4 {
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-ink-strong);
}
h5, .h5, h6, .h6 {
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.25;
  color: var(--color-ink-strong);
}
h1, .h1 { font-size: var(--fs-h1); }
h2, .h2 { font-size: var(--fs-h2); }
h3, .h3 { font-size: var(--fs-h3); }
h4, .h4 { font-size: var(--fs-h4); }
h5, .h5 { font-size: var(--fs-h5); }
h6, .h6 { font-size: var(--fs-h6); }
.display { font-size: var(--fs-display); }

/* Italique d'accent — Fraunces, un ou deux mots clés (réservé hero & punchlines) */
.italic-accent, .h1 em, .hero-title em, .display em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-variation-settings: 'opsz' 144, 'SOFT' 50;
  color: var(--color-highlight);
  letter-spacing: -0.02em;
  font-feature-settings: 'ss01' on;
}

.lead { font-size: var(--fs-md); line-height: 1.55; color: var(--color-ink-soft); max-width: 56ch; }
.prose { max-width: 70ch; }
.prose p + p { margin-top: var(--space-4); }
.prose ul, .prose ol { padding-left: 1.25rem; }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose li + li { margin-top: var(--space-2); }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: currentColor;
  opacity: 0.6;
}
.text-muted { color: var(--color-ink-soft); }
.text-accent { color: var(--color-accent); }
.text-success { color: var(--color-success); }
.text-urgence { color: var(--color-urgence); }
.text-center { text-align: center; }
.text-balance { text-wrap: balance; }
.text-pretty { text-wrap: pretty; }

/* =========================================================================
   4. Layout primitives
   ========================================================================= */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-px);
}
.container-narrow {
  width: 100%;
  max-width: var(--container-narrow);
  margin-inline: auto;
  padding-inline: var(--container-px);
}
.section { padding-block: var(--section-y); }
.section-tight { padding-block: clamp(48px, 6vw, 80px); }
.section-soft { background: var(--color-bg-soft); }
.section-divider { border-top: 1px solid var(--color-line); }

.stack { display: flex; flex-direction: column; gap: var(--space-6); }
.stack-sm { display: flex; flex-direction: column; gap: var(--space-3); }
.stack-lg { display: flex; flex-direction: column; gap: var(--space-8); }
.cluster { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; }
.cluster-lg { display: flex; flex-wrap: wrap; gap: var(--space-5); align-items: center; }
.grid { display: grid; gap: var(--space-6); }
.grid-2 { grid-template-columns: 1fr; }
.grid-3 { grid-template-columns: 1fr; }
.grid-4 { grid-template-columns: 1fr; }
@media (min-width: 720px)  { .grid-2 { grid-template-columns: repeat(2, 1fr); } .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .grid-3 { grid-template-columns: repeat(3, 1fr); } .grid-4 { grid-template-columns: repeat(4, 1fr); } }

.align-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-2 { gap: var(--space-2); } .gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); } .gap-6 { gap: var(--space-6); } .gap-8 { gap: var(--space-8); }

.mt-2 { margin-top: var(--space-2); } .mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); } .mt-8 { margin-top: var(--space-8); }
.mb-2 { margin-bottom: var(--space-2); } .mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); } .mb-8 { margin-bottom: var(--space-8); }
.py-4 { padding-block: var(--space-4); } .py-6 { padding-block: var(--space-6); }

.hide-mobile { display: none; }
@media (min-width: 900px) { .hide-mobile { display: initial; } .hide-desktop { display: none; } }

/* =========================================================================
   5. Accessibilité
   ========================================================================= */
.skip-link {
  position: absolute;
  top: -100px;
  left: 8px;
  z-index: 200;
  background: var(--color-ink-strong);
  color: #fff;
  padding: 12px 18px;
  border-radius: var(--radius-btn);
  font-weight: 500;
  text-decoration: none;
  transition: top var(--duration-base) var(--ease-out);
}
.skip-link:focus-visible { top: 12px; outline: 3px solid var(--color-accent-soft); }

:where(a, button, [role="button"], input, select, textarea, [tabindex]):focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* =========================================================================
   6. Buttons
   ========================================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: inherit;
  font-size: var(--fs-base);
  font-weight: 500;
  line-height: 1;
  padding: 14px 22px;
  border-radius: var(--radius-btn);
  border: 1px solid transparent;
  background: transparent;
  color: inherit;
  cursor: pointer;
  text-decoration: none;
  transition: background-color var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out),
              color var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
  white-space: nowrap;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.btn:disabled, .btn[aria-disabled="true"] { opacity: 0.5; pointer-events: none; }
.btn .icon { width: 18px; height: 18px; flex: 0 0 18px; }
.btn-sm { padding: 9px 14px; font-size: var(--fs-sm); }
.btn-lg { padding: 18px 28px; font-size: var(--fs-md); }
.btn-block { width: 100%; }

.btn-primary {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover { background: var(--color-accent-hover); border-color: var(--color-accent-hover); box-shadow: var(--shadow-md); }

.btn-secondary {
  background: #fff;
  color: var(--color-ink-strong);
  border-color: var(--color-line-strong);
}
.btn-secondary:hover { border-color: var(--color-ink-strong); background: var(--color-white); }

.btn-tertiary {
  padding-inline: 0;
  color: var(--color-accent);
  background: transparent;
}
.btn-tertiary:hover { color: var(--color-accent-hover); }
.btn-tertiary .icon { transition: transform var(--duration-base) var(--ease-out); }
.btn-tertiary:hover .icon { transform: translateX(3px); }

.btn-ghost {
  color: var(--color-ink);
  background: transparent;
}
.btn-ghost:hover { background: var(--color-bg-soft); }

.btn-urgence {
  background: var(--color-urgence);
  color: #fff;
  border-color: var(--color-urgence);
  box-shadow: var(--shadow-urgence);
  font-weight: 600;
  min-height: 52px;
}
.btn-urgence:hover { background: var(--color-urgence-hover); border-color: var(--color-urgence-hover); }

/* =========================================================================
   7. Badges
   ========================================================================= */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-xs);
  font-weight: 500;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--color-bg-soft);
  color: var(--color-ink);
  border: 1px solid var(--color-line);
  line-height: 1.4;
}
.badge .icon { width: 14px; height: 14px; }
.badge-accent  { background: var(--color-accent-soft);  color: var(--color-accent);    border-color: transparent; }
.badge-success { background: var(--color-success-soft); color: var(--color-success);   border-color: transparent; }
.badge-warning { background: var(--color-warning-soft); color: #92400e;                 border-color: transparent; }
.badge-urgence { background: var(--color-urgence-soft); color: var(--color-urgence);    border-color: transparent; }
.badge-outline { background: transparent; }

/* Pulse uniquement utilisé pour urgence badge admin */
.badge-pulse { position: relative; }
.badge-pulse::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: var(--radius-full);
  border: 1px solid currentColor;
  opacity: 0;
  animation: badgePulse 1.6s ease-out infinite;
}
@keyframes badgePulse {
  0%   { transform: scale(1);    opacity: 0.5; }
  100% { transform: scale(1.25); opacity: 0;   }
}

/* =========================================================================
   8. Header / Navigation
   ========================================================================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid transparent;
  transition: background-color var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out),
              padding var(--duration-base) var(--ease-out);
}
.site-header.is-scrolled {
  background: rgba(255, 255, 255, 0.95);
  border-bottom-color: var(--color-line);
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  height: var(--header-h);
  transition: height var(--duration-base) var(--ease-out);
}
.site-header.is-scrolled .container { height: var(--header-h-compact); }

.logo {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-weight: 600;
  letter-spacing: -0.02em;
  font-size: var(--fs-md);
  color: var(--color-ink-strong);
}
.logo-sos {
  color: var(--color-accent);
  font-weight: 700;
  letter-spacing: 0.02em;
}
.logo-rest { font-weight: 500; }

.nav-primary { display: none; }
@media (min-width: 1024px) {
  .nav-primary {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }
}
.nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 12px;
  border-radius: var(--radius-btn);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-ink);
  position: relative;
  transition: color var(--duration-base) var(--ease-out), background-color var(--duration-base) var(--ease-out);
}
.nav-link:hover { color: var(--color-ink-strong); background: var(--color-bg-soft); }
.nav-link.is-active { color: var(--color-accent); }

.nav-dropdown { position: relative; }
.nav-dropdown-trigger { cursor: pointer; }
.nav-dropdown-trigger .icon-chevron { transition: transform var(--duration-base) var(--ease-out); }
.nav-dropdown:hover .nav-dropdown-trigger .icon-chevron,
.nav-dropdown:focus-within .nav-dropdown-trigger .icon-chevron { transform: rotate(180deg); }
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 280px;
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-md);
  padding: var(--space-2);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-out),
              visibility 0s linear var(--duration-base);
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition-delay: 0s;
}
.nav-dropdown-item {
  display: block;
  padding: 10px 12px;
  border-radius: var(--radius-btn);
  font-size: var(--fs-sm);
  color: var(--color-ink);
}
.nav-dropdown-item:hover { background: var(--color-bg-soft); color: var(--color-accent); }
.nav-dropdown-item-meta {
  display: block;
  font-size: var(--fs-xs);
  color: var(--color-ink-soft);
  margin-top: 2px;
}

.nav-phone {
  display: none;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-ink);
  padding: 8px 10px;
  border-radius: var(--radius-btn);
}
.nav-phone:hover { color: var(--color-accent); }
.nav-phone .icon { width: 16px; height: 16px; color: var(--color-accent); }
@media (min-width: 1100px) { .nav-phone { display: inline-flex; } }

.header-actions { display: flex; align-items: center; gap: var(--space-2); }

.burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-btn);
  color: var(--color-ink-strong);
}
.burger:hover { background: var(--color-bg-soft); }
@media (min-width: 1024px) { .burger { display: none; } }

/* Drawer mobile */
.mobile-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--z-drawer);
  pointer-events: none;
}
.mobile-drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.4);
  opacity: 0;
  transition: opacity var(--duration-base) var(--ease-out);
}
.mobile-drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(360px, 90vw);
  background: #fff;
  box-shadow: var(--shadow-lg);
  transform: translateX(100%);
  transition: transform var(--duration-slow) var(--ease-out);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.mobile-drawer.is-open { pointer-events: auto; }
.mobile-drawer.is-open .mobile-drawer-backdrop { opacity: 1; }
.mobile-drawer.is-open .mobile-drawer-panel { transform: translateX(0); }
.mobile-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-line);
}
.mobile-drawer-body { padding: var(--space-5) var(--space-6); display: flex; flex-direction: column; gap: 2px; flex: 1; }
.mobile-drawer-body a {
  padding: 12px 6px;
  font-size: var(--fs-md);
  font-weight: 500;
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-line);
}
.mobile-drawer-body a:last-child { border-bottom: 0; }
.mobile-drawer-footer { padding: var(--space-5) var(--space-6); border-top: 1px solid var(--color-line); display: flex; flex-direction: column; gap: var(--space-3); }
body.no-scroll { overflow: hidden; }

/* =========================================================================
   9. Hero
   ========================================================================= */
.hero {
  position: relative;
  padding-block: clamp(72px, 10vw, 160px) clamp(56px, 7vw, 112px);
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-9);
  align-items: center;
}
@media (min-width: 1024px) {
  .hero-grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-11); }
}
.hero-title {
  font-size: var(--fs-h1);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--color-ink-strong);
  text-wrap: balance;
}
.hero-subtitle {
  margin-top: var(--space-5);
  font-size: var(--fs-md);
  color: var(--color-ink-soft);
  line-height: 1.55;
  max-width: 54ch;
}
.hero-actions { margin-top: var(--space-7); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero-trust {
  margin-top: var(--space-7);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  font-size: var(--fs-sm);
  color: var(--color-ink-soft);
}
.hero-trust-item { display: inline-flex; align-items: center; gap: 8px; }
.hero-trust-item .icon { color: var(--color-success); width: 16px; height: 16px; }

.hero-visual {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 5/6;
  background: var(--color-bg-mute);
  box-shadow: var(--shadow-lg);
}
.hero-visual img { width: 100%; height: 100%; object-fit: cover; }
.hero-floating-card {
  position: absolute;
  left: 20px;
  bottom: 20px;
  right: 20px;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(8px);
  border-radius: var(--radius-card);
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  box-shadow: var(--shadow-md);
}
.hero-floating-card .icon { width: 22px; height: 22px; color: var(--color-success); }
.hero-floating-card-title { font-weight: 600; color: var(--color-ink-strong); font-size: var(--fs-sm); }
.hero-floating-card-text  { font-size: var(--fs-xs); color: var(--color-ink-soft); }

/* SplitText wrapper */
.word { display: inline-block; overflow: hidden; line-height: 1; padding-bottom: 0.06em; vertical-align: top; }
.word-inner { display: inline-block; transform: translateY(100%); will-change: transform; }
.no-js .word-inner { transform: none; }

/* =========================================================================
   10. Sections génériques
   ========================================================================= */
.section-head {
  max-width: 720px;
  margin-bottom: var(--space-9);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.section-head.is-center { margin-inline: auto; text-align: center; align-items: center; }
.section-head h2 { letter-spacing: -0.02em; }
.section-head p { color: var(--color-ink-soft); font-size: var(--fs-md); line-height: 1.55; }

/* =========================================================================
   11. Cards (services / generic)
   ========================================================================= */
.card {
  background: var(--surface-card);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: transform var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}
.card:hover {
  transform: translateY(-4px);
  border-color: var(--color-accent);
  box-shadow: var(--shadow-md);
}
.card-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-btn);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-accent-soft);
  color: var(--color-accent);
}
.card-icon-wrap .icon { width: 22px; height: 22px; }
.card-title {
  font-size: var(--fs-h5);
  font-weight: 600;
  color: var(--color-ink-strong);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.card-text { color: var(--color-ink-soft); font-size: var(--fs-sm); line-height: 1.6; }
.card-benefit {
  margin-top: auto;
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--color-success);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.card-link {
  margin-top: var(--space-2);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-accent);
}
.card-link .icon { width: 16px; height: 16px; transition: transform var(--duration-base) var(--ease-out); }
.card:hover .card-link .icon { transform: translateX(3px); }

.card-urgence {
  background: var(--color-urgence-soft);
  border-color: transparent;
}
.card-urgence .card-icon-wrap {
  background: rgba(220,38,38,0.12);
  color: var(--color-urgence);
}

/* Stat blocks */
.stat-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
@media (min-width: 720px) { .stat-row { grid-template-columns: repeat(4, 1fr); gap: var(--space-7); } }
.stat-block {
  padding: var(--space-5);
  border-radius: var(--radius-card);
  background: #fff;
  border: 1px solid var(--color-line);
}
.stat-value {
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--color-ink-strong);
  line-height: 1;
}
.stat-label {
  margin-top: var(--space-2);
  font-size: var(--fs-sm);
  color: var(--color-ink-soft);
}

/* Timeline méthode */
.method-track {
  display: grid;
  gap: var(--space-4);
  counter-reset: step;
}
@media (min-width: 1024px) { .method-track { grid-template-columns: repeat(5, 1fr); } }
.method-step {
  position: relative;
  padding: var(--space-6);
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  counter-increment: step;
}
.method-step::before {
  content: counter(step, decimal-leading-zero);
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--color-accent);
  font-weight: 600;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-4);
}
.method-step h3 { font-size: var(--fs-md); margin-bottom: 6px; }
.method-step p { font-size: var(--fs-sm); color: var(--color-ink-soft); line-height: 1.55; }

/* =========================================================================
   12. Forms
   ========================================================================= */
.form-stack { display: flex; flex-direction: column; gap: var(--space-5); }
.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-ink-strong);
}
.field-hint { font-size: var(--fs-xs); color: var(--color-ink-soft); }
.field-error { font-size: var(--fs-xs); color: var(--color-urgence); margin-top: 4px; }
.input,
.textarea,
.select {
  width: 100%;
  height: 52px;
  padding: 0 16px;
  background: #fff;
  border: 1px solid var(--color-line-strong);
  border-radius: var(--radius-btn);
  color: var(--color-ink-strong);
  font-size: var(--fs-base);
  transition: border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}
.textarea { height: auto; min-height: 140px; padding: 14px 16px; line-height: 1.5; resize: vertical; }
.input:hover, .textarea:hover, .select:hover { border-color: var(--color-ink-soft); }
.input:focus, .textarea:focus, .select:focus {
  border-color: var(--color-accent);
  outline: 0;
  box-shadow: 0 0 0 4px var(--color-accent-soft);
}
.input::placeholder, .textarea::placeholder { color: #9ca3af; }
.field.has-error .input,
.field.has-error .textarea,
.field.has-error .select { border-color: var(--color-urgence); }
.field.has-error .input:focus,
.field.has-error .textarea:focus { box-shadow: 0 0 0 4px var(--color-urgence-soft); }

.checkbox, .radio {
  display: inline-flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: var(--fs-sm);
  line-height: 1.45;
}
.checkbox input, .radio input { margin-top: 3px; accent-color: var(--color-accent); width: 16px; height: 16px; }

.field-honeypot {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Choice tiles (urgence, type, etc.) */
.choice-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
@media (min-width: 720px) { .choice-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .choice-grid-3 { grid-template-columns: repeat(3, 1fr); } }
.choice-tile {
  position: relative;
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  padding: var(--space-5);
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  cursor: pointer;
  transition: border-color var(--duration-base) var(--ease-out), background-color var(--duration-base) var(--ease-out);
}
.choice-tile input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.choice-tile-title { font-weight: 600; color: var(--color-ink-strong); margin-bottom: 4px; }
.choice-tile-text { font-size: var(--fs-sm); color: var(--color-ink-soft); line-height: 1.5; }
.choice-tile:hover { border-color: var(--color-accent); }
.choice-tile input:checked ~ .choice-tile-body { color: var(--color-accent); }
.choice-tile:has(input:checked) {
  border-color: var(--color-accent);
  background: var(--color-accent-soft);
}
.choice-tile-icon { width: 22px; height: 22px; color: var(--color-accent); flex: 0 0 22px; }

/* Stepper form */
.devis-stepper {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-modal);
  padding: clamp(20px, 3vw, 36px);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.stepper-progress {
  height: 4px;
  background: var(--color-bg-mute);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: var(--space-6);
}
.stepper-progress-bar {
  height: 100%;
  background: var(--color-accent);
  border-radius: 999px;
  transition: width var(--duration-slow) var(--ease-out);
  width: 25%;
}
.stepper-steps {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--space-7);
  gap: var(--space-2);
  flex-wrap: wrap;
}
.stepper-step {
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.stepper-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid var(--color-line-strong);
  font-size: 11px;
  font-weight: 600;
}
.stepper-step.is-current { color: var(--color-accent); }
.stepper-step.is-current .stepper-step-num { background: var(--color-accent); border-color: var(--color-accent); color: #fff; }
.stepper-step.is-done .stepper-step-num { background: var(--color-success); border-color: var(--color-success); color: #fff; }

.stepper-viewport { overflow: hidden; }
.stepper-track {
  display: flex;
  width: 400%;
  transform: translateX(0%);
  transition: transform var(--duration-slow) var(--ease-out);
}
.stepper-pane { width: 25%; flex: 0 0 25%; padding-right: var(--space-4); }
.stepper-actions {
  display: flex;
  justify-content: space-between;
  margin-top: var(--space-7);
  gap: var(--space-3);
  flex-wrap: wrap;
}
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25%       { transform: translateX(-8px); }
  75%       { transform: translateX(8px); }
}
.shake { animation: shake 0.4s var(--ease-io); }

/* Dropzone */
.dropzone {
  border: 1px dashed var(--color-line-strong);
  border-radius: var(--radius-card);
  padding: var(--space-7);
  text-align: center;
  background: var(--color-bg-soft);
  color: var(--color-ink-soft);
  cursor: pointer;
  transition: border-color var(--duration-base) var(--ease-out), background-color var(--duration-base) var(--ease-out);
}
.dropzone:hover, .dropzone.is-drag-over { border-color: var(--color-accent); background: var(--color-accent-soft); color: var(--color-accent); }
.dropzone .icon { width: 28px; height: 28px; margin-inline: auto; margin-bottom: var(--space-2); }
.dropzone-previews {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.dropzone-thumb {
  position: relative;
  aspect-ratio: 1/1;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-bg-mute);
}
.dropzone-thumb img { width: 100%; height: 100%; object-fit: cover; }
.dropzone-thumb-remove {
  position: absolute; top: 4px; right: 4px;
  width: 22px; height: 22px;
  border-radius: 999px;
  background: rgba(0,0,0,0.6);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}
.dropzone-thumb-remove .icon { width: 14px; height: 14px; }

/* =========================================================================
   13. Gallery
   ========================================================================= */
.gallery-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-7);
}
.gallery-filter {
  font-size: var(--fs-sm);
  padding: 8px 14px;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: #fff;
  color: var(--color-ink);
  transition: border-color var(--duration-base) var(--ease-out), color var(--duration-base) var(--ease-out), background-color var(--duration-base) var(--ease-out);
}
.gallery-filter:hover { border-color: var(--color-ink-strong); }
.gallery-filter.is-active { background: var(--color-ink-strong); color: #fff; border-color: var(--color-ink-strong); }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}
.gallery-item {
  position: relative;
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--color-bg-mute);
  aspect-ratio: 4/3;
  cursor: zoom-in;
  transition: transform var(--duration-base) var(--ease-out);
}
.gallery-item:hover { transform: scale(1.01); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--duration-slow) var(--ease-out); }
.gallery-item:hover img { transform: scale(1.04); }
.gallery-item-meta {
  position: absolute;
  inset: auto 0 0 0;
  padding: var(--space-5) var(--space-4) var(--space-4);
  background: linear-gradient(180deg, rgba(15,23,42,0) 0%, rgba(15,23,42,0.72) 100%);
  color: #fff;
}
.gallery-item-title { font-weight: 600; font-size: var(--fs-sm); }
.gallery-item-sub { font-size: var(--fs-xs); opacity: 0.85; }

/* Lightbox */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  background: rgba(15,23,42,0.92);
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--duration-base) var(--ease-out);
}
.lightbox.is-open { display: flex; opacity: 1; }
.lightbox-content {
  position: relative;
  max-width: 92vw;
  max-height: 88vh;
  transform: scale(0.96);
  transition: transform var(--duration-base) var(--ease-out);
}
.lightbox.is-open .lightbox-content { transform: scale(1); }
.lightbox-img { max-width: 92vw; max-height: 88vh; border-radius: var(--radius-card); display: block; }
.lightbox-close,
.lightbox-prev,
.lightbox-next {
  position: absolute;
  background: rgba(255,255,255,0.12);
  color: #fff;
  width: 44px; height: 44px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  backdrop-filter: blur(6px);
  transition: background-color var(--duration-base) var(--ease-out);
}
.lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover { background: rgba(255,255,255,0.25); }
.lightbox-close { top: -56px; right: 0; }
.lightbox-prev  { top: 50%; left: -56px; transform: translateY(-50%); }
.lightbox-next  { top: 50%; right: -56px; transform: translateY(-50%); }
@media (max-width: 800px) {
  .lightbox-close { top: 12px; right: 12px; }
  .lightbox-prev  { top: auto; bottom: 12px; left: 12px; transform: none; }
  .lightbox-next  { top: auto; bottom: 12px; right: 12px; transform: none; }
}

/* Before / After */
.ba-slider {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-card);
  user-select: none;
  touch-action: pan-y;
  aspect-ratio: 4/3;
  background: var(--color-bg-mute);
}
.ba-slider img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.ba-after { clip-path: inset(0 50% 0 0); }
.ba-handle {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 3px;
  background: #fff;
  transform: translateX(-50%);
  pointer-events: none;
}
.ba-handle::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 44px; height: 44px;
  margin: -22px 0 0 -22px;
  background: #fff;
  border-radius: 999px;
  box-shadow: var(--shadow-md);
  pointer-events: auto;
}
.ba-handle::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 16px; height: 16px;
  margin: -8px 0 0 -8px;
  border-left: 2px solid var(--color-ink-strong);
  border-right: 2px solid var(--color-ink-strong);
}
.ba-input {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  opacity: 0;
  cursor: ew-resize;
  z-index: 2;
}
.ba-input:focus-visible + .ba-handle::before { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.ba-label {
  position: absolute;
  top: 12px;
  font-size: var(--fs-xs);
  font-weight: 500;
  padding: 4px 10px;
  background: rgba(15,23,42,0.7);
  color: #fff;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ba-label-before { left: 12px; }
.ba-label-after  { right: 12px; }

/* =========================================================================
   14. Testimonials
   ========================================================================= */
.testimonial-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 720px)  { .testimonial-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .testimonial-grid { grid-template-columns: repeat(3, 1fr); } }
.testimonial-card {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.testimonial-rating { display: inline-flex; gap: 2px; color: var(--color-warning); }
.testimonial-rating .icon { width: 16px; height: 16px; }
.testimonial-quote {
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--color-ink-strong);
  font-weight: 400;
}
.testimonial-author {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-ink-strong);
}
.testimonial-meta { font-size: var(--fs-xs); color: var(--color-ink-soft); }

/* =========================================================================
   15. FAQ accordéon
   ========================================================================= */
.faq-list { display: flex; flex-direction: column; gap: var(--space-2); }
.faq-item {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  transition: border-color var(--duration-base) var(--ease-out);
  overflow: hidden;
}
.faq-item[open] { border-color: var(--color-line-strong); }
.faq-summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  font-weight: 500;
  color: var(--color-ink-strong);
}
.faq-summary::-webkit-details-marker { display: none; }
.faq-summary .icon { width: 18px; height: 18px; color: var(--color-ink-soft); transition: transform var(--duration-base) var(--ease-out); flex: 0 0 18px; }
.faq-item[open] .faq-summary .icon { transform: rotate(180deg); }
.faq-body {
  padding: 0 var(--space-5) var(--space-5);
  color: var(--color-ink-soft);
  line-height: 1.65;
  font-size: var(--fs-sm);
}

/* =========================================================================
   16. Final CTA banner
   ========================================================================= */
.cta-banner {
  position: relative;
  border-radius: 24px;
  background: var(--color-ink-strong);
  color: #fff;
  padding: clamp(40px, 6vw, 80px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  align-items: flex-start;
}
.cta-banner::before {
  content: '';
  position: absolute;
  inset: -50%;
  background: radial-gradient(circle at 20% 20%, rgba(37,99,235,0.45), transparent 50%);
  pointer-events: none;
}
.cta-banner > * { position: relative; }
.cta-banner h2 { color: #fff; max-width: 24ch; }
.cta-banner p  { color: rgba(255,255,255,0.78); max-width: 56ch; font-size: var(--fs-md); }

/* =========================================================================
   17. Footer
   ========================================================================= */
.site-footer {
  border-top: 1px solid var(--color-line);
  background: var(--color-white);
  padding-block: clamp(56px, 6vw, 96px) var(--space-8);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 720px)  { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.footer-brand { display: flex; flex-direction: column; gap: var(--space-4); max-width: 320px; }
.footer-brand p { color: var(--color-ink-soft); font-size: var(--fs-sm); line-height: 1.6; }
.footer-coords { display: flex; flex-direction: column; gap: var(--space-2); font-size: var(--fs-sm); }
.footer-coords a { color: var(--color-ink); display: inline-flex; align-items: center; gap: 8px; }
.footer-coords a:hover { color: var(--color-accent); }
.footer-coords .icon { width: 16px; height: 16px; color: var(--color-ink-soft); }

.footer-col-title {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-3);
  font-weight: 600;
}
.footer-list { display: flex; flex-direction: column; gap: var(--space-2); font-size: var(--fs-sm); }
.footer-list a { color: var(--color-ink); transition: color var(--duration-base) var(--ease-out); }
.footer-list a:hover { color: var(--color-accent); }

.footer-bottom {
  margin-top: var(--space-9);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: space-between;
  align-items: center;
  font-size: var(--fs-xs);
  color: var(--color-ink-soft);
}
.footer-social { display: flex; gap: var(--space-2); }
.footer-social a {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--color-line);
  color: var(--color-ink);
  transition: color var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);
}
.footer-social a:hover { color: var(--color-accent); border-color: var(--color-accent); }
.footer-social .icon { width: 16px; height: 16px; }

/* =========================================================================
   18. Floating urgence
   ========================================================================= */
.floating-urgence {
  position: fixed;
  z-index: var(--z-floating);
  right: max(20px, env(safe-area-inset-right));
  bottom: max(20px, env(safe-area-inset-bottom));
  display: flex;
  flex-direction: column;
  gap: 10px;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 600ms var(--ease-out), transform 600ms var(--ease-out);
}
@media (max-width: 640px) {
  .floating-urgence {
    right: max(12px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
  }
}
.floating-urgence.is-visible { opacity: 1; transform: translateY(0); }
.floating-urgence-cta {
  min-height: 52px;
  padding: 0 22px;
  border-radius: 999px;
  background: var(--color-urgence);
  color: #fff;
  font-weight: 600;
  font-size: var(--fs-sm);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-shadow: var(--shadow-urgence);
  text-decoration: none;
  transition: background-color var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
}
.floating-urgence-cta:hover { background: var(--color-urgence-hover); transform: translateY(-2px); }
.floating-urgence-cta .icon { width: 20px; height: 20px; }
.floating-urgence-secondary {
  align-self: flex-end;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--color-line);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--color-ink);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  box-shadow: var(--shadow-sm);
}
.floating-urgence-secondary .icon { width: 16px; height: 16px; color: #25d366; }
.floating-urgence-secondary:hover { border-color: var(--color-ink-strong); }
body.page-urgence .floating-urgence { display: none; }
@media (max-width: 720px) {
  .floating-urgence { left: 12px; right: 12px; bottom: 12px; }
  .floating-urgence-cta { width: 100%; justify-content: center; }
  .floating-urgence-secondary { width: 100%; justify-content: center; }
}

/* =========================================================================
   19. Cookie banner
   ========================================================================= */
.cookie-banner {
  position: fixed;
  z-index: var(--z-toast);
  left: 20px;
  right: 20px;
  bottom: 20px;
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-lg);
  padding: var(--space-5) var(--space-6);
  display: none;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 560px;
  margin-inline: auto;
}
.cookie-banner.is-visible { display: flex; }
.cookie-banner-title { font-weight: 600; color: var(--color-ink-strong); }
.cookie-banner-text  { font-size: var(--fs-sm); color: var(--color-ink-soft); line-height: 1.55; }
.cookie-banner-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; }
@media (max-width: 720px) {
  .cookie-banner { left: 12px; right: 12px; bottom: 12px; padding: var(--space-4); }
  .cookie-banner-actions .btn { flex: 1; }
}

/* =========================================================================
   20. Reveal animations CSS de base (fallback)
   ========================================================================= */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 600ms var(--ease-out), transform 600ms var(--ease-out);
  will-change: opacity, transform;
}
[data-reveal="left"]  { transform: translateX(-24px); }
[data-reveal="right"] { transform: translateX(24px); }
[data-reveal="scale"] { transform: scale(0.96); }
[data-reveal="fade"]  { transform: none; }
[data-reveal].is-revealed,
.no-js [data-reveal] {
  opacity: 1;
  transform: none;
}

/* Page transition */
.page-transition main { opacity: 0; animation: pageIn 320ms var(--ease-out) forwards; }
@keyframes pageIn { to { opacity: 1; } }

/* =========================================================================
   21. Breadcrumbs
   ========================================================================= */
.breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  font-size: var(--fs-xs);
  color: var(--color-ink-soft);
  padding-block: var(--space-5);
}
.breadcrumbs a { color: var(--color-ink-soft); transition: color var(--duration-base) var(--ease-out); }
.breadcrumbs a:hover { color: var(--color-accent); }
.breadcrumbs .sep { opacity: 0.5; }

/* =========================================================================
   22. Utilities & misc
   ========================================================================= */
.divider-text {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  color: var(--color-ink-soft);
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.divider-text::before, .divider-text::after { content: ''; flex: 1; height: 1px; background: var(--color-line); }

.tag-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }

.alert {
  border-radius: var(--radius-card);
  padding: var(--space-4) var(--space-5);
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.alert .icon { width: 20px; height: 20px; flex: 0 0 20px; margin-top: 1px; }
.alert-info { background: var(--color-accent-soft); color: var(--color-accent); }
.alert-success { background: var(--color-success-soft); color: var(--color-success); }
.alert-warning { background: var(--color-warning-soft); color: #92400e; }
.alert-urgence { background: var(--color-urgence-soft); color: var(--color-urgence); }

.icon { display: inline-block; width: 20px; height: 20px; vertical-align: middle; flex: 0 0 auto; }
.icon svg { width: 100%; height: 100%; display: block; }

/* =========================================================================
   23. Reduced motion
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .word-inner { transform: none !important; }
  .floating-urgence { opacity: 1; transform: none; }
  .badge-pulse::before { animation: none; }
}

/* =========================================================================
   24. Signatures éditoriales — vague, photos warm, stats oldstyle, map
   ========================================================================= */

/* ----- Identité tricolore : barre rouge SOS en haut de page ----- */
body::before {
  content: '';
  display: block;
  height: 4px;
  background: var(--color-highlight);   /* rouge SOS */
  position: relative;
  z-index: var(--z-header);
}

/* Wave divider — remplacé par une fine ligne rouge (ou retiré du markup) */
.wave-divider {
  display: none;
}

/* Bande rouge fine — séparateur signature SOS entre 2 sections */
.sos-stripe {
  height: 3px;
  background: var(--color-highlight);
  margin: 0;
}
.sos-stripe-thin {
  height: 1px;
  background: var(--color-highlight);
  opacity: 0.6;
}

/* Alternance bandeaux clairs */
.section-sand,
.section-soft { background: var(--color-paper-soft); }
.section-cream { background: var(--color-paper); }
.section-blue { background: var(--color-accent); color: #fff; }
.section-blue h1, .section-blue h2, .section-blue h3, .section-blue h4 { color: #fff; }
.section-blue .lead, .section-blue p { color: rgba(255,255,255,0.88); }
.section-ink { background: var(--color-ink-strong); color: #fff; }
.section-ink h1, .section-ink h2, .section-ink h3, .section-ink h4 { color: #fff; }
.section-ink .lead, .section-ink p { color: rgba(255,255,255,0.85); }

/* Photos — léger contrast/saturation, pas de filtre warm (palette froide tricolore) */
.photo-warm img,
img.photo-warm {
  filter: saturate(1.04) contrast(1.04);
  transition: filter var(--duration-slow) var(--ease-out);
}

/* Stats — gros chiffres Inter bold, soulignés d'un trait rouge */
.stat-editorial { display: flex; flex-direction: column; gap: var(--space-2); }
.stat-editorial-value {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: clamp(3rem, 5vw + 1rem, 5.25rem);
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--color-ink-strong);
  font-variant-numeric: tabular-nums;
  position: relative;
  display: inline-block;
}
.stat-editorial-value::after {
  content: '';
  display: block;
  width: 32px;
  height: 3px;
  background: var(--color-highlight);
  margin-top: var(--space-2);
}
.stat-editorial-label {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-ink-soft);
  font-weight: 500;
}

/* Stats inline (hero) — tabulaires, séparateurs rouges */
.stats-inline {
  display: flex; align-items: baseline; flex-wrap: wrap;
  gap: var(--space-4) var(--space-6);
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-sm);
  letter-spacing: 0.02em;
  color: var(--color-ink-soft);
}
.stats-inline strong {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-lg);
  color: var(--color-ink-strong);
  margin-right: 6px;
  letter-spacing: -0.02em;
}
.stats-inline .stat-sep {
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--color-highlight);
  border-radius: 50%;
  margin: 0 var(--space-2);
  vertical-align: middle;
}

/* Eyebrow — petite étiquette rouge, sobre */
.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-highlight);
  display: inline-flex; align-items: center; gap: var(--space-2);
}
.eyebrow::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 2px;
  background: currentColor;
}

/* Pull-quote — citation accentuée d'une barre rouge épaisse */
.pull-quote {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: clamp(1.5rem, 2vw + 0.6rem, 2.25rem);
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--color-ink-strong);
  border-left: 4px solid var(--color-highlight);
  padding-left: var(--space-6);
  margin: var(--space-7) 0;
  max-width: 64ch;
}
.pull-quote em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-highlight);
  font-weight: 500;
}
.pull-quote-source {
  display: block;
  margin-top: var(--space-4);
  font-family: var(--font-sans);
  font-style: normal;
  font-weight: 500;
  font-size: var(--fs-sm);
  color: var(--color-ink-soft);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pull-quote-source::before { content: '— '; }

/* Buttons — primary rouge SOS, secondary outline bleu marine */
.btn-primary,
button.btn-primary {
  background: var(--color-highlight);
  color: #fff;
  border-radius: var(--radius-btn);
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: var(--shadow-red);
  transition: background var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
}
.btn-primary:hover {
  background: var(--color-highlight-hover);
  transform: translateY(-1px);
  box-shadow: var(--shadow-urgence);
}
.btn-secondary {
  background: transparent;
  color: var(--color-accent);
  border: 1.5px solid var(--color-accent);
  border-radius: var(--radius-btn);
  font-weight: 600;
  transition: background var(--duration-base) var(--ease-out), color var(--duration-base) var(--ease-out);
}
.btn-secondary:hover {
  background: var(--color-accent);
  color: #fff;
}
.btn-urgence {
  background: var(--color-urgence);
  color: #fff;
  font-weight: 700;
  box-shadow: var(--shadow-urgence);
  position: relative;
  overflow: hidden;
}
.btn-urgence::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.18) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform 0.8s var(--ease-out);
}
.btn-urgence:hover::before { transform: translateX(100%); }
.btn-urgence:hover { background: var(--color-urgence-hover); }

/* Cards — fond blanc, bordure gris léger, hover bord bleu marine */
.card, .card-service, .card-feature, .card-benefit {
  background: var(--surface-card);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  transition: border-color var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
}
.card:hover, .card-service:hover, .card-feature:hover, .card-benefit:hover {
  border-color: var(--color-accent);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

/* Header — blanc avec base bleu marine au scroll, accent rouge sur CTA */
.site-header {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(14px) saturate(1.4);
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
  background: rgba(255, 255, 255, 0.98);
  border-bottom-color: var(--color-line);
  box-shadow: 0 1px 0 rgba(0,47,108,0.04);
}

/* Logo wordmark — SOS rouge, "Toiture Martinique" bleu marine */
.logo {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--font-sans);
  letter-spacing: -0.02em;
}
.logo-sos {
  color: var(--color-highlight);
  font-family: var(--font-sans);
  font-weight: 800;
  letter-spacing: 0.02em;
  font-size: 1.1em;
}
.logo-rest {
  color: var(--color-accent);
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* Hero — fond blanc avec halos subtils bleu marine + rouge */
.hero {
  position: relative;
  background:
    radial-gradient(ellipse 80% 50% at 90% -10%, rgba(220,38,38,0.06), transparent 60%),
    radial-gradient(ellipse 70% 50% at -10% 110%, rgba(0,47,108,0.06), transparent 55%),
    #FFFFFF;
  border-bottom: 1px solid var(--color-line);
}
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,47,108,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,47,108,0.025) 1px, transparent 1px);
  background-size: 56px 56px;
  background-position: -1px -1px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse 60% 60% at 50% 40%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 60% 60% at 50% 40%, #000 30%, transparent 80%);
}
.hero > .container { position: relative; z-index: 1; }

.hero-title {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(2.5rem, 5vw + 1rem, 4.75rem);
  letter-spacing: -0.04em;
  line-height: 0.98;
  color: var(--color-ink-strong);
}
.hero-title em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--color-highlight);
  letter-spacing: -0.02em;
  font-variation-settings: 'opsz' 144, 'SOFT' 50;
}
.hero-title b, .hero-title strong {
  color: var(--color-highlight);
  font-weight: 800;
}
.hero-subtitle {
  font-family: var(--font-sans);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(1.05rem, 0.8vw + 0.9rem, 1.25rem);
  color: var(--color-ink-soft);
  max-width: 54ch;
  line-height: 1.5;
  margin-top: var(--space-5);
}
.hero-visual {
  border-radius: 8px;
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-lg);
}
.hero-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,47,108,0) 60%, rgba(0,47,108,0.10) 100%);
  pointer-events: none;
}

/* Card flottante sur hero */
.hero-floating-card {
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid var(--color-line);
  backdrop-filter: blur(12px);
}
.hero-floating-card .icon { color: var(--color-highlight); }
.hero-floating-card-title { font-family: var(--font-sans); }

/* Floating urgence — rouge plus marqué + WhatsApp en blanc bordure bleu marine */
.floating-urgence-main {
  background: var(--color-urgence);
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: var(--shadow-urgence);
}
.floating-urgence-secondary {
  background: #fff;
  border: 1.5px solid var(--color-accent);
  color: var(--color-accent);
  font-weight: 600;
}

/* Footer — fond clair (gris bleuté), accent rouge SOS au sommet */
.site-footer {
  background: var(--color-paper-soft);  /* #F8F9FB — gris très clair bleuté */
  color: var(--color-ink-soft);
  position: relative;
  border-top: 1px solid var(--color-line);
}
.site-footer::before {
  content: '';
  display: block;
  height: 3px;
  background: var(--color-highlight); /* signature rouge SOS en haut du footer */
}
.site-footer h3, .site-footer h4, .site-footer .footer-title {
  color: var(--color-ink-strong);
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.01em;
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: 0.10em;
}
.site-footer a {
  color: var(--color-ink-soft);
  transition: color var(--duration-base) var(--ease-out);
}
.site-footer a:hover {
  color: var(--color-highlight);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1.5px;
}
.site-footer .footer-bottom {
  border-top: 1px solid var(--color-line);
  color: var(--color-ink-soft);
}
.site-footer .footer-logo .logo-sos { color: var(--color-highlight); }
.site-footer .footer-logo .logo-rest { color: var(--color-ink-strong); }

/* Liens accent — soulignement rouge subtil */
.content a:not(.btn):not(.logo):not(.no-underline) {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-color: var(--color-highlight);
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
}
.content a:not(.btn):not(.logo):not(.no-underline):hover {
  text-decoration-thickness: 2.5px;
}

/* Cocarde SOS — petit badge rouge décoratif (utilisable près du logo, headings, etc.) */
.sos-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--color-highlight);
  color: #fff;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 4px;
}
.sos-badge::before {
  content: '';
  width: 6px; height: 6px;
  background: #fff;
  border-radius: 50%;
}

/* Tricolore inline — petite décoration trois bandes verticales */
.tricolore-inline {
  display: inline-flex;
  height: 14px;
  border-radius: 2px;
  overflow: hidden;
  vertical-align: middle;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}
.tricolore-inline span {
  display: block;
  width: 8px;
  height: 100%;
}
.tricolore-inline span:nth-child(1) { background: var(--color-accent); }
.tricolore-inline span:nth-child(2) { background: #fff; }
.tricolore-inline span:nth-child(3) { background: var(--color-highlight); }

/* Drapeau Martinique (CTM 2023) — 3 bandes horizontales rouge / vert / noir */
.martinique-inline {
  display: inline-flex;
  flex-direction: column;
  height: 14px;
  width: 22px;
  border-radius: 2px;
  overflow: hidden;
  vertical-align: middle;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}
.martinique-inline span {
  display: block;
  width: 100%;
  flex: 1;
}
.martinique-inline span:nth-child(1) { background: #CC0000; }
.martinique-inline span:nth-child(2) { background: #008542; }
.martinique-inline span:nth-child(3) { background: #000000; }

/* Carte Martinique stylisée */
.martinique-map {
  position: relative;
  width: 100%;
  max-width: 540px;
  aspect-ratio: 4 / 5;
  margin: 0 auto;
}
.martinique-map svg.silhouette {
  width: 100%; height: 100%;
  fill: var(--color-bg-soft);
  stroke: var(--color-accent);
  stroke-width: 1.5;
  filter: drop-shadow(0 8px 20px rgba(0,47,108,0.12));
}
.commune-dot {
  position: absolute;
  width: 10px; height: 10px;
  background: var(--color-highlight);
  border: 2px solid #fff;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  cursor: pointer;
  transition: transform var(--duration-base) var(--ease-out), background var(--duration-base) var(--ease-out);
  z-index: 2;
}
.commune-dot:hover, .commune-dot:focus-visible {
  transform: translate(-50%, -50%) scale(1.6);
  background: var(--color-accent);
  outline: none;
}
.commune-dot-label {
  position: absolute;
  white-space: nowrap;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  background: var(--color-ink-strong);
  color: #fff;
  padding: 4px 8px;
  border-radius: 4px;
  transform: translate(-50%, -135%);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease-out);
  z-index: 3;
}
.commune-dot:hover + .commune-dot-label,
.commune-dot:focus-visible + .commune-dot-label { opacity: 1; }

::selection { background: var(--color-highlight); color: #fff; }

body { font-feature-settings: 'ss01' on, 'cv11' on; }
strong, b { font-weight: 700; color: var(--color-ink-strong); }
em, i { font-style: italic; }

/* =========================================================================
   25. SOS push — bandeau astreinte, stats rouges, CTA rouge, pulse urgence
   ========================================================================= */

/* Bandeau astreinte 24/7 — sous la barre rouge SOS en top de page */
.sos-bar {
  background: var(--color-ink-strong);
  color: #fff;
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 10px 0;
  position: relative;
  z-index: var(--z-header);
}
.sos-bar .container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.sos-bar a {
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  border-bottom: 1.5px solid var(--color-highlight);
  padding-bottom: 1px;
  transition: color var(--duration-base) var(--ease-out);
}
.sos-bar a:hover { color: var(--color-highlight); }
.sos-bar .live-dot {
  display: inline-block;
  width: 8px; height: 8px;
  background: var(--color-highlight);
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
  animation: sos-pulse-dot 1.6s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(220,38,38,0.6);
}
@keyframes sos-pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220,38,38,0.6); }
  50%      { box-shadow: 0 0 0 6px rgba(220,38,38,0); }
}
@media (max-width: 640px) {
  .sos-bar { font-size: var(--fs-xs); padding: 8px 0; }
  .sos-bar .hide-mobile { display: none; }
}

/* Stats — chiffres en rouge SOS dominant, version big-impact */
.stat-sos {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-5) 0;
}
.stat-sos-value {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(2.75rem, 4.5vw + 1rem, 4.5rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
  color: var(--color-highlight);
  font-variant-numeric: tabular-nums;
}
.stat-sos-label {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-ink-soft);
  font-weight: 600;
}
.stat-sos-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  border-block: 1px solid var(--color-line);
  padding: var(--space-7) 0;
}
@media (min-width: 768px) {
  .stat-sos-row { grid-template-columns: repeat(4, 1fr); }
  .stat-sos-row > .stat-sos + .stat-sos {
    border-left: 1px solid var(--color-line);
    padding-left: var(--space-6);
  }
}

/* CTA section rouge plein — gros bloc avant footer */
.section-cta-sos {
  background:
    radial-gradient(circle at 100% 0%, rgba(255,255,255,0.08), transparent 50%),
    radial-gradient(circle at 0% 100%, rgba(0,0,0,0.10), transparent 50%),
    var(--color-highlight);
  color: #fff;
  padding-block: clamp(64px, 8vw, 112px);
  position: relative;
  overflow: hidden;
}
.section-cta-sos::before {
  content: 'SOS';
  position: absolute;
  bottom: -3rem;
  right: -1rem;
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(8rem, 24vw, 22rem);
  line-height: 1;
  color: rgba(255,255,255,0.08);
  letter-spacing: -0.06em;
  pointer-events: none;
}
.section-cta-sos .container {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
}
@media (min-width: 768px) {
  .section-cta-sos .container { grid-template-columns: 1.5fr 1fr; }
}
.section-cta-sos h2 {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(2rem, 3.5vw + 0.5rem, 3.5rem);
  letter-spacing: -0.035em;
  line-height: 1.02;
  color: #fff;
  margin: 0;
}
.section-cta-sos h2 em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
}
.section-cta-sos p {
  margin-top: var(--space-4);
  font-size: var(--fs-md);
  color: rgba(255,255,255,0.92);
  max-width: 56ch;
  line-height: 1.55;
}
.section-cta-sos .cta-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}
.section-cta-sos .btn-cta-primary {
  background: #fff;
  color: var(--color-highlight);
  padding: 18px 30px;
  border-radius: var(--radius-btn);
  font-weight: 700;
  letter-spacing: -0.01em;
  font-size: var(--fs-md);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  transition: transform var(--duration-base) var(--ease-out), background var(--duration-base) var(--ease-out);
}
.section-cta-sos .btn-cta-primary:hover {
  transform: translateY(-2px);
  background: #FFF7F7;
}
.section-cta-sos .btn-cta-ghost {
  color: #fff;
  border: 1.5px solid rgba(255,255,255,0.5);
  padding: 18px 26px;
  border-radius: var(--radius-btn);
  font-weight: 600;
  transition: background var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);
}
.section-cta-sos .btn-cta-ghost:hover {
  background: rgba(255,255,255,0.12);
  border-color: #fff;
}
.section-cta-sos .cta-phone-block {
  background: rgba(0,0,0,0.18);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  text-align: center;
  backdrop-filter: blur(4px);
}
.section-cta-sos .cta-phone-block .label {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.7);
  font-weight: 600;
}
.section-cta-sos .cta-phone-block .num {
  display: block;
  margin-top: var(--space-3);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: clamp(1.5rem, 2vw + 0.4rem, 2rem);
  color: #fff;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}

/* Service cards icons — passent en rouge SOS pour pousser la signature */
.card-service .card-icon-wrap,
.card-benefit .card-icon-wrap,
.card .card-icon-wrap {
  color: var(--color-highlight);
  background: var(--color-highlight-soft);
  border-radius: var(--radius-btn);
  padding: 10px;
  display: inline-flex;
  margin-bottom: var(--space-4);
}
.card-service:hover .card-icon-wrap,
.card-benefit:hover .card-icon-wrap,
.card:hover .card-icon-wrap {
  background: var(--color-highlight);
  color: #fff;
}

/* Floating urgence — pulse permanent sur le bouton principal */
.floating-urgence-main {
  position: relative;
}
.floating-urgence-main::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  background: var(--color-highlight);
  opacity: 0.35;
  z-index: -1;
  animation: sos-floating-pulse 2s ease-in-out infinite;
}
@keyframes sos-floating-pulse {
  0%, 100% { transform: scale(1); opacity: 0.35; }
  50%      { transform: scale(1.15); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .floating-urgence-main::before, .sos-bar .live-dot { animation: none; }
}

/* Stripe rouge horizontal réutilisable */
.sos-stripe {
  height: 3px;
  background: var(--color-highlight);
  margin: 0;
}

/* Trust strip — bandeau marron-doux sous le hero avec 4 marqueurs (signature plus assumée) */
.trust-strip {
  background: var(--color-paper-soft);
  border-block: 1px solid var(--color-line);
  padding: var(--space-5) 0;
}
.trust-strip .container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3) var(--space-5);
  align-items: center;
}
@media (min-width: 768px) {
  .trust-strip .container { grid-template-columns: repeat(4, 1fr); }
}
.trust-strip-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-ink);
}
.trust-strip-item .icon {
  color: var(--color-highlight);
  width: 22px; height: 22px;
}

/* =========================================================================
   26. v4 — hero massif + marquee + méthode numéros + bento services
   ========================================================================= */

/* ---- Hero massif (override) ---- */
.hero-massive {
  position: relative;
  padding-block: clamp(56px, 7vw, 96px) clamp(56px, 7vw, 112px);
  overflow: hidden;
  background: #fff;
  border-bottom: 1px solid var(--color-line);
}
.hero-massive::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,47,108,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,47,108,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 70% 60% at 30% 50%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 30% 50%, #000 30%, transparent 80%);
  pointer-events: none;
}
.hero-massive > .container {
  position: relative;
  z-index: 1;
}
.hero-massive .hero-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-9);
  align-items: end;
}
@media (min-width: 1024px) {
  .hero-massive .hero-row {
    grid-template-columns: 1.35fr 1fr;
    gap: var(--space-11);
  }
}
.hero-massive .hero-title-xxl {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(3rem, 7.5vw + 1rem, 7rem);
  line-height: 0.92;
  letter-spacing: -0.05em;
  color: var(--color-ink-strong);
  margin: 0;
}
.hero-massive .hero-title-xxl em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--color-highlight);
  letter-spacing: -0.02em;
  font-variation-settings: 'opsz' 144, 'SOFT' 50;
}
.hero-massive .hero-title-xxl .ink-soft {
  color: var(--color-ink-soft);
  font-weight: 600;
}
.hero-massive .hero-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-6);
}
.hero-massive .hero-subtitle {
  margin-top: var(--space-6);
  max-width: 50ch;
  font-size: clamp(1.05rem, 0.8vw + 0.9rem, 1.2rem);
  color: var(--color-ink-soft);
  line-height: 1.55;
}
.hero-massive .hero-actions {
  margin-top: var(--space-7);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.hero-massive .hero-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  isolation: isolate;
}
.hero-massive .hero-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.05);
}
.hero-massive .hero-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(140deg, rgba(0,47,108,0.10), transparent 50%, rgba(220,38,38,0.18));
  z-index: 1;
  pointer-events: none;
}
.hero-massive .hero-photo-tag {
  position: absolute;
  top: var(--space-5);
  left: var(--space-5);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.96);
  padding: 8px 12px;
  border-radius: 4px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-ink-strong);
  box-shadow: var(--shadow-sm);
}
.hero-massive .hero-photo-tag::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--color-highlight);
  border-radius: 50%;
  animation: sos-pulse-dot 1.6s ease-in-out infinite;
}
.hero-massive .hero-photo-cta {
  position: absolute;
  left: var(--space-5);
  right: var(--space-5);
  bottom: var(--space-5);
  z-index: 2;
  background: rgba(10,20,40,0.88);
  color: #fff;
  border-radius: 8px;
  padding: var(--space-4) var(--space-5);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  gap: var(--space-4);
}
.hero-massive .hero-photo-cta .icon { color: var(--color-highlight); width: 24px; height: 24px; }
.hero-massive .hero-photo-cta-text {
  flex: 1;
}
.hero-massive .hero-photo-cta-title {
  font-weight: 600;
  font-size: var(--fs-sm);
  letter-spacing: -0.01em;
}
.hero-massive .hero-photo-cta-sub {
  font-size: var(--fs-xs);
  opacity: 0.7;
  margin-top: 2px;
}
.hero-massive .hero-photo-cta-arrow {
  color: #fff;
  opacity: 0.6;
  transition: transform var(--duration-base) var(--ease-out), opacity var(--duration-base) var(--ease-out);
}
.hero-massive .hero-photo-cta:hover .hero-photo-cta-arrow {
  transform: translateX(4px);
  opacity: 1;
}

/* ---- Marquee scrolling — 34 communes ---- */
.marquee {
  background: var(--color-ink-strong);
  color: #fff;
  padding: var(--space-5) 0;
  overflow: hidden;
  position: relative;
  border-block: 1px solid rgba(255,255,255,0.04);
}
.marquee::before,
.marquee::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 64px;
  z-index: 2;
  pointer-events: none;
}
.marquee::before {
  left: 0;
  background: linear-gradient(90deg, var(--color-ink-strong), transparent);
}
.marquee::after {
  right: 0;
  background: linear-gradient(-90deg, var(--color-ink-strong), transparent);
}
.marquee-track {
  display: flex;
  width: max-content;
  gap: 0;
  animation: marquee-scroll 40s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-item {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: clamp(1.1rem, 1.2vw + 0.6rem, 1.5rem);
  letter-spacing: -0.01em;
  padding: 0 var(--space-7);
  display: inline-flex;
  align-items: center;
  gap: var(--space-7);
  white-space: nowrap;
  color: #fff;
}
.marquee-item::after {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--color-highlight);
  border-radius: 50%;
}
.marquee-item:last-child::after { display: inline-block; }
@keyframes marquee-scroll {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-50%, 0, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
}

/* ---- Section méthode — gros numéros watermark + photo + texte ---- */
.method-bold {
  background: #fff;
  padding-block: clamp(64px, 8vw, 128px);
}
.method-bold .method-step {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
  padding: var(--space-9) 0;
  border-top: 1px solid var(--color-line);
  position: relative;
}
.method-bold .method-step:first-child { border-top: 0; }
@media (min-width: 768px) {
  .method-bold .method-step {
    grid-template-columns: 1fr 1.4fr;
    gap: var(--space-10);
  }
  .method-bold .method-step:nth-child(even) {
    direction: rtl;
  }
  .method-bold .method-step:nth-child(even) > * {
    direction: ltr;
  }
}
.method-bold .method-num {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(6rem, 14vw, 13rem);
  line-height: 0.9;
  letter-spacing: -0.06em;
  color: var(--color-highlight-soft);
  -webkit-text-stroke: 1px var(--color-highlight);
  margin: 0;
}
.method-bold .method-content { max-width: 56ch; }
.method-bold .method-content h3 {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: clamp(1.5rem, 1.8vw + 0.4rem, 2.1rem);
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--color-ink-strong);
  margin: 0;
}
.method-bold .method-content p {
  margin-top: var(--space-3);
  color: var(--color-ink-soft);
  font-size: var(--fs-md);
  line-height: 1.55;
}
.method-bold .method-content .method-detail {
  margin-top: var(--space-5);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-highlight);
}

/* ---- Bento grid services — asymétrique ---- */
.bento-services {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .bento-services {
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: minmax(180px, auto);
  }
  .bento-services .bento-1 { grid-column: span 4; grid-row: span 2; }
  .bento-services .bento-2 { grid-column: span 2; }
  .bento-services .bento-3 { grid-column: span 2; }
  .bento-services .bento-4 { grid-column: span 3; }
  .bento-services .bento-5 { grid-column: span 3; }
  .bento-services .bento-6 { grid-column: span 2; }
  .bento-services .bento-7 { grid-column: span 2; }
  .bento-services .bento-8 { grid-column: span 2; }
}
.bento-card {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
}
.bento-card:hover {
  border-color: var(--color-highlight);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.bento-card.bento-feature {
  background:
    radial-gradient(circle at 100% 0%, rgba(220,38,38,0.06), transparent 50%),
    #fff;
  border-color: var(--color-line-strong);
}
.bento-card.bento-feature .bento-icon {
  background: var(--color-highlight);
  color: #fff;
}
.bento-card.bento-dark {
  background: var(--color-ink-strong);
  color: #fff;
  border-color: transparent;
}
.bento-card.bento-dark:hover { border-color: var(--color-highlight); }
.bento-card.bento-dark .bento-title { color: #fff; }
.bento-card.bento-dark .bento-text { color: rgba(255,255,255,0.7); }
.bento-card.bento-dark .bento-icon { background: rgba(255,255,255,0.1); color: var(--color-highlight); }
.bento-card .bento-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--color-highlight-soft);
  color: var(--color-highlight);
  margin-bottom: var(--space-4);
}
.bento-card.bento-1 .bento-icon { width: 56px; height: 56px; }
.bento-card .bento-title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-lg);
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-ink-strong);
  margin: 0;
}
.bento-card.bento-1 .bento-title {
  font-size: clamp(1.5rem, 1.8vw + 0.4rem, 2.1rem);
}
.bento-card .bento-text {
  margin-top: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-ink-soft);
  line-height: 1.5;
}
.bento-card.bento-1 .bento-text {
  font-size: var(--fs-md);
  max-width: 50ch;
}
.bento-card .bento-arrow {
  margin-top: var(--space-5);
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-highlight);
  font-weight: 600;
  font-size: var(--fs-sm);
  letter-spacing: 0.01em;
}
.bento-card .bento-arrow svg {
  transition: transform var(--duration-base) var(--ease-out);
}
.bento-card:hover .bento-arrow svg { transform: translateX(4px); }
.bento-card .bento-badge {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-highlight);
  padding: 4px 8px;
  background: var(--color-highlight-soft);
  border-radius: 4px;
}

/* ---- Hero page interne — variante compacte de hero-massive ---- */
.hero-page {
  position: relative;
  padding-block: clamp(48px, 6vw, 88px) clamp(40px, 5vw, 64px);
  overflow: hidden;
  background: #fff;
  border-bottom: 1px solid var(--color-line);
}
.hero-page::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,47,108,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,47,108,0.035) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 70% 70% at 30% 30%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 70% at 30% 30%, #000 30%, transparent 80%);
  pointer-events: none;
}
.hero-page > .container { position: relative; z-index: 1; }
.hero-page .hero-page-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-5);
}
.hero-page h1, .hero-page .h1 {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(2.25rem, 5vw + 0.6rem, 4.5rem);
  letter-spacing: -0.04em;
  line-height: 0.98;
  color: var(--color-ink-strong);
  margin: 0;
  max-width: 18ch;
}
.hero-page h1 em, .hero-page .h1 em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--color-highlight);
  font-variation-settings: 'opsz' 144, 'SOFT' 50;
}
.hero-page .hero-page-sub {
  margin-top: var(--space-5);
  max-width: 60ch;
  font-size: clamp(1.05rem, 0.5vw + 0.95rem, 1.2rem);
  color: var(--color-ink-soft);
  line-height: 1.55;
}
.hero-page .hero-page-actions {
  margin-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.hero-page.hero-page-urgence {
  background:
    radial-gradient(circle at 90% 10%, rgba(220,38,38,0.10), transparent 50%),
    radial-gradient(circle at 0% 100%, rgba(220,38,38,0.05), transparent 55%),
    #fff;
}
.hero-page.hero-page-urgence::before { display: none; }
.hero-page.hero-page-urgence .hero-page-meta .sos-badge {
  font-size: 0.78rem;
  padding: 6px 12px;
  letter-spacing: 0.14em;
}

/* ---- Breadcrumb refait ---- */
.crumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  color: var(--color-ink-soft);
  letter-spacing: 0.02em;
  margin-bottom: var(--space-4);
}
.crumbs a { color: var(--color-ink-soft); transition: color var(--duration-base) var(--ease-out); }
.crumbs a:hover { color: var(--color-highlight); }
.crumbs .crumbs-sep { color: var(--color-line-strong); }

/* ---- Eyebrow section avec numéro de section éditorial ---- */
.section-num {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-highlight);
  margin-bottom: var(--space-4);
}
.section-num strong {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: var(--fs-base);
  letter-spacing: -0.02em;
  color: var(--color-ink-strong);
}
.section-num::before {
  content: '';
  width: 28px;
  height: 2px;
  background: var(--color-highlight);
  display: inline-block;
}

/* =========================================================================
   27. v4.2 — Images : stats avec photo, méthode avec thumbnail, bento backdrop
   ========================================================================= */

/* Stats avec photo en haut — chaque chiffre est précédé d'une photo carrée */
.stat-sos {
  padding: 0 !important;          /* override le padding générique stat-sos */
}
.stat-sos-photo {
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  overflow: hidden;
  background: var(--color-paper-soft);
  margin-bottom: var(--space-5);
  position: relative;
  border: 1px solid var(--color-line);
}
.stat-sos-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.03);
  transition: transform var(--duration-slow) var(--ease-out);
}
.stat-sos:hover .stat-sos-photo img {
  transform: scale(1.04);
}
.stat-sos-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(10,20,40,0.18));
  pointer-events: none;
}
.stat-sos-row {
  /* override grille pour 4 cards verticales */
  gap: var(--space-7) var(--space-5) !important;
  padding: var(--space-9) 0 !important;
}
@media (min-width: 768px) {
  .stat-sos-row > .stat-sos + .stat-sos {
    border-left: 0 !important;
    padding-left: 0 !important;
  }
}

/* Méthode avec photo par étape — colonne droite quand >= 768px */
.method-bold .method-step {
  grid-template-columns: 1fr !important;
  gap: var(--space-6) !important;
}
@media (min-width: 768px) {
  .method-bold .method-step {
    grid-template-columns: 200px 1fr 1.2fr !important;
    align-items: center !important;
    gap: var(--space-8) !important;
  }
  .method-bold .method-step:nth-child(even) {
    direction: ltr;   /* annule l'inversion v4 — on revient simple */
  }
}
.method-step-photo {
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--color-line);
  position: relative;
}
.method-step-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.04);
}
.method-step-photo .photo-tag {
  position: absolute;
  bottom: var(--space-2);
  left: var(--space-2);
  background: rgba(255,255,255,0.96);
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-highlight);
}
@media (min-width: 768px) {
  .method-bold .method-num {
    font-size: clamp(5rem, 9vw, 9rem) !important;
    align-self: center;
    text-align: center;
    margin: 0 !important;
  }
}

/* Bento services — photos de fond sur cards spéciales */
.bento-card.bento-feature {
  background-image:
    linear-gradient(135deg, rgba(255,255,255,0.94) 0%, rgba(255,255,255,0.82) 60%, rgba(255,255,255,0.5) 100%),
    var(--bento-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.bento-card.bento-dark {
  background-image:
    linear-gradient(135deg, rgba(10,20,40,0.94) 0%, rgba(10,20,40,0.82) 100%),
    var(--bento-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Pull-quote — photo d'équipe en fond floutée */
.section-quote-photo {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.section-quote-photo::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--quote-bg, none);
  background-size: cover;
  background-position: center;
  filter: blur(28px) saturate(1.1) brightness(0.94);
  opacity: 0.35;
  transform: scale(1.1);
  z-index: -1;
}
.section-quote-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(248,249,251,0.7), rgba(248,249,251,0.95));
  z-index: -1;
}

/* Hero subtitle utility (used on contact + similar pages) — fix .ink-soft inline */
.hero-page h1 .ink-soft,
.hero-page-sub .ink-soft { color: var(--color-ink-soft); font-weight: 600; }

/* Reveal images sur about/contact heros : ajouter un bandeau photos en haut de la page A propos */
.about-team-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin-top: var(--space-7);
}
@media (min-width: 768px) {
  .about-team-strip { grid-template-columns: repeat(3, 1fr); }
}
.about-team-photo {
  aspect-ratio: 4 / 5;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
  background: var(--color-paper-soft);
}
.about-team-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.04);
}

/* ---- Cards services avec photo cover ---- */
.card-service-img {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: border-color var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
  text-decoration: none;
  color: inherit;
  position: relative;
}
.card-service-img:hover {
  border-color: var(--color-highlight);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.card-service-img .card-photo {
  aspect-ratio: 16 / 10;
  background: var(--color-paper-soft);
  overflow: hidden;
  position: relative;
}
.card-service-img .card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}
.card-service-img:hover .card-photo img {
  transform: scale(1.05);
}
.card-service-img .card-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 65%, rgba(10,20,40,0.20));
  pointer-events: none;
}
.card-service-img .card-photo .card-photo-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  background: var(--color-highlight);
  color: #fff;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  z-index: 1;
}
.card-service-img .card-photo .card-photo-tag {
  position: absolute;
  bottom: var(--space-3);
  left: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.96);
  padding: 5px 10px;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--color-ink-strong);
  z-index: 1;
}
.card-service-img .card-photo .card-photo-tag .icon {
  width: 12px; height: 12px;
  color: var(--color-highlight);
}
.card-service-img .card-body {
  padding: var(--space-5) var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}
.card-service-img .card-title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-lg);
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-ink-strong);
  margin: 0;
}
.card-service-img .card-text {
  font-size: var(--fs-sm);
  color: var(--color-ink-soft);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}
.card-service-img .card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.card-service-img .card-bonus {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-highlight);
}
.card-service-img .card-arrow {
  color: var(--color-highlight);
  font-size: var(--fs-sm);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.card-service-img .card-arrow svg {
  transition: transform var(--duration-base) var(--ease-out);
}
.card-service-img:hover .card-arrow svg { transform: translateX(4px); }

/* ---- Hero urgence avec photo droite ---- */
.urgence-hero-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
}
@media (min-width: 1024px) {
  .urgence-hero-row {
    grid-template-columns: 1.25fr 1fr;
    gap: var(--space-9);
  }
}
.urgence-hero-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  isolation: isolate;
}
.urgence-hero-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.06) contrast(1.05);
}
.urgence-hero-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(220,38,38,0.25), transparent 50%, rgba(10,20,40,0.30));
  z-index: 1;
}
.urgence-hero-photo .photo-overlay {
  position: absolute;
  inset: auto var(--space-4) var(--space-4) var(--space-4);
  background: rgba(10,20,40,0.92);
  border-radius: 8px;
  padding: var(--space-4) var(--space-5);
  color: #fff;
  z-index: 2;
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.urgence-hero-photo .photo-overlay .live-dot {
  display: inline-block;
  width: 10px; height: 10px;
  background: var(--color-highlight);
  border-radius: 50%;
  flex: 0 0 10px;
  animation: sos-pulse-dot 1.6s ease-in-out infinite;
}
.urgence-hero-photo .photo-overlay-text {
  flex: 1;
}
.urgence-hero-photo .photo-overlay-title {
  font-weight: 700;
  font-size: var(--fs-sm);
  letter-spacing: -0.01em;
}
.urgence-hero-photo .photo-overlay-sub {
  font-size: var(--fs-xs);
  opacity: 0.7;
  margin-top: 2px;
}

/* ---- Urgence process steps avec photos ---- */
.urgence-process-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  margin-top: var(--space-7);
}
@media (min-width: 720px)  { .urgence-process-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .urgence-process-grid { grid-template-columns: repeat(5, 1fr); } }
.urgence-step {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
}
.urgence-step:hover {
  border-color: var(--color-highlight);
  transform: translateY(-3px);
}
.urgence-step-photo {
  aspect-ratio: 4 / 3;
  background: var(--color-paper-soft);
  overflow: hidden;
  position: relative;
}
.urgence-step-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.urgence-step-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(10,20,40,0.32));
  pointer-events: none;
}
.urgence-step-num {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  width: 32px;
  height: 32px;
  background: var(--color-highlight);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.8rem;
  font-family: var(--font-sans);
  z-index: 1;
}
.urgence-step-body {
  padding: var(--space-4) var(--space-5) var(--space-5);
  flex: 1;
}
.urgence-step-title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-md);
  letter-spacing: -0.01em;
  line-height: 1.25;
  color: var(--color-ink-strong);
  margin: 0;
}
