html.js [data-animate],
html.js .fx-reveal,
html.js .fx-media,
html.js .fx-heading {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s ease, transform .8s cubic-bezier(.22,1,.36,1);
  will-change: opacity, transform;
}
html.js .fx-heading {
  transform: translateY(28px) scale(.985);
  transition-duration: .95s;
}
html.js .fx-media {
  transform: translateY(18px) scale(.985);
  transition-duration: 1s;
}
html.js [data-animate].is-visible,
html.js .fx-reveal.is-visible,
html.js .fx-media.is-visible,
html.js .fx-heading.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}
html.js [data-animate="hero-title"] { transition-duration: 1s; }
html.js [data-animate="hero-subtle"] { transition-duration: .9s; }
html.js [data-animate="service-card"] { transition-duration: .75s; }
html.js [data-animate="body-copy"] { transition-duration: .7s; }
html.js video[data-autoplay-local="true"] {
  display:block;
}
@media (prefers-reduced-motion: reduce) {
  html.js [data-animate],
  html.js .fx-reveal,
  html.js .fx-media,
  html.js .fx-heading {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}


.native-video-frame {
  position: relative;
  width: 100%;
  height: 100%;
  /*background: #111;*/
  overflow: visible;
  isolation: isolate;
}
.native-video-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: #111;
  border-radius: 20px;
  position: relative;
  z-index: 2;
  pointer-events: auto;
}
.native-video-frame video::-webkit-media-controls-panel {
  display: flex !important;
}
.native-video-frame video::-webkit-media-controls-enclosure {
  border-radius: 0 0 20px 20px;
}

