/* ============================================================
   Assi Wood — Animations CSS
   GSAP-triggered classes + CSS-only animations
   ============================================================ */

/* Base state for animated elements (set by JS) */
.anim-fade-up {
  opacity: 0;
  transform: translateY(40px);
}
.anim-fade-in {
  opacity: 0;
}
.anim-scale-up {
  opacity: 0;
  transform: scale(0.92);
}
.anim-slide-left {
  opacity: 0;
  transform: translateX(-40px);
}
.anim-slide-right {
  opacity: 0;
  transform: translateX(40px);
}

/* Revealed state */
.anim-fade-up.is-revealed,
.anim-fade-in.is-revealed,
.anim-scale-up.is-revealed,
.anim-slide-left.is-revealed,
.anim-slide-right.is-revealed {
  opacity: 1;
  transform: none;
  transition: opacity 0.7s cubic-bezier(0.25,0.46,0.45,0.94),
              transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94);
}

/* Stagger delay helpers */
.anim-delay-1 { transition-delay: 0.1s !important; }
.anim-delay-2 { transition-delay: 0.2s !important; }
.anim-delay-3 { transition-delay: 0.3s !important; }
.anim-delay-4 { transition-delay: 0.4s !important; }
.anim-delay-5 { transition-delay: 0.5s !important; }
.anim-delay-6 { transition-delay: 0.6s !important; }

/* Section heading clip animation */
.heading-clip-wrap {
  overflow: hidden;
  display: block;
}
.heading-clip-inner {
  display: block;
  transform: translateY(100%);
  transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.heading-clip-wrap.is-revealed .heading-clip-inner {
  transform: translateY(0);
}

/* Counter animation class */
.stat-counter { display: inline; }

/* Parallax wrapper */
.parallax-wrap { will-change: transform; }

/* Wood grain shimmer on hover */
.wood-shimmer {
  position: relative;
  overflow: hidden;
}
.wood-shimmer::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.06) 50%,
    transparent 100%
  );
  transform: skewX(-20deg);
  transition: left 0.6s ease;
  pointer-events: none;
}
.wood-shimmer:hover::before { left: 150%; }

/* Line reveal */
.line-reveal {
  overflow: hidden;
}
.line-reveal__inner {
  display: block;
  transform: translateY(110%);
  transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.line-reveal.is-revealed .line-reveal__inner {
  transform: translateY(0);
}

/* Fade-up group: children stagger via nth-child */
.stagger-group > * {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.stagger-group.is-revealed > *:nth-child(1)  { opacity:1; transform:none; transition-delay:0s;    }
.stagger-group.is-revealed > *:nth-child(2)  { opacity:1; transform:none; transition-delay:0.1s;  }
.stagger-group.is-revealed > *:nth-child(3)  { opacity:1; transform:none; transition-delay:0.2s;  }
.stagger-group.is-revealed > *:nth-child(4)  { opacity:1; transform:none; transition-delay:0.3s;  }
.stagger-group.is-revealed > *:nth-child(5)  { opacity:1; transform:none; transition-delay:0.4s;  }
.stagger-group.is-revealed > *:nth-child(6)  { opacity:1; transform:none; transition-delay:0.5s;  }
.stagger-group.is-revealed > *:nth-child(7)  { opacity:1; transform:none; transition-delay:0.6s;  }
.stagger-group.is-revealed > *:nth-child(8)  { opacity:1; transform:none; transition-delay:0.7s;  }
.stagger-group.is-revealed > *:nth-child(9)  { opacity:1; transform:none; transition-delay:0.8s;  }
.stagger-group.is-revealed > *:nth-child(10) { opacity:1; transform:none; transition-delay:0.9s;  }

/* Floating animation for elements */
@keyframes float {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
.float-anim { animation: float 5s ease-in-out infinite; }

/* Page transition */
.page-transition-overlay {
  position: fixed;
  inset: 0;
  background: var(--color-bg-dark);
  z-index: 9998;
  transform: translateY(100%);
  pointer-events: none;
}
.page-transition-overlay.is-entering {
  animation: pageEnter 0.5s cubic-bezier(0.76, 0, 0.24, 1) forwards;
}
.page-transition-overlay.is-leaving {
  animation: pageLeave 0.5s cubic-bezier(0.76, 0, 0.24, 1) forwards;
}
@keyframes pageEnter {
  0% { transform: translateY(100%); }
  100% { transform: translateY(0); }
}
@keyframes pageLeave {
  0% { transform: translateY(0); }
  100% { transform: translateY(-100%); }
}

/* Custom cursor */
.cursor {
  pointer-events: none;
  position: fixed;
  z-index: 9999;
  width: 12px; height: 12px;
  background: var(--color-primary);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.1s ease, width 0.3s ease, height 0.3s ease, opacity 0.3s ease;
  mix-blend-mode: difference;
}
.cursor-ring {
  pointer-events: none;
  position: fixed;
  z-index: 9998;
  width: 36px; height: 36px;
  border: 1.5px solid rgba(139,105,20,0.5);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.15s ease, width 0.3s ease, height 0.3s ease;
}
.cursor.is-hovering { width: 20px; height: 20px; }
.cursor-ring.is-hovering { width: 56px; height: 56px; border-color: var(--color-primary); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .anim-fade-up, .anim-fade-in, .anim-scale-up,
  .anim-slide-left, .anim-slide-right,
  .stagger-group > *,
  .heading-clip-inner, .line-reveal__inner {
    transition: none !important;
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  .factory__track, .testimonials__track {
    animation: none !important;
  }
}
