:root {
  --motion-reveal-duration: 0.78s;
  --motion-stagger-step: 90ms;
  --motion-hover-duration: 0.22s;
  --motion-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --motion-ease-press: cubic-bezier(0.2, 0.8, 0.2, 1);
  --motion-lift-y: -3px;
  --loader-cube-size: 120px;
  --loader-explode: 18px;
  --loader-cycle: 5.8s;
  --loader-ease: cubic-bezier(0.42, 0, 0.58, 1);
  --loader-ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
}

.site-loader {
  position: fixed;
  inset: 0;
  z-index: 2400;
  display: grid;
  place-items: center;
  background:
    radial-gradient(800px 500px at 50% 40%, rgba(40, 50, 70, 0.08), rgba(0, 0, 0, 0) 70%),
    linear-gradient(160deg, #0b0d12, #06070a);
  opacity: 0;
  visibility: visible;
  pointer-events: all;
  animation: loader-overlay-in 0.6s var(--motion-ease-out) forwards;
  transition: opacity 0.6s var(--motion-ease-out), visibility 0s linear 0.6s;
}

body:not(.is-loaded) {
  overflow: hidden;
}

body.is-loaded .site-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.loader-wrap {
  position: relative;
  width: calc(var(--loader-cube-size) * 2);
  height: calc(var(--loader-cube-size) * 2);
  display: grid;
  place-items: center;
  perspective: 900px;
  perspective-origin: 50% 40%;
  opacity: 1;
  will-change: transform;
  animation: loader-wrap-float var(--loader-cycle) var(--loader-ease-soft) infinite;
}

.loader-shadow {
  position: absolute;
  width: calc(var(--loader-cube-size) * 1.2);
  height: calc(var(--loader-cube-size) * 0.24);
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.55) 0%, rgba(0, 0, 0, 0) 70%);
  filter: blur(10px);
  transform: translateY(calc(var(--loader-cube-size) * 0.7));
  will-change: transform, opacity;
  animation: loader-shadow-breathe var(--loader-cycle) var(--loader-ease-soft) infinite;
}

.loader-cube {
  position: relative;
  width: var(--loader-cube-size);
  height: var(--loader-cube-size);
  transform-origin: 50% 50%;
  will-change: transform;
  transform-style: preserve-3d;
  animation: loader-cube-cycle var(--loader-cycle) linear infinite;
}

.loader-face {
  position: absolute;
  inset: 0;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: linear-gradient(145deg, #ffffff, #f7f7f7 70%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.2),
    inset -12px -12px 24px rgba(0, 0, 0, 0.06),
    inset 12px 12px 24px rgba(255, 255, 255, 0.35);
  transform-origin: 50% 50%;
  will-change: transform, opacity;
  backface-visibility: hidden;
  animation: loader-face-assemble var(--loader-cycle) var(--loader-ease) infinite;
}

.loader-face::before {
  content: "";
  position: absolute;
  inset: 8%;
  background:
    radial-gradient(120px 60px at 20% 15%, rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0) 60%);
  opacity: 0.6;
}

.loader-face.front { filter: brightness(1.0); }
.loader-face.back { filter: brightness(0.85); }
.loader-face.right { filter: brightness(0.92); }
.loader-face.left { filter: brightness(0.9); }
.loader-face.top { filter: brightness(1.05); }
.loader-face.bottom { filter: brightness(0.82); }

.loader-face.front {
  --face-transform: translateZ(calc(var(--loader-cube-size) / 2));
  --explode-x: 0px; --explode-y: -8px; --explode-z: var(--loader-explode);
  --mis-x: -6deg; --mis-y: 4deg;
}
.loader-face.back {
  --face-transform: rotateY(180deg) translateZ(calc(var(--loader-cube-size) / 2));
  --explode-x: 0px; --explode-y: 6px; --explode-z: calc(var(--loader-explode) * -1);
  --mis-x: 5deg; --mis-y: -6deg;
}
.loader-face.right {
  --face-transform: rotateY(90deg) translateZ(calc(var(--loader-cube-size) / 2));
  --explode-x: var(--loader-explode); --explode-y: 4px; --explode-z: 0px;
  --mis-x: -4deg; --mis-y: 6deg;
}
.loader-face.left {
  --face-transform: rotateY(-90deg) translateZ(calc(var(--loader-cube-size) / 2));
  --explode-x: calc(var(--loader-explode) * -1); --explode-y: -2px; --explode-z: 0px;
  --mis-x: 6deg; --mis-y: -5deg;
}
.loader-face.top {
  --face-transform: rotateX(90deg) translateZ(calc(var(--loader-cube-size) / 2));
  --explode-x: 0px; --explode-y: calc(var(--loader-explode) * -1); --explode-z: 0px;
  --mis-x: -6deg; --mis-y: -3deg;
}
.loader-face.bottom {
  --face-transform: rotateX(-90deg) translateZ(calc(var(--loader-cube-size) / 2));
  --explode-x: 0px; --explode-y: var(--loader-explode); --explode-z: 0px;
  --mis-x: 5deg; --mis-y: 4deg;
}

@keyframes loader-overlay-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes loader-cube-cycle {
  0% {
    transform: translate3d(0, 0px, 0) rotateX(-27deg) rotateY(30deg) rotateZ(0deg) scale(1);
  }
  25% {
    transform: translate3d(0, -3px, 0) rotateX(-29deg) rotateY(120deg) rotateZ(1deg) scale(1.008);
  }
  50% {
    transform: translate3d(0, -1px, 0) rotateX(-26deg) rotateY(210deg) rotateZ(0deg) scale(1);
  }
  75% {
    transform: translate3d(0, -4px, 0) rotateX(-30deg) rotateY(300deg) rotateZ(-1deg) scale(1.008);
  }
  100% {
    transform: translate3d(0, 0px, 0) rotateX(-27deg) rotateY(390deg) rotateZ(0deg) scale(1);
  }
}

@keyframes loader-shadow-breathe {
  0%, 100% {
    transform: translateY(calc(var(--loader-cube-size) * 0.7)) scale(1);
    opacity: 0.55;
  }
  55% {
    transform: translateY(calc(var(--loader-cube-size) * 0.68)) scale(1.06);
    opacity: 0.45;
  }
}

@keyframes loader-face-assemble {
  0% {
    opacity: 0.9;
    transform:
      var(--face-transform)
      translate3d(var(--explode-x), var(--explode-y), var(--explode-z))
      rotateX(var(--mis-x)) rotateY(var(--mis-y));
  }
  18% {
    opacity: 1;
    transform:
      var(--face-transform)
      translate3d(0px, 0px, 0px)
      rotateX(0deg) rotateY(0deg);
  }
  82% {
    transform:
      var(--face-transform)
      translate3d(0px, 0px, 0px)
      rotateX(0deg) rotateY(0deg);
  }
  100% {
    opacity: 0.9;
    transform:
      var(--face-transform)
      translate3d(var(--explode-x), var(--explode-y), var(--explode-z))
      rotateX(var(--mis-x)) rotateY(var(--mis-y));
  }
}

@keyframes loader-wrap-float {
  0%, 100% {
    transform: translate3d(0, 0px, 0);
  }
  50% {
    transform: translate3d(0, -4px, 0);
  }
}

html {
  scroll-behavior: smooth;
}

body.motion-reduce {
  scroll-behavior: auto;
}

body.motion-ready .motion-reveal {
  opacity: 0;
  transform: translate3d(0, 24px, 0);
  filter: blur(8px);
  will-change: transform, opacity, filter;
  transition:
    transform var(--motion-reveal-duration) var(--motion-ease-out),
    opacity var(--motion-reveal-duration) var(--motion-ease-out),
    filter var(--motion-reveal-duration) var(--motion-ease-out);
  transition-delay: var(--motion-delay, 0ms);
}

body.motion-ready .motion-reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  filter: blur(0);
}

.btn,
.header-cta,
.integration-cta,
.contact-us-card-cta,
.integrations-filter,
.faq-question {
  transition:
    transform var(--motion-hover-duration) var(--motion-ease-out),
    box-shadow var(--motion-hover-duration) var(--motion-ease-out),
    border-color var(--motion-hover-duration) var(--motion-ease-out),
    background-color var(--motion-hover-duration) var(--motion-ease-out),
    color var(--motion-hover-duration) var(--motion-ease-out);
  transform: translateZ(0);
}

.btn:active,
.header-cta:active,
.integration-cta:active,
.contact-us-card-cta:active,
.integrations-filter:active,
.faq-question:active,
.is-pressed {
  transform: translate3d(0, 1px, 0) scale(0.985) !important;
  transition-duration: 0.14s !important;
  transition-timing-function: var(--motion-ease-press) !important;
}

.btn:focus-visible,
.header-cta:focus-visible,
.integration-cta:focus-visible,
.contact-us-card-cta:focus-visible,
.integrations-filter:focus-visible,
.faq-question:focus-visible {
  outline: 2px solid rgba(78, 178, 255, 0.75);
  outline-offset: 2px;
}

.integration-api-card,
.business-case-card,
.pricing-card,
.onboarding-card,
.contact-us-card,
.unique-slide-card {
  --card-lift: 0px;
  --tilt-rx: 0deg;
  --tilt-ry: 0deg;
  will-change: transform, box-shadow, border-color;
  transition:
    transform var(--motion-hover-duration) var(--motion-ease-out),
    box-shadow var(--motion-hover-duration) var(--motion-ease-out),
    border-color var(--motion-hover-duration) var(--motion-ease-out),
    filter var(--motion-hover-duration) var(--motion-ease-out);
  transform-style: preserve-3d;
  transform: translate3d(0, var(--card-lift), 0) rotateX(var(--tilt-rx)) rotateY(var(--tilt-ry));
}

.integration-api-card:hover,
.business-case-card:hover,
.pricing-card:hover,
.onboarding-card:hover,
.contact-us-card:hover {
  --card-lift: var(--motion-lift-y);
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow:
    0 20px 38px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset,
    0 0 24px rgba(44, 102, 225, 0.12);
}

.unique-slide-card:hover {
  --card-lift: 0px;
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow:
    0 20px 38px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset,
    0 0 24px rgba(44, 102, 225, 0.12);
}

.integration-api-card:hover .integration-api-icon svg,
.integration-item:hover .integration-item-icon svg {
  animation: icon-nudge 0.45s var(--motion-ease-out);
}

@keyframes icon-nudge {
  0% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-1px) rotate(-2deg); }
  100% { transform: translateY(0) rotate(0deg); }
}

.contact-us-card-cta {
  position: relative;
  overflow: hidden;
}

.contact-us-card-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 20%,
    rgba(255, 255, 255, 0.26) 48%,
    rgba(255, 255, 255, 0) 80%
  );
  transform: translateX(-130%);
  transition: transform 0.7s var(--motion-ease-out);
  pointer-events: none;
}

.contact-us-card-cta:hover::before,
.contact-us-card-cta:focus-visible::before {
  transform: translateX(130%);
}

.faq-item.is-open .faq-answer-text {
  animation: faq-copy-in 0.24s var(--motion-ease-out);
}

@keyframes faq-copy-in {
  from {
    opacity: 0;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

body.motion-ready .hero-bg,
body.motion-ready .hero-spline-frame {
  will-change: transform;
  transition: transform 0.25s linear;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .site-loader,
  .loader-cube,
  .loader-face,
  .loader-shadow,
  .loader-wrap {
    animation: none !important;
  }

  .loader-wrap {
    opacity: 1;
  }

  body.motion-ready .motion-reveal {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }

  .integration-api-card,
  .business-case-card,
  .pricing-card,
  .onboarding-card,
  .contact-us-card,
  .unique-slide-card,
  .btn,
  .header-cta,
  .integration-cta,
  .contact-us-card-cta,
  .integrations-filter,
  .faq-question {
    transition: none !important;
    animation: none !important;
    transform: none !important;
  }

  .contact-us-card-cta::before {
    display: none;
  }
}
