/* Premium Micro-animations and Transitions */

/* Fade In Up - for scroll reveal */
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fade-in-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Staggered Delay for grid items */
.delay-100 { transition-delay: 100ms; }
.delay-200 { transition-delay: 200ms; }
.delay-300 { transition-delay: 300ms; }
.delay-400 { transition-delay: 400ms; }

/* Image Hover Zoom */
.img-zoom-container {
  overflow: hidden;
  border-radius: 12px;
}

.img-zoom-container img {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.img-zoom-container:hover img {
  transform: scale(1.08);
}

/* Float Animation for Hero Elements */
@keyframes float {
  0% { transform: translateY(0px); }
  50% { transform: translateY(-15px); }
  100% { transform: translateY(0px); }
}

.floating {
  animation: float 6s ease-in-out infinite;
}

/* Pulse Animation for Trust Badges */
@keyframes pulse {
  0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(179, 27, 27, 0.4); }
  70% { transform: scale(1.05); box-shadow: 0 0 0 10px rgba(179, 27, 27, 0); }
  100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(179, 27, 27, 0); }
}

.pulse-hover:hover {
  animation: pulse 1.5s infinite;
}

/* Spice Particles / Background Elements */
@keyframes drift {
  0% { transform: rotate(0deg) translate(0px, 0px); }
  50% { transform: rotate(180deg) translate(20px, 15px); }
  100% { transform: rotate(360deg) translate(0px, 0px); }
}

.bg-particle {
  position: absolute;
  opacity: 0.1;
  z-index: -1;
  pointer-events: none;
  animation: drift 20s linear infinite;
}

/* Slide in Cart */
@keyframes slideInRight {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}

@keyframes slideOutRight {
  from { transform: translateX(0); }
  to { transform: translateX(100%); }
}

.cart-slide-in {
  animation: slideInRight 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.cart-slide-out {
  animation: slideOutRight 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

/* Shimmer Loading Effect for Images */
@keyframes shimmer {
  0% { background-position: -1000px 0; }
  100% { background-position: 1000px 0; }
}

.skeleton-loading {
  background: #f6f7f8;
  background-image: linear-gradient(to right, #f6f7f8 0%, #edeef1 20%, #f6f7f8 40%, #f6f7f8 100%);
  background-repeat: no-repeat;
  background-size: 1000px 100%; 
  animation: shimmer 2s infinite linear forwards;
}

/* Cinematic Text Reveal */
.text-reveal {
  overflow: hidden;
}

.text-reveal > * {
  transform: translateY(100%);
  opacity: 0;
  transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.8s ease;
}

.text-reveal.visible > * {
  transform: translateY(0);
  opacity: 1;
}

/* Staggered children for text reveal */
.text-reveal.stagger > *:nth-child(1) { transition-delay: 0.1s; }
.text-reveal.stagger > *:nth-child(2) { transition-delay: 0.2s; }
.text-reveal.stagger > *:nth-child(3) { transition-delay: 0.3s; }
.text-reveal.stagger > *:nth-child(4) { transition-delay: 0.4s; }

/* Mouse Tracking Glow for Cards */
.glow-card {
  position: relative;
  /* preserve-3d for tilt effect */
  transform-style: preserve-3d;
  transition: transform 0.1s ease;
  will-change: transform;
}

.glow-card > * {
  /* Inner elements pop out during 3D tilt */
  transform: translateZ(30px);
}

.glow-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 1;
  border: 2px solid transparent;
  background: radial-gradient(
    800px circle at var(--mouse-x) var(--mouse-y), 
    rgba(179, 27, 27, 0.4),
    transparent 40%
  );
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
}

.glow-card:hover::before {
  opacity: 1;
}

/* Floating Parallax Elements */
.parallax-element {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  will-change: transform;
  /* Base floating animation */
  animation: float 6s ease-in-out infinite;
}

@keyframes float {
  0% { transform: translateY(0px) rotate(0deg); }
  50% { transform: translateY(-20px) rotate(10deg); }
  100% { transform: translateY(0px) rotate(0deg); }
}

/* Skew Wrapper */
.skew-wrapper {
  will-change: transform;
  transition: transform 0.1s ease-out;
}
