/* Phase 4 safeguard: page hero text must stay readable even if motion JS fails. */
.onexus-hero__title,
.onexus-hero__body,
.onexus-eyebrow,
.onexus-hero h1,
.content-page h1 {
  opacity: 1 !important;
}

@media (prefers-reduced-motion: no-preference) {
  .hero__content {
    animation: onexus-hero-rise 760ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
  }

  .hero__video,
  .onexus-service-hero__image {
    animation: onexus-hero-object 1100ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
  }

  .onexus-reveal {
    opacity: 1;
    transform: translateY(12px);
    transition: opacity 520ms ease, transform 520ms ease;
    transition-delay: var(--reveal-delay, 0ms);
  }

  .onexus-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
  }

  .onexus-native-motion .onexus-native-reveal {
    opacity: 1;
    transform: translateY(12px);
    filter: blur(0);
    transition: opacity 680ms cubic-bezier(0.2, 0.8, 0.2, 1), transform 680ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 680ms cubic-bezier(0.2, 0.8, 0.2, 1);
    transition-delay: var(--native-delay, 0ms);
  }

  .onexus-native-motion .onexus-native-reveal.is-motion-visible {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }

  .info-card,
  .case-card,
  .onexus-card,
  .onexus-service-step,
  .tool-list article,
  .feature-grid article {
    transition: transform 220ms ease, border-color 220ms ease, background 220ms ease, box-shadow 220ms ease;
  }

  .info-card:hover,
  .case-card:hover,
  .onexus-card:hover,
  .onexus-service-step:hover,
  .tool-list article:hover,
  .feature-grid article:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 141, 117, 0.55);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
  }

  .onexus-card-media img,
  .onexus-service-hero__image {
    transition: transform 600ms ease, filter 600ms ease;
  }

  .case-card:hover .onexus-card-media img,
  .onexus-service-card:hover .onexus-card-media img {
    transform: scale(1.04);
    filter: saturate(1.04) contrast(1.04);
  }
}

@keyframes onexus-hero-rise {
  from {
    opacity: 1;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes onexus-hero-object {
  from {
    opacity: 1;
    transform: translate3d(12px, 8px, 0) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .onexus-motion-bg,
  .onexus-motion-scrim {
    display: none !important;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}
