.cliipsi-slider {
  position: relative;
  margin: 20px 0;
  --cliipsi-min-height: 300px;
  --cliipsi-max-height: 600px;
  --cliipsi-mobile-min-height: 250px;
  --cliipsi-mobile-max-height: 400px;
}

.cliipsi-viewport {
  position: relative;
  overflow: hidden;
  min-height: var(--cliipsi-min-height, 300px);
  max-height: var(--cliipsi-max-height, 600px);
}

.cliipsi-track {
  display: flex;
  will-change: transform;
  transition: transform var(--cliipsi-speed, 600ms) ease;
}

.cliipsi-slide {
  flex: 0 0 100%;
  position: relative;
}

.cliipsi-slide-img {
  width: 100%;
  height: 100%;
  min-height: var(--cliipsi-min-height, 300px);
  max-height: var(--cliipsi-max-height, 600px);
  object-fit: cover;
  object-position: center center;
  display: block;
}

.cliipsi-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(12px, 3vw, 40px);
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, .45) 100%);
}

.cliipsi-title {
  color: #fff;
  margin: 0 0 8px;
  max-width: 70ch;
}

.cliipsi-hover {
  color: #fff;
  opacity: 1;
  transform: translateY(0);
  transition: .25s;
  max-width: 80ch;
}

.cliipsi-slide:hover .cliipsi-hover {
  opacity: 1;
  transform: translateY(0);
}

.cliipsi-btn {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #ffffff;
  color: #111;
  font-weight: 700;
  text-decoration: none;
}

/* Navigation */
.cliipsi-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 0;
  cursor: pointer;
  background: rgba(255, 255, 255, .85);
  color: #111;
  font-size: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
  z-index: 10;
  transition: background 0.2s ease;
}

.cliipsi-nav:hover {
  background: rgba(255, 255, 255, 1);
}

.cliipsi-prev {
  left: 12px;
}

.cliipsi-next {
  right: 12px;
}

/* Dots */
.cliipsi-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 14px;
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
  pointer-events: auto;
  z-index: 10;
}

.cliipsi-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 0;
  cursor: pointer;
  background: rgba(255, 255, 255, .45);
  padding: 0;
  flex-shrink: 0;
}

.cliipsi-dot.is-active {
  background: rgba(255, 255, 255, .95);
}

/* Progressbar */
.cliipsi-progress {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 8px;
  height: 4px;
  background: rgba(255, 255, 255, .25);
  border-radius: 99px;
  overflow: hidden;
}

.cliipsi-progress span {
  display: block;
  height: 100%;
  width: 100%;
  transform-origin: left;
  transform: scaleX(0);
  background: #fff;
}

/* Fade effect */
.cliipsi-slider[data-effect="fade"] .cliipsi-track {
  display: block;
}

.cliipsi-slider[data-effect="fade"] .cliipsi-slide {
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--cliipsi-speed, 600ms) ease, visibility var(--cliipsi-speed, 600ms) ease;
}

.cliipsi-slider[data-effect="fade"] .cliipsi-slide.is-active {
  opacity: 1;
  visibility: visible;
}

/* Produit incrusté */
.cliipsi-product {
  pointer-events: auto;
  display: flex;
  gap: 12px;
  margin-top: 14px;
  background: rgba(255, 255, 255, .92);
  border-radius: 14px;
  padding: 10px;
  max-width: 520px;
}

.cliipsi-product-media img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 10px;
  display: block;
}

.cliipsi-product-name {
  color: #111;
  text-decoration: none;
  font-weight: 700;
  display: block;
}

.cliipsi-product-price {
  color: #111;
  opacity: .9;
  margin-top: 2px;
}

.cliipsi-product-buy {
  display: inline-flex;
  margin-top: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

/* Anim texte */
.anim {
  opacity: 0;
  transform: translateY(10px);
  transition: .45s ease;
}

.anim.is-in {
  opacity: 1;
  transform: translateY(0);
}

.anim.anim-zoom-in {
  transform: scale(.96);
}

.anim.anim-zoom-in.is-in {
  transform: scale(1);
}

.anim.anim-slide-left {
  transform: translateX(18px);
}

.anim.anim-slide-left.is-in {
  transform: translateX(0);
}

.anim.anim-fade-down {
  transform: translateY(-10px);
}

.anim.anim-fade-down.is-in {
  transform: translateY(0);
}

/* Effets bouton */
.btnanim.btnanim-pulse.is-in {
  animation: cliipsiPulse 1.4s ease-in-out infinite;
}

@keyframes cliipsiPulse {

  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.04);
  }
}

.btnanim.btnanim-bounce.is-in {
  animation: cliipsiBounce 1.2s ease-in-out infinite;
}

@keyframes cliipsiBounce {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-3px);
  }
}

.btnanim.btnanim-shine {
  position: relative;
  overflow: hidden;
}

.btnanim.btnanim-shine.is-in::after {
  content: "";
  position: absolute;
  top: -40%;
  left: -30%;
  width: 30%;
  height: 200%;
  background: rgba(255, 255, 255, .55);
  transform: rotate(20deg);
  animation: cliipsiShine 2.2s ease-in-out infinite;
}

@keyframes cliipsiShine {
  0% {
    left: -30%;
  }

  55% {
    left: 130%;
  }

  100% {
    left: 130%;
  }
}

@media (max-width: 768px) {
  .cliipsi-viewport {
    min-height: var(--cliipsi-mobile-min-height, 250px);
    max-height: var(--cliipsi-mobile-max-height, 400px);
  }

  .cliipsi-slide-img {
    min-height: var(--cliipsi-mobile-min-height, 250px);
    max-height: var(--cliipsi-mobile-max-height, 400px);
    aspect-ratio: 1 / 1;
    object-position: center top;
  }

  .cliipsi-overlay {
    padding: 14px;
  }

  .cliipsi-product {
    max-width: 100%;
  }

  .cliipsi-nav {
    width: 38px;
    height: 38px;
    font-size: 24px;
  }

  .cliipsi-title {
    font-size: 1.2rem;
  }

  .cliipsi-hover {
    font-size: 0.9rem;
  }
}