/* =========================================================
   Widget « Nos dernières réalisations » — cartes portfolio.
   ========================================================= */

.ecmp-real {
	--ecmp-r-cols: 5;
	--ecmp-r-gap: 20px;
	--ecmp-r-radius: 14px;
	--ecmp-r-ratio: 4 / 3;
	--ecmp-r-card: #ffffff;
	--ecmp-r-border: rgba(17, 24, 39, 0.10);
	--ecmp-r-title: #111827;
	--ecmp-r-type: #6b7280;
	--ecmp-r-stat: #16a34a;
	--ecmp-r-filter-bg-normal: transparent;
	--ecmp-r-filter-ink-normal: #6b7280;
	--ecmp-r-filter-border-normal: rgba(17, 24, 39, 0.10);
	--ecmp-r-filter-bg: #111827;
	--ecmp-r-filter-ink: #ffffff;
	--ecmp-r-filter-border: #111827;
	--ecmp-r-filter-bg-hover: transparent;
	--ecmp-r-filter-ink-hover: #111827;
	--ecmp-r-filter-border-hover: #111827;
	--ecmp-r-filter-bg-focus: transparent;
	--ecmp-r-filter-ink-focus: #111827;
	--ecmp-r-filter-border-focus: #111827;
	--ecmp-r-filter-outline-focus: rgba(17, 24, 39, 0.25);
	display: block;
}
.ecmp-real *, .ecmp-real *::before, .ecmp-real *::after { box-sizing: border-box; }

/* ---- En-tête ---- */
.ecmp-real__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 22px;
}
.ecmp-real__title { margin: 0; font-size: 1.6rem; font-weight: 700; color: var(--ecmp-r-title); }
.ecmp-real__more {
	text-decoration: none;
	font-weight: 600;
	white-space: nowrap;
	color: #2563eb;
}
.ecmp-real__more:hover { text-decoration: underline; }

/* ---- Filtres (catégories) ---- */
.ecmp-real__filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.ecmp-real .ecmp-real__filters .ecmp-real__filter {
	appearance: none;
	padding: 8px 16px;
	border: 1px solid var(--ecmp-r-filter-border-normal);
	border-radius: 40px;
	background-color: var(--ecmp-r-filter-bg-normal);
	box-shadow: none;
	cursor: pointer;
	font-size: 14px;
	font-family: inherit;
	font-weight: inherit;
	letter-spacing: 0;
	line-height: 1.2;
	text-decoration: none;
	text-shadow: none;
	text-transform: none;
	color: var(--ecmp-r-filter-ink-normal);
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.ecmp-real .ecmp-real__filters .ecmp-real__filter:hover,
.ecmp-real .ecmp-real__filters .ecmp-real__filter:focus-visible {
	background-color: var(--ecmp-r-filter-bg-hover);
	color: var(--ecmp-r-filter-ink-hover);
	border-color: var(--ecmp-r-filter-border-hover);
	box-shadow: none;
}
.ecmp-real .ecmp-real__filters .ecmp-real__filter:focus-visible {
	outline: 2px solid var(--ecmp-r-filter-outline-focus);
	outline-offset: 2px;
}
.ecmp-real .ecmp-real__filters .ecmp-real__filter.is-active {
	background-color: var(--ecmp-r-filter-bg);
	color: var(--ecmp-r-filter-ink);
	border-color: var(--ecmp-r-filter-border);
}
.ecmp-real .ecmp-real__filters .ecmp-real__filter.is-active:focus-visible {
	background-color: var(--ecmp-r-filter-bg-focus);
	color: var(--ecmp-r-filter-ink-focus);
	border-color: var(--ecmp-r-filter-border-focus);
}
.ecmp-real-card.is-hidden { display: none; }

/* ---- Grille ---- */
.ecmp-real__grid {
	display: grid;
	grid-template-columns: repeat(var(--ecmp-r-cols), minmax(0, 1fr));
	gap: var(--ecmp-r-gap);
}

/* ---- Carte ---- */
.ecmp-real-card {
	display: flex;
	flex-direction: column;
	background: var(--ecmp-r-card);
	border: 1px solid var(--ecmp-r-border);
	border-radius: var(--ecmp-r-radius);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.ecmp-real-lift-yes .ecmp-real-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 40px -22px rgba(0, 0, 0, 0.30);
}

.ecmp-real-card__media { display: flex; flex-direction: column; }
.ecmp-real-card__bar {
	display: flex;
	align-items: center;
	gap: 5px;
	height: 26px;
	padding: 0 10px;
	background: #fbfbfc;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.ecmp-real-card__bar i { width: 7px; height: 7px; border-radius: 50%; background: #e1574c; }
.ecmp-real-card__bar i:nth-child(2) { background: #e6b34a; }
.ecmp-real-card__bar i:nth-child(3) { background: #4caf72; }

.ecmp-real-card__shot { position: relative; aspect-ratio: var(--ecmp-r-ratio); overflow: hidden; background: #eef0f2; }
.ecmp-real-card__img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: top center;
	display: block;
}
.ecmp-real-card__img--ph { background: linear-gradient(135deg, #e9edf1 0%, #d6dbe1 100%); }

.ecmp-real-card__body { padding: 14px 16px 18px; display: flex; flex-direction: column; }
.ecmp-real-card__t { font-size: 1.05rem; font-weight: 700; line-height: 1.25; color: var(--ecmp-r-title); }
.ecmp-real-card__type { margin-top: 3px; font-size: 0.9rem; color: var(--ecmp-r-type); }
.ecmp-real-card__stat { margin-top: 12px; font-weight: 700; color: var(--ecmp-r-stat); }
.ecmp-real-card__stat strong { font-weight: 800; }
.ecmp-real-card__stat span { font-weight: 500; color: var(--ecmp-r-type); }

/* ---- Carrousel mobile ---- */
@media (max-width: 767px) {
	.ecmp-real-carousel-yes .ecmp-real__grid {
		display: flex;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		gap: var(--ecmp-r-gap);
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding-bottom: 6px;
		margin: 0 -4px;
		padding-left: 4px;
		padding-right: 4px;
	}
	.ecmp-real-carousel-yes .ecmp-real__grid::-webkit-scrollbar { display: none; }
	.ecmp-real-carousel-yes .ecmp-real-card { flex: 0 0 78%; scroll-snap-align: start; }
}

/* ---- État éditeur ---- */
.ecmp-real .ecmp-empty,
.ecmp-empty {
	padding: 20px; border: 1px dashed #c3c4c7; border-radius: 8px;
	color: #646970; text-align: center; font-size: 14px;
}

@media (prefers-reduced-motion: reduce) {
	.ecmp-real-card { transition: none; }
}
