/* ============================================
   BRAND PARTNERS V4 — Formation Detail Pages
   Template A : Masterclass (présentiel)
   Template B : Parcours (en ligne)
   ============================================ */

/* --- Custom property par formation --- */
:root {
  --formation-color: var(--color-accent-laterite);
}

/* ============================================
   TEMPLATE A : MASTERCLASS
   ============================================ */

/* Hero dark gradient */
.fm-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  padding: var(--space-3xl) 0;
  background: linear-gradient(180deg, var(--formation-color) 0%, #1A1A1A 60%);
  overflow: hidden;
}

.fm-hero__back {
  position: absolute;
  top: 6rem;
  left: var(--gutter);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(250,250,248,0.5);
  text-decoration: none;
  transition: color 0.3s;
}

.fm-hero__back:hover { color: rgba(250,250,248,0.9); }

.fm-hero__content {
  position: relative;
  z-index: 2;
}

.fm-hero .section-number { color: rgba(250,250,248,0.8); }

.fm-hero__title {
  font-family: var(--font-editorial);
  font-size: var(--text-6xl);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-bg-primary);
  max-width: 800px;
  margin-bottom: var(--space-md);
}

.fm-hero__subtitle {
  font-family: var(--font-editorial);
  font-size: var(--text-2xl);
  font-style: italic;
  color: rgba(250,250,248,0.85);
  max-width: 600px;
  margin-bottom: var(--space-xl);
}

.fm-hero__meta {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
}

.fm-hero__pill {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(250,250,248,0.85);
  background: rgba(250,250,248,0.1);
  backdrop-filter: blur(8px);
  padding: 0.4rem 1rem;
  border: 1px solid rgba(250,250,248,0.15);
}

/* Split Info Grid (V5) */
.fm-hero__split-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: var(--space-xl);
  border-top: 1px solid rgba(250,250,248,0.1);
}

.fm-hero__split-left {
  padding: var(--space-md) var(--space-md) var(--space-md) 0;
  border-right: 1px solid rgba(250,250,248,0.1);
}

.fm-hero__split-right {
  padding: var(--space-md) 0 var(--space-md) var(--space-md);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.fm-hero__info-label {
  font-family: var(--font-body);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(250,250,248,0.4);
  margin-bottom: 0.2rem;
}

.fm-hero__info-value {
  font-family: var(--font-editorial);
  font-size: var(--text-lg);
  color: #fafaf8;
}

.fm-hero__info-value strong {
  color: var(--formation-color);
}

/* Double CTA */
.fm-hero__dual-cta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: var(--space-md);
}

.fm-btn--outline {
  color: rgba(250,250,248,0.7);
  background: transparent;
  border: 1px solid rgba(250,250,248,0.15);
}

/* Cover image */
.fm-cover {
  width: 100%;
  height: 50vh;
  overflow: hidden;
}

.fm-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Brief / Value proposition */
.fm-brief {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: start;
}

.fm-brief__left {
  font-family: var(--font-editorial);
  font-size: var(--text-3xl);
  font-style: italic;
  line-height: var(--leading-snug);
  color: var(--color-text-primary);
}

.fm-brief__right {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
}

/* Stats row */
.fm-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gutter);
  margin-top: var(--space-3xl);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-xl);
}

.fm-stat {
  text-align: center;
}

.fm-stat__number {
  font-family: var(--font-editorial);
  font-size: var(--text-4xl);
  color: var(--color-text-primary);
  line-height: 1;
}

.fm-stat__label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-secondary);
  margin-top: var(--space-xs);
}

/* Programme */
.fm-programme {
  counter-reset: fm-module;
}

.fm-module {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--space-lg);
  padding: var(--space-xl) 0;
  border-bottom: 1px solid var(--color-border);
}

.fm-module__num {
  font-family: var(--font-editorial);
  font-size: var(--text-3xl);
  color: rgba(26,26,26,0.1);
  line-height: 1;
}

.fm-module__title {
  font-family: var(--font-editorial);
  font-size: var(--text-2xl);
  color: var(--color-text-primary);
  margin-bottom: var(--space-xs);
}

.fm-module__desc {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

/* Objectifs encart — Premium Dark */
.fm-objectives {
  background: var(--color-text-primary);
  padding: var(--space-xl);
  border-left: none;
  margin-bottom: var(--space-xl);
  counter-reset: objective;
}

.fm-objectives__title {
  font-family: var(--font-editorial);
  font-size: var(--text-xl);
  font-style: italic;
  font-weight: 400;
  letter-spacing: normal;
  text-transform: none;
  color: rgba(250,250,248,0.5);
  margin-bottom: var(--space-lg);
}

.fm-objectives ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fm-objectives li {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: rgba(250,250,248,0.85);
  line-height: var(--leading-relaxed);
  padding: var(--space-sm) 0;
  padding-left: 2.2rem;
  position: relative;
  border-bottom: 1px solid rgba(250,250,248,0.08);
  counter-increment: objective;
}

.fm-objectives li:last-child {
  border-bottom: none;
}

.fm-objectives li::before {
  content: "0" counter(objective);
  position: absolute;
  left: 0;
  font-family: var(--font-editorial);
  font-size: var(--text-sm);
  color: var(--formation-color);
  opacity: 0.7;
}

/* Public & Prérequis — 2 cartes dark */
.fm-audience-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gutter);
}

.fm-audience-card {
  background: var(--color-text-primary);
  color: var(--color-bg-primary);
  padding: var(--space-xl);
}

.fm-audience-card__label {
  font-family: var(--font-editorial);
  font-size: var(--text-xl);
  font-weight: 400;
  font-style: italic;
  letter-spacing: normal;
  text-transform: none;
  color: var(--formation-color);
  margin-bottom: var(--space-md);
}

.fm-audience-card p {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: rgba(250,250,248,0.8);
}

/* Formateur split */
.fm-instructor {
  display: grid;
  grid-template-columns: 40% 1fr;
  gap: var(--space-xl);
  align-items: start;
}

.fm-instructor__photo {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  filter: grayscale(30%);
}

.fm-instructor__quote {
  font-family: var(--font-editorial);
  font-size: var(--text-2xl);
  font-style: italic;
  line-height: var(--leading-snug);
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
}

.fm-instructor__name {
  font-family: var(--font-editorial);
  font-size: var(--text-lg);
  color: var(--color-text-primary);
}

.fm-instructor__title {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-accent-laterite);
  margin-bottom: var(--space-md);
}

.fm-instructor__bio {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

/* Infos pratiques grille */
.fm-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gutter);
}

.fm-info-item {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-lg);
}

.fm-info-item__label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-xs);
}

.fm-info-item__value {
  font-family: var(--font-editorial);
  font-size: var(--text-2xl);
  color: var(--color-text-primary);
}

/* Bloc prix/CTA dark */
.fm-pricing {
  background: var(--color-text-primary);
  color: var(--color-bg-primary);
  text-align: center;
  padding: var(--space-section) 0;
}

.fm-pricing__price {
  font-family: var(--font-editorial);
  font-size: var(--text-5xl);
  line-height: 1;
  margin-bottom: var(--space-md);
}

.fm-pricing__includes {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: rgba(250,250,248,0.8);
  line-height: var(--leading-relaxed);
  max-width: 500px;
  margin: 0 auto var(--space-xl);
}

.fm-pricing__seats {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--formation-color);
  margin-top: var(--space-md);
}

/* Témoignage */
.fm-testimonial {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}

.fm-testimonial__quote {
  font-family: var(--font-editorial);
  font-size: var(--text-2xl);
  font-style: italic;
  line-height: var(--leading-snug);
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
}

.fm-testimonial__author {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

/* FAQ — Accordéon déployable */
.fm-faq-item {
  border-bottom: 1px solid var(--color-border);
}

.fm-faq-item__q {
  font-family: var(--font-editorial);
  font-size: var(--text-lg);
  color: var(--color-text-primary);
  padding: var(--space-lg) 0;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  user-select: none;
  -webkit-user-select: none;
}

.fm-faq-item__q::after {
  content: "+";
  font-family: var(--font-body);
  font-size: var(--text-xl);
  font-weight: 300;
  color: var(--color-text-secondary);
  flex-shrink: 0;
  transition: transform 0.3s ease;
  line-height: 1;
}

.fm-faq-item.is-open .fm-faq-item__q::after {
  content: "−";
  transform: rotate(180deg);
  color: var(--color-accent-laterite);
}

.fm-faq-item__a {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding: 0 0;
}

.fm-faq-item.is-open .fm-faq-item__a {
  max-height: 300px;
  padding: 0 0 var(--space-lg) 0;
}

/* Formations suggérées */
.fm-related {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gutter);
}

/* CTA final */
.fm-final-cta {
  text-align: center;
}

.fm-final-cta__quote {
  font-family: var(--font-editorial);
  font-size: var(--text-5xl);
  font-style: italic;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
  max-width: 800px;
  margin: 0 auto var(--space-xl);
}

/* Bouton partagé */
.fm-btn {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 2.5rem;
  text-decoration: none;
  transition: all 0.3s;
}

.fm-btn--light {
  color: var(--color-text-primary);
  background: var(--color-bg-primary);
}

.fm-btn--dark {
  color: var(--color-bg-primary);
  background: var(--color-text-primary);
}

.fm-btn--laterite {
  color: var(--color-bg-primary);
  background: var(--color-accent-laterite);
}

.fm-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

/* ============================================
   TEMPLATE B : PARCOURS
   ============================================ */

/* Hero light éditorial */
.fp-hero {
  background: var(--color-bg-secondary);
  padding: 8rem 0 var(--space-3xl);
}

.fp-hero__layout {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: var(--space-3xl);
  align-items: end;
}

.fp-hero__cat {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-accent-laterite);
  display: block;
  margin-bottom: var(--space-md);
}

.fp-hero__title {
  font-family: var(--font-editorial);
  font-size: var(--text-5xl);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--space-md);
}

.fp-hero__subtitle {
  font-family: var(--font-editorial);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--color-text-secondary);
}

.fp-hero__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.fp-hero__meta-item {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-sm);
}

.fp-hero__meta-label {
  font-family: var(--font-body);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-secondary);
  display: block;
  margin-bottom: 0.2rem;
}

.fp-hero__meta-value {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-primary);
}

/* Cover */
.fp-cover {
  width: 100%;
  height: 40vh;
  overflow: hidden;
}

.fp-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Intro bloc beige */
.fp-intro {
  background: var(--color-bg-secondary);
  padding: var(--space-xl) 0;
}

.fp-intro p {
  font-family: var(--font-editorial);
  font-size: var(--text-xl);
  font-style: italic;
  line-height: var(--leading-snug);
  color: var(--color-text-dark);
  max-width: 700px;
}

/* Body layout : contenu + sidebar */
.fp-body {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-3xl);
  align-items: start;
}

/* Sidebar sticky */
.fp-sidebar {
  position: sticky;
  top: 6rem;
}

.fp-sidebar__card {
  border: 1px solid var(--color-border);
  padding: var(--space-xl);
  background: var(--color-bg-primary);
}

.fp-sidebar__tag {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-bg-primary);
  background: var(--color-text-primary);
  padding: 0.25rem 0.6rem;
  display: inline-block;
  margin-bottom: var(--space-md);
}

.fp-sidebar__price {
  font-family: var(--font-editorial);
  font-size: var(--text-4xl);
  color: var(--color-text-primary);
  line-height: 1;
  margin-bottom: var(--space-lg);
}

.fp-sidebar__facts {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-lg);
  border-top: 1px solid var(--color-border);
}

.fp-sidebar__fact {
  display: flex;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-border);
  font-family: var(--font-body);
  font-size: var(--text-sm);
}

.fp-sidebar__fact-label { color: var(--color-text-secondary); }
.fp-sidebar__fact-value { color: var(--color-text-primary); font-weight: 500; }

.fp-sidebar__cta {
  display: block;
  width: 100%;
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-bg-primary);
  background: var(--color-accent-laterite);
  padding: 1rem;
  text-decoration: none;
  transition: all 0.3s;
  margin-bottom: var(--space-md);
}

.fp-sidebar__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(160,82,45,0.25);
}

.fp-sidebar__pdf {
  display: block;
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-secondary);
  text-decoration: none;
  padding: var(--space-sm) 0;
  border: 1px solid var(--color-border);
  transition: all 0.3s;
  margin-bottom: var(--space-lg);
}

.fp-sidebar__pdf:hover {
  border-color: var(--color-text-primary);
  color: var(--color-text-primary);
}

.fp-sidebar__session {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.fp-sidebar__session strong {
  color: var(--color-text-primary);
}

.fp-sidebar__social {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-accent-laterite);
  text-align: center;
}

/* Content sections */
.fp-content h3 {
  font-family: var(--font-editorial);
  font-size: var(--text-2xl);
  color: var(--color-text-primary);
  margin-bottom: var(--space-md);
}

/* Méthode pédagogique — 3 cartes */
.fp-method-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gutter);
  margin-top: var(--space-lg);
}

.fp-method-card {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-lg);
}

.fp-method-card__title {
  font-family: var(--font-editorial);
  font-size: var(--text-xl);
  color: var(--color-text-primary);
  margin-bottom: var(--space-xs);
}

.fp-method-card__desc {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

/* CTA final dark */
.fp-final-cta {
  background: var(--color-text-primary);
  color: var(--color-bg-primary);
  text-align: center;
  padding: var(--space-section) 0;
}

.fp-final-cta__title {
  font-family: var(--font-editorial);
  font-size: var(--text-4xl);
  font-style: italic;
  line-height: var(--leading-tight);
  max-width: 600px;
  margin: 0 auto var(--space-xl);
}

.fp-final-cta__guarantee {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(250,250,248,0.5);
  margin-top: var(--space-md);
}

/* ============================================
   RESPONSIVE — 768px
   ============================================ */
@media (max-width: 768px) {
  /* Masterclass */
  .fm-hero {
    min-height: auto;
    padding: var(--space-3xl) 0 var(--space-xl);
    padding-top: 7rem;
  }
  .fm-hero__title { font-size: var(--text-5xl) !important; } /* Charte globale */
  .fm-hero__subtitle { font-size: var(--text-lg); }
  .fm-hero__meta { flex-wrap: wrap; gap: var(--space-xs); }
  .fm-hero__urgency {
    flex-direction: column;
    gap: var(--space-xs);
    text-align: center;
  }
  .fm-hero__urgency span:nth-child(2) { display: none; }
  .fm-cover { height: 35vh; }
  .fm-brief { grid-template-columns: 1fr; gap: var(--space-xl); }
  .fm-brief__left { font-size: var(--text-xl); } /* Réduit pour respirer */
  .fm-stats { grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
  .fm-stat__number { font-size: var(--text-3xl); }
  .fm-audience-grid { grid-template-columns: 1fr; }
  .fm-instructor { grid-template-columns: 1fr; }
  .fm-instructor__photo { aspect-ratio: 3/4; max-height: 400px; object-fit: cover; } /* Portrait */
  .fm-info-grid { grid-template-columns: 1fr 1fr; }
  .fm-pricing { padding: var(--space-3xl) 0; }
  .fm-pricing__price { font-size: var(--text-5xl) !important; } /* Prix monumental */
  .fm-related { grid-template-columns: 1fr; }
  .fm-final-cta__quote { font-size: var(--text-4xl); }

  /* Suppression hover mobile — Formation */
  .fm-btn:hover { transform: none; box-shadow: none; }
  .fp-sidebar__cta:hover { transform: none; box-shadow: none; }
  .fp-sidebar__pdf:hover { border-color: var(--color-border); color: var(--color-text-secondary); }

  /* Parcours */
  .fp-hero { padding: 7rem 0 var(--space-xl); }
  .fp-hero__layout { grid-template-columns: 1fr; gap: var(--space-xl); }
  .fp-hero__title { font-size: var(--text-5xl) !important; } /* Charte globale */
  .fp-hero__meta { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 0; 
  }
  .fp-hero__meta-item { 
    padding: var(--space-sm); 
    border-bottom: 1px solid var(--color-border);
  }
  .fp-hero__meta-item:nth-child(odd) { border-right: 1px solid var(--color-border); }
  .fp-body { grid-template-columns: 1fr; }
  .fp-sidebar {
    position: static;
    order: -1;
    margin-bottom: var(--space-xl);
  }
  .fp-sidebar__card { border: none; background: transparent; padding: 0; }
  .fp-sidebar__price { font-size: var(--text-5xl) !important; margin-bottom: var(--space-md); }
  .fp-sidebar__cta { padding: 1.1rem; font-size: var(--text-sm); }
  .fp-sidebar__pdf { padding: 0.8rem; }
  .fp-method-grid { grid-template-columns: 1fr; }
  .fp-method-card { 
    padding-top: var(--space-md); 
    padding-bottom: var(--space-md);
  }
  .fp-final-cta { padding: var(--space-3xl) 0; }
  .fp-final-cta__title { font-size: var(--text-3xl); }
}

/* ============================================
   RESPONSIVE — 480px
   ============================================ */
@media (max-width: 480px) {
  /* Masterclass */
  .fm-hero {
    padding: 6rem 0 var(--space-md);
  }
  .fm-hero__title { font-size: var(--text-5xl) !important; } /* Maintenu */
  .fm-hero__subtitle { font-size: var(--text-base); }
  .fm-hero__pill { font-size: 0.75rem; padding: 0.3rem 0.7rem; }
  .fm-cover { height: 30vh; }
  .fm-stats { grid-template-columns: repeat(3, 1fr); }
  .fm-stat__number { font-size: var(--text-2xl); }
  .fm-info-grid { grid-template-columns: 1fr; }
  .fm-info-item__value { font-size: var(--text-xl); }
  .fm-pricing__price { font-size: var(--text-4xl) !important; }
  .fm-final-cta__quote { font-size: var(--text-3xl); }
  /* Modules Programme — Redesign Card Mobile */
  .fm-module {
    display: block;
    position: relative;
    padding: var(--space-xl) var(--space-lg);
    padding-left: calc(var(--space-lg) + 4px);
    margin-bottom: var(--space-md);
    border-bottom: none;
    border-left: 4px solid var(--color-accent-laterite);
    background: var(--color-bg-primary);
  }
  .fm-module__num {
    font-size: var(--text-5xl);
    color: rgba(26,26,26,0.05);
    position: absolute;
    top: var(--space-sm);
    right: var(--space-md);
    line-height: 1;
    pointer-events: none;
  }
  .fm-module__title {
    font-size: var(--text-xl);
    margin-bottom: var(--space-xs);
    position: relative;
    z-index: 1;
  }
  .fm-module__desc {
    font-size: var(--text-sm);
    position: relative;
    z-index: 1;
  }

  /* Parcours */
  .fp-hero { padding: 6rem 0 var(--space-lg); }
  .fp-hero__title { font-size: var(--text-4xl) !important; }
  .fp-sidebar__price { font-size: var(--text-3xl); }
  .fp-final-cta { padding: var(--space-2xl) 0; }
  .fp-final-cta__title { font-size: var(--text-2xl); }

  /* Boutons pleine largeur */
  .fm-btn {
    display: block;
    width: 100%;
    text-align: center;
  }
}
