/**
 * Styles calqués sur le thème Vaya (Tailwind compilé) — éléments architectes.
 * Base : 62.5% ≈ 1rem = 10px (comme l’ancienne feuille).
 */

:root {
	--vaya-main-offset: 200px;
	--vaya-logo-unit: var(--vaya-main-offset);
	--vaya-content-side-offset: 9.65rem;
	--vaya-header-gap: 0.2rem;
	--vaya-color-primary: #023ac4;
	/* Écart logo ↔ zone nav (aligné sur gap du wrap header desktop) */
	--vaya-header-wrap-gap: clamp(2rem, 3vw, 3.6rem);
	--vaya-gap-nav-to-grid: 0rem;
	/* Colonne centrale (main + alignement des onglets nav) */
	--vaya-content-max: calc(90vw - 2 * var(--vaya-content-side-offset));
	/* Bandeau #vaya-header-panel (nav + réseaux) */
	--vaya-header-nav-height: calc(var(--vaya-logo-unit) / 1);
	/* Onglets nav (carrés bleus) : 0.336 × 1.2 ≈ 0.403 */
	--vaya-tab-square: calc(var(--vaya-header-nav-height) * 0.403);
	--vaya-tab-height: var(--vaya-tab-square);
	/* Onglets style minimal (bordure) — padding / typo −20 % */
	--vaya-nav-tab-minimal-py: 0.196rem;
	--vaya-nav-tab-minimal-px: 0.336rem;
	--vaya-nav-tab-minimal-fs: clamp(0.44rem, 0.504vw, 0.472rem);
	--vaya-mosaic-gap: 40px;
}

body.front-end {
	font-size: 62.5%;
	-webkit-font-smoothing: antialiased;
	padding: 0;
	margin: 0;
}

/* Neutralise la contrainte auto WP des layouts "constrained". */
.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	max-width: none !important;
}

main {
	display: block;
	min-height: 50vh;
	margin-top: 0;
	width: var(--vaya-content-max);
	max-width: var(--vaya-content-max);
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

/* --- Typo utilitaires (noms identiques à l’originel) --- */
.text-xxxs {
	font-size: 1.2rem;
}
.text-xxs {
	font-size: 1.4rem;
}
.text-xs {
	font-size: 1.6rem;
}
.text-sm {
	font-size: 1.8rem;
}
.text-md {
	font-size: 2rem;
}
.text-lg {
	font-size: 2.4rem;
}
.text-3xl {
	font-size: 3.2rem;
}
.uppercase {
	text-transform: uppercase;
}
.text-grey-soft {
	color: #38383899;
}
.fill-main {
	fill: #000;
}
.text-white {
	color: #fff;
}
.font-medium {
	font-weight: 500;
}
.leading-tight {
	line-height: 1.2;
}

/* --- Layout --- */
.wrap {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
._with-paddings {
	padding-left: 3rem;
	padding-right: 3rem;
}
.px-12 {
	padding-left: 0;
	padding-right: 0;
}
.py-20 {
	padding-top: 5rem;
	padding-bottom: 5rem;
}
.py-hero {
	padding-top: 8rem;
	padding-bottom: 8rem;
}
.flex {
	display: flex;
}
.flex-wrap {
	flex-wrap: wrap;
}
.items-center {
	align-items: center;
}
.justify-between {
	justify-content: space-between;
}
.gap-8 {
	gap: 2rem;
}
.gap-12 {
	gap: 3rem;
}
.gap-24 {
	gap: 6rem;
}
.gap-6 {
	gap: 1.5rem;
}
.gap-x-20 {
	column-gap: 5rem;
}
.gap-y-8 {
	row-gap: 2rem;
}
.gap-28 {
	gap: 7rem;
}
.gap-55 {
	gap: 5.5rem;
}
.mt-8 {
	margin-top: 2rem;
}
.mt-16 {
	margin-top: 4rem;
}
.mt-20 {
	margin-top: 5rem;
}
.mb-8 {
	margin-bottom: 2rem;
}
.mb-12 {
}
.mb-22 {
	margin-bottom: 2.2rem;
}
.pb-12rem {
	padding-bottom: 12rem;
}
.mt-2 {
	margin-top: 0.5rem;
}
.mt-4 {
	margin-top: 1rem;
}
.mt-6 {
	margin-top: 1.5rem;
}

/* Grille fiche projet */
.grid-12 {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
}
.gap-x-7 {
	column-gap: 7rem;
}
.gap-y-6 {
	row-gap: 6rem;
}
.col-span-3 {
	grid-column: span 3 / span 3;
}
.col-span-8 {
	grid-column: span 8 / span 8;
}
.col-start-5 {
	grid-column-start: 5;
}
.sticky-sidebar {
	position: sticky;
	top: 12.3rem;
}
.grid-2 {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-3 {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
.gap-8 {
	gap: 2rem;
}
.aspect-4-3 {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.aspect-3-4 {
	aspect-ratio: 3 / 4;
	overflow: hidden;
}
.object-cover {
	object-fit: cover;
}
.w-full {
	width: 100%;
}
.h-full {
	height: 100%;
}
.text-center {
	text-align: center;
}

@media (max-width: 1020px) {
	.tablet-stack {
		display: flex;
		flex-direction: column;
	}
	.tablet-full {
		grid-column: 1 / -1;
		width: 100%;
	}
	.col-start-5 {
		grid-column-start: 1;
	}
	.sticky-sidebar {
		position: static;
	}
}

@media (max-width: 800px) {
	.grid-2,
	.grid-3 {
		grid-template-columns: 1fr;
	}
	.desktop-hide {
		display: none;
	}
}

@media (min-width: 801px) {
	.desktop-hide {
		display: block;
	}
}

/* --- Couleurs Vaya --- */
.bg-primary {
	background-color: var(--vaya-color-primary);
}
.bg-grey {
	background-color: #808080;
}
.bg-white {
	background-color: #fff;
}
.border-top-light {
	border-top: 1px solid #f2f2f2;
}

/* --- Header --- */
.header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999;
	width: 100%;
	padding-top: 0;
	padding-bottom: 0;
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.header__wrap {
	display: flex;
	justify-content: space-between;
	gap: 24px;
	align-items: flex-start;
	padding-left: 0;
	padding-right: 0;
}
.header__wrap--v2 {
	padding: 0;
}
.header__head {
	display: flex;
	justify-content: space-between;
	gap: 3rem;
	width: 100%;
	align-items: center;
}
.header__brand {
	margin: 0;
	line-height: 0;
}
.header__logo-full img {
	display: block;
	height: auto;
	width: 18.3rem;
	max-width: 100%;
}
.header__logo-short {
	display: none;
}
.header__logo-short img {
	display: block;
	width: 5rem;
	height: 5rem;
	object-fit: contain;
}
.header__logo-full {
	display: flex;
}

/* Transparent sur fiches projet (héro) */
.nav-transparent .header:not(.is-fixed):not(.is-active) .header__logo-full {
	display: flex;
}
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--header .menu__link,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--header .menu__list > li > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__link,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li > a {
	color: #fff;
}
/* Onglets non actifs : fond blanc semi-transparent (sauf si page courante / ancêtre WP) */
.nav-transparent
	.header:not(.is-fixed):not(.is-active)
	.menu--tabs
	.menu__list
	> li:not(.current-menu-item):not(.current_page_item):not(.current-menu-ancestor):not(.current-menu-parent):not(
		.current_page_parent
	):not(.current_page_ancestor)
	> a {
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
}
.nav-transparent
	.header:not(.is-fixed):not(.is-active)
	.menu--tabs
	.menu__list
	> li:not(.current-menu-item):not(.current_page_item):not(.current-menu-ancestor):not(.current-menu-parent):not(
		.current_page_parent
	):not(.current_page_ancestor)
	> a:hover {
	opacity: 1;
	background-color: var(--wp--preset--color--accent, #023ac4);
	color: #fff;
}
/* Page active : fond bleu + texte blanc (y compris archive CPT / parent de section) */
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current-menu-item > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current_page_item > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current-menu-ancestor > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current-menu-parent > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current_page_parent > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current_page_ancestor > a,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li > a[aria-current="page"] {
	background-color: var(--wp--preset--color--accent, #023ac4);
	color: #fff;
	opacity: 1;
}
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current-menu-item > a:hover,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current_page_item > a:hover,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current-menu-ancestor > a:hover,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current-menu-parent > a:hover,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current_page_parent > a:hover,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li.current_page_ancestor > a:hover,
.nav-transparent .header:not(.is-fixed):not(.is-active) .menu--tabs .menu__list > li > a[aria-current="page"]:hover {
	opacity: 1;
	background-color: var(--wp--preset--color--accent, #023ac4);
	color: #fff;
}
.nav-transparent .header:not(.is-fixed):not(.is-active) .header__socials--v2 .social-icon {
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
}

.header.is-fixed,
.header.is-fixed.is-active {
	background-color: transparent;
}

/* Logo compact uniquement après scroll (.is-scrolled), pas au menu ouvert en haut de page */
.header.is-scrolled .header__logo-full {
	display: none !important;
}
.header.is-scrolled .header__logo-short {
	display: inline-flex !important;
}

.header__content {
	display: flex;
	align-items: center;
	gap: 4rem;
}
@media (max-width: 800px) {
	.header__head {
		width: 100%;
	}
	.header__content {
		display: none;
	}
	.header.is-active .header__content {
		display: flex;
		flex-direction: column;
		height: 100%;
		justify-content: center;
		align-items: center;
	}
	.header.is-active {
		height: 100%;
		background: #fff;
	}
	.header.is-active .header__wrap {
		flex-direction: column;
		height: 100%;
	}
}

.menu--header .menu__list,
.header .menu__list {
	display: flex;
	gap: 4rem;
	list-style: none;
	margin: 0;
	padding: 0;
}
.menu--header .menu__link,
.header .menu__link,
.menu--header .menu__list > li > a {
	font-size: 2rem;
	font-weight: 700;
	text-transform: uppercase;
	text-decoration: none;
	transition: opacity 0.4s;
}
.menu--header .menu__link:hover,
.header .menu__link:hover,
.menu--header .menu__list > li > a:hover {
	opacity: 0.6;
}

.burger {
	appearance: none;
	border: 0;
	background: transparent;
	cursor: pointer;
	padding: 0.8rem;
}
.burger__item {
	display: block;
	width: 3.2rem;
	height: 2px;
	background: #000;
	position: relative;
}
.nav-transparent .burger__item {
	background: #fff;
}
.header.is-fixed .burger__item,
.header.is-active .burger__item {
	background: #000;
}
.burger__item::before,
.burger__item::after {
	content: "";
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background: inherit;
}
.burger__item::before {
	top: -0.8rem;
}
.burger__item::after {
	top: 0.8rem;
}

/* --- Footer ---
   wp_nav_menu : .menu--header / .menu--footer et .menu__list sont sur le même <ul> (pas un ul enfant). */
footer ul.menu__list {
	list-style: none;
	margin: 0;
	padding: 0;
}
footer ul.menu__list > li {
	list-style: none;
}
footer ul.menu--header.menu__list {
	display: flex;
	gap: 6rem;
	align-items: center;
	flex-wrap: wrap;
}
footer ul.menu--footer.menu__list {
	display: flex;
	gap: 7rem;
	align-items: center;
	flex-wrap: wrap;
}
footer .menu--header .menu__link,
footer .menu--footer .menu__link,
footer ul.menu--footer.menu__list > li > a {
	font-size: 2rem;
	color: #fff;
	text-decoration: none;
	transition: opacity 0.4s;
}
footer .menu--footer .menu__link,
footer ul.menu--footer.menu__list > li > a {
	font-size: 1.2rem;
}
footer .menu__link:hover,
footer ul.menu--footer.menu__list > li > a:hover {
	opacity: 0.6;
}
.footer-logo-white img {
	/* Logo SVG : fond #023ac4 = même bleu que .bg-primary — pas d’inversion */
	max-width: 14.1rem;
	height: auto;
}
.footer-link {
	text-decoration: none;
}
.footer-link:hover {
	opacity: 0.85;
}
.footer-legal {
	align-items: center;
}

.vaya-credit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.35rem 0.6rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.9);
	text-decoration: none;
	opacity: 0.78;
	transition:
		opacity 0.25s ease,
		transform 0.25s ease,
		background-color 0.25s ease;
}

.vaya-credit:hover,
.vaya-credit:focus-visible {
	opacity: 1;
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.96);
}

.vaya-credit img {
	display: block;
	width: auto;
	height: 0.8rem;
}

@media (max-width: 800px) {
	footer ul.menu--header.menu__list {
		flex-direction: column;
		gap: 1rem;
		align-items: flex-start;
	}
}

/* --- Hero projet --- */
.vaya-hero {
	position: relative;
	overflow: hidden;
	width: 100%;
	aspect-ratio: 4 / 3;
	max-height: 80vh;
	background: #808080;
}
.vaya-hero__title {
	position: absolute;
	top: 11.5rem;
	left: 50%;
	transform: translateX(-50%);
	color: #fff;
	text-transform: uppercase;
	font-size: 3.2rem;
	font-weight: 500;
	z-index: 50;
	margin: 0;
	text-align: center;
	max-width: 90%;
}
.vaya-hero__media {
	position: absolute;
	inset: 0;
}
.vaya-hero__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.hero-gradient-overlays {
	position: absolute;
	inset: 0;
	z-index: 40;
	pointer-events: none;
}
.hero-gradient-overlays::before,
.hero-gradient-overlays::after {
	content: "";
	position: absolute;
	height: 24rem;
	width: 100%;
	left: 0;
}
.hero-gradient-overlays::before {
	top: 0;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent);
}
.hero-gradient-overlays::after {
	bottom: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
}

.meta-hr {
	border: 0;
	border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.meta-label {
	font-weight: 500;
	margin: 0 0 0.4rem;
}
.project-meta-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 1.7rem;
}

/* --- Barre bas projet --- */
.vaya-project-bottombar {
	height: 10.1rem;
	min-height: 8rem;
}
.sticky-bottom {
	position: sticky;
	bottom: 0;
	z-index: 20;
}
.bottombar-archive-icon {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
.bottombar-link {
	text-decoration: none;
	color: inherit;
	max-width: 40%;
}
.bottombar-link:hover {
	opacity: 0.85;
}

/* --- Fiche projet : layout editorial (maquette) --- */
.vaya-project-single--layout-a {
	padding-top: clamp(1.2rem, 2.2vw, 2rem);
	padding-bottom: clamp(2rem, 3.5vw, 3.2rem);
}

.vaya-project-topnav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.2rem;
	margin-bottom: clamp(2rem, 3.2vw, 3rem);
}

.vaya-project-topnav__group {
	display: inline-flex;
	align-items: center;
	gap: 1px;
}

.vaya-project-topnav__tile {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: clamp(3rem, 4vw, 3.8rem);
	padding: 0 1rem;
	background: var(--vaya-color-primary);
	color: #fff;
	text-decoration: none;
	font-size: clamp(0.95rem, 1.1vw, 1.2rem);
	font-weight: 700;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	line-height: 1;
}

.vaya-project-topnav__tile.is-active {
	margin-right: auto;
}

.vaya-project-layout {
	display: grid;
	grid-template-columns: minmax(18rem, 24rem) minmax(0, 1fr);
	gap: clamp(1rem, 2vw, 1.8rem);
	align-items: start;
}

.vaya-project-layout__sidebar {
	font-size: 1.15rem;
	line-height: 1.45;
}

.vaya-project-back {
	margin: 0 0 1rem;
}

.vaya-project-back__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--vaya-color-primary, #023ac4);
	text-decoration: none;
	transition: opacity 0.2s ease;
}

.vaya-project-back__link:hover,
.vaya-project-back__link:focus-visible {
	opacity: 0.7;
}

.vaya-project-back__icon {
	display: block;
	width: 1.6rem;
	height: 1.6rem;
}

.vaya-project-layout__title {
	margin: 0 0 1.2rem;
	font-size: clamp(1.4rem, 1.7vw, 1.9rem);
	text-transform: uppercase;
	letter-spacing: 0.01em;
	line-height: 1.2;
}

.vaya-project-layout__meta {
	list-style: none;
	margin: 0 0 1.4rem;
	padding: 0;
	display: grid;
	gap: 0.8rem;
}

.vaya-project-layout__meta li {
	display: grid;
	gap: 0.12rem;
}

.vaya-project-layout__meta strong {
	font-size: 0.95rem;
	font-weight: 700;
}

.vaya-project-layout__meta span {
	font-size: 0.95rem;
}

.vaya-project-layout__description {
	font-size: 0.92rem;
	line-height: 1.45;
}

.vaya-project-layout__description p {
	margin: 0 0 0.8rem;
}

.vaya-project-layout__visual {
	background: #f2f2f2;
	max-width: 840px;
	width: 100%;
	margin-left: auto;
}

.vaya-project-layout__visual img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}

.vaya-project-gallery {
	display: grid;
	gap: 5px;
	max-height: calc(100vh - 12rem);
	overflow-y: auto;
}

.vaya-project-gallery__item {
	margin: 0;
}

.vaya-project-gallery__item img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}

@media (max-width: 900px) {
	.vaya-project-topnav {
		flex-direction: column;
		align-items: flex-start;
	}

	.vaya-project-topnav__tile.is-active {
		margin-right: 0;
	}

	.vaya-project-layout {
		grid-template-columns: 1fr;
	}

	.vaya-project-gallery {
		max-height: none;
		overflow: visible;
	}
}

/* --- Pages editoriales (Vision / Atelier / Equipe) : structure commune --- */
.vaya-page {
	padding-bottom: clamp(3rem, 6vw, 5rem);
}

.vaya-page__layout {
	display: grid;
	grid-template-columns: minmax(24rem, 34rem) minmax(0, 1fr);
	gap: clamp(1rem, 2vw, 1.8rem);
	align-items: start;
}

.vaya-page__layout--single {
	grid-template-columns: 1fr;
}

.vaya-page__content {
	font-size: clamp(1.9rem, 1.35vw, 2.35rem);
	line-height: 1.38;
}

.vaya-page__content p {
	margin: 0 0 1.2rem;
}

.vaya-page__title {
	margin: 0;
	font-size: clamp(1.4rem, 1.7vw, 1.9rem);
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 1.2;
	text-transform: uppercase;
}

/* Texte sous le H1 (pas l’image dans la colonne média) */
.vaya-page--atelier .vaya-page__content > :where(h1, .wp-block-post-title) + *,
.vaya-page--contact .vaya-page__content > :where(h1, .wp-block-post-title) + *,
.vaya-page--vision .vaya-page__content > :where(h1, .wp-block-post-title) + * {
	padding-top: 32px;
}

/* Colonne image : alignée en haut, sans décalage 32px */
.vaya-page--atelier .vaya-page__media,
.vaya-page--contact .vaya-page__media,
.vaya-page--vision .vaya-page__media {
	margin-top: 0;
	padding-top: 0;
	align-self: start;
}

.vaya-page--atelier .vaya-page__media > :first-child,
.vaya-page--contact .vaya-page__media > :first-child,
.vaya-page--vision .vaya-page__media > :first-child,
.vaya-page--atelier .vaya-page__media .wp-block-post-featured-image,
.vaya-page--contact .vaya-page__media .wp-block-post-featured-image,
.vaya-page--vision .vaya-page__media .wp-block-post-featured-image {
	margin-top: 0;
	padding-top: 0;
}

/* Équipe : zone sous le H1 (mosaïque ou message vide) */
.vaya-page--equipe .vaya-archive--member > .archive-header + * {
	padding-top: 32px;
}

.vaya-page__section-title {
	margin: 0 0 0.8rem;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

/* Tous les H1 suivent la hiérarchie typo de la single projet. */
main h1,
main .wp-block-post-title,
main .wp-block-query-title {
	margin: 0;
	font-size: clamp(1.4rem, 1.7vw, 1.9rem);
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 1.2;
	text-transform: uppercase;
}

.vaya-page--atelier .vaya-page__content {
	font-size: 0.92rem;
	line-height: 1.45;
}

.vaya-page--atelier .vaya-page__content p {
	margin: 0 0 0.8rem;
}

.vaya-page--vision .vaya-page__content {
	font-size: 0.92rem;
	line-height: 1.45;
}

.vaya-page--vision .vaya-page__content p {
	margin: 0 0 0.8rem;
}

.vaya-page__media {
	background: #f2f2f2;
}

.vaya-page__media .wp-block-post-featured-image,
.vaya-page__media .wp-block-image {
	margin: 0;
}

.vaya-page__media img {
	width: 100%;
	display: block;
	object-fit: cover;
}

.vaya-page--vision .vaya-page__media img {
	aspect-ratio: 4 / 3;
}

.vaya-page--atelier .vaya-page__media img {
	aspect-ratio: 840 / 622;
}

.vaya-page--atelier .vaya-page__media {
	max-width: 840px;
	width: 100%;
	margin-left: auto;
}

.vaya-page--atelier .vaya-page__layout {
	grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
}

.vaya-vision-topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.2rem;
	margin-bottom: clamp(3rem, 8vw, 6rem);
}

/* Topbar déplacée dans main (#vaya-header-panel) */
.vaya-main-topbar {
	margin-bottom: clamp(1rem, 2.2vw, 2rem);
}

.vaya-main-topbar .vaya-vision-topbar {
	margin-bottom: 0;
}

.vaya-vision-topbar__links {
	display: inline-flex;
	align-items: center;
	gap: 1px;
}

.vaya-vision-topbar__tile {
	margin: 0;
}

.vaya-vision-topbar__tile a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: clamp(2.88rem, 3.52vw, 3.36rem);
	padding: 0.48rem 1rem;
	background: var(--vaya-color-primary);
	color: #fff;
	text-decoration: none;
	font-size: clamp(1.05rem, 1.2vw, 1.2rem);
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.vaya-main-topbar .vaya-vision-topbar__tile.is-current {
	margin-right: auto;
}

.vaya-main-topbar .header__topbar.is-compact {
	justify-content: flex-end;
}

/* Onglets carrés bleus (topbar dans main) */
.vaya-main-topbar .vaya-vision-topbar:not(.vaya-vision-topbar--minimal) {
	justify-content: flex-end;
}

.vaya-main-topbar .vaya-vision-topbar:not(.vaya-vision-topbar--minimal) .vaya-vision-topbar__tile a {
	width: var(--vaya-tab-square);
	height: var(--vaya-tab-height);
	min-width: var(--vaya-tab-square);
	min-height: var(--vaya-tab-height);
	max-width: var(--vaya-tab-square);
	max-height: var(--vaya-tab-height);
	padding: 0;
	font-size: 0.84rem;
	font-weight: 700;
	background: var(--vaya-color-primary);
	color: #fff;
	border: none;
}

.vaya-vision-topbar__tile.is-current a {
	min-width: clamp(7.5rem, 8vw, 9.2rem);
}

/* Topbar dans le header : pas de marge “page”, l’espacement est géré par le header */
.header--v2 .vaya-vision-topbar {
	margin-bottom: 0;
}

/* Onglet actif à gauche : le groupe des autres onglets reste collé à droite */
.header--v2 .vaya-vision-topbar__tile.is-current {
	margin-right: auto;
}

.header--v2 .vaya-vision-topbar__tile.is-current a {
	min-width: 0;
}

.vaya-main-topbar .vaya-vision-topbar__tile.is-current a {
	min-width: 0;
}

/* Navigation secondaire : style minimal (aucun état « actif » distinct) */
.vaya-vision-topbar--minimal {
	justify-content: flex-end;
	gap: clamp(1.45rem, 3vw, 2.6rem);
	margin-bottom: clamp(2rem, 5vw, 3.5rem);
}

.vaya-vision-topbar--minimal .vaya-vision-topbar__links {
	gap: clamp(1.15rem, 2.5vw, 2.15rem);
	flex-wrap: wrap;
	justify-content: flex-end;
}

.vaya-vision-topbar--minimal .vaya-vision-topbar__tile a {
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
	width: auto;
	min-height: var(--vaya-tab-height);
	height: var(--vaya-tab-height);
	max-height: var(--vaya-tab-height);
	max-width: none;
	padding: 0 var(--vaya-nav-tab-minimal-px);
	background: transparent;
	color: rgba(26, 26, 26, 0.88);
	border: 1px solid rgba(2, 58, 196, 0.22);
	border: 1px solid color-mix(in srgb, var(--vaya-color-primary) 22%, transparent);
	font-size: var(--vaya-nav-tab-minimal-fs);
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.08em;
	transition:
		color 0.25s ease,
		border-color 0.25s ease,
		background-color 0.25s ease;
}

.vaya-main-topbar .vaya-vision-topbar--minimal .vaya-vision-topbar__tile a {
	width: auto;
	min-width: 0;
	min-height: var(--vaya-tab-height);
	height: var(--vaya-tab-height);
	max-height: var(--vaya-tab-height);
	max-width: none;
	padding: 0 var(--vaya-nav-tab-minimal-px);
	font-size: var(--vaya-nav-tab-minimal-fs);
	background: transparent;
	color: rgba(26, 26, 26, 0.88);
	border: 1px solid rgba(2, 58, 196, 0.22);
	border: 1px solid color-mix(in srgb, var(--vaya-color-primary) 22%, transparent);
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.08em;
}

.vaya-vision-topbar--minimal .vaya-vision-topbar__tile a:hover,
.vaya-vision-topbar--minimal .vaya-vision-topbar__tile a:focus-visible {
	background: rgba(2, 58, 196, 0.06);
	background: color-mix(in srgb, var(--vaya-color-primary) 6%, transparent);
	border-color: rgba(2, 58, 196, 0.38);
	border-color: color-mix(in srgb, var(--vaya-color-primary) 38%, transparent);
	color: var(--vaya-color-primary);
}

.header--v2 .vaya-vision-topbar--minimal {
	margin-bottom: clamp(1.2rem, 3vw, 2rem);
}

.vaya-page--contact .vaya-page__media img {
	aspect-ratio: 4 / 3;
}

.vaya-page--contact .vaya-page__media {
	max-width: 840px;
	width: 100%;
	margin-left: auto;
}

.vaya-page--contact .vaya-page__layout {
	grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
	align-items: start;
}

/* Infos contact : 15px (priorité sur .vaya-page__content clamp + presets blocs WP) */
body.vaya-page-contact .vaya-page__contact-coords,
body.vaya-page-contact .vaya-page--contact .vaya-page__contact-coords,
.vaya-page--contact .vaya-page__contact-coords {
	font-size: 15px;
	line-height: 1.4;
}

body.vaya-page-contact .vaya-page__contact-coords :where(p, a, li, span, .wp-block-paragraph),
.vaya-page--contact .vaya-page__contact-coords :where(p, a, li, span, .wp-block-paragraph) {
	font-size: 15px;
	line-height: 1.4;
}

/* Classes typo éditeur (has-*-font-size) sur les paragraphes contact */
body.vaya-page-contact .vaya-page__contact-coords [class*="font-size"],
.vaya-page--contact .vaya-page__contact-coords [class*="font-size"] {
	font-size: 15px !important;
}

.vaya-page--contact .vaya-page__content {
	text-align: left;
	justify-self: start;
	max-width: 100%;
}

.vaya-page--contact .vaya-page__content > .vaya-page__contact-coords,
.vaya-page--contact .vaya-page__content .vaya-page__contact-coords {
	margin-top: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 100%;
	gap: 0.28rem;
}

.vaya-page--contact .vaya-page__content p {
	margin: 0;
	text-align: left;
}

.vaya-page--contact .vaya-page__contact-coords p {
	margin: 0;
}

.vaya-page--contact .vaya-page__contact-coords a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 0.1em;
}

.vaya-page--equipe .vaya-archive--member {
	padding-top: 0;
}

.vaya-atelier-contact-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.2rem 1.6rem;
}

.vaya-atelier-contact-grid p {
	margin: 0;
}

.vaya-atelier-contact-grid a {
	color: inherit;
	text-decoration: underline;
}

@media (max-width: 900px) {
	.vaya-page__layout {
		grid-template-columns: 1fr;
	}

	.vaya-page--contact .vaya-page__layout {
		grid-template-columns: 1fr;
	}

	.vaya-page__content {
		font-size: 1.95rem;
	}

	body.vaya-page-contact .vaya-page__contact-coords,
	body.vaya-page-contact .vaya-page__contact-coords :where(p, a, .wp-block-paragraph),
	.vaya-page--contact .vaya-page__contact-coords,
	.vaya-page--contact .vaya-page__contact-coords :where(p, a, .wp-block-paragraph) {
		font-size: 15px;
	}

	.vaya-vision-topbar {
		flex-direction: column;
		align-items: flex-start;
	}

	.vaya-main-topbar .vaya-vision-topbar {
		flex-wrap: wrap;
		row-gap: 0.6rem;
	}

	.vaya-main-topbar .vaya-vision-topbar__tile.is-current {
		margin-right: 0;
	}

	/* Carrés bleus — mobile : hauteur +20 % */
	.vaya-main-topbar .vaya-vision-topbar:not(.vaya-vision-topbar--minimal) .vaya-vision-topbar__tile a {
		width: var(--vaya-tab-square);
		min-width: var(--vaya-tab-square);
		min-height: var(--vaya-tab-height);
		max-width: var(--vaya-tab-square);
		padding: 0;
		font-size: 0.75rem;
	}

	.vaya-main-topbar .vaya-vision-topbar--minimal .vaya-vision-topbar__tile a {
		width: auto;
		min-height: var(--vaya-tab-height);
		height: var(--vaya-tab-height);
		padding: 0 var(--vaya-nav-tab-minimal-px);
	}
}

/* --- Membre / Atelier : carte = même bloc que projets (carré + overlay) ; fiche : photo carrée --- */
.vaya-archive--member .vaya-member-grid .vaya-project-mosaic__link {
	aspect-ratio: 1 / 1;
	width: 100%;
}

.vaya-members-summary__hero {
	position: relative;
}

.vaya-members-summary__hero .vaya-members-toggle-icon {
	position: absolute;
	top: 1.2rem;
	right: 1.2rem;
	z-index: 4;
}

/* Liste ACF : même carte carrée que projets */
.vaya-members-acf-grid .vaya-project-mosaic__link {
	aspect-ratio: 1 / 1;
	width: 100%;
}

.vaya-member-photo--square {
	aspect-ratio: 1 / 1;
	width: 100%;
	max-width: 100%;
	overflow: hidden;
}

.vaya-member-photo--square .vaya-member-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* --- Membre --- */
.vaya-member-columns {
	display: flex;
	flex-wrap: wrap;
	gap: 7rem;
	align-items: flex-start;
}

.vaya-member-single--cv {
	padding-top: clamp(2rem, 4vw, 3.6rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
}

.vaya-member-cv {
	max-width: 110rem;
}

.vaya-member-cv__header {
	margin-bottom: 1.8rem;
}

.vaya-member-cv__name {
	margin: 0;
	font-size: clamp(2rem, 2.2vw, 2.8rem);
	font-weight: 700;
	line-height: 1.2;
}

.vaya-member-cv__content {
	font-size: clamp(1.55rem, 1.35vw, 1.9rem);
	line-height: 1.5;
}

.vaya-member-cv__content h2,
.vaya-member-cv__content h3 {
	margin: 2.2rem 0 1rem;
	font-size: clamp(1.7rem, 1.5vw, 2.1rem);
	line-height: 1.25;
}

.vaya-member-cv__content p {
	margin: 0 0 1rem;
}

.vaya-member-cv__content ul {
	margin: 0 0 1.4rem 1.4rem;
	padding: 0;
}

.vaya-member-cv__content li {
	margin-bottom: 0.4rem;
}

.vaya-member-cv__back {
	margin: 2rem 0 0;
}

.vaya-member-cv__back a {
	text-decoration: none;
	color: inherit;
	font-size: 1.35rem;
}
.columns-wide {
	max-width: 120rem;
	margin: 0 auto;
}
.col-38 {
	flex: 0 0 38%;
	max-width: 38%;
}
.col-62 {
	flex: 1 1 0;
	min-width: 28rem;
}
@media (max-width: 800px) {
	.col-38,
	.col-62 {
		flex: 1 1 100%;
		max-width: 100%;
	}
}

/* --- Contenu --- */
.text-content {
	line-height: 1.56;
}
.text-content p {
	margin: 0 0 1em;
}
.text-content img {
	max-width: 100%;
	height: auto;
}

/* WordPress core */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	word-wrap: normal !important;
}

.pagination {
	display: flex;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.pagination a,
.pagination span {
	padding: 0.5rem 1rem;
	text-decoration: none;
}

/* Cartes archive */
.vaya-card-project__link {
	text-decoration: none;
	color: inherit;
	display: block;
}
.vaya-card-project__link:hover .vaya-card-project__img {
	transform: scale(1.02);
	transition: transform 0.4s;
}

/* --- Blocs ACF (Vaya) --- */
.predefined-bg-lightgrey {
	background-color: #f8f8f8;
}
.mb-24 {
	margin-bottom: 6rem;
}
.text-main {
	color: #000;
}
.pt-gutter {
	padding-top: 3.2rem;
}
.aspect-square {
	aspect-ratio: 1 / 1;
}
.overflow-hidden {
	overflow: hidden;
}

/* Navigation entre membres (bloc ACF members-navigation, logique Vaya) */
.vaya-members-nav__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 11rem;
	gap: 2rem;
}
.vaya-members-nav__item {
	display: flex;
	align-items: center;
	gap: 2rem;
	text-decoration: none;
	color: inherit;
	flex: 1 1 0;
	min-width: 0;
}
.vaya-members-nav__text span {
	display: block;
}
.vaya-members-nav__avatar {
	display: block;
	width: 7.6rem;
	height: 7.6rem;
	border-radius: 9999px;
	flex-shrink: 0;
}
.vaya-members-nav__plus {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 6rem;
	height: 6rem;
	background: rgb(0 0 0 / 0.05);
	flex-shrink: 0;
}
.vaya-members-nav__plus svg {
	display: block;
}
.vaya-members-nav__center {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	width: 30rem;
	max-width: 100%;
	min-height: 11rem;
	padding: 2rem 3rem;
	border-left: 1px solid #f2f2f2;
	border-right: 1px solid #f2f2f2;
	text-decoration: underline;
	color: inherit;
	font-size: 1.8rem;
	line-height: 1.2;
}
@media (max-width: 800px) {
	.vaya-members-nav__inner {
		flex-direction: column;
		align-items: stretch;
		min-height: 0;
		gap: 0;
	}
	.vaya-members-nav__item {
		justify-content: space-between;
		padding: 2rem 0;
	}
	.vaya-members-nav__item--first {
		order: 1;
	}
	.vaya-members-nav__item--second {
		order: 2;
	}
	.vaya-members-nav__center {
		order: 3;
		width: 100%;
		min-height: 0;
		border-left: 0;
		border-right: 0;
		border-top: 1px solid #f2f2f2;
		border-bottom: 1px solid #f2f2f2;
		margin-bottom: 3rem;
		padding: 3rem;
	}
}

/* Grille Atelier / liste membres : 2 colonnes (maquette Vaya) */
.vaya-members-acf-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 5px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.vaya-members-acf-item {
	min-width: 0;
}
@media (max-width: 600px) {
	.vaya-members-acf-grid {
		grid-template-columns: 1fr;
	}
}

/*
 * Archive équipe : grille ⅔ de la largeur contenu (projet = 100 % du main),
 * POSTULER centré sur la croisée des 4 cases, cadre blanc = épaisseur du gap.
 */
.vaya-member-mosaic-wrap {
	--vaya-member-grid-gap: 5px;
	position: relative;
	width: 100%;
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

/* Archive CPT membre (/atelier/) : 2 colonnes */
.vaya-archive--member .vaya-member-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--vaya-member-grid-gap);
	list-style: none;
	margin: 0;
	padding: 0;
}
.vaya-archive--member .vaya-member-grid > li {
	min-width: 0;
}

.vaya-member-card {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
}

.vaya-member-card__front {
	border: 0;
	padding: 0;
	cursor: pointer;
	text-align: left;
}

.vaya-member-card__front.vaya-project-mosaic__link {
	width: 100%;
	height: 100%;
}

.vaya-member-card__back {
	position: absolute;
	inset: 0;
	background: #fff;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, 0.08);
}

.vaya-member-card__back-inner {
	padding: clamp(0.65rem, 1vw, 0.95rem);
	height: 100%;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	min-height: 0;
}

.vaya-member-card__back h3 {
	margin: 0 0 0.25rem;
	font-size: clamp(0.72rem, 0.78vw, 0.86rem);
	line-height: 1.15;
	text-transform: uppercase;
	color: var(--vaya-color-primary);
	text-shadow: none;
}

/* Force le style du titre CV (évite l’héritage de styles mosaïque/éditeur). */
.vaya-archive--member .vaya-member-card.is-open .vaya-member-card__back h3,
.vaya-archive--member .vaya-member-card__back h3 {
	color: var(--vaya-color-primary) !important;
	text-shadow: none !important;
}

.vaya-archive--member .vaya-member-card.is-open .vaya-project-mosaic__title {
	color: var(--vaya-color-primary) !important;
	text-shadow: none !important;
}

.vaya-member-card__cv {
	flex: 1 1 auto;
	min-height: 0;
	overflow: auto;
	font-size: clamp(0.62rem, 0.72vw, 0.78rem);
	line-height: 1.22;
	word-break: break-word;
	hyphens: auto;
}

.vaya-member-card__cv p {
	margin: 0 0 0.35rem;
}

.vaya-member-card__cv ul {
	margin: 0 0 0.45rem 0.95rem;
	padding: 0;
}

.vaya-member-card__cv li {
	margin-bottom: 0.12rem;
}

.vaya-member-card__cv h4 {
	margin: 0.35rem 0 0.2rem;
	font-size: clamp(0.66rem, 0.74vw, 0.82rem);
	line-height: 1.15;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

/* Colonne de droite : titre + méta alignés à droite (grille 2 colonnes) */
@media (min-width: 601px) {
	.vaya-archive--member .vaya-member-grid > li:nth-child(2n) .vaya-project-mosaic__caption {
		align-items: flex-end;
		text-align: right;
	}
	.vaya-archive--member .vaya-member-grid > li:nth-child(2n) .vaya-project-mosaic__title,
	.vaya-archive--member .vaya-member-grid > li:nth-child(2n) .vaya-project-mosaic__meta {
		text-align: right;
		width: 100%;
		max-width: 100%;
	}
}

@media (max-width: 600px) {
	.vaya-member-mosaic-wrap {
		max-width: 100%;
	}
	.vaya-archive--member .vaya-member-grid {
		grid-template-columns: 1fr;
	}
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--cta .vaya-project-mosaic__link {
	background: var(--wp--preset--color--accent, #023ac4);
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--cta .vaya-project-mosaic__caption {
	align-items: center;
	justify-content: center;
	padding: clamp(1rem, 2vw, 1.6rem);
	text-align: center;
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--cta .vaya-project-mosaic__title {
	display: block;
	width: 100%;
	margin: 0;
	text-align: center;
	font-size: clamp(1.2rem, 2vw, 1.6rem);
	letter-spacing: 0.05em;
	transform: none;
	text-shadow: none;
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--cta .vaya-project-mosaic__link::after {
	background: rgba(0, 0, 0, 0.08);
	opacity: 1;
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--cta .vaya-project-mosaic__link:hover::after,
.vaya-archive--member .vaya-member-grid .vaya-card-member--cta .vaya-project-mosaic__link:focus-visible::after {
	background: rgba(0, 0, 0, 0.18);
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--about .vaya-project-mosaic__link {
	background: var(--wp--preset--color--accent, #023ac4);
	color: #fff;
	padding: clamp(1.1rem, 1.8vw, 1.6rem);
	overflow: auto;
}

.vaya-archive--member .vaya-member-grid .vaya-card-member--about .vaya-project-mosaic__link::after {
	content: none;
}

.vaya-member-about-card {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.vaya-member-about-card h2 {
	margin: 0;
	font-size: clamp(1rem, 1.2vw, 1.25rem);
	line-height: 1.2;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.vaya-member-about-card p {
	margin: 0;
	font-size: clamp(0.82rem, 0.9vw, 0.95rem);
	line-height: 1.35;
}

/* Bandeau « POSTULER » — archive vide (pas de grille) */
.vaya-atelier-cta--fallback {
	width: 100%;
	box-sizing: border-box;
	margin-top: clamp(3rem, 8vw, 6rem);
}

.vaya-atelier-cta__inner {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-top: clamp(1.25rem, 2.5vw, 2rem);
	padding-bottom: clamp(1.25rem, 2.5vw, 2rem);
}

.vaya-atelier-cta__link {
	display: inline-block;
	font-size: clamp(0.875rem, 2vw, 1.375rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	color: #fff;
	transition: opacity 0.2s ease;
}

.vaya-atelier-cta__link:hover,
.vaya-atelier-cta__link:focus-visible {
	opacity: 0.88;
	color: #fff;
}

.vaya-members-summary {
	cursor: pointer;
	list-style: none;
}
.vaya-members-summary::-webkit-details-marker {
	display: none;
}
.vya-minus {
	display: none;
}
.vaya-members-details[open] .vya-plus {
	display: none;
}
.vaya-members-details[open] .vya-minus {
	display: inline;
}

.vaya-members-toggle-icon {
	width: 6rem;
	height: 6rem;
	background: rgb(0 0 0 / 0.05);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
	line-height: 1;
	flex-shrink: 0;
}
.vaya-members-details[open] .vaya-members-toggle-icon {
	background: rgb(0 0 0 / 0.1);
}

.wrap-xl {
	max-width: 160rem;
	margin-left: auto;
	margin-right: auto;
}
.wrap-md {
	max-width: 100rem;
	margin-left: auto;
	margin-right: auto;
}
.wrap-sm {
	max-width: 90rem;
	margin-left: auto;
	margin-right: auto;
}
.wrap-xs {
	max-width: 72rem;
	margin-left: auto;
	margin-right: auto;
}
.wrap-xxs {
	max-width: 60rem;
	margin-left: auto;
	margin-right: auto;
}

/* --- Bloc ACF project-slider (plein écran) --- */
.vaya-project-slider {
	position: relative;
	height: 100vh;
	min-height: 42rem;
	overflow: hidden;
}
.vaya-project-slider__backgrounds {
	list-style: none;
	margin: 0;
	padding: 0;
}
.vaya-project-slider__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0;
	transition: opacity 0.45s ease;
	z-index: 1;
}
.vaya-project-slider__bg[data-index="0"] {
	opacity: 1;
}
.vaya-project-slider__bg--mobile {
	display: none;
}
@media (max-width: 800px) {
	.vaya-project-slider__bg--desktop {
		display: none;
	}
	.vaya-project-slider__bg--mobile {
		display: block;
	}
}
.vaya-project-slider__cards-wrap {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 4.3rem;
	z-index: 60;
	width: 100%;
	max-width: 144rem;
	pointer-events: none;
}
.vaya-project-slider__cards-wrap a {
	pointer-events: auto;
}
.vaya-project-slider__cards {
	list-style: none;
	margin: 0;
	padding: 0;
	position: relative;
	height: 30rem;
	width: 100%;
}
.vaya-project-slider__card {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	top: 0;
	z-index: 1;
	display: flex;
	align-items: flex-end;
	opacity: 0;
	transition: opacity 0.45s ease;
}
.vaya-project-slider__card[data-index="0"] {
	opacity: 1;
}
.vaya-project-slider__card-link {
	display: flex;
	flex-direction: column;
	max-width: 42.6rem;
	width: 100%;
	text-decoration: none;
	color: inherit;
}
.vaya-project-slider__title {
	text-transform: uppercase;
	font-size: 2rem;
	margin: 0 0 1rem;
	color: #fff;
	font-weight: 500;
}
.text-content--slider {
	color: #fff;
}
.vaya-project-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 60;
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 1rem;
}
.vaya-project-slider__nav--prev {
	left: 3rem;
}
.vaya-project-slider__nav--next {
	right: 3rem;
}
.vaya-acf-empty {
	padding: 2rem;
	background: #f5f5f5;
	border: 1px dashed #ccc;
}

/* =============================================================================
   Design v2 — en-tête (logo carré, onglets carrés, réseaux à droite) + archive projets mosaïque
   ============================================================================= */

/* Header v2 : logo + barre carrée + réseaux */

.header--v2 .header__brand {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	height: var(--vaya-tab-height);
	line-height: 0;
}

/* Logo plein par défaut ; logo compact uniquement au scroll (.is-scrolled) */
.header--v2 .header__logo {
	align-items: center;
	justify-content: center;
	height: var(--vaya-tab-height);
	line-height: 0;
}

.header--v2 .header__logo-full {
	display: inline-flex;
}

.header--v2 .header__logo-short {
	display: none;
}

.header--v2.is-scrolled .header__logo-full {
	display: none;
}

.header--v2.is-scrolled .header__logo-short {
	display: inline-flex;
}

/* Le header est en overlay fixe : on laisse passer les clics sauf sur logo + réseaux. */
.header--v2 {
	pointer-events: none;
}

.header--v2 .header__logo,
.header--v2 .header__brand,
.header--v2 .header__socials--v2,
.header--v2 .header__socials--v2 .social-icon {
	pointer-events: auto;
}

/* Logo = même gabarit carré que les onglets nav (--vaya-tab-height) */
.header--v2 .header__logo-full img,
.header--v2 .header__logo-short img {
	display: block;
	width: var(--vaya-tab-height);
	height: var(--vaya-tab-height);
	min-width: var(--vaya-tab-height);
	min-height: var(--vaya-tab-height);
	max-width: var(--vaya-tab-height);
	max-height: var(--vaya-tab-height);
	object-fit: contain;
	object-position: center;
}

/* Header v2 — rangée logo / burger / réseaux */
.header--v2 .header__row-v2 {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	gap: var(--vaya-header-wrap-gap);
	width: 100%;
	min-width: 0;
}

.header--v2 .burger--v2-tab {
	display: none;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: var(--vaya-tab-square);
	height: var(--vaya-tab-height);
	min-width: var(--vaya-tab-square);
	min-height: var(--vaya-tab-height);
	padding: 0;
	background: var(--vaya-color-primary);
	border-radius: 0;
}

.header--v2 .burger--v2-tab .burger__item {
	width: 1.75rem;
	background: #fff;
}

.header--v2 .burger--v2-tab .burger__item::before,
.header--v2 .burger--v2-tab .burger__item::after {
	background: #fff;
}

.header--v2 .header__mobile-nav {
	display: none;
}

@media (min-width: 801px) {
	.header--v2 .header__wrap--v2 {
		flex-direction: row;
		align-items: center;
		gap: var(--vaya-header-wrap-gap);
	}
	/* #vaya-header-panel — bandeau nav + réseaux */
	.header--v2 .header__content--v2 {
		display: flex !important;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		flex: 1;
		min-width: 0;
		position: static;
		height: var(--vaya-tab-height);
		min-height: var(--vaya-tab-height);
		max-height: var(--vaya-tab-height);
		padding: 0;
		background: transparent;
		box-sizing: border-box;
		gap: clamp(0.8rem, 1.6vw, 1.6rem);
	}

	.header--v2 .header__topbar {
		flex: 1 1 auto;
		min-width: 0;
		margin: 0;
		margin-bottom: 0;
	}

	/* Si aucun onglet “actif” n’est détecté : on garde uniquement le groupe à droite */
	.header--v2 .header__topbar.is-compact {
		justify-content: flex-end;
	}

	.header--v2 .vaya-vision-topbar__tile a {
		width: var(--vaya-tab-square);
		height: var(--vaya-tab-height);
		min-width: var(--vaya-tab-square);
		min-height: var(--vaya-tab-height);
		max-width: var(--vaya-tab-square);
		max-height: var(--vaya-tab-height);
		padding: 0;
		font-size: 1.2rem;
		background: var(--vaya-color-primary);
		color: #fff;
	}

	/* Réseaux : 2 carrés ; hauteur totale = même que les onglets (75 % de la nav) */
	.header--v2 .header__socials--v2 {
		--vaya-social-stack-gap: 0.2rem;
		--vaya-social-cell: calc((var(--vaya-tab-height) - var(--vaya-social-stack-gap)) / 2);
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: var(--vaya-social-stack-gap);
		margin-left: auto;
		flex-shrink: 0;
		width: var(--vaya-social-cell);
		height: var(--vaya-tab-height);
		max-height: var(--vaya-tab-height);
		box-sizing: border-box;
	}
	.header--v2 .header__socials--v2 .social-icon {
		display: flex;
		align-items: center;
		justify-content: center;
		flex-shrink: 0;
		width: var(--vaya-social-cell);
		height: var(--vaya-social-cell);
		min-width: var(--vaya-social-cell);
		min-height: var(--vaya-social-cell);
		background: #e8e8e8;
		color: #000;
		text-decoration: none;
		box-sizing: border-box;
		transition: opacity 0.2s ease, background 0.2s ease;
	}
	.header--v2 .header__socials--v2 .social-icon:hover {
		opacity: 0.88;
	}
	.header--v2 .header__socials--v2 .social-icon svg {
		width: 42%;
		height: 42%;
		max-width: 2.2rem;
		max-height: 2.2rem;
	}
}


/* --- Archive projets : nav dans le rail `main` ; mosaïque en pleine largeur --- */
body.vaya-archive-project,
body.post-type-archive-project {
	--vaya-project-archive-gap: 120px;
	--vaya-mosaic-gap: 120px;
	--vaya-content-max: calc(90vw - 2 * var(--vaya-content-side-offset));
	overflow-x: clip;
}

body.vaya-archive-project main.vaya-archive-project-layout,
body.post-type-archive-project main.vaya-archive-project-layout,
body.vaya-archive-project main,
body.post-type-archive-project main {
	width: var(--vaya-content-max);
	max-width: var(--vaya-content-max);
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

body.vaya-archive-project .vaya-main-topbar {
	width: 100%;
	max-width: 100%;
	margin-right: var(--vaya-mosaic-gap);
	box-sizing: border-box;
}

body.vaya-archive-project main.vaya-archive-project-layout {
	padding-bottom: clamp(3rem, 6vw, 5rem);
}

/* Grille masonry : breakout pleine largeur (nav dans `main`, listing en pleine largeur) */
body.vaya-archive-project .vaya-archive-project-mosaic-outer.alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	box-sizing: border-box;
}

body.vaya-archive-project .vaya-archive-project-mosaic-outer,
body.vaya-archive-project .wp-block-vaya-project-archive,
body.vaya-archive-project .vaya-archive-project-block {
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
	box-sizing: border-box;
}

/* Archive projets — filet de secours (voir project-archive.css) */
body.vaya-archive-project .vaya-autogrid__projects-area,
body.post-type-archive-project .vaya-autogrid__projects-area {
	display: flex !important;
	flex-flow: row nowrap !important;
	align-items: flex-start !important;
	width: 100% !important;
	max-width: 100% !important;
}

body.vaya-archive-project .vaya-autogrid__column,
body.post-type-archive-project .vaya-autogrid__column {
	flex: 1 1 0 !important;
	min-width: 0 !important;
	width: 0 !important;
	box-sizing: border-box;
}

body.vaya-archive-project .vaya-autogrid__image,
body.post-type-archive-project .vaya-autogrid__image {
	width: 100% !important;
	height: auto !important;
	display: block !important;
}

.vaya-archive-project-shell {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.vaya-archive--project-v2 {
	padding-top: 0;
}

.vaya-archive--project-v2 .archive-header {
	display: none;
}

/* Archive projets : masonry — voir assets/css/project-archive.css */

.vaya-project-mosaic__link {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	background: #f4f3f0;
}

/* Overlay bleu primaire — animation d’entrée au hover / focus */
.vaya-project-mosaic__link::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-project-mosaic__link:hover::after,
.vaya-project-mosaic__link:focus-visible::after,
.vaya-members-summary:hover .vaya-project-mosaic__link::after,
.vaya-members-summary:focus-within .vaya-project-mosaic__link::after {
	background: rgba(2, 58, 196, 0.42);
	opacity: 1;
}

.vaya-project-mosaic__media {
	display: block;
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: relative;
	z-index: 0;
}

.vaya-project-mosaic__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.55s cubic-bezier(0.33, 1, 0.68, 1);
	will-change: transform;
}

.vaya-project-mosaic__caption {
	position: absolute;
	inset: 0;
	z-index: 2;
	padding: 1.2rem 1.6rem;
	background: none;
	color: #fff;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: stretch;
	gap: 0;
	pointer-events: none;
}

/* Seul le titre visible par défaut (méta repliée en max-height:0) */
.vaya-project-mosaic__title {
	font-size: 1.4rem;
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.2;
	text-shadow: 0 1px 10px rgba(0, 0, 0, 0.55);
	flex-shrink: 0;
	transition:
		transform 0.45s cubic-bezier(0.33, 1, 0.68, 1),
		text-shadow 0.4s ease;
}

.vaya-project-mosaic__link:hover .vaya-project-mosaic__img,
.vaya-project-mosaic__link:focus-visible .vaya-project-mosaic__img,
.vaya-members-summary:hover .vaya-project-mosaic__link .vaya-project-mosaic__img,
.vaya-members-summary:focus-within .vaya-project-mosaic__link .vaya-project-mosaic__img {
	transform: scale(1.05);
}

/* Titre : léger relevé au survol */
.vaya-project-mosaic__link:hover .vaya-project-mosaic__title,
.vaya-project-mosaic__link:focus-visible .vaya-project-mosaic__title,
.vaya-members-summary:hover .vaya-project-mosaic__link .vaya-project-mosaic__title,
.vaya-members-summary:focus-within .vaya-project-mosaic__link .vaya-project-mosaic__title {
	transform: translateY(-3px);
	text-shadow: 0 2px 20px rgba(0, 0, 0, 0.45);
}

/* Méta : révélé par hauteur + fondu + glissement (pas de display:none → transitions OK) */
.vaya-project-mosaic__meta {
	max-height: 0;
	margin: 0;
	padding: 0;
	overflow: hidden;
	opacity: 0;
	transform: translateY(0.6rem);
	font-size: calc(1.2rem * 0.8);
	line-height: 1.35;
	transition:
		opacity 0.4s cubic-bezier(0.33, 1, 0.68, 1) 0.06s,
		transform 0.45s cubic-bezier(0.33, 1, 0.68, 1) 0.05s,
		max-height 0.45s cubic-bezier(0.33, 1, 0.68, 1),
		margin 0.35s ease;
}

.vaya-project-mosaic__link:hover .vaya-project-mosaic__meta,
.vaya-project-mosaic__link:focus-visible .vaya-project-mosaic__meta,
.vaya-members-summary:hover .vaya-project-mosaic__link .vaya-project-mosaic__meta,
.vaya-members-summary:focus-within .vaya-project-mosaic__link .vaya-project-mosaic__meta {
	opacity: 1;
	max-height: 6rem;
	transform: translateY(0);
	margin-top: 0.35rem;
}

@media (prefers-reduced-motion: reduce) {
	.vaya-project-mosaic__link::after,
	.vaya-project-mosaic__img,
	.vaya-project-mosaic__title,
	.vaya-project-mosaic__meta {
		transition-duration: 0.01ms;
	}
	.vaya-project-mosaic__link:hover .vaya-project-mosaic__img,
	.vaya-project-mosaic__link:focus-visible .vaya-project-mosaic__img,
	.vaya-members-summary:hover .vaya-project-mosaic__link .vaya-project-mosaic__img,
	.vaya-members-summary:focus-within .vaya-project-mosaic__link .vaya-project-mosaic__img {
		transform: none;
	}
	.vaya-project-mosaic__link:hover .vaya-project-mosaic__title,
	.vaya-project-mosaic__link:focus-visible .vaya-project-mosaic__title,
	.vaya-members-summary:hover .vaya-project-mosaic__link .vaya-project-mosaic__title,
	.vaya-members-summary:focus-within .vaya-project-mosaic__link .vaya-project-mosaic__title {
		transform: none;
	}
}

@media (max-width: 800px) {
	body.vaya-archive-project main,
	body.vaya-archive-project main.vaya-archive-project-layout {
		padding-top: calc(var(--vaya-logo-unit) + max(2.4rem, var(--vaya-gap-nav-to-grid)));
	}
}

/* =============================================================================
   Accueil — grille 2×2 (doublon de home-front.css pour fiabilité au déploiement)
   ============================================================================= */
body.vaya-front-home main:has(.vaya-home-grid),
body.home main:has(.vaya-home-grid) {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	min-height: 100vh;
	min-height: 100dvh;
	box-sizing: border-box;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

body.vaya-front-home main:has(.vaya-home-grid) .wp-block-post-content,
body.home main:has(.vaya-home-grid) .wp-block-post-content {
	width: 100%;
	margin: 0;
}

.vaya-home-grid__tile a {
	background: var(--vaya-color-primary, #023ac4);
	color: #fff;
	border: 1px solid var(--vaya-color-primary, #023ac4);
}

.vaya-home-grid__link::after {
	background: rgba(2, 58, 196, 0.42);
	opacity: 0;
}

@media (min-width: 781px) and (max-width: 1100px) {
	body.vaya-front-home main:has(.vaya-home-grid),
	body.home main:has(.vaya-home-grid) {
		width: 100%;
		max-width: 100%;
	}

	body.vaya-front-home main:has(.vaya-home-grid) .wp-block-post-content,
	body.home main:has(.vaya-home-grid) .wp-block-post-content {
		display: flex;
		justify-content: center;
	}

	.vaya-home-grid {
		width: min(64.4rem, calc(100vw - 4rem));
		max-width: 100%;
	}
}

/* =============================================================================
   Tablette (801–1100px) — desktop (>1100px) inchangé
   ============================================================================= */
@media (min-width: 801px) and (max-width: 1100px) {
	.vaya-page--atelier .vaya-page__layout {
		display: flex;
		flex-direction: column;
		gap: clamp(1.25rem, 3vw, 2rem);
	}

	.vaya-page--contact .vaya-page__layout {
		display: grid;
		grid-template-columns: minmax(0, 1fr);
		gap: clamp(1.25rem, 3vw, 2rem);
	}

	.vaya-page--atelier .vaya-page__media,
	.vaya-page--contact .vaya-page__media {
		order: 1;
		max-width: 100%;
		width: 100%;
		margin-left: 0;
	}

	.vaya-page--atelier .vaya-page__content,
	.vaya-page--contact .vaya-page__content {
		order: 2;
	}
}

/* =============================================================================
   Mobile (≤800px)
   ============================================================================= */
@media (max-width: 800px) {
	:root {
		--vaya-content-side-offset: 1.25rem;
		--vaya-content-max: calc(100vw - 2 * var(--vaya-content-side-offset));
		--vaya-logo-unit: clamp(4.8rem, 14vw, 6.5rem);
		--vaya-mobile-tab-scale: 1.7;
		--vaya-mobile-tab-height: calc(var(--vaya-tab-height) * var(--vaya-mobile-tab-scale));
	}

	main,
	body.vaya-archive-project main,
	body.post-type-archive-project main,
	body.vaya-archive-project main.vaya-archive-project-layout {
		width: 100%;
		max-width: calc(100vw - 2 * var(--vaya-content-side-offset));
		margin-left: auto;
		margin-right: auto;
		box-sizing: border-box;
	}

	main > .wrap,
	main > .wrap.px-12,
	main .wrap.px-12 {
		width: 100%;
		max-width: 100%;
		padding-left: 0;
		padding-right: 0;
		box-sizing: border-box;
	}

	body:not(.vaya-front-home):not(.home) main {
		padding-top: calc(var(--vaya-mobile-tab-height, var(--vaya-logo-unit)) + 0.6rem);
	}

	body.vaya-front-home main,
	body.home main {
		padding-top: calc(var(--vaya-mobile-tab-height, var(--vaya-logo-unit)) + 0.6rem);
	}

	/* Nav dans le header (overlay burger) — masquer la barre dans main */
	.vaya-main-topbar {
		display: none !important;
	}

	/* Atelier : une colonne, image puis texte (priorité sur la grille 2 col. desktop) */
	.vaya-page--atelier .vaya-page__layout {
		display: flex;
		flex-direction: column;
		gap: clamp(1.25rem, 3vw, 2rem);
	}

	.vaya-page--atelier .vaya-page__media {
		order: 1;
		max-width: 100%;
		width: 100%;
		margin-left: 0;
	}

	.vaya-page--atelier .vaya-page__content {
		order: 2;
		width: 100%;
	}

	/* Contact : une colonne, image puis texte */
	.vaya-page--contact .vaya-page__layout {
		display: flex;
		flex-direction: column;
		gap: clamp(1.25rem, 3vw, 2rem);
	}

	.vaya-page--contact .vaya-page__media {
		order: 1;
		max-width: 100%;
		width: 100%;
		margin-left: 0;
	}

	.vaya-page--contact .vaya-page__content {
		order: 2;
		width: 100%;
	}

	/* Header v2 mobile : logo bord gauche, burger bord droit (sauf home) */
	.header--v2 {
		pointer-events: auto;
		width: 100%;
	}

	.header--v2 .header__wrap--v2,
	.header--v2 .header__wrap--v2.wrap {
		width: 100%;
		max-width: none;
		margin: 0;
		padding: 0;
		box-sizing: border-box;
	}

	.header--v2 .header__content--v2 {
		display: flex !important;
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		height: auto !important;
		min-height: 0 !important;
		max-height: none !important;
		padding: 0;
		gap: 0;
		background: transparent;
	}

	.header--v2 .header__row-v2 {
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		width: 100%;
		min-height: var(--vaya-mobile-tab-height);
		margin: 0;
		padding: 0;
		gap: 0;
		box-sizing: border-box;
	}

	.header--v2 .header__brand {
		margin: 0;
		padding: 0;
		flex-shrink: 0;
		height: var(--vaya-mobile-tab-height);
	}

	.header--v2 .header__logo,
	.header--v2 .header__logo-full,
	.header--v2 .header__logo-short {
		height: var(--vaya-mobile-tab-height);
	}

	.header--v2 .header__logo-full img,
	.header--v2 .header__logo-short img {
		width: var(--vaya-mobile-tab-height);
		height: var(--vaya-mobile-tab-height);
		min-width: var(--vaya-mobile-tab-height);
		min-height: var(--vaya-mobile-tab-height);
		max-width: var(--vaya-mobile-tab-height);
		max-height: var(--vaya-mobile-tab-height);
	}

	.header--v2 .burger--v2-tab {
		display: inline-flex;
		flex-shrink: 0;
		margin: 0 0 0 auto;
		width: var(--vaya-mobile-tab-height);
		height: var(--vaya-mobile-tab-height);
		min-width: var(--vaya-mobile-tab-height);
		min-height: var(--vaya-mobile-tab-height);
	}

	body.vaya-front-home .header--v2 .burger--v2-tab,
	body.home .header--v2 .burger--v2-tab {
		display: none !important;
	}

	.header--v2 .header__socials--v2 {
		display: none !important;
	}

	.header--v2.is-active {
		height: 100%;
		background: #fff;
	}

	.header--v2.is-active .header__content--v2 {
		position: fixed;
		inset: 0;
		z-index: 1001;
		height: 100% !important;
		max-height: none !important;
		padding: 0;
		background: #fff;
		box-sizing: border-box;
	}

	.header--v2.is-active .header__mobile-nav {
		display: flex;
		flex: 1;
		align-items: center;
		justify-content: center;
		width: 100%;
	}

	.header--v2.is-active .header__mobile-nav .header__topbar {
		width: 100%;
		margin: 0;
	}

	.header--v2.is-active .header__mobile-nav .vaya-vision-topbar {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		gap: 0.35rem;
	}

	.header--v2.is-active .header__mobile-nav .vaya-vision-topbar__links {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		gap: 0.35rem;
	}

	.header--v2.is-active .header__mobile-nav .vaya-vision-topbar__tile {
		width: 100%;
		margin: 0;
	}

	.header--v2.is-active .header__mobile-nav .vaya-vision-topbar__tile a {
		width: 100%;
		min-height: var(--vaya-mobile-tab-height);
		height: var(--vaya-mobile-tab-height);
		max-width: none;
		font-size: clamp(0.9rem, 2.8vw, 1.05rem);
		background: var(--vaya-color-primary);
		color: #fff;
	}

	.header--v2.is-active .header__mobile-nav .vaya-vision-topbar__links {
		gap: calc(0.35rem * var(--vaya-mobile-tab-scale, 1.7));
	}

	.header--v2.is-active .header__mobile-nav .vaya-vision-topbar {
		gap: calc(0.35rem * var(--vaya-mobile-tab-scale, 1.7));
	}
}
