/* Skeleton loader + fade-in per le immagini dinamiche del CMS */

img.cms-img {
	max-width: 100%;
}
/* L'opacità 0 è applicata dal JS solo alle immagini non ancora caricate:
   senza JavaScript le immagini restano comunque visibili. */
img.cms-img.cms-loading {
	opacity: 0;
}
img.cms-img.is-loaded {
	opacity: 1;
	transition: opacity .45s ease;
}
/* immagini "libere" (cover dettaglio, gallery): responsive a tutta larghezza */
.cms-img.cms-fluid {
	width: 100%;
	height: auto;
	display: block;
}
.cms-img.cms-rounded {
	border-radius: 12px;
}

/* Placeholder shimmer applicato dal JS al contenitore dell'immagine in caricamento */
.cms-skel {
	position: relative;
	overflow: hidden;
	background: #e8ecf3;
	min-height: 40px;
}
.cms-skel::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(90deg, #e8ecf3 0%, #f3f6fb 50%, #e8ecf3 100%);
	background-size: 200% 100%;
	animation: cms-shimmer 1.25s ease-in-out infinite;
}
.cms-skel.is-loaded::after {
	display: none;
}

@keyframes cms-shimmer {
	0% { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* Skeleton testuale (titoli/righe) per blocchi dinamici */
.skel-line {
	display: block;
	height: 1em;
	border-radius: 4px;
	background: linear-gradient(90deg, #e8ecf3 0%, #f3f6fb 50%, #e8ecf3 100%);
	background-size: 200% 100%;
	animation: cms-shimmer 1.25s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
	.cms-skel::after, .skel-line { animation: none; }
	img.cms-img { transition: none; }
}
