/**
 * Archive : Nos Offres + Page Toutes nos offres
 * Les styles des cards .carte-offre sont dans ri-grille-offres.css — pas de
 * duplication ici. Ce fichier couvre uniquement les éléments propres aux deux
 * contextes (grille pleine page, bannière interstitielle, pagination,
 * responsive).
 */

/* ========================================
   Section grille
   ======================================== */

.ri-archive-nos-offres .ri-grille-offres {
	width: 100%;
	padding-block: 0 var(--ri-block-padding-xl);
	background-color: var(--ri-color-white);
}

.ri-grille-offres .grille {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	row-gap: var(--ri-gap-lg);
	column-gap: var(--ri-gap-md);
}

/* ========================================
   Bannière sur-mesure — 2 colonnes
   ======================================== */

.ri-grille-offres .offre-banniere {
	grid-column: span 2;
	display: flex;
	align-self: stretch;
	background-color: var(--ri-color-grey);
	padding: var(--ri-space-md);
	gap: var(--ri-gap-lg);
}

.ri-grille-offres .offre-banniere-content {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: var(--ri-space-lg);
}

.ri-grille-offres .offre-banniere-text {
	display: flex;
	flex-direction: column;
	gap: var(--ri-space-md);
}

.ri-grille-offres .offre-banniere-titre {
	margin: 0;
	font: 700 var(--ri-size-title-h2) / 1.4 var(--ri-font-1);
}

.ri-grille-offres .offre-banniere-texte {
	margin: 0;
	font: 400 var(--ri-size-text-body) / 1.7 var(--ri-font-1);
}

.ri-grille-offres .offre-banniere-cta {
	display: inline-flex;
	align-self: flex-start;
	padding: 12px 16px;
	background-color: var(--ri-color-grey-soft);
	font: 700 var(--ri-size-text-body-sm) / 1 var(--ri-font-1);
	color: var(--ri-color-teal);
	text-decoration: none;
	transition: opacity var(--ri-transition-base);
}

.ri-grille-offres .offre-banniere-cta:hover {
	opacity: 0.85;
}

.ri-grille-offres .offre-banniere-image {
	flex-shrink: 0;
	width: 40%;
	display: flex;
	align-items: start;
	justify-content: center;
}

.ri-grille-offres .offre-banniere-image img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: contain;
}

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

.ri-archive-nos-offres .nav-links {
	display: flex;
	justify-content: center;
	gap: var(--ri-space-sm);
	margin-top: var(--ri-space-lg);
}

.ri-archive-nos-offres .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding-inline: 8px;
	font: 400 var(--ri-size-text-body-sm) / 1 var(--ri-font-1);

	text-decoration: none;
	transition: background-color var(--ri-transition-base);
}

.ri-archive-nos-offres .page-numbers.current,
.ri-archive-nos-offres .page-numbers:hover {
	background-color: var(--ri-color-teal);
	color: var(--ri-color-white);
}

/* ========================================
   Aucun résultat
   ======================================== */

.ri-archive-nos-offres .no-results {
	font: 400 var(--ri-size-text-body) / 1.7 var(--ri-font-1);
}

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

@media (max-width: 1024px) {

	.ri-grille-offres .grille {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 782px) {

	.ri-grille-offres .grille {
		grid-template-columns: 1fr;
		row-gap: 16px;
	}

	.ri-grille-offres .offre-banniere {
		grid-column: span 1;
		flex-direction: column;
	}

	.ri-grille-offres .offre-banniere-image {
		width: 100%;
		padding: 0;
		aspect-ratio: 16 / 9;
	}
}
