/**
 * Components CSS — Ader-al Theme
 * Componentes reutilizáveis: cards, badges, widgets, formulários CF7, etc.
 *
 * @package ader-al
 */

/* ═══════════════════════════════════════════════════
   BADGES / TAGS
═══════════════════════════════════════════════════ */
.badge {
	display: inline-block;
	padding: 0.25em 0.75em;
	font-size: 0.75rem;
	font-weight: var(--ader-font-weight-semi);
	border-radius: var(--ader-radius-full);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	line-height: 1.4;
}

.badge-primary {
	background: var(--ader-primary);
	color: var(--ader-text-light);
}

.badge-secondary {
	background: var(--ader-secondary);
	color: var(--ader-text);
}

/* ═══════════════════════════════════════════════════
   WIDGETS DA SIDEBAR
═══════════════════════════════════════════════════ */
.widget {
	margin-bottom: var(--ader-space-xl);
}

.widget-title {
	font-size: 1rem;
	font-weight: var(--ader-font-weight-bold);
	color: var(--ader-primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding-bottom: var(--ader-space-sm);
	border-bottom: 2px solid var(--ader-secondary);
	margin-bottom: var(--ader-space-md);
}

/* ═══════════════════════════════════════════════════
   CONTACT FORM 7
═══════════════════════════════════════════════════ */
.cf7-row {
	display: flex;
	gap: var(--ader-space-md);
	margin-bottom: 0;
}

.cf7-col {
	flex: 1;
}

@media (max-width: 600px) {
	.cf7-row {
		flex-direction: column;
	}
}

.wpcf7-form .wpcf7-form-control-wrap {
	display: block;
	margin-bottom: var(--ader-space-md);
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form select,
.wpcf7-form textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--ader-border);
	border-radius: var(--ader-radius-md);
	font-family: var(--ader-font);
	font-size: 0.95rem;
	color: var(--ader-text);
	background: var(--ader-bg);
	transition: border-color var(--ader-transition-fast), box-shadow var(--ader-transition-fast);
	appearance: none;
}

.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
	outline: none;
	border-color: var(--ader-primary);
	box-shadow: 0 0 0 3px rgba(40, 62, 137, 0.1);
}

.wpcf7-form textarea {
	min-height: 140px;
	resize: vertical;
}

.wpcf7-form label {
	display: block;
	font-size: 0.875rem;
	font-weight: var(--ader-font-weight-medium);
	margin-bottom: var(--ader-space-xs);
	color: var(--ader-text);
}

.wpcf7-form input[type="submit"],
.wpcf7-submit {
	background: var(--ader-primary);
	color: var(--ader-text-light);
	border: none;
	padding: 0.85rem 2rem;
	border-radius: var(--ader-radius-md);
	font-family: var(--ader-font);
	font-size: 0.95rem;
	font-weight: var(--ader-font-weight-semi);
	cursor: pointer;
	transition: background var(--ader-transition-fast), transform var(--ader-transition-fast);
}

.wpcf7-form input[type="submit"]:hover {
	background: var(--ader-primary-dark);
	transform: translateY(-1px);
}

.wpcf7-not-valid-tip {
	color: #dc3545;
	font-size: 0.8rem;
	margin-top: var(--ader-space-xs);
}

.wpcf7-response-output {
	display: none;
	padding: var(--ader-space-md);
	border-radius: var(--ader-radius-md);
	margin-top: var(--ader-space-md);
	font-size: 0.9rem;
}

/* CF7 6.x — classes de estado no <form>, não no response-output */
form.sent .wpcf7-response-output,
form.failed .wpcf7-response-output,
form.invalid .wpcf7-response-output,
form.unaccepted .wpcf7-response-output,
form.spam .wpcf7-response-output,
form.aborted .wpcf7-response-output {
	display: block;
}

form.sent .wpcf7-response-output {
	background: #d4edda;
	border: 1px solid #c3e6cb;
	color: #155724;
}

form.failed .wpcf7-response-output,
form.spam .wpcf7-response-output,
form.aborted .wpcf7-response-output {
	background: #f8d7da;
	border: 1px solid #f5c6cb;
	color: #721c24;
}

form.invalid .wpcf7-response-output,
form.unaccepted .wpcf7-response-output {
	background: #fff3cd;
	border: 1px solid #ffeeba;
	color: #856404;
}

/* ═══════════════════════════════════════════════════
   PAGINAÇÃO
═══════════════════════════════════════════════════ */
.page-links,
.posts-navigation,
.post-navigation {
	margin: var(--ader-space-2xl) 0;
}

.nav-links {
	display: flex;
	gap: var(--ader-space-md);
	justify-content: space-between;
}

.nav-previous a,
.nav-next a {
	display: inline-flex;
	align-items: center;
	gap: var(--ader-space-sm);
	font-weight: var(--ader-font-weight-medium);
	color: var(--ader-primary);
}

/* ═══════════════════════════════════════════════════
   CONTEÚDO DO EDITOR (GUTENBERG + CLÁSSICO)
═══════════════════════════════════════════════════ */
.entry-content h2,
.entry-content h3,
.entry-content h4 {
	margin-top: var(--ader-space-2xl);
	margin-bottom: var(--ader-space-md);
	color: var(--ader-primary);
}

.entry-content h2:first-child,
.entry-content h3:first-child {
	margin-top: 0;
}

.entry-content ul,
.entry-content ol {
	margin-bottom: var(--ader-space-lg);
}

.entry-content a {
	color: var(--ader-primary);
	text-decoration: underline;
}

.entry-content img {
	border-radius: var(--ader-radius-md);
	margin: var(--ader-space-lg) 0;
}

.entry-content .wp-block-image figcaption,
.entry-content figcaption {
	font-size: 0.8rem;
	color: var(--ader-text-muted);
	text-align: center;
	margin-top: var(--ader-space-sm);
}

/* Alinhamentos Gutenberg */
.entry-content .alignwide {
	margin-left: calc(-1 * var(--ader-space-2xl));
	margin-right: calc(-1 * var(--ader-space-2xl));
}

.entry-content .alignfull {
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	width: 100vw;
	max-width: 100vw;
}

.entry-content .alignleft {
	float: left;
	margin-right: var(--ader-space-xl);
	margin-bottom: var(--ader-space-md);
}

.entry-content .alignright {
	float: right;
	margin-left: var(--ader-space-xl);
	margin-bottom: var(--ader-space-md);
}

/* ═══════════════════════════════════════════════════
   HEADER INTERIOR — META DA PÁGINA
═══════════════════════════════════════════════════ */
.post-thumbnail {
	margin-bottom: var(--ader-space-xl);
	border-radius: var(--ader-radius-lg);
	overflow: hidden;
	max-width: 400px;
}

.post-thumbnail img {
	width: 100%;
	height: auto;
	display: block;
}

.entry-meta {
	display: flex;
	align-items: center;
	gap: var(--ader-space-md);
	font-size: 0.875rem;
	color: var(--ader-text-muted);
	margin-bottom: var(--ader-space-xl);
	padding-bottom: var(--ader-space-md);
	border-bottom: 1px solid var(--ader-border);
}

/* ═══════════════════════════════════════════════════
   EVENTOS — DETALHE
═══════════════════════════════════════════════════ */
.evento-thumbnail {
	margin-bottom: var(--ader-space-xl);
	border-radius: var(--ader-radius-md);
	overflow: hidden;
}

.evento-thumbnail img {
	width: 100%;
	height: auto;
	display: block;
}

.evento-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ader-space-md);
	margin-bottom: var(--ader-space-xl);
}

.evento-meta-item {
	display: inline-flex;
	align-items: center;
	gap: var(--ader-space-sm);
	background: var(--ader-secondary);
	color: var(--ader-primary);
	padding: var(--ader-space-sm) var(--ader-space-lg);
	border-radius: var(--ader-radius-full);
	font-size: 0.875rem;
	font-weight: var(--ader-font-weight-semi);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.evento-inscricao {
	margin-top: var(--ader-space-2xl);
	padding-top: var(--ader-space-xl);
	border-top: 1px solid var(--ader-border);
}

/* ═══════════════════════════════════════════════════
   BOAS PRÁTICAS — GRELHA DE VÍDEOS
═══════════════════════════════════════════════════ */

.boas-praticas-wrap {
	padding-top: var(--ader-space-2xl);
	padding-bottom: var(--ader-space-2xl);
}

.bp-video-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ader-space-xl);
}

.bp-video-card {
	background: var(--ader-bg-alt);
	border-radius: var(--ader-radius-md);
	overflow: hidden;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	outline: none;
}

.bp-video-card:hover,
.bp-video-card:focus-visible {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0,0,0,.15);
}

.bp-video-thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #000;
}

.bp-video-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: opacity 0.2s ease;
}

.bp-video-card:hover .bp-video-thumb img {
	opacity: 0.85;
}

.bp-play-btn {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}

.bp-play-btn svg {
	filter: drop-shadow(0 2px 8px rgba(0,0,0,.4));
	transition: transform 0.2s ease;
}

.bp-video-card:hover .bp-play-btn svg {
	transform: scale(1.1);
}

.bp-video-info {
	padding: var(--ader-space-md) var(--ader-space-lg);
}

.bp-video-title {
	font-size: 0.95rem;
	font-weight: var(--ader-font-weight-semi);
	color: var(--ader-text);
	line-height: 1.4;
	margin: 0;
}

/* ── LIGHTBOX ───────────────────────────────────── */

.bp-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.bp-lightbox[hidden] {
	display: none;
}

.bp-lightbox-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.85);
}

.bp-lightbox-inner {
	position: relative;
	z-index: 1;
	width: 90%;
	max-width: 900px;
	background: #000;
	border-radius: var(--ader-radius-md);
	overflow: hidden;
	box-shadow: 0 24px 64px rgba(0,0,0,.6);
}

.bp-lightbox-title-bar {
	background: var(--ader-primary);
	padding: 10px 48px 10px 16px;
}

.bp-lightbox-title-text {
	color: #fff;
	font-size: 0.9rem;
	font-weight: var(--ader-font-weight-semi);
}

.bp-lightbox-close {
	position: absolute;
	top: 6px;
	right: 8px;
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 4px;
	line-height: 1;
	z-index: 2;
}

.bp-lightbox-video {
	aspect-ratio: 16 / 9;
}

.bp-lightbox-video iframe {
	width: 100%;
	height: 100%;
	display: block;
}

/* ── RESPONSIVE ─────────────────────────────────── */

@media (max-width: 900px) {
	.bp-video-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 560px) {
	.bp-video-grid {
		grid-template-columns: 1fr;
	}
}

/* ═══════════════════════════════════════════════════
   PÁGINA 404
═══════════════════════════════════════════════════ */
.error-404 {
	min-height: 60vh;
	display: flex;
	align-items: center;
}

.error-404-inner {
	text-align: center;
	padding: var(--ader-space-4xl) 0;
}

.error-404-inner h1 {
	font-size: clamp(2rem, 5vw, 4rem);
	color: var(--ader-primary);
	margin-bottom: var(--ader-space-md);
}

.error-404-inner p {
	color: var(--ader-text-muted);
	margin-bottom: var(--ader-space-xl);
}

/* ═══════════════════════════════════════════════════
   SLIDER DE NOTÍCIAS (quando > 3 artigos)
═══════════════════════════════════════════════════ */
.noticias-slider-wrapper,
.avisos-slider-wrapper {
	position: relative;
	overflow: hidden;
}

.noticias-slider-track,
.avisos-slider-track {
	display: flex;
	transition: transform 0.5s ease;
}

.noticias-slider-track .noticia-card,
.avisos-slider-track .noticia-card {
	flex: 0 0 calc(33.333% - var(--ader-space-lg));
	margin-right: var(--ader-space-xl);
}

/* Imagem dos avisos — preenche largura total do card */
.avisos-section .noticia-card-img img,
.avisos-slider-track .noticia-card-img img {
	object-fit: cover;
	width: 100%;
	height: 100% !important;
}

.aviso-single-imagem {
	margin-bottom: var(--ader-space-xl);
	border-radius: var(--ader-radius-lg);
	overflow: hidden;
	max-width: 500px;
}

.aviso-single-imagem img {
	display: block;
	width: 100%;
	height: auto;
}

.aviso-single-medida {
	font-size: 1.5rem;
	font-weight: var(--ader-font-weight-bold);
	color: var(--ader-text);
	margin: 0 0 var(--ader-space-lg);
}

.aviso-single-datas {
	display: flex;
	flex-direction: column;
	gap: var(--ader-space-sm);
	margin-bottom: var(--ader-space-xl);
}

.aviso-single-descricao {
	margin-top: var(--ader-space-xl);
}

/* Nome do programa no card de aviso — pill cor secundária */
.aviso-card-programa {
	display: inline-flex;
	align-items: center;
	background: var(--ader-secondary);
	color: var(--ader-primary);
	padding: var(--ader-space-sm) var(--ader-space-lg);
	border-radius: var(--ader-radius-full);
	font-size: 0.8rem;
	font-weight: var(--ader-font-weight-semi);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--ader-space-sm);
}

/* Datas de abertura/fim nos cards e single de avisos */
.aviso-card-datas,
.aviso-datas-destaque {
	display: flex;
	gap: 8px;
	margin: var(--ader-space-sm) 0;
	flex-wrap: wrap;
}

.aviso-data-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: var(--ader-space-sm) var(--ader-space-lg);
	border-radius: var(--ader-radius-full);
	font-size: 0.875rem;
	font-weight: var(--ader-font-weight-semi);
}

.aviso-data-abertura {
	background: #2e7d32;
	color: #fff;
}

.aviso-data-fim {
	background: #e65100;
	color: #fff;
}

.aviso-data-label {
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.75rem;
	opacity: 0.85;
}

.aviso-data-label::after {
	content: ':';
}

.aviso-data-valor {
	font-weight: var(--ader-font-weight-bold);
}

.slider-controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--ader-space-md);
	margin-top: var(--ader-space-xl);
}

.slider-btn {
	width: 40px;
	height: 40px;
	border-radius: var(--ader-radius-full);
	border: 2px solid var(--ader-primary);
	background: transparent;
	color: var(--ader-primary);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	transition: background var(--ader-transition-fast), color var(--ader-transition-fast);
}

.slider-btn:hover {
	background: var(--ader-primary);
	color: var(--ader-text-light);
}

/* ═══════════════════════════════════════════════════
   LOADING / TRANSIÇÕES DE PÁGINA
═══════════════════════════════════════════════════ */
.page-loader {
	position: fixed;
	inset: 0;
	background: var(--ader-bg);
	z-index: calc(var(--ader-z-modal) + 1);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.4s ease;
}

.page-loader.is-hidden {
	opacity: 0;
	pointer-events: none;
}

.loader-spinner {
	width: 40px;
	height: 40px;
	border: 3px solid var(--ader-border);
	border-top-color: var(--ader-primary);
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

/* ═══════════════════════════════════════════════════
   BREADCRUMB
═══════════════════════════════════════════════════ */
.breadcrumb {
	margin-bottom: var(--ader-space-sm);
}

.breadcrumb-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
}

.breadcrumb-item {
	font-size: 0.8rem;
	color: rgba(255,255,255,0.7);
	margin: 0;
}

.breadcrumb-item a {
	color: rgba(255,255,255,0.8);
	text-decoration: none;
}

.breadcrumb-item a:hover {
	color: var(--ader-secondary);
}

.breadcrumb-item--active span {
	color: var(--ader-secondary);
}

/* Ícone das secções de números */
.numero-icone {
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--ader-space-md);
}

/* ═══════════════════════════════════════════════════
   MAPA INTERATIVO ADER-AL
═══════════════════════════════════════════════════ */
.mapa-ader-wrapper {
	position: relative;
	width: 100%;
	max-width: 700px;
	margin: 2rem auto;
}

.mapa-ader-svg {
	width: 100%;
	height: auto;
	display: block;
}

.mapa-concelho {
	stroke: #ffffff;
	stroke-width: 25;
	transition: fill 0.2s ease, filter 0.2s ease;
}

.mapa-concelho--active {
	fill: #7b9dd4;
	cursor: pointer;
}

.mapa-concelho--inactive {
	fill: #dde3ef;
	cursor: default;
}

.mapa-concelho--active:hover,
.mapa-concelho--active:focus {
	fill: var(--ader-primary);
	filter: drop-shadow(0 0 6px rgba(40, 62, 137, 0.35));
	outline: none;
}

.mapa-tooltip {
	position: absolute;
	background: #ffffff;
	border: 1px solid var(--ader-border, #e0e0e0);
	border-radius: 8px;
	padding: 12px 16px;
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.12);
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.15s ease;
	z-index: 100;
	min-width: 200px;
	max-width: 280px;
}

.mapa-tooltip.is-visible {
	opacity: 1;
}

.mapa-tooltip strong {
	display: block;
	font-size: 0.95rem;
	color: var(--ader-primary, #283e89);
	margin-bottom: 8px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--ader-secondary, #f5c824);
}

.mapa-tooltip ul {
	margin: 0;
	padding-left: 16px;
	font-size: 0.78rem;
	color: var(--ader-text, #212529);
	line-height: 1.6;
}

.mapa-legenda {
	display: flex;
	gap: 1.5rem;
	justify-content: center;
	margin-top: 1rem;
	flex-wrap: wrap;
}

.mapa-legenda-item {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.82rem;
	color: var(--ader-text, #212529);
}

.mapa-legenda-item::before {
	content: '';
	display: inline-block;
	width: 16px;
	height: 16px;
	border-radius: 3px;
	border: 1px solid rgba(0,0,0,0.1);
}

.mapa-legenda-item--active::before {
	background: #7b9dd4;
}

.mapa-legenda-item--inactive::before {
	background: #dde3ef;
}

/* ═══════════════════════════════════════════════════
   EQUIPA TÉCNICA — ORGANOGRAMA
═══════════════════════════════════════════════════ */

/* Variáveis locais do organograma */
.org-chart {
	--org-node-w: 160px;
	--org-gap: 48px;
	--org-h: 40px;          /* altura dos conectores */
	--org-line: 2px;
	--org-color: var(--ader-primary);

	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 2rem 0 3rem;
}

/* ── Linhas / conectores ── */

.org-row {
	display: flex;
	justify-content: center;
	gap: var(--org-gap);
	position: relative;
	width: 100%;
}

/* Linha vertical do topo até à barra */
.org-row--bottom {
	margin-top: calc(2 * var(--org-h));
}

.org-row--bottom::after {
	content: '';
	position: absolute;
	top: calc(-2 * var(--org-h));
	left: 50%;
	transform: translateX(-50%);
	width: var(--org-line);
	height: var(--org-h);
	background: var(--org-color);
}

/* Barra horizontal */
.org-row--bottom::before {
	content: '';
	position: absolute;
	top: calc(-1 * var(--org-h));
	left: 50%;
	transform: translateX(-50%);
	width: calc((var(--org-n, 4) - 1) * (var(--org-node-w) + var(--org-gap)));
	height: var(--org-line);
	background: var(--org-color);
}

/* Linha vertical de cada nó até à barra */
.org-row--bottom .org-node {
	position: relative;
}
.org-row--bottom .org-node::before {
	content: '';
	position: absolute;
	top: calc(-1 * var(--org-h));
	left: 50%;
	transform: translateX(-50%);
	width: var(--org-line);
	height: var(--org-h);
	background: var(--org-color);
}

/* ── Card do membro ── */

.org-node {
	width: var(--org-node-w);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.org-node__photo {
	width: 110px;
	height: 110px;
	border-radius: 50%;
	overflow: hidden;
	border: 3px solid var(--ader-primary);
	background: #e9ecef;
	flex-shrink: 0;
}

.org-node__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.org-node__photo-placeholder {
	width: 100%;
	height: 100%;
	background: var(--ader-primary);
	opacity: 0.2;
}

.org-node__info {
	margin-top: 10px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 3px;
}

.org-node__nome {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--ader-primary);
	line-height: 1.3;
}

.org-node__cargo {
	font-size: 0.75rem;
	color: #666;
	line-height: 1.3;
}

.org-node__email {
	font-size: 0.7rem;
	color: var(--ader-primary);
	text-decoration: none;
	word-break: break-all;
}

.org-node__email:hover {
	text-decoration: underline;
}

/* ── Responsivo ── */

@media (max-width: 768px) {
	.org-chart {
		--org-node-w: 110px;
		--org-gap: 16px;
		--org-h: 28px;
	}
	.org-node__photo {
		width: 86px;
		height: 86px;
	}
}

@media (max-width: 540px) {
	.org-row {
		flex-wrap: wrap;
	}
	.org-row--bottom {
		flex-direction: column;
		align-items: center;
		margin-top: 16px;
		padding-top: 16px;
		border-top: 2px solid var(--ader-primary);
	}
	.org-row--bottom::before,
	.org-row--bottom::after,
	.org-row--bottom .org-node::before {
		display: none;
	}
	.org-node {
		width: 160px;
	}
}

/* ═══════════════════════════════════════════════════
   AVISO CARD — novo design Figma
═══════════════════════════════════════════════════ */
.avisos-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ader-space-lg);
}

.avisos-grid--single {
	grid-template-columns: 1fr;
	max-width: 420px;
	margin-inline: auto;
}

.avisos-grid--double {
	grid-template-columns: repeat(2, minmax(0, 380px));
	justify-content: center;
}

.aviso-card {
	background: #f8f9fa;
	border-radius: var(--ader-radius-lg);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.07);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.aviso-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.11);
}

.aviso-card-img {
	overflow: hidden;
	border-radius: var(--ader-radius-lg) var(--ader-radius-lg) 0 0;
	aspect-ratio: 16 / 9;
}

.aviso-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.aviso-card:hover .aviso-card-img img {
	transform: scale(1.04);
}

.aviso-card-body {
	padding: var(--ader-space-xl) var(--ader-space-xl) var(--ader-space-lg);
	display: flex;
	flex-direction: column;
	flex: 1;
}

.aviso-card-medida {
	font-size: 1.25rem;
	font-weight: var(--ader-font-weight-bold);
	color: var(--ader-text);
	margin: 0 0 var(--ader-space-md);
	line-height: 1.2;
}

.aviso-card-titulo {
	font-size: 1rem;
	font-weight: var(--ader-font-weight-medium);
	color: var(--ader-text);
	margin: 0 0 var(--ader-space-lg);
	line-height: 1.4;
}

.aviso-card-titulo a {
	color: inherit;
	text-decoration: none;
}

.aviso-card-titulo a:hover {
	color: var(--ader-primary);
}

.aviso-card-divider {
	border: none;
	border-top: 2px solid var(--ader-primary);
	margin: 0 0 var(--ader-space-lg);
	width: 60%;
}

.aviso-card-datas {
	display: flex;
	flex-direction: column;
	gap: var(--ader-space-sm);
	margin-top: auto;
}

.aviso-data-dot {
	display: flex;
	align-items: center;
	gap: var(--ader-space-sm);
	font-size: 0.875rem;
	color: var(--ader-text);
}

.aviso-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	flex-shrink: 0;
}

.aviso-data-dot--abertura .aviso-dot {
	background: #2e7d32;
}

.aviso-data-dot--fim .aviso-dot {
	background: var(--ader-secondary);
}

.aviso-card-footer {
	display: flex;
	justify-content: flex-end;
	padding: var(--ader-space-md) var(--ader-space-xl);
}

.aviso-card-arrow {
	display: inline-flex;
	align-items: center;
	color: var(--ader-secondary);
	transition: transform 0.3s ease;
}

.aviso-card:hover .aviso-card-arrow {
	transform: translateX(6px);
}

/* Slider — manter compatibilidade */
.avisos-slider-track .aviso-card {
	flex: 0 0 calc(33.333% - var(--ader-space-lg));
	margin-right: var(--ader-space-xl);
}

@media (max-width: 1024px) {
	.avisos-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.avisos-grid {
		grid-template-columns: 1fr;
	}
}

/* ═══════════════════════════════════════════════════
   ÍCONE AUTO PDF — links .pdf no conteúdo
═══════════════════════════════════════════════════ */
.interior-content a[href$=".pdf"]:not(:has(img)),
.entry-content a[href$=".pdf"]:not(:has(img)) {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	vertical-align: middle;
}

.interior-content a[href$=".pdf"]:not(:has(img))::before,
.entry-content a[href$=".pdf"]:not(:has(img))::before {
	content: '';
	display: inline-block;
	flex-shrink: 0;
	width: 18px;
	height: 20px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 36'%3E%3Cpath d='M20 0H4C1.8 0 0 1.8 0 4v28c0 2.2 1.8 4 4 4h24c2.2 0 4-1.8 4-4V12L20 0z' fill='%23283e89'/%3E%3Cpath d='M20 0l12 12H20V0z' fill='%231c2e6e'/%3E%3Ctext x='16' y='27' font-family='Arial,sans-serif' font-size='11' font-weight='bold' fill='white' text-anchor='middle'%3EPDF%3C/text%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}
