@media (prefers-reduced-motion: no-preference) {
	[data-reveal] {
		opacity: 0;
		transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
		            transform 0.8s cubic-bezier(0.22, 1, 0.36, 1),
		            clip-path 0.8s cubic-bezier(0.22, 1, 0.36, 1);
	}
	/* Basic directions */
	[data-reveal="fade-up"], [data-reveal=""] { transform: translateY(40px); }
	[data-reveal="fade-in"] { transform: none; }
	[data-reveal="fade-left"] { transform: translateX(40px); }
	[data-reveal="fade-right"] { transform: translateX(-40px); }

	/* Scale - images zoom from 1.08 to 1.0 */
	[data-reveal="scale"] {
		transform: scale(1.08);
		overflow: hidden;
	}

	/* Clip-up - text slides up from behind a mask */
	[data-reveal="clip-up"] {
		clip-path: inset(100% 0 0 0);
		transform: none;
	}

	/* Stagger container - children animate sequentially */
	[data-reveal-stagger] > * {
		opacity: 0;
		transform: translateY(24px);
		transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
		            transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
	}
	[data-reveal-stagger].is-revealed > * {
		opacity: 1;
		transform: none;
	}

	/* Revealed state */
	[data-reveal].is-revealed {
		opacity: 1;
		transform: none;
		clip-path: inset(0 0 0 0);
	}
}
/* Hero background sizing */
.hero-section,
.hero-swiper-slide {
	background-size: cover;
	background-position: center;
}
