/* ============================================================
   GROMALLY PREMIUM — Animations & Transitions
   ============================================================ */

/* --- Scroll Reveal Base --- */
.reveal {
  opacity: 0;
  transform: translateY(60px) scale(0.98);
  transition: opacity 1s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1);
  filter: blur(5px);
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-80px);
  transition: opacity 1s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(80px);
  transition: opacity 1s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}

.reveal-scale {
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 1s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1);
  filter: blur(10px);
}

.reveal-scale.visible {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}

/* Stagger delays */
.delay-1 { transition-delay: 0.1s; animation-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; animation-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; animation-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; animation-delay: 0.4s; }
.delay-5 { transition-delay: 0.5s; animation-delay: 0.5s; }

/* --- Hero Animations --- */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(40px) scale(0.98); filter: blur(5px); }
  to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px) rotate(1deg); }
}

@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 20px var(--gro-green-glow); }
  50% { box-shadow: 0 0 50px var(--gro-green-glow), 0 0 80px rgba(0, 255, 102, 0.2); }
}

/* --- Marquee Animation --- */
@keyframes marquee-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* --- Hero Text Reveal --- */
.hero-animate {
  animation: fadeInUp 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
}

/* --- Floating Phone --- */
.animate-float {
  animation: float 6s ease-in-out infinite;
}

/* --- Pulse Glow --- */
.animate-pulse-glow {
  animation: pulseGlow 4s ease-in-out infinite;
}

/* --- Loading screen transition --- */
.site-loader {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 1s ease, visibility 1s ease;
}

.site-loader.loaded {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.site-loader .loader-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  animation: loaderReveal 0.9s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
  position: relative;
}

/* Radial glow behind the logo */
.site-loader .loader-logo::before {
  content: '';
  position: absolute;
  inset: -80px;
  background: radial-gradient(ellipse at center,
    rgba(0, 210, 110, 0.4) 0%,
    rgba(0, 200, 100, 0.2) 35%,
    rgba(0, 190, 80, 0.08) 60%,
    transparent 75%
  );
  animation: loaderGlowPulse 1.8s ease-in-out infinite;
  border-radius: 50%;
  z-index: -1;
}

/* Outer wide halo */
.site-loader .loader-logo::after {
  content: '';
  position: absolute;
  inset: -160px;
  background: radial-gradient(ellipse at center,
    rgba(191, 255, 0, 0.1) 0%,
    rgba(0, 200, 100, 0.05) 40%,
    transparent 65%
  );
  animation: loaderGlowPulse 1.8s ease-in-out infinite reverse;
  border-radius: 50%;
  z-index: -2;
}

.site-loader .loader-logo img {
  width: 220px;
  height: 220px;
  object-fit: contain;
  animation: logoGlowPulse 1.8s ease-in-out infinite;
}

@keyframes loaderReveal {
  from { opacity: 0; transform: scale(0.75); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes loaderGlowPulse {
  0%, 100% { opacity: 0.7; transform: scale(1); }
  50%       { opacity: 1;   transform: scale(1.18); }
}

@keyframes logoGlowPulse {
  0%, 100% {
    filter:
      drop-shadow(0 0 10px rgba(0, 220, 120, 1))
      drop-shadow(0 0 28px rgba(0, 200, 100, 0.8))
      drop-shadow(0 0 60px rgba(0, 180, 80, 0.5))
      drop-shadow(0 0 100px rgba(0, 160, 60, 0.25));
  }
  50% {
    filter:
      drop-shadow(0 0 18px rgba(191, 255, 0, 1))
      drop-shadow(0 0 45px rgba(0, 220, 120, 0.95))
      drop-shadow(0 0 90px rgba(0, 200, 100, 0.7))
      drop-shadow(0 0 150px rgba(0, 180, 80, 0.4));
  }
}
