/* --- Reduced motion preference --- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* --- Hover lift effect --- */
.hover-lift {
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
}
.hover-lift:hover {
  transform: translateY(-4px);
}

/* --- Subtle border glow on hover --- */
.hover-glow {
  transition: border-color var(--duration-normal),
              box-shadow var(--duration-normal);
}
.hover-glow:hover {
  border-color: var(--color-primary-200);
  box-shadow: var(--shadow-glow);
}

/* --- Underline grow effect for links --- */
.link-underline {
  position: relative;
}
.link-underline::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-primary-500);
  transition: width var(--duration-normal) var(--ease-out);
}
.link-underline:hover::after {
  width: 100%;
}
