/* <!-- 
  Built by Christian Vendramel Rebolo
  If you're reading this, give credit  😉
  Unauthorized copying is prohibited.
--> */

/* cr-dev-signature: Christian Vendramel Rebolo */

/* ============================================================
   THIAGOFNX — ANIMAÇÕES
   ============================================================ */

/* ── Keyframes ── */
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

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

@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to   { opacity: 1; transform: translateX(0); }
}

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

@keyframes pulseRing {
  0%   { transform: scale(0.9); opacity: 0.5; }
  50%  { transform: scale(1.15); opacity: 0.12; }
  100% { transform: scale(0.9); opacity: 0.5; }
}

@keyframes scrollHint {
  0%, 100% { opacity: 0.3; transform: translateY(0); }
  50%       { opacity: 1;   transform: translateY(6px); }
}

/* ── Reveal por scroll (base — controlado via JS / IntersectionObserver) ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s var(--ease),
              transform 0.8s var(--ease);
}

.reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* Variantes de direção */
.reveal--left  { transform: translateX(-28px); }
.reveal--right { transform: translateX(28px); }
.reveal--scale { transform: scale(0.94); }

.reveal--left.is-visible,
.reveal--right.is-visible,
.reveal--scale.is-visible {
  transform: none;
}

/* Delays escalonados */
.delay-1 { transition-delay: 0.10s; }
.delay-2 { transition-delay: 0.20s; }
.delay-3 { transition-delay: 0.30s; }
.delay-4 { transition-delay: 0.40s; }
.delay-5 { transition-delay: 0.50s; }

/* ── Entrada da página ── */
.page-enter {
  animation: fadeIn 0.5s var(--ease) both;
}

/* ── Scroll hint (seta animada no hero) ── */
.scroll-hint {
  animation: scrollHint 2s ease-in-out infinite;
}

/* ── Floating (logo mark no hero) ── */
.floating {
  animation: float 4s ease-in-out infinite;
}

/* ── Fade-in com delay para hero ── */
.hero-anim-1 { animation: fadeInUp 0.7s var(--ease) 0.1s both; }
.hero-anim-2 { animation: fadeInUp 0.7s var(--ease) 0.25s both; }
.hero-anim-3 { animation: fadeInUp 0.7s var(--ease) 0.4s both; }
.hero-anim-4 { animation: fadeInUp 0.7s var(--ease) 0.55s both; }
.hero-anim-5 { animation: fadeIn  0.9s var(--ease) 0.8s  both; }
