.contact-hub {
	background: linear-gradient(180deg, #f5f8fd 0, #fff 24rem);
	min-height: 65vh;
}

.contact-hub__header {
	max-width: 760px;
	margin-bottom: 2.5rem;
}

.contact-hub__eyebrow {
	color: var(--laranja-principal);
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
}

.contact-hub__header h1 {
	color: #123c7a;
	font-size: clamp(2rem, 4vw, 3.4rem);
	font-weight: 700;
	letter-spacing: -.04em;
	margin: .5rem 0 .75rem;
}

.contact-hub__header p { color: #58677c; font-size: 1.05rem; }

.contact-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
}

.contact-card {
	align-items: flex-start;
	background: #fff;
	border: 1px solid #dfe7f1;
	border-radius: 1rem;
	box-shadow: 0 12px 32px rgba(22, 60, 110, .08);
	color: #33445b;
	display: flex;
	gap: 1.1rem;
	min-height: 190px;
	padding: 1.65rem;
	position: relative;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.contact-card:hover {
	border-color: #f19000;
	box-shadow: 0 18px 40px rgba(22, 60, 110, .14);
	color: #33445b;
	transform: translateY(-3px);
}

.contact-card--featured { grid-column: 1 / -1; margin-inline: auto; max-width: 720px; min-height: auto; width: 100%; }
.contact-card__icon { align-items: center; background: #fff3df; border-radius: .8rem; color: #e58000; display: flex; flex: 0 0 3rem; font-size: 1.25rem; height: 3rem; justify-content: center; }
.contact-card__content { display: flex; flex-direction: column; gap: .7rem; line-height: 1.65; min-width: 0; overflow-wrap: anywhere; padding-right: 1.5rem; }
.contact-card__content strong { color: #163c70; font-size: 1.08rem; }
.contact-card__arrow { color: #e58000; position: absolute; right: 1.5rem; top: 1.8rem; }

.lgpd-intro { background: #f5f8fd; border-left: 4px solid var(--laranja-principal); border-radius: .5rem; color: #3f4f63; padding: 1.5rem; }
.lgpd-form { background: #fff; border: 1px solid #e1e8f1; border-radius: 1rem; box-shadow: 0 14px 38px rgba(22, 60, 110, .08); padding: clamp(1.25rem, 3vw, 2.5rem); }
.lgpd-form fieldset { border: 0; margin: 0 0 2rem; padding: 0; }
.lgpd-form legend { color: #163c70; font-size: 1.12rem; font-weight: 700; margin-bottom: 1rem; }
.lgpd-options { display: grid; gap: .65rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.lgpd-option { align-items: flex-start; border: 1px solid #dce5ef; border-radius: .55rem; display: flex; gap: .65rem; padding: .8rem; }
.lgpd-option input { flex: 0 0 auto; margin-top: .28rem; }
.lgpd-representative { background: #fff8ed; border-radius: .65rem; display: none; margin-top: 1rem; padding: 1rem; }
.lgpd-representative.is-visible { display: block; }
.required-mark { color: #b84700; }

@media (max-width: 767px) {
	.contact-grid, .lgpd-options { grid-template-columns: 1fr; }
	.contact-card--featured { grid-column: auto; }
	.contact-card { min-height: auto; }
	.contact-card__content { padding-right: .5rem; }
	.contact-card__arrow { display: none; }
}
