/* ============================================================
   Estilos compartilhados de TODAS as páginas internas
   Hero escuro animado + tipografia + componentes institucionais
   ============================================================ */

/* === HERO COMPACTO DAS PÁGINAS INTERNAS === */
.page-hero {
	background: linear-gradient(120deg, #001528 0%, #002347 60%, #003a70 100%);
	color: #fff;
	padding: 36px 0 32px;
	position: relative;
	overflow: hidden;
	margin-top: 0;
	border-top: 0;
}

/* Padrão de pontos sutis */
.page-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle, rgba(255,255,255,.045) 1.5px, transparent 1.5px);
	background-size: 28px 28px;
	pointer-events: none;
}

/* Glow lateral sutil */
.page-hero::after {
	content: '';
	position: absolute;
	top: -120%;
	right: -8%;
	width: 480px;
	height: 480px;
	background: radial-gradient(circle, rgba(61, 139, 220, .12), transparent 70%);
	border-radius: 50%;
	pointer-events: none;
	animation: glowPulse 10s ease-in-out infinite;
}

@keyframes glowPulse {
	0%, 100% { transform: scale(1); opacity: .5; }
	50%      { transform: scale(1.12); opacity: .9; }
}

/* Container das moléculas animadas */
.hero-molecules {
	position: absolute;
	inset: 0;
	pointer-events: none;
	overflow: hidden;
	z-index: 0;
}

.hero-molecules .mol {
	position: absolute;
	opacity: .18;
	animation: floatMol 18s ease-in-out infinite;
}

.hero-molecules .mol svg {
	width: 100%;
	height: 100%;
	display: block;
}

.hero-molecules .mol-1 { top: 18%;  right: 6%;  width: 60px;  height: 60px;  animation-delay: 0s; }
.hero-molecules .mol-2 { top: 55%;  right: 18%; width: 44px;  height: 44px;  animation-delay: 3s; }
.hero-molecules .mol-3 { top: 28%;  right: 32%; width: 70px;  height: 70px;  animation-delay: 6s; opacity: .12; }
.hero-molecules .mol-4 { top: 65%;  right: 4%;  width: 50px;  height: 50px;  animation-delay: 9s; }
.hero-molecules .mol-5 { top: 12%;  right: 26%; width: 38px;  height: 38px;  animation-delay: 12s; }
.hero-molecules .mol-6 { top: 50%;  right: 44%; width: 48px;  height: 48px;  animation-delay: 15s; opacity: .1; }

@keyframes floatMol {
	0%, 100% { transform: translate(0, 0)     rotate(0deg);   }
	25%      { transform: translate(-15px, -12px) rotate(90deg);  }
	50%      { transform: translate(-6px, 18px)  rotate(180deg); }
	75%      { transform: translate(12px, -6px)  rotate(270deg); }
}

/* Conteúdo do hero (acima das animações) - alinhado à esquerda */
.page-hero .crq-container {
	position: relative;
	z-index: 2;
	text-align: left;
}

.page-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,.08);
	color: rgba(255,255,255,.85);
	font-size: .68rem;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	padding: 5px 12px;
	border-radius: 4px;
	border: 1px solid rgba(255,255,255,.15);
	margin-bottom: 10px;
}

.page-hero__title {
	color: #fff;
	font-family: var(--crq-font-base);
	font-size: clamp(1.6rem, 1.2rem + 1.2vw, 2.1rem);
	font-weight: 700;
	margin: 0 0 8px;
	line-height: 1.15;
	letter-spacing: -.005em;
}

.page-hero__lead {
	color: rgba(255,255,255,.78);
	font-size: .98rem;
	max-width: 680px;
	line-height: 1.55;
	margin: 0;
	font-weight: 400;
}

/* === CORPO DA PÁGINA === */
.page-body { padding: 64px 0; }
.page-grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 60px;
	align-items: start;
	max-width: 1180px;
	margin: 0 auto;
}
.page-content h2 {
	font-family: var(--crq-font-display);
	font-size: 1.65rem;
	color: var(--crq-primary-dark);
	margin: 48px 0 16px;
	font-weight: 700;
	line-height: 1.2;
	position: relative;
	padding-bottom: 12px;
}
.page-content h2::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 50px;
	height: 3px;
	background: var(--crq-primary);
	border-radius: 2px;
}
.page-content h2:first-child { margin-top: 0; }
.page-content h3 {
	font-size: 1.2rem;
	color: var(--crq-primary);
	margin: 32px 0 12px;
	font-weight: 700;
}
.page-content p {
	font-size: 1.02rem;
	line-height: 1.75;
	color: #2c3744;
	margin: 0 0 16px;
}
.page-content ul { padding-left: 1.3em; margin: 0 0 20px; }
.page-content ul li { margin: 8px 0; line-height: 1.65; color: #2c3744; }
.page-content blockquote {
	border-left: 4px solid var(--crq-primary);
	background: var(--crq-soft);
	padding: 18px 24px;
	margin: 24px 0;
	border-radius: 0 10px 10px 0;
	font-style: italic;
	color: var(--crq-primary-dark);
}
.page-content strong { color: var(--crq-primary-dark); }

/* === SIDEBAR === */
.page-sidebar { position: sticky; top: 24px; }
.sidebar-card {
	background: var(--crq-soft);
	border-radius: 12px;
	padding: 24px;
	margin-bottom: 20px;
	border: 1px solid var(--crq-border-light);
}
.sidebar-card h4 {
	margin: 0 0 14px;
	color: var(--crq-primary-dark);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--crq-primary);
}
.sidebar-card ul { list-style: none; padding: 0; margin: 0; }
.sidebar-card ul li { margin: 0; border-bottom: 1px dashed var(--crq-border-light); }
.sidebar-card ul li:last-child { border-bottom: 0; }
.sidebar-card ul a {
	display: block;
	padding: 10px 0;
	color: var(--crq-text-soft);
	font-size: .92rem;
	text-decoration: none;
	transition: all .2s;
	font-weight: 500;
}
.sidebar-card ul a:hover { color: var(--crq-primary); padding-left: 6px; }
.sidebar-card ul a::before { content: '›'; color: var(--crq-primary); font-weight: 700; margin-right: 8px; }
.sidebar-card.is-active { background: linear-gradient(135deg, var(--crq-primary-dark), var(--crq-primary)); color: #fff; }
.sidebar-card.is-active h4 { color: #fff; border-bottom-color: rgba(255,255,255,.3); }
.sidebar-card.is-active p { color: rgba(255,255,255,.85); margin: 0 0 14px; font-size: .92rem; line-height: 1.55; }
.sidebar-card.is-active .btn-light { display: inline-block; background: #fff; color: var(--crq-primary-dark); padding: 10px 18px; border-radius: 50px; text-decoration: none; font-weight: 700; font-size: .88rem; }

/* === BLOCOS DE CONTEÚDO === */
.sub-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 20px;
	margin-top: 24px;
}
.sub-card {
	background: #fff;
	border: 1px solid var(--crq-border-light);
	border-radius: 12px;
	padding: 28px 24px;
	text-decoration: none;
	color: inherit;
	transition: all .25s var(--ease);
	position: relative;
	overflow: hidden;
}
.sub-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 4px;
	height: 0;
	background: var(--crq-primary);
	transition: height .3s;
}
.sub-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,35,112,.12); border-color: var(--crq-primary); text-decoration: none; }
.sub-card:hover::before { height: 100%; }
.sub-card__icon {
	width: 44px;
	height: 44px;
	border-radius: 10px;
	background: var(--crq-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}
.sub-card__icon svg { width: 22px; height: 22px; fill: var(--crq-primary); }
.sub-card h3 { margin: 0 0 6px; color: var(--crq-primary-dark); font-size: 1.1rem; font-family: var(--crq-font-display); font-weight: 700; }
.sub-card p { margin: 0; color: var(--crq-text-soft); font-size: .9rem; line-height: 1.5; }
.sub-card__arrow { display: inline-flex; align-items: center; gap: 4px; margin-top: 14px; color: var(--crq-primary); font-weight: 600; font-size: .88rem; }

/* Valor (Missão/Visão/Valores) */
.value-block {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 18px;
	margin: 24px 0;
}
.value-item {
	background: #fff;
	border-left: 4px solid var(--crq-primary);
	padding: 22px 24px;
	border-radius: 0 10px 10px 0;
	box-shadow: 0 2px 10px rgba(0,35,112,.06);
	transition: all .25s var(--ease);
}
.value-item:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,35,112,.12); }
.value-item__label { font-size: .72rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--crq-primary); margin-bottom: 6px; display: block; }
.value-item h4 { margin: 0 0 8px; color: var(--crq-primary-dark); font-size: 1.05rem; font-weight: 700; }
.value-item p { margin: 0; font-size: .94rem; color: var(--crq-text-soft); line-height: 1.55; }

/* === LISTA DE VALORES (chips) === */
.values-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 18px 0;
}
.values-chips span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: linear-gradient(135deg, var(--crq-soft), #fff);
	color: var(--crq-primary-dark);
	padding: 10px 18px;
	border-radius: 50px;
	font-weight: 600;
	font-size: .92rem;
	border: 1px solid var(--crq-border-light);
	transition: all .25s var(--ease);
}
.values-chips span:hover { background: var(--crq-primary); color: #fff; transform: translateY(-2px); }
.values-chips span::before { content: '✓'; color: var(--crq-primary); font-weight: 900; }
.values-chips span:hover::before { color: #fff; }

/* === CARDS DE PESSOAS (diretoria/conselheiros) === */
.people-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 22px;
	margin: 24px 0;
}
.person-card {
	background: #fff;
	border: 1px solid var(--crq-border-light);
	border-radius: 14px;
	padding: 28px 22px 22px;
	text-align: center;
	transition: all .25s var(--ease);
	position: relative;
	overflow: hidden;
}
.person-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 70px;
	background: linear-gradient(135deg, var(--crq-primary-dark), var(--crq-primary));
}
.person-card:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(0,35,112,.15); }
.person-card__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--crq-soft), #fff);
	margin: 0 auto 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--crq-font-display);
	font-size: 1.6rem;
	font-weight: 800;
	color: var(--crq-primary);
	border: 4px solid #fff;
	position: relative;
	z-index: 2;
	box-shadow: 0 4px 12px rgba(0,0,0,.1);
}
.person-card__role {
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--crq-primary);
	margin: 0 0 6px;
}
.person-card__name {
	font-family: var(--crq-font-display);
	font-size: 1.05rem;
	color: var(--crq-primary-dark);
	margin: 0;
	font-weight: 700;
	line-height: 1.25;
}

.people-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 14px;
	margin: 20px 0 32px;
}
.people-list li {
	background: #fff;
	border: 1px solid var(--crq-border-light);
	border-radius: 10px;
	padding: 14px 18px 14px 60px;
	font-weight: 600;
	color: var(--crq-primary-dark);
	font-size: .98rem;
	list-style: none;
	position: relative;
	transition: all .25s var(--ease);
}
.people-list li::before {
	content: attr(data-initial);
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--crq-soft), #fff);
	color: var(--crq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--crq-font-display);
	font-weight: 800;
	font-size: .95rem;
	border: 2px solid var(--crq-border-light);
}
.people-list li:hover {
	border-color: var(--crq-primary);
	transform: translateX(4px);
}

/* Comissões */
.commission-block {
	background: #fff;
	border: 1px solid var(--crq-border-light);
	border-left: 5px solid var(--crq-primary);
	border-radius: 0 12px 12px 0;
	padding: 22px 26px;
	margin: 18px 0;
	transition: all .25s var(--ease);
}
.commission-block:hover { box-shadow: 0 8px 22px rgba(0,35,112,.1); transform: translateX(4px); }
.commission-block h3 {
	margin: 0 0 10px;
	color: var(--crq-primary-dark);
	font-size: 1.1rem;
}
.commission-block__president {
	background: var(--crq-soft);
	padding: 8px 14px;
	border-radius: 8px;
	display: inline-block;
	font-size: .88rem;
	margin: 8px 0;
	color: var(--crq-primary-dark);
}
.commission-block__members {
	margin: 6px 0 0;
	color: var(--crq-text-soft);
	font-size: .92rem;
	line-height: 1.6;
}

/* Esconde breadcrumb numérico abaixo do menu (foi pedido para remover) */
.crq-breadcrumbs { display: none; }

/* ============= PORTAL EXTERNO (página-ponte) ============= */
.portal-cta {
	background: #001528;
	background: linear-gradient(135deg, #001528 0%, #002347 60%, #003a70 100%);
	color: #ffffff;
	border-radius: 16px;
	padding: 40px 36px;
	margin: 28px 0;
	position: relative;
	overflow: hidden;
	box-shadow: 0 12px 32px rgba(0,35,112,.18);
}
.portal-cta::before {
	content: '';
	position: absolute;
	top: -80%;
	right: -30%;
	width: 320px;
	height: 320px;
	background: radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
	border-radius: 50%;
	pointer-events: none;
	z-index: 0;
}
.portal-cta__inner { position: relative; z-index: 2; max-width: 720px; }
.portal-cta__label {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: rgba(255,255,255,.18);
	color: #ffffff !important;
	font-size: .74rem;
	font-weight: 800;
	letter-spacing: .18em;
	text-transform: uppercase;
	padding: 7px 15px;
	border-radius: 50px;
	border: 1px solid rgba(255,255,255,.4);
	margin-bottom: 18px;
}
.portal-cta__title {
	color: #ffffff !important;
	font-family: var(--crq-font-base);
	font-size: 1.65rem;
	font-weight: 800;
	margin: 0 0 12px;
	line-height: 1.25;
	letter-spacing: -.01em;
}
.portal-cta__desc {
	color: #ffffff !important;
	font-size: 1.02rem;
	line-height: 1.6;
	margin: 0 0 26px;
	font-weight: 400;
	opacity: 1;
}
.portal-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: #fff;
	color: var(--crq-primary-dark);
	padding: 14px 28px;
	border-radius: 50px;
	font-weight: 700;
	font-size: .95rem;
	text-decoration: none;
	transition: all .25s var(--ease);
	box-shadow: 0 6px 20px rgba(0,0,0,.15);
}
.portal-cta__btn:hover {
	background: var(--crq-soft);
	color: var(--crq-primary-dark);
	text-decoration: none;
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(0,0,0,.2);
}
.portal-cta__btn svg { width: 16px; height: 16px; fill: currentColor; }

/* ============= FORMULÁRIOS BONITOS ============= */
.crq-form {
	background: #fff;
	border: 1px solid var(--crq-border-light);
	border-radius: 14px;
	padding: 32px;
	box-shadow: 0 4px 16px rgba(0,35,112,.05);
}
.crq-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin-bottom: 14px;
}
.crq-form__row--3 { grid-template-columns: 2fr 1fr 1fr; }
.crq-form__row--full { grid-template-columns: 1fr; }
.crq-form__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.crq-form__label {
	font-size: .82rem;
	font-weight: 600;
	color: var(--crq-primary-dark);
	display: flex;
	align-items: center;
	gap: 4px;
}
.crq-form__label--required::after {
	content: '*';
	color: #c1322d;
	font-weight: 800;
}
.crq-form__input,
.crq-form__textarea,
.crq-form__select {
	width: 100%;
	padding: 11px 14px;
	border: 1.5px solid var(--crq-border-light);
	border-radius: 8px;
	font-family: var(--crq-font-base);
	font-size: .92rem;
	color: var(--crq-text);
	background: #fff;
	transition: all .2s var(--ease);
}
.crq-form__input:focus,
.crq-form__textarea:focus,
.crq-form__select:focus {
	outline: none;
	border-color: var(--crq-primary);
	box-shadow: 0 0 0 3px rgba(0,58,112,.1);
}
.crq-form__textarea {
	resize: vertical;
	min-height: 120px;
	line-height: 1.55;
}
.crq-form__hint {
	font-size: .78rem;
	color: var(--crq-text-soft);
	margin: 4px 0 0;
}
.crq-form__submit {
	background: linear-gradient(135deg, var(--crq-primary-dark), var(--crq-primary));
	color: #fff;
	padding: 14px 32px;
	border: none;
	border-radius: 50px;
	font-family: var(--crq-font-base);
	font-size: .95rem;
	font-weight: 700;
	cursor: pointer;
	transition: all .25s var(--ease);
	display: inline-flex;
	align-items: center;
	gap: 10px;
	box-shadow: 0 6px 18px rgba(0,35,112,.2);
}
.crq-form__submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(0,35,112,.3);
}
.crq-form__submit svg { width: 16px; height: 16px; fill: currentColor; }
.crq-form__actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 22px;
	padding-top: 22px;
	border-top: 1px solid var(--crq-border-light);
	flex-wrap: wrap;
	gap: 14px;
}
.crq-form__note {
	font-size: .82rem;
	color: var(--crq-text-soft);
	margin: 0;
}
.crq-form fieldset {
	border: none;
	padding: 0;
	margin: 0 0 22px;
}
.crq-form fieldset legend {
	font-weight: 700;
	color: var(--crq-primary-dark);
	font-size: .92rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--crq-primary);
	margin-bottom: 16px;
	width: 100%;
}

@media (max-width: 640px) {
	.crq-form { padding: 22px; }
	.crq-form__row { grid-template-columns: 1fr; }
	.crq-form__row--3 { grid-template-columns: 1fr; }
}

/* ============= DADOS ABERTOS / SELETOR DE ANO ============= */
.year-selector {
	display: flex;
	gap: 10px;
	margin: 24px 0 32px;
	flex-wrap: wrap;
}
.year-btn {
	padding: 12px 24px;
	background: #fff;
	border: 2px solid var(--crq-border-light);
	color: var(--crq-primary-dark);
	font-weight: 700;
	font-family: var(--crq-font-base);
	font-size: 1.05rem;
	border-radius: 50px;
	cursor: pointer;
	transition: all .2s var(--ease);
	text-decoration: none;
}
.year-btn:hover {
	border-color: var(--crq-primary);
	color: var(--crq-primary);
	text-decoration: none;
}
.year-btn.is-active {
	background: linear-gradient(135deg, var(--crq-primary-dark), var(--crq-primary));
	color: #fff;
	border-color: var(--crq-primary);
	box-shadow: 0 6px 16px rgba(0,35,112,.2);
}

.doc-category {
	background: #fff;
	border: 1px solid var(--crq-border-light);
	border-left: 4px solid var(--crq-primary);
	border-radius: 0 12px 12px 0;
	padding: 22px 24px;
	margin-bottom: 16px;
	transition: all .2s var(--ease);
}
.doc-category:hover { box-shadow: 0 8px 22px rgba(0,35,112,.08); }
.doc-category__head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 12px;
}
.doc-category__icon {
	width: 42px;
	height: 42px;
	background: linear-gradient(135deg, var(--crq-soft), #fff);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	border: 1px solid var(--crq-border-light);
}
.doc-category__icon svg { width: 22px; height: 22px; fill: var(--crq-primary); }
.doc-category__title {
	margin: 0;
	font-family: var(--crq-font-display);
	font-size: 1.15rem;
	color: var(--crq-primary-dark);
	font-weight: 700;
}
.doc-category__desc {
	color: var(--crq-text-soft);
	font-size: .92rem;
	line-height: 1.55;
	margin: 0 0 14px;
}
.doc-category__files {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.doc-file-chip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--crq-soft);
	color: var(--crq-primary-dark);
	padding: 8px 14px 8px 10px;
	border-radius: 8px;
	font-size: .85rem;
	font-weight: 600;
	text-decoration: none;
	transition: all .2s var(--ease);
	border: 1px solid var(--crq-border-light);
	position: relative;
}
.doc-file-chip:hover {
	background: var(--crq-primary);
	color: #fff;
	text-decoration: none;
	border-color: var(--crq-primary);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,35,112,.15);
}
.doc-file-chip svg { width: 18px; height: 22px; fill: currentColor; flex-shrink: 0; }
.doc-file-chip[data-format]::after {
	content: attr(data-format);
	display: inline-block;
	background: var(--crq-primary);
	color: #fff;
	padding: 2px 6px;
	border-radius: 4px;
	font-size: .6rem;
	font-weight: 800;
	letter-spacing: .08em;
	margin-left: 4px;
}
.doc-file-chip:hover[data-format]::after {
	background: #fff;
	color: var(--crq-primary-dark);
}
.doc-empty {
	background: var(--crq-soft);
	border-radius: 10px;
	padding: 30px;
	text-align: center;
	color: var(--crq-text-soft);
	font-style: italic;
}

/* Body padding ajustes */
.page-body { padding: 56px 0 64px; }

/* Responsivo */
@media (max-width: 980px) {
	.page-grid { grid-template-columns: 1fr; }
	.page-sidebar { position: static; }
}
@media (max-width: 640px) {
	.page-body { padding: 40px 0 48px; }
	.page-hero { padding: 28px 0 24px; }
	.page-hero__title { font-size: 1.5rem; }
}
