/* Accellaw motion — respects prefers-reduced-motion */

:root {
  --motion-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --motion-snappy: cubic-bezier(0.4, 0, 0.2, 1);
}

.motion-reduce *,
.motion-reduce *::before,
.motion-reduce *::after {
  animation-duration: 0.001ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.001ms !important;
}

@keyframes ac-fade-up {
  from {
    opacity: 0;
    transform: translate3d(0, 28px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes ac-fade-down {
  from {
    opacity: 0;
    transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes ac-scale-in {
  from {
    opacity: 0;
    transform: scale(0.94);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes ac-blur-in {
  from {
    opacity: 0;
    filter: blur(14px);
  }
  to {
    opacity: 1;
    filter: blur(0);
  }
}

@keyframes ac-slide-in-right {
  from {
    opacity: 0;
    transform: translate3d(-24px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes ac-header-drop {
  from {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes ac-shimmer-bg {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@keyframes ac-float-soft {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -12px, 0);
  }
}

@keyframes ac-pulse-ring {
  0% {
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.12);
  }
  70% {
    box-shadow: 0 0 0 12px rgba(0, 0, 0, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  }
}

@keyframes ac-line-grow {
  from {
    transform: scaleX(0);
    opacity: 0;
  }
  to {
    transform: scaleX(1);
    opacity: 1;
  }
}

@keyframes ac-marquee-shift {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-50%, 0, 0);
  }
}

/* Ambient mesh (desktop-friendly) */
html.motion-enhanced body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.55;
  background:
    radial-gradient(ellipse 80% 55% at 20% -10%, rgba(255, 119, 89, 0.09), transparent),
    radial-gradient(ellipse 60% 45% at 95% 10%, rgba(24, 99, 220, 0.06), transparent),
    radial-gradient(ellipse 55% 50% at 10% 100%, rgba(53, 103, 93, 0.07), transparent);
  animation: ac-shimmer-bg 18s ease-in-out infinite alternate;
}

/* Header bar */
.motion-enhanced .ac-nav-header {
  animation: ac-header-drop 0.85s var(--motion-ease) forwards;
}

.motion-enhanced .ac-nav-slot {
  animation: ac-fade-down 0.72s var(--motion-ease) backwards;
}

.motion-enhanced .ac-nav-slot a[class*="bg-primary"] {
  animation: ac-scale-in 0.52s var(--motion-ease) backwards;
}

/* Scroll reveal */
.motion-enhanced .ac-reveal {
  opacity: 0;
  transform: translate3d(0, 32px, 0);
  transition:
    opacity 0.88s var(--motion-ease) var(--ac-delay, 0s),
    transform 0.88s var(--motion-ease) var(--ac-delay, 0s),
    filter 0.72s ease var(--ac-delay, 0s);
  will-change: opacity, transform;
}

.motion-enhanced .ac-reveal.ac-inview {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.motion-enhanced main .ac-stagger > * {
  opacity: 0;
  transform: translate3d(0, 24px, 0);
  transition:
    opacity 0.65s var(--motion-ease),
    transform 0.65s var(--motion-ease);
}

.motion-enhanced main .ac-stagger.ac-group-inview > * {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(1) {
  transition-delay: 0.04s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(2) {
  transition-delay: 0.1s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(3) {
  transition-delay: 0.16s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(4) {
  transition-delay: 0.22s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(5) {
  transition-delay: 0.28s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(6) {
  transition-delay: 0.34s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(7) {
  transition-delay: 0.4s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(8) {
  transition-delay: 0.46s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(9) {
  transition-delay: 0.52s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(10) {
  transition-delay: 0.58s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(11) {
  transition-delay: 0.64s;
}
.motion-enhanced main .ac-stagger.ac-group-inview > *:nth-child(12) {
  transition-delay: 0.7s;
}

.motion-enhanced main form .rounded-xl[class*="shadow"],
.motion-enhanced main form .rounded-xl[class*="border"] {
  transition:
    transform 0.4s var(--motion-snappy),
    box-shadow 0.42s ease;
}

.motion-enhanced main input:focus-visible,
.motion-enhanced main textarea:focus-visible,
.motion-enhanced main select:focus-visible {
  animation: ac-pulse-ring 1.2s ease-out 1;
}
/* Rows / cards hover */
.motion-enhanced main a[class*="rounded"],
.motion-enhanced main button[type="submit"],
.motion-enhanced main .group {
  transition:
    transform 0.35s var(--motion-snappy),
    box-shadow 0.35s var(--motion-snappy),
    border-color 0.35s var(--motion-snappy);
}

.motion-enhanced main a[class*="bg-primary"]:hover,
.motion-enhanced main button[type="submit"]:hover {
  transform: translateY(-2px) scale(1.015);
}

/* Table-style service rows */
.motion-enhanced main [class*="divide-y"] > div {
  transition:
    transform 0.4s var(--motion-ease),
    background-color 0.35s ease;
}

.motion-enhanced main [class*="divide-y"] > div:hover {
  transform: translate3d(6px, 0, 0);
}

.motion-enhanced img {
  transition: transform 6s ease, filter 0.6s ease;
}

.motion-enhanced .group:hover img[class*="object-cover"]:not(.ac-no-zoom) {
  transform: scale(1.03);
}

/* Decorative float */
.motion-enhanced .ac-float {
  animation: ac-float-soft 7s ease-in-out infinite;
}

.motion-enhanced .ac-float-delayed {
  animation: ac-float-soft 9s ease-in-out infinite 1.2s;
}

/* Primary emphasis pulse (subtle) */
.motion-enhanced .ac-attn-pulse {
  animation: ac-pulse-ring 3.5s ease-out infinite;
}

.motion-enhanced footer {
  opacity: 0;
  animation: ac-fade-up 0.75s var(--motion-ease) 0.2s forwards;
}

/* Underline flourish on bold nav/current */
.motion-enhanced .ac-nav-link-hover {
  position: relative;
}
.motion-enhanced .ac-nav-link-hover::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 2px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.35s var(--motion-ease);
}
.motion-enhanced .ac-nav-link-hover:hover::after {
  transform: scaleX(1);
}

.motion-enhanced main .material-symbols-outlined {
  transition: transform 0.45s var(--motion-ease);
}

.motion-enhanced main a:hover .material-symbols-outlined,
.motion-enhanced main button:hover .material-symbols-outlined {
  transform: translate3d(4px, 0, 0);
}

/* Ghost buttons — no fill; gold rectangle border on hover */
.ac-btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 0;
  transition:
    border-color 0.25s var(--motion-snappy),
    color 0.25s ease;
}

.ac-btn-ghost:hover {
  border-color: #C9A961 !important;
}
