/* effects.css — ефекти, винесені з inline-<style> Webflow-експорту.
 * 1) .clipped — градієнтний текст (у Webflow CSS цього правила не було, лише в inline)
 * 2) .shiny-cta / .shiny-cta-form / .shiny-cta-mob — анімована «сяюча» кнопка
 *    (в експорті цей блок дублювався 3 рази — тут один раз). */

/* ── Gradient-clipped text ───────────────────────────────────────────────── */
.clipped {
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
}

/* ── Shiny CTA ───────────────────────────────────────────────────────────── */
:root {
  --shiny-cta-bg: #000000;
  --shiny-cta-bg-subtle: #1a1818;
  --shiny-cta-fg: #ffffff;
  --shiny-cta-highlight: white;
  --shiny-cta-highlight-subtle: #8484ff;
}
@property --gradient-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
@property --gradient-angle-offset {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
@property --gradient-percent {
  syntax: "<percentage>";
  initial-value: 5%;
  inherits: false;
}
@property --gradient-shine {
  syntax: "<color>";
  initial-value: white;
  inherits: false;
}

.shiny-cta,
.shiny-cta-form,
.shiny-cta-mob {
  --animation: gradient-angle linear infinite;
  --duration: 3s;
  --shadow-size: 2px;
  isolation: isolate;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  outline-offset: 4px;
  padding: 1.25rem 2.5rem;
  font-family: inherit;
  font-size: 1.125rem;
  line-height: 1.2;
  border: 1px solid transparent;
  border-radius: 16px;
  color: var(--shiny-cta-fg);
  background: linear-gradient(var(--shiny-cta-bg), var(--shiny-cta-bg)) padding-box,
    conic-gradient(
        from calc(var(--gradient-angle) - var(--gradient-angle-offset)),
        transparent,
        var(--shiny-cta-highlight) var(--gradient-percent),
        var(--gradient-shine) calc(var(--gradient-percent) * 2),
        var(--shiny-cta-highlight) calc(var(--gradient-percent) * 3),
        transparent calc(var(--gradient-percent) * 4)
      )
      border-box;
  box-shadow: inset 0 0 0 1px var(--shiny-cta-bg-subtle);
}
/* .shiny-cta — пігулка (округла), форма/моб — 16px (за замовчуванням) */
.shiny-cta {
  border-radius: 360px;
}

.shiny-cta::before,
.shiny-cta::after,
.shiny-cta span::before,
.shiny-cta-form::before,
.shiny-cta-form::after,
.shiny-cta-form span::before,
.shiny-cta-mob::before,
.shiny-cta-mob::after,
.shiny-cta-mob span::before {
  content: "";
  pointer-events: none;
  position: absolute;
  inset-inline-start: 50%;
  inset-block-start: 50%;
  translate: -50% -50%;
  z-index: -1;
}
.shiny-cta:active,
.shiny-cta-form:active,
.shiny-cta-mob:active {
  translate: 0 1px;
}

/* Inner shimmer */
.shiny-cta::after,
.shiny-cta-form::after,
.shiny-cta-mob::after {
  --animation: shimmer linear infinite;
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(-50deg, transparent, var(--shiny-cta-highlight), transparent);
  mask-image: radial-gradient(circle at bottom, transparent 40%, black);
  opacity: 0.6;
}
.shiny-cta span,
.shiny-cta-form span,
.shiny-cta-mob span {
  z-index: 1;
}
.shiny-cta span::before,
.shiny-cta-form span::before,
.shiny-cta-mob span::before {
  --size: calc(100% + 1rem);
  width: var(--size);
  height: var(--size);
  box-shadow: inset 0 -1ex 2rem 4px var(--shiny-cta-highlight);
  opacity: 0;
}

/* Animate */
.shiny-cta,
.shiny-cta-form,
.shiny-cta-mob {
  --transition: 800ms cubic-bezier(0.25, 1, 0.5, 1);
  transition: var(--transition);
  transition-property: --gradient-angle-offset, --gradient-percent, --gradient-shine;
}
.shiny-cta,
.shiny-cta::before,
.shiny-cta::after,
.shiny-cta-form,
.shiny-cta-form::before,
.shiny-cta-form::after,
.shiny-cta-mob,
.shiny-cta-mob::before,
.shiny-cta-mob::after {
  animation: var(--animation) var(--duration),
    var(--animation) calc(var(--duration) / 0.4) reverse paused;
  animation-composition: add;
}
.shiny-cta span::before,
.shiny-cta-form span::before,
.shiny-cta-mob span::before {
  transition: opacity var(--transition);
  animation: calc(var(--duration) * 1.5) breathe linear infinite;
}

.shiny-cta:is(:hover, :focus-visible),
.shiny-cta-form:is(:hover, :focus-visible),
.shiny-cta-mob:is(:hover, :focus-visible) {
  --gradient-percent: 20%;
  --gradient-angle-offset: 95deg;
  --gradient-shine: var(--shiny-cta-highlight-subtle);
}
.shiny-cta:is(:hover, :focus-visible),
.shiny-cta:is(:hover, :focus-visible)::before,
.shiny-cta:is(:hover, :focus-visible)::after,
.shiny-cta-form:is(:hover, :focus-visible),
.shiny-cta-form:is(:hover, :focus-visible)::before,
.shiny-cta-form:is(:hover, :focus-visible)::after,
.shiny-cta-mob:is(:hover, :focus-visible),
.shiny-cta-mob:is(:hover, :focus-visible)::before,
.shiny-cta-mob:is(:hover, :focus-visible)::after {
  animation-play-state: running;
}
.shiny-cta:is(:hover, :focus-visible) span::before,
.shiny-cta-form:is(:hover, :focus-visible) span::before,
.shiny-cta-mob:is(:hover, :focus-visible) span::before {
  opacity: 1;
}

@keyframes gradient-angle {
  to {
    --gradient-angle: 360deg;
  }
}
@keyframes shimmer {
  to {
    rotate: 360deg;
  }
}
@keyframes breathe {
  from,
  to {
    scale: 1;
  }
  50% {
    scale: 1.2;
  }
}

/* ── Reveal-анімації (заміна Webflow IX2 «fade-in on scroll») ─────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1),
    transform 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  will-change: opacity, transform;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
