/* ─── Variables (theme WP par défaut) ───────────────────────────────────── */
.ev-container {
	--ev-primary:    var(--wp--preset--color--primary, var(--wp--preset--color--accent-1, #2d7a3a));
	--ev-primary-dk: var(--wp--preset--color--primary-dark, #1f5828);

	--ev-bg:         var(--wp--preset--color--base, #ffffff);
	--ev-surface:    var(--wp--preset--color--base, #ffffff);
	--ev-text:       var(--wp--preset--color--contrast, #1e1e1e);
	--ev-muted:      var(--wp--preset--color--contrast-2, #666);

	--ev-border:     var(--wp--preset--color--contrast-3, rgba(0,0,0,0.12));

	--ev-radius:     var(--wp--custom--radius, 8px);
	--ev-shadow:     0 2px 8px rgba(0, 0, 0, 0.08);

	--ev-font:       var(--wp--preset--font-family--body, system-ui, sans-serif);

	--ev-space:      var(--wp--style--block-gap, 1rem);
}

/* Base typographie */
.ev-container {
	font-family: var(--ev-font);
	color: var(--ev-text);
}

/* ─── Toolbar ───────────────────────────────────────────────────────────── */
.ev-toolbar {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--ev-space);
	margin-bottom: 15px;
}

.ev-toolbar-left {
	display: flex;
	align-items: center;
	gap: var(--ev-space);
	flex-wrap: wrap;
	flex: 1;
}

.ev-toolbar-right {
	display: flex;
	align-items: center;
	gap: var(--ev-space);
}

/* ─── Recherche texte libre ─────────────────────────────────────────────── */
.ev-search-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	color: var(--vert-frab);
	font-weight: 600;
}

.ev-search-icon {
	position: absolute;
	left: .65rem;
	color: var(--ev-muted);
	pointer-events: none;
}

.ev-search-text {
	padding: .45rem .75rem .45rem 2.1rem;
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius);
	background: var(--ev-bg);
	color: var(--ev-text);
	font-family: inherit;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	width: 240px;
	transition: border-color .15s, box-shadow .15s;
}

.ev-search-text:focus {
	outline: none;
	border-color: var(--ev-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ev-primary) 15%, transparent);
}

.ev-search-text::placeholder {
	color: var(--ev-muted);
}

.ev-results-count {
	font-size: 16px;
	padding: 0rem 1rem;
	color: var(--vert-frab);
	font-weight: 600;
}

/* ─── Toggle vue ───────────────────────────────────────────────────────── */
.ev-view-toggle {
	display: flex;
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius);
	overflow: hidden;
	background: var(--ev-surface);
}

.ev-btn-vue {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: calc(var(--ev-space) * 0.6) var(--ev-space);
	background: transparent;
	border: none;
	cursor: pointer;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	color: var(--ev-text);
	transition: background 0.15s, color 0.15s;
	line-height: 1;
}

.ev-btn-vue + .ev-btn-vue {
	border-left: 1px solid var(--ev-border);
}

.ev-btn-vue.active,
.ev-btn-vue:hover {
	background: var(--ev-primary);
	color: #fff;
}

/* ─── Bouton filtres ───────────────────────────────────────────────────── */
.ev-btn-filtres {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: calc(var(--ev-space) * 0.6) var(--ev-space);
	background: var(--ev-bg);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius);
	cursor: pointer;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	color: var(--ev-text);
	transition: background 0.15s;
}

.ev-btn-filtres:hover {
	background: var(--wp--preset--color--contrast-3, rgba(0,0,0,0.06));
}

/* ─── Offcanvas ───────────────────────────────────────────────────────── */
.ev-offcanvas {
	position: fixed;
	top: 0;
	right: 0;
	width: min(400px, 100vw);
	height: 100%;
	background: var(--ev-surface);
	z-index: 10000;
	transform: translateX(100%);
	transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
	display: flex;
	flex-direction: column;
	box-shadow: -4px 0 24px rgba(0, 0, 0, 0.14);
}

.ev-offcanvas.open {
	transform: translateX(0);
}

.ev-offcanvas-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	z-index: 9999;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.28s ease;
}

.ev-offcanvas-backdrop.open {
	opacity: 1;
	pointer-events: all;
}

.ev-offcanvas-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: calc(var(--ev-space) * 1.2) calc(var(--ev-space) * 1.5);
	border-bottom: 1px solid var(--ev-border);
}

.ev-offcanvas-header h3 {
	margin: 0;
	font-size: var(--wp--preset--font-size--medium, 1.1rem);
	font-weight: 600;
}

.ev-offcanvas-close {
	background: none;
	border: none;
	font-size: 1.6rem;
	cursor: pointer;
	color: var(--ev-muted);
}

.ev-offcanvas-body {
	flex: 1;
	overflow-y: auto;
	padding: calc(var(--ev-space) * 1.5);
	display: flex;
	flex-direction: column;
	gap: calc(var(--ev-space) * 1.5);
}

.ev-offcanvas-footer {
	display: flex;
	gap: var(--ev-space);
	padding: calc(var(--ev-space) * 1.2) calc(var(--ev-space) * 1.5);
	border-top: 1px solid var(--ev-border);
}

/* ─── Boutons filtres ─────────────────────────────────────────────────── */
.ev-btn-reset-filters,
.ev-btn-apply-filters {
	flex: 1;
	padding: var(--ev-space);
	border-radius: var(--ev-radius);
	cursor: pointer;
	font-size: var(--wp--preset--font-size--small, 0.9rem);
	font-weight: 500;
}

.ev-btn-reset-filters {
	background: transparent;
	border: 1px solid var(--ev-border);
	color: var(--ev-muted);
}

.ev-btn-apply-filters {
	background: var(--ev-primary);
	border: none;
	color: #fff;
}

.ev-btn-apply-filters:hover {
	background: var(--ev-primary-dk);
}

/* ─── Filtres ─────────────────────────────────────────────────────────── */
.ev-filter-label {
	font-weight: 600;
	font-size: 0.8rem;
	color: var(--ev-muted);
	margin-bottom: 0.6rem;
}

.ev-filter-dates input[type="date"] {
	padding: 6px 10px;
	border: 1px solid var(--ev-border);
	border-radius: 4px;
	color: var(--ev-text);
	background: var(--ev-bg);
	font-family: inherit;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	width: 100%;
	box-sizing: border-box;
}

/* ─── Carte ───────────────────────────────────────────────────────────── */
.ev-map {
	width: 100%;
	height: 550px;
	border-radius: var(--ev-radius);
	border: 1px solid var(--ev-border);
}

/* ─── Masquage explicite (display:flex écrase [hidden] en spécificité égale) */
.ev-card[hidden] {
	display: none !important;
}

/* ─── Liste ──────────────────────────────────────────────────────────── */
.ev-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
	align-items: start;
}

/* ─── Card ────────────────────────────────────────────────────────────── */
.ev-card {
	display: flex;
	flex-direction: row;
	gap: 1.25rem;
	padding: 1rem 1.1rem;
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius);
	background: var(--ev-surface);
	box-shadow: var(--ev-shadow);
	transition: box-shadow 0.2s, transform 0.2s;
	text-decoration: none;
}

.ev-card:hover {
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.13);
	transform: translateY(-3px);
}

/* ── Vignette ───────────────────────────────────────────────────────── */
.ev-card-thumb-link {
	flex-shrink: 0;
	width: 130px;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--ev-radius);
	display: block;
	align-self: flex-start;
}

.ev-card-thumb {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease;
	display: block;
}

.ev-card:hover .ev-card-thumb {
	transform: scale(1.05);
}

/* ── Corps ──────────────────────────────────────────────────────────── */
.ev-card-body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: .4rem;
}

.ev-card-header {
	display: flex;
	align-items: center;
	gap: .75rem;
	flex-wrap: wrap;
}

/* ── Catégories ─────────────────────────────────────────────────────── */
.ev-card-cats {
	display: flex;
	gap: .35rem;
	flex-wrap: wrap;
}

.ev-card-cat {
	font-size: .7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--ev-primary);
	background: color-mix(in srgb, var(--ev-primary) 12%, transparent);
	padding: 2px 7px;
	border-radius: 2px;
	white-space: nowrap;
}

/* ── Date ───────────────────────────────────────────────────────────── */
.ev-card-date {
	display: flex;
	align-items: center;
	gap: .3rem;
	font-size: .8rem;
	color: var(--ev-muted);
	margin: 0;
	white-space: nowrap;
}

/* ── Titre ──────────────────────────────────────────────────────────── */
.ev-card-title {
	font-size: 1.05rem;
	font-weight: 600;
	line-height: 1.3;
	margin: .1rem 0 0;
}

.ev-card-title a {
	color: var(--ev-text);
	text-decoration: none;
	transition: color .15s;
}

.ev-card-title a:hover {
	color: var(--ev-primary);
}

/* ── Extrait ────────────────────────────────────────────────────────── */
.ev-card-excerpt {
	font-size: .875rem;
	color: var(--ev-muted);
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	line-height: 1.5;
}

/* ── Lien CTA ───────────────────────────────────────────────────────── */
.ev-card-link {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	font-size: .85rem;
	font-weight: 500;
	color: var(--ev-primary);
	text-decoration: none;
	margin-top: auto;
	padding-top: .25rem;
}

.ev-card-link:hover {
	text-decoration: underline;
}

/* ── Bouton « Plus de résultats » ───────────────────────────────────── */
.ev-load-more-wrapper {
	text-align: center;
	padding: 2rem 0 .5rem;
}

.ev-load-more {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .7rem 2rem;
	background: transparent;
	border: 1.5px solid var(--ev-primary);
	border-radius: var(--ev-radius);
	color: var(--ev-primary);
	font-family: var(--ev-font);
	font-size: .95rem;
	font-weight: 500;
	cursor: pointer;
	transition: background .15s, color .15s;
}

.ev-load-more:hover {
	background: var(--ev-primary);
	color: #fff;
}

.ev-load-more[hidden] {
	display: none;
}

/* ─── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
	.ev-list {
		grid-template-columns: 1fr;
	}

	.ev-toolbar-left,
	.ev-toolbar-right {
		flex-wrap: wrap;
	}

	.ev-search-text {
		width: 100%;
	}

	.ev-search-wrapper {
		width: 100%;
	}
}

/* ─── Filtres catégories (offcanvas) ─────────────────────────────────────── */
.ev-filter-cats {
	display: flex;
	flex-direction: column;
	gap: .35rem;
}

.ev-filter-cat-label {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	cursor: pointer;
	padding: .25rem 0;
}

.ev-filter-cat-label input {
	accent-color: var(--ev-primary);
	width: 15px;
	height: 15px;
	flex-shrink: 0;
}

.ev-filter-dates {
	display: flex;
	flex-direction: column;
	gap: .4rem;
}

.ev-filter-dates label {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
}

/* ─── Bloc carte détail (single événement) ───────────────────────────────── */
.bloc-geolocalisation {
	width: 100%;
}

.js-map {
	width: 100%;
	height: 400px;
	border-radius: 6px;
	overflow: hidden;
}