/* ============================================================
   ACCURACY QUOTING — ANIMATIONS
   Modern dark SaaS aesthetic
   Scroll reveals, stagger, shimmer, counters, glow borders
   All disabled for prefers-reduced-motion
   ============================================================ */

/* ---------- Scroll Reveal Base States ---------- */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

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

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

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

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

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

.reveal-scale {
  opacity: 0;
  transform: scale(0.95);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

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


/* ---------- Staggered Children ---------- */
.stagger-children > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.stagger-children.visible > *:nth-child(1) { transition-delay: 0ms; }
.stagger-children.visible > *:nth-child(2) { transition-delay: 70ms; }
.stagger-children.visible > *:nth-child(3) { transition-delay: 140ms; }
.stagger-children.visible > *:nth-child(4) { transition-delay: 210ms; }
.stagger-children.visible > *:nth-child(5) { transition-delay: 280ms; }
.stagger-children.visible > *:nth-child(6) { transition-delay: 350ms; }
.stagger-children.visible > *:nth-child(7) { transition-delay: 420ms; }
.stagger-children.visible > *:nth-child(8) { transition-delay: 490ms; }
.stagger-children.visible > *:nth-child(9) { transition-delay: 560ms; }

.stagger-children.visible > * {
  opacity: 1;
  transform: translateY(0);
}


/* ---------- Button Shimmer (subtle) ---------- */
.btn-shimmer {
  position: relative;
  overflow: hidden;
}

.btn-shimmer::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.08) 40%,
    rgba(255, 255, 255, 0.12) 50%,
    rgba(255, 255, 255, 0.08) 60%,
    transparent 100%
  );
  transition: none;
  animation: shimmer 5s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

@keyframes shimmer {
  0%   { left: -100%; }
  25%  { left: 150%; }
  100% { left: 150%; }
}


/* ---------- Stat Counter Pulse ---------- */
.counter-animate {
  transition: color 0.3s ease;
}

.counter-animate.counting {
  color: var(--orange);
}


/* ---------- Hero Entrance ---------- */
.hero-enter .hero-badge {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.1s forwards;
}

.hero-enter h1 {
  opacity: 0;
  transform: translateY(24px);
  animation: fadeUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.2s forwards;
}

.hero-enter .hero-subtitle {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.4s forwards;
}

.hero-enter .hero-ctas {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.55s forwards;
}

.hero-enter .hero-stats {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.7s forwards;
}

.hero-enter .hero-visual {
  opacity: 0;
  transform: translateX(24px);
  animation: fadeLeft 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards;
}

@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeLeft {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}


/* ---------- Nav Scroll Transition (frosted glass) ---------- */
.navbar {
  transition: background-color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              backdrop-filter 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              -webkit-backdrop-filter 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              border-color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              padding 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}


/* ---------- Animated Gradient Border for Featured Cards ---------- */
.card-glow {
  position: relative;
  transition: box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.card-glow::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(
    135deg,
    rgba(249, 115, 22, 0.4),
    rgba(249, 115, 22, 0.1) 30%,
    transparent 50%,
    rgba(249, 115, 22, 0.1) 70%,
    rgba(249, 115, 22, 0.4)
  );
  background-size: 300% 300%;
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  mask-composite: exclude;
  animation: gradient-rotate 6s ease infinite;
  opacity: 0.7;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: 1;
}

.card-glow:hover::before {
  opacity: 1;
}

.card-glow:hover {
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(249, 115, 22, 0.2);
  transform: translateY(-2px);
}

@keyframes gradient-rotate {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}


/* ---------- Parallax-Ready ---------- */
.parallax-ready {
  will-change: transform;
  transition: transform 0.1s linear;
}


/* ---------- Image Hover Zoom ---------- */
.img-hover-zoom {
  overflow: hidden;
}

.img-hover-zoom img {
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.img-hover-zoom:hover img {
  transform: scale(1.04);
}


/* ---------- Pulse Ring (for badges) ---------- */
@keyframes pulse-ring {
  0% {
    box-shadow: 0 0 0 0 rgba(249, 115, 22, 0.35);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(249, 115, 22, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(249, 115, 22, 0);
  }
}


/* ============================================================
   REDUCED MOTION — Disable all animations
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .reveal,
  .reveal-left,
  .reveal-right,
  .reveal-scale,
  .stagger-children > * {
    opacity: 1;
    transform: none;
  }

  .hero-enter .hero-badge,
  .hero-enter h1,
  .hero-enter .hero-subtitle,
  .hero-enter .hero-ctas,
  .hero-enter .hero-stats,
  .hero-enter .hero-visual {
    opacity: 1;
    transform: none;
    animation: none;
  }

  .btn-shimmer::after {
    animation: none;
    display: none;
  }

  .card-glow::before {
    animation: none;
    opacity: 0.7;
  }

  .parallax-ready {
    will-change: auto;
    transition: none;
  }
}
