/**
 * Estilos do fluxo público do Portal da Transparência.
 *
 * Paleta: cor primária #002c41 (aplicada em botões e cards de ano/mês).
 *
 * @package DMJP_Portal_Transparencia
 */

.dmjp-portal-public,
.dmjp-portal-section {
	--dmjp-bg: #f6f7f9;
	--dmjp-card: #fff;
	--dmjp-border: #d8dee9;
	--dmjp-primary: #002c41;
	--dmjp-primary-hover: #013d59;
	--dmjp-primary-active: #00202f;
	--dmjp-text: #1e293b;
	color: var(--dmjp-text);
	font-size: 1rem;
	line-height: 1.5;
}

.dmjp-portal-public {
	max-width: 960px;
	margin: 0 auto;
	padding: 1.5rem 1rem 2.5rem;
}

.dmjp-portal-heading {
	margin: 0 0 0.5rem;
	font-size: 1.75rem;
}

.dmjp-portal-subheading {
	margin: 1.5rem 0 0.5rem;
	font-size: 1.15rem;
}

.dmjp-portal-subheading--center {
	text-align: center;
}

.dmjp-portal-lead {
	margin: 0 0 1.25rem;
	color: #475569;
}

.dmjp-portal-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}

/* ====== Botões do fluxo público ====== */
.dmjp-portal-btn {
	display: inline-block;
	padding: 0.65rem 1.1rem;
	border-radius: 6px;
	border: 1px solid var(--dmjp-primary, #002c41);
	background: var(--dmjp-primary, #002c41);
	color: #fff;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	font-size: 0.95rem;
	transition: background-color 0.15s, border-color 0.15s, box-shadow 0.15s, color 0.15s;
}

.dmjp-portal-btn:hover,
.dmjp-portal-btn:focus {
	background: var(--dmjp-primary-hover, #013d59);
	border-color: var(--dmjp-primary-hover, #013d59);
	color: #fff;
	outline: none;
	box-shadow: 0 2px 8px rgba(0, 44, 65, 0.25);
}

.dmjp-portal-btn:active {
	background: var(--dmjp-primary-active, #00202f);
	border-color: var(--dmjp-primary-active, #00202f);
	color: #fff;
}

.dmjp-portal-btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.dmjp-portal-btn--primary,
.dmjp-portal-btn--ghost {
	background: var(--dmjp-primary, #002c41);
	border-color: var(--dmjp-primary, #002c41);
	color: #fff;
}

/* NOTA: o antigo estado `.btn-active` do toggle público/corregedoria foi removido
 * junto com a separação dos pontos de entrada (v2). Cada formulário agora vive em
 * sua própria página e não há mais botões de alternância. */

.dmjp-portal-panel {
	background: var(--dmjp-card);
	/* border: 1px solid var(--dmjp-border); */
	border-radius: 8px;
	padding: 1.25rem 1.25rem 0.5rem;
}

.dmjp-portal-form--public .dmjp-portal-input {
	width: 100%;
	padding: 0.5rem 0.65rem;
	border: 1px solid var(--dmjp-border);
	border-radius: 4px;
	box-sizing: border-box;
	font: inherit;
}

/* ====== Grid do formulário público (2 colunas em desktop, 1 em mobile) ====== */
.dmjp-form-row {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin: 0 0 1rem;
}

.dmjp-form-col {
	flex: 1 1 calc(50% - 0.5rem);
	min-width: 0; /* impede que inputs forcem a coluna a crescer além do container */
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.dmjp-form-col > label {
	font-weight: 500;
	line-height: 1.3;
}

@media (max-width: 768px) {
	.dmjp-form-row {
		flex-direction: column;
		gap: 0.75rem;
	}
	.dmjp-form-col {
		flex: 1 1 100%;
	}
}

.dmjp-portal-honeypot {
	position: absolute;
	left: -9999px;
	height: 0;
	overflow: hidden;
}

/* Bloco de aceite legal no formulário */
.dmjp-portal-aceite {
	margin: 0.75rem 0 1rem;
	font-size: 0.95rem;
}

.dmjp-portal-aceite label {
	display: inline-flex;
	align-items: flex-start;
	gap: 0.5rem;
	cursor: pointer;
}

.dmjp-portal-aceite input[type="checkbox"] {
	margin-top: 0.2rem;
}

.dmjp-portal-msg {
	padding: 0.75rem 1rem;
	border-radius: 6px;
	background: #eef2ff;
	border: 1px solid #c7d2fe;
	margin: 0 0 1rem;
}

.dmjp-portal-msg--error {
	background: #fef2f2;
	border-color: #fecaca;
	color: #991b1b;
}

/* ====== Grid de cards (anos e meses) ======
 * Variante única — mesmas regras para `.dmjp-portal-grid--years` e `.dmjp-portal-grid--meses`.
 * `minmax(140px, 1fr)` reduz a probabilidade de quebra em palavras mais longas (Fevereiro,
 * Setembro, Novembro) mantendo o layout responsivo.
 */
.dmjp-portal-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 0.75rem;
	align-items: stretch; /* força cada item a ocupar toda a altura da linha */
}

.dmjp-portal-grid__item {
	display: flex;     /* permite o <a> esticar para ocupar o item inteiro */
	margin: 0;
	padding: 0;
}

/*
 * Card base compartilhado entre anos e meses. Altura controlada por `min-height`
 * (não depende do conteúdo); conteúdo centralizado via flexbox.
 */
.dmjp-portal-card {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1 1 auto;
	width: 100%;
	min-height: 84px;
	padding: 0.9rem 0.9rem;
	box-sizing: border-box;

	text-align: center;
	text-decoration: none;
	color: #fff;
	background: var(--dmjp-primary, #002c41);
	border: 1px solid var(--dmjp-primary, #002c41);
	border-radius: 8px;

	font-size: 1rem;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.01em;

	transition: background-color 0.15s, border-color 0.15s, box-shadow 0.15s, transform 0.08s;
}

.dmjp-portal-card:visited {
	color: #fff;
}

.dmjp-portal-card:hover,
.dmjp-portal-card:focus {
	background: var(--dmjp-primary-hover, #013d59);
	border-color: var(--dmjp-primary-hover, #013d59);
	color: #fff;
	box-shadow: 0 4px 14px rgba(0, 44, 65, 0.22);
	outline: none;
}

.dmjp-portal-card:active {
	background: var(--dmjp-primary-active, #00202f);
	border-color: var(--dmjp-primary-active, #00202f);
	color: #fff;
	transform: translateY(1px);
}

.dmjp-portal-card__label {
	display: block;
	width: 100%;
	color: inherit;
	/* Quebra controlada: se a palavra for maior que o card, quebra mas mantém altura
	 * consistente (o min-height acima absorve o espaço extra). */
	overflow-wrap: anywhere;
	word-break: break-word;
	hyphens: auto;
}

/* Responsivo: em telas muito estreitas, o grid cai naturalmente para 1–2 colunas graças
 * ao `auto-fill`. Mantemos a mesma altura mínima; apenas reduzimos o padding lateral. */
@media (max-width: 420px) {
	.dmjp-portal-card {
		padding: 0.9rem 0.6rem;
	}
}

/* ====== Tabela de resultado público ======
 * Visual institucional: cabeçalho em cor primária (#002c41), corpo com linhas zebradas
 * suaves, bordas discretas. Wrapper com scroll horizontal para preservar o layout em
 * telas estreitas sem quebrar o fluxo do tema.
 */
.dmjp-resultado-tabela-wrap {
	margin: 0 0 1.25rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: 8px;
	border: 1px solid var(--dmjp-border, #d8dee9);
	background: var(--dmjp-card, #fff);
}

.dmjp-resultado-tabela {
	width: 100%;
	min-width: 880px; /* garante colunas legíveis; abaixo disso, o wrap rola lateral */
	border-collapse: collapse;
	font-size: 0.95rem;
	color: var(--dmjp-text, #1e293b);
}

.dmjp-resultado-tabela thead th {
	background: var(--dmjp-primary, #002c41);
	color: #fff;
	text-align: left;
	vertical-align: top;
	padding: 0.75rem 0.9rem;
	border-bottom: 1px solid var(--dmjp-primary-active, #00202f);
	font-weight: 700;
	line-height: 1.25;
}

.dmjp-resultado-tabela__th-label {
	display: block;
	letter-spacing: 0.02em;
}

.dmjp-col-desc {
	display: block;
	margin-top: 0.25rem;
	font-size: 0.72rem;
	font-weight: 400;
	line-height: 1.3;
	opacity: 0.85;
	color: #e2e8f0;
	text-transform: none;
}

.dmjp-resultado-tabela tbody td {
	padding: 0.75rem 0.9rem;
	border-bottom: 1px solid var(--dmjp-border, #d8dee9);
	vertical-align: middle;
	white-space: nowrap;
}

.dmjp-resultado-tabela tbody tr:last-child td {
	border-bottom: none;
}

.dmjp-resultado-tabela tbody tr:nth-child(even) td {
	background: #f9fafb;
}

/* Em telas estreitas, a tabela rola horizontalmente; um leve indicador visual ajuda a
 * sinalizar que há mais conteúdo. */
@media (max-width: 720px) {
	.dmjp-resultado-tabela-wrap {
		background:
			linear-gradient(to right, #fff 30%, rgba(255, 255, 255, 0)),
			linear-gradient(to right, rgba(255, 255, 255, 0), #fff 70%) 100% 0,
			radial-gradient(farthest-side at 0 50%, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0)),
			radial-gradient(farthest-side at 100% 50%, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0)) 100% 0;
		background-repeat: no-repeat;
		background-size: 40px 100%, 40px 100%, 14px 100%, 14px 100%;
		background-attachment: local, local, scroll, scroll;
	}
}

/* ====== Mensagem legal (apenas no formulário de entrada) ====== */
.dmjp-portal-legal {
	margin-top: 1rem;
	padding: 1rem 1.25rem;
	background: #fffbeb;
	border: 1px solid #fde68a;
	border-radius: 8px;
}

.dmjp-portal-legal--form {
	margin: 1rem 0;
}

.dmjp-portal-legal__body {
	font-size: 0.95rem;
}

.dmjp-portal-back {
	margin-top: 1.5rem;
}

.dmjp-portal-back a {
	text-decoration: underline;
}

.required {
	color: #b91c1c;
}

/* ============================================================================
   reCAPTCHA (bridge com Elementor Pro)
============================================================================ */

.dmjp-portal-recaptcha {
	margin: 0.75rem 0;
}

.dmjp-portal-recaptcha--v3 small {
	display: block;
	font-size: 0.8rem;
	color: #64748b;
	line-height: 1.4;
}

.dmjp-portal-recaptcha--v2 .g-recaptcha {
	display: inline-block;
	max-width: 100%;
	transform-origin: 0 0;
}

@media (max-width: 360px) {
	.dmjp-portal-recaptcha--v2 .g-recaptcha {
		transform: scale(0.85);
	}
}

/* ============================================================================
   Área restrita (Corregedoria / órgão público)
   - Reutiliza a paleta e tabela da área pública (.dmjp-resultado-tabela).
============================================================================ */

.dmjp-restrito-header {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	margin-bottom: 1rem;
}

.dmjp-restrito-user {
	margin: 0;
	color: #475569;
	font-size: 0.95rem;
}

.dmjp-restrito-logout {
	margin-left: 0.75rem;
	text-decoration: underline;
}

.dmjp-restrito-filtros {
	background: #fff;
	border: 1px solid var(--dmjp-border, #d8dee9);
	border-radius: 8px;
	padding: 1rem 1rem 0.75rem;
	margin-bottom: 1rem;
}

.dmjp-restrito-filtros .dmjp-form-col select {
	width: 100%;
}

.dmjp-form-col--actions {
	flex-direction: row;
	align-items: flex-end;
	gap: 0.5rem;
}

.dmjp-form-col--actions > * {
	flex: 0 0 auto;
}

.dmjp-portal-btn--ghost {
	background: transparent;
	color: var(--dmjp-primary, #002c41);
}

.dmjp-portal-btn--ghost:hover,
.dmjp-portal-btn--ghost:focus {
	background: rgba(0, 44, 65, 0.06);
	color: var(--dmjp-primary, #002c41);
	box-shadow: none;
}

.dmjp-portal-msg--warning {
	background: #fffbeb;
	border: 1px solid #fde68a;
	border-radius: 8px;
	padding: 0.9rem 1rem;
	color: #78350f;
}

.dmjp-restrito-sumario {
	margin: 0.25rem 0 0.75rem;
	color: #475569;
	font-size: 0.9rem;
}

.dmjp-restrito-paginacao {
	margin-top: 1.25rem;
}

.dmjp-restrito-paginacao__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
}

.dmjp-restrito-paginacao__item {
	display: inline-block;
}

.dmjp-restrito-paginacao__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.25rem;
	height: 2.25rem;
	padding: 0 0.6rem;
	border: 1px solid var(--dmjp-border, #d8dee9);
	border-radius: 6px;
	background: #fff;
	color: var(--dmjp-primary, #002c41);
	font-weight: 600;
	text-decoration: none;
	line-height: 1;
}

.dmjp-restrito-paginacao__link:hover,
.dmjp-restrito-paginacao__link:focus {
	background: var(--dmjp-primary, #002c41);
	color: #fff;
	border-color: var(--dmjp-primary, #002c41);
	outline: none;
}

.dmjp-restrito-paginacao__item.is-current .dmjp-restrito-paginacao__link {
	background: var(--dmjp-primary, #002c41);
	color: #fff;
	border-color: var(--dmjp-primary, #002c41);
	cursor: default;
}

.dmjp-restrito-paginacao__item.is-disabled .dmjp-restrito-paginacao__link {
	color: #94a3b8;
	background: #f1f5f9;
	border-color: #e2e8f0;
	cursor: not-allowed;
}

@media (max-width: 768px) {
	.dmjp-form-col--actions {
		flex-direction: column;
		align-items: stretch;
	}
}
