:root{
  --paper:      #fafaf9;
  --paper-2:    #f3efe6;
  --ink:        #0a0a0a;
  --ink-soft:   rgba(10,10,10,0.65);
  --bronze:     #8b6f47;
  --oxblood:    #6b1f24;
  --rule:       rgba(10,10,10,0.10);
  --rule-soft:  rgba(10,10,10,0.06);
}

html, body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: 'Cormorant Garamond', Georgia, serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

/* ============================================================ */
/* SR-ONLY (titre H1 caché visuellement, visible pour SEO/AT)   */
/* ============================================================ */
.fa-sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================ */
/* SECTION WRAPPER                                              */
/* ============================================================ */
.ba-section-fiducie-explainer {
  position: relative;
  margin: 0;
  padding: 0;
  background: var(--paper);
}

/* ============================================================ */
/* SCROLL HINT — invitation à découvrir la section suivante     */
/* ============================================================ *
 * Stratégie position:fixed (Sprint UX 2026-04-30 fix v2) :
 * - Avant : position:absolute dans la section explainer → le bouton
 *   se retrouvait par-dessus le contenu de l'animation (texte cropé)
 * - Maintenant : fixed bottom-center de la viewport → toujours visible
 *   sans interférer avec l'animation, disparaît au scroll
 * - Pattern UX standard (NYT, Stripe, sites éditoriaux modernes)
 */
.fa-scroll-hint {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 20px;
  background: rgba(250, 250, 249, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(10, 10, 10, 0.10);
  border-radius: 999px;
  color: var(--ink);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-decoration: none;
  text-transform: uppercase;
  opacity: 0;
  pointer-events: none;
  z-index: 100;
  /* Ombre subtile pour contraste sur n'importe quel fond */
  box-shadow: 0 4px 16px rgba(10, 10, 10, 0.08), 0 1px 2px rgba(10, 10, 10, 0.06);
  animation: fa-scroll-hint-in 0.6s ease-out 3s forwards;
  transition: opacity 0.4s ease, transform 0.3s ease;
}
.fa-scroll-hint:hover {
  background: rgba(250, 250, 249, 0.95);
  transform: translateX(-50%) translateY(-2px);
  border-color: rgba(139, 111, 71, 0.3);
}
.fa-scroll-hint-arrow {
  display: inline-block;
  font-size: 14px;
  color: var(--bronze);
  animation: fa-scroll-arrow-pulse 2s ease-in-out infinite;
}
.fa-scroll-hint.is-hidden {
  opacity: 0 !important;
  pointer-events: none !important;
  animation: none;
}
@keyframes fa-scroll-hint-in {
  from { opacity: 0; transform: translateX(-50%) translateY(8px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }
}
@keyframes fa-scroll-arrow-pulse {
  0%, 100% { transform: translateY(0); opacity: 0.7; }
  50%      { transform: translateY(3px); opacity: 1; }
}

/* Note : le smooth scroll global a été retiré (figeait le scroll vers le
   haut). Le smooth scroll est désormais géré uniquement en JS au clic
   sur le scroll-hint, via scrollIntoView({ behavior: 'smooth' }). */

@media (max-width: 720px) {
  .fa-scroll-hint {
    /* position: fixed hérité du desktop (toujours en bas de la viewport) */
    bottom: 18px;
    padding: 10px 18px;
    font-size: 11px;
    gap: 6px;
    /* Visibilité renforcée sur mobile : fond plus opaque + ombre marquée */
    background: rgba(250, 250, 249, 0.95);
    box-shadow: 0 4px 14px rgba(10, 10, 10, 0.14);
  }
  .fa-scroll-hint-text {
    /* Sur mobile, version courte pour rester lisible sur petits écrans */
    display: none;
  }
  .fa-scroll-hint::before {
    content: 'Voir la suite';
    color: var(--ink);
    font-weight: 600;
  }
  .fa-scroll-hint-arrow {
    /* Conserver la flèche mobile, juste un peu plus petite */
    font-size: 12px;
  }
}

/* Très petits écrans (< 380px) : ne pas dépasser la largeur disponible */
@media (max-width: 379px) {
  .fa-scroll-hint {
    padding: 8px 12px;
    font-size: 10px;
    max-width: 88vw;
  }
}

/* Respect des préférences utilisateur : pas d'animation si désactivée */
@media (prefers-reduced-motion: reduce) {
  .fa-scroll-hint {
    animation: none;
    opacity: 1;
    pointer-events: auto;
  }
  .fa-scroll-hint-arrow {
    animation: none;
  }
}

/* ============================================================ */
/* CONTAINER ANIMATION                                          */
/* ============================================================ */
#fiducie-anim {
  position: relative;
  /* Hauteur calculée pour tenir dans la viewport disponible sous la nav.
     --ba-nav-h ≈ 96px desktop / 64px mobile (nav Bensaid sticky). */
  --ba-nav-h: 96px;
  --fa-vpad: 8px;
  /* Hauteur calculée pour RÉSERVER une zone propre en bas pour le
     scroll-hint (~80px) — l'animation s'arrête au-dessus du bouton
     pour qu'il n'y ait jamais de chevauchement visuel. Le bouton est
     en position fixed bottom-center, dans cette zone libre. */
  --fa-scroll-hint-zone: 80px;
  --fa-h: calc(100dvh - var(--ba-nav-h) - var(--fa-vpad) * 2 - var(--fa-scroll-hint-zone));
  --fa-w-from-h: calc(var(--fa-h) * 16 / 9);
  --fa-w-cap:    min(82vw, 1600px);
  width: min(var(--fa-w-from-h), var(--fa-w-cap));
  height: auto;
  aspect-ratio: 16 / 9;
  margin: var(--fa-vpad) auto;
  background: var(--paper);
  border-radius: 4px;
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 24px 48px -16px rgba(10,10,10,0.10),
              0 4px 12px -4px rgba(10,10,10,0.06);
}

@media (max-width: 720px) {
  #fiducie-anim {
    --ba-nav-h: 64px;
    --fa-vpad: 6px;
    --fa-scroll-hint-zone: 72px;
    /* Sur mobile : hauteur fixe basée sur la viewport - nav - zone
       bouton (pour que le scroll-hint fixed ne chevauche pas
       l'animation). Width auto via padding. Le contenu interne
       est aussi adapté avec font-sizes mobile (voir règles ci-dessous). */
    width: 94vw;
    aspect-ratio: auto;
    height: calc(100dvh - var(--ba-nav-h) - var(--fa-vpad) * 2 - var(--fa-scroll-hint-zone));
    min-height: 440px;
    max-height: 700px;
  }

  /* Réduction des fonts pour que le contenu interne tienne dans le
     conteneur mobile sans débordement. Calibré pour mobile portrait. */
  #fiducie-anim .fa-headline {
    font-size: clamp(22px, 6.5vw, 32px) !important;
    line-height: 1.15 !important;
  }
  #fiducie-anim .fa-scene-3 .fa-headline {
    font-size: clamp(20px, 5.8vw, 28px) !important;
  }
  #fiducie-anim .fa-cell-title {
    font-size: clamp(13px, 3.6vw, 17px) !important;
  }
  #fiducie-anim .fa-cell-desc {
    font-size: clamp(11px, 3vw, 13px) !important;
  }
  #fiducie-anim .fa-cell-num {
    font-size: clamp(10px, 2.8vw, 12px) !important;
  }
  #fiducie-anim .fa-cell {
    padding: 12px 14px !important;
  }
  #fiducie-anim .fa-eyebrow {
    font-size: clamp(9px, 2.4vw, 11px) !important;
  }
  #fiducie-anim .fa-sub {
    font-size: clamp(11px, 3vw, 14px) !important;
    line-height: 1.4 !important;
  }
  #fiducie-anim .fa-actor-name {
    font-size: clamp(11px, 3vw, 14px) !important;
  }
  #fiducie-anim .fa-actor-label {
    font-size: clamp(9px, 2.4vw, 11px) !important;
  }
  #fiducie-anim .fa-iso-label {
    font-size: clamp(9px, 2.4vw, 11px) !important;
  }
  #fiducie-anim .fa-iso-value {
    font-size: clamp(11px, 3vw, 14px) !important;
  }
  #fiducie-anim .fa-signature {
    font-size: clamp(14px, 4vw, 20px) !important;
  }

  /* Phantom number plus petit pour ne pas dominer */
  .fa-phantom { font-size: clamp(180px, 50vw, 50vw) !important; }
}

.fa-stage{
  position: absolute; inset: 0;
  background: var(--paper);
}

/* Phantom number (giant background numeral) */
.fa-phantom {
  position: absolute;
  right: -0.08em;
  bottom: -0.18em;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(180px, 28em, 28em);
  line-height: 0.8;
  color: var(--ink);
  opacity: 0.05;
  user-select: none;
  pointer-events: none;
  z-index: 0;
  letter-spacing: -0.04em;
}
@media (max-width: 720px) {
  .fa-phantom { font-size: clamp(220px, 60vw, 60vw); right: -0.06em; bottom: -0.05em; }
}

/* ============================================================ */
/* CHROME — top progress + corner labels                         */
/* ============================================================ */
.fa-chrome {
  position: absolute;
  inset: 0;
  z-index: 30;
  pointer-events: none;
  font-family: 'Inter', sans-serif;
  font-size: clamp(9px, 0.7vw, 11px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
}

.fa-progress {
  position: absolute;
  top: 0; left: 0; right: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 0;
}
.fa-progress-seg {
  position: relative;
  height: 2px;
  background: var(--rule-soft);
  overflow: hidden;
}
.fa-progress-seg + .fa-progress-seg {
  border-left: 1px solid var(--rule);
}
.fa-progress-fill {
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 0%;
  background: var(--ink);
}

.fa-corner {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 0.6em;
  font-weight: 500;
}
.fa-corner.tl { top: 16px;    left: 22px; }
.fa-corner.tr { top: 16px;    right: 22px; }
.fa-bh {
  font-family: 'Times New Roman', serif;
  font-size: 8px;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(10,10,10,0.18);
  font-weight: 400;
  margin-right: 4px;
  line-height: 1;
}
#fiducie-anim[data-voix="set-piece"] .fa-bh {
  color: rgba(250,250,249,0.22);
}
.fa-corner.bl { bottom: 16px; left: 22px; }
.fa-corner.br { bottom: 16px; right: 22px; }

@media (min-width: 1100px) {
  .fa-corner.tl { top: 22px;    left: 32px; }
  .fa-corner.tr { top: 22px;    right: 32px; }
  .fa-corner.bl { bottom: 22px; left: 32px; }
  .fa-corner.br { bottom: 22px; right: 32px; }
}

.fa-corner .fa-dot {
  width: 5px; height: 5px;
  background: var(--bronze);
  border-radius: 50%;
  display: inline-block;
}
.fa-corner .fa-rule {
  display: inline-block;
  width: 24px; height: 1px;
  background: var(--bronze);
}
.fa-counter {
  font-feature-settings: "lnum" 1, "tnum" 1;
  color: var(--ink-soft);
}
.fa-scene-name {
  color: var(--ink-soft);
  font-weight: 500;
}

/* ============================================================ */
/* SCENES — common                                              */
/* ============================================================ */
.fa-scene {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(38px, 5.4vw, 92px) clamp(40px, 6vw, 96px);
  opacity: 0;
  visibility: hidden;
  z-index: 1;
}
.fa-scene.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.fa-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: clamp(10px, 0.78em, 12px);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.9em;
  margin-bottom: clamp(20px, 2.4vw, 38px);
}
.fa-eyebrow .fa-eyebrow-rule {
  display: inline-block;
  width: 38px; height: 1px;
  background: var(--bronze);
}
.fa-eyebrow .fa-eyebrow-num {
  color: var(--bronze);
  font-weight: 600;
}

/* Helvetica monumental headline */
.fa-headline {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-weight: 700;
  font-size: clamp(36px, 4.4em, 4.8em);
  line-height: 1.0;
  letter-spacing: -0.035em;
  color: var(--ink);
  margin: 0;
  max-width: 18ch;
}
.fa-headline em,
.fa-headline .fa-it {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.015em;
  color: var(--oxblood);
}

.fa-line { display: block; overflow: hidden; }
.fa-line .fa-line-inner {
  display: inline-block;
  transform: translateY(110%);
}

.fa-sub {
  margin-top: clamp(20px, 2.4vw, 36px);
  max-width: 60ch;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(14px, 1.3em, 1.45em);
  line-height: 1.45;
  color: var(--ink-soft);
  letter-spacing: 0.005em;
}

/* Slide 2 (Mécanisme) — espacements compacts car contenu plus dense
   (titre + 3 rows iso-stack + paragraphe sub) qui débordait du conteneur */
.fa-scene-2 .fa-sub {
  margin-top: clamp(14px, 1.6vw, 22px);
  font-size: clamp(13px, 1.15em, 1.3em);
  line-height: 1.4;
}
.fa-scene-2 .fa-iso-stack {
  margin-top: clamp(16px, 2vw, 28px);
}
.fa-scene-2 .fa-iso-row {
  padding: clamp(8px, 1vw, 14px) 0;
}
.fa-sub em {
  color: var(--oxblood);
  font-weight: 400;
}

.fa-ref {
  margin-top: clamp(18px, 2vw, 28px);
  font-family: 'Inter', sans-serif;
  font-size: clamp(10px, 0.72em, 11px);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-soft);
  display: flex; align-items: center; gap: 0.8em;
}
.fa-ref .fa-ref-rule {
  width: 28px; height: 1px; background: var(--bronze);
}

/* ============================================================ */
/* SCENE 1 — diagram of three actors                            */
/* ============================================================ */
.fa-diagram {
  margin-top: clamp(28px, 3vw, 48px);
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  align-items: center;
  gap: clamp(8px, 1.4vw, 24px);
  max-width: 920px;
  width: 100%;
}

.fa-actor {
  text-align: center;
  opacity: 0;
}
.fa-actor-label {
  font-family: 'Inter', sans-serif;
  font-size: clamp(9px, 0.65em, 11px);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 10px;
  font-weight: 500;
}
.fa-actor-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-style: italic;
  font-size: clamp(20px, 1.7em, 1.8em);
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.fa-actor.is-fiduciaire .fa-actor-name {
  color: var(--oxblood);
  font-weight: 500;
}

.fa-arc {
  display: flex; align-items: center; justify-content: center;
  height: 60px; min-width: 40px;
  opacity: 0;
}
.fa-arc svg {
  width: 100%; height: 100%;
  overflow: visible;
}
.fa-arc-path {
  fill: none;
  stroke: var(--bronze);
  stroke-width: 1;
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
}
.fa-arc-arrow {
  fill: var(--bronze);
  opacity: 0;
}

/* ============================================================ */
/* SCENE 2 — patrimoine séparé                                  */
/* ============================================================ */
.fa-scene-2 {
  align-items: flex-start;
  justify-content: center;
}

.fa-iso-stack {
  margin-top: clamp(20px, 2.4vw, 36px);
  position: relative;
  width: 100%;
  max-width: 1100px;
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 0.8vw, 14px);
}

.fa-iso-row {
  display: flex;
  align-items: center;
  gap: clamp(14px, 2vw, 32px);
  padding: clamp(10px, 1.2vw, 18px) 0;
  border-top: 1px solid var(--rule);
  opacity: 0;
}
.fa-iso-row:last-child { border-bottom: 1px solid var(--rule); }

.fa-iso-label {
  font-family: 'Inter', sans-serif;
  font-size: clamp(9px, 0.7em, 11px);
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-soft);
  width: clamp(120px, 16vw, 200px);
  flex-shrink: 0;
  font-weight: 500;
}
.fa-iso-value {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(16px, 1.45em, 1.5em);
  line-height: 1.25;
  color: var(--ink);
  flex: 1;
}
.fa-iso-row.is-key {
  position: relative;
}
.fa-iso-row.is-key .fa-iso-label {
  color: var(--oxblood);
}
.fa-iso-row.is-key .fa-iso-value {
  font-style: italic;
  font-weight: 500;
  color: var(--oxblood);
  font-size: clamp(20px, 1.85em, 1.95em);
}
.fa-iso-bracket {
  position: absolute;
  left: -18px;
  top: 0; bottom: 0;
  width: 6px;
  border-left: 1px solid var(--bronze);
  border-top: 1px solid var(--bronze);
  border-bottom: 1px solid var(--bronze);
  transform: scaleY(0);
  transform-origin: top;
}

/* ============================================================ */
/* SCENE 3 — 4 forms                                            */
/* ============================================================ */
.fa-grid {
  margin-top: clamp(18px, 2.2vw, 36px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  width: 100%;
  max-width: 980px;
}
.fa-cell {
  background: var(--paper);
  padding: clamp(14px, 1.8vw, 28px);
  display: flex;
  flex-direction: column;
  gap: clamp(6px, 0.8vw, 12px);
  min-height: clamp(86px, 9vw, 140px);
  opacity: 0;
  position: relative;
  overflow: hidden;
}
.fa-cell-num {
  font-family: 'Inter', sans-serif;
  font-size: clamp(9px, 0.7em, 11px);
  letter-spacing: 0.28em;
  color: var(--bronze);
  font-weight: 600;
}
.fa-cell-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(18px, 1.65em, 1.75em);
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.fa-scene-3 .fa-headline { font-size: clamp(30px, 3.4em, 3.8em); }
.fa-cell-title em {
  font-style: italic;
  color: var(--oxblood);
  font-weight: 400;
}
.fa-cell-desc {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(13px, 1.05em, 1.1em);
  color: var(--ink-soft);
  line-height: 1.4;
  margin-top: auto;
}

/* ============================================================ */
/* SCENE 4 — outro                                              */
/* ============================================================ */
.fa-outro-group {
  margin-top: clamp(24px, 2.6vw, 40px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2.2vw, 32px);
  max-width: 980px;
}
.fa-people {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(20px, 3vw, 56px);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: clamp(18px, 2vw, 28px) 0;
}
.fa-person { opacity: 0; }
.fa-person-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(20px, 1.7em, 1.8em);
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.fa-person-role {
  font-family: 'Inter', sans-serif;
  font-size: clamp(9px, 0.7em, 11px);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 8px;
  font-weight: 500;
}

.fa-bronze-rule {
  width: 0;
  height: 1px;
  background: var(--bronze);
  align-self: flex-start;
}

.fa-sites {
  display: flex;
  gap: clamp(16px, 2.4vw, 36px);
  font-family: 'Inter', sans-serif;
  font-size: clamp(10px, 0.78em, 12px);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 500;
  flex-wrap: wrap;
}
.fa-sites span { opacity: 0; }

/* signature wordmark */
.fa-signature {
  position: absolute;
  left: clamp(40px, 6vw, 96px);
  bottom: clamp(64px, 7vw, 110px);
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: clamp(16px, 1.3em, 1.45em);
  letter-spacing: 0.18em;
  color: var(--ink);
  opacity: 0;
  display: none; /* shown only in outro */
}

/* ============================================================ */
/* WATERMARK LOGO (bottom right during animation)               */
/* ============================================================ */
.fa-watermark {
  position: absolute;
  right: clamp(22px, 2.4vw, 36px);
  bottom: clamp(56px, 6.4vw, 92px);
  width: clamp(30px, 3vw, 46px);
  height: auto;
  z-index: 15;
  opacity: 0.18;
  pointer-events: none;
  filter: invert(0); /* keep dark on cream */
}

/* ============================================================ */
/* REPLAY                                                        */
/* ============================================================ */
.fa-replay {
  position: absolute;
  left: 50%;
  bottom: clamp(40px, 4.4vw, 64px);
  transform: translate(-50%, 8px);
  z-index: 40;
  font-family: 'Inter', sans-serif;
  font-size: clamp(10px, 0.78em, 12px);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 500;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 10px 22px;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: color 280ms cubic-bezier(0.16,1,0.3,1),
              border-color 280ms cubic-bezier(0.16,1,0.3,1),
              transform 280ms cubic-bezier(0.16,1,0.3,1);
}
.fa-replay.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
.fa-replay:hover {
  color: var(--oxblood);
  border-color: var(--ink);
  transform: translate(-50%, -2px);
}
.fa-replay .fa-arrow {
  display: inline-block;
  margin-left: 0.7em;
  transition: transform 280ms cubic-bezier(0.16,1,0.3,1);
}
.fa-replay:hover .fa-arrow { transform: translateX(4px); }

/* utility */
.fa-word { display: inline-block; }

/* ============================================================ */
/* VOIX — mood variants                                          */
/* ============================================================ */
/* set-piece (dark reverse) */
#fiducie-anim[data-voix="set-piece"] {
  background: #1a1a1a;
}
#fiducie-anim[data-voix="set-piece"] .fa-stage { background: #1a1a1a; }
#fiducie-anim[data-voix="set-piece"] .fa-headline { color: #fafaf9; }
#fiducie-anim[data-voix="set-piece"] .fa-eyebrow { color: #fafaf9; }
#fiducie-anim[data-voix="set-piece"] .fa-actor-name { color: #fafaf9; }
#fiducie-anim[data-voix="set-piece"] .fa-actor.is-fiduciaire .fa-actor-name { color: #c89a9d; }
#fiducie-anim[data-voix="set-piece"] .fa-headline em,
#fiducie-anim[data-voix="set-piece"] .fa-headline .fa-it,
#fiducie-anim[data-voix="set-piece"] .fa-cell-title em,
#fiducie-anim[data-voix="set-piece"] .fa-iso-row.is-key .fa-iso-label,
#fiducie-anim[data-voix="set-piece"] .fa-iso-row.is-key .fa-iso-value,
#fiducie-anim[data-voix="set-piece"] .fa-sub em { color: #c89a9d; }
#fiducie-anim[data-voix="set-piece"] .fa-sub,
#fiducie-anim[data-voix="set-piece"] .fa-actor-label,
#fiducie-anim[data-voix="set-piece"] .fa-iso-label,
#fiducie-anim[data-voix="set-piece"] .fa-iso-value,
#fiducie-anim[data-voix="set-piece"] .fa-cell-title,
#fiducie-anim[data-voix="set-piece"] .fa-cell-desc,
#fiducie-anim[data-voix="set-piece"] .fa-cell-num,
#fiducie-anim[data-voix="set-piece"] .fa-person-name,
#fiducie-anim[data-voix="set-piece"] .fa-person-role,
#fiducie-anim[data-voix="set-piece"] .fa-sites,
#fiducie-anim[data-voix="set-piece"] .fa-ref,
#fiducie-anim[data-voix="set-piece"] .fa-corner,
#fiducie-anim[data-voix="set-piece"] .fa-counter,
#fiducie-anim[data-voix="set-piece"] .fa-scene-name { color: rgba(250,250,249,0.72); }
#fiducie-anim[data-voix="set-piece"] .fa-cell { background: #1a1a1a; }
#fiducie-anim[data-voix="set-piece"] .fa-grid { background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.18); }
#fiducie-anim[data-voix="set-piece"] .fa-iso-row { border-color: rgba(255,255,255,0.18); }
#fiducie-anim[data-voix="set-piece"] .fa-people { border-color: rgba(255,255,255,0.18); }
#fiducie-anim[data-voix="set-piece"] .fa-progress-seg { background: rgba(255,255,255,0.08); }
#fiducie-anim[data-voix="set-piece"] .fa-progress-seg + .fa-progress-seg { border-color: rgba(255,255,255,0.18); }
#fiducie-anim[data-voix="set-piece"] .fa-progress-fill { background: #fafaf9; }
#fiducie-anim[data-voix="set-piece"] .fa-phantom { color: #fafaf9; opacity: 0.07; }
#fiducie-anim[data-voix="set-piece"] .fa-replay {
  background: #1a1a1a; color: #fafaf9; border-color: rgba(255,255,255,0.22);
}
#fiducie-anim[data-voix="set-piece"] .fa-watermark { filter: invert(1); }
#fiducie-anim[data-voix="set-piece"] .fa-signature { color: #fafaf9; }

/* editorial (paper-2 with bronze emphasis) */
#fiducie-anim[data-voix="editorial"] { background: var(--paper-2); }
#fiducie-anim[data-voix="editorial"] .fa-stage { background: var(--paper-2); }
#fiducie-anim[data-voix="editorial"] .fa-eyebrow .fa-eyebrow-rule,
#fiducie-anim[data-voix="editorial"] .fa-corner .fa-rule,
#fiducie-anim[data-voix="editorial"] .fa-ref .fa-ref-rule { width: 56px; background: var(--bronze); }
#fiducie-anim[data-voix="editorial"] .fa-eyebrow { color: var(--bronze); letter-spacing: 0.4em; }
#fiducie-anim[data-voix="editorial"] .fa-eyebrow-num { color: var(--oxblood); }
#fiducie-anim[data-voix="editorial"] .fa-cell { background: var(--paper-2); }
#fiducie-anim[data-voix="editorial"] .fa-headline em,
#fiducie-anim[data-voix="editorial"] .fa-headline .fa-it,
#fiducie-anim[data-voix="editorial"] .fa-cell-title em,
#fiducie-anim[data-voix="editorial"] .fa-iso-row.is-key .fa-iso-value,
#fiducie-anim[data-voix="editorial"] .fa-actor.is-fiduciaire .fa-actor-name,
#fiducie-anim[data-voix="editorial"] .fa-sub em { color: var(--oxblood); }
#fiducie-anim[data-voix="editorial"] .fa-bronze-rule { background: var(--oxblood); }
#fiducie-anim[data-voix="editorial"] .fa-replay { background: var(--paper-2); }
#fiducie-anim[data-voix="editorial"] .fa-phantom { font-style: italic; opacity: 0.07; color: var(--bronze); }

/* ============================================================ */
/* GRAMMAIRE — typographic system variants                       */
/* ============================================================ */
/* cormorant — all-serif, lyrical */
#fiducie-anim[data-grammaire="cormorant"] .fa-headline {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(40px, 5em, 5.4em);
  letter-spacing: -0.02em;
  line-height: 1.02;
}
#fiducie-anim[data-grammaire="cormorant"] .fa-scene-3 .fa-headline {
  font-size: clamp(34px, 4em, 4.4em);
}
#fiducie-anim[data-grammaire="cormorant"] .fa-headline .fa-it,
#fiducie-anim[data-grammaire="cormorant"] .fa-headline em {
  font-weight: 300;
  letter-spacing: -0.005em;
}

/* bodoni — display numerals, editorial sommaire */
#fiducie-anim[data-grammaire="bodoni"] .fa-headline {
  font-family: 'Bodoni Moda', 'Didot', 'Bodoni 72', serif;
  font-weight: 400;
  font-size: clamp(38px, 4.6em, 5em);
  letter-spacing: -0.025em;
  line-height: 1.0;
}
#fiducie-anim[data-grammaire="bodoni"] .fa-scene-3 .fa-headline {
  font-size: clamp(32px, 3.8em, 4.2em);
}
#fiducie-anim[data-grammaire="bodoni"] .fa-headline .fa-it,
#fiducie-anim[data-grammaire="bodoni"] .fa-headline em {
  font-family: 'Bodoni Moda', 'Didot', serif;
  font-weight: 400;
  font-style: italic;
}
#fiducie-anim[data-grammaire="bodoni"] .fa-eyebrow-num,
#fiducie-anim[data-grammaire="bodoni"] .fa-cell-num {
  font-family: 'Bodoni Moda', 'Didot', serif;
  font-style: italic;
  font-size: 1.4em;
  letter-spacing: 0;
}
#fiducie-anim[data-grammaire="bodoni"] .fa-phantom {
  font-family: 'Bodoni Moda', 'Didot', serif;
  font-weight: 400;
  font-style: italic;
}

/* ============================================================ */
/* TWEAKS PANEL                                                  */
/* ============================================================ */
.tw-panel{
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 2147483646;
  width: 264px;
  background: rgba(250,250,249,0.92);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid var(--rule);
  border-radius: 6px;
  box-shadow: 0 24px 48px -16px rgba(10,10,10,0.18),
              0 4px 12px -4px rgba(10,10,10,0.08);
  font-family: 'Inter', sans-serif;
  color: var(--ink);
  overflow: hidden;
  display: none;
}
.tw-panel.is-on { display: block; }
.tw-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--rule);
}
.tw-hd-title {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
  display: flex; align-items: center; gap: 8px;
}
.tw-hd-title::before {
  content: ""; width: 4px; height: 4px; background: var(--bronze); border-radius: 50%;
}
.tw-x {
  appearance: none; background: transparent; border: 0;
  color: var(--ink-soft); cursor: pointer; padding: 2px 6px;
  font-size: 16px; line-height: 1; font-family: serif;
}
.tw-x:hover { color: var(--oxblood); }
.tw-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 16px; }
.tw-row { display: flex; flex-direction: column; gap: 8px; }
.tw-lbl {
  display: flex; align-items: baseline; justify-content: space-between;
  font-size: 9.5px; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; color: var(--ink);
}
.tw-lbl-hint {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-soft);
}
.tw-seg {
  display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
  border: 1px solid var(--rule); border-radius: 4px; overflow: hidden;
}
.tw-seg button {
  appearance: none; background: transparent; border: 0;
  padding: 9px 6px;
  font-family: 'Inter', sans-serif;
  font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase;
  font-weight: 500; color: var(--ink-soft);
  cursor: pointer;
  border-right: 1px solid var(--rule);
  transition: background 220ms cubic-bezier(0.16,1,0.3,1),
              color 220ms cubic-bezier(0.16,1,0.3,1);
}
.tw-seg button:last-child { border-right: 0; }
.tw-seg button:hover { color: var(--ink); }
.tw-seg button.is-on {
  background: var(--ink);
  color: var(--paper);
}