/**
 * Portal da Transparência — miúdo da página (referência layout municipal).
 */

.cm-trans-portal {
	/* max-width: 1100px; */
	margin: 0 auto 3rem;
	padding: 0 1rem 2rem;
	box-sizing: border-box;
	color: var(--text-primary, #2b2b2b);
	background: var(--white, #fff);
}

/* —— Fil de ariane (título da página vem no hero do tema) —— */

.cm-trans-portal__breadcrumb {
	font-size: 0.8rem;
	color: var(--text-secondary, #838383);
	margin: 0 0 0.75rem;
}

.cm-trans-portal__breadcrumb a {
	color: var(--text-secondary, #838383);
	text-decoration: none;
}

.cm-trans-portal__breadcrumb a:hover {
	color: var(--secondary-color, #e7343b);
	text-decoration: underline;
}

.cm-trans-portal__bc-sep {
	margin: 0 0.2em;
	color: var(--text-secondary, #838383);
}

.cm-trans-portal__bc-current {
	color: var(--text-primary, #2b2b2b);
}

.cm-trans-portal__rule {
	border: 0;
	border-top: 1px solid var(--border-light, #e5e5e5);
	margin: 0;
}

/* —— Boas-vindas —— */

.cm-trans-portal__welcome {
	margin: 0.5rem 0 0;
}

.cm-trans-portal__welcome-title {
	margin: 0 0 0.65rem;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--primary-color, #2b2b2b);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cm-trans-portal__welcome-text {
	margin: 0;
	max-width: 70ch;
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--text-primary, #2b2b2b);
}

/* —— Grelha: 4 colunas + Controle Interno por baixo da 1.ª —— */

.cm-trans-portal__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	grid-template-areas:
		"geral pessoal admin orc"
		"ci . . .";
	column-gap: 2rem;
	row-gap: 2rem;
	margin-top: 1.75rem;
	align-items: start;
}

.cm-trans-portal__section--geral {
	grid-area: geral;
}

.cm-trans-portal__section--pessoal {
	grid-area: pessoal;
}

.cm-trans-portal__section--administracao {
	grid-area: admin;
}

.cm-trans-portal__section--orcamento {
	grid-area: orc;
}

.cm-trans-portal__section--controle_interno {
	grid-area: ci;
}

@media screen and (max-width: 960px) {
	.cm-trans-portal__grid {
		grid-template-columns: 1fr;
		grid-template-areas:
			"geral"
			"ci"
			"pessoal"
			"admin"
			"orc";
		row-gap: 1.75rem;
		column-gap: 0;
	}
}

/* —— Títulos de secção (Geral, Pessoal, …) —— */

.cm-trans-portal__section-title {
	margin: 0 0 0.65rem;
	padding: 0;
	font-size: 0.88rem;
	font-weight: 700;
	line-height: 1.25;
	color: var(--primary-color, #2b2b2b);
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

/* —— Lista simples + chevron azul à esquerda —— */

.cm-trans-portal__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cm-trans-portal__item {
	margin: 0;
	padding: 0;
}

.cm-trans-portal__link {
	display: flex;
	align-items: flex-start;
	gap: 0.4rem;
	padding: 0.32rem 0;
	text-decoration: none;
	color: var(--text-primary, #2b2b2b);
	font-size: 0.9rem;
	line-height: 1.45;
	border: 0;
	background: transparent;
	box-shadow: none;
	border-radius: 0;
	transition: color 0.12s ease;
}

.cm-trans-portal__link:hover {
	color: var(--secondary-color, #e7343b);
}

.cm-trans-portal__chev {
	flex-shrink: 0;
	width: 1em;
	color: var(--tertiary-color, #1e40af);
	font-weight: 700;
	font-size: 0.85rem;
	line-height: 1.5;
	margin-top: 0.05em;
}

.cm-trans-portal__link:hover .cm-trans-portal__chev {
	color: var(--secondary-color, #e7343b);
}

.cm-trans-portal__label {
	flex: 1;
	min-width: 0;
}

/* —— Arquivos / singles de transparência —— */

.cm-trans-archive__layout {
	display: flex;
	gap: 2rem;
	flex-wrap: wrap;
}

.cm-trans-archive__sidebar {
	flex: 0 0 200px;
}

.cm-trans-archive__sidebar-title,
.cm-trans-single__years-title {
	font-size: 1rem;
	margin: 0 0 0.75rem;
}

.cm-trans-archive__years-grid,
.cm-trans-single__years-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.cm-trans-years__chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 4.5rem;
	padding: 0.55rem 0.85rem;
	border-radius: 999px;
	background: var(--white, #fff);
	border: 1px solid var(--border-light, #e5e5e5);
	color: var(--text-primary, #2b2b2b);
	text-decoration: none;
	font-weight: 600;
	line-height: 1.2;
	transition:
		color 0.2s ease,
		border-color 0.2s ease,
		background-color 0.2s ease,
		box-shadow 0.2s ease;
}

.cm-trans-years__chip:hover {
	color: var(--primary-color, #2b2b2b);
	border-color: var(--border-primary, #2b2b2b);
	background: var(--bg-secondary, #f8f9fa);
}

.cm-trans-years__chip--current {
	background: var(--bg-secondary, #f8f9fa);
	border-color: var(--border-primary, #2b2b2b);
	color: var(--primary-color, #2b2b2b);
	font-weight: 700;
}

.cm-trans-archive__content {
	flex: 1;
	min-width: 260px;
}

.cm-trans-archive__cards {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
	align-items: stretch;
}

.cm-trans-archive__card-item {
	margin: 0;
	display: flex;
}

.cm-trans-archive__card-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	width: 100%;
	min-height: 88px;
	padding: 1rem 1.125rem;
	border: 1px solid var(--border-light, #e5e5e5);
	border-radius: 0.75rem;
	background: var(--white, #fff);
	color: var(--text-primary, #2b2b2b);
	text-decoration: none;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
	font-weight: 600;
	line-height: 1.4;
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

.cm-trans-archive__card-link:hover {
	border-color: var(--border-primary, #2b2b2b);
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
	transform: translateY(-1px);
}

.cm-trans-archive__card-title {
	flex: 1;
	min-width: 0;
	color: var(--primary-color, #e7343b);
	overflow-wrap: anywhere;
	word-break: break-word;
}

.cm-trans-archive__card-chevron {
	flex: 0 0 auto;
	color: var(--primary-color, #e7343b);
	font-size: 1rem;
	line-height: 1;
}

.cm-trans-archive__card-link:hover .cm-trans-archive__card-title,
.cm-trans-archive__card-link:hover .cm-trans-archive__card-chevron {
	color: var(--primary-color, #2b2b2b);
}

.cm-trans-archive__empty {
	color: var(--text-primary, #838383);
}

.cm-trans-single__panel {
	max-width: 800px;
}

.cm-trans-single__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
}

.cm-trans-single__meta-group {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.cm-trans-single__meta {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--text-primary, #2b2b2b);
	font-weight: 600;
}

.cm-trans-single__meta-label {
	color: var(--text-secondary, #838383);
	font-weight: 600;
}

.cm-trans-single__meta-value {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 4.5rem;
	padding: 0.45rem 0.75rem;
	border-radius: 999px;
	background: var(--white, #fff);
	border: 1px solid var(--border-light, #e5e5e5);
	color: var(--primary-color, #2b2b2b);
	font-weight: 700;
}

.cm-trans-single__meta-title {
	color: var(--text-primary, #2b2b2b);
	font-weight: 500;
	word-break: break-word;
}

.cm-trans-single__download {
	margin: 0;
}

.cm-trans-single__download-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.8rem 1.1rem;
	border-radius: 0.75rem;
	background: var(--primary-color, #2b2b2b);
	color: var(--white, #fff);
	text-decoration: none;
	font-weight: 700;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition:
		transform 0.2s ease,
		box-shadow 0.2s ease,
		background-color 0.2s ease;
}

.cm-trans-single__download-link:hover {
	background: var(--secondary-color, #e7343b);
	color: var(--white, #fff);
	box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
	transform: translateY(-1px);
}

.cm-trans-single__content {
	color: var(--text-primary, #2b2b2b);
	line-height: 1.75;
}

.cm-trans-single__content > *:first-child {
	margin-top: 0;
}

.cm-trans-single__content > *:last-child {
	margin-bottom: 0;
}

.cm-trans-single__content p,
.cm-trans-single__content ul,
.cm-trans-single__content ol,
.cm-trans-single__content blockquote {
	margin-bottom: 1rem;
}

.cm-trans-single__content a {
	color: var(--primary-color, #2b2b2b);
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.cm-trans-single__years-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

@media screen and (max-width: 768px) {
	.cm-trans-single__header {
		align-items: stretch;
	}

	.cm-trans-single__download,
	.cm-trans-single__download-link {
		width: 100%;
	}
}
