/**
 * Template PÃƒÆ’Ã‚Â¡gina Principal ÃƒÂ¢Ã¢â€šÂ¬Ã¢â‚¬Å“ Slider a full screen (por baixo do header e do footer)
 */

/* Barras laterais: gradiente azul (#32bebf) ÃƒÂ¢Ã¢â‚¬Â Ã¢â‚¬â„¢ vermelho (#c81f26) */
body.pagina-principal-template {
	position: relative;
}

body.pagina-principal-template::before {
	content: "";
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	width: 10px;
	min-height: 100vh;
	min-height: 100dvh;
	background: linear-gradient(to bottom, #32bebf 0%, #c81f26 100%);
	z-index: 5;
	pointer-events: none;
}

/* iPhone/iOS: barra acompanha overscroll (arrastar para baixo/cima) */
@supports (-webkit-touch-callout: none) {
	body.pagina-principal-template::before {
		top: -300px;
		bottom: -300px;
		min-height: unset;
	}
}

.pagina-principal-slider {
	--header-height: 150px;
	--footer-height: 200px;
	position: relative;
	width: 100vw;
	max-width: 100vw;
	height: 100vh;
	max-height: 100vh;
	overflow: hidden;
	/* Cola ao topo e ocupa toda a largura (por baixo do header) */
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	margin-top: calc(-1 * var(--header-height));
	/* Permite scroll vertical da pÃƒÆ’Ã‚Â¡gina */
	touch-action: auto;
}

/* Overlay preto 40% por cima da imagem do slider */
.pagina-principal-slider::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	pointer-events: none;
	z-index: 1;
}

.pagina-principal-banners {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 100%;
	max-height: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
}

.pagina-principal-banner {
	--banner-bg: none;
	--overlay-opacity: 0.4;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	min-height: 100%;
	max-height: 100%;
	opacity: 0;
	transition: opacity 0.6s ease-in-out;
	pointer-events: none;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #1a1a1a;
	background-image: var(--banner-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-attachment: fixed;
}

.pagina-principal-banner.is-active {
	position: absolute;
	opacity: 1;
	pointer-events: none;
	z-index: 1;
}

.pagina-principal-banner-overlay {
	position: absolute;
	inset: 0;
	background: transparent;
	pointer-events: none;
}

/* ConteÃƒÆ’Ã‚Âºdo (tÃƒÆ’Ã‚Â­tulo + texto) sÃƒÆ’Ã‚Â³ na legenda; nÃƒÆ’Ã‚Â£o mostrar no centro do slide */
.pagina-principal-banner-inner {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	margin: 0;
	padding: 0;
	pointer-events: none;
}

.pagina-principal-banner-titulo {
	margin: 0 0 16px;
	font-size: clamp(28px, 4vw, 44px);
	font-weight: 700;
	line-height: 1.2;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

.pagina-principal-banner-texto {
	font-size: clamp(16px, 2vw, 18px);
	line-height: 1.6;
	opacity: 0.95;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

.pagina-principal-banner-texto p:last-child {
	margin-bottom: 0;
}

.pagina-principal-banner-texto a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Legenda: alinhada a baixo, sempre acima do footer; fundo sem nada */
.pagina-principal-slider-legend {
	position: absolute;
	top: calc(var(--header-height, 150px) + 16px);
	bottom: calc(var(--footer-height, 200px) + -32px);
	left: 60px;
	z-index: 2;
	max-width: 70%;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	pointer-events: none;
	background: none;
	color: #fff;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
	font-family: "Geist", "Helvetica Neue", sans-serif;
	font-weight: 300;
}

/* Por defeito 4 tÃ­tulos (atual + 3 seguintes); ao hover aparecem todos e sÃ£o clicÃ¡veis */
.pagina-principal-slider-legend-titles {
	position: relative;
	display: flex;
	flex-direction: column-reverse;
	gap: 3px;
	margin-bottom: 20px;
	max-width: 100%;
	width: fit-content; /* Zona de hover sÃ³ Ã  largura do texto; entre linhas continua a contar */
	overflow: visible;
	pointer-events: auto;
	transition: gap 0.3s ease-out;
}

.pagina-principal-slider-legend-title {
	font-size: 36px;
	font-weight: 600;
	line-height: 1.15;
	min-height: 1.15em;
	flex-shrink: 0;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.85);
	transition: max-height 0.35s ease-out, opacity 0.35s ease-out, color 0.2s ease, font-size 0.35s ease-out, min-height 0.35s ease-out, margin 0.35s ease-out, padding 0.35s ease-out;
	cursor: pointer;
	overflow: hidden;
	width: fit-content;
	max-width: 100%;
	align-self: flex-start;
}

/* Por defeito: sÃ³ os 4 visÃ­veis; os outros fora do fluxo para nÃ£o somarem gap */
.pagina-principal-slider-legend-title:not(.is-visible) {
	position: absolute;
	left: 0;
	top: 0;
	max-height: 0;
	opacity: 0;
	margin: 0;
	padding: 0;
	min-height: 0;
	line-height: 1.15;
	pointer-events: none;
	overflow: hidden;
}

.pagina-principal-slider-legend-title.is-visible {
	max-height: 1.5em;
	opacity: 1;
	min-height: 1.15em;
}

.pagina-principal-slider-legend-title.is-visible:not(.is-active) {
	color: rgba(255, 255, 255, 0.5);
}

.pagina-principal-slider-legend-title.is-visible:not(.is-active):hover {
	color: rgba(255, 255, 255, 0.95);
}

/* Ao hover: aparecem todos; voltar ao fluxo para o gap ser uniforme */
.pagina-principal-slider-legend-titles:hover .pagina-principal-slider-legend-title {
	position: static;
	pointer-events: auto;
	max-height: 1.5em;
	opacity: 1;
	min-height: 1.15em;
}

.pagina-principal-slider-legend-titles:hover .pagina-principal-slider-legend-title:not(.is-active) {
	color: rgba(255, 255, 255, 0.85);
}

.pagina-principal-slider-legend-titles:hover .pagina-principal-slider-legend-title:not(.is-active):hover {
	color: #fff;
}

.pagina-principal-slider-legend-title.is-active {
	color: #c81f26;
	font-weight: 800;
	font-size: 56px;
	max-height: 2em;
	opacity: 1;
	min-height: 1.15em;
	order: -1; /* Sempre em baixo na lista (column-reverse: order menor = mais em baixo) */
}

/* AnimaÃƒÆ’Ã‚Â§ÃƒÆ’Ã‚Â£o: descer suavemente ao trocar de slide */
@keyframes pagina-principal-legend-slide-in {
	from {
		opacity: 0;
		transform: translateY(-16px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.pagina-principal-slider-legend-text {
	transition: opacity 0.35s ease-out, transform 0.35s ease-out;
}

.pagina-principal-slider-legend-text.legend-updated {
	animation: pagina-principal-legend-slide-in 0.45s ease-out forwards;
}

/* Texto em branco; altura fixa */
.pagina-principal-slider-legend-text {
	margin-top: 10px;
	min-height: 12em;
	height: 8em;
	font-size: 22px;
	font-weight: 500;
	line-height: 1.45;
	letter-spacing: 0.01em;
	color: #fff;
	overflow-y: auto;
	pointer-events: auto;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, 0.5) transparent;
}

.pagina-principal-slider-legend-text::-webkit-scrollbar {
	width: 6px;
}

.pagina-principal-slider-legend-text::-webkit-scrollbar-track {
	background: transparent;
}

.pagina-principal-slider-legend-text::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, 0.4);
	border-radius: 3px;
}

.pagina-principal-slider-legend-text::-webkit-scrollbar-thumb:hover {
	background: rgba(255, 255, 255, 0.6);
}

.pagina-principal-slider-legend-text p:last-child {
	margin-bottom: 0;
}

.pagina-principal-conteudo {
	max-width: var(--theme-content-width, 1200px);
	margin: 0 auto;
	padding: 32px 24px;
}

/* NÃƒÆ’Ã‚Â£o ocupa espaÃƒÆ’Ã‚Â§o quando nÃƒÆ’Ã‚Â£o hÃƒÆ’Ã‚Â¡ conteÃƒÆ’Ã‚Âºdo (editor vazio) */
.pagina-principal-conteudo:empty {
	display: none;
}

/* Zona de conteÃƒÂºdo carregado ao clicar num link do menu (sem mudar de pÃƒÂ¡gina) Ã¢â‚¬â€œ Geist */
.pagina-principal-conteudo-dinamico-wrap,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-voltar,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-wrap,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-titulo,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-descricao,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-descricao p,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-descricao a,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-loading,
.pagina-principal-conteudo-dinamico-wrap .conteudo-dinamico-error {
	font-family: "Geist", "Helvetica Neue", sans-serif !important;
}

.pagina-principal-conteudo-dinamico-wrap {
	position: relative;
	margin: 60px 60px 100px;
}

.pagina-principal-conteudo-dinamico-wrap[hidden] {
	display: none;
}

.conteudo-dinamico-voltar {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 16px;
	padding: 8px 0;
	font-size: 16px;
	line-height: 1;
	color: #c81f26;
	background: none;
	border: none;
	cursor: pointer;
	transition: opacity 0.15s;
}

.conteudo-dinamico-voltar:hover {
	opacity: 0.8;
}

/* Container: texto em cima, media (vÃ­deos + galeria) em baixo */
.conteudo-dinamico-wrap {
	display: flex;
	flex-direction: column;
	gap: 0;
	width: 100%;
}

.conteudo-dinamico-texto {
	min-width: 0;
}

.conteudo-dinamico-titulo {
	margin: 0 0 25px;
	text-transform: uppercase;
	color: #c81f26;
}

.conteudo-dinamico-descricao {
	margin: 0;
	font-size: 20px;
	color: #fff;
}

.conteudo-dinamico-descricao p:first-child {
	margin-top: 0;
}

.conteudo-dinamico-descricao a {
	color: #fff;
}

.conteudo-dinamico-datas-single {
	margin: 0 0 16px 0;
	font-size: 16px;
	color: rgba(255, 255, 255, 0.9);
}

/* SecÃ§Ã£o Media: vÃ­deos + galeria */
.conteudo-dinamico-media-wrap {
	margin-top: 40px;
}

.conteudo-dinamico-media-titulo {
	margin: 0 0 24px 0;
	font-size: 28px;
	font-weight: 600;
	color: #c81f26;
	font-family: "Geist", "Helvetica Neue", sans-serif !important;
}

/* VÃ­deos */
.conteudo-dinamico-videos,
.conteudo-dinamico-video-item,
.conteudo-dinamico-video-titulo {
	font-family: "Geist", "Helvetica Neue", sans-serif !important;
}

.conteudo-dinamico-videos {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-bottom: 32px;
}

.conteudo-dinamico-video-item {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.conteudo-dinamico-video-titulo {
	margin: 0;
	font-size: 20px;
	font-weight: 600;
	color: #c81f26;
}

.conteudo-dinamico-video-embed {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #000;
	border-radius: 4px;
	overflow: hidden;
}

.conteudo-dinamico-video-embed iframe,
.conteudo-dinamico-video-embed video,
.conteudo-dinamico-video-embed embed,
.conteudo-dinamico-video-embed object {
	width: 100%;
	height: 100%;
	border: none;
	display: block;
}

/* Imagens no texto: mini-galeria 1:1, todas na mesma linha, alinhadas Ã  esquerda */
.conteudo-dinamico-descricao table {
	display: block;
	margin: 12px 0;
	border: none;
	overflow-x: auto;
}

.conteudo-dinamico-descricao table tbody {
	display: flex;
	flex-wrap: nowrap;
	gap: 2px;
	justify-content: flex-start;
}

.conteudo-dinamico-descricao table tr {
	display: contents;
}

.conteudo-dinamico-descricao table td {
	display: block;
	padding: 0;
	border: none;
	vertical-align: top;
	flex-shrink: 0;
}

.conteudo-dinamico-descricao table td a {
	display: block;
	line-height: 0;
}

.conteudo-dinamico-descricao table img,
.conteudo-dinamico-descricao p img {
	width: 100px;
	height: 100px;
	object-fit: cover;
	border-radius: 4px;
	display: block;
	vertical-align: top;
	cursor: pointer;
	margin: 0 !important; /* anula aligncenter / alignleft do WordPress */
}

.conteudo-dinamico-descricao .aligncenter,
.conteudo-dinamico-descricao .alignleft,
.conteudo-dinamico-descricao img.aligncenter,
.conteudo-dinamico-descricao img.alignleft {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* ParÃ¡grafo com vÃ¡rias imagens: em linha, pouco espaÃ§o, 100x100, alinhadas Ã  esquerda */
.conteudo-dinamico-descricao p:has(> img) {
	display: flex;
	flex-wrap: nowrap;
	gap: 25px;
	align-items: flex-start;
	justify-content: flex-start;
	margin: 50px 0;
	overflow-x: auto;
	text-align: left;
}

.conteudo-dinamico-descricao p:has(> img) img {
	flex-shrink: 0;
}

.conteudo-dinamico-descricao p:has(> img:only-child),
.conteudo-dinamico-descricao p:has(> a:only-child > img) {
	display: inline-flex;
	margin: 4px 4px 4px 0;
}

.conteudo-dinamico-descricao p:has(> img:only-child) + p:has(> img:only-child),
.conteudo-dinamico-descricao p:has(> a:only-child > img) + p:has(> a:only-child > img) {
	margin-left: 0;
}

.conteudo-dinamico-galeria-titulo {
	margin: 0 0 16px 0;
	font-size: 20px;
	font-weight: 600;
	color: #c81f26;
	font-family: "Geist", "Helvetica Neue", sans-serif !important;
}

.conteudo-dinamico-galeria {
	width: 100%;
	max-width: 800px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
}

.conteudo-dinamico-galeria-link {
	display: block;
	cursor: pointer;
	border-radius: 4px;
	overflow: hidden;
}

.conteudo-dinamico-galeria-link:focus {
	outline: 2px solid #c81f26;
	outline-offset: 2px;
}

.conteudo-dinamico-galeria img {
	width: 100%;
	aspect-ratio: 1;
	max-width: 150px;
	object-fit: cover;
	display: block;
	border-radius: 4px;
}

.conteudo-dinamico-galeria-link:only-child {
	grid-column: 1 / -1;
}

/* Agenda em accordions (#!agenda) */
.conteudo-dinamico-agenda-lista .conteudo-dinamico-titulo {
	margin-bottom: 24px;
}

.conteudo-dinamico-accordion {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.conteudo-dinamico-accordion-item {
	margin: 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.conteudo-dinamico-accordion-item:last-child {
	border-bottom: none;
}

.conteudo-dinamico-accordion-heading {
	margin: 0;
}

.conteudo-dinamico-accordion-trigger {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 16px;
	width: 100%;
	padding: 5px;
	text-align: left;
	color: #fff;
	background: transparent;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.3;
	position: relative;
	transition: color 0.2s ease, background 0.2s ease;
}

.conteudo-dinamico-accordion-trigger:hover,
.conteudo-dinamico-accordion-trigger:focus {
	color: #c81f26;
	outline: none;
}

.conteudo-dinamico-accordion-trigger-datas {
	font-size: 14px;
	font-weight: 400;
	opacity: 0.9;
}

.conteudo-dinamico-accordion-icon {
	position: absolute;
	right: 16px;
	top: 45%;
	transform: translateY(-50%);
	width: 10px;
	height: 10px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-60%) rotate(45deg);
	transition: transform 0.25s ease;
}

.conteudo-dinamico-accordion-trigger[aria-expanded="true"] .conteudo-dinamico-accordion-icon {
	transform: translateY(15%) rotate(-135deg);
}

.conteudo-dinamico-accordion-panel {
	overflow: hidden;
}

.conteudo-dinamico-accordion-panel[hidden] {
	display: none;
}

.conteudo-dinamico-accordion-panel-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
	padding: 20px 0 24px;
}

.conteudo-dinamico-accordion-datas-panel {
	grid-column: 1 / -1;
	margin: 0 0 4px 0;
	font-size: 14px;
	font-weight: 600;
	color: #c81f26;
	opacity: 0.95;
}

@media (min-width: 640px) {
	.conteudo-dinamico-accordion-panel-inner {
		gap: 24px;
		align-items: start;
	}
}

.conteudo-dinamico-accordion-thumbnail {
	position: relative;
	border-radius: 8px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.08);
}

.conteudo-dinamico-accordion-thumbnail img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (min-width: 640px) {
	.conteudo-dinamico-accordion-thumbnail {
		max-height: 300px;
		max-width: 100vw;
	}
}

.conteudo-dinamico-accordion-descricao {
	margin: 0;
	font-size: 15px;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.95);
	min-width: 0; /* evita overflow em grid */
}

.conteudo-dinamico-accordion-descricao p {
	margin-top: 0;
	margin-bottom: 0.75em;
}

.conteudo-dinamico-accordion-descricao p:last-child {
	margin-bottom: 0;
}

.conteudo-dinamico-accordion-descricao .event-field-container {
	padding: 12px 16px;
	background: rgba(255, 255, 255, 0.06);
	border-radius: 6px;
	border-left: 3px solid #c81f26;
}

.conteudo-dinamico-accordion-descricao .event-field {
	margin: 0 0 4px 0;
	font-size: 0.95em;
}

.conteudo-dinamico-accordion-descricao .event-field-desc {
	margin: 0;
	font-size: 0.9em;
	opacity: 0.92;
}

.conteudo-dinamico-accordion-descricao .event-field-desc p {
	margin: 2px 0;
}

.conteudo-dinamico-accordion-link-wrap {
	margin: 0;
}

.conteudo-dinamico-accordion-ver-mais {
	color: #c81f26;
	text-decoration: none;
	font-weight: 500;
}

.conteudo-dinamico-accordion-ver-mais:hover,
.conteudo-dinamico-accordion-ver-mais:focus {
	text-decoration: underline;
	outline: none;
}

.conteudo-dinamico-agenda-vazio {
	margin: 0;
	opacity: 0.9;
}

.conteudo-dinamico-galeria img:only-child {
	grid-column: 1 / -1;
}

/* Sem galeria visÃƒÆ’Ã‚Â­vel: sÃƒÆ’Ã‚Â³ o container de texto */
.conteudo-dinamico-galeria:empty {
	display: none;
}

.conteudo-dinamico-wrap:has(.conteudo-dinamico-galeria:empty) {
	grid-template-columns: 1fr;
}

/* ConteÃºdo dinÃ¢mico: mobile */
@media (max-width: 768px) {
	.pagina-principal-conteudo-dinamico-wrap {
		margin: 16px 16px 160px;
		padding: 0 8px;
	}

	.conteudo-dinamico-voltar {
		margin-bottom: 12px;
		font-size: 15px;
	}

	.conteudo-dinamico-wrap {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	.conteudo-dinamico-titulo {
		font-size: clamp(20px, 5vw, 28px);
		margin: 0 0 16px;
		line-height: 1.2;
		word-wrap: break-word;
	}

	.conteudo-dinamico-descricao {
		font-size: 16px;
		line-height: 1.5;
	}

	.conteudo-dinamico-descricao p {
		margin-bottom: 16px;
	}

	.conteudo-dinamico-galeria {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}

	.conteudo-dinamico-descricao table img,
	.conteudo-dinamico-descricao p img {
		width: 80px;
		height: 80px;
	}

	.conteudo-dinamico-descricao p:has(> img) {
margin: 8px 0;
	gap: 6px;
	}

	.conteudo-dinamico-media-wrap {
		margin-top: 24px;
	}

	.conteudo-dinamico-media-titulo {
		font-size: 24px;
		margin-bottom: 16px;
	}

	.conteudo-dinamico-videos {
		gap: 16px;
		grid-template-columns: 1fr;
		margin-bottom: 20px;
	}

	.conteudo-dinamico-video-titulo {
		font-size: 18px;
	}
}

.conteudo-dinamico-loading,
.conteudo-dinamico-error {
	color: inherit;
	margin: 0;
}

/* Modal da galeria: lightbox com navegaÃƒÂ§ÃƒÂ£o anterior/seguinte */
.conteudo-dinamico-galeria-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.9);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease, visibility 0.2s ease;
}

.conteudo-dinamico-galeria-modal.is-open {
	opacity: 1;
	visibility: visible;
}

.conteudo-dinamico-galeria-modal-inner {
	position: relative;
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.conteudo-dinamico-galeria-modal-img {
	max-width: 100%;
	max-height: 90vh;
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}

.conteudo-dinamico-galeria-modal-fechar,
.conteudo-dinamico-galeria-modal-prev,
.conteudo-dinamico-galeria-modal-next {
	position: absolute;
	z-index: 2;
	width: 48px;
	height: 48px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 32px;
	line-height: 1;
	color: #fff;
	background: rgba(0, 0, 0, 0.4);
	border: none;
	border-radius: 4px;
	cursor: pointer;
	transition: background 0.15s;
}

.conteudo-dinamico-galeria-modal-fechar:hover,
.conteudo-dinamico-galeria-modal-prev:hover,
.conteudo-dinamico-galeria-modal-next:hover {
	background: rgba(200, 31, 38, 0.8);
}

.conteudo-dinamico-galeria-modal-fechar {
	top: 16px;
	right: 16px;
	font-size: 40px;
}

.conteudo-dinamico-galeria-modal-prev {
	left: 16px;
	top: 50%;
	transform: translateY(-50%);
}

.conteudo-dinamico-galeria-modal-next {
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
}

.conteudo-dinamico-galeria-modal-prev:focus,
.conteudo-dinamico-galeria-modal-next:focus,
.conteudo-dinamico-galeria-modal-fechar:focus {
	outline: 2px solid #c81f26;
	outline-offset: 2px;
}

/* Footer por cima do slide (fixo no fundo do ecrÃƒÆ’Ã‚Â£) ÃƒÂ¢Ã¢â€šÂ¬Ã¢â‚¬Å“ sÃƒÆ’Ã‚Â³ no template PÃƒÆ’Ã‚Â¡gina Principal */
body.pagina-principal-template {
	--footer-height: 200px;
}

body.pagina-principal-template #footer {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 10;
}

/* Controlos do slider no footer, lado direito ÃƒÂ¢Ã¢â€šÂ¬Ã¢â‚¬Å“ maiores e em vermelho */
.pagina-principal-slider-controls {
	position: fixed;
	bottom: 16px;
	right: 16px;
	z-index: 11;
	display: flex;
	align-items: center;
	gap: 8px;
	pointer-events: auto;
}

.pagina-principal-slider-btn {
	width: 44px;
	height: 44px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	line-height: 1;
	color: #c81f26;
	background: transparent;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	transition: color 0.15s, opacity 0.15s;
	pointer-events: auto;
}

.pagina-principal-slider-btn:hover {
	color: #e82a32;
	opacity: 1;
}

.pagina-principal-slider-btn:focus {
	outline: none;
}

/* Mobile (< 1024px): setas e pausa por baixo do texto da legenda */
@media (max-width: 1024px) {
	.pagina-principal-slider-legend .pagina-principal-slider-controls {
		position: static;
		margin-top: 48px;
		align-self: flex-start;
		order: 10;
		pointer-events: auto;
	}
}

/* Sem padding-bottom no main: o conteÃƒÂºdo ÃƒÂ© sÃƒÂ³ o slider (100vh) e o footer ÃƒÂ© fixo por cima */
body.pagina-principal-template main {
	padding-bottom: 0;
}

@media (max-width: 1024px) {
	/* Legenda: alinhada a baixo, sempre acima do footer */
	.pagina-principal-slider-legend {
		left: 30px;
		max-width: 90%;
		bottom: calc(var(--footer-height, 200px) + 32px);
	}
	.pagina-principal-slider-legend-title.is-active {
		font-size: 28px;
	}
	.pagina-principal-slider-legend-title {
		font-size: 20px;
	}
	.pagina-principal-slider-legend-active-title {
	    height: 2.5em;
	    font-size: 40px;
	    color: #c81f26;
	}
	.pagina-principal-slider-legend-text {
	    font-size: 16px;
	    font-weight: 500;
	    color: #fff;
	}
	.pagina-principal-slider-legend-text:empty {
		height: 0;
		min-height: 0;
		margin: 0;
		padding: 0;
		overflow: hidden;
		border: none;
	}
}

/* Slider + legenda: mobile */
@media (max-width: 768px) {
	body.pagina-principal-template::before {
		width: 6px;
	}

	.pagina-principal-slider {
		--header-height: 100px;
		--footer-height: 120px;
	}

	.pagina-principal-banner {
		background-attachment: scroll;
	}

	.pagina-principal-slider-legend {
		left: 16px;
		right: 16px;
		max-width: none;
		top: calc(var(--header-height, 80px) + 8px);
		bottom: calc(var(--footer-height, 120px) + 96px);
		padding: 0;
	}

	.pagina-principal-slider-legend-titles {
		margin-bottom: 12px;
		gap: 2px;
	}

	/* Mobile fechado: mostrar ativo + 3 seguintes (is-visible); 1º toque = abrir */
	.pagina-principal-slider-legend-titles:not(.is-expanded) .pagina-principal-slider-legend-title:not(.is-visible) {
		position: absolute;
		left: 0;
		top: 0;
		max-height: 0;
		opacity: 0;
		margin: 0;
		padding: 0;
		min-height: 0;
		pointer-events: none;
		overflow: hidden;
	}

	/* Mobile expandido: mostrar todos os títulos (2º toque = trocar slide) */
	.pagina-principal-slider-legend-titles.is-expanded .pagina-principal-slider-legend-title {
		position: static;
		pointer-events: auto;
		max-height: 1.3em;
		opacity: 1;
		min-height: 1.1em;
	}

	.pagina-principal-slider-legend-titles.is-expanded .pagina-principal-slider-legend-title:not(.is-active) {
		color: rgba(255, 255, 255, 0.85);
	}

	.pagina-principal-slider-legend-title.is-active {
		font-size: 24px;
		max-height: 1.4em;
	}

	.pagina-principal-slider-legend-title.is-visible {
		max-height: 1.3em;
		min-height: 1.1em;
	}

	.pagina-principal-slider-legend-title {
		font-size: 18px;
		cursor: pointer;
	}

	.pagina-principal-slider-legend-text {
		font-size: 16px;
		line-height: 1.45;
		min-height: 10em;
		height: auto;
		max-height: 6em;
	}

	.pagina-principal-slider-legend-text:empty {
		min-height: 0;
		height: 0;
		max-height: 0;
	}
}