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

@keyframes fadeFromRight {
  from { opacity: 0; transform: translateX(32px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 8px var(--green); }
  50%       { box-shadow: 0 0 16px var(--green), 0 0 24px var(--green); }
}

@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}


.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}

.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; }


.skill-card-lg:hover {
  box-shadow: 0 0 20px rgba(56, 189, 248, 0.2), 0 0 40px rgba(56, 189, 248, 0.08);
}

.skill-pill:hover {
  box-shadow: 0 0 12px rgba(56, 189, 248, 0.2);
}

.project-card:hover {
  box-shadow: 0 0 30px rgba(56, 189, 248, 0.15), 0 8px 32px rgba(0, 0, 0, 0.4);
  border-color: var(--border-hover);
  transform: translateY(-4px);
}

.card:hover {
  box-shadow: 0 0 24px rgba(56, 189, 248, 0.12), 0 6px 24px rgba(0, 0, 0, 0.3);
  border-color: var(--border-hover);
  transform: translateY(-3px);
}

.stat-card:hover {
  box-shadow: 0 0 20px rgba(56, 189, 248, 0.15);
  border-color: var(--border-hover);
  transform: translateY(-3px);
}

.nav-links a:hover {
  color: var(--blue-bright);
  text-shadow: 0 0 12px rgba(56, 189, 248, 0.5);
}

.project-action-btn:hover {
  background: var(--blue-glow);
  border-color: var(--border-hover);
  color: var(--blue-bright);
  box-shadow: 0 0 10px rgba(56, 189, 248, 0.2);
}