/* ─────────────────────────────────────────────
   Tariqa Pro — Site vitrine public
   Grammaire : noir chaleureux + ambre unique, Archivo Black massif,
   sobre, frontal. « La racine, pas le vernis. »
   0 emoji · 0 tiret long dans le copy · un seul accent par bloc.
   ───────────────────────────────────────────── */

* { box-sizing: border-box; }
body { margin: 0; background: var(--noir-900); color: var(--ink); font: var(--type-body); -webkit-font-smoothing: antialiased; }
.wrap { max-width: 1280px; margin: 0 auto; padding-inline: var(--s-7); }
@media (max-width: 768px) { .wrap { padding-inline: var(--s-5); } }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.skip { position: absolute; left: -999px; }
.skip:focus { left: var(--s-5); top: var(--s-5); z-index: 50; background: var(--ambre-300); color: var(--noir-900); padding: 10px 16px; border-radius: var(--r-pill); }

/* ─── Boutons ─── */
.btn-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 30px; border-radius: var(--r-pill);
  font: 900 13px/1 var(--font-display); letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--noir-900); background: var(--ambre-300); border: none; cursor: pointer;
  box-shadow: 0 12px 36px -10px rgba(238,154,58,0.5);
  transition: transform var(--dur-fast) var(--ease-tariqa), box-shadow var(--dur-base) ease, filter var(--dur-base) ease;
}
.btn-cta::after { content: "→"; transition: transform var(--dur-base) ease; }
.btn-cta:hover { transform: translateY(-2px); box-shadow: 0 18px 48px -12px rgba(238,154,58,0.65); filter: brightness(1.04); }
.btn-cta:hover::after { transform: translateX(4px); }
.btn-cta:active { transform: translateY(0); filter: brightness(0.96); }
.btn-cta:focus-visible { outline: 2px solid var(--ambre-300); outline-offset: 3px; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 15px 24px; border-radius: var(--r-pill);
  font: 500 12px/1 var(--font-mono); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ambre-200); background: transparent; border: 1px solid var(--ambre-600); cursor: pointer;
  transition: background var(--dur-base) ease, border-color var(--dur-base) ease, color var(--dur-base) ease, transform var(--dur-fast) var(--ease-tariqa);
}
.btn-ghost:hover { background: rgba(248,181,105,0.10); border-color: var(--ambre-300); color: var(--ambre-100); transform: translateY(-1px); }
.btn-ghost:active { transform: translateY(0); }
.btn-ghost:focus-visible { outline: 2px solid var(--ambre-300); outline-offset: 3px; }

.eyebrow { font: var(--type-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--accent); }
.ico { display: inline-block; background: var(--ambre-300); -webkit-mask: var(--src) center / contain no-repeat; mask: var(--src) center / contain no-repeat; }

/* ─── Topbar ─── */
.topbar { position: sticky; top: 0; z-index: 20; background: rgba(14,8,5,0.85); backdrop-filter: blur(14px); border-bottom: 1px solid var(--hairline); }
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; padding-block: 14px; }
.topbar .logo { height: 22px; opacity: 0.95; }
.topbar nav { display: flex; gap: var(--s-6); }
.topbar nav a { font: 500 12px/1 var(--font-mono); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-muted); transition: color var(--dur-base) ease; }
.topbar nav a:hover, .topbar nav a[aria-current="page"] { color: var(--ambre-300); }
.topbar .btn-cta { padding: 11px 20px; font-size: 11px; }
@media (max-width: 980px) { .topbar nav { display: none; } }

/* ─── Hero accueil ─── */
.hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--hairline);
  background: radial-gradient(ellipse 70% 50% at 12% 0%, rgba(238,154,58,0.12), transparent 60%), var(--noir-900); }
.hero .wrap { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: var(--s-7); align-items: center; min-height: 80vh; padding-block: var(--s-9); }
.hero-photo { position: relative; align-self: stretch; border-radius: var(--r-card); overflow: hidden; min-height: 440px; }
.hero-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: contrast(1.10) saturate(1.06); }
.hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(115deg, transparent 35%, rgba(14,8,5,0.85) 100%), linear-gradient(0deg, rgba(7,4,3,0.6), transparent 50%); }
.hero h1 { font: 900 clamp(44px, 7vw, 100px)/0.86 var(--font-display); letter-spacing: -0.035em; text-transform: uppercase; margin: 18px 0 0; text-wrap: balance; }
.hero h1 .am { color: var(--ambre-300); }
.hero h1 .it { font: 500 italic 0.92em/0.84 var(--font-editorial); text-transform: none; letter-spacing: -0.01em; color: var(--ambre-200); }
.hero .lede { font: var(--type-lede); color: var(--ink-muted); max-width: 50ch; margin: var(--s-5) 0 var(--s-6); }
.hero .actions { display: flex; flex-wrap: wrap; gap: var(--s-3); }
.hero .meta { display: flex; flex-wrap: wrap; gap: var(--s-2) var(--s-5); margin-top: var(--s-7); padding-top: var(--s-5); border-top: 1px solid var(--hairline);
  font: var(--type-mono-mini); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim); }
.hero .meta b { color: var(--ambre-200); font-weight: 500; }
@media (max-width: 980px) {
  .hero .wrap { grid-template-columns: 1fr; min-height: auto; gap: var(--s-6); }
  .hero-photo { min-height: 320px; order: 2; }
}

/* ─── Page hero (pages internes) ─── */
.page-hero { border-bottom: 1px solid var(--hairline);
  background: radial-gradient(ellipse 60% 50% at 0% 0%, rgba(238,154,58,0.10), transparent 60%), var(--noir-900); }
.page-hero .wrap { padding-block: var(--s-9) var(--s-8); }
.breadcrumb { font: var(--type-mono-mini); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim); margin-bottom: var(--s-5); }
.breadcrumb a:hover { color: var(--ambre-300); }
.page-hero h1 { font: 900 clamp(40px, 6vw, 84px)/0.9 var(--font-display); letter-spacing: -0.03em; text-transform: uppercase; margin: 10px 0 0; text-wrap: balance; }
.page-hero h1 .am { color: var(--ambre-300); }
.page-hero h1 .it { font: 500 italic 0.92em/0.84 var(--font-editorial); text-transform: none; color: var(--ambre-200); }
.page-hero .lede { font: var(--type-lede); color: var(--ink-muted); max-width: 60ch; margin-top: var(--s-5); }

/* ─── Marquee ─── */
.marquee { background: var(--noir-950); border-block: 1px solid var(--hairline); overflow: hidden; padding-block: 20px; }
.marquee .track { display: flex; gap: var(--s-6); width: max-content; animation: marq 38s linear infinite; }
.marquee .track span { font: 900 clamp(20px, 2.4vw, 32px)/1 var(--font-display); letter-spacing: -0.01em; text-transform: uppercase; color: var(--ambre-300); white-space: nowrap; display: inline-flex; align-items: center; gap: var(--s-6); }
.marquee svg { width: 18px; height: 18px; color: var(--ambre-500); flex: none; }
@keyframes marq { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee .track { animation: none; } }

/* ─── Section générique ─── */
.section { padding-block: var(--s-10); border-bottom: 1px solid var(--hairline); }
.section.tight { padding-block: var(--s-9); }
.section-head { display: grid; grid-template-columns: 280px 1fr; gap: var(--s-6); margin-bottom: var(--s-8); }
.section-head h2 { font: var(--type-h2); letter-spacing: var(--ls-h2); text-transform: uppercase; margin: 8px 0 0; text-wrap: balance; }
.section-head h2 .am { color: var(--ambre-300); }
.section-head h2 .it { font: 500 italic 0.92em/0.9 var(--font-editorial); text-transform: none; color: var(--ambre-200); }
.section-head p { color: var(--ink-muted); font: var(--type-lede); margin: 0; max-width: 52ch; }
@media (max-width: 880px) { .section-head { grid-template-columns: 1fr; gap: var(--s-3); } }

.prose p { color: var(--ink-muted); max-width: 68ch; }
.prose p .am { color: var(--ambre-300); }
.prose h3 { margin-top: var(--s-7); }

/* ─── Problème (contraste avant/après) ─── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-6); border-top: 1px solid var(--hairline-2); }
.split .col { padding: var(--s-7) var(--s-6); }
.split .col:first-child { border-right: 1px solid var(--hairline); padding-left: 0; }
.split .col .tag { font: var(--type-mono-mini); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--ink-dim); }
.split .col.bad .tag { color: var(--ink-dim); }
.split .col.good .tag { color: var(--ambre-300); }
.split .col h3 { margin: 12px 0 var(--s-5); }
.split ul { list-style: none; margin: 0; padding: 0; }
.split li { display: flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--hairline); color: var(--ink-muted); font-size: 16px; }
.split li svg { width: 20px; height: 20px; flex: none; margin-top: 2px; }
.split .bad li svg { color: var(--ink-dim); }
.split .good li svg { color: var(--ambre-300); }
@media (max-width: 760px) { .split { grid-template-columns: 1fr; }
  .split .col:first-child { border-right: none; border-bottom: 1px solid var(--hairline); padding-left: var(--s-6); } }

/* ─── Piliers ─── */
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--hairline-2); }
.pillar { padding: var(--s-7) var(--s-6); border-left: 1px solid var(--hairline); }
.pillar:first-child { border-left: none; padding-left: 0; }
.pillar .ico { width: 38px; height: 38px; }
.pillar .n { font: var(--type-mono-mini); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--ink-dim); margin-top: var(--s-5); }
.pillar h3 { font: 900 30px/0.95 var(--font-display); letter-spacing: -0.02em; text-transform: uppercase; margin: 10px 0 12px; }
.pillar p { color: var(--ink-muted); margin: 0; font-size: 16px; }
@media (max-width: 760px) { .pillars { grid-template-columns: 1fr; }
  .pillar { border-left: none; border-top: 1px solid var(--hairline); padding: var(--s-6) 0; }
  .pillar:first-child { border-top: none; padding-top: 0; } }

/* ─── Étapes / méthode (6 piliers) ─── */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
.step { background: var(--bg-card); border: 1px solid var(--hairline); border-radius: var(--r-card); padding: var(--s-6); transition: border-color var(--dur-base) ease, transform var(--dur-slow) var(--ease-tariqa); }
.step:hover { border-color: var(--ambre-600); transform: translateY(-4px); }
.step .num { font: 900 13px/1 var(--font-display); letter-spacing: 0.1em; color: var(--noir-900); background: var(--ambre-300); width: 34px; height: 34px; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; }
.step h3 { font: 900 22px/1 var(--font-display); text-transform: uppercase; letter-spacing: -0.01em; margin: var(--s-4) 0 10px; }
.step p { color: var(--ink-muted); margin: 0; font-size: 15px; }
@media (max-width: 880px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .steps { grid-template-columns: 1fr; } }

/* ─── Cadence hebdomadaire ─── */
.cadence { border-top: 1px solid var(--hairline-2); }
.day { display: grid; grid-template-columns: 200px 1fr; gap: var(--s-5); padding: var(--s-5) 0; border-bottom: 1px solid var(--hairline); align-items: baseline; }
.day .lbl { font: 900 14px/1.2 var(--font-display); text-transform: uppercase; letter-spacing: 0.02em; color: var(--ambre-200); }
.day .desc { color: var(--ink-muted); }
.day .desc b { color: var(--ink); font-weight: 700; }
@media (max-width: 640px) { .day { grid-template-columns: 1fr; gap: 6px; } }

/* ─── Manifeste (mur d'ambre) ─── */
.manifesto { background: var(--ambre-300); color: var(--noir-900); position: relative; overflow: hidden; border-bottom: 1px solid var(--hairline); }
.manifesto .wrap { padding-block: var(--s-10); position: relative; z-index: 1; }
.manifesto .sablier { position: absolute; right: -60px; top: -50px; width: 360px; color: rgba(14,8,5,0.08); z-index: 0; }
.manifesto .eyebrow { color: rgba(14,8,5,0.6); }
.manifesto h2 { font: 900 clamp(40px, 7vw, 116px)/0.86 var(--font-display); letter-spacing: -0.04em; text-transform: uppercase; margin: 14px 0; max-width: 16ch; text-wrap: balance; color: var(--noir-900); }
.manifesto h2 .it { font: 500 italic 0.92em/0.84 var(--font-editorial); text-transform: none; letter-spacing: -0.01em; }
.manifesto .stamp { display: inline-block; margin-top: var(--s-5); border: 2px solid var(--noir-900); padding: 10px 18px;
  font: 900 11px/1 var(--font-display); letter-spacing: 0.18em; text-transform: uppercase; transform: rotate(-3deg); }

/* ─── Stats ─── */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); border-top: 1px solid var(--hairline-2); padding-top: var(--s-7); }
.stat .big { font: 900 clamp(40px, 5vw, 64px)/1 var(--font-display); color: var(--ambre-300); letter-spacing: -0.02em; }
.stat .cap { font: 500 13px/1.5 var(--font-mono); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-dim); margin-top: 10px; }
@media (max-width: 640px) { .stats { grid-template-columns: 1fr; gap: var(--s-5); } }

/* ─── Intervenants ─── */
.team { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
.member { background: var(--bg-card); border: 1px solid var(--hairline); border-radius: var(--r-card); overflow: hidden;
  transition: transform var(--dur-slow) var(--ease-tariqa), border-color var(--dur-base) ease, box-shadow var(--dur-slow) ease; }
.member:hover { transform: translateY(-5px); border-color: var(--ambre-500); box-shadow: var(--shadow-card); }
.member .ph { aspect-ratio: 1/1; background: var(--noir-950); }
.member .ph img { width: 100%; height: 100%; object-fit: cover; }
.member .body { padding: var(--s-5); border-top: 1px solid var(--hairline); }
.member .who { font: 900 24px/1 var(--font-display); letter-spacing: -0.01em; text-transform: uppercase; margin: 0; }
.member .role { font: 500 11px/1.3 var(--font-mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ambre-300); margin: 8px 0 12px; }
.member p { color: var(--ink-muted); margin: 0; font-size: 15px; }
@media (max-width: 760px) { .team { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; } }

/* ─── Témoignages (grille de cartes) ─── */
.quotes { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-5); }
.qcard { background: var(--bg-card); border: 1px solid var(--hairline); border-radius: var(--r-card); padding: var(--s-6); display: flex; flex-direction: column; }
.qcard .bar { width: 40px; height: 3px; background: var(--ambre-300); margin-bottom: var(--s-5); }
.qcard blockquote { margin: 0 0 var(--s-5); font: 500 italic 21px/1.4 var(--font-editorial); color: var(--creme-50); text-wrap: pretty; }
.qcard blockquote .am { color: var(--ambre-300); }
.qcard .by { margin-top: auto; }
.qcard .nm { font: 800 14px/1 var(--font-display-alt); text-transform: uppercase; letter-spacing: 0.02em; }
.qcard .tt { font: 500 11px/1.3 var(--font-mono); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-dim); margin-top: 6px; }
@media (max-width: 760px) { .quotes { grid-template-columns: 1fr; } }

/* Grand témoignage seul */
.quote { text-align: left; }
.quote .bar { width: 44px; height: 3px; background: var(--ambre-300); margin-bottom: var(--s-6); }
.quote blockquote { font: 500 italic clamp(26px, 4vw, 48px)/1.2 var(--font-editorial); color: var(--creme-50); margin: 0; max-width: 24ch; text-wrap: pretty; }
.quote blockquote .am { color: var(--ambre-300); }
.quote .by { display: flex; align-items: center; gap: 14px; margin-top: var(--s-6); }
.quote .by img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 1px solid var(--ambre-700); filter: grayscale(1) contrast(1.05); }
.quote .by .nm { font: 800 14px/1 var(--font-display-alt); text-transform: uppercase; letter-spacing: 0.02em; }
.quote .by .tt { font: 500 11px/1.3 var(--font-mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim); margin-top: 6px; }

/* ─── Galeries d'images de contexte (placeholders prêts pour photos) ─── */
.gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); }
.gtile { position: relative; aspect-ratio: 4/3; border-radius: var(--r-card); overflow: hidden; border: 1px solid var(--hairline);
  background: var(--bg-card); display: grid; place-content: center; text-align: center; padding: var(--s-5); }
.gtile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.gtile .gmark { width: 30px; height: 30px; color: var(--ambre-500); opacity: 0.55; margin: 0 auto var(--s-3); }
.gtile .glabel { position: relative; font: var(--type-mono-mini); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim); }
.gtile.tall { aspect-ratio: 3/4; }
.gallery.cols4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 760px) { .gallery, .gallery.cols4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .gallery, .gallery.cols4 { grid-template-columns: 1fr; } }

/* ─── Témoignages vidéo (grille) ─── */
.vgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
.vcard { background: var(--bg-card); border: 1px solid var(--hairline); border-radius: var(--r-card); overflow: hidden; display: block;
  transition: transform var(--dur-slow) var(--ease-tariqa), border-color var(--dur-base) ease, box-shadow var(--dur-slow) ease; }
.vcard:hover { transform: translateY(-5px); border-color: var(--ambre-500); box-shadow: var(--shadow-card); }
.vcard:focus-visible { outline: 2px solid var(--ambre-300); outline-offset: 2px; }
.vcard .vthumb { display: block; position: relative; aspect-ratio: 16/9; background: var(--noir-950); }
.vcard .vthumb img { width: 100%; height: 100%; object-fit: cover; }
.vcard .vthumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,5,3,0.5), transparent 55%); }
.vcard .vplay { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 52px; height: 52px; border-radius: var(--r-pill);
  background: var(--ambre-300); color: var(--noir-900); display: grid; place-content: center; box-shadow: 0 8px 24px -6px rgba(238,154,58,0.6);
  transition: transform var(--dur-base) var(--ease-tariqa); }
.vcard .vplay svg { width: 22px; height: 22px; margin-left: 2px; }
.vcard:hover .vplay { transform: translate(-50%,-50%) scale(1.08); }
.vcard .vbody { display: block; padding: var(--s-5); border-top: 1px solid var(--hairline); }
.vcard .vname { display: block; font: 900 18px/1 var(--font-display); text-transform: uppercase; letter-spacing: -0.01em; margin: 0; }
.vcard .vrole { display: block; font: 500 11px/1.3 var(--font-mono); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ambre-300); margin: 8px 0 0; }
.vcard .vtitle { display: block; font: 400 15px/1.5 var(--font-body); color: var(--ink-muted); margin: 10px 0 0; text-wrap: pretty; }
@media (max-width: 880px) { .vgrid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .vgrid { grid-template-columns: 1fr; } }
@media (min-width: 881px) { .vgrid.wide { grid-template-columns: repeat(2, 1fr); } }

/* ─── FAQ (accordéon natif) ─── */
.faq { border-top: 1px solid var(--hairline-2); }
.faq details { border-bottom: 1px solid var(--hairline); }
.faq summary { cursor: pointer; list-style: none; padding: var(--s-5) 0; display: flex; justify-content: space-between; gap: var(--s-5); align-items: center;
  font: 900 19px/1.3 var(--font-display-alt); text-transform: uppercase; letter-spacing: -0.01em; color: var(--ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font: 400 28px/1 var(--font-body); color: var(--ambre-300); flex: none; transition: transform var(--dur-base) ease; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details[open] summary { color: var(--ambre-200); }
.faq .ans { padding: 0 0 var(--s-6); color: var(--ink-muted); max-width: 72ch; }
.faq .ans p { margin: 0 0 var(--s-3); }

/* ─── Bande CTA ─── */
.cta-band { background: var(--noir-950); border-bottom: 1px solid var(--hairline);
  background-image: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(238,154,58,0.10), transparent 60%); }
.cta-band .wrap { padding-block: var(--s-10); text-align: center; }
.cta-band h2 { font: 900 clamp(36px, 5.5vw, 80px)/0.9 var(--font-display); text-transform: uppercase; letter-spacing: -0.03em; margin: 0 auto var(--s-5); max-width: 18ch; text-wrap: balance; }
.cta-band h2 .am { color: var(--ambre-300); }
.cta-band p { color: var(--ink-muted); max-width: 52ch; margin: 0 auto var(--s-7); font: var(--type-lede); }
.cta-band .note { font: var(--type-mono-mini); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim); margin-top: var(--s-5); }

/* ─── Footer ─── */
.foot { padding-block: var(--s-8); }
.foot .wrap { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: var(--s-6); }
.foot .brand { display: flex; align-items: center; gap: 14px; margin-bottom: var(--s-4); }
.foot .sablier { width: 26px; color: var(--ambre-300); }
.foot .logo { height: 18px; opacity: 0.9; }
.foot .tag { color: var(--ink-dim); font-size: 14px; max-width: 38ch; }
.foot .fcol h4 { font: 500 11px/1 var(--font-mono); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-dim); margin: 0 0 var(--s-4); }
.foot .fcol a { display: block; color: var(--ink-muted); font-size: 14px; padding: 6px 0; }
.foot .fcol a:hover { color: var(--ambre-300); }
.foot .legal { grid-column: 1 / -1; border-top: 1px solid var(--hairline); margin-top: var(--s-6); padding-top: var(--s-6);
  font: var(--type-mono-mini); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-dim); display: flex; flex-wrap: wrap; gap: var(--s-4) var(--s-6); justify-content: space-between; }
.foot .legal b { color: var(--ambre-200); font-weight: 500; }
@media (max-width: 760px) { .foot .wrap { grid-template-columns: 1fr; } }

/* ─── Module vidéo flottant (témoignage) ─── */
.vsticky { position: fixed; right: 24px; bottom: 24px; z-index: 40; width: 300px; max-width: calc(100vw - 24px);
  background: var(--bg-card); border: 1px solid var(--hairline-2); border-radius: var(--r-card);
  box-shadow: var(--shadow-card); overflow: hidden;
  opacity: 0; transform: translateY(16px); pointer-events: none;
  transition: opacity var(--dur-slow) var(--ease-tariqa), transform var(--dur-slow) var(--ease-tariqa); }
.vsticky.show { opacity: 1; transform: none; pointer-events: auto; }
.vsticky-link { display: block; }
.vsticky-thumb { position: relative; display: block; aspect-ratio: 16/9; background: var(--noir-950); }
.vsticky-thumb img { width: 100%; height: 100%; object-fit: cover; }
.vsticky-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,5,3,0.5), transparent 55%); }
.vsticky-play { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 54px; height: 54px; border-radius: var(--r-pill);
  background: var(--ambre-300); color: var(--noir-900); display: grid; place-content: center; box-shadow: 0 8px 24px -6px rgba(238,154,58,0.6);
  transition: transform var(--dur-base) var(--ease-tariqa); }
.vsticky-play svg { width: 24px; height: 24px; margin-left: 2px; }
.vsticky:hover .vsticky-play { transform: translate(-50%,-50%) scale(1.08); }
.vsticky-body { display: block; padding: 16px; }
.vsticky-eyebrow { font: var(--type-mono-mini); letter-spacing: 0.16em; text-transform: uppercase; color: var(--ambre-300); display: block; }
.vsticky-title { font: 800 15px/1.3 var(--font-display-alt); color: var(--ink); margin-top: 6px; display: block; text-wrap: pretty; }
.vsticky-close { position: absolute; right: 8px; top: 8px; z-index: 2; width: 30px; height: 30px; border-radius: var(--r-pill); border: none; cursor: pointer;
  background: rgba(10,5,3,0.7); color: var(--ink-muted); font: 400 20px/1 var(--font-body); backdrop-filter: blur(6px);
  display: grid; place-content: center; transition: color var(--dur-base) ease, background var(--dur-base) ease; }
.vsticky-close:hover { color: var(--ink); background: rgba(10,5,3,0.9); }
.vsticky-close:focus-visible, .vsticky-link:focus-visible { outline: 2px solid var(--ambre-300); outline-offset: 2px; }
@media (max-width: 560px) { .vsticky { width: 220px; right: 12px; bottom: 12px; } .vsticky-play { width: 44px; height: 44px; } .vsticky-title { font-size: 14px; } }
@media (prefers-reduced-motion: reduce) { .vsticky { transition: opacity var(--dur-base) ease; transform: none; } }

/* ─── Animation d'entrée ─── */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(8px); transition: opacity var(--dur-slow) var(--ease-tariqa), transform var(--dur-slow) var(--ease-tariqa); }
  .reveal.in { opacity: 1; transform: none; }
}
