/**
 * Archive projets — autogrid (3 colonnes flex, irrégularité largeur, images centrées).
 */

.vaya-autogrid__header {
	margin: 0;
	padding: 0 var(--vaya-autogrid-area-pad-x, 10px) clamp(1rem, 2vw, 1.6rem);
	box-sizing: border-box;
}

.vaya-autogrid__header .vaya-page__title {
	margin: 0;
}

.vaya-autogrid__empty {
	margin: 0;
	padding: 0 var(--vaya-autogrid-area-pad-x, 10px);
	box-sizing: border-box;
}

.vaya-autogrid {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0 0 clamp(4rem, 10vw, 11rem);
	padding: 0 var(--vaya-autogrid-pad-x, 10px);
	box-sizing: border-box;
}

.vaya-autogrid__projects-area {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: flex-start;
	width: 100%;
	padding: 0 var(--vaya-autogrid-area-pad-x, 10px);
	box-sizing: border-box;
}

.vaya-autogrid__column {
	flex: 1 1 0;
	min-width: 0;
	width: 0;
	margin-right: var(--vaya-autogrid-col-gap, 20px);
	box-sizing: border-box;
}

.vaya-autogrid__column:last-child {
	margin-right: 0;
}

/* --- Item projet --- */
.vaya-autogrid__project {
	display: flex;
	justify-content: center;
	margin: 0 0 var(--vaya-autogrid-item-gap, 60px);
	position: relative;
	box-sizing: border-box;
}

/* Largeurs thumbnail */
.vaya-autogrid__project--landscape-small .vaya-autogrid__thumbnail,
.vaya-autogrid__project--portrait-small .vaya-autogrid__thumbnail {
	width: 80%;
}

.vaya-autogrid__project--landscape-medium .vaya-autogrid__thumbnail,
.vaya-autogrid__project--portrait-medium .vaya-autogrid__thumbnail {
	width: 90%;
}

.vaya-autogrid__project--landscape-large .vaya-autogrid__thumbnail,
.vaya-autogrid__project--portrait-large .vaya-autogrid__thumbnail {
	width: 100%;
}

.vaya-autogrid__thumbnail {
	position: relative;
	width: 100%;
	margin: 0;
	font-size: 0;
	line-height: 0;
}

.vaya-autogrid__lazy {
	display: block;
	position: relative;
	width: 100%;
	overflow: hidden;
}

.vaya-autogrid__lazy--color-1 {
	background-color: rgb(255, 253, 245);
}

.vaya-autogrid__lazy--color-2 {
	background-color: rgb(255, 251, 242);
}

.vaya-autogrid__lazy--color-3 {
	background-color: rgb(255, 253, 241);
}

.vaya-autogrid__image {
	display: block;
	width: 100%;
	height: auto;
	opacity: 0;
	transition:
		opacity 0.5s ease 0.2s,
		transform 0.55s cubic-bezier(0.33, 1, 0.68, 1);
	will-change: transform;
}

.vaya-autogrid__lazy--loaded .vaya-autogrid__image {
	opacity: 1;
}

/* Survol image : léger zoom + overlay bleu (comme cartes équipe / mosaïque) */
.vaya-autogrid__lazy::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(2, 58, 196, 0);
	opacity: 0;
	transition:
		background 0.45s cubic-bezier(0.4, 0, 0.2, 1),
		opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

.vaya-autogrid__project:hover .vaya-autogrid__lazy::after,
.vaya-autogrid__project:focus-within .vaya-autogrid__lazy::after {
	background: rgba(2, 58, 196, 0.42);
	opacity: 1;
}

.vaya-autogrid__project:hover .vaya-autogrid__image,
.vaya-autogrid__project:focus-within .vaya-autogrid__image {
	transform: scale(1.05);
}

.vaya-autogrid__caption {
	font-size: 0.75rem;
	line-height: 1.35;
	letter-spacing: 0.01em;
	margin: 8px 0 0;
	width: 100%;
	transition: opacity 0.3s ease;
}

.vaya-autogrid__caption a {
	display: inline-block;
	color: rgba(26, 26, 26, 0.72);
	text-decoration: none;
	font-weight: 400;
	text-transform: none;
}

/* Lien cliquable sur toute la carte (ancêtre positionné = .vaya-autogrid__project) */
.vaya-autogrid__caption a::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 3;
}

.vaya-autogrid__project:hover .vaya-autogrid__caption,
.vaya-autogrid__project:focus-within .vaya-autogrid__caption {
	opacity: 0.25;
}

.vaya-autogrid__project .vaya-autogrid__caption a:hover,
.vaya-autogrid__project .vaya-autogrid__caption a:focus-visible {
	color: var(--vaya-color-primary, #023ac4);
}

/* --- Responsive --- */
@media (min-width: 480px) {
	.vaya-autogrid {
		--vaya-autogrid-pad-x: 20px;
		--vaya-autogrid-area-pad-x: 40px;
		--vaya-autogrid-col-gap: 30px;
		--vaya-autogrid-item-gap: 90px;
	}
}

@media (min-width: 768px) {
	.vaya-autogrid {
		--vaya-autogrid-item-gap: 120px;
	}

	.vaya-autogrid__caption {
		font-size: 1rem;
		margin-top: 10px;
	}
}

@media (min-width: 1280px) {
	.vaya-autogrid {
		--vaya-autogrid-col-gap: 50px;
	}
}

/* Mobile : 1 colonne, ordre WordPress (géré en JS) */
@media (max-width: 767px) {
	body.vaya-archive-project,
	body.post-type-archive-project {
		--vaya-autogrid-pad-x: var(--vaya-content-side-offset, 1.25rem);
		--vaya-autogrid-area-pad-x: 0;
		--vaya-autogrid-col-gap: 0;
		--vaya-autogrid-item-gap: clamp(3rem, 8vw, 4.5rem);
	}

	.vaya-autogrid__projects-area {
		flex-direction: column;
	}

	.vaya-autogrid__column {
		width: 100%;
		flex: 0 0 auto;
		margin-right: 0;
	}

	.vaya-autogrid__project--landscape-small .vaya-autogrid__thumbnail,
	.vaya-autogrid__project--portrait-small .vaya-autogrid__thumbnail,
	.vaya-autogrid__project--landscape-medium .vaya-autogrid__thumbnail,
	.vaya-autogrid__project--portrait-medium .vaya-autogrid__thumbnail,
	.vaya-autogrid__project--landscape-large .vaya-autogrid__thumbnail,
	.vaya-autogrid__project--portrait-large .vaya-autogrid__thumbnail {
		width: 100%;
	}
}

@media (prefers-reduced-motion: reduce) {
	.vaya-autogrid__lazy::after,
	.vaya-autogrid__image {
		transition-duration: 0.01ms;
	}

	.vaya-autogrid__project:hover .vaya-autogrid__image,
	.vaya-autogrid__project:focus-within .vaya-autogrid__image {
		transform: none;
	}

	.vaya-autogrid__project:hover .vaya-autogrid__lazy::after,
	.vaya-autogrid__project:focus-within .vaya-autogrid__lazy::after {
		opacity: 0;
	}
}
