/**
 * FacetWP — Styles partagés entre toutes les archives
 *
 * Pattern HTML attendu dans chaque archive :
 *   <div class="archive-filters">
 *       <?php echo facetwp_display('facet', 'mon_facet'); ?>
 *   </div>
 *   <div class="... facetwp-template">…</div>
 *
 * Chaque archive scope ses propres couleurs/tailles via son préfixe.
 * Ce fichier gère uniquement la structure et les styles communs.
 */

/* ========================================
   Barre de filtres
   ======================================== */

.archive-filters {
	display: flex;
	align-items: center;
	gap: var(--ri-space-sm);
	flex-wrap: wrap;
}

.ri-archive:has(.ri-titre-texte) .archive-filters {
	margin-bottom: var(--ri-space-xl);
}

.archive-filters .facetwp-facet,
.ri-archive .facetwp-facet-pagination {
	position: relative;
	margin: 0;
}

/* Contrôles — tous types sauf reset */

.archive-filters .facetwp-facet:not(.facetwp-type-reset) select,
.archive-filters .facetwp-facet:not(.facetwp-type-reset) input,
.archive-filters .facetwp-facet:not(.facetwp-type-reset) input[readonly],
.archive-filters .facetwp-type-fselect .fs-wrap {
	box-sizing: border-box;
	height: 47px;
	appearance: none;
	-webkit-appearance: none;
	padding: 12px 40px 12px 16px;
	min-width: 240px;
	background-color: var(--ri-color-white);
	outline: 1px solid var(--ri-color-grey-mid);
	border: none;
	font: 400 var(--ri-size-text-body-sm) / 1 var(--ri-font-1);
	color: var(--ri-color-grey) !important;
	cursor: pointer;
	transition: outline-color var(--ri-transition-base);
}

.archive-filters .facetwp-facet:not(.facetwp-type-reset) select:focus,
.archive-filters .facetwp-facet:not(.facetwp-type-reset) input:focus,
.archive-filters .facetwp-type-fselect .fs-wrap:focus-within {
	outline-color: var(--ri-color-teal);
	color: var(--ri-color-teal);
}

.post-type-archive .fdate-wrap {
	border-radius: 0;
}

/* Chevron — tous types sauf reset */

.archive-filters .facetwp-facet:not(.facetwp-type-reset)::after {
	content: "";
	position: absolute;
	right: 8px;
	top: 50%;
	translate: 0 -50%;
	width: 12.5px;
	height: 6.25px;
	background-color: var(--ri-color-teal);
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	pointer-events: none;
}

/* Facet "effacer" — calé à droite */

.archive-filters .facetwp-type-reset {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-self: stretch;
	margin-left: auto;
	margin-bottom: 0;
}

.archive-filters .facetwp-type-reset a {
	font: 700 var(--ri-size-text-body-sm) / 1 var(--ri-font-1);
	color: var(--ri-color-teal);
	text-align: right;
	text-decoration: none;
	white-space: nowrap;
	cursor: pointer;
	transition: opacity var(--ri-transition-base);
}

.archive-filters .facetwp-type-reset a:hover {
	opacity: 0.7;
}

/* ========================================
   Pagination FacetWP
   ======================================== */

.facetwp-pagination-wrapper:not(:has(.facetwp-page)) {
	display: none;
}

.facetwp-pagination-wrapper .facetwp-pager {
	display: flex;
	justify-content: center;
	gap: var(--ri-space-xs);
}

.facetwp-pagination-wrapper .facetwp-page {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	font: 400 var(--ri-size-text-body) / 1 var(--ri-font-1);
	color: var(--ri-color-teal);
	text-decoration: none;
	cursor: pointer;
	transition: background-color var(--ri-transition-base);
}

.facetwp-pagination-wrapper .facetwp-page.active,
.facetwp-pagination-wrapper .facetwp-page:hover {
	background-color: var(--ri-color-yellow);
}

a.facetwp-page.next,
a.facetwp-page.prev {
	width: 100px;
}

/* ========================================
   État de chargement
   ======================================== */

.facetwp-loading .facetwp-template {
	opacity: 0.5;
	pointer-events: none;
	transition: opacity var(--ri-transition-slow);
}

/* ========================================
   Responsive
   ======================================== */

@media (max-width: 782px) {

	.archive-filters {
		flex-direction: column;
		align-items: stretch;
	}

	.archive-filters .facetwp-facet:not(.facetwp-type-reset) select,
	.archive-filters .facetwp-facet:not(.facetwp-type-reset) input,
	.archive-filters .facetwp-type-fselect .fs-wrap {
		min-width: unset;
		width: 100%;
	}

	.archive-filters .facetwp-type-reset a {
		margin-top: var(--ri-space-sm);
	}
}
