/* Bloc « Remontée des événements » — grille de cartes photo plein cadre,
   titre en surimpression sur un dégradé sombre (lisibilité RGAA). */
.vv-evenements-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: clamp(1rem, 2.5vw, 2rem);
	grid-template-columns: repeat(3, 1fr);
}

.vv-evenements-grid--cols-1 { grid-template-columns: 1fr; }
.vv-evenements-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.vv-evenements-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.vv-evenements-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 781px) {
	.vv-evenements-grid--cols-3,
	.vv-evenements-grid--cols-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.vv-evenements-grid { grid-template-columns: 1fr; }
}

.vv-evenement-card {
	margin: 0;
	display: flex;
}

.vv-evenement-card__link {
	display: block;
	width: 100%;
	color: #fff;
	text-decoration: none;
	border-radius: 6px;
	overflow: hidden;
}

/* Focus clavier visible (RGAA). */
.vv-evenement-card__link:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

.vv-evenement-card__media {
	position: relative;
	margin: 0;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: #2a2a2a;
}

.vv-evenement-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.vv-evenement-card__img--placeholder {
	background: linear-gradient(135deg, #3a3a3a, #555);
}

.vv-evenement-card__link:hover .vv-evenement-card__img,
.vv-evenement-card__link:focus-visible .vv-evenement-card__img {
	transform: scale(1.04);
}

/* Dégradé sombre en bas pour garantir le contraste du texte. */
.vv-evenement-card__scrim {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(0, 0, 0, 0.78) 0%,
		rgba(0, 0, 0, 0.5) 28%,
		rgba(0, 0, 0, 0) 60%
	);
}

.vv-evenement-card__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: clamp(1rem, 2.5vw, 1.75rem);
}

.vv-evenement-card__surtitre {
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	letter-spacing: 0.02em;
	opacity: 0.92;
}

.vv-evenement-card__title {
	margin: 0;
	color: #fff;
	font-size: var(--wp--preset--font-size--large, 1.5rem);
	line-height: 1.15;
	text-wrap: balance;
}

.vv-evenement-card__price {
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	font-weight: 600;
	opacity: 0.95;
}

/* ---- Variante compacte : cartes plus petites (ex. pont événements) ---- */
.vv-evenements-grid.vv-evenements-grid--compact {
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: clamp(0.6rem, 1.5vw, 1rem);
}

.vv-evenements-grid--compact .vv-evenement-card__media {
	aspect-ratio: 4 / 5;
}

.vv-evenements-grid--compact .vv-evenement-card__caption {
	padding: clamp(0.6rem, 1.5vw, 1rem);
	gap: 0.2rem;
}

.vv-evenements-grid--compact .vv-evenement-card__title {
	font-size: var(--wp--preset--font-size--medium, 1.125rem);
}

.vv-evenements-grid--compact .vv-evenement-card__surtitre,
.vv-evenements-grid--compact .vv-evenement-card__price {
	font-size: var(--wp--preset--font-size--x-small, 0.75rem);
}

@media (prefers-reduced-motion: reduce) {
	.vv-evenement-card__img {
		transition: none;
	}
	.vv-evenement-card__link:hover .vv-evenement-card__img,
	.vv-evenement-card__link:focus-visible .vv-evenement-card__img {
		transform: none;
	}
}
