/* ============================================================================
 * sections.css — Circuits Paris Ouest LP
 *
 * Styles scopés par section (Epic 2). Convention :
 *   - 1 bloc commenté par section (header, hero, bandeau-confiance, ...).
 *   - Classes préfixées par le nom de la section.
 *   - Mobile-first, breakpoints conformes au design system (640 / 1024).
 *   - Ne pas dupliquer les tokens : on consomme uniquement les CSS variables
 *     déclarées dans styles.css.
 * ========================================================================= */

/* ============================================================================
 * Section : Header (story 2.1)
 * ========================================================================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  height: 56px;
  transition:
    height 200ms ease,
    box-shadow 200ms ease;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--space-4);
}

.site-header--scrolled {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.site-header__brand {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1rem;
  color: var(--fg);
  letter-spacing: var(--tracking-heading);
  text-decoration: none;
  white-space: nowrap;
}

.site-header__brand:hover {
  text-decoration: none;
}

.site-header__nav {
  display: none;
}

.site-header__nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: var(--space-6);
}

.site-header__nav-list a {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--fg-secondary);
  text-decoration: none;
}

.site-header__nav-list a:hover {
  color: var(--fg);
  text-decoration: none;
}

.site-header__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.site-header__tel {
  display: none;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--fg);
  text-decoration: none;
}

.site-header__tel:hover {
  color: var(--accent);
  text-decoration: none;
}

.site-header__burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* Tap target ≥ 44px (WCAG 2.5.5 AAA / Apple HIG / Material) */
  width: 44px;
  height: 44px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: transparent;
  cursor: pointer;
}

.site-header__cta-desktop {
  display: none;
}

@media (min-width: 1024px) {
  .site-header {
    height: 72px;
  }
  .site-header--scrolled {
    height: 64px;
  }
  .site-header__nav {
    display: block;
  }
  .site-header__tel {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
  }
  .site-header__burger {
    display: none;
  }
  .site-header__cta-desktop {
    display: inline-flex;
  }
}

/* Drawer mobile */
.drawer {
  position: fixed;
  inset: 0;
  z-index: 100;
  pointer-events: none;
  visibility: hidden;
  /* Caché DOM-side quand fermé → pas d'overflow horizontal global (axe + Playwright responsive tests).
     L'animation slide est conservée via le toggle JS qui retire display:none avant translateX(0). */
  display: none;
}

.drawer--open {
  display: block;
}

.drawer__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  transition: background 250ms ease;
}

.drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 80%;
  max-width: 360px;
  background: var(--bg-elevated);
  padding: var(--space-6);
  transform: translateX(100%);
  transition: transform 300ms ease;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.drawer--open {
  pointer-events: auto;
  visibility: visible;
}

.drawer--open .drawer__overlay {
  background: rgba(0, 0, 0, 0.4);
}

.drawer--open .drawer__panel {
  transform: translateX(0);
}

.drawer__close {
  align-self: flex-end;
  /* Tap target ≥ 44px (WCAG 2.5.5 AAA) */
  width: 44px;
  height: 44px;
  font-size: 1.25rem;
}

.drawer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.drawer__list a {
  display: block;
  padding: var(--space-3) 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.125rem;
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
}

/* ============================================================================
 * Section : Hero (story 2.2 → refonte v2 Direction B, story 9.1)
 *
 * Direction B (cf research/06-da-cinema §2) :
 *   - Photo cinéma 21:9 desktop / verticale 9:16 mobile (placeholder pour
 *     l'instant — la vraie photo viendra de Bruno).
 *   - Overlay sombre garantissant contraste WCAG AA sur le H1.
 *   - Texte aligné à gauche, padding généreux.
 *   - Double CTA primary + secondary, trust markers en pied.
 *   - Ligne LED orange en bas (composant Epic 8 .led-line).
 *
 * Mobile : photo en haut, texte en dessous (stack) — gérée via le placeholder
 *   ratio 21:9 qui devient plus petit visuellement, mais structure conservée.
 * ========================================================================= */
.hero,
.hero--v2 {
  position: relative;
  overflow: hidden;
  min-height: 88vh;
  background: var(--color-graphite, #1f2326);
  padding: var(--space-16) 0 var(--space-12);
  color: var(--color-ivoire-chaud, #f5efe6);
  isolation: isolate;
}

.hero__bg {
  position: absolute;
  inset: 0;
  margin: 0;
  z-index: 0;
}

.hero__bg .placeholder,
.hero__bg-placeholder {
  width: 100%;
  height: 100%;
  border-radius: 0;
  /* texture cinéma : graphite + grain léger via background overlay */
  background:
    radial-gradient(ellipse at 30% 40%, rgba(140, 90, 60, 0.18) 0%, transparent 55%),
    linear-gradient(180deg, #2e3338 0%, #1f2326 100%);
  color: rgba(245, 239, 230, 0.45);
}

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(31, 35, 38, 0.55) 0%, rgba(31, 35, 38, 0.7) 100%);
}

.hero__content {
  position: relative;
  z-index: 2;
  max-width: 720px;
  padding-top: var(--space-16);
  padding-bottom: var(--space-8);
}

.hero__eyebrow {
  display: inline-block;
  margin-bottom: var(--space-5);
  font-family: var(--font-mono, ui-monospace, monospace);
  color: var(--color-orange-brique, #c2410c);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.8125rem;
}

.hero__title {
  font-size: var(--text-display-md);
  line-height: var(--lh-display);
  letter-spacing: var(--tracking-display);
  font-weight: 500;
  max-width: 18ch;
  margin-bottom: var(--space-6);
  color: var(--color-ivoire-chaud, #f5efe6);
  text-wrap: balance;
}

.hero__lead {
  font-size: var(--text-body-lg);
  color: rgba(245, 239, 230, 0.85);
  max-width: 560px;
  margin-bottom: var(--space-8);
}

.hero__ctas {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.hero__ctas .btn {
  width: 100%;
  justify-content: center;
}

.hero__trust-markers {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(245, 239, 230, 0.85);
}

/* === Stats hero v2 (premium éditorial cinéma) ====================== */
.hero__trust-stats {
  list-style: none;
  padding: var(--space-6) 0 0;
  margin: 0 0 var(--space-8);
  display: grid;
  grid-template-columns: auto auto auto;
  gap: var(--space-8);
  align-items: end;
  border-top: 1px solid rgba(245, 239, 230, 0.18);
}

.hero__stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.hero__stat-value {
  font-family: var(--font-serif-accent, 'Iowan Old Style', Baskerville, serif);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--color-ivoire-chaud, #f5efe6);
  font-feature-settings:
    'lnum' 1,
    'tnum' 1;
}

.hero__stat-label {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(245, 239, 230, 0.65);
  line-height: 1.4;
}

@media (max-width: 640px) {
  .hero__trust-stats {
    grid-template-columns: 1fr;
    gap: var(--space-4);
    padding-top: var(--space-4);
  }

  .hero__stat-value {
    font-size: 1.75rem;
  }
}

.hero__phone,
.hero__social-proof {
  font-size: 0.9375rem;
  color: rgba(245, 239, 230, 0.75);
  margin-bottom: var(--space-2);
}

.hero__phone a,
.hero__social-proof a {
  color: var(--color-ivoire-chaud, #f5efe6);
}

.hero__social-proof span[aria-hidden] {
  color: var(--color-orange-brique, #c2410c);
}

/* Ratio utilitaire 21:9 pour le hero v2 — défini ici localement
   (placeholder.css = zone Epic 7, on évite de la modifier). */
.placeholder-21-9 {
  aspect-ratio: 21 / 9;
}

.hero-led-line {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  z-index: 3;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--color-orange-brique, #c2410c) 20%,
    var(--color-orange-brique, #c2410c) 80%,
    transparent 100%
  );
  box-shadow: 0 0 12px rgba(194, 65, 12, 0.55);
}

@media (min-width: 768px) {
  .hero__trust-markers {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .hero,
  .hero--v2 {
    padding: var(--space-24) 0 var(--space-20);
  }
  .hero__content {
    padding-top: var(--space-20);
    padding-bottom: var(--space-12);
  }
  .hero__title {
    font-size: var(--text-display-xl);
    max-width: 22ch;
  }
  .hero__ctas {
    flex-direction: row;
  }
  .hero__ctas .btn {
    width: auto;
  }
}

/* ============================================================================
 * Section : Bandeau de confiance (story 2.3)
 * ========================================================================= */
.trust-bar {
  padding: var(--space-10) 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg-subtle);
}

.trust-bar__eyebrow {
  display: block;
  margin-bottom: var(--space-5);
  text-align: center;
}

.trust-bar__row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.trust-bar__logos {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
}

.trust-bar__logo {
  width: 96px;
  height: 48px;
  filter: grayscale(1);
}

.trust-bar__rating {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.9375rem;
  color: var(--fg-secondary);
  text-decoration: none;
}

.trust-bar__stars {
  color: var(--accent);
  letter-spacing: 0.1em;
}

@media (min-width: 1024px) {
  .trust-bar__row {
    flex-direction: row;
    justify-content: space-between;
  }
}

/* ---------------------------------------------------------------------------
 * Story 9.5 — Trust bar refonte (marquee logos + 3 stat counters)
 *
 * Marquee animation 30s linear infinite, pause on hover (WCAG 2.2.2).
 * Mask gradient pour fade aux extrémités.
 * prefers-reduced-motion : marquee statique, logos en flex-wrap centré.
 * ------------------------------------------------------------------------- */
.trust-bar--v2 {
  background: var(--color-ivoire-chaud, #f5efe6);
  padding: var(--space-10) 0;
}

.trust-bar__marquee {
  position: relative;
  overflow: hidden;
  margin: var(--space-6) 0;
  /* Fade aux extrémités */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 8%,
    black 92%,
    transparent 100%
  );
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}

.trust-bar__marquee-track {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  width: max-content;
  animation: trust-bar-marquee 30s linear infinite;
}

.trust-bar__marquee:hover .trust-bar__marquee-track,
.trust-bar__marquee:focus-within .trust-bar__marquee-track {
  animation-play-state: paused;
}

@keyframes trust-bar-marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .trust-bar__marquee {
    -webkit-mask-image: none;
    mask-image: none;
  }
  .trust-bar__marquee-track {
    animation: none;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }
}

.trust-bar__stats {
  list-style: none;
  padding: 0;
  margin: var(--space-8) 0 var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  text-align: center;
  align-items: center;
}

.trust-bar__stats .stat-counter {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.trust-bar__stats .stat-counter__value {
  font-family: var(--font-serif, 'Georgia', serif);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 500;
  color: var(--color-orange-brique, #c2410c);
  line-height: 1;
}

.trust-bar__stats .stat-counter__label {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-secondary);
}

@media (min-width: 768px) {
  .trust-bar__stats {
    flex-direction: row;
    justify-content: center;
    gap: var(--space-16);
  }
}

/* ============================================================================
 * Section : Pourquoi (story 2.4)
 * ========================================================================= */
.why {
  padding: var(--space-20) 0;
}

.why__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.why__lead {
  max-width: 640px;
  margin-bottom: var(--space-10);
  color: var(--fg-secondary);
}

.why__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

.why__pillar h3 {
  font-size: var(--text-heading-md);
  margin: var(--space-4) 0 var(--space-2);
}

@media (min-width: 1024px) {
  .why__title {
    font-size: var(--text-display-md);
  }
  .why__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-12);
  }
}

/* ---------------------------------------------------------------------------
 * Story 9.6 — Pourquoi nous v2 (layout asymétrique + 4 piliers numérotés)
 *
 * Layout asymétrique 5/7 desktop : titre/lead à gauche (sticky), 4 piliers à
 * droite en 2x2. Mobile : empilé. Numéros mono uppercase 01..04 en orange
 * brique au-dessus de chaque pilier. Icônes SVG line-art monochrome 1.25.
 * ------------------------------------------------------------------------- */
.why--v2 .why__grid-wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
}

.why--v2 .why__header {
  display: flex;
  flex-direction: column;
}

.why--v2 .why__header .why__eyebrow {
  margin-bottom: var(--space-3);
}

.why--v2 .why__header .why__title,
.why--v2 .why__header .why__lead {
  margin-bottom: var(--space-4);
}

.why--v2 .why__pillars {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

.why__pillar {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.why__number {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-orange-brique, #c2410c);
  font-weight: 500;
}

.why__icon {
  width: 32px;
  height: 32px;
  stroke: var(--color-graphite, #1f2326);
  color: var(--color-graphite, #1f2326);
  fill: none;
}

.why--v2 .why__pillar h3 {
  margin: 0;
}

.why--v2 .why__pillar p {
  margin: 0;
  color: var(--fg-secondary);
}

@media (min-width: 768px) {
  .why--v2 .why__pillars {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-10);
  }
}

@media (min-width: 1024px) {
  .why--v2 .why__grid-wrapper {
    grid-template-columns: 5fr 7fr;
    gap: var(--space-20);
    align-items: start;
  }
  .why--v2 .why__header {
    position: sticky;
    top: 120px;
  }
}

/* ============================================================================
 * Section : Offre (story 2.5)
 * ========================================================================= */
.offer {
  padding: var(--space-20) 0;
  background: var(--bg-subtle);
}

.offer__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
  max-width: 22ch;
}

.offer__lead {
  max-width: 720px;
  margin-bottom: var(--space-10);
  color: var(--fg-secondary);
}

.offer__columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-12);
}

.offer__col {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.offer__col h3 {
  font-size: var(--text-heading-md);
  margin-bottom: var(--space-3);
}

.offer__concret {
  margin-bottom: var(--space-10);
}

.offer__concret h3 {
  font-size: var(--text-heading-md);
  margin-bottom: var(--space-4);
}

.offer__concret ul {
  list-style: disc;
  padding-left: var(--space-6);
  color: var(--fg-secondary);
}

.offer__concret li {
  margin-bottom: var(--space-2);
}

.offer__media {
  margin: var(--space-8) 0;
}

.offer__cta {
  text-align: center;
}

/* Lien discret vers la plaquette PDF — vise Sandrine (Office Manager).
 * Pas un CTA primaire, juste une porte de sortie B2B pour pitcher en interne. */
.offer__plaquette {
  text-align: center;
  margin-top: var(--space-4);
  font-size: 0.9rem;
  color: var(--neutral-600, #525252);
}

.offer__plaquette a {
  color: var(--neutral-700, #404040);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  font-weight: 500;
}

.offer__plaquette a:hover,
.offer__plaquette a:focus-visible {
  color: var(--accent);
  text-decoration-thickness: 2px;
}

.offer__plaquette-hint {
  display: block;
  margin-top: 2px;
  font-size: 0.8rem;
  color: var(--fg-muted);
  font-style: italic;
}

@media (min-width: 1024px) {
  .offer__title {
    font-size: var(--text-display-md);
  }
  .offer__columns {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================================================
 * Section : Journée type (story 2.6)
 * ========================================================================= */
.day {
  padding: var(--space-20) 0;
}

.day__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.day__lead {
  max-width: 640px;
  color: var(--fg-secondary);
  margin-bottom: var(--space-10);
}

.day__timeline {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  border-left: 2px solid var(--border);
  padding-left: var(--space-6);
}

.day__hour {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-body-sm);
  color: var(--accent);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-1);
}

.day__timeline h3 {
  font-size: var(--text-heading-md);
  margin-bottom: var(--space-2);
}

.day__note {
  margin-top: var(--space-8);
  padding: var(--space-4);
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  color: var(--fg-secondary);
}

@media (min-width: 1024px) {
  .day__title {
    font-size: var(--text-display-md);
  }
}

/* ---------------------------------------------------------------------------
 * Story 9.2 — Journée type numérotée (pattern Linear 01-07)
 *
 * Le numéro est gros, à gauche, serif italic. Le contenu reste à droite.
 * Sur desktop : layout 2 colonnes (numéro sticky | contenu défilant).
 * Sur mobile : empilé classique, numéro au-dessus du contenu.
 * Copy PRD §3 conservée : 7 étapes avec leurs horaires/titres exacts.
 * ------------------------------------------------------------------------- */
.day--v2 .day__steps {
  list-style: none;
  padding: 0;
  margin: 0;
  border-left: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.day--v2 .day__step {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: var(--space-5);
  row-gap: var(--space-2);
  align-items: start;
  position: relative;
}

.day--v2 .day__number {
  grid-row: 1 / span 4;
  font-family: var(--font-serif, 'Georgia', serif);
  font-style: italic;
  font-weight: 900;
  font-size: clamp(48px, 6vw, 96px);
  line-height: 0.9;
  color: var(--color-orange-brique, #c2410c);
  letter-spacing: -0.02em;
  user-select: none;
}

.day--v2 .day__step .day__hour {
  margin-bottom: 0;
}

.day--v2 .day__step h3 {
  font-size: var(--text-heading-md);
  margin: 0;
}

.day--v2 .day__step p {
  margin: 0;
  color: var(--fg-secondary);
  max-width: 56ch;
}

@media (min-width: 1024px) {
  .day--v2 .day__steps {
    gap: var(--space-16);
  }
  .day--v2 .day__step {
    grid-template-columns: minmax(140px, 200px) 1fr;
    column-gap: var(--space-10);
  }
  .day--v2 .day__number {
    font-size: clamp(96px, 8vw, 144px);
    position: sticky;
    top: 120px;
    align-self: start;
  }
}

/* ============================================================================
 * Section : Formats & Tarifs (story 2.7)
 * ========================================================================= */
.pricing {
  padding: var(--space-20) 0;
  background: var(--bg-subtle);
}

.pricing__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.pricing__lead {
  max-width: 720px;
  color: var(--fg-secondary);
  margin-bottom: var(--space-10);
}

.pricing__table {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.pricing__card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.pricing__card h3 {
  font-size: var(--text-heading-md);
  margin-bottom: var(--space-2);
}

.pricing__meta {
  font-size: var(--text-body-sm);
  color: var(--fg-muted);
  margin-bottom: var(--space-4);
}

.pricing__price {
  font-size: var(--text-body-lg);
  color: var(--fg);
}

.pricing__price strong {
  font-size: var(--text-heading-md);
  color: var(--accent);
}

.pricing__note {
  font-size: var(--text-body-sm);
  color: var(--fg-secondary);
  margin-bottom: var(--space-6);
}

.pricing__reassurance {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-8);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  font-size: var(--text-body-sm);
  color: var(--fg-secondary);
}

.pricing__reassurance li::before {
  content: '✓  ';
  color: var(--success);
}

.pricing__cta {
  text-align: center;
}

/* ---------------------------------------------------------------------------
 * Story 9.3 — Card pricing centrale "Le plus demandé"
 *
 * La card "Journée complète" est mise en exergue : badge en haut, border
 * orange brique, ombre légère, légère élévation visuelle (margin négative
 * desktop). Les autres cards restent visibles mais discrètes.
 * Mobile : on retire la mise en avant verticale pour éviter overflow.
 * ------------------------------------------------------------------------- */
.pricing__card {
  position: relative;
}

.pricing__card--featured {
  border: 2px solid var(--color-orange-brique, #c2410c);
  box-shadow: 0 8px 24px rgba(31, 35, 38, 0.08);
  background: var(--color-ivoire-chaud, #fafaf7);
  z-index: 2;
}

.pricing__badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-orange-brique, #c2410c);
  color: var(--color-ivoire-chaud, #f5efe6);
  padding: 6px 14px;
  border-radius: 999px;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  white-space: nowrap;
  box-shadow: 0 2px 6px rgba(194, 65, 12, 0.25);
}

.pricing__features {
  list-style: none;
  padding: 0;
  margin: var(--space-5) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--text-body-sm);
  color: var(--fg-secondary);
}

.pricing__features li::before {
  content: '✓';
  color: var(--color-orange-brique, #c2410c);
  margin-right: 8px;
  font-weight: 600;
}

@media (min-width: 1024px) {
  .pricing__card--featured {
    margin-top: -8px;
    margin-bottom: -8px;
    padding-top: calc(var(--space-6) + 4px);
    padding-bottom: calc(var(--space-6) + 4px);
  }
}

@media (min-width: 1024px) {
  .pricing__title {
    font-size: var(--text-display-md);
  }
  .pricing__table {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================================================
 * Section : Écoresponsable (story 2.8)
 * ========================================================================= */
.eco {
  padding: var(--space-20) 0;
}

.eco__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.eco__lead {
  max-width: 640px;
  color: var(--fg-secondary);
  margin-bottom: var(--space-10);
}

.eco__list,
.eco__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

.eco__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.eco__icon {
  width: 32px;
  height: 32px;
  stroke: var(--color-graphite, #1f2326);
  color: var(--color-graphite, #1f2326);
  fill: none;
  margin-bottom: var(--space-1);
}

.eco__list h3 {
  font-size: var(--text-body-lg);
  font-weight: 500;
  color: var(--fg);
  margin-bottom: var(--space-1);
}

.eco__item p {
  color: var(--fg-secondary);
  margin: 0;
}

/* Bloc transparence — accent sauge UNIQUEMENT (cf research/06-da-cinema §3.3).
   Card avec border-left sauge sourde, padding généreux, fond off-white. */
.eco__transparency {
  margin-top: var(--space-10);
  color: var(--fg-muted);
  font-size: var(--text-body-sm);
}

.eco__transparency--card {
  border-left: 4px solid var(--color-sauge-sourde, #5a6b5f);
  padding: var(--space-5) var(--space-6);
  background: var(--color-off-white, #fafaf7);
  border-radius: 0 var(--radius-md, 4px) var(--radius-md, 4px) 0;
  color: var(--fg-default, #1f2326);
  font-size: var(--text-body-md);
}

.eco__transparency--card h3 {
  font-size: var(--text-body-lg);
  font-weight: 500;
  color: var(--color-sauge-sourde, #5a6b5f);
  margin: 0 0 var(--space-2);
}

.eco__transparency--card p {
  margin: 0;
}

@media (min-width: 768px) {
  .eco__list,
  .eco__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .eco__title {
    font-size: var(--text-display-md);
  }
  .eco__list,
  .eco__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-10);
  }
}

/* ============================================================================
 * Section : Équipe (story 2.9)
 * ========================================================================= */
.team {
  padding: var(--space-20) 0;
  background: var(--bg-subtle);
}

.team__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.team__lead {
  max-width: 640px;
  color: var(--fg-secondary);
  margin-bottom: var(--space-10);
}

.team__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.team__card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}

.team__card h3 {
  font-size: var(--text-heading-md);
  margin: var(--space-4) 0 var(--space-1);
}

.team__role {
  font-size: var(--text-body-sm);
  color: var(--accent);
  margin-bottom: var(--space-2);
}

.team__note {
  margin-top: var(--space-10);
  color: var(--fg-secondary);
}

@media (min-width: 1024px) {
  .team__title {
    font-size: var(--text-display-md);
  }
  .team__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* ============================================================================
 * Section : Témoignages (story 2.10)
 * ========================================================================= */
.testimonials {
  padding: var(--space-20) 0;
}

.testimonials__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.testimonials__lead {
  max-width: 640px;
  color: var(--fg-secondary);
  margin-bottom: var(--space-10);
}

.testimonials__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.testimonials__card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.testimonials__card blockquote {
  margin: 0 0 var(--space-4);
  font-style: italic;
  color: var(--fg-secondary);
  line-height: var(--lh-body);
}

.testimonials__signature {
  font-size: var(--text-body-sm);
  color: var(--fg);
  font-weight: 500;
  margin: 0;
}

@media (min-width: 1024px) {
  .testimonials__title {
    font-size: var(--text-display-md);
  }
  .testimonials__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ---------------------------------------------------------------------------
 * Story 9.7 — Témoignages refonte (tag persona + avatar + see-all)
 *
 * Chaque card : tag persona en haut (mono uppercase orange), verbatim blockquote
 * serif italique, footer avec avatar rond 48×48 + signature. Card vidéo : on
 * span 2 cols desktop, conserve le placeholder 16:9.
 * ------------------------------------------------------------------------- */
.testimonials__grid--v2 {
  gap: var(--space-6);
}

.testimonials__card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--color-off-white, #fafaf7);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  gap: var(--space-3);
}

.testimonials__tag {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-orange-brique, #c2410c);
  font-weight: 500;
  display: inline-block;
}

.testimonials__card blockquote {
  font-family: var(--font-serif, 'Georgia', serif);
  font-style: italic;
  font-size: var(--text-body-lg);
  line-height: 1.45;
  color: var(--fg-default, #1f2326);
  margin: 0;
}

.testimonials__footer {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: auto;
}

.testimonials__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--color-anthracite, #2e3338);
  color: rgba(245, 239, 230, 0.6);
  font-size: 0.875rem;
}

.testimonials__see-all {
  margin-top: var(--space-8);
  text-align: center;
}

.testimonials__see-all a {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-orange-brique, #c2410c);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
}

.testimonials__card--video .placeholder-16-9 {
  margin: var(--space-2) 0;
}

@media (min-width: 1024px) {
  .testimonials__grid--v2 {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8);
  }
  .testimonials__card--video {
    grid-column: span 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
    align-items: center;
  }
  .testimonials__card--video .testimonials__tag {
    grid-column: 1 / -1;
  }
  .testimonials__card--video .placeholder-16-9 {
    grid-row: span 2;
  }
}

/* ============================================================================
 * Section : FAQ (story 2.11)
 * ========================================================================= */
.faq {
  padding: var(--space-20) 0;
  background: var(--bg-subtle);
}

.faq__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.faq__lead {
  max-width: 640px;
  color: var(--fg-secondary);
  margin-bottom: var(--space-10);
}

.faq__list {
  border-top: 1px solid var(--border);
}

.faq__item {
  border-bottom: 1px solid var(--border);
}

.faq__item > summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  cursor: pointer;
  padding: var(--space-5) 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-body-lg);
  color: var(--fg);
}

.faq__item > summary::-webkit-details-marker {
  display: none;
}

.faq__item > summary::after {
  content: '+';
  font-size: 1.5rem;
  color: var(--fg-muted);
  transition: transform 200ms ease;
}

.faq__item[open] > summary::after {
  content: '−';
}

.faq__answer {
  padding-bottom: var(--space-5);
  color: var(--fg-secondary);
  line-height: var(--lh-body);
}

@media (min-width: 1024px) {
  .faq__title {
    font-size: var(--text-display-md);
  }
}

/* ---------------------------------------------------------------------------
 * Story 9.8 — Polish FAQ (chevron rotatif + hover + focus visible + spacing)
 *
 * On garde le `<details>/<summary>` natif (a11y + SEO @graph FAQPage intact).
 * Améliorations purement CSS :
 *   - Chevron `›` rotatif 250ms cubic-bezier au lieu du +/-
 *   - Hover sur summary : fond ivoire chaud subtil + transition
 *   - Focus visible : outline orange brique (clavier-friendly)
 *   - Espacement entre items soigné (padding généreux)
 *   - prefers-reduced-motion : pas d'animation
 * ------------------------------------------------------------------------- */
.faq--polished .faq__item,
.faq__item.faq__item--polished,
.faq__item {
  border-bottom: 1px solid var(--border);
  transition: background-color 250ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.faq__item > summary {
  position: relative;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-4) var(--space-6) 0;
  transition: background-color 250ms cubic-bezier(0.2, 0.8, 0.2, 1);
  outline: none;
}

.faq__item > summary:hover {
  background-color: var(--color-ivoire-chaud, #f5efe6);
}

.faq__item > summary:focus-visible {
  outline: 2px solid var(--color-orange-brique, #c2410c);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Chevron rotatif : on remplace le marqueur +/− par un `›` qui pivote */
.faq__item > summary::after {
  content: '›';
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 1.5rem;
  line-height: 1;
  color: var(--color-orange-brique, #c2410c);
  transform: rotate(0deg);
  transition: transform 250ms cubic-bezier(0.2, 0.8, 0.2, 1);
  display: inline-block;
  flex-shrink: 0;
}

.faq__item[open] > summary::after {
  content: '›';
  transform: rotate(90deg);
}

.faq__answer {
  padding: 0 var(--space-4) var(--space-6) 0;
  max-width: 78ch;
}

@media (prefers-reduced-motion: reduce) {
  .faq__item,
  .faq__item > summary,
  .faq__item > summary::after {
    transition: none;
  }
}

/* ============================================================================
 * Section : CTA final (ancre form Epic 4)
 * ========================================================================= */
.cta-final {
  padding: var(--space-20) 0;
  text-align: center;
}

.cta-final__title {
  font-size: var(--text-heading-lg);
  margin-bottom: var(--space-4);
}

.cta-final__lead {
  max-width: 640px;
  margin: 0 auto var(--space-6);
  color: var(--fg-secondary);
}

.cta-final__phone {
  font-size: var(--text-body);
  color: var(--fg-secondary);
}

@media (min-width: 1024px) {
  .cta-final__title {
    font-size: var(--text-display-md);
  }
}

/* ============================================================================
 * Section : Footer (story 2.1)
 * ========================================================================= */
.site-footer {
  background: #0a0a0a;
  color: #d4d4d4;
  padding: var(--space-20) 0 var(--space-12);
  margin-top: var(--space-20);
}

/* Override `p { color: var(--fg-secondary) }` (#525252 — 2.53:1 sur #0a0a0a, KO WCAG AA).
   #d4d4d4 sur #0a0a0a = 13.55:1 (large marge). */
.site-footer p,
.site-footer li,
.site-footer span {
  color: #d4d4d4;
}

.site-footer a {
  color: #d4d4d4;
}

.site-footer a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}

@media (min-width: 1024px) {
  .site-footer__grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }
}

.site-footer__heading {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.875rem;
  color: #fafaf7;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-4);
}

.site-footer__brand {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.25rem;
  color: #ffffff;
  margin-bottom: var(--space-3);
}

.site-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: 0.9375rem;
}

.site-footer__social {
  display: flex;
  gap: var(--space-3);
}

.site-footer__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid #262626;
  border-radius: var(--radius-md);
}

.site-footer__bottom {
  margin-top: var(--space-12);
  padding-top: var(--space-6);
  border-top: 1px solid #262626;
  font-size: 0.8125rem;
  /* footer bg dark #0a0a0a → texte gris clair suffisant pour WCAG AA */
  color: #a3a3a3;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-2);
}
