/* ============================================
   primecodevaultlink.com - Animations
   ============================================ */

/* Glitch */
.glitch {
  position: relative;
  display: inline-block;
}

.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.glitch::before {
  color: var(--accent-secondary);
  z-index: -1;
  animation: glitchTop 2.5s infinite;
}

.glitch::after {
  color: var(--accent-primary);
  z-index: -2;
  animation: glitchBottom 2.5s infinite;
}

@keyframes glitchTop {
  0%, 100% { transform: translate(0); }
  20% { transform: translate(-2px, -1px); }
  40% { transform: translate(2px, 1px); }
}
@keyframes glitchBottom {
  0%, 100% { transform: translate(0); }
  20% { transform: translate(2px, 1px); }
  40% { transform: translate(-2px, -1px); }
}

/* Slide */
.slide-in-left {
  opacity: 0;
  transform: translateX(-60px);
  transition: opacity 0.8s var(--transition-smooth), transform 0.8s var(--transition-smooth);
}
.slide-in-right {
  opacity: 0;
  transform: translateX(60px);
  transition: opacity 0.8s var(--transition-smooth), transform 0.8s var(--transition-smooth);
}
.slide-in-up {
  opacity: 0;
  transform: translateY(60px);
  transition: opacity 0.8s var(--transition-smooth), transform 0.8s var(--transition-smooth);
}
.slide-in-down {
  opacity: 0;
  transform: translateY(-60px);
  transition: opacity 0.8s var(--transition-smooth), transform 0.8s var(--transition-smooth);
}

.slide-in-left.visible, .slide-in-right.visible,
.slide-in-up.visible, .slide-in-down.visible {
  opacity: 1;
  transform: translate(0);
}

.fade-in {
  opacity: 0;
  transition: opacity 1s var(--transition-smooth);
}
.fade-in.visible { opacity: 1; }

.scale-in {
  opacity: 0;
  transform: scale(0.92);
  transition: opacity 0.8s var(--transition-smooth), transform 0.8s var(--transition-smooth);
}
.scale-in.visible {
  opacity: 1;
  transform: scale(1);
}

/* Float */
.float {
  animation: floatY 6s ease-in-out infinite;
}
.float-slow {
  animation: floatY 10s ease-in-out infinite;
}
.float-fast {
  animation: floatY 4s ease-in-out infinite;
}

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

/* Glow pulse */
.glow-pulse {
  animation: glowPulse 2.5s ease-in-out infinite;
}

@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 0 rgba(0, 212, 255, 0.3); }
  50% { box-shadow: 0 0 40px rgba(0, 212, 255, 0.6); }
}

/* Gradient shift */
.gradient-shift {
  background-size: 200% 200%;
  animation: gradientShift 6s ease infinite;
}

@keyframes gradientShift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* Orbit */
.orbit {
  animation: orbit 20s linear infinite;
}

@keyframes orbit {
  to { transform: rotate(360deg); }
}

/* Counter */
.counter {
  font-variant-numeric: tabular-nums;
}

/* Morph blob */
.morph-blob {
  border-radius: 42% 58% 70% 30% / 45% 30% 70% 55%;
  animation: morph 8s ease-in-out infinite;
}

@keyframes morph {
  0%, 100% { border-radius: 42% 58% 70% 30% / 45% 30% 70% 55%; }
  50% { border-radius: 70% 30% 50% 50% / 30% 60% 40% 70%; }
}

/* Shimmer */
.shimmer {
  position: relative;
  overflow: hidden;
}

.shimmer::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  animation: shimmerSlide 3s infinite;
}

@keyframes shimmerSlide {
  0% { left: -100%; }
  100% { left: 200%; }
}

/* Wave children */
.wave > * {
  animation: waveUp 1s ease forwards;
  opacity: 0;
}
.wave > *:nth-child(1) { animation-delay: 0s; }
.wave > *:nth-child(2) { animation-delay: 0.1s; }
.wave > *:nth-child(3) { animation-delay: 0.2s; }
.wave > *:nth-child(4) { animation-delay: 0.3s; }
.wave > *:nth-child(5) { animation-delay: 0.4s; }
.wave > *:nth-child(6) { animation-delay: 0.5s; }
.wave > *:nth-child(7) { animation-delay: 0.6s; }
.wave > *:nth-child(8) { animation-delay: 0.7s; }

@keyframes waveUp {
  0% { opacity: 0; transform: translateY(20px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* Bounce in */
.bounce-in {
  animation: bounceIn 0.8s var(--transition-bounce) forwards;
}

@keyframes bounceIn {
  0% { opacity: 0; transform: scale(0.6); }
  60% { opacity: 1; transform: scale(1.05); }
  100% { transform: scale(1); }
}

/* Tilt card */
.tilt-card {
  transform-style: preserve-3d;
  perspective: 1000px;
}

/* Aurora blobs */
.aurora-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.4;
  pointer-events: none;
  z-index: 0;
}

.aurora-1 {
  width: 500px;
  height: 500px;
  background: var(--accent-secondary);
  top: 0;
  left: 0;
  animation: floatY 12s ease-in-out infinite;
}

.aurora-2 {
  width: 600px;
  height: 600px;
  background: var(--accent-tertiary);
  bottom: 0;
  right: 0;
  animation: floatY 14s ease-in-out infinite reverse;
}

.aurora-3 {
  width: 400px;
  height: 400px;
  background: var(--accent-primary);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: morph 10s ease-in-out infinite;
}

/* Animated gradient text */
.animated-gradient {
  background: linear-gradient(135deg, #00d4ff, #8b5cf6, #e82127, #00d4ff);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: animatedGradient 8s ease infinite;
}

@keyframes animatedGradient {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* Reveal mask */
.reveal-mask {
  position: relative;
  overflow: hidden;
}

.reveal-mask::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-primary);
  transform-origin: right;
  transition: transform 1.2s var(--transition-smooth);
}

.reveal-mask.visible::after {
  transform: scaleX(0);
}

/* Hover line */
.hover-line {
  position: relative;
  display: inline-block;
}

.hover-line::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--accent-secondary);
  transition: width 0.4s var(--transition-smooth);
}

.hover-line:hover::after {
  width: 100%;
}

/* Draw border */
.draw-border path,
.draw-border rect,
.draw-border circle {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: drawStroke 3s var(--transition-smooth) forwards;
}

@keyframes drawStroke {
  to { stroke-dashoffset: 0; }
}

/* Infinite slide */
.infinite-slide {
  display: flex;
  animation: infiniteSlide 30s linear infinite;
}

.infinite-slide:hover {
  animation-play-state: paused;
}

@keyframes infiniteSlide {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Magnetic button cursor */
.magnetic-btn {
  position: relative;
  overflow: hidden;
}

.magnetic-btn::before {
  content: '';
  position: absolute;
  top: var(--y, 50%);
  left: var(--x, 50%);
  width: 0;
  height: 0;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.3), transparent 60%);
  border-radius: 50%;
  transition: width 0.4s, height 0.4s;
  transform: translate(-50%, -50%);
}

.magnetic-btn:hover::before {
  width: 300px;
  height: 300px;
}

/* Typewriter */
.typewriter {
  display: inline-block;
  overflow: hidden;
  border-right: 2px solid var(--accent-secondary);
  white-space: nowrap;
  animation: typing 3.5s steps(30) 1s forwards, blink 0.75s step-end infinite;
  width: 0;
}

@keyframes typing {
  to { width: 100%; }
}

@keyframes blink {
  50% { border-color: transparent; }
}

/* Cursor follow */
.cursor-glow {
  position: fixed;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(0, 212, 255, 0.15), transparent 60%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: transform 0.2s var(--transition-smooth);
  mix-blend-mode: screen;
}

/* Border gradient animation */
.gradient-border {
  position: relative;
  background: var(--bg-secondary);
  border-radius: var(--radius-lg);
}

.gradient-border::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, var(--accent-secondary), var(--accent-tertiary), var(--accent-primary));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  background-size: 200% 200%;
  animation: gradientShift 6s ease infinite;
}

/* Marquee */
.marquee {
  display: flex;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}

.marquee-track {
  display: flex;
  gap: 40px;
  animation: marqueeMove 30s linear infinite;
}

@keyframes marqueeMove {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
