.ue-mosaique {
	display: grid;
	grid-template-columns: repeat( var( --ue-cols, 3 ), 1fr );
	gap: var( --ue-gap, 20px );
	margin: 1.5em 0;
}

.ue-mosaique__item {
	display: block;
	text-decoration: none;
	color: inherit;
}

.ue-mosaique__frame {
	display: block;
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: 8px;
	background: #efe7d6;
}

.ue-mosaique__img,
.ue-mosaique__frame img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.45s ease;
}

.ue-mosaique__placeholder {
	display: block;
	width: 100%;
	height: 100%;
	background: #efe7d6;
}

a.ue-mosaique__item:hover .ue-mosaique__frame img,
a.ue-mosaique__item:focus .ue-mosaique__frame img {
	transform: scale( 1.05 );
}

.ue-mosaique__title {
	display: block;
	text-align: center;
	margin-top: 12px;
	font-family: "Playfair Display", Georgia, "Times New Roman", serif;
	font-size: 1.15rem;
	line-height: 1.3;
	color: #2c2c2c;
}

a.ue-mosaique__item:hover .ue-mosaique__title,
a.ue-mosaique__item:focus .ue-mosaique__title {
	color: #c5a55a;
}

@media ( max-width: 781px ) {
	.ue-mosaique {
		grid-template-columns: repeat( 2, 1fr );
	}
}

@media ( max-width: 480px ) {
	.ue-mosaique {
		grid-template-columns: 1fr;
	}
}
