/* Animaciones CSS continuas (complementan AOS) */

@media (prefers-reduced-motion: reduce) {
    .anim-float,
    .anim-pulse-soft,
    .anim-shimmer,
    .hero-v2__glow {
        animation: none !important;
    }

    [data-aos] {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* Hero */
.hero-v2__glow {
    animation: anim-glow-pulse 4s ease-in-out infinite;
}

.hero-v2__portrait-wrap {
    animation: anim-float 5s ease-in-out infinite;
}

@keyframes anim-glow-pulse {
    0%, 100% { opacity: 0.4; transform: scale(1); }
    50% { opacity: 0.55; transform: scale(1.06); }
}

@keyframes anim-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

/* Iconos en tarjetas */
.action-card__icon,
.causa-card-v2__icon,
.service-card__icon {
    transition: transform var(--transition);
}

.action-card:hover .action-card__icon,
.causa-card-v2:hover .causa-card-v2__icon {
    transform: scale(1.08) rotate(-3deg);
}

/* Stats */
.stat-item {
    transition: transform var(--transition), box-shadow var(--transition);
}

.stat-item:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-sm);
}

/* Botones */
.btn-accent,
.btn-primary {
    transition: transform var(--transition), background var(--transition), box-shadow var(--transition);
}

.btn-accent:hover,
.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(0, 92, 48, 0.25);
}

/* Redes sociales */
.social-links__item {
    transition: transform var(--transition), background var(--transition), color var(--transition);
}

.social-links__item:hover {
    transform: translateY(-2px);
}

/* Decoración secciones */
.section-cta::before {
    content: '';
    position: absolute;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--color-glow) 0%, transparent 70%);
    top: -80px;
    left: -80px;
    pointer-events: none;
    animation: anim-shimmer 8s linear infinite;
}

@keyframes anim-shimmer {
    0% { opacity: 0.3; transform: translate(0, 0); }
    50% { opacity: 0.5; transform: translate(20px, 15px); }
    100% { opacity: 0.3; transform: translate(0, 0); }
}

/* AOS: suavizar entrada */
[data-aos] {
    pointer-events: auto;
}
