/* Animations & Micro-interactions */

/* Intro Loader */
.intro-loader {
  position: fixed;
  inset: 0;
  background-color: var(--color-pitch-black);
  z-index: var(--z-loader);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: transform 1.2s cubic-bezier(0.77, 0, 0.175, 1);
}

.intro-loader.fade-out {
  transform: translateY(-100%);
}

.loader-logo {
  font-family: var(--font-serif);
  font-size: var(--text-4xl);
  color: var(--color-bone-white);
  letter-spacing: -0.05em;
  opacity: 0;
  animation: fadeInOut 2.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

@keyframes fadeInOut {
  0% {
    opacity: 0;
    transform: translateY(20px) scale(0.95);
    filter: blur(10px);
  }
  30% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
  70% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-20px) scale(1.05);
    filter: blur(10px);
  }
}

/* Scroll Reveal Initial States */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1.2s cubic-bezier(0.19, 1, 0.22, 1), transform 1.2s cubic-bezier(0.19, 1, 0.22, 1);
  will-change: opacity, transform;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Staggered Children Reveal */
.products-scroll.reveal .product-card {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s cubic-bezier(0.19, 1, 0.22, 1), transform 1s cubic-bezier(0.19, 1, 0.22, 1);
}

.products-scroll.reveal.is-visible .product-card {
  opacity: 1;
  transform: translateY(0);
}

/* Add delays using CSS nth-child */
.products-scroll.reveal.is-visible .product-card:nth-child(1) { transition-delay: 0.1s; }
.products-scroll.reveal.is-visible .product-card:nth-child(2) { transition-delay: 0.2s; }
.products-scroll.reveal.is-visible .product-card:nth-child(3) { transition-delay: 0.3s; }
.products-scroll.reveal.is-visible .product-card:nth-child(4) { transition-delay: 0.4s; }

.ig-grid.reveal .ig-post {
  opacity: 0;
  transform: translateY(20px) scale(0.98);
  transition: opacity 0.8s cubic-bezier(0.19, 1, 0.22, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
}

.ig-grid.reveal.is-visible .ig-post {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.ig-grid.reveal.is-visible .ig-post:nth-child(1) { transition-delay: 0.1s; }
.ig-grid.reveal.is-visible .ig-post:nth-child(2) { transition-delay: 0.15s; }
.ig-grid.reveal.is-visible .ig-post:nth-child(3) { transition-delay: 0.2s; }
.ig-grid.reveal.is-visible .ig-post:nth-child(4) { transition-delay: 0.25s; }

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

/* Smooth Image Reveal Effect for Manifesto */
.manifesto-image.reveal {
  opacity: 0;
  clip-path: inset(100% 0 0 0);
  transition: opacity 1.5s cubic-bezier(0.77, 0, 0.175, 1), clip-path 1.5s cubic-bezier(0.77, 0, 0.175, 1);
  transform: none; /* Override default reveal transform */
}

.manifesto-image.reveal.is-visible {
  opacity: 1;
  clip-path: inset(0 0 0 0);
}

.manifesto-image img {
  transform: scale(1.1);
  transition: transform 2s cubic-bezier(0.19, 1, 0.22, 1);
}

.manifesto-image.reveal.is-visible img {
  transform: scale(1);
}