:root {
  --ui-motion-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ui-motion-fast: 160ms;
  --ui-motion-base: 620ms;
  --ui-motion-distance: 28px;
  --ui-motion-shadow-soft: 0 18px 40px rgba(13, 30, 37, 0.08);
  --ui-motion-shadow-strong: 0 28px 60px rgba(13, 30, 37, 0.14);
  --ui-motion-shadow-action: 0 14px 32px rgba(13, 30, 37, 0.16);
  --ui-motion-shadow-card: 0 30px 70px rgba(13, 30, 37, 0.18);
  --ui-motion-ring: 0 0 0 1px rgba(0, 32, 70, 0.08);
}

html.has-ui-motion [data-ui-reveal] {
  opacity: 0;
  transform: translate3d(0, var(--ui-motion-distance), 0) scale(0.972);
  filter: saturate(0.94) blur(2px);
  transition:
    opacity var(--ui-motion-base) var(--ui-motion-ease),
    transform var(--ui-motion-base) var(--ui-motion-ease),
    filter var(--ui-motion-base) var(--ui-motion-ease);
  transition-delay: var(--ui-motion-delay, 0ms);
  will-change: opacity, transform, filter;
}

html.has-ui-motion [data-ui-reveal="card"] {
  --ui-motion-distance: 22px;
  --ui-motion-base: 540ms;
}

html.has-ui-motion [data-ui-reveal="media"] {
  --ui-motion-distance: 18px;
  --ui-motion-base: 580ms;
}

html.has-ui-motion [data-ui-reveal].is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: saturate(1) blur(0);
}

html.has-ui-motion [data-ui-reveal] > * {
  transition:
    opacity 420ms var(--ui-motion-ease),
    transform 420ms var(--ui-motion-ease);
}

html.has-ui-motion [data-ui-reveal]:not(.is-visible) > * {
  opacity: 0;
  transform: translate3d(0, 14px, 0);
}

html.has-ui-motion [data-ui-reveal].is-visible > * {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

html.has-ui-motion [data-ui-reveal].is-visible > *:nth-child(1) {
  transition-delay: 40ms;
}

html.has-ui-motion [data-ui-reveal].is-visible > *:nth-child(2) {
  transition-delay: 90ms;
}

html.has-ui-motion [data-ui-reveal].is-visible > *:nth-child(3) {
  transition-delay: 140ms;
}

html.has-ui-motion [data-ui-reveal].is-visible > *:nth-child(4) {
  transition-delay: 190ms;
}

html.has-ui-motion [data-ui-reveal].is-visible > *:nth-child(5) {
  transition-delay: 240ms;
}

html.has-ui-motion [data-ui-hover="action"],
html.has-ui-motion [data-ui-hover="card"] {
  transform: translateZ(0);
  transition:
    transform var(--ui-motion-fast) var(--ui-motion-ease),
    box-shadow 220ms var(--ui-motion-ease),
    filter 220ms var(--ui-motion-ease),
    background-color 220ms var(--ui-motion-ease),
    border-color 220ms var(--ui-motion-ease),
    color 220ms var(--ui-motion-ease);
}

html.has-ui-motion [data-ui-hover="card"] {
  transform-origin: center top;
}

html.has-ui-motion [data-ui-hover="card"] img {
  transition:
    transform 620ms var(--ui-motion-ease),
    filter 620ms var(--ui-motion-ease),
    opacity 620ms var(--ui-motion-ease);
  transform-origin: center center;
}

@media (hover: hover) and (pointer: fine) {
  html.has-ui-motion [data-ui-hover="action"]:hover {
    transform: translate3d(0, -4px, 0) scale(1.02);
    filter: saturate(1.05) brightness(1.01);
    box-shadow: var(--ui-motion-shadow-action), var(--ui-motion-ring);
  }

  html.has-ui-motion [data-ui-hover="action"]:active {
    transform: translate3d(0, -1px, 0) scale(0.988);
  }

  html.has-ui-motion [data-ui-hover="card"]:hover {
    transform: translate3d(0, -12px, 0) scale(1.016);
    filter: saturate(1.04) brightness(1.01);
    box-shadow: var(--ui-motion-shadow-card), var(--ui-motion-ring);
  }

  html.has-ui-motion [data-ui-hover="card"]:hover img {
    transform: scale(1.07);
    filter: saturate(1.08) brightness(1.02);
    opacity: 0.98;
  }
}

html.has-ui-motion [data-ui-hover="action"]:focus-visible,
html.has-ui-motion [data-ui-hover="card"]:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px rgba(255, 119, 38, 0.22),
    0 0 0 5px rgba(255, 119, 38, 0.08);
}

@media (prefers-reduced-motion: reduce) {
  html.has-ui-motion [data-ui-reveal],
  html.has-ui-motion [data-ui-reveal] > *,
  html.has-ui-motion [data-ui-hover="action"],
  html.has-ui-motion [data-ui-hover="card"],
  html.has-ui-motion [data-ui-hover="card"] img {
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
    transition: none !important;
  }
}
