/* ============================================================
   LOCKPOINT — Animations CSS
   Keyframes, scroll reveals, transitions
   ============================================================ */

/* ─── Keyframes ─────────────────────────────────────────── */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes fade-left {
  from { opacity: 0; transform: translateX(28px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes fade-right {
  from { opacity: 0; transform: translateX(-28px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes scale-in {
  from { opacity: 0; transform: scale(.92); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes slide-up-sticky {
  from { opacity: 0; transform: translateX(-50%) translateY(24px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 3px rgba(22,163,74,.2); }
  50%       { box-shadow: 0 0 0 7px rgba(22,163,74,.08); }
}

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

@keyframes shimmer {
  from { background-position: -200% center; }
  to   { background-position: 200% center; }
}

/* ─── Scroll Reveal Classes ─────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s cubic-bezier(.4,0,.2,1), transform .6s cubic-bezier(.4,0,.2,1);
}

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

.reveal-left {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity .6s cubic-bezier(.4,0,.2,1), transform .6s cubic-bezier(.4,0,.2,1);
}

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

.reveal-right {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity .6s cubic-bezier(.4,0,.2,1), transform .6s cubic-bezier(.4,0,.2,1);
}

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

.reveal-scale {
  opacity: 0;
  transform: scale(.95);
  transition: opacity .5s cubic-bezier(.4,0,.2,1), transform .5s cubic-bezier(.4,0,.2,1);
}

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

/* Stagger delays */
.delay-1 { transition-delay: .1s !important; }
.delay-2 { transition-delay: .2s !important; }
.delay-3 { transition-delay: .3s !important; }
.delay-4 { transition-delay: .4s !important; }
.delay-5 { transition-delay: .5s !important; }
.delay-6 { transition-delay: .6s !important; }

/* ─── Hero entrance ─────────────────────────────────────── */
.hero-content > * { opacity: 0; animation: fade-up .7s cubic-bezier(.4,0,.2,1) forwards; }
.hero-content .hero-badge-wrap { animation-delay: .1s; }
.hero-content .hero-title { animation-delay: .2s; }
.hero-content .hero-text { animation-delay: .3s; }
.hero-content .hero-cta { animation-delay: .4s; }
.hero-content .hero-trust { animation-delay: .5s; }
.hero-visual { animation: fade-left .8s .35s cubic-bezier(.4,0,.2,1) both; }

/* ─── Floating badge animation ──────────────────────────── */
.hero-floating-badge-1 {
  animation: fade-right .8s .6s cubic-bezier(.34,1.56,.64,1) both;
}

.hero-floating-badge-2 {
  animation: fade-left .8s .7s cubic-bezier(.34,1.56,.64,1) both;
}

/* ─── Logo shimmer ───────────────────────────────────────── */
.nav-logo {
  background: linear-gradient(90deg, var(--ink) 0%, var(--ink) 40%, var(--blue) 50%, var(--ink) 60%, var(--ink) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* On hover only */
.nav-logo:hover {
  animation: shimmer 1.2s linear;
}

/* ─── Button ripple effect ───────────────────────────────── */
.btn {
  isolation: isolate;
}

/* ─── Page transition ────────────────────────────────────── */
.page-enter {
  animation: fade-in .35s ease forwards;
}

/* ─── Number counter animation ───────────────────────────── */
@keyframes count-up {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Trust card hover ───────────────────────────────────── */
.trust-card .icon-box {
  transition: transform var(--transition), background var(--transition);
}

.trust-card:hover .icon-box {
  transform: scale(1.1) rotate(-5deg);
  background: var(--blue);
  color: var(--white);
}

/* ─── CTA pulse ──────────────────────────────────────────── */
@keyframes btn-pulse {
  0%   { box-shadow: 0 8px 32px rgba(0,78,158,.20); }
  50%  { box-shadow: 0 8px 48px rgba(0,78,158,.40); }
  100% { box-shadow: 0 8px 32px rgba(0,78,158,.20); }
}

.btn-primary.pulse-anim {
  animation: btn-pulse 2.5s infinite;
}

/* ─── Nav link underline animation ──────────────────────── */
.nav-link {
  position: relative;
}

/* ─── Zigzag visual hover ────────────────────────────────── */
.zigzag-visual-inner {
  transition: transform var(--transition-slow);
}

.zigzag-item:hover .zigzag-visual-inner {
  transform: scale(1.02);
}

/* ─── Area card icon float ───────────────────────────────── */
.area-card:hover .icon-box-lg {
  animation: float 3s infinite;
}

/* ─── Reduce motion ──────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-left, .reveal-right, .reveal-scale {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .hero-content > *, .hero-visual, .hero-floating-badge-1, .hero-floating-badge-2 {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}
