/* Custom animations + transitions overlay */

@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}
.animate-float { animation: floatY 4s ease-in-out infinite; }

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

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.shimmer {
  background: linear-gradient(90deg, var(--mf-cream) 0%, var(--mf-orange-soft) 50%, var(--mf-cream) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

/* Underline-grow effect for links */
.link-grow {
  position: relative;
  display: inline-block;
}
.link-grow::after {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 0; height: 2px;
  background: var(--mf-orange);
  transition: width 300ms ease;
}
.link-grow:hover::after { width: 100%; }

/* Card glow on hover */
.glow-on-hover {
  position: relative;
  overflow: hidden;
}
.glow-on-hover::before {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 60%; height: 200%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.18), transparent);
  transform: rotate(20deg) translateX(-100%);
  transition: transform 600ms ease;
  pointer-events: none;
}
.glow-on-hover:hover::before { transform: rotate(20deg) translateX(280%); }

/* Reveal-on-scroll alt for non-AOS use */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms ease-out, transform 700ms ease-out;
}
.reveal.in-view { opacity: 1; transform: translateY(0); }
