/*
 * Styles de base du widget Post Grid.
 * Ce fichier donne une structure stable à la grille, aux cartes, aux images
 * et aux boutons. Les réglages Elementor peuvent ensuite compléter ou
 * remplacer ces valeurs via le CSS généré par Elementor.
 */

/* Applique un calcul de largeur prévisible sur toute la grille. */
.grid-post-list,
.grid-post-list *,
.grid-post-list *::before,
.grid-post-list *::after {
	box-sizing: border-box;
}

.grid-post-wrapper,
.grid-post-wrapper *,
.grid-post-wrapper *::before,
.grid-post-wrapper *::after {
	box-sizing: border-box;
}

/* Le wrapper occupe toute la largeur disponible de la zone Elementor. */
.grid-post-wrapper {
	width: 100%;
	max-width: 100%;
}

/*
 * La liste des articles est une grille CSS.
 * Le PHP ajoute ensuite des classes de colonnes selon les réglages Elementor.
 */
.grid-post-list {
	display: grid;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	gap: 24px;
	list-style: none;
	align-items: stretch;
	overflow: clip;
}

/* Chaque élément peut s'étirer pour que toutes les cartes gardent la même hauteur. */
.grid-post-item {
	display: flex;
	min-width: 0;
}

/* Classes de colonnes desktop ajoutées au rendu selon le contrôle Elementor. */
.grid-post-columns-1 {
	grid-template-columns: 1fr;
}

.grid-post-columns-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-post-columns-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-post-columns-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

/*
 * Carte principale d'un article.
 * Le flex en colonne permet de garder l'image en haut, le contenu au centre
 * et le bouton en bas quand les cartes n'ont pas toutes la même quantité de texte.
 */
.grid-post-card {
	display: flex;
	flex-direction: column;
	align-self: stretch;
	width: 100%;
	height: 100%;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
	background: #fff;
	border-radius: 8px;
}

/*
 * Neutralise les animations de hover héritées du thème ou d'Elementor.
 * Le widget garde ainsi un rendu stable tant qu'une animation dédiée n'est pas prévue.
 */
.grid-post-card:hover,
.grid-post-card:hover *,
.grid-post-card:focus-within,
.grid-post-card:focus-within * {
	animation: none !important;
	transition: none !important;
}

/* Empêche aussi les zooms ou déplacements automatiques sur la carte et l'image. */
.grid-post-card:hover,
.grid-post-card:focus-within,
.grid-post-card:hover .grid-post-image img,
.grid-post-card:focus-within .grid-post-image img {
	transform: none !important;
}

/* Conteneur de l'image mise en avant. */
.grid-post-image {
	display: block;
	overflow: hidden;
}

/* L'image remplit la largeur de la carte et garde un cadrage propre. */
.grid-post-image img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: 220px;
	object-fit: cover;
}

/*
 * Zone de contenu de la carte.
 * Elle pousse le bouton vers le bas grâce au `margin-top: auto` du wrapper bouton.
 */
.grid-post-content {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	align-items: flex-start;
	min-width: 0;
	gap: 12px;
	padding: 22px;
}

/* Métadonnées affichées au-dessus du titre : date, auteur, catégorie, etc. */
.grid-post-meta {
	font-size: 13px;
	line-height: 1.4;
	color: #6b7280;
}

/* Titre de l'article, avec une base simple avant les réglages typographiques Elementor. */
.grid-post-heading {
	width: 100%;
	margin: 0;
	font-size: 22px;
	line-height: 1.25;
}

/* Lien du titre. `overflow-wrap` évite qu'un mot très long casse la carte. */
.grid-post-title {
	display: inline-block;
	max-width: 100%;
	color: #172033;
	text-decoration: none;
	overflow-wrap: anywhere;
}

/* Extrait de l'article. La largeur fixe à 100% garde l'alignement dans la carte. */
.grid-post-excerpt {
	width: 100%;
	margin: 0;
	color: #4b5563;
	font-size: 15px;
	line-height: 1.7;
	overflow-wrap: anywhere;
}

/* Bouton interne de la carte, séparé du bouton global "Voir plus". */
.grid-post-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	max-width: 100%;
	white-space: normal;
	overflow-wrap: anywhere;
}

/* Wrapper du bouton de carte. Le `margin-top: auto` l'aligne en bas de la carte. */
.grid-post-button-wrap {
	display: flex;
	align-items: flex-start;
	width: 100%;
	margin-top: auto;
}

/* Texte et icône du bouton utilisent le même alignement vertical. */
.grid-post-button-text,
.grid-post-button-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

/* Garde l'icône du bouton compacte et alignée avec le texte. */
.grid-post-button-icon {
	line-height: 1;
}

/* Les SVG héritent de la couleur du bouton, donc Elementor peut les styliser facilement. */
.grid-post-button-icon svg {
	display: block;
	width: 1em;
	height: 1em;
	fill: currentColor;
}

/* Zone du bouton global qui charge les articles suivants en AJAX. */
.grid-post-load-more-wrap {
	display: flex;
	justify-content: center;
	width: 100%;
	margin-top: 28px;
}

/* Bouton "Voir plus", indépendant du bouton placé dans chaque carte. */
.grid-post-load-more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	max-width: 100%;
	white-space: normal;
	overflow-wrap: anywhere;
}

/* Texte et icône du bouton "Voir plus". */
.grid-post-load-more-text,
.grid-post-load-more-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

/* Garde l'icône du bouton "Voir plus" alignée sur une seule ligne. */
.grid-post-load-more-icon {
	line-height: 1;
}

/* Même logique que le bouton de carte : le SVG suit la couleur courante du bouton. */
.grid-post-load-more-icon svg {
	display: block;
	width: 1em;
	height: 1em;
	fill: currentColor;
}

/* État utilisé pendant le chargement AJAX des prochains articles. */
.grid-post-load-more:disabled,
.grid-post-load-more.is-loading {
	cursor: wait;
	opacity: 0.72;
	transform: none;
}

/* Focus clavier visible sur les liens internes de la grille. */
.grid-post-list a:focus-visible {
	outline: 3px solid #f59e0b;
	outline-offset: 3px;
	border-radius: 6px;
}

/* Focus clavier visible sur le bouton "Voir plus". */
.grid-post-load-more:focus-visible {
	outline: 3px solid #f59e0b;
	outline-offset: 3px;
}

/* Message affiché quand la requête ne renvoie aucun article. */
.grid-post-empty {
	margin: 0;
}

/* Texte disponible pour les lecteurs d'écran sans être visible à l'écran. */
.grid-post-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Colonnes tablette : ces classes prennent le dessus sous 1024px. */
@media (max-width: 1024px) {
	.grid-post-tablet-columns-1,
	.grid-post-tablet-columns-1.grid-post-columns-2,
	.grid-post-tablet-columns-1.grid-post-columns-3,
	.grid-post-tablet-columns-1.grid-post-columns-4 {
		grid-template-columns: 1fr;
	}

	.grid-post-tablet-columns-2,
	.grid-post-tablet-columns-2.grid-post-columns-3,
	.grid-post-tablet-columns-2.grid-post-columns-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.grid-post-tablet-columns-3,
	.grid-post-tablet-columns-3.grid-post-columns-4 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.grid-post-tablet-columns-4 {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

/* Colonnes mobile et petits ajustements de lisibilité sous 767px. */
@media (max-width: 767px) {
	.grid-post-mobile-columns-1,
	.grid-post-mobile-columns-1.grid-post-columns-2,
	.grid-post-mobile-columns-1.grid-post-columns-3,
	.grid-post-mobile-columns-1.grid-post-columns-4 {
		grid-template-columns: 1fr;
	}

	.grid-post-mobile-columns-2,
	.grid-post-mobile-columns-2.grid-post-columns-3,
	.grid-post-mobile-columns-2.grid-post-columns-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.grid-post-mobile-columns-3 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.grid-post-mobile-columns-4 {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.grid-post-content {
		padding: 18px;
	}

	.grid-post-heading {
		font-size: 20px;
	}
}
