/* About page (CMS id 10) — ported from maquette about.html */
/* ════════════════════════════════
       ABOUT PAGE
    ════════════════════════════════ */

    /* ── HERO ── */
    .about-hero {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(48px,7vw,108px) var(--g) clamp(22px,3vw,44px);
      overflow: hidden;
    }
.about-hero__label {
      font: 300 8px/1 var(--fb); letter-spacing: .28em; text-transform: uppercase;
      color: rgba(12,12,12,.3); margin-bottom: clamp(20px,2.8vw,38px);
    }
.about-hero__inner {
      display: flex; align-items: flex-end; justify-content: space-between;
      gap: clamp(16px,3vw,48px);
    }
.about-hero__title {
      font-family: var(--fd); font-size: clamp(68px,14vw,196px);
      letter-spacing: .01em; text-transform: uppercase; color: var(--dk); line-height: .82;
      flex-shrink: 0;
    }
.about-hero__right {
      text-align: right; flex-shrink: 0; padding-bottom: .2em; max-width: 340px;
    }
.about-hero__deck {
      font-family: var(--fb); font-weight: 300;
      font-size: clamp(13px,1.2vw,16px); line-height: 1.75; color: rgba(12,12,12,.45);
      letter-spacing: .02em;
      margin-bottom: 16px;
    }
.about-hero__meta {
      font: 300 7.5px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase;
      color: rgba(12,12,12,.26);
    }
.about-hero__rule { border: none; border-top: 2px solid var(--dk); margin: 0; }
/* ── INTRO ── */
    .about-intro {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(52px,6.5vw,96px) var(--g);
      display: grid; grid-template-columns: 1fr 1fr;
      gap: clamp(32px,6vw,96px); align-items: start;
      border-bottom: 1px solid var(--border);
    }
.about-intro__left {}
.about-intro__overline {
      font: 300 8px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase;
      color: rgba(12,12,12,.3); margin-bottom: clamp(16px,2vw,24px);
    }
.about-intro__p {
      font-family: var(--fb); font-weight: 300;
      font-size: clamp(13px,1.2vw,15px); line-height: 1.85;
      color: rgba(12,12,12,.68); letter-spacing: .01em;
    }
.about-intro__p + .about-intro__p { margin-top: 20px; }
.about-intro__right {
      padding-top: clamp(8px,1vw,14px);
    }
.about-intro__pq {
      border-left: 2px solid var(--dk); padding-left: clamp(20px,2.5vw,34px);
    }
.about-intro__pq-mark {
      font-family: var(--fi); font-size: clamp(72px,8vw,108px);
      line-height: .55; color: rgba(12,12,12,.07); display: block;
      margin-bottom: 4px; user-select: none;
    }
.about-intro__pq-text {
      font-family: var(--fi); font-style: italic; font-weight: 300;
      font-size: clamp(18px,2vw,26px); line-height: 1.5; color: var(--dk);
    }
/* ── THREE PILLARS ── */
    .about-pillars {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(52px,6.5vw,96px) var(--g);
    }
.about-pillars__header {
      display: flex; align-items: baseline; justify-content: space-between;
      margin-bottom: clamp(36px,4.5vw,68px);
    }
.about-pillars__label { font: 300 8px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase; color: rgba(12,12,12,.3); }
.about-pillars__h { font-family: var(--fd); font-size: clamp(44px,6vw,88px); letter-spacing: .02em; text-transform: uppercase; color: var(--dk); line-height: .88; }
.about-pillars__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; }
.pillar {
      padding: clamp(28px,3.5vw,52px) clamp(20px,2.5vw,40px);
      border-top: 2px solid var(--dk); border-right: 1px solid var(--border);
      display: flex; flex-direction: column;
    }
.pillar:last-child { border-right: none; }
.pillar__num { font: 300 9px/1 var(--fb); letter-spacing: .08em; color: rgba(12,12,12,.2); margin-bottom: 20px; display: block; }
.pillar__title {
      font-family: var(--fd); font-size: clamp(24px,3vw,40px);
      letter-spacing: .02em; text-transform: uppercase; color: var(--dk); line-height: .9;
      margin-bottom: clamp(16px,2vw,26px);
      min-height: calc(clamp(24px,3vw,40px) * 2.4);
      display: flex; align-items: flex-start;
    }
.pillar__p {
      font-family: var(--fb); font-weight: 300;
      font-size: clamp(12px,1.1vw,14px); line-height: 1.9;
      color: rgba(12,12,12,.58); letter-spacing: .01em;
    }
.pillar__p + .pillar__p { margin-top: 14px; }
.pillar__stat {
      display: block; margin-top: auto; padding-top: clamp(20px,2.5vw,32px);
      font-family: var(--fd); font-size: clamp(40px,5vw,64px);
      letter-spacing: .01em; color: rgba(12,12,12,.08); line-height: 1;
    }
/* ── MARQUEE ── */
    .about-marquee {
      overflow: hidden; border-bottom: 1px solid var(--border);
      padding: 15px 0; user-select: none;
    }
.about-marquee__track {
      display: inline-flex; align-items: center; gap: 0;
      animation: mqRun 32s linear infinite;
      white-space: nowrap;
    }
.about-marquee:hover .about-marquee__track { animation-play-state: paused; }
.mq-w { font: 300 8.5px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase; color: rgba(12,12,12,.28); padding: 0 24px; }
.mq-d { color: rgba(12,12,12,.12); padding: 0; }
/* ── BW INTERLUDE ── */
    .about-bw {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      overflow: hidden; padding: clamp(28px,4vw,56px) var(--g);
    }
.about-bw__duo {
      max-width: var(--mw); margin: 0 auto;
      display: grid; grid-template-columns: 1fr 1fr;
      gap: clamp(12px,2vw,28px);
    }
.about-bw__fig { display: flex; flex-direction: column; gap: 14px; }
.about-bw__frame {
      height: clamp(280px,38vh,460px); overflow: hidden;
      position: relative;
    }
.about-bw img {
      width: 100%; height: 115%; object-fit: cover; object-position: center 20%;
      display: block; filter: grayscale(0.25); opacity: .9;
      will-change: transform; transform: translateY(0);
    }
.about-bw__cap {
      font: 300 8px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase;
      color: rgba(12,12,12,.32); text-align: center;
    }
@media (max-width: 600px) {
  .about-bw__duo { grid-template-columns: 1fr; }
}
/* ── PILLAR IMAGE ── */
    .pillar__img {
      width: 100%; aspect-ratio: 16/9; overflow: hidden;
      margin-bottom: clamp(18px,2.5vw,28px);
    }
.pillar__img img { width: 100%; height: 115%; object-fit: cover; display: block; will-change: transform; }
.pillar:nth-child(2) .pillar__img img,
    .pillar:nth-child(3) .pillar__img img { filter: grayscale(0.55); }
/* ── MANIFESTO (dark) ── */
    .about-manifesto {
      background: var(--dk); color: #fff;
      padding: clamp(68px,8.5vw,128px) var(--g);
    }
.about-manifesto__inner { max-width: var(--mw); margin: 0 auto; }
.about-manifesto__label {
      font: 300 8px/1 var(--fb); letter-spacing: .28em; text-transform: uppercase;
      color: rgba(255,255,255,.22); margin-bottom: clamp(24px,3vw,42px);
    }
.about-manifesto__text {
      font-family: var(--fd); font-size: clamp(36px,6.5vw,96px);
      letter-spacing: .015em; text-transform: uppercase; color: #fff; line-height: .9;
      max-width: 1100px;
    }
.about-manifesto__text em {
      font-style: normal; color: rgba(255,255,255,.2);
    }
.about-manifesto__sub {
      font-family: var(--fb); font-weight: 300;
      font-size: clamp(12px,1.1vw,14px);
      line-height: 1.85; letter-spacing: .03em;
      color: rgba(255,255,255,.38);
      max-width: 600px; margin-top: clamp(32px,4vw,56px);
    }
/* ── TECHNICAL SPECS ── */
    .about-specs {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(52px,6.5vw,96px) var(--g);
      border-bottom: 1px solid var(--border);
    }
.about-specs__header { margin-bottom: clamp(36px,4.5vw,64px); }
.about-specs__label { font: 300 8px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase; color: rgba(12,12,12,.3); margin-bottom: 16px; }
.about-specs__h { font-family: var(--fd); font-size: clamp(40px,5.5vw,80px); letter-spacing: .02em; text-transform: uppercase; color: var(--dk); line-height: .88; }
.about-specs__grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 0 clamp(40px,6vw,96px); }
.spec-group { border-top: 1px solid var(--border); padding-top: clamp(22px,2.8vw,36px); margin-bottom: clamp(28px,3.5vw,48px); }
.spec-group__title { font: 300 8.5px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase; color: var(--dk); margin-bottom: 20px; }
.spec-row {
      display: flex; justify-content: space-between; align-items: baseline;
      padding: 10px 0; border-bottom: 1px solid var(--border);
      gap: 16px;
    }
.spec-row:last-child { border-bottom: none; }
.spec-row__key { font: 300 11px/1.4 var(--fb); letter-spacing: .06em; color: rgba(12,12,12,.5); }
.spec-row__val { font-family: var(--fi); font-size: 14px; color: var(--dk); font-style: italic; text-align: right; }
/* ── STATS ── */
    .about-stats {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(52px,6.5vw,96px) var(--g);
      display: grid; grid-template-columns: repeat(4,1fr); gap: 0;
      border-bottom: 2px solid var(--dk);
    }
.stat {
      border-right: 1px solid var(--border); padding: clamp(20px,2.5vw,36px) clamp(20px,2.5vw,36px) clamp(20px,2.5vw,36px) 0;
    }
.stat:last-child { border-right: none; padding-right: 0; }
.stat:not(:first-child) { padding-left: clamp(20px,2.5vw,36px); }
.stat__num {
      font-family: var(--fd); font-size: clamp(52px,7vw,96px);
      letter-spacing: .01em; color: var(--dk); line-height: .85;
      margin-bottom: 14px; display: block;
    }
.stat__label { font: 300 8px/1.5 var(--fb); letter-spacing: .18em; text-transform: uppercase; color: rgba(12,12,12,.38); }
/* ── COUPE ── */
    .about-coupe {
      border-top: 1px solid var(--border);
      padding: clamp(52px,7vw,108px) var(--g);
    }
.about-coupe__inner {
      max-width: var(--mw); margin: 0 auto;
      display: grid; grid-template-columns: 1fr 1fr;
      gap: clamp(36px,6vw,96px); align-items: center;
    }
.about-coupe__img-wrap {
      position: relative;
    }
.about-coupe__img-wrap img {
      width: 100%; height: auto; display: block;
      filter: grayscale(1);
    }
.about-coupe__label {
      font: 300 8px/1 var(--fb); letter-spacing: .28em; text-transform: uppercase;
      color: rgba(12,12,12,.3); margin-bottom: clamp(20px,2.5vw,32px);
    }
.about-coupe__h {
      font-family: var(--fd); font-size: clamp(40px,5.5vw,80px);
      letter-spacing: .015em; text-transform: uppercase; color: var(--dk);
      line-height: .88; margin-bottom: clamp(20px,2.5vw,32px);
    }
.about-coupe__desc {
      font-family: var(--fb); font-weight: 300;
      font-size: clamp(13px,1.2vw,15px); line-height: 1.85;
      color: rgba(12,12,12,.62); letter-spacing: .01em;
      margin-bottom: clamp(28px,3.5vw,48px);
    }
.about-coupe__rule { border: none; border-top: 1px solid var(--border); margin-bottom: clamp(28px,3.5vw,48px); }
.about-coupe__q {
      border-left: 2px solid var(--dk); padding-left: clamp(18px,2vw,28px);
    }
.about-coupe__q-intro {
      font-family: var(--fi); font-style: italic;
      font-size: clamp(16px,1.6vw,20px); line-height: 1.5; color: var(--dk);
      margin-bottom: 18px;
    }
.about-coupe__q-body {
      font-family: var(--fb); font-weight: 300;
      font-size: clamp(12px,1.1vw,14px); line-height: 1.9;
      color: rgba(12,12,12,.52); letter-spacing: .01em;
    }
@media (max-width: 768px) {
  .about-coupe__inner { grid-template-columns: 1fr; }
}
/* ── CTA ── */
    .about-cta {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(68px,8vw,120px) var(--g);
      text-align: center;
    }
.about-cta__label { font: 300 8px/1 var(--fb); letter-spacing: .28em; text-transform: uppercase; color: rgba(12,12,12,.3); margin-bottom: 20px; }
.about-cta__h { font-family: var(--fd); font-size: clamp(40px,5.5vw,80px); letter-spacing: .02em; text-transform: uppercase; color: var(--dk); line-height: .88; margin-bottom: clamp(20px,2.5vw,36px); }
.about-cta__p { font-family: var(--fi); font-style: italic; font-size: clamp(15px,1.4vw,18px); line-height: 1.7; color: rgba(12,12,12,.45); max-width: 520px; margin: 0 auto clamp(28px,3.5vw,48px); }
.about-cta__links { display: flex; align-items: center; justify-content: center; gap: 20px; flex-wrap: wrap; }
.about-cta__btn {
      display: inline-flex; align-items: center; gap: 10px;
      padding: 14px 32px;
      font: 300 9px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase;
      border: 1px solid var(--dk); color: var(--dk); transition: all .22s;
    }
.about-cta__btn:hover { background: var(--dk); color: #fff; }
.about-cta__btn--filled { background: var(--dk); color: #fff; }
.about-cta__btn--filled:hover { background: transparent; color: var(--dk); }
.about-cta__btn svg { width: 12px; height: 12px; stroke: currentColor; stroke-width: 1.5; fill: none; }
/* ── HERO TITLE CLIP REVEAL ── */
    .about-hero__title {
      animation: titleClip 1.4s .15s cubic-bezier(.22,1,.36,1) both;
    }
.about-hero__rule {
      transform-origin: left;
      animation: ruleGrow 1.2s .8s cubic-bezier(.22,1,.36,1) both;
    }
/* ── PILLAR HOVER ── */
    .pillar { transition: background .28s ease; cursor: default; }
.pillar:hover { background: rgba(12,12,12,.024); }
.pillar__stat { transition: opacity .3s, font-size .35s cubic-bezier(.22,1,.36,1), color .3s; }
.pillar:hover .pillar__stat { opacity: .16; font-size: clamp(52px,6.8vw,88px); }
.stat__num.counted { animation: statCountDone .7s .05s ease; }
/* ── SPEC ROW HOVER ── */
    .spec-row { position: relative; overflow: hidden; transition: background .18s, padding-left .22s cubic-bezier(.22,1,.36,1); }
.spec-row::before {
      content: ''; position: absolute; left: 0; top: 2px; bottom: 2px;
      width: 2px; background: var(--dk);
      transform: scaleY(0); transform-origin: bottom;
      transition: transform .22s cubic-bezier(.22,1,.36,1);
    }
.spec-row:hover { background: rgba(12,12,12,.025); padding-left: 10px; }
.spec-row:hover::before { transform: scaleY(1); }
/* ── MANIFESTO ATMOSPHERIC ── */
    .about-manifesto { position: relative; overflow: hidden; }
.about-manifesto::before {
      content: ''; position: absolute; inset: 0; pointer-events: none;
      background: radial-gradient(ellipse 65% 65% at 25% 35%, rgba(255,255,255,.055) 0%, transparent 68%);
      animation: mfGlow 14s ease-in-out infinite alternate;
    }
/* ── MARQUEE EDGE FADE ── */
    .about-marquee {
      -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 7%, black 93%, transparent 100%);
      mask-image: linear-gradient(90deg, transparent 0%, black 7%, black 93%, transparent 100%);
    }
/* ── PRICE BREAKDOWN ── */
    .about-price {
      max-width: var(--mw); margin: 0 auto;
      padding: clamp(52px,6.5vw,96px) var(--g);
      border-bottom: 1px solid var(--border);
    }
.about-price__header { margin-bottom: clamp(36px,4.5vw,64px); display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.about-price__label { font: 300 8px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase; color: rgba(12,12,12,.3); }
.about-price__h { font-family: var(--fd); font-size: clamp(40px,5.5vw,80px); letter-spacing: .02em; text-transform: uppercase; color: var(--dk); line-height: .88; }
.about-price__inner {
      display: grid; grid-template-columns: 1.1fr 0.9fr;
      gap: clamp(32px,5vw,80px); align-items: center;
    }
.about-price__chart-wrap {
      position: relative; width: 100%;
    }
.about-price__chart-wrap svg { width: 100%; height: auto; display: block; }
.about-price__p {
      font-family: var(--fi); font-style: italic; font-size: clamp(14px,1.3vw,17px);
      line-height: 1.85; color: rgba(12,12,12,.52);
      margin-bottom: clamp(24px,3vw,36px);
    }
.about-price__center {
      position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
      text-align: center; pointer-events: none; user-select: none;
    }
.about-price__center-num { font-family: var(--fd); font-size: clamp(44px,5.5vw,68px); color: var(--dk); line-height: 1; display: block; }
.about-price__center-num em { font-style: normal; font-size: .62em; opacity: .55; }
.about-price__center-label { font: 300 7.5px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase; color: rgba(12,12,12,.3); display: block; margin-top: 5px; }
.about-price__legend { display: flex; flex-direction: column; }
/* ── CTA MAGNETIC ── */
    .about-cta__btn { transition: transform .2s ease, background .22s, color .22s; }

/* ── KEYFRAMES (depuis la maquette — étaient manquantes) ── */
@keyframes titleClip { from { clip-path: inset(0 100% 0 0); } to { clip-path: inset(0 0% 0 0); } }
@keyframes ruleGrow  { from { transform: scaleX(0); } to { transform: scaleX(1); } }
@keyframes mqRun     { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes mfGlow {
  0%   { transform: translate(0, 0); opacity: 1; }
  33%  { transform: translate(18%, 12%); opacity: .6; }
  66%  { transform: translate(-8%, 18%); opacity: .9; }
  100% { transform: translate(10%, -12%); opacity: .5; }
}
@keyframes statCountDone { 0%,100% { opacity: 1; } 40% { opacity: .25; } }
@keyframes mbl-fadeUp   { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes mbl-lineGrow { from { transform: scaleX(0); } to { transform: scaleX(1); } }
@keyframes mbl-bob      { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(5px); } }

/* ── Éléments mobile-only masqués sur desktop ── */
.about-hero__scroll-hint { display: none; }
.about-pillars__swipe    { display: none; }

@media (max-width: 1024px) {
  .about-pillars__grid { grid-template-columns: 1fr 1fr; }
  .pillar:nth-child(2) { border-right: none; }
  .pillar:nth-child(3) { border-top: 1px solid var(--border); border-right: none; grid-column: 1 / -1; }
  .about-stats { grid-template-columns: repeat(2,1fr); }
  .stat:nth-child(2) { border-right: none; }
  .stat:nth-child(3) { border-top: 1px solid var(--border); }
}
/* ════════════════════════════════
   MOBILE — Redesign complet (depuis about (1).html)
   NB : règles footer/nav volontairement omises — gérées par le thème.
════════════════════════════════ */
@media (max-width: 768px) {
  /* --g scopé au wrapper .pm-about pour ne pas toucher header/footer du thème */
  .pm-about { --g: 20px; }
  .bg-para { display: none; }

  /* ── HERO ── */
  .about-hero {
    min-height: 85svh;
    display: flex; flex-direction: column; justify-content: space-between;
    padding: 36px var(--g) 32px;
  }
  .about-hero__label { margin-bottom: 0; font-size: 7.5px; }
  .about-hero__inner {
    display: flex; flex-direction: column; align-items: flex-start;
    gap: 24px; padding-top: 28px;
  }
  .about-hero__title { font-size: clamp(72px,20vw,104px); line-height: .82; }
  .about-hero__right {
    display: block !important; text-align: left; max-width: 100%; padding-bottom: 0;
  }
  .about-hero__deck { font-size: 13px; line-height: 1.78; }
  .about-hero__meta { margin-top: 4px; }
  .about-hero__scroll-hint {
    display: flex; align-items: center; gap: 10px;
    font: 300 7.5px/1 var(--fb); letter-spacing: .22em;
    text-transform: uppercase; color: rgba(12,12,12,.28);
    animation: mbl-fadeUp .8s 1.6s both;
  }
  .about-hero__scroll-hint-line {
    display: block; width: 28px; height: 1px;
    background: rgba(12,12,12,.2); transform-origin: left;
    animation: mbl-lineGrow .8s 1.6s cubic-bezier(.22,1,.36,1) both;
  }
  .about-hero__scroll-hint-arrow {
    display: block; animation: mbl-bob 2s 2.4s ease-in-out infinite;
    font-size: 10px; opacity: .4;
  }

  /* ── INTRO ── */
  .about-intro { grid-template-columns: 1fr; padding: 52px var(--g); gap: 40px; }
  .about-intro__right { order: -1; padding-top: 0; }
  .about-intro__pq-mark { font-size: 52px; line-height: .6; }
  .about-intro__pq-text { font-size: 19px; line-height: 1.45; }

  /* ── PILLARS : carrousel horizontal swipeable ── */
  .about-pillars { padding: 52px 0; overflow: hidden; }
  .about-pillars__header {
    display: flex; flex-direction: column; align-items: flex-start;
    justify-content: flex-start; gap: 6px;
    padding: 0 var(--g); margin-bottom: 28px;
  }
  .about-pillars__h { font-size: clamp(36px,11vw,52px); }
  .about-pillars__grid {
    display: flex; flex-direction: row;
    overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
    padding: 0 var(--g) 4px;
    padding-right: calc(var(--g) + 24px);
    gap: 16px;
  }
  .about-pillars__grid::-webkit-scrollbar { display: none; }
  .pillar {
    flex: 0 0 calc(100vw - var(--g) * 2 - 24px);
    scroll-snap-align: start;
    border-right: none !important; border-top: 2px solid var(--dk) !important;
    border-bottom: none !important;
  }
  .pillar__img { aspect-ratio: 4/3; }
  .pillar__img img { height: 100%; }

  .about-pillars__swipe {
    display: flex; justify-content: center; align-items: center; gap: 8px;
    font: 300 7.5px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase;
    color: rgba(12,12,12,.3); padding: 16px var(--g) 0;
  }
  .about-pillars__dots { display: flex; gap: 5px; align-items: center; }
  .about-pillars__dot {
    display: block; height: 2px; width: 6px; border-radius: 2px;
    background: rgba(12,12,12,.2);
    transition: width .3s cubic-bezier(.22,1,.36,1), background .3s;
  }
  .about-pillars__dot.active { width: 20px; background: var(--dk); }

  /* ── PHOTOS N&B ── */
  .about-bw { padding: 24px var(--g); }
  .about-bw__duo { grid-template-columns: 1fr; }
  .about-bw__frame { height: clamp(200px,56vw,300px); }
  .about-bw img { height: 100%; }

  /* ── MANIFESTO : cinématique ── */
  .about-manifesto { padding: 80px var(--g); min-height: 80svh; display: flex; align-items: flex-end; }
  .about-manifesto__inner { width: 100%; }
  .about-manifesto__text { font-size: clamp(36px,10.5vw,56px); max-width: none; line-height: .9; }
  .about-manifesto__sub { font-size: 13px; max-width: none; margin-top: 28px; }

  /* ── STATS ── */
  .about-stats { grid-template-columns: 1fr 1fr; padding: 0; border-top: none; border-bottom: 2px solid var(--dk); }
  .stat { padding: 28px 18px; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
  .stat:nth-child(2) { border-right: none; }
  .stat:nth-child(3) { border-right: 1px solid var(--border); border-bottom: none; }
  .stat:nth-child(4) { border-right: none; border-bottom: none; }
  .stat__num { font-size: clamp(44px,13vw,64px); margin-bottom: 10px; }
  .stat__label { font-size: 7.5px; line-height: 1.7; }

  /* ── SPECS ── */
  .about-specs { padding: 52px var(--g); }
  .about-specs__grid { grid-template-columns: 1fr; }
  .about-specs__h { font-size: clamp(32px,9.5vw,48px); line-height: .9; }
  .spec-row { flex-direction: column; gap: 3px; padding: 13px 0; }
  .spec-row__key { font-size: 10px; letter-spacing: .08em; }
  .spec-row__val { font-size: 14px; text-align: left; font-style: italic; }

  /* ── PRIX ── */
  .about-price { padding: 52px var(--g); }
  .about-price__inner { grid-template-columns: 1fr; gap: 36px; }
  .about-price__right { order: -1; }
  .about-price__chart-wrap { max-width: 240px; margin: 0 auto; }
  .about-price__h { font-size: clamp(32px,9.5vw,48px); line-height: .9; }

  /* ── COUPE ── */
  .about-coupe__inner { grid-template-columns: 1fr; gap: 32px; }
  .about-coupe { padding: 52px var(--g); }
  .about-coupe__h { font-size: clamp(32px,9.5vw,48px); line-height: .9; }

  /* ── CTA ── */
  .about-cta { padding: 72px var(--g); }
  .about-cta__h { font-size: clamp(36px,11vw,52px); }
  .about-cta__links { flex-direction: column; align-items: stretch; gap: 12px; }
  .about-cta__btn { width: 100%; justify-content: center; padding: 16px 24px; font-size: 9.5px; letter-spacing: .18em; }
}

@media (max-width: 390px) {
  .about-hero__title { font-size: 68px; }
  .pillar { flex: 0 0 calc(100vw - var(--g) * 2); }
  .about-price__chart-wrap { max-width: 210px; }
}
/* ── Donut chart legend (JS-injected) — from maquette ── */
.legend-item {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 0; border-bottom: 1px solid var(--border);
  cursor: default; transition: opacity .15s;
}
.legend-item:last-child { border-bottom: none; }
.legend-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; transition: transform .2s; }
.legend-item:hover .legend-dot { transform: scale(1.5); }
.legend-name { font: 300 11px/1.4 var(--fb); letter-spacing: .04em; color: rgba(12,12,12,.72); flex: 1; }
.legend-val { font-family: var(--fd); font-size: clamp(18px,2vw,24px); color: var(--dk); }

/* ── Background watermark "PREMIERE MANCHE" — from maquette ── */
.bg-para {
  position: fixed; inset: 0; z-index: 1;
  pointer-events: none; overflow: hidden;
  mix-blend-mode: multiply;
}
.bg-para__t {
  position: absolute; top: 50%; left: 50%;
  font-family: var(--fd); font-size: min(30vw, 36vh);
  white-space: nowrap; letter-spacing: .1em;
  color: rgba(11,14,21,.016);
  user-select: none; will-change: transform;
  transform: translate(-50%,-50%) rotate(-9deg);
}
