/* ── Scroll reveal (site-wide) ── */
.reveal,
.reveal-left,
.reveal-right,
.reveal-scale,
.reveal-fade {
  opacity: 0;
  transition:
    opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.reveal       { transform: translateY(40px); }
.reveal-left  { transform: translateX(-40px); }
.reveal-right { transform: translateX(40px); }
.reveal-scale { transform: scale(0.94); }
.reveal-fade  { transform: none; }

.reveal.revealed,
.reveal-left.revealed,
.reveal-right.revealed,
.reveal-scale.revealed,
.reveal-fade.revealed {
  opacity: 1;
  transform: none;
}

/* Stagger children inside grids / lists */
.stagger-child {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.stagger-parent.revealed .stagger-child {
  opacity: 1;
  transform: none;
}

/* Hero entrance (page load) */
.hero-animate {
  opacity: 0;
  transform: translateY(32px);
  animation: heroEnter 1s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.hero-animate-delay-1 { animation-delay: 0.12s; }
.hero-animate-delay-2 { animation-delay: 0.24s; }
.hero-animate-delay-3 { animation-delay: 0.36s; }

@keyframes heroEnter {
  to {
    opacity: 1;
    transform: none;
  }
}

/* Live section accent — animated top line when visible */
.section-live {
  position: relative;
}

.section-live::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 0;
  height: 2px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, #e2791d, #f4a04a, #e2791d, transparent);
  background-size: 200% 100%;
  opacity: 0;
  transition: width 1s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.6s;
  pointer-events: none;
}

.section-live.revealed::after {
  width: min(320px, 60%);
  opacity: 1;
  animation: liveShimmer 4s linear infinite;
}

@keyframes liveShimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Subtle floating live accent dots */
.live-float {
  animation: liveFloat 5s ease-in-out infinite;
}

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

/* Cards lift gently when revealed */
.reveal-card {
  transition:
    opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.75s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.4s;
}

.reveal-card:not(.revealed) {
  opacity: 0;
  transform: translateY(28px) scale(0.98);
}

.reveal-card.revealed {
  opacity: 1;
  transform: none;
}

.reveal-card.revealed:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 48px rgba(226, 121, 29, 0.1);
}

/* Parallax backgrounds */
[data-parallax] {
  will-change: transform;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-left,
  .reveal-right,
  .reveal-scale,
  .reveal-fade,
  .stagger-child,
  .reveal-card:not(.revealed) {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .hero-animate {
    opacity: 1;
    transform: none;
    animation: none;
  }

  .section-live::after {
    display: none;
  }

  .live-float {
    animation: none;
  }

  [data-parallax] {
    transform: none !important;
  }
}
