/* ==========================================================================
   Animaciones Clínica — Estilos
   Estados de las animaciones aplicadas vía data-animate desde Elementor
   ========================================================================== */

/* Estado inicial común */
[data-animate] {
	opacity: 0;
	transition-property: opacity, transform, filter;
	transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
	transition-duration: 0.9s; /* lo sobrescribe el JS con data-duration */
	will-change: opacity, transform, filter;
}

/* Variantes — estado oculto */
[data-animate="fade-up"]    { transform: translateY(30px); }
[data-animate="fade-down"]  { transform: translateY(-30px); }
[data-animate="fade-right"] { transform: translateX(-40px); }
[data-animate="fade-left"]  { transform: translateX(40px); }
[data-animate="zoom-in"]    { transform: scale(0.92); }
[data-animate="zoom-out"]   { transform: scale(1.08); }
[data-animate="blur-in"]    { filter: blur(12px); }

/* Estado revelado (lo añade el JS al entrar en viewport) */
[data-animate].ncanim-in {
	opacity: 1;
	transform: none;
	filter: none;
}

/* --------------------------------------------------------------------------
   Seguridad en el EDITOR de Elementor:
   nunca ocultamos contenido mientras se edita.
   -------------------------------------------------------------------------- */
.elementor-editor-active [data-animate],
.elementor-editor-preview [data-animate] {
	opacity: 1 !important;
	transform: none !important;
	filter: none !important;
}

/* --------------------------------------------------------------------------
   Accesibilidad: respeta a quien reduce el movimiento.
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	[data-animate] {
		opacity: 1 !important;
		transform: none !important;
		filter: none !important;
		transition: none !important;
	}
}
