/* Default hidden state */
.section-content {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

/* Active when in viewport */
.section-content.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Optional: different styles */
.section-content.fade-left {
  transform: translateX(-40px);
}
.section-content.fade-left.visible {
  transform: translateX(0);
}

.section-content.fade-right {
  transform: translateX(40px);
}
.section-content.fade-right.visible {
  transform: translateX(0);
}
