/* ============================================
   Page Méthode — cohérent avec Accueil & Manifeste
   ============================================ */

/* Grilles — cartes à hauteur égale */
.section--alt .grid.grid--3,
.section-outils .grid.grid--3 {
  grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 768px) {
  .section--alt .grid.grid--3,
  .section-outils .grid.grid--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1100px) {
  .section--alt .grid.grid--3,
  .section-outils .grid.grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.grid .card-ccc,
.grid .card--outil {
  height: 100%;
  min-width: 0;
}

/* =============================================
   Hero — même responsivité que l’accueil
   ============================================= */

.methode-hero {
  box-sizing: border-box;
  padding: var(--space-3xl) 0 var(--space-2xl);
  background-color: var(--neutral-900);
  color: var(--neutral-0);
  display: flex;
  align-items: center;
  min-height: auto;
  height: auto;
  overflow: clip;
}

.methode-hero .container {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xl);
  width: 100%;
}

/* Photo en dessous : centrer le texte (mobile + tablet) */
@media (max-width: 1099px) {
  .methode-hero__content {
    text-align: center;
  }

  .methode-hero__ctas {
    justify-content: center;
  }
}

.methode-hero__title {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  margin-bottom: var(--space-lg);
  color: var(--neutral-0);
  line-height: 1.15;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.methode-hero__subtitle {
  font-size: var(--text-lg);
  color: var(--neutral-300);
  margin-bottom: var(--space-2xl);
  max-width: none;
}

.methode-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
}

.methode-hero .btn--ghost {
  text-decoration: none;
  color: var(--neutral-300);
  font-weight: 600;
  border: 1px solid var(--neutral-500);
}

.methode-hero .btn--ghost:hover {
  color: var(--neutral-0);
  border-color: var(--neutral-0);
}

.methode-hero .btn--ghost .btn__arrow {
  display: inline-block;
  transition: transform var(--duration-fast) var(--ease-out);
}

.methode-hero .btn--ghost:hover .btn__arrow {
  transform: translateX(4px);
}

.methode-hero__img-wrap {
  width: 100%;
  max-width: var(--content-img-landscape-w);
  margin-inline: auto;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-sizing: border-box;
}

.methode-hero__img-wrap picture {
  display: block;
  width: 100%;
}

.methode-hero__img-wrap img {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: middle;
}

/* Tablet (iPad) : titres plus grands */
@media (min-width: 481px) and (max-width: 1024px) {
  .methode-hero__title {
    font-size: clamp(3rem, 10vw, var(--text-6xl));
  }
}

/* Mobile : titre hero bien plus grand que le sous-titre */
@media (max-width: 480px) {
  .methode-hero__title {
    font-size: clamp(var(--text-3xl), 10vw, var(--text-5xl));
  }
}

@media (max-width: 767px) {
  .methode-hero {
    padding: var(--space-2xl) 0 var(--space-2xl);
  }

  .methode-hero__subtitle {
    margin-bottom: var(--space-xl);
  }

  .methode-hero__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-sm);
  }

  .methode-hero__ctas .btn {
    justify-content: center;
  }

  .methode-hero__img-wrap {
    max-height: min(75vh, 380px);
  }

  .methode-hero__img-wrap img {
    max-height: min(75vh, 380px);
    object-fit: cover;
    object-position: center top;
  }
}

/* Tablet (768px – 1099px) */
@media (min-width: 768px) and (max-width: 1099px) {
  .methode-hero {
    padding: var(--space-4xl) 0 var(--space-3xl);
  }

  .methode-hero__img-wrap {
    max-width: 28rem;
  }

  .methode-hero__ctas {
    gap: var(--space-xl);
  }
}

/* Desktop (≥ 1100px) : côte à côte, cadre carré centré comme l’accueil */
@media (min-width: 1100px) {
  .methode-hero {
    min-height: var(--hero-min-height);
    height: var(--hero-min-height);
    padding: var(--space-4xl) 0 var(--space-3xl);
  }

  .methode-hero .container {
    flex-direction: row;
    align-items: stretch;
    gap: var(--space-4xl);
    transform: translateY(-1rem);
  }

  .methode-hero__content {
    flex: 0 0 55%;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .methode-hero__visual {
    flex: 1 1 45%;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Cadre carré, image centrée */
  .methode-hero__img-wrap {
    width: 100%;
    max-width: 100%;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }

  .methode-hero__img-wrap picture {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .methode-hero__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .methode-hero__ctas {
    gap: var(--space-xl);
  }
}

/* Grand écran : cadre carré plafonné */
@media (min-width: 1400px) {
  .methode-hero__img-wrap {
    max-width: min(var(--content-img-landscape-w), 72vh);
  }
}

/* Transition hero → section suivante */
.methode-hero + .section {
  padding-top: var(--space-3xl);
}

@media (min-width: 768px) {
  .methode-hero + .section {
    padding-top: calc(var(--space-section) / 2);
  }
}

/* =============================================
   Section headers — centrés avec sous-titre
   ============================================= */

.section-etapes .section__header,
.section-outils .section__header,
.section-ccc .section__header,
.section-changements .section__header {
  text-align: center;
  margin-bottom: var(--space-lg);
}

.section-etapes .section__header .section__title,
.section-outils .section__header .section__title,
.section-ccc .section__header .section__title,
.section-changements .section__header .section__title {
  margin-bottom: var(--space-xs);
}

.section-etapes .section__header .section__subtitle,
.section-outils .section__header .section__subtitle,
.section-ccc .section__header .section__subtitle,
.section-changements .section__header .section__subtitle {
  max-width: 42rem;
  margin-inline: auto;
  color: var(--neutral-600);
  font-size: var(--text-sm);
}

@media (min-width: 768px) {
  .section-etapes .section__header,
  .section-outils .section__header,
  .section-ccc .section__header,
  .section-changements .section__header {
    margin-bottom: var(--space-2xl);
  }

  .section-etapes .section__header .section__title,
  .section-outils .section__header .section__title,
  .section-ccc .section__header .section__title,
  .section-changements .section__header .section__title {
    margin-bottom: var(--space-md);
  }

  .section-etapes .section__header .section__subtitle,
  .section-outils .section__header .section__subtitle,
  .section-ccc .section__header .section__subtitle,
  .section-changements .section__header .section__subtitle {
    font-size: var(--text-lg);
  }
}

/* =============================================
   Modèle CCC
   ============================================= */

/* Citation CCC — même design que l'accueil */
.section-ccc__quote {
  margin: var(--space-lg) auto var(--space-xl);
  padding-left: var(--space-lg);
  border-left: 3px solid var(--accent-warm);
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-style: italic;
  max-width: var(--max-width-narrow);
  color: var(--neutral-700);
}

@media (min-width: 768px) {
  .section-ccc__quote {
    margin: var(--space-2xl) auto var(--space-3xl);
    padding-left: var(--space-xl);
    border-left-width: 4px;
    font-size: var(--text-lg);
  }
}

/* =============================================
   Section 3 outils — Tabs + Carousel
   ============================================= */

.outils-tabs__nav {
  display: flex;
  justify-content: center;
  gap: var(--space-md);
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}

.outils-tabs__tab {
  flex: 1;
  max-width: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-md);
  border: 2px solid var(--neutral-200);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  border-bottom: none;
  background: var(--neutral-0);
  cursor: pointer;
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--neutral-600);
  transition: border-color 0.2s, color 0.2s, box-shadow 0.2s, background 0.2s;
}

.outils-tabs__tab img {
  width: 32px;
  height: 32px;
  object-fit: contain;
  border-radius: var(--radius-sm);
}

@media (min-width: 768px) {
  .outils-tabs__tab {
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    font-size: var(--text-base);
  }

  .outils-tabs__tab img {
    width: 48px;
    height: 48px;
  }
}

.outils-tabs__tab:hover {
  border-color: var(--primary);
  color: var(--primary);
}

.outils-tabs__tab.is-active {
  border-color: var(--primary);
  background: var(--neutral-0);
  color: var(--primary);
  border-bottom: 2px solid var(--neutral-0);
  margin-bottom: -2px;
}

.outils-tabs__panel {
  display: none;
}

.outils-tabs__panel.is-active {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  background: var(--neutral-0);
  border: 2px solid var(--primary);
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
  padding: var(--space-lg);
  box-shadow: var(--shadow-md);
  animation: fadeInPanel 0.3s ease-out;
}

@keyframes fadeInPanel {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.outils-tabs__content h3 {
  font-family: var(--font-display);
  font-size: var(--text-base);
  margin-bottom: var(--space-xs);
  color: var(--neutral-900);
}

.outils-tabs__content p {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--neutral-600);
  margin: 0 0 var(--space-sm);
}

.outils-tabs__content p:last-child {
  margin-bottom: 0;
}

.outils-tabs__carousel {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--neutral-50);
  border: 1px solid var(--neutral-200);
  aspect-ratio: 16 / 9;
  position: relative;
}

@media (min-width: 768px) {
  .outils-tabs__panel.is-active {
    flex-direction: row;
    align-items: center;
    gap: var(--space-3xl);
    padding: var(--space-2xl);
  }

  .outils-tabs__content {
    flex: 0 0 40%;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .outils-tabs__content h3 {
    font-size: var(--text-xl);
    margin-bottom: var(--space-md);
  }

  .outils-tabs__content p {
    font-size: var(--text-base);
    line-height: 1.7;
  }

  .outils-tabs__carousel {
    flex: 1;
    min-width: 0;
    aspect-ratio: 16 / 9;
  }
}

/* Carousel engine */
.outil-carousel {
  display: flex;
  flex-direction: column;
}

.outil-carousel__track {
  display: flex;
  flex: 1;
  min-height: 0;
  width: 100%;
  transition: transform 0.4s ease-out;
  will-change: transform;
}

.outil-carousel__slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  min-width: 0;
}

.outil-carousel__slide--banner {
  position: relative;
}

.carousel-banner {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block;
  padding: var(--space-xs) var(--space-md);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--neutral-0);
  background: rgba(29, 29, 27, 0.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 100px;
  white-space: nowrap;
  z-index: 1;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
}

@media (max-width: 480px) {
  .carousel-banner {
    font-size: 0.65rem;
    padding: 0.35rem var(--space-sm);
    bottom: 2rem;
  }
}

.carousel-banner--fixed {
  position: absolute;
  bottom: 2.5rem;
  top: auto;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  font-size: 0.7rem;
  background: rgba(29, 29, 27, 0.7);
}

@media (max-width: 480px) {
  .carousel-banner--fixed {
    font-size: 0.6rem;
    bottom: 2rem;
  }
}

.outil-carousel__slide img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  image-rendering: -webkit-optimize-contrast;
}

.outil-carousel--questlab .outil-carousel__slide {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--neutral-100);
}

.outil-carousel--questlab .outil-carousel__slide img {
  object-fit: contain;
  width: 92%;
  height: 88%;
  border-radius: var(--radius-md);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

#panel-kickstart .outil-carousel__slide:first-child img {
  object-position: center 25%;
}

.outil-carousel__dots {
  position: absolute;
  bottom: var(--space-sm);
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  z-index: 2;
}

.outil-carousel__dots .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  border: 2px solid rgba(255, 255, 255, 0.8);
  padding: 0;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
}

.outil-carousel__dots .dot.is-active {
  background: var(--neutral-0);
  border-color: var(--neutral-0);
  transform: scale(1.3);
}

/* Mobile : stack les onglets */
@media (max-width: 480px) {
  .outils-tabs__nav {
    flex-direction: column;
    gap: var(--space-sm);
  }

  .outils-tabs__tab {
    max-width: none;
    border-radius: var(--radius-lg);
    border-bottom: 2px solid var(--neutral-200);
  }

  .outils-tabs__tab.is-active {
    border-bottom: 2px solid var(--primary);
    margin-bottom: 0;
  }

  .outils-tabs__panel.is-active {
    border-radius: var(--radius-xl);
    margin-top: var(--space-md);
  }
}

/* =============================================
   Timeline 5 étapes — vraie timeline alternée
   ============================================= */

.etapes-timeline {
  position: relative;
  max-width: 56rem;
  margin-inline: auto;
  padding-left: 44px;
}

.etapes-timeline::before {
  content: '';
  position: absolute;
  left: 14px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--primary), var(--accent-warm));
  border-radius: 2px;
}

.etapes-timeline__item {
  position: relative;
  padding-bottom: var(--space-lg);
}

.etapes-timeline__item:last-child {
  padding-bottom: 0;
}

.etapes-timeline__number {
  position: absolute;
  left: -44px;
  top: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  box-shadow: 0 0 0 4px var(--neutral-100);
}

.etapes-timeline__number span {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--neutral-0);
  line-height: 1;
}

.etapes-timeline__card {
  background: var(--neutral-0);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-md);
  border-left: 3px solid var(--primary);
  transition: transform var(--duration-base) var(--ease-out),
    box-shadow var(--duration-base) var(--ease-out);
}

@media (hover: hover) {
  .etapes-timeline__card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
  }
}

.etapes-timeline__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin: 0 0 var(--space-sm);
  color: var(--neutral-900);
}

.etapes-timeline__body p {
  margin-bottom: var(--space-xs);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.etapes-timeline__body p:last-child {
  margin-bottom: 0;
}

.etapes-timeline__impact {
  margin-top: var(--space-sm);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--neutral-200);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  font-weight: 600;
}

.etapes-timeline__impact p {
  margin: 0 0 var(--space-xs);
}

.etapes-timeline__impact p:last-child {
  margin-bottom: 0;
}

.etapes-timeline__benefit--r {
  color: var(--primary);
}

.etapes-timeline__benefit--c {
  color: var(--accent-warm);
}

/* Tablet : tailles intermédiaires */
@media (min-width: 768px) {
  .etapes-timeline {
    padding-left: 72px;
  }

  .etapes-timeline::before {
    left: 24px;
    width: 3px;
  }

  .etapes-timeline__item {
    padding-bottom: var(--space-2xl);
  }

  .etapes-timeline__number {
    left: -72px;
    width: 48px;
    height: 48px;
    box-shadow: 0 0 0 6px var(--neutral-100);
  }

  .etapes-timeline__number span {
    font-size: var(--text-lg);
  }

  .etapes-timeline__card {
    padding: var(--space-xl) var(--space-2xl);
    border-radius: var(--radius-xl);
    border-left-width: 4px;
  }

  .etapes-timeline__title {
    font-size: var(--text-xl);
    margin-bottom: var(--space-md);
  }

  .etapes-timeline__body p {
    font-size: var(--text-base);
    margin-bottom: var(--space-sm);
  }

  .etapes-timeline__impact {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    font-size: var(--text-sm);
  }
}

/* Étape 3 — card avec image intégrée */
.etapes-timeline__card--visual {
  padding: 0;
  overflow: hidden;
  border-left: none;
}

.etapes-timeline__card--visual .etapes-timeline__card-text {
  padding: var(--space-xl) var(--space-2xl);
  border-left: 4px solid var(--primary);
}

.etapes-timeline__card-img {
  margin: 0 var(--space-xl) var(--space-xl);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--neutral-200);
  aspect-ratio: 16 / 9;
}

.etapes-timeline__card-img img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center bottom;
}

/* Desktop : timeline centrée avec alternance gauche/droite */
@media (min-width: 1100px) {
  .etapes-timeline {
    padding-left: 0;
  }

  .etapes-timeline::before {
    left: 50%;
    transform: translateX(-50%);
  }

  .etapes-timeline__item {
    padding-left: 0;
    width: 50%;
    padding-right: var(--space-3xl);
  }

  .etapes-timeline__item .etapes-timeline__card {
    border-left: none;
    border-right: 4px solid var(--primary);
  }

  .etapes-timeline__item .etapes-timeline__card--visual .etapes-timeline__card-text {
    border-left: none;
    border-right: 4px solid var(--primary);
  }

  .etapes-timeline__number {
    left: auto;
    right: -24px;
    box-shadow: 0 0 0 6px var(--neutral-100);
  }

  /* Items à droite */
  .etapes-timeline__item--right {
    margin-left: 50%;
    padding-right: 0;
    padding-left: var(--space-3xl);
  }

  .etapes-timeline__item--right .etapes-timeline__card {
    border-right: none;
    border-left: 4px solid var(--primary);
  }

  .etapes-timeline__item--right .etapes-timeline__card--visual .etapes-timeline__card-text {
    border-right: none;
    border-left: 4px solid var(--primary);
  }

  .etapes-timeline__item--right .etapes-timeline__number {
    right: auto;
    left: -24px;
  }
}

/* =============================================
   Pipeline Algorithme CCC
   ============================================= */

.algo-pipeline {
  max-width: 56rem;
  margin: var(--space-2xl) auto 0;
  background: var(--neutral-0);
  border-radius: var(--radius-xl);
  padding: var(--space-lg);
  box-shadow: var(--shadow-md);
}

.algo-pipeline__header {
  text-align: center;
  margin-bottom: var(--space-lg);
}

.algo-pipeline__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
}

@media (min-width: 768px) {
  .algo-pipeline {
    margin-top: var(--space-3xl);
    padding: var(--space-2xl);
  }

  .algo-pipeline__header {
    margin-bottom: var(--space-2xl);
  }

  .algo-pipeline__title {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-sm);
  }
}

.algo-pipeline__subtitle {
  color: var(--neutral-600);
  max-width: 36rem;
  margin-inline: auto;
  font-size: var(--text-sm);
}

@media (min-width: 768px) {
  .algo-pipeline__subtitle {
    font-size: var(--text-base);
  }
}

.algo-pipeline__steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  align-items: start;
}

.algo-pipeline__arrow {
  display: none;
}

@media (min-width: 768px) {
  .algo-pipeline__steps {
    grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
    gap: var(--space-md);
    align-items: center;
  }

  .algo-pipeline__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-xl);
    color: var(--neutral-400);
    font-weight: 700;
  }
}

.algo-pipeline__step {
  text-align: center;
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background: var(--neutral-50);
  border: 1px solid var(--neutral-200);
  transition: transform var(--duration-base) var(--ease-out),
    box-shadow var(--duration-base) var(--ease-out);
}

@media (min-width: 768px) {
  .algo-pipeline__step {
    padding: var(--space-lg);
  }
}

@media (hover: hover) {
  .algo-pipeline__step:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
  }
}

.algo-pipeline__step--result {
  background: var(--neutral-0);
  border: 2px solid var(--primary);
}

.algo-pipeline__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--accent-warm);
  color: var(--neutral-0);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: var(--text-base);
  margin-bottom: var(--space-md);
}

.algo-pipeline__step--result .algo-pipeline__number {
  background: var(--primary);
  color: var(--neutral-0);
}

.algo-pipeline__step h4 {
  font-size: var(--text-base);
  font-weight: 700;
  margin-bottom: var(--space-xs);
  color: var(--neutral-900);
}

.algo-pipeline__step p {
  font-size: var(--text-sm);
  margin: 0;
  color: var(--neutral-600);
  line-height: 1.5;
}

/* =============================================
   Section "Ce que CoQuest change concrètement"
   ============================================= */

.changements-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  max-width: 56rem;
  margin-inline: auto;
}

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

  .changements-grid .changement-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: 50%;
    justify-self: center;
  }
}

.changement-card {
  background: var(--neutral-0);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  border-top: 3px solid var(--primary);
  transition: transform var(--duration-base) var(--ease-out),
    box-shadow var(--duration-base) var(--ease-out);
}

@media (hover: hover) {
  .changement-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
  }
}

.changement-card__problem {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  margin: 0 0 var(--space-md);
  color: var(--neutral-900);
}

/* Comparison : Avant | CoQuest côte à côte avec séparateur */
.changement-card__comparison {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 0;
  margin-bottom: var(--space-md);
}

.changement-card__comparison::before {
  content: '';
  grid-column: 2;
  grid-row: 1;
  background: var(--neutral-200);
  width: 1px;
  height: 100%;
}

.changement-card__before,
.changement-card__after {
  font-size: var(--text-sm);
  line-height: 1.5;
  margin: 0;
  padding: var(--space-sm) var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  min-width: 0;
}

.changement-card__before span,
.changement-card__after span {
  display: inline-block;
  width: fit-content;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 2px var(--space-sm);
  border-radius: var(--radius-md);
  line-height: 1.6;
  margin-bottom: var(--space-xs);
}

.changement-card__before {
  color: var(--neutral-600);
}

.changement-card__before span {
  background: var(--neutral-200);
  color: var(--neutral-600);
}

.changement-card__after {
  color: var(--neutral-900);
}

.changement-card__after span {
  background: color-mix(in srgb, var(--primary) 12%, transparent);
  color: var(--primary);
}

/* Bénéfices Recruteur / Candidat avec badges */
.changement-card__benefits {
  margin-top: var(--space-sm);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--neutral-200);
  font-size: var(--text-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.changement-card__benefits p {
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: var(--space-sm);
}

.changement-card__benefits p strong {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 1px var(--space-sm);
  border-radius: var(--radius-md);
  white-space: nowrap;
  flex-shrink: 0;
}

.changement-card__benefits .etapes-timeline__benefit--r strong {
  background: color-mix(in srgb, var(--primary) 10%, transparent);
  color: var(--primary);
}

.changement-card__benefits .etapes-timeline__benefit--c strong {
  background: color-mix(in srgb, var(--accent-warm) 10%, transparent);
  color: var(--accent-warm);
}

@media (min-width: 768px) {
  .changement-card {
    padding: var(--space-xl);
  }

  .changement-card__problem {
    font-size: var(--text-lg);
  }
}

/* =============================================
   Preuve sociale
   ============================================= */

.methode-proof__grid {
  display: grid;
  gap: var(--space-lg);
  max-width: var(--max-width);
  margin-inline: auto;
}

.methode-proof__quote {
  padding: var(--space-lg);
  background: var(--neutral-0);
  border-radius: var(--radius-lg);
  border-left: 4px solid var(--accent-warm);
  box-shadow: var(--shadow-sm);
}

.methode-proof__quote p {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-style: italic;
  color: var(--neutral-800);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-sm);
}

.methode-proof__quote footer {
  display: flex;
  align-items: baseline;
  gap: var(--space-xs);
}

.methode-proof__quote cite {
  font-style: normal;
  font-weight: 700;
  color: var(--primary-dark);
  font-size: var(--text-sm);
}

.methode-proof__quote footer span {
  color: var(--neutral-500);
  font-size: var(--text-sm);
}

@media (min-width: 768px) {
  .methode-proof__grid {
    grid-template-columns: 1fr 1fr;
  }

  .methode-proof__quote p {
    font-size: var(--text-lg);
  }
}

/* =============================================
   CTA final fusionné (offres + démo)
   ============================================= */

.methode-cta-final__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

.methode-cta-final__offres {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
  width: 100%;
}

.methode-cta-final__offres .btn {
  width: 100%;
  text-align: center;
  justify-content: center;
}

.methode-cta-final__separator {
  color: rgba(255, 255, 255, 0.6);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  margin: 0;
}

.methode-cta-final__demo {
  color: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.3);
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  transition: background-color var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.methode-cta-final__demo:hover {
  background-color: rgba(255, 255, 255, 0.15);
  color: var(--neutral-0);
}

@media (min-width: 768px) {
  .methode-cta-final__actions {
    gap: var(--space-lg);
  }

  .methode-cta-final__offres {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: none;
    width: auto;
    gap: var(--space-md);
  }

  .methode-cta-final__offres .btn {
    width: auto;
  }

  .methode-cta-final__separator {
    font-size: var(--text-lg);
  }

  .methode-cta-final__demo {
    font-size: var(--text-lg);
  }
}
