/**
 * Bogosland Animations — Luxury Moroccan Spa Edition
 * Scroll reveal, keyframes, hover effects, micro-interactions
 * All animated elements use will-change for GPU-accelerated 60fps
 */


/* ════════════════════════════════════════════
   SCROLL REVEAL — Base
════════════════════════════════════════════ */

.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity 0.9s var(--ease-out-expo),
    transform 0.9s var(--ease-out-expo);
  will-change: transform, opacity;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-48px);
  transition:
    opacity 0.9s var(--ease-out-expo),
    transform 0.9s var(--ease-out-expo);
  will-change: transform, opacity;
}
.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(48px);
  transition:
    opacity 0.9s var(--ease-out-expo),
    transform 0.9s var(--ease-out-expo);
  will-change: transform, opacity;
}
.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}

.reveal-scale {
  opacity: 0;
  transform: scale(0.9);
  transition:
    opacity 0.8s var(--ease-out-expo),
    transform 0.8s var(--ease-out-expo);
  will-change: transform, opacity;
}
.reveal-scale.visible {
  opacity: 1;
  transform: scale(1);
}


/* ════════════════════════════════════════════
   CLIP-PATH REVEAL
════════════════════════════════════════════ */

.clip-reveal {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s var(--ease-out-expo);
  will-change: clip-path;
}
.clip-reveal.visible {
  clip-path: inset(0 0% 0 0);
}


/* ════════════════════════════════════════════
   STAGGER CHILDREN — 6 items, 0.12s apart
════════════════════════════════════════════ */

.reveal-stagger > * {
  opacity: 0;
  transform: translateY(32px);
  transition:
    opacity 0.7s var(--ease-out-expo),
    transform 0.7s var(--ease-out-expo);
  will-change: transform, opacity;
}

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

.reveal-stagger.visible > *:nth-child(1) { transition-delay: 0.00s; }
.reveal-stagger.visible > *:nth-child(2) { transition-delay: 0.12s; }
.reveal-stagger.visible > *:nth-child(3) { transition-delay: 0.24s; }
.reveal-stagger.visible > *:nth-child(4) { transition-delay: 0.36s; }
.reveal-stagger.visible > *:nth-child(5) { transition-delay: 0.48s; }
.reveal-stagger.visible > *:nth-child(6) { transition-delay: 0.60s; }


/* ════════════════════════════════════════════
   KEYFRAMES
════════════════════════════════════════════ */

/* Gold shimmer sweep */
@keyframes gold-shimmer {
  0%   { background-position: -300% center; }
  100% { background-position: 300% center; }
}

/* Pulse glow — gold ring expansion */
@keyframes pulse-gold {
  0%, 100% {
    box-shadow:
      0 0 0 0   rgba(201, 169, 110, 0.5),
      0 0 0 0   rgba(201, 169, 110, 0.2);
  }
  60% {
    box-shadow:
      0 0 0 10px rgba(201, 169, 110, 0),
      0 0 0 20px rgba(201, 169, 110, 0);
  }
}

/* WhatsApp pulse */
@keyframes pulse-whatsapp {
  0%, 100% {
    box-shadow:
      0 4px 20px rgba(37, 211, 102, 0.5),
      0 0 0 0   rgba(37, 211, 102, 0.3);
  }
  60% {
    box-shadow:
      0 4px 28px rgba(37, 211, 102, 0.6),
      0 0 0 14px rgba(37, 211, 102, 0);
  }
}

/* Gentle float — hero elements, decorative shapes */
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-10px); }
}

/* Marquee scroll — text ticker */
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Fade in */
@keyframes fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Slide up entrance */
@keyframes slide-up {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Scroll indicator drip */
@keyframes scroll-drip {
  0%   { transform: translateY(0);    opacity: 1; }
  80%  { transform: translateY(12px); opacity: 0; }
  100% { transform: translateY(0);    opacity: 0; }
}

/* Slow rotation — decorative rings */
@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* Counter number tick */
@keyframes count-up {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Gradient background shift */
@keyframes gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Moroccan pattern drift — very subtle */
@keyframes pattern-drift {
  0%   { background-position: 0px 0px; }
  100% { background-position: 60px 60px; }
}


/* ════════════════════════════════════════════
   GOLD SHIMMER TEXT
════════════════════════════════════════════ */

.text-shimmer {
  background: linear-gradient(
    90deg,
    var(--bgl-gold-dim) 10%,
    var(--bgl-gold)        30%,
    var(--bgl-gold-bright) 50%,
    var(--bgl-gold)        70%,
    var(--bgl-gold-dim) 90%
  );
  background-size: 300% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gold-shimmer 4s linear infinite;
  font-feature-settings: var(--font-features);
}

/* Static gold gradient text */
.text-gold {
  background: linear-gradient(
    135deg,
    var(--bgl-gold-dim) 0%,
    var(--bgl-gold)     50%,
    var(--bgl-gold-bright) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}


/* ════════════════════════════════════════════
   HOVER LIFT — Cards
════════════════════════════════════════════ */

.lift {
  transition:
    transform 0.35s var(--ease-out-expo),
    box-shadow 0.35s ease;
  will-change: transform;
}
.lift:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-gold-lift);
}

/* Card hover alias */
.card-hover {
  transition:
    transform 0.35s var(--ease-out-expo),
    border-color 0.3s ease,
    box-shadow 0.35s ease;
  will-change: transform;
}
.card-hover:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-gold);
}


/* ════════════════════════════════════════════
   MAGNETIC BUTTON
════════════════════════════════════════════ */

.btn-magnetic {
  transition:
    transform 0.35s var(--ease-out-expo),
    box-shadow 0.35s var(--ease-out-expo);
  will-change: transform;
}
.btn-magnetic:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: var(--shadow-glow);
}


/* ════════════════════════════════════════════
   FLOAT ANIMATION
════════════════════════════════════════════ */

.float {
  animation: float 6s ease-in-out infinite;
  will-change: transform;
}

/* Staggered float variants */
.float--delay-1 { animation-delay: -2s; }
.float--delay-2 { animation-delay: -4s; }


/* ════════════════════════════════════════════
   PULSE
════════════════════════════════════════════ */

.pulse {
  animation: pulse-gold 2.8s ease-in-out infinite;
}


/* ════════════════════════════════════════════
   SCROLL INDICATOR
════════════════════════════════════════════ */

.scroll-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  margin-top: 3.5rem;
  color: var(--bgl-muted);
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.scroll-indicator__line {
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, var(--bgl-gold) 0%, transparent 100%);
  position: relative;
  overflow: hidden;
}

.scroll-indicator__line::after {
  content: '';
  position: absolute;
  top: -100%;
  left: 0;
  right: 0;
  height: 60%;
  background: var(--bgl-gold-bright);
  animation: scroll-drip 2s ease-in-out infinite;
}


/* ════════════════════════════════════════════
   MARQUEE TICKER
════════════════════════════════════════════ */

.marquee-track {
  display: flex;
  width: max-content;
  animation: marquee 30s linear infinite;
  will-change: transform;
}
.marquee-track:hover {
  animation-play-state: paused;
}


/* ════════════════════════════════════════════
   PAGE ENTRANCE
════════════════════════════════════════════ */

.page-enter {
  animation: fade-in 0.7s ease forwards;
}


/* ════════════════════════════════════════════
   DELAY UTILITIES
════════════════════════════════════════════ */

.delay-100 { transition-delay: 0.10s !important; }
.delay-200 { transition-delay: 0.20s !important; }
.delay-300 { transition-delay: 0.30s !important; }
.delay-400 { transition-delay: 0.40s !important; }
.delay-500 { transition-delay: 0.50s !important; }
.delay-600 { transition-delay: 0.60s !important; }
.delay-700 { transition-delay: 0.70s !important; }


/* ════════════════════════════════════════════
   MOROCCAN PATTERN DRIFT (section overlay)
════════════════════════════════════════════ */

.moroccan-animated::before {
  animation: pattern-drift 20s linear infinite;
}


/* ════════════════════════════════════════════
   REDUCED MOTION — respect user preference
════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .reveal,
  .reveal-left,
  .reveal-right,
  .reveal-scale,
  .clip-reveal,
  .reveal-stagger > * {
    opacity: 1;
    transform: none;
    clip-path: none;
  }
}
