/**
 * Site-wide commercial motion — visible polish, still business-appropriate.
 */

@keyframes es-fx-pop-in {
  0% {
    opacity: 0;
    transform: translate3d(0, 32px, 0) scale(0.9);
  }
  65% {
    transform: translate3d(0, -4px, 0) scale(1.03);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes es-fx-shine-once {
  0% {
    transform: translateX(-130%);
  }
  100% {
    transform: translateX(130%);
  }
}

@keyframes es-fx-ambient-drift {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
    opacity: 0.45;
  }
  50% {
    transform: translate(12px, -18px) scale(1.08);
    opacity: 0.7;
  }
}

@keyframes es-fx-cta-glow {
  0%,
  100% {
    box-shadow: 0 10px 28px rgba(11, 92, 168, 0.28);
  }
  50% {
    box-shadow: 0 14px 36px rgba(11, 92, 168, 0.42);
  }
}

@keyframes es-fx-stat-pulse {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.04);
  }
}

@keyframes es-fx-border-spin {
  to {
    --es-border-angle: 360deg;
  }
}

@media (prefers-reduced-motion: no-preference) {
  /*
   * Visible state must beat variant hide rules (higher specificity).
   * Without this, .es-motion--slide-left.es-motion-hide keeps opacity:0 forever.
   */
  .es-motion-hide.es-motion-visible,
  [class*="es-motion--"].es-motion-hide.es-motion-visible,
  .es-title-fx.es-motion-hide.es-motion-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: none;
  }

  /* —— Reveal variants (hidden only, before .es-motion-visible) —— */
  .es-motion--scale.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(0, 40px, 0) scale(0.94);
  }

  .es-motion--fade.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(0, 32px, 0);
  }

  .es-motion--rise.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(0, 56px, 0);
  }

  /* Opacity only from main.css .es-motion-hide — variants use transform/filter only */
  .es-motion--slide.es-motion-hide:not(.es-motion-visible),
  .es-motion--slide-left.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(-56px, 32px, 0);
  }

  .es-motion--slide-right.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(56px, 32px, 0);
  }

  .es-motion--blur.es-motion-hide:not(.es-motion-visible) {
    filter: blur(12px);
    transform: translate3d(0, 28px, 0);
  }

  .es-motion--pop.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(0, 36px, 0) scale(0.9);
    transition: none;
  }

  .es-motion--pop.es-motion-visible {
    animation: es-fx-pop-in 0.78s cubic-bezier(0.22, 1, 0.36, 1)
      calc(var(--es-motion-stagger, 0s) + 0.05s) both;
  }

  /* —— Titles —— */
  .es-title-fx {
    position: relative;
    display: inline-block;
  }

  .es-title-fx.es-motion-hide:not(.es-motion-visible) {
    transform: translate3d(0, 28px, 0);
  }

  .es-title-fx::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -10px;
    width: 64px;
    height: 4px;
    border-radius: 4px;
    background: linear-gradient(
      90deg,
      var(--color-primary),
      rgba(11, 92, 168, 0.15)
    );
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.72s cubic-bezier(0.22, 1, 0.36, 1)
      calc(var(--es-motion-stagger, 0s) + 0.22s);
  }

  .es-motion-visible .es-title-fx::after,
  .es-section-head.es-motion-visible .es-title-fx::after,
  h1.es-title-fx.es-motion-visible::after,
  h2.es-title-fx.es-motion-visible::after {
    transform: scaleX(1);
  }

  .es-section-head--center .es-title-fx::after {
    left: 50%;
    margin-left: -32px;
    transform: scaleX(0);
    transform-origin: center;
  }

  .es-section-head--center .es-title-fx.es-motion-visible::after {
    transform: scaleX(1);
  }

  .es-page-hero h1.es-title-fx::after {
    width: 80px;
    height: 4px;
    bottom: -12px;
  }

  /* —— Kicker —— */
  .es-section:not(.es-section--primary) .es-kicker.es-kicker-fx {
    position: relative;
    padding-bottom: 12px;
    letter-spacing: 0.06em;
  }

  .es-section:not(.es-section--primary) .es-kicker.es-kicker-fx::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: min(64px, 32vw);
    height: 3px;
    border-radius: 3px;
    background: linear-gradient(
      90deg,
      var(--color-primary),
      rgba(11, 92, 168, 0.2)
    );
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.68s cubic-bezier(0.22, 1, 0.36, 1)
      calc(var(--es-motion-stagger, 0s) + 0.1s);
  }

  .es-motion-visible .es-kicker.es-kicker-fx::after,
  .es-kicker.es-kicker-fx.es-motion-visible::after {
    transform: scaleX(1);
  }

  /* —— Lead copy —— */
  .es-lead-fx.es-motion-hide {
    transform: translate3d(0, 24px, 0);
    letter-spacing: 0.02em;
  }

  .es-lead-fx.es-motion-visible {
    letter-spacing: normal;
    transition:
      opacity 0.88s cubic-bezier(0.22, 1, 0.36, 1),
      transform 0.88s cubic-bezier(0.22, 1, 0.36, 1),
      letter-spacing 1s ease;
  }

  /* —— Images —— */
  .es-img-fx {
    position: relative;
    overflow: hidden;
  }

  .es-img-fx::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(
      105deg,
      transparent 38%,
      rgba(255, 255, 255, 0.28) 50%,
      transparent 62%
    );
    transform: translateX(-130%);
    transition: transform 0.65s ease;
  }

  .es-img-fx:hover::before,
  .es-img-fx:focus-within::before {
    transform: translateX(130%);
  }

  .es-img-fx.es-img-fx--revealed::before {
    animation: es-fx-shine-once 0.95s ease calc(var(--es-motion-stagger, 0s) + 0.25s)
      both;
  }

  .es-img-fx.es-parallax-on {
    transform: translate3d(0, var(--es-parallax-y, 0), 0);
    transition: transform 0.12s linear;
    will-change: transform;
  }

  .es-img-fx img {
    display: block;
    width: 100%;
    transition: transform 0.88s cubic-bezier(0.22, 1, 0.36, 1)
      calc(var(--es-motion-stagger, 0s) + 0.08s);
  }

  .es-motion-hide.es-img-fx img,
  .es-motion-hide .es-img-fx img {
    transform: scale(1.08);
  }

  .es-motion-visible.es-img-fx img,
  .es-motion-visible .es-img-fx img {
    transform: scale(1);
  }

  .es-img-fx:hover img,
  .es-card--link:hover .es-img-fx img,
  .es-feature-card:hover .es-img-fx img,
  .es-post-card:hover .es-img-fx img,
  .es-project-card:hover .es-img-fx img {
    transform: scale(1.08);
  }

  /* —— Cards —— */
  .es-card--link,
  .es-feature-card,
  .es-post-card,
  .es-project-card,
  .es-stat,
  .es-hscroll--products .es-product-card {
    position: relative;
  }

  .es-card--link,
  .es-feature-card,
  .es-post-card,
  .es-project-card {
    overflow: hidden;
  }

  .es-card--link > *,
  .es-feature-card > * {
    position: relative;
    z-index: 1;
  }

  .es-card--link::before,
  .es-feature-card::before,
  .es-post-card::before,
  .es-project-card::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(
      135deg,
      rgba(11, 92, 168, 0.18),
      transparent 40%,
      rgba(13, 42, 67, 0.08)
    );
    transition: opacity 0.35s ease;
  }

  .es-card--link:hover::before,
  .es-feature-card:hover::before,
  .es-post-card:hover::before,
  .es-project-card:hover::before {
    opacity: 1;
  }

  .es-card--link:hover,
  .es-feature-card:hover,
  .es-post-card:hover,
  .es-project-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 22px 50px rgba(13, 42, 67, 0.14);
  }

  .es-card--link.es-motion-visible,
  .es-feature-card.es-motion-visible,
  .es-post-card.es-motion-visible,
  .es-project-card.es-motion-visible {
    transition:
      transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
      box-shadow 0.35s ease,
      border-color 0.35s ease,
      opacity 0.82s ease;
  }

  /* Animated gradient border on featured cards */
  .es-card--link.es-motion-visible::after,
  .es-feature-card.es-motion-visible::after {
    content: "";
    position: absolute;
    inset: -2px;
    border-radius: inherit;
    padding: 2px;
    background: conic-gradient(
      from var(--es-border-angle, 0deg),
      rgba(11, 92, 168, 0.55),
      rgba(13, 42, 67, 0.12),
      rgba(11, 92, 168, 0.35),
      rgba(13, 42, 67, 0.08)
    );
    -webkit-mask:
      linear-gradient(#fff 0 0) content-box,
      linear-gradient(#fff 0 0);
    mask:
      linear-gradient(#fff 0 0) content-box,
      linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.35s ease;
    z-index: 0;
  }

  .es-card--link:hover::after,
  .es-feature-card:hover::after {
    opacity: 1;
    animation: es-fx-border-spin 3.6s linear infinite;
  }

  @property --es-border-angle {
    syntax: "<angle>";
    initial-value: 0deg;
    inherits: false;
  }

  /* Stats */
  .es-stat.es-motion--pop.es-motion-visible strong {
    display: inline-block;
    animation: es-fx-stat-pulse 0.55s ease calc(var(--es-motion-stagger, 0s) + 0.35s)
      both;
  }

  /* —— Buttons —— */
  .es-btn--primary {
    position: relative;
    overflow: hidden;
    isolation: isolate;
  }

  .es-btn--primary.es-btn-fx.es-motion-visible {
    animation: es-fx-cta-glow 3.2s ease-in-out infinite;
  }

  .es-btn--primary::after {
    content: "";
    position: absolute;
    top: 0;
    left: -120%;
    width: 55%;
    height: 100%;
    background: linear-gradient(
      90deg,
      transparent,
      rgba(255, 255, 255, 0.28),
      transparent
    );
    transform: skewX(-16deg);
    transition: left 0.5s ease;
    pointer-events: none;
  }

  .es-btn--primary:hover::after,
  .es-btn--primary:focus-visible::after {
    left: 130%;
  }

  .es-btn-fx:not(.es-btn--primary) {
    transition:
      transform 0.28s cubic-bezier(0.22, 1, 0.36, 1),
      box-shadow 0.28s ease,
      border-color 0.28s ease,
      background-color 0.28s ease;
  }

  .es-btn-fx:not(.es-btn--primary):hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(13, 42, 67, 0.12);
  }

  /* —— Section ambient —— */
  .es-section.es-section-ambient {
    position: relative;
    overflow: hidden;
  }

  .es-section.es-section-ambient::before {
    content: "";
    position: absolute;
    width: min(420px, 70vw);
    height: min(420px, 70vw);
    top: -120px;
    right: -80px;
    border-radius: 50%;
    background: radial-gradient(
      circle,
      rgba(11, 92, 168, 0.09) 0%,
      transparent 68%
    );
    pointer-events: none;
    animation: es-fx-ambient-drift 14s ease-in-out infinite;
  }

  .es-section.es-section-ambient::after {
    content: "";
    position: absolute;
    width: min(360px, 60vw);
    height: min(360px, 60vw);
    bottom: -100px;
    left: -60px;
    border-radius: 50%;
    background: radial-gradient(
      circle,
      rgba(13, 42, 67, 0.06) 0%,
      transparent 70%
    );
    pointer-events: none;
    animation: es-fx-ambient-drift 18s ease-in-out infinite reverse;
  }

  .es-section.es-section-ambient > .es-container {
    position: relative;
    z-index: 1;
  }

  /* —— FAQ / filters —— */
  .es-filter__item.es-motion-visible {
    transition:
      transform 0.32s ease,
      border-color 0.2s ease,
      background-color 0.2s ease;
  }

  .es-filter__item.es-motion-visible:hover {
    transform: translateY(-2px) scale(1.02);
  }

  details.es-motion-visible {
    transition:
      box-shadow 0.3s ease,
      border-color 0.3s ease,
      opacity 0.82s ease,
      transform 0.82s ease;
  }

  details.es-motion-visible[open] {
    box-shadow: 0 12px 32px rgba(13, 42, 67, 0.08);
  }

  /* —— WooCommerce —— */
  .woocommerce ul.products li.product > a:first-child,
  .woocommerce ul.products li.product .woocommerce-loop-product__link {
    display: block;
    overflow: hidden;
    border-radius: 8px;
  }

  .woocommerce ul.products li.product img {
    transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .woocommerce ul.products li.product:hover img {
    transform: scale(1.06);
  }

  .woocommerce ul.products li.product.es-motion-visible:hover {
    transform: translateY(-6px);
  }

  .es-section-image.es-img-fx img {
    border-radius: 14px;
  }

  /* H-scroll cards */
  .es-hscroll > .es-motion-visible {
    transition:
      transform 0.35s ease,
      box-shadow 0.35s ease,
      opacity 0.82s ease;
  }

  .es-hscroll > .es-motion-visible:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(13, 42, 67, 0.12);
  }
}

@media (prefers-reduced-motion: reduce) {
  .es-title-fx::after,
  .es-kicker.es-kicker-fx::after,
  .es-img-fx::before,
  .es-btn--primary::after,
  .es-section.es-section-ambient::before,
  .es-section.es-section-ambient::after {
    display: none;
  }

  .es-card--link::before,
  .es-card--link::after,
  .es-feature-card::before,
  .es-feature-card::after,
  .es-post-card::before,
  .es-project-card::before {
    display: none;
  }

  .es-img-fx img,
  .es-img-fx.es-parallax-on {
    transform: none !important;
  }

  .es-motion--pop.es-motion-visible {
    animation: none;
  }
}
