/* ============================================================
   SCROLL REVEAL STATES
   These are the initial states. GSAP/JS will animate them in.
   ============================================================ */
.reveal-up {
  opacity: 0;
  transform: translateY(40px);
  will-change: opacity, transform;
}

.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  will-change: opacity, transform;
}

.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  will-change: opacity, transform;
}

.reveal-scale {
  opacity: 0;
  transform: scale(0.92);
  will-change: opacity, transform;
}

.reveal-fade {
  opacity: 0;
  will-change: opacity;
}

/* When GSAP triggers, add .animated class or use inline styles */
.reveal-up.animated,
.reveal-left.animated,
.reveal-right.animated,
.reveal-scale.animated,
.reveal-fade.animated {
  opacity: 1;
  transform: none;
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}

/* Stagger children */
.stagger-children > * {
  opacity: 0;
  transform: translateY(30px);
}

/* ============================================================
   KEYFRAME ANIMATIONS
   ============================================================ */

/* Float idle animation */
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-12px); }
}

/* Float with slight sway */
@keyframes floatSway {
  0%   { transform: translateY(0)   rotate(0deg); }
  33%  { transform: translateY(-10px) rotate(0.5deg); }
  66%  { transform: translateY(-6px)  rotate(-0.5deg); }
  100% { transform: translateY(0)   rotate(0deg); }
}

/* Pulse */
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.05); }
}

/* Glow pulse */
@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 20px rgba(232,25,44,0.3); }
  50%       { box-shadow: 0 0 50px rgba(232,25,44,0.6), 0 0 100px rgba(232,25,44,0.2); }
}

/* Slide in from bottom */
@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

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

/* Shine sweep */
@keyframes shine {
  from { background-position: -200% center; }
  to   { background-position: 200% center; }
}

/* Spin */
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Rotate gradient border */
@keyframes rotateGrad {
  to { --gradient-angle: 360deg; }
}

/* Character idle float */
.char-idle { animation: float 4s ease-in-out infinite; }
.char-idle-slow { animation: float 6s ease-in-out infinite; }
.char-idle-offset { animation: floatSway 5s ease-in-out infinite 0.5s; }

/* Logo entrance */
.logo-entrance {
  animation: slideInUp 0.8s var(--ease-out) both;
}

/* Text shimmer effect */
.text-shimmer {
  background: linear-gradient(
    90deg,
    var(--morico-white) 0%,
    var(--morico-gold) 50%,
    var(--morico-white) 100%
  );
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: shine 3s linear infinite;
}

/* Red glow text */
.text-glow-red {
  color: var(--morico-red);
  text-shadow:
    0 0 20px rgba(232,25,44,0.5),
    0 0 60px rgba(232,25,44,0.2);
}

/* Gold glow text */
.text-glow-gold {
  color: var(--morico-gold);
  text-shadow:
    0 0 20px rgba(212,168,75,0.5),
    0 0 60px rgba(212,168,75,0.2);
}

/* ============================================================
   TIMELINE (About page)
   ============================================================ */
.timeline {
  position: relative;
  padding-inline-start: 2rem;
}

.timeline::before {
  content: '';
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  width: 2px;
  background: linear-gradient(to bottom, transparent, var(--morico-red) 15%, var(--morico-red) 85%, transparent);
}

.timeline-item {
  position: relative;
  padding-bottom: var(--space-lg);
}

.timeline-item::before {
  content: '';
  position: absolute;
  inset-inline-start: -2.4rem;
  top: 0.4rem;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--morico-red);
  box-shadow: 0 0 15px rgba(232,25,44,0.5);
  border: 3px solid var(--morico-black);
}

.timeline-year {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--morico-red);
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}

.timeline-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--morico-white);
  margin-bottom: 0.5rem;
}

.timeline-text {
  font-size: 0.9rem;
  color: var(--morico-gray-light);
  line-height: 1.7;
}

/* ============================================================
   PAGE TRANSITION
   ============================================================ */
.page-transition-overlay {
  position: fixed;
  inset: 0;
  background: var(--morico-black);
  z-index: 9998;
  pointer-events: none;
  transform: scaleY(0);
  transform-origin: bottom;
}

.page-transition-overlay.entering {
  transform: scaleY(1);
  transition: transform 0.4s var(--ease-in);
  transform-origin: bottom;
}

.page-transition-overlay.leaving {
  transform: scaleY(0);
  transition: transform 0.4s var(--ease-out);
  transform-origin: top;
}

/* ============================================================
   SKELETON LOADING
   ============================================================ */
@keyframes shimmerSkeleton {
  from { background-position: -500px 0; }
  to   { background-position: 500px 0; }
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--morico-gray-mid) 25%,
    rgba(255,255,255,0.05) 50%,
    var(--morico-gray-mid) 75%
  );
  background-size: 500px 100%;
  animation: shimmerSkeleton 1.5s ease-in-out infinite;
  border-radius: var(--radius-sm);
}

/* ============================================================
   PARTICLE CANVAS
   ============================================================ */
.particle-bg {
  position: relative;
  overflow: hidden;
}

.particle-bg canvas {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.particle-bg > *:not(canvas) {
  position: relative;
  z-index: 1;
}

/* ============================================================
   SECTION ENTRANCE ANIMATIONS
   (fallback for no-JS via prefers-reduced-motion override)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .reveal-up, .reveal-left, .reveal-right, .reveal-scale, .reveal-fade {
    opacity: 1;
    transform: none;
  }

  .stagger-children > * {
    opacity: 1;
    transform: none;
  }
}
