/**
 * Bloc : Grille Offres (ri-grille-offres)
 * Convention : classe complète sur la section, classes courtes scopées dedans.
 * Les styles des cards .carte-offre sont définis ici,
 * réutilisés par archive-nos-offres.css.
 */

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

.single-nos-offres .ri-grille-offres {
	padding-block: 0 var(--ri-block-padding-xl);
}

.ri-grille-offres .header {
	margin-bottom: 32px;
}

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

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

.ri-grille-offres .footer {
	margin-top: 40px;
	display: flex;
	justify-content: flex-end;
}

/* ========================================
   Page
   ======================================== */

.page .site-content > .ri-grille-offres {
	padding-block: 40px;
}

.page .site-content > .ri-grille-offres:first-child {
	padding-block-start: 0;
}

/* ========================================
   Card offre
   ======================================== */

.ri-grille-offres .carte-offre {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: auto auto 1fr;
	background-color: var(--ri-color-grey-soft);
}

.ri-grille-offres .carte-tags {
	grid-column: 1;
	grid-row: 1;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 8px 8px 0;
}

.ri-grille-offres .tag {
	display: inline-block;
	padding: 2px 8px;
	background-color: var(--ri-color-yellow);
	font: 700 var(--ri-size-text-body-xs) / 1.4 var(--ri-font-1);
}

.ri-grille-offres .carte-image-wrapper {
	grid-column: 1;
	grid-row: 2;
	margin: 8px;
	width: calc(100% - 16px);
	aspect-ratio: 411 / 240;
	overflow: hidden;
}

.ri-grille-offres .carte-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ri-grille-offres .carte-main {
	grid-column: 1;
	grid-row: 3;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 24px;
	padding: 16px 16px 24px;
}

.ri-grille-offres .carte-body {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.ri-grille-offres .carte-titre {
	margin: 0;
	font: 700 var(--ri-size-title-h2) / 1.4 var(--ri-font-1);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ri-grille-offres .carte-titre a {
	color: inherit;
	text-decoration: none;
}

.ri-grille-offres .carte-description {
	margin: 0;
	font: 400 var(--ri-size-text-body) / 1.7 var(--ri-font-1);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ri-grille-offres .carte-cta-wrapper {
	display: flex;
	justify-content: flex-end;
}

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

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

/* Placeholder éditeur */
.ri-grille-offres.is-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	padding: var(--ri-space-lg);
	border: 2px dashed var(--ri-color-grey);
	color: var(--ri-color-grey);
	font-size: 14px;
}

/* Responsive */
@media (max-width: 1024px) {

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

@media (max-width: 782px) {

	.ri-grille-offres .header {
		margin-bottom: var(--ri-space-md);
	}

	.ri-grille-offres .grille {
		grid-template-columns: 1fr;
		gap: var(--ri-space-sm);
	}

	.ri-grille-offres .carte-offre {
		display: grid;
		grid-template-columns: 1fr 120px;
		grid-template-rows: auto;
		align-items: end;
		padding: 12px 8px;
		gap: 12px;
	}

	.ri-grille-offres .carte-tags {
		padding: 0;
		align-self: flex-start;
		flex-wrap: nowrap;
		overflow: hidden;
	}

	.ri-grille-offres .carte-tags .tag:nth-child(n+3) {
		display: none;
	}

	.ri-grille-offres .carte-image-wrapper {
		grid-column: 2;
		grid-row: 1 / 3;
		margin: 0;
		width: 120px;
		height: 120px;
		aspect-ratio: 1 / 1;
		align-self: stretch;
	}

	.ri-grille-offres .carte-main {
		grid-column: 1;
		grid-row: 2;
		padding: 0;
		gap: 0;
	}

	.ri-grille-offres .carte-body {
		gap: 0;
	}

	.ri-grille-offres .carte-titre {
		line-height: 1.3;
	}

	.ri-grille-offres .carte-description,
	.ri-grille-offres .carte-cta-wrapper {
		display: none;
	}
}
