@layer component {
  theme-carousel {
    position: relative;
    display: block;
    will-change: opacity;
    backface-visibility: hidden;
    transform: translateZ(0);
  }

  theme-carousel.jumping {
    transition: opacity 0.5s cubic-bezier(.19, 1, .22, 1);
    pointer-events: none;
  }

  @media (prefers-reduced-motion: reduce) {
    theme-carousel.jumping {
      transition: none;
    }
  }

  theme-carousel .carousel__track {
    position: relative;
    display: flex;
    flex-wrap: inherit;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none;
  }

  theme-carousel .carousel__track::-webkit-scrollbar {
    display: none;
  }

  theme-carousel .carousel__track>* {
    flex-shrink: 0;
    list-style: none;
    scroll-snap-align: start;
  }

  theme-carousel .carousel__track-scroll-behavior--auto {
    scroll-behavior: auto;
  }

  theme-carousel .carousel__track-scroll-snap-type--none {
    scroll-snap-type: none;
  }

  theme-carousel[data-scroll-snap-align="center"] .carousel__track>* {
    scroll-snap-align: center;
  }

  theme-carousel[data-scroll-snap-align="end"] .carousel__track>* {
    scroll-snap-align: end;
  }

  theme-carousel[data-direction="vertical"] .carousel__track {
    flex-direction: column;
    overflow-x: unset;
    overflow-y: auto;
    scroll-snap-type: y mandatory;
  }

  @media (min-width: 960px) {
    theme-carousel[data-desktop-direction="vertical"] .carousel__track {
      flex-direction: column;
      overflow-x: unset;
      overflow-y: auto;
      scroll-snap-type: y mandatory;
    }
  }

  @media (max-width: 959px) {
    theme-carousel[data-mobile-direction="vertical"] .carousel__track {
      flex-direction: column;
      overflow-x: unset;
      overflow-y: auto;
      scroll-snap-type: y mandatory;
    }
  }

  theme-carousel[data-direction="fade"] .carousel__track {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
    overflow: hidden;
    scroll-snap-type: none;
    align-items: stretch;
  }

  theme-carousel[data-direction="fade"] .carousel__track>* {
    grid-area: 1 / 1;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    height: 100%;
    min-height: 0;
    max-height: 100%;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
  }

  theme-carousel[data-direction="fade"] .carousel__track>.active {
    opacity: 1;
    pointer-events: auto;
  }

  @media (min-width: 960px) {
    theme-carousel[data-desktop-direction="fade"] .carousel__track {
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      grid-template-rows: minmax(0, 1fr);
      overflow: hidden;
      scroll-snap-type: none;
      align-items: stretch;
    }

    theme-carousel[data-desktop-direction="fade"] .carousel__track>* {
      grid-area: 1 / 1;
      width: 100%;
      min-width: 0;
      max-width: 100%;
      height: 100%;
      min-height: 0;
      max-height: 100%;
      overflow: hidden;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.5s ease;
    }

    theme-carousel[data-desktop-direction="fade"] .carousel__track>.active {
      opacity: 1;
      pointer-events: auto;
    }
  }

  @media (max-width: 959px) {
    theme-carousel[data-mobile-direction="fade"] .carousel__track {
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      grid-template-rows: minmax(0, 1fr);
      overflow: hidden;
      scroll-snap-type: none;
      align-items: stretch;
    }

    theme-carousel[data-mobile-direction="fade"] .carousel__track>* {
      grid-area: 1 / 1;
      width: 100%;
      min-width: 0;
      max-width: 100%;
      height: 100%;
      min-height: 0;
      max-height: 100%;
      overflow: hidden;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.5s ease;
    }

    theme-carousel[data-mobile-direction="fade"] .carousel__track>.active {
      opacity: 1;
      pointer-events: auto;
    }
  }
}