    /* ===== Story section ===== */
    .story {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 64px;
      align-items: center;
      position: relative;
    }
    .story-text .eyebrow {
      display: inline-block;
      font-size: .76rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .14em;
      color: var(--terra);
      margin-bottom: 14px;
    }
    .story-text h2 {
      margin-bottom: 22px;
      color: var(--forest);
      font-size: clamp(1.6rem, 2.6vw, 2.1rem);
    }
    [data-theme="dark"] .story-text h2 { color: var(--text); }
    .story-text h2 em { font-style: italic; color: var(--terra); font-weight: 500; }
    .story-text p { color: var(--text-soft); margin-bottom: 14px; line-height: 1.75; font-size: 1rem; }
    .story-text strong { color: var(--text); font-weight: 700; }

    .story-visual {
      position: relative;
      aspect-ratio: 4/5;
      max-height: 520px;
    }
    .story-visual img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: 24px;
      box-shadow: 0 30px 60px -20px rgba(27,67,50,.35);
    }
    .story-visual::after {
      content: '';
      position: absolute;
      inset: 12px -12px -12px 12px;
      border: 2px solid var(--terra);
      border-radius: 24px;
      z-index: -1;
      opacity: .5;
    }
    .story-badge {
      position: absolute;
      bottom: 24px; left: -24px;
      background: var(--surface);
      padding: 14px 20px 14px 16px;
      border-radius: 18px;
      box-shadow: 0 14px 32px -8px rgba(27,67,50,.25);
      display: flex;
      align-items: center;
      gap: 14px;
      max-width: 240px;
    }
    [data-theme="dark"] .story-badge { background: var(--surface); border: 1px solid var(--border); }
    .story-badge .ic {
      width: 40px; height: 40px;
      background: rgba(231,111,81,.14);
      color: var(--terra);
      border-radius: 12px;
      display: grid; place-items: center;
      font-size: 1.05rem;
      flex-shrink: 0;
    }
    .story-badge .lbl { font-size: .76rem; color: var(--text-mute); }
    .story-badge .val { font-weight: 700; color: var(--text); font-size: .92rem; }

    /* ===== Stat strip — cards séparées avec gradient subtil ===== */
    .stat-strip {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
    }
    .stat-card-v3 {
      position: relative;
      padding: 28px 22px;
      background: #1B4332;
      background-image: linear-gradient(135deg, #1B4332 0%, #143727 100%);
      color: var(--cream);
      border-radius: 22px;
      overflow: hidden;
      transition: transform var(--t);
    }
    .stat-card-v3:hover { transform: translateY(-4px); }
    .stat-card-v3:nth-child(2) { background: #C95A3D; background-image: linear-gradient(135deg, #E76F51 0%, #C95A3D 100%); }
    .stat-card-v3:nth-child(3) { background: #B8800B; background-image: linear-gradient(135deg, #F4A300 0%, #B8800B 100%); color: #0F1B16; }
    .stat-card-v3:nth-child(4) { background: #143727; background-image: linear-gradient(135deg, #2D6A4F 0%, #143727 100%); }
    .stat-card-v3::before {
      content: '';
      position: absolute;
      top: -40px; right: -40px;
      width: 130px; height: 130px;
      background: radial-gradient(circle, rgba(255,255,255,.12), transparent 60%);
      filter: blur(20px);
    }
    .stat-card-v3 .ic {
      width: 38px; height: 38px;
      background: rgba(255,255,255,.16);
      color: var(--cream);
      border-radius: 12px;
      display: grid; place-items: center;
      font-size: .92rem;
      margin-bottom: 14px;
      position: relative;
    }
    .stat-card-v3:nth-child(3) .ic { background: rgba(15,27,22,.18); color: #0F1B16; }
    .stat-card-v3 .num {
      font-family: 'Fraunces', serif;
      font-size: 2.4rem;
      font-weight: 700;
      line-height: 1;
      letter-spacing: -0.02em;
      position: relative;
    }
    .stat-card-v3 .lbl {
      font-size: .88rem;
      opacity: .85;
      margin-top: 6px;
      position: relative;
    }
    .stat-card-v3:nth-child(3) .lbl { opacity: .75; }

    /* ===== Timeline modernisée ===== */
    .timeline-wrap {
      max-width: 760px;
      margin: 0 auto;
      position: relative;
    }
    .timeline {
      position: relative;
      padding-left: 44px;
    }
    .timeline::before {
      content: '';
      position: absolute;
      left: 18px; top: 12px; bottom: 12px;
      width: 2px;
      background: linear-gradient(180deg, var(--terra), var(--gold), var(--forest-3));
      border-radius: 2px;
    }
    .tl-item {
      position: relative;
      padding: 22px 24px;
      margin-bottom: 16px;
      background: var(--surface);
      border: 1px solid var(--border-soft);
      border-radius: 18px;
      transition: border-color var(--t), box-shadow var(--t), transform var(--t);
    }
    [data-theme="dark"] .tl-item { background: var(--surface); border-color: var(--border); }
    .tl-item:hover {
      transform: translateX(4px);
      border-color: var(--terra);
      box-shadow: 0 14px 32px -10px rgba(231,111,81,.25);
    }
    .tl-item::before {
      content: '';
      position: absolute;
      left: -34px; top: 26px;
      width: 14px; height: 14px;
      background: var(--terra);
      border-radius: 50%;
      border: 3px solid var(--bg);
      box-shadow: 0 0 0 3px var(--terra);
    }
    .tl-item::after {
      content: '';
      position: absolute;
      left: -22px; top: 32px;
      width: 22px;
      height: 2px;
      background: var(--terra);
      opacity: .5;
    }
    .tl-year {
      display: inline-block;
      font-family: 'Fraunces', serif;
      font-weight: 700;
      color: var(--terra);
      margin-bottom: 8px;
      font-size: 1.15rem;
      letter-spacing: -0.01em;
    }
    .tl-item h4 { margin-bottom: 6px; color: var(--forest); }
    [data-theme="dark"] .tl-item h4 { color: var(--text); }
    .tl-item p { color: var(--text-soft); line-height: 1.6; font-size: .95rem; }

    /* ===== Section title centered ===== */
    .section-title-c {
      text-align: center;
      max-width: 560px;
      margin: 0 auto 40px;
    }
    .section-title-c .eyebrow {
      font-size: .76rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .14em;
      color: var(--terra);
      margin-bottom: 12px;
      display: block;
    }
    .section-title-c h2 {
      color: var(--forest);
      margin-bottom: 12px;
    }
    [data-theme="dark"] .section-title-c h2 { color: var(--text); }
    .section-title-c h2 em { font-style: italic; color: var(--terra); font-weight: 500; }
    .section-title-c p { color: var(--text-soft); font-size: 1rem; }

    @media (max-width: 968px) {
      .story { grid-template-columns: 1fr; gap: 40px; }
      .story-visual { aspect-ratio: 16/10; max-height: 400px; }
      .story-badge { bottom: -24px; left: 16px; }
      .stat-strip { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 600px) {
      .stat-strip { grid-template-columns: 1fr 1fr; gap: 12px; }
      .stat-card-v3 { padding: 22px 18px; }
      .stat-card-v3 .num { font-size: 1.9rem; }
      .timeline { padding-left: 36px; }
      .tl-item::before { left: -29px; }
      .tl-item::after { left: -17px; width: 16px; }
    }
