/* ============================================================
   RÓTULOS AVANTI — animations.css
   ============================================================ */

/* AOS override personalizado */
[data-aos] { pointer-events: none; }
[data-aos].aos-animate { pointer-events: auto; }

/* Counter animation */
.counter-value { transition: all 0.1s; }

/* Línea decorativa animada */
.line-reveal {
  position: relative;
  overflow: hidden;
}
.line-reveal::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0;
  background: var(--color-primary);
  transition: width 0.6s ease;
}
.line-reveal:hover::after { width: 100%; }

/* Shimmer loading */
@keyframes shimmer {
  0% { background-position: -1000px 0; }
  100% { background-position: 1000px 0; }
}
.shimmer {
  background: linear-gradient(90deg, var(--color-mid) 25%, var(--color-border) 50%, var(--color-mid) 75%);
  background-size: 1000px 100%;
  animation: shimmer 2s infinite;
}

/* Pulse verde */
@keyframes pulsGreen {
  0%, 100% { box-shadow: 0 0 0 0 rgba(100,169,11,0.4); }
  50% { box-shadow: 0 0 0 12px rgba(100,169,11,0); }
}
.pulse-green { animation: pulsGreen 2s infinite; }

/* Float */
@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
.float { animation: floatY 4s ease-in-out infinite; }

/* Rotate slow */
@keyframes rotateSlow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.rotate-slow { animation: rotateSlow 20s linear infinite; }

/* Fade in up (custom, sin AOS) */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
.anim-fade-up { animation: fadeInUp 0.7s ease forwards; }
.anim-fade-up--d1 { animation-delay: 0.1s; opacity: 0; }
.anim-fade-up--d2 { animation-delay: 0.25s; opacity: 0; }
.anim-fade-up--d3 { animation-delay: 0.4s; opacity: 0; }
.anim-fade-up--d4 { animation-delay: 0.55s; opacity: 0; }

/* Counter number */
@keyframes countUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Scroll progress bar */
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  background: var(--color-primary);
  z-index: 9999;
  width: 0%;
  transition: width 0.1s;
}

/* Navbar reveal animation */
@keyframes navSlideDown {
  from { transform: translateY(-100%); }
  to { transform: translateY(0); }
}
.navbar { animation: navSlideDown 0.5s ease; }

/* Hero text stagger */
.hero .hero__eyebrow { animation: fadeInUp 0.6s ease 0.2s both; }
.hero h1 { animation: fadeInUp 0.7s ease 0.4s both; }
.hero .hero__sub { animation: fadeInUp 0.7s ease 0.6s both; }
.hero .hero__actions { animation: fadeInUp 0.7s ease 0.8s both; }
.scroll-indicator { animation: fadeInUp 0.7s ease 1.2s both; }

/* Card hover states */
.servicio-card, .blog-card, .proyecto-card, .portfolio-item {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.servicio-card:hover, .blog-card:hover {
  transform: translateY(-4px);
}

/* Green underline on hover links */
.green-hover {
  position: relative;
  display: inline-block;
}
.green-hover::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-primary);
  transition: width 0.25s ease;
}
.green-hover:hover::after { width: 100%; }

/* Toast notification */
@keyframes toastIn {
  from { transform: translateY(100px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
@keyframes toastOut {
  from { transform: translateY(0); opacity: 1; }
  to { transform: translateY(100px); opacity: 0; }
}
.toast {
  position: fixed;
  bottom: 32px;
  right: 32px;
  background: var(--color-primary);
  color: #fff;
  padding: 16px 24px;
  font-size: 14px;
  font-weight: 500;
  z-index: 9999;
  animation: toastIn 0.4s ease;
  max-width: 320px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
.toast.hide { animation: toastOut 0.4s ease forwards; }
