/* =====================================================================
 * Avila Spaces â€” Listagem de Eventos
 * EstÃ©tica: editorial / arquitetÃ³nica quente â€” creme + terracota + Futura PT.
 * Grelha + Lista + filtros. (SecÃ§Ã£o 9.1 do PRD)
 * ===================================================================== */

.aev {
	--cream:      #F9F7F5;
	--cream-2:    #F4EFEA;
	--paper:      #FFFFFF;
	--ink:        #25272C;
	--ink-soft:   #575655;
	--muted:      #8A8784;
	--terra:      #C44F26;
	--terra-2:    #DF805F;
	--terra-tint: #E2BAAB;
	--line:       rgba(37, 39, 44, 0.12);
	--line-soft:  rgba(37, 39, 44, 0.07);
	--shadow:     0 18px 50px -24px rgba(37, 39, 44, 0.45);

	font-family: "futura-pt", "Futura", "Century Gothic", system-ui, sans-serif;
	color: var(--ink);
	background: var(--cream);
	margin: 0 auto;
	-webkit-font-smoothing: antialiased;
}

/* ---------- CabeÃ§alho editorial ---------- */
.aev-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
	padding-bottom: 22px;
	border-bottom: 1px solid var(--ink);
	margin-bottom: 30px;
}
.aev-head__title {
	margin: 0;
	font-size: clamp(34px, 6vw, 68px);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 0.95;
	text-transform: uppercase;
}
.aev-head__title em {
	font-style: normal;
	color: var(--terra);
}
.aev-head__meta {
	font-size: 13px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--muted);
	white-space: nowrap;
	padding-bottom: 6px;
}
.aev-head__eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--ink);
	padding-bottom: 6px;
}

/* ---------- Hero / banner da pÃ¡gina de eventos ---------- */
.aev-hero {
	background: #F9F7F5;
	font-family: "futura-pt", "Futura", "Century Gothic", system-ui, sans-serif;
	color: #25272C;
	padding: clamp(46px, 8vw, 104px) clamp(18px, 5vw, 64px) clamp(18px, 3vw, 36px);
	-webkit-font-smoothing: antialiased;
}
.aev-hero__inner { max-width: 1320px; margin: 0 auto; }
.aev-hero__title {
	margin: 0 0 20px; font-size: clamp(46px, 9vw, 124px); font-weight: 600;
	letter-spacing: -0.035em; line-height: 0.88; text-transform: uppercase; color: #25272C;
}
.aev-hero__title::after { content: "."; color: #C44F26; }
.aev-hero__lead {
	margin: 0; max-width: 740px; font-size: clamp(17px, 1.9vw, 22px);
	line-height: 1.5; color: #575655;
}
.aev-hero + .aev { padding-top: clamp(18px, 3vw, 34px); }

/* ---------- Barra de controlo (filtros + toggle de vista) ---------- */
.aev-controls {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	flex-wrap: wrap;
	margin-bottom: 34px;
}
.aev-filters { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

/* BotÃ£o "Filtros" â€” sÃ³ aparece em tablet/mobile (toggle do painel de filtros). */
.aev-filters-toggle {
	display: none; /* escondido no desktop; mostrado no media query abaixo */
	align-items: center;
	gap: 8px;
	appearance: none;
	font: inherit;
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ink);
	background: transparent;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 10px 18px;
	cursor: pointer;
	transition: border-color 0.25s, color 0.25s, background 0.25s;
}
.aev-filters-toggle:hover { border-color: var(--terra); }
.aev-filters-toggle[aria-expanded="true"] { border-color: var(--terra); color: var(--terra); }
.aev-filters-toggle__icon { width: 15px; height: 15px; display: inline-block; }
.aev-filters-count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 18px; height: 18px; padding: 0 5px;
	background: var(--terra); color: #fff;
	border-radius: 999px; font-size: 11px; line-height: 1; font-weight: 600;
}
.aev-filters-count[hidden] { display: none; }
.aev-filtergroup { position: relative; }
.aev-filtergroup select {
	appearance: none;
	font: inherit;
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ink);
	background: transparent;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 10px 38px 10px 18px;
	cursor: pointer;
	transition: border-color 0.25s, color 0.25s, background 0.25s;
	max-width: 220px;
}
.aev-filtergroup::after {
	content: "";
	position: absolute;
	right: 16px; top: 50%;
	width: 7px; height: 7px;
	border-right: 1.5px solid var(--terra);
	border-bottom: 1.5px solid var(--terra);
	transform: translateY(-65%) rotate(45deg);
	pointer-events: none;
}
.aev-filtergroup select:hover { border-color: var(--terra); }
.aev-filtergroup select:focus-visible { outline: 2px solid var(--terra); outline-offset: 2px; }

/* Filtro de intervalo de datas (PRD 9.1.6) â€” sem chevron, com inputs a condizer. */
.aev-filtergroup--dates { display: flex; gap: 10px; align-items: center; }
.aev-filtergroup--dates::after { display: none; }
.aev-daterange { display: inline-flex; align-items: center; gap: 6px; }
.aev-daterange span {
	font-size: 12px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ink);
	opacity: 0.6;
}
.aev-filtergroup--dates input[type="date"] {
	font: inherit;
	font-size: 13px;
	color: var(--ink);
	background: transparent;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 9px 14px;
	cursor: pointer;
	transition: border-color 0.25s;
}
.aev-filtergroup--dates input[type="date"]:hover { border-color: var(--terra); }
.aev-filtergroup--dates input[type="date"]:focus-visible { outline: 2px solid var(--terra); outline-offset: 2px; }

.aev-toggle {
	display: inline-flex;
	border: 1px solid var(--line);
	border-radius: 999px;
	background: var(--paper);
}
.aev-toggle button {
	font: inherit;
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--muted);
	background: transparent;
	border: 0;
	border-radius: 999px;
	padding: 9px 12px;
	cursor: pointer;
	transition: color 0.25s, background 0.25s;
}
.aev-toggle button[aria-pressed="true"] {
	color: var(--cream);
	background: var(--ink);
}

/* ===================================================================
 * GRELHA
 * =================================================================== */
.aev-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 10px;
	/* background: var(--line-soft); */
	/* border: 1px solid var(--line-soft); */
}
/* Hairline grid: as fronteiras finas entre cards reforÃ§am o ar editorial. */

.aev-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--cream-2);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: background 0.4s, transform 0.4s;
	animation: aev-rise 0.7s cubic-bezier(0.2, 0.7, 0.2, 1) both;
	box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px !important;
}
.aev-card:hover { background: var(--paper); }

.aev-card__media {
	position: relative;
	aspect-ratio: 20 / 12;
	overflow: hidden;
	background: var(--terra-tint);
}
.aev-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.aev-card:hover .aev-card__media img { transform: scale(1.06); }
.aev-card__media--empty {
	display: flex; align-items: center; justify-content: center;
	background: linear-gradient(135deg, var(--terra-tint), var(--cream-2));
	color: var(--terra);
	font-size: 13px; letter-spacing: 0.2em; text-transform: uppercase;
}

/* Bloco de data sobreposto Ã  imagem */
.aev-card__date {
	position: absolute;
	left: 14px; bottom: 14px;
	background: var(--cream);
	color: var(--ink);
	padding: 8px 12px 6px;
	text-align: center;
	line-height: 1;
	box-shadow: var(--shadow);
}
.aev-card__day { display: block; font-size: 30px; font-weight: 600; letter-spacing: -0.03em; }
.aev-card__mon { display: block; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terra); margin-top: 4px; }

.aev-card__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 20px 20px 22px;
	flex: 1;
}
.aev-card__type {
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--terra);
}
.aev-card__title {
	margin: 0;
	font-size: 21px !important;
	font-weight: 600;
	line-height: 1.12;
	letter-spacing: -0.01em;
}
.aev-card__loc {
	display: flex; align-items: center; gap: 8px;
	font-size: 14px; color: var(--ink-soft);
}
.aev-card__loc::before {
	content: ""; width: 5px; height: 5px; border-radius: 50%;
	background: var(--terra); flex: none;
}
.aev-card__foot {
	margin-top: auto;
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px;
	padding-top: 14px;
	border-top: 1px solid var(--line-soft);
}
.aev-price {
	font-size: 14px; letter-spacing: 0.02em;
	color: var(--ink);
}
.aev-price--free { color: var(--terra); text-transform: uppercase; letter-spacing: 0.12em; font-size: 12px; }
.aev-price__member { display: block; margin-top: 2px; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; opacity: 0.6; }
.aev-card__cta {
	font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--ink); display: inline-flex; align-items: center; gap: 7px;
	transition: gap 0.3s, color 0.3s;
}
.aev-card__cta svg { width: 16px; height: 8px; transition: transform 0.3s; }
.aev-card:hover .aev-card__cta { color: var(--terra); gap: 11px; }

/* Badges de estado (reaproveita a linguagem dos badges do detalhe) */
.aev-badges { position: absolute; top: 14px; right: 14px; display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.aev-badge {
	font-size: 10px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
	padding: 5px 10px; border-radius: 999px; backdrop-filter: blur(4px);
}
.aev-badge--full      { background: rgba(243,232,200,0.92); color: #7a5b00; }
.aev-badge--cancelled { background: rgba(246,214,214,0.92); color: #8a1f1f; }
.aev-badge--members   { background: rgba(217,232,246,0.92); color: #16527e; }

/* ===================================================================
 * LISTA
 * =================================================================== */
.aev-list { display: none; flex-direction: column; border-top: 1px solid var(--ink); }
.aev[data-view="list"] .aev-grid { display: none; }
.aev[data-view="list"] .aev-list { display: flex; }

.aev-row {
	display: grid;
	grid-template-columns: 96px 1.4fr 1fr auto;
	align-items: center;
	gap: 28px;
	padding: 22px 8px;
	border-bottom: 1px solid var(--line);
	text-decoration: none;
	color: inherit;
	transition: background 0.3s, padding-left 0.3s;
	animation: aev-rise 0.7s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}
.aev-row:hover { background: var(--cream-2); padding-left: 18px; }
.aev-row__date { text-align: center; line-height: 0.95; }
.aev-row__day { display: block; font-size: 40px; font-weight: 600; letter-spacing: -0.03em; color: var(--terra); }
.aev-row__mon { display: block; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-top: 5px; }
.aev-row__main { min-width: 0; }
.aev-row__type { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terra); }
h3.aev-row__title { margin: 4px 0 0; font-size: clamp(20px, 2.4vw, 28px); font-weight: 600; line-height: 1.08; letter-spacing: -0.01em; }
.aev-row__meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; color: var(--ink-soft); font-size: 14px; }
.aev-row__meta .aev-badge { backdrop-filter: none; }
.aev-row__arrow {
	width: 46px; height: 46px; border-radius: 50%;
	border: 1px solid var(--line);
	display: flex; align-items: center; justify-content: center;
	color: var(--ink);
	transition: background 0.3s, color 0.3s, border-color 0.3s, transform 0.3s;
}
.aev-row:hover .aev-row__arrow { background: var(--terra); border-color: var(--terra); color: #fff; transform: rotate(-45deg); }
.aev-row__arrow svg { width: 18px; height: 9px; }

.aev .is-hidden { display: none !important; }
/* Itens de passados ainda nÃ£o revelados pelo "Ver mais". */
.aev .is-beyond { display: none !important; }
.aev-past__actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin: 44px 0 8px; }
.aev-past__more, .aev-past__less {
	padding: 13px 30px;
	background: transparent; color: var(--ink);
	border: 1px solid var(--ink); border-radius: 999px;
	font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; cursor: pointer;
	transition: background 0.25s, color 0.25s, border-color 0.25s;
}
.aev-past__more:hover { background: var(--ink); color: var(--paper); }
/* "Ver menos" mais discreto que o "Ver mais". */
.aev-past__less { border-color: var(--line); color: var(--muted); }
.aev-past__less:hover { border-color: var(--ink); color: var(--ink); }
.aev-past__more[hidden], .aev-past__less[hidden] { display: none; }

/* ---------- Eventos passados (secÃ§Ã£o recolhÃ­vel, formato lista) ---------- */
.aev-past { margin-top: 48px; border-top: 1px solid var(--ink); }
.aev[data-view="calendar"] .aev-past { display: none; }
.aev-past__summary {
	list-style: none; cursor: pointer;
	display: flex; align-items: center; gap: 12px;
	padding: 22px 8px;
	font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted);
}
.aev-past__summary::-webkit-details-marker { display: none; }
.aev-past__summary::after {
	content: "+"; margin-left: auto;
	font-size: 22px; line-height: 1; color: var(--ink-soft);
	transition: transform 0.25s;
}
.aev-past[open] .aev-past__summary::after { content: "\2013"; }
.aev-past__summary:hover { color: var(--ink); }
.aev-past__count {
	min-width: 22px; height: 22px; padding: 0 6px; border-radius: 11px;
	background: var(--cream-2); color: var(--ink-soft);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 12px; letter-spacing: 0;
}
/* Grelha/lista de passados seguem a vista ativa, tal como os prÃ³ximos â€” mas com classes
   prÃ³prias para nÃ£o serem afetadas pelo estado "sem eventos" (.aev.is-empty) da secÃ§Ã£o de cima. */
.aev-past__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 10px;
}
.aev-past__list { display: none; flex-direction: column; }
.aev[data-view="list"] .aev-past__grid { display: none; }
.aev[data-view="list"] .aev-past__list { display: flex; }

/* Esmaecidos e nÃ£o-clicÃ¡veis (sem link para a pÃ¡gina) â€” tratamento "desativado" igual
   ao dos eventos passados na pÃ¡gina single: opacidade reduzida + texto apagado. */
.aev-pcard, .aev-prow { opacity: 0.6; cursor: default; }
.aev-prow:hover { background: transparent; padding-left: 8px; }
.aev-pcard:hover { background: var(--cream-2); }
.aev-pcard:hover .aev-card__media img { transform: none; }
/* TÃ­tulo e data deixam de ser preto/terra e passam a tons apagados. */
.aev-prow .aev-row__title, .aev-pcard .aev-card__title { color: var(--muted); }
.aev-prow .aev-row__day, .aev-pcard .aev-card__day { color: #b6afa4; }
.aev-prow .aev-row__type, .aev-pcard .aev-card__type,
.aev-prow .aev-row__mon, .aev-pcard .aev-card__mon { color: var(--muted); }
/* Imagem dos cards passados a cinza (dessaturada), reforÃ§ando o estado "desativado". */
.aev-pcard .aev-card__media img { filter: grayscale(1); }
.aev-pcard:hover .aev-card__media img { filter: grayscale(1); }

/* ===================================================================
 * CALENDÃRIO (mensal)
 * =================================================================== */
.aev-calendar { display: none; }
.aev[data-view="calendar"] .aev-grid,
.aev[data-view="calendar"] .aev-list { display: none; }
.aev[data-view="calendar"] .aev-calendar { display: block; }
.aev[data-view="calendar"] .aev-filters {visibility: hidden;}
.aev[data-view="calendar"] .aev-empty { display: none; }

.aev-cal-head { display: flex; align-items: center; justify-content: center; gap: 28px; margin-bottom: 18px; }
.aev-cal-month { font-size: clamp(20px, 3vw, 30px); font-weight: 600; letter-spacing: -0.01em; text-transform: uppercase; min-width: 9ch; text-align: center; }
.aev-cal-nav {
	width: 46px; height: 46px; border-radius: 50%;
	border: 1px solid var(--line); background: var(--paper);
	font-size: 22px; line-height: 1; color: var(--ink); cursor: pointer;
	transition: background 0.25s, color 0.25s, border-color 0.25s;
}
.aev-cal-nav:hover { background: var(--terra); color: #fff; border-color: var(--terra); }

.aev-cal-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }
.aev-cal-dow { border-bottom: 1px solid var(--ink); }
.aev-cal-dowcell { padding: 8px 10px; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.aev-cal-days { gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); }
.aev-cal-cell { background: var(--cream); min-height: 116px; padding: 8px 8px 10px; display: flex; flex-direction: column; gap: 6px; }
.aev-cal-cell.is-empty { background: var(--cream-2); opacity: 0.5; }
.aev-cal-cell.has-events { background: var(--paper); }
.aev-cal-num { font-size: 14px; color: var(--ink-soft); font-weight: 600; }
.aev-cal-cell.is-today { box-shadow: inset 0 0 0 2px var(--terra); }
.aev-cal-cell.is-today .aev-cal-num {
	color: #fff; background: var(--terra); width: 24px; height: 24px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center; font-size: 12px;
}
.aev-cal-evs { display: flex; flex-direction: column; gap: 4px; }
.aev-cal-ev {
	display: block; text-decoration: none; font-size: 12px; line-height: 1.25; color: var(--ink);
	background: var(--terra-tint); border-left: 2px solid var(--terra);
	padding: 3px 6px; border-radius: 3px;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background 0.2s, color 0.2s;
}
.aev-cal-ev:hover { background: var(--terra-2); color: #fff; }
.aev-cal-ev-time { font-weight: 600; margin-right: 5px; }
.aev-cal-ev.is-full { opacity: 0.6; }
.aev-cal-ev.is-cancelled { opacity: 0.5; text-decoration: line-through; }
/* Eventos passados no calendÃ¡rio: nÃ£o-clicÃ¡veis (span) e apagados, sem hover de link. */
.aev-cal-ev.is-past {
	background: var(--cream-2); border-left-color: var(--line);
	color: var(--muted); cursor: default; opacity: 0.75;
}
.aev-cal-ev.is-past:hover { background: var(--cream-2); color: var(--muted); }
.aev-cal-more { font-size: 11px; color: var(--muted); padding: 2px 6px; }

@media (max-width: 720px) {
	.aev-cal-cell { min-height: 70px; padding: 5px; }
	.aev-cal-ev {font-size: 0;padding: 0;background: transparent;border: 0;}
	.aev-cal-ev-time { font-size: 0; }
	.aev-cal-ev::before {content: "";display: block;width: 7px;height: 7px;border-radius: 50%;background: var(--terra);margin: 2px;}
	.aev-cal-ev.is-cancelled::before { background: #8a1f1f; }
	.aev-cal-ev.is-past::before { background: var(--muted); }
	/* cabeÃ§alho do mÃªs: â€¹ mÃªs â€º numa sÃ³ linha, setas mais pequenas (nÃ£o caem para baixo) */
	.aev-cal-head { gap: 10px; justify-content: space-between; flex-wrap: nowrap; }
	.aev-cal-nav { width: 34px; height: 34px; font-size: 16px; flex: 0 0 auto; padding: 0 !important; }
	.aev-cal-month { font-size: 20px; min-width: 0; flex: 1 1 auto; }
	/* botões de vista + filtro: paddings compactos para caberem em mobile */
	.aev-toggle button { padding: 7px 11px; font-size: 11px; letter-spacing: 0.06em; }
	.aev-filters-toggle { padding: 8px 14px; }
	.aev-filtergroup select { padding: 9px 30px 9px 14px; }
}

/* ---------- Estado vazio ---------- */
.aev-empty {
	display: none;
	padding: 80px 20px;
	text-align: center;
	color: var(--muted);
	font-size: 18px;
	letter-spacing: 0.02em;
	border: 1px dashed var(--line);
}
.aev.is-empty .aev-grid,
.aev.is-empty .aev-list { display: none !important; }
.aev.is-empty .aev-empty { display: block; }

/* ===================================================================
 * WIDGET de localizaÃ§Ã£o (PRD 9.3) â€” compacto, atÃ© 3 eventos
 * =================================================================== */
.aev-widget {
	--terra: #C44F26; --ink: #25272C; --ink-soft: #575655; --muted: #8A8784;
	--cream-2: #F4EFEA; --line: rgba(37,39,44,0.12);
	font-family: "futura-pt", "Futura", "Century Gothic", system-ui, sans-serif;
	color: var(--ink);
}
.aev-widget__head {
	display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
	padding-bottom: 12px; margin-bottom: 4px; border-bottom: 1px solid var(--ink);
}
.aev-widget__title { margin: 0; font-size: 15px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; }
.aev-widget__all {
	font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none;
	color: var(--terra); display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
	transition: gap 0.25s;
}
.aev-widget__all:hover { gap: 10px; }
.aev-widget__all svg { width: 15px; height: 8px; }

.aev-w-item {
	display: grid; grid-template-columns: 54px 1fr; align-items: center; gap: 16px;
	padding: 16px 4px; border-bottom: 1px solid var(--line); text-decoration: none; color: inherit;
	transition: padding-left 0.25s, background 0.25s;
}
.aev-w-item:hover { padding-left: 12px; background: var(--cream-2); }
.aev-w-date { text-align: center; line-height: 0.95; }
.aev-w-day { display: block; font-size: 26px; font-weight: 600; letter-spacing: -0.03em; color: var(--terra); }
.aev-w-mon { display: block; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-top: 3px; }
.aev-w-main { min-width: 0; }
.aev-w-title { margin: 0; font-size: 16px; font-weight: 600; line-height: 1.15; }
.aev-w-meta { margin-top: 3px; font-size: 12.5px; color: var(--ink-soft); display: flex; gap: 10px; flex-wrap: wrap; }
.aev-w-empty { padding: 18px 4px; color: var(--muted); font-size: 14px; }

/* ---------- AnimaÃ§Ã£o de entrada (staggered) ---------- */
@keyframes aev-rise {
	from { opacity: 0; transform: translateY(18px); }
	to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
	.aev-card, .aev-row, .aev-card__media img { animation: none !important; transition: none !important; }
}

/* ---------- Responsivo ---------- */
@media (max-width: 720px) {
	.aev-row { grid-template-columns: 64px 1fr auto; gap: 16px; }
	.aev-row__meta { display: none; }
	.aev-row__day { font-size: 30px; }
}

/* ---------- Filtros responsivos: colapsam atrÃ¡s do botÃ£o "Filtros" ---------- */
@media (max-width: 900px) {
	.aev-controls { gap: 14px; }
	.aev-filters-toggle {display: inline-flex;order: 1;padding: 10px 15px !important;}
	.aev-toggle {order: 2;}
	.aev-filters {
		order: 3;
		flex-basis: 100%;
		width: 100%;
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
		display: none; /* colapsado por defeito; abre via .is-open (JS) */
	}
	.aev-filters.is-open {display: flex;visibility: visible !important;}
	.aev-filtergroup { width: 100%; }
	.aev-filtergroup select { width: 100%; max-width: none; }
	.aev-filtergroup--dates { flex-direction: column; align-items: stretch; gap: 10px; }
	.aev-daterange { justify-content: space-between; }
	.aev-filtergroup--dates input[type="date"] { width: 100%; }
	.aev-clear { width: 100%; margin-left: 0; text-align: center; }
}

/* BotÃ£o "Limpar filtros" â€” sÃ³ visÃ­vel quando hÃ¡ filtros ativos (toggle no JS). */
.aev-clear {
	appearance: none;
	font: inherit;
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--terra);
	background: transparent;
	border: 1px solid var(--terra);
	border-radius: 999px;
	padding: 10px 18px;
	cursor: pointer;
	transition: background 0.25s, color 0.25s;
}
.aev-clear:hover { background: var(--terra); color: #fff; }
.aev-clear[hidden] { display: none; }

/* ===== Popup de eventos do dia (mobile + "+more" no desktop) ===== */
.aev-cal-modal{ display:none; }
.aev-cal-modal.is-open{ display:block; }
.aev-cal-modal__backdrop{ position:fixed; inset:0; background:rgba(37,39,44,.55); z-index:10000; }
.aev-cal-modal__panel{
	position:fixed; z-index:10001; background:var(--paper); color:var(--ink);
	box-shadow:0 10px 40px rgba(0,0,0,.25); display:flex; flex-direction:column;
	left:50%; top:50%; transform:translate(-50%,-50%);
	width:min(480px,92vw); max-height:80vh; border-radius:14px;
}
.aev-cal-modal__head{
	display:flex; align-items:center; justify-content:space-between; gap:12px;
	padding:16px 18px; border-bottom:1px solid var(--line-soft);
}
.aev-cal-modal__title{ margin:0; font-size:17px; font-weight:600; letter-spacing:-.01em; text-transform:capitalize; }
.aev-cal-modal__close{
	border:0; background:transparent; cursor:pointer; font-size:26px; line-height:1;
	color:var(--muted); padding:2px 6px; border-radius:6px;
}
.aev-cal-modal__close:hover{ color:var(--terra); }
.aev-cal-modal__list{ list-style:none; margin:0; padding:8px 0; overflow-y:auto; }
.aev-cal-di{ border-bottom:1px solid var(--line-soft); }
.aev-cal-di:last-child{ border-bottom:0; }
.aev-cal-di__link,
.aev-cal-di.is-past{ display:flex; gap:12px; align-items:flex-start; padding:12px 18px; text-decoration:none; color:inherit; }
.aev-cal-di__link:hover{ background:var(--terra-tint); }
.aev-cal-di.is-past{ opacity:.6; }
.aev-cal-di__time{ font-weight:700; color:var(--terra); min-width:48px; }
.aev-cal-di__body{ display:flex; flex-direction:column; gap:2px; }
.aev-cal-di__title{ font-size:14px; font-weight:600; }
.aev-cal-di__meta{ font-size:12px; color:var(--muted); }
.aev-cal-di .aev-badge{ margin-left:6px; }
body.aev-modal-open{ overflow:hidden; }

/* dica "toque no dia" â€” sÃ³ mobile */
.aev-cal-hint{ display:none; }

/* mobile: bottom-sheet */
@media (max-width:720px){
	.aev-cal-modal__panel{
		left:0; right:0; bottom:0; top:auto; transform:none;
		width:100%; max-height:75vh; border-radius:16px 16px 0 0;
	}
	.aev-cal-cell.has-events{ cursor:pointer; }
	.aev-cal-hint{ display:block; text-align:center; font-size:13px; color:var(--muted); margin:0 0 12px; }
}
