/* Scroll Reveal Animations base classes */

.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s cubic-bezier(0.25, 1, 0.5, 1), transform 1s cubic-bezier(0.25, 1, 0.5, 1);
  will-change: opacity, transform;
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 1s cubic-bezier(0.25, 1, 0.5, 1), transform 1s cubic-bezier(0.25, 1, 0.5, 1);
}

.reveal-left.active {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 1s cubic-bezier(0.25, 1, 0.5, 1), transform 1s cubic-bezier(0.25, 1, 0.5, 1);
}

.reveal-right.active {
  opacity: 1;
  transform: translateX(0);
}

/* Staggered delays */
.delay-100 { transition-delay: 100ms; }
.delay-200 { transition-delay: 200ms; }
.delay-300 { transition-delay: 300ms; }
.delay-400 { transition-delay: 400ms; }
.delay-500 { transition-delay: 500ms; }

/* Parallax Image Masking */
.img-mask {
  position: relative;
  overflow: hidden;
}

.img-mask::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-primary);
  transform-origin: bottom;
  transform: scaleY(1);
  transition: transform 1.2s cubic-bezier(0.77, 0, 0.175, 1);
}

.img-mask.active::after {
  transform: scaleY(0);
}

.img-parallax {
  will-change: transform;
  transform: scale(1.1);
  transition: transform 1.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.img-mask.active .img-parallax {
  transform: scale(1);
}

/* Premium hover effects on cards */
.wine-card {
  transition: transform 0.4s ease;
}

.wine-card:hover {
  transform: translateY(-10px);
}

.wine-card-img-wrapper {
  overflow: hidden;
}

.wine-card-img {
  transition: transform 0.8s ease;
}

.wine-card:hover .wine-card-img {
  transform: scale(1.05);
}
