/* Hero entrance animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

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

.hero-animate-1 {
  animation: fadeInUp 0.8s ease forwards;
  opacity: 0;
}

.hero-animate-2 {
  animation: fadeInUp 0.8s ease 0.15s forwards;
  opacity: 0;
}

.hero-animate-3 {
  animation: fadeInUp 0.8s ease 0.3s forwards;
  opacity: 0;
}

.hero-animate-4 {
  animation: fadeInUpLarge 1s ease 0.5s forwards;
  opacity: 0;
}

.mockup-float {
  animation: mockupFloat 6s ease-in-out infinite;
}

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

/* ══════════════════════════════════════
   ANIMATED GRADIENT ORBS
   ══════════════════════════════════════ */
.hero-orbs {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.12;
  will-change: transform;
}

.hero-orb-1 {
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, var(--gold) 0%, transparent 70%);
  top: -15%;
  left: 40%;
  animation: orbDrift1 12s ease-in-out infinite;
}

.hero-orb-2 {
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, #e85d2a 0%, transparent 70%);
  top: 20%;
  right: -5%;
  animation: orbDrift2 15s ease-in-out infinite;
  opacity: 0.08;
}

.hero-orb-3 {
  width: 350px;
  height: 350px;
  background: radial-gradient(circle, var(--gold) 0%, transparent 70%);
  bottom: 5%;
  left: 10%;
  animation: orbDrift3 18s ease-in-out infinite;
  opacity: 0.06;
}

@keyframes orbDrift1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(60px, 30px) scale(1.05); }
  66% { transform: translate(-40px, -20px) scale(0.95); }
}

@keyframes orbDrift2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(-50px, 40px) scale(1.1); }
  66% { transform: translate(30px, -30px) scale(0.9); }
}

@keyframes orbDrift3 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(40px, -40px) scale(1.08); }
}

/* ══════════════════════════════════════
   GRAIN TEXTURE OVERLAY
   ══════════════════════════════════════ */
.hero-grain {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 128px 128px;
}

/* ══════════════════════════════════════
   TYPING EFFECT
   ══════════════════════════════════════ */
.typed-wrap {
  display: inline;
}

.typed-text {
  color: var(--gold);
  font-weight: 600;
}

.typed-cursor {
  display: inline-block;
  color: var(--gold);
  font-weight: 300;
  animation: cursorBlink 0.8s step-end infinite;
  margin-left: 1px;
}

@keyframes cursorBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}

/* ══════════════════════════════════════
   PARALLAX SCROLL
   ══════════════════════════════════════ */
.parallax-scroll {
  will-change: transform;
  transition: transform 0.1s linear;
}

/* ══════════════════════════════════════
   SCROLL REVEAL
   ══════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

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

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ══════════════════════════════════════
   NAVBAR TRANSITION
   ══════════════════════════════════════ */
.navbar {
  transition: background-color var(--transition-base), border-color var(--transition-base), backdrop-filter var(--transition-base);
}

.navbar.scrolled {
  background-color: rgba(10, 10, 15, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--dark-border);
}

/* ══════════════════════════════════════
   HOVER EFFECTS
   ══════════════════════════════════════ */
.card-hover {
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.card-hover:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
}

/* Integration logos */
.integration-logo {
  filter: grayscale(1);
  opacity: 0.5;
  transition: all var(--transition-base);
}

.integration-logo:hover {
  filter: grayscale(0);
  opacity: 1;
}

/* ══════════════════════════════════════
   REDUCED MOTION
   ══════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .hero-animate-1,
  .hero-animate-2,
  .hero-animate-3,
  .hero-animate-4 {
    opacity: 1;
    animation: none;
  }

  .mockup-float {
    animation: none;
  }

  .hero-orb {
    animation: none;
  }

  .typed-cursor {
    animation: none;
  }

  * {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
