
.form-result-idle {
  color: #525252;
}

.dark .form-result-idle {
  color: #a3a3a3;
}

.form-result-success {
  color: #15803d;
}

.dark .form-result-success {
  color: #4ade80;
}

.form-result-error {
  color: #b91c1c;
}

.dark .form-result-error {
  color: #f87171;
}

.reveal {
  opacity: 0;
  transform: translateY(56px) scale(0.97);
  filter: blur(8px);
  transition:
    opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.8s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.8s ease;
}

.reveal-left {
  opacity: 0;
  transform: translateX(-72px) rotate(-1.2deg);
  filter: blur(8px);
  transition: all 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal-right {
  opacity: 0;
  transform: translateX(72px) rotate(1.2deg);
  filter: blur(8px);
  transition: all 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal.visible,
.reveal-left.visible,
.reveal-right.visible {
  opacity: 1;
  transform: none;
  filter: blur(0);
}

.stagger > * {
  opacity: 0;
  transform: translateY(36px);
  transition: all 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.stagger.visible > *:nth-child(1) {
  opacity: 1;
  transform: none;
  transition-delay: 0.08s;
}

.stagger.visible > *:nth-child(2) {
  opacity: 1;
  transform: none;
  transition-delay: 0.18s;
}

.stagger.visible > *:nth-child(3) {
  opacity: 1;
  transform: none;
  transition-delay: 0.28s;
}

.stagger.visible > *:nth-child(4) {
  opacity: 1;
  transform: none;
  transition-delay: 0.38s;
}

.image-reveal {
  opacity: 0;
  overflow: hidden;
  transform: translateY(40px) scale(0.98);
  filter: blur(8px);
  transition:
    opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.85s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.85s ease;
}

.image-reveal img {
  transform: scale(1.12);
  transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.image-reveal.visible {
  opacity: 1;
  transform: none;
  filter: blur(0);
}

.image-reveal.visible img {
  transform: scale(1);
}

.case-carousel {
  --case-carousel-nav-top: 50%;
  cursor: grab;
  overflow: hidden;
  overscroll-behavior-x: contain;
  position: relative;
  touch-action: pan-y;
}

.case-carousel:active {
  cursor: grabbing;
}

.case-carousel .swiper-wrapper {
  align-items: stretch;
}

.case-carousel .swiper-slide {
  height: auto;
  user-select: none;
}

.case-carousel-nav {
  top: var(--case-carousel-nav-top);
}

.case-carousel-control:focus-visible,
.case-carousel-pagination .swiper-pagination-bullet:focus-visible {
  outline: 3px solid #2563eb;
  outline-offset: 3px;
}

.case-carousel-control.swiper-button-disabled {
  cursor: not-allowed;
  opacity: 0.35;
}

.case-carousel-pagination .swiper-pagination-bullet {
  position: relative;
  margin: 0 !important;
  height: 2.75rem;
  width: 2.75rem;
  flex-shrink: 0;
  border-radius: 9999px;
  background: transparent;
  opacity: 1;
}

.case-carousel-pagination .swiper-pagination-bullet::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  height: 0.625rem;
  width: 0.625rem;
  border-radius: 9999px;
  background: #a3a3a3;
  transform: translate(-50%, -50%);
  transition:
    background-color 0.2s ease,
    transform 0.2s ease;
}

.case-carousel-pagination .swiper-pagination-bullet-active {
  background: transparent;
}

.case-carousel-pagination .swiper-pagination-bullet-active::before {
  background: #171717;
  transform: translate(-50%, -50%) scale(1.25);
}

.dark .case-carousel-pagination .swiper-pagination-bullet::before {
  background: rgb(255 255 255 / 0.35);
}

.dark .case-carousel-pagination .swiper-pagination-bullet-active::before {
  background: #ffffff;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }

  .reveal,
  .reveal-left,
  .reveal-right,
  .image-reveal,
  .stagger > * {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}
