/* ===== KEYFRAMES ===== */
@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@keyframes pulse-or {
  0%, 100% { box-shadow: 0 0 0 0 rgba(212,175,55,0.4); }
  50%       { box-shadow: 0 0 0 12px rgba(212,175,55,0); }
}

@keyframes flottement {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}

@keyframes apparition {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ===== CLASSES SCROLL-REVEAL ===== */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal.reveal-gauche {
  transform: translateX(-40px);
}
.reveal.reveal-droite {
  transform: translateX(40px);
}
.reveal.visible {
  opacity: 1;
  transform: translate(0, 0);
}
.reveal:nth-child(2) { transition-delay: 0.1s; }
.reveal:nth-child(3) { transition-delay: 0.2s; }
.reveal:nth-child(4) { transition-delay: 0.3s; }

/* ===== TYPEWRITER ===== */
.typewriter-cursor::after {
  content: '|';
  color: var(--or);
  animation: clignote 0.8s step-end infinite;
}
@keyframes clignote {
  50% { opacity: 0; }
}

/* ===== COMPTEUR ===== */
.compteur-chiffre {
  font-family: var(--font-titre);
  font-size: clamp(3rem, 8vw, 6rem);
  font-weight: 900;
  color: var(--or);
  display: block;
  line-height: 1;
}

/* ===== BARRE SONDAGE ===== */
.barre-sondage-fond {
  background: rgba(255,255,255,0.1);
  border-radius: 4px;
  height: 12px;
  overflow: hidden;
  margin: 0.4rem 0 0.8rem;
}
.barre-sondage-valeur {
  height: 100%;
  background: linear-gradient(90deg, var(--rouge), var(--or));
  border-radius: 4px;
  width: 0%;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ===== PULSE bouton CTA ===== */
.pulse { animation: pulse-or 2s infinite; }

/* ===== FADE-IN message mur ===== */
.message-nouveau {
  animation: apparition 0.5s ease forwards;
}
