/*!
 * Believe Timeline — styles (Three.js engine)
 * Scopés sous #believe-tl-root. Police Rubik réutilisée du thème parent (believe.com)
 * ou auto-hébergée (preview WP).
 */
/* Scrollbar verticale conservée par défaut (le focus verrouille la position sans la retirer). */
html { overflow-y: auto; }

#believe-tl-root { position: relative; }
#believe-tl-root .believe-tl-sentinel { display: none; }

/* Lecteur d'embed CENTRÉ et fixe (taille au ratio posée par JS), sans overlay plein écran. */
#believe-tl-root .believe-tl-player {
  /* top 43.5% = 50% − 6.5% : aligné sur le centre VISUEL de la scène (lens-shift LENS_SHIFT_Y=0.13 NDC). */
  position: fixed; left: 50%; top: 43.5%; transform: translate(-50%, -50%);
  z-index: 20; background: #000; box-shadow: 0 1vw 4vw rgba(0,0,0,.10);
}
#believe-tl-root .believe-tl-player[hidden] { display: none; }
#believe-tl-root .believe-tl-player iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }

#believe-tl-root .believe-tl-experience { position: relative; width: 100%; }
#believe-tl-root .believe-tl-experience__sticky {
  /* Fond NOIR : c'est l'élément sticky plein écran que Safari iOS 26 échantillonne pour tinter sa
     barre (theme-color n'est plus supporté). Le canvas OPAQUE le recouvre → la scène reste visible ;
     seule la barre Safari + l'overscroll prennent ce noir. NE PAS re-synchroniser ce fond en JS. */
  position: sticky; top: 0; width: 100%; overflow: hidden; background: #000;
  height: 100vh;   /* fallback navigateurs sans svh/dvh */
  height: 100svh;  /* hauteur stable (barre visible) — évite le saut */
  height: 100dvh;  /* dynamique : suit la barre ; buffer=boîte (stage.js) → pas d'étirement */
}
#believe-tl-root .believe-tl-canvas { display: block; width: 100%; height: 100%; background: #ff5454; }

/* Nav : traits horizontaux fixes à DROITE (un par année). Actif = plus long. Survol → l'année
   apparaît à gauche du trait. */
/* UI masquée jusqu'à la fin de l'apparition de l'intro (.is-ui-ready ajoutée par main.js).
   La nav fond en bloc ; la transport bar se révèle en CASCADE haut→bas : année → la ligne se
   trace → les boutons (fondu, comme au retour de focus). */
#believe-tl-root:not(.is-ui-ready) .believe-tl-nav { opacity: 0 !important; pointer-events: none; }
#believe-tl-root:not(.is-ui-ready) .believe-tl-transport { pointer-events: none; }
#believe-tl-root:not(.is-ui-ready) .believe-tl-transport__year,
#believe-tl-root:not(.is-ui-ready) .believe-tl-transport__controls { opacity: 0; }
#believe-tl-root:not(.is-ui-ready) .believe-tl-transport__track { transform: scaleX(0); }
/* délais de cascade (sélecteur .is-ui-ready = priorité sur la base → les delays gagnent) */
#believe-tl-root.is-ui-ready .believe-tl-transport__track { transition-delay: .12s; }
#believe-tl-root.is-ui-ready .believe-tl-transport__controls { transition-delay: .28s; }
#believe-tl-root .believe-tl-nav {
  position: fixed; right: 0; top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; align-items: flex-end; gap: 0.7vw; z-index: 10;
  transition: opacity .4s ease, transform .4s ease;
}
#believe-tl-root .believe-tl-nav.is-hidden { /* focus → fade-out vers la DROITE */
  opacity: 0; transform: translateY(-50%) translateX(2vw); pointer-events: none;
}
#believe-tl-root .believe-tl-nav__dot {
  position: relative; width: 1vw; height: 2px; padding: 0; border: 0;
  background: #ffffff; opacity: 0.5; cursor: pointer;
  transition: width .25s ease, opacity .25s ease;
}
#believe-tl-root .believe-tl-nav__dot::before { content: ""; position: absolute; inset: -0.35vw 0 -0.35vw -0.8vw; } /* zone survol/clic élargie */
#believe-tl-root .believe-tl-nav__dot:hover { opacity: 1; }
#believe-tl-root .believe-tl-nav__dot.is-active { width: 1.6vw; opacity: 1; }
#believe-tl-root .believe-tl-nav__year {
  position: absolute; right: calc(100% + 0.6vw); top: 50%; transform: translateY(-50%);
  opacity: 0; white-space: nowrap; pointer-events: none; color: #fff;
  font: 700 0.8vw/1 "Rubik", Arial, sans-serif; text-transform: uppercase;
  transition: opacity .2s ease;
}
#believe-tl-root .believe-tl-nav__dot:hover .believe-tl-nav__year,
#believe-tl-root .believe-tl-nav__dot.is-active .believe-tl-nav__year { opacity: 1; } /* année toujours visible sur l'actif */
/* Au survol de la nav, l'année active permanente s'efface ; seule l'année survolée reste. */
#believe-tl-root .believe-tl-nav:hover .believe-tl-nav__dot.is-active .believe-tl-nav__year { opacity: 0; }
#believe-tl-root .believe-tl-nav:hover .believe-tl-nav__dot:hover .believe-tl-nav__year { opacity: 1; }

/* Badge SCROLL, fixe bas-droite. */
#believe-tl-root .believe-tl-cue {
  position: fixed; right: 24px; bottom: 24px; z-index: 10;
  width: 76px; height: 76px; border-radius: 50%; background: #fff; color: #000;
  display: flex; align-items: center; justify-content: center;
  font: 800 14px "Rubik", Arial, sans-serif; transition: opacity .4s;
}

/* Fallback HTML (toujours dans le DOM : SEO/a11y/no-WebGL). */
#believe-tl-root .believe-tl-html {
  background: #000; color: #fff; padding: 4rem 1.5rem;
  font-family: "Noto Sans", sans-serif; line-height: 1.55;
}
#believe-tl-root .believe-tl-html__inner { max-width: 760px; margin: 0 auto; }

/* WebGL actif : le fallback HTML (texte + image dans le DOM) ne sert QUE de SEO/accessibilité →
   masqué visuellement À TOUTES LES LARGEURS (desktop ET mobile) mais conservé dans le DOM et
   l'arbre d'accessibilité (technique sr-only, pas display:none). En fallback (pas de .is-webgl),
   il reste pleinement visible. */
#believe-tl-root.is-webgl .believe-tl-html {
  position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0;
  overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; border: 0;
}
#believe-tl-root .believe-tl-html h2 {
  font-family: "Rubik", Arial, sans-serif;
  font-size: 2.4rem;
  font-weight: 800;
  line-height: 1;
  text-transform: none;
}
#believe-tl-root .believe-tl-entry { padding: 2rem 0; border-top: 1px solid rgba(255,255,255,.15); }
#believe-tl-root .believe-tl-entry__year {
  font-family: "Rubik", Arial, sans-serif;
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1;
  margin: 0;
  text-transform: none;
}
#believe-tl-root .believe-tl-entry__title {
  font-family: "Rubik", Arial, sans-serif;
  font-weight: 800;
  margin: .25rem 0 1rem;
  text-transform: none;
}
/* Corps de texte en casse normale (lisibilité) ; seul le petit label de type reste en CAPS. */
#believe-tl-root .believe-tl-html__intro,
#believe-tl-root .believe-tl-entry__meta,
#believe-tl-root .believe-tl-item__desc {
  font-family: "Noto Sans", sans-serif;
  line-height: 1.55;
}
#believe-tl-root .believe-tl-html__intro { font-size: 1.05rem; opacity: .85; margin: 0 0 1.5rem; }
#believe-tl-root .believe-tl-entry__meta { opacity: .7; font-size: .9rem; }
#believe-tl-root .believe-tl-items { display: grid; gap: 1rem; }
#believe-tl-root .believe-tl-item {
  display: block; text-align: left; background: #111; color: #fff;
  padding: 1.25rem; border-radius: 8px; text-decoration: none;
}
#believe-tl-root a.believe-tl-item:hover { background: #1c1c1c; }
#believe-tl-root .believe-tl-item__type { display: block; font-size: .7rem; letter-spacing: .08em; opacity: .6; text-transform: uppercase; }
#believe-tl-root .believe-tl-item__title { display: block; font-weight: 800; font-size: 1.05rem; line-height: 1.35; margin-top: .35rem; }
#believe-tl-root .believe-tl-item__desc { display: block; opacity: .85; margin-top: .5rem; font-size: .95rem; }
/* Images du fallback : taille bornée (ne dominent pas la lecture). */
#believe-tl-root .believe-tl-item__img {
  display: block; width: 100%; max-width: 480px; max-height: 360px;
  height: auto; object-fit: cover; border-radius: 8px; margin-top: .75rem;
}

/* Mobile : on garde le canvas (Three.js partout), mais on densifie le fallback si affiché. */
@media (max-width: 600px) {
  #believe-tl-root .believe-tl-nav { gap: 2vw; right: 0; }
  #believe-tl-root .believe-tl-nav__dot { width: 2.25vw; }
  #believe-tl-root .believe-tl-nav__dot.is-active { width: 3.5vw; }
  /* Zone tactile élargie (les vw du desktop sont trop petits au doigt) : haut/bas + vers la gauche. */
  #believe-tl-root .believe-tl-nav__dot::before { inset: -9px 0 -9px -28px; }
  /* Pas de hover au doigt + le label long (« THE BIRTH OF BELIEVE ») débordait : on masque le
     label nav en portrait. L'année courante reste lue dans la transport bar du bas. */
  #believe-tl-root .believe-tl-nav__year { display: none; }
  #believe-tl-root .believe-tl-cue { width: 60px; height: 60px; font-size: 12px; }
}

/* Légende DOM (hors WebGL) : titre + description de la carte visuelle active. */
#believe-tl-root .believe-tl-caption {
  position: fixed; left: 50%; bottom: 6vw; transform: translateX(-50%);
  z-index: 12; width: 40vw; text-align: center; color: #fff;
  opacity: 0; transition: opacity .35s ease; pointer-events: none;
}
#believe-tl-root .believe-tl-caption.is-visible { opacity: 1; }
#believe-tl-root .believe-tl-caption__desc {
  display: block; margin: 0.2vw 0; font: 400 0.78vw/1.35 "Noto Sans", sans-serif; opacity: 1;
}
#believe-tl-root .believe-tl-caption__desc:empty { display: none; } /* pas de ligne vide hors focus */
#believe-tl-root .believe-tl-caption__title {
  display: block; margin-top: 0.25vw; font: 800 1.1vw/1.15 "Rubik", Arial, sans-serif; text-transform: uppercase;
}
@media (max-width: 600px) {
  #believe-tl-root .believe-tl-caption { bottom: 22vw; width: 86vw; }
  #believe-tl-root .believe-tl-caption__title { font-size: 4.4vw; }
  #believe-tl-root .believe-tl-caption__desc { font-size: 3.2vw; }
}

/* Transport bar (lecteur) : barre de progression + précédent / play / suivant. Fixe bas-centre.
   Toutes les tailles en vw (échelle au viewport). Largeur réduite de 25 % (24vw → 18vw). */
#believe-tl-root .believe-tl-transport {
  position: fixed; left: 50%; bottom: 0.7vw; transform: translateX(-50%);
  z-index: 13; width: 38vw;
  display: flex; flex-direction: column; align-items: center;  /* espacement par marges (collapse propre) */
  color: #fff; transition: opacity .4s ease;
}
#believe-tl-root .believe-tl-transport__year {
  font: 700 1vw "Noto Sans", sans-serif; text-transform: uppercase; opacity: 1;
  transition: opacity .45s ease; /* apparition (1er de la cascade) */
}
/* Texte unique sous l'année — VISIBLE seulement en focus (titre du contenu). Collapse→expand
   + fade : son apparition fait remonter l'année de sa hauteur (barre ancrée en bas). */
#believe-tl-root .believe-tl-transport__text {
  max-width: 100%; text-align: center; overflow: hidden;
  opacity: 0; max-height: 0;
  font: 800 1.6vw/1.25 "Rubik", Arial, sans-serif; text-transform: uppercase;
  transition: opacity .35s ease, max-height .35s ease, margin .35s ease;
}
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__text {
  opacity: 1; max-height: 24vw; margin-top: 0.5vw;
}
#believe-tl-root .believe-tl-transport__text:empty { display: none; } /* slot titre vide → pas d'espace */
/* Description du contenu (2ᵉ texte), focus only, sous le titre. */
#believe-tl-root .believe-tl-transport__desc {
  max-width: 100%; text-align: center; overflow: hidden; opacity: 0; max-height: 0;
  font: 400 1vw "Noto Sans", sans-serif;
  transition: opacity .35s ease, max-height .35s ease, margin .35s ease;
}
#believe-tl-root .believe-tl-transport__desc:empty { display: none; }
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__desc {
  opacity: 1; max-height: 30vw; margin-top: 0.3vw; white-space: normal;
}
#believe-tl-root .believe-tl-transport__desc a { color: #fff; text-decoration: underline; }
#believe-tl-root .believe-tl-transport__desc a:hover { opacity: .8; }
#believe-tl-root .believe-tl-transport__scrub {
  display: flex; align-items: center; width: 100%; max-width: 20.4vw; /* barre de progression réduite de 15 % (24 → 20.4vw) */
  margin-top: 0.9vw; padding: 0.6vw 0; max-height: 4vw;   /* zone de préhension large pour le drag */
  cursor: pointer; touch-action: none;
  transition: opacity .35s ease, max-height .35s ease, margin .35s ease, padding .35s ease;
}
/* En focus : scrub + boutons latéraux disparaissent (fade) et se collapsent (plus d'espace). */
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__scrub {
  opacity: 0; max-height: 0; margin: 0; padding: 0; pointer-events: none;
}
#believe-tl-root .believe-tl-transport__scrub.is-dragging { cursor: grabbing; }
#believe-tl-root .believe-tl-transport__track {
  position: relative; flex: 1 1 auto; height: 0.12vw; border-radius: 0.12vw;
  background: rgba(255, 255, 255, .3); cursor: pointer;
  transform-origin: left center; /* la ligne se « trace » de gauche à droite à l'apparition */
  transition: transform .55s cubic-bezier(.5, 0, .2, 1);
}
#believe-tl-root .believe-tl-transport__fill {
  position: absolute; left: 0; top: 0; height: 100%; width: 0%;
  background: #fff; border-radius: 0.12vw;
}
#believe-tl-root .believe-tl-transport__handle {
  position: absolute; top: 50%; left: 0%; width: 0.7vw; height: 0.7vw;
  margin-left: -0.35vw; transform: translateY(-50%);
  border-radius: 50%; background: #fff; cursor: grab;
}
#believe-tl-root .believe-tl-transport__scrub.is-dragging .believe-tl-transport__handle { cursor: grabbing; }
#believe-tl-root .believe-tl-transport__controls {
  display: flex; align-items: center; justify-content: center; gap: 1.6vw; margin-top: 0.9vw;
  transition: gap .35s ease, opacity .4s ease; /* opacity = apparition (3ᵉ de la cascade) */
}
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__controls { gap: 0; } /* recentre play/close */
#believe-tl-root .believe-tl-transport__btn {
  display: flex; align-items: center; justify-content: center;
  padding: 0; border: 0; background: none; color: #fff; cursor: pointer;
}
#believe-tl-root .believe-tl-transport__btn svg { display: block; fill: currentColor; }
/* Avance/retour rapide (⏪ élément préc. / ⏩ élément suiv.) masqués → ne restent que ⏮ année préc. / play / ⏭ année suiv. */
#believe-tl-root .believe-tl-transport__btn--rew,
#believe-tl-root .believe-tl-transport__btn--fwd { display: none; }
#believe-tl-root .believe-tl-transport__btn--prev svg,
#believe-tl-root .believe-tl-transport__btn--next svg,
#believe-tl-root .believe-tl-transport__btn--rew svg,
#believe-tl-root .believe-tl-transport__btn--fwd svg { width: 1.2075vw; height: 1.2075vw; } /* prev/next +15 % */
#believe-tl-root .believe-tl-transport__btn--play {
  width: 2.875vw; height: 2.875vw; border: 0.138vw solid #fff; border-radius: 50%; /* play +15 % */
  transition: background .2s, color .2s, transform .2s;
}
#believe-tl-root .believe-tl-transport__btn--play svg { width: 1.0925vw; height: 1.0925vw; } /* play icon +15 % */
#believe-tl-root .believe-tl-transport__btn--play:hover { background: #fff; color: #000; transform: scale(1.06); }
#believe-tl-root .believe-tl-transport__btn--prev,
#believe-tl-root .believe-tl-transport__btn--next,
#believe-tl-root .believe-tl-transport__btn--rew,
#believe-tl-root .believe-tl-transport__btn--fwd {
  max-width: 6vw; overflow: hidden; transition: opacity .25s ease, max-width .35s ease;
}
#believe-tl-root .believe-tl-transport__btn--prev:hover,
#believe-tl-root .believe-tl-transport__btn--next:hover,
#believe-tl-root .believe-tl-transport__btn--rew:hover,
#believe-tl-root .believe-tl-transport__btn--fwd:hover { opacity: .65; }
/* En focus : seuls play/pause/close restent ; les latéraux disparaissent (fade + collapse). */
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__btn--prev,
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__btn--next,
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__btn--rew,
#believe-tl-root .believe-tl-transport.is-focus .believe-tl-transport__btn--fwd {
  opacity: 0; max-width: 0; pointer-events: none;
}
@media (max-width: 600px) {
  #believe-tl-root .believe-tl-transport { bottom: 2.5vw; width: 62vw; }
  /* __year/__text grossis ; ratio desktop conservé (1.6vw/1vw = 1.6) → __text = __year × 1.6.
     NB : placé APRÈS la règle de base __year (font:700 1vw) pour la surcharger (même spécificité). */
  #believe-tl-root .believe-tl-transport__year { font-size: 4vw; }
  /* « Play or scroll » / « click to discover » (hors focus) réduit de 15 % (4 → 3.4vw) ; l'année
     AU FOCUS garde 4vw (sélecteur plus spécifique → ne s'applique qu'hors focus). */
  #believe-tl-root .believe-tl-transport:not(.is-focus) .believe-tl-transport__year { font-size: 3.4vw; }
  #believe-tl-root .believe-tl-transport__text { font-size: 6.4vw; }
  #believe-tl-root .believe-tl-transport__desc { font-size: 3.2vw; }
  /* Barre de progression mobile : 40vw (zone tactile haute = max-height 12vw). */
  #believe-tl-root .believe-tl-transport__scrub { margin-top: 3vw; max-height: 12vw; max-width: 40vw; }
  #believe-tl-root .believe-tl-transport__controls { gap: 7vw; margin-top: 3vw; }
  #believe-tl-root .believe-tl-transport__track { height: 0.5vw; border-radius: 0.5vw; }
  #believe-tl-root .believe-tl-transport__handle { width: 2.2vw; height: 2.2vw; margin-left: -1.1vw; }
  #believe-tl-root .believe-tl-transport__btn--prev svg,
  #believe-tl-root .believe-tl-transport__btn--next svg,
  #believe-tl-root .believe-tl-transport__btn--rew svg,
  #believe-tl-root .believe-tl-transport__btn--fwd svg { width: 5vw; height: 5vw; }
  #believe-tl-root .believe-tl-transport__btn--play { width: 11vw; height: 11vw; border: 0.5vw solid #fff; }
  #believe-tl-root .believe-tl-transport__btn--play svg { width: 4.5vw; height: 4.5vw; }
}

/* Lightbox lecteur d'embeds (overlay hors WebGL). */
.believe-tl-lb {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.82);
  display: flex; align-items: center; justify-content: center;
}
.believe-tl-lb[hidden] { display: none; }
.believe-tl-lb__frame {
  position: relative; width: min(90vw, 960px); aspect-ratio: 16 / 9;
  background: #000;
}
.believe-tl-lb__frame iframe { width: 100%; height: 100%; border: 0; }
.believe-tl-lb__close {
  position: absolute; top: 16px; right: 16px;
  width: 44px; height: 44px; border: 0; border-radius: 50%;
  background: #fff; color: #000; cursor: pointer;
  font: 700 18px "Rubik", Arial, sans-serif;
}
@media (max-width: 600px) {
  .believe-tl-lb__frame { width: 94vw; }
}
