.ws-carousel-pro {
  position: relative;
  inline-size: 100%;
  overflow: visible;

  --ws-carousel-gap: 16px;
  --ws-carousel-desktop: 4;
  --ws-carousel-tablet: 2;
  --ws-carousel-mobile: 1;

  --ws-carousel-radius: inherit;
  --ws-carousel-border: color-mix(in srgb, currentColor 14%, transparent);
  --ws-carousel-surface: color-mix(in srgb, currentColor 4%, transparent);

  color: inherit;
}

.ws-carousel-pro__viewport {
  overflow: hidden;
  inline-size: 100%;
}

.ws-carousel-pro__track {
  display: flex;
  gap: var(--ws-carousel-gap);
  will-change: transform;
  touch-action: pan-y;
  user-select: none;
  backface-visibility: hidden;
  transform: translateZ(0);
}

.ws-carousel-pro__slide {
  position: relative;
  flex-shrink: 0;
  min-inline-size: 0;
  overflow: visible;
  isolation: isolate;
}

.ws-carousel-pro__slide {
  overflow: visible;
}

.ws-carousel-pro__card {
  position: relative; 
  min-block-size: inherit;
  block-size: 100%;
  overflow: hidden;
  border: 1px solid var(--ws-carousel-border);
  border-radius: var(--ws-carousel-radius, 16px);
  background: var(--ws-carousel-surface);
  color: inherit;
  transition:
    transform var(--ws-carousel-transition-duration, 260ms)
    var(--ws-carousel-transition-easing, ease),
    box-shadow 260ms ease,
    border-color 260ms ease;
 
}



.ws-carousel-pro--netflix .ws-carousel-pro__card:hover {
  transform: translateY(-4px) scale(1.025);
  z-index: 5;
  box-shadow: 0 1rem 2rem color-mix(in srgb, currentColor 18%, transparent);
}

.ws-carousel-pro__arrow {
  position: absolute;
  inset-block-start: 50%;
  z-index: 10;
  transform: translateY(-50%);
  inline-size: 2.75rem;
  block-size: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, currentColor 16%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, Canvas 86%, transparent);
  color: CanvasText;
  cursor: pointer;
  font-size: 1.8rem;
  line-height: 1;
  box-shadow: 0 0.5rem 1.5rem color-mix(in srgb, currentColor 12%, transparent);
}

.ws-carousel-pro__arrow:hover,
.ws-carousel-pro__arrow:focus {
  background: CanvasText;
  color: Canvas;
}

.ws-carousel-pro__arrow--prev {
  inset-inline-start: 0.75rem;
}

.ws-carousel-pro__arrow--next {
  inset-inline-end: 0.75rem;
}

.ws-carousel-pro__arrow:disabled {
  opacity: 0.35;
  pointer-events: none;
}

.ws-carousel-pro__dots {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-block-start: 1rem;
}

.ws-carousel-pro__dot {
  inline-size: 0.55rem;
  block-size: 0.55rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, currentColor 28%, transparent);
  cursor: pointer;
  transition:
    inline-size 180ms ease,
    background-color 180ms ease;
}

.ws-carousel-pro__dot.is-active {
  inline-size: 1.35rem;
  background: currentColor;
}

.ws-carousel-pro.is-dragging,
.ws-carousel-pro.is-dragging * {
  cursor: grabbing;
}


.ws-carousel-pro--hero .ws-carousel-pro__slide {
  inline-size: 100% !important;
}

.ws-carousel-pro--hero .ws-carousel-pro__card {
  min-block-size: min(90vh, 980px);
  border-radius: clamp(1rem, 2vw, 2rem);
}

.ws-carousel-pro--hero .ws-carousel-pro__track {
  align-items: stretch;
}


.ws-carousel-pro[data-center-mode="true"]
.ws-carousel-pro__slide {

  transition:
    transform 500ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 400ms ease,
    filter 400ms ease;
}

.ws-carousel-pro[data-center-mode="true"]
.ws-carousel-pro__slide:not(.is-center) {

  transform: scale(.92);
  opacity: .7;
  filter: saturate(.7) brightness(.8);
}

.ws-carousel-pro[data-center-mode="true"]
.ws-carousel-pro__slide.is-center {

  transform: scale(1);
  opacity: 1;
  z-index: 8;
}


.ws-carousel-pro__slide.is-active
.ws-carousel-slide__background {

  transform: scale(1.04);
}

.ws-carousel-pro__slide.is-prev
.ws-carousel-slide__background {

  transform: translateX(-2%) scale(1.01);
}

.ws-carousel-pro__slide.is-next
.ws-carousel-slide__background {

  transform: translateX(2%) scale(1.01);
}

.ws-carousel-pro__slide [class*="ws-image-"] {
  max-inline-size: none;
}

/* height presets */
.ws-carousel-pro--height-small .ws-carousel-pro__card {
  min-block-size: 220px;
}

.ws-carousel-pro--height-medium .ws-carousel-pro__card {
  min-block-size: 360px;
}

.ws-carousel-pro--height-large .ws-carousel-pro__card {
  min-block-size: 520px;
}

.ws-carousel-pro--height-full .ws-carousel-pro__card {
  min-block-size: 80vh;
}

/* aspect ratio context */
.ws-carousel-pro--ratio-16-9 {
  --ws-carousel-slide-ratio: 16 / 9;
}

.ws-carousel-pro--ratio-21-9 {
  --ws-carousel-slide-ratio: 21 / 9;
}

.ws-carousel-pro--ratio-4-3 {
  --ws-carousel-slide-ratio: 4 / 3;
}

.ws-carousel-pro--ratio-1-1 {
  --ws-carousel-slide-ratio: 1 / 1;
}

.ws-carousel-pro--ratio-auto {
  --ws-carousel-slide-ratio: auto;
}

@media (max-width: 782px) {
  .ws-carousel-pro__arrow {
    inline-size: 2.25rem;
    block-size: 2.25rem;
    font-size: 1.45rem;
  }
}

.ws-carousel-pro__arrow:focus-visible,
.ws-carousel-pro__dot:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .ws-carousel-pro__track,
  .ws-carousel-pro__card,
  .ws-carousel-pro__arrow,
  .ws-carousel-pro__dot {
    transition: none !important;
  }
}

.ws-carousel-pro__slide.is-active {
  z-index: 4;
}

.ws-carousel-pro__slide.is-visible {
  opacity: 1;
}

.ws-carousel-pro__slide:not(.is-visible) {
  opacity: 0.72;
}

.ws-carousel-pro__slide.is-prev,
.ws-carousel-pro__slide.is-next {
  opacity: 0.88;
}

.ws-carousel-pro__slide.is-center {
  z-index: 5;
}
.ws-carousel-pro__viewport {
  padding-inline:
    var(--ws-carousel-peek, 0px);
}
.ws-carousel-pro__progress {
  position: relative;
  inline-size: 100%;
  block-size: 3px;
  background:
    color-mix(in srgb, currentColor 12%, transparent);
  overflow: hidden;
}

.ws-carousel-pro__progress-bar {
  inline-size: 0%;
  block-size: 100%;
  background: currentColor;
  transition:
    inline-size
    var(--ws-carousel-transition-duration, 260ms)
    linear;
}

.ws-carousel-pro__slide,
.ws-carousel-pro__card,
.ws-carousel-slide__background {

  transform: translateZ(0);
  backface-visibility: hidden;
}

.ws-carousel-slide__background video,
.ws-carousel-slide__background iframe {

  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.ws-carousel-slide__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}


.ws-carousel-pro--hero
.ws-carousel-slide__overlay {

  background:
    linear-gradient(
      to top,
      rgb(0 0 0 / .72),
      rgb(0 0 0 / .18),
      transparent
    );
}

