/*
 * Pagina Contato.
 *
 * Responsabilidade: estilizar os componentes institucionais localizados em
 * `template-parts/contato/`, mantendo escopo BEM com prefixo `rnen-contato`.
 */

.rnen-contato {
	--rnen-contato-background: var(--wp--preset--color--neutral-0, var(--rnen-color-background));
	--rnen-contato-surface: var(--wp--preset--color--neutral-50, var(--rnen-color-surface));
	--rnen-contato-surface-raised: var(--wp--preset--color--neutral-0, var(--rnen-color-surface-raised));
	--rnen-contato-title-color: var(--wp--preset--color--neutral-900, var(--rnen-color-text));
	--rnen-contato-text-color: var(--wp--preset--color--neutral-600, var(--rnen-color-text-muted));
	--rnen-contato-accent: var(--wp--preset--color--primary-700, var(--rnen-color-primary-700));
	--rnen-contato-accent-dark: var(--wp--preset--color--primary-900, var(--rnen-color-primary-900));
	--rnen-contato-accent-soft: var(--wp--preset--color--primary-50, var(--rnen-color-primary-50));

	padding-block: var(--rnen-space-16);
	background: var(--rnen-contato-background);
}

.rnen-contato--informacoes,
.rnen-contato--formulario,
.rnen-contato--faq {
	background: var(--rnen-contato-surface);
}

.rnen-contato__container {
	width: min(100% - (var(--rnen-container-padding) * 2), var(--rnen-container-max-width));
	margin-inline: auto;
}

.rnen-contato__narrow {
	max-width: var(--rnen-container-narrow-width);
	text-align: center;
}

.rnen-contato__hero-grid,
.rnen-contato__form-grid,
.rnen-contato__social-card {
	display: grid;
	gap: var(--rnen-space-12);
	align-items: center;
}

.rnen-contato__hero-grid {
	grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.95fr);
}

.rnen-contato__form-grid,
.rnen-contato__social-card {
	grid-template-columns: minmax(0, 0.8fr) minmax(18rem, 1.2fr);
}

.rnen-contato__hero-content,
.rnen-contato__form-intro {
	max-width: 46rem;
}

.rnen-contato__eyebrow {
	display: inline-flex;
	width: fit-content;
	margin-block-end: var(--rnen-space-4);
	color: var(--rnen-contato-accent);
	font-size: var(--rnen-font-size-sm);
	font-weight: var(--rnen-font-weight-bold);
	line-height: var(--rnen-line-height-tight);
	text-transform: uppercase;
	letter-spacing: 0;
}

.rnen-contato--hero .rnen-contato__eyebrow {
	padding: var(--rnen-space-2) var(--rnen-space-3);
	background: var(--rnen-contato-accent-soft);
	border-radius: var(--rnen-radius-full);
}

.rnen-contato__hero-title,
.rnen-contato__section-title,
.rnen-contato__cta-title {
	color: var(--rnen-contato-title-color);
	line-height: var(--rnen-line-height-heading);
}

.rnen-contato__hero-title {
	max-width: 14ch;
	margin-block-end: var(--rnen-space-5);
	font-size: var(--rnen-font-size-5xl);
	line-height: var(--rnen-line-height-tight);
}

.rnen-contato__hero-text,
.rnen-contato__section-text,
.rnen-contato__cta-text {
	color: var(--rnen-contato-text-color);
	font-size: var(--rnen-font-size-lg);
	line-height: var(--rnen-line-height-base);
}

.rnen-contato__hero-text,
.rnen-contato__section-text {
	max-width: 42rem;
	margin-block-end: 0;
}

.rnen-contato__hero-media {
	position: relative;
	margin: 0;
}

.rnen-contato__hero-media::before {
	position: absolute;
	inset: var(--rnen-space-6) calc(var(--rnen-space-6) * -1) calc(var(--rnen-space-6) * -1) var(--rnen-space-6);
	z-index: 0;
	content: "";
	background: var(--rnen-contato-surface);
	border-radius: var(--rnen-radius-lg);
}

.rnen-contato__hero-image {
	position: relative;
	z-index: 1;
	width: 100%;
	aspect-ratio: 640 / 520;
	height: auto;
	object-fit: cover;
	background: var(--rnen-contato-surface);
	border-radius: var(--rnen-radius-lg);
	box-shadow: var(--rnen-shadow-md);
}

.rnen-contato__section-header {
	max-width: 48rem;
	margin-inline: auto;
	text-align: center;
}

.rnen-contato__section-title {
	max-width: 24ch;
	margin-inline: auto;
	margin-block-end: var(--rnen-space-5);
	font-size: var(--rnen-font-size-4xl);
}

.rnen-contato__cards {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--rnen-space-6);
	margin-block-start: var(--rnen-space-12);
}

.rnen-contato__card,
.rnen-contato__form-wrapper,
.rnen-contato__social-card,
.rnen-contato__map-frame,
.rnen-contato__faq-item {
	background: var(--rnen-contato-surface-raised);
	border: var(--rnen-border-width) var(--rnen-border-style) var(--wp--preset--color--neutral-200, var(--rnen-color-border));
	border-radius: var(--rnen-radius-lg);
	box-shadow: var(--rnen-shadow-xs);
}

.rnen-contato__card {
	padding: var(--rnen-space-6);
}

.rnen-contato__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 4rem;
	height: 4rem;
	margin-block-end: var(--rnen-space-5);
	color: var(--rnen-contato-accent);
	background: var(--rnen-contato-accent-soft);
	border-radius: var(--rnen-radius-full);
}

.rnen-contato__icon-svg,
.rnen-contato__social-icon {
	fill: none;
	stroke: currentcolor;
	stroke-width: 3;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.rnen-contato__icon-svg {
	width: 2rem;
	height: 2rem;
}

.rnen-contato__card-title {
	margin-block-end: var(--rnen-space-3);
	color: var(--rnen-contato-title-color);
	font-size: var(--rnen-font-size-xl);
	line-height: var(--rnen-line-height-heading);
}

.rnen-contato__card-text p {
	margin-block-end: var(--rnen-space-1);
	color: var(--rnen-contato-text-color);
	font-size: var(--rnen-font-size-md);
	line-height: var(--rnen-line-height-base);
}

.rnen-contato__card-text p:last-child {
	margin-block-end: 0;
}

.rnen-contato__social-card {
	padding: var(--rnen-space-8);
	align-items: center;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: var(--rnen-space-8);
}

.rnen-contato__social-nav {
	display: flex;
	flex-wrap: wrap;
	gap: var(--rnen-space-3);
	align-items: center;
	justify-content: flex-end;
}

.rnen-contato__social-link {
	display: inline-flex;
	align-items: center;
	gap: var(--rnen-space-3);
	width: fit-content;
	min-height: 3rem;
	padding: var(--rnen-space-3) var(--rnen-space-5);
	color: var(--rnen-contato-accent);
	font-weight: var(--rnen-font-weight-semibold);
	line-height: var(--rnen-line-height-tight);
	text-decoration: none;
	background: var(--rnen-contato-accent-soft);
	border-radius: var(--rnen-radius-full);
	transition:
		color var(--rnen-transition-base),
		background-color var(--rnen-transition-base);
}

.rnen-contato__social-link:hover,
.rnen-contato__social-link:focus-visible {
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	background: var(--rnen-contato-accent);
}

.rnen-contato__social-icon {
	width: 1.5rem;
	height: 1.5rem;
}

.rnen-contato__form-wrapper {
	padding: var(--rnen-space-6);
}

.rnen-contato__form {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--rnen-space-5);
}

.rnen-contato__form-note,
.rnen-contato__field--full {
	grid-column: 1 / -1;
}

.rnen-contato__form-note {
	margin: 0;
	color: var(--rnen-contato-text-color);
	font-size: var(--rnen-font-size-sm);
	line-height: var(--rnen-line-height-base);
}

.rnen-contato__label {
	display: block;
	margin-block-end: var(--rnen-space-2);
	color: var(--rnen-contato-title-color);
	font-size: var(--rnen-font-size-sm);
	font-weight: var(--rnen-font-weight-semibold);
}

.rnen-contato__input,
.rnen-contato__textarea {
	width: 100%;
	padding: var(--rnen-space-3);
	color: var(--rnen-contato-title-color);
	font: inherit;
	background: var(--rnen-contato-surface-raised);
	border: var(--rnen-border-width) var(--rnen-border-style) var(--wp--preset--color--neutral-300, var(--rnen-color-border-strong));
	border-radius: var(--rnen-radius-md);
}

.rnen-contato__textarea {
	resize: vertical;
}

.rnen-contato__input:focus,
.rnen-contato__textarea:focus {
	border-color: var(--rnen-color-focus);
	outline: var(--rnen-border-width) var(--rnen-border-style) var(--rnen-color-focus);
	outline-offset: var(--rnen-space-1);
}

.rnen-contato__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3rem;
	padding: var(--rnen-space-3) var(--rnen-space-5);
	font-size: var(--rnen-font-size-md);
	font-weight: var(--rnen-font-weight-semibold);
	line-height: var(--rnen-line-height-tight);
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	border: var(--rnen-border-width) var(--rnen-border-style) transparent;
	border-radius: var(--rnen-radius-full);
	transition:
		color var(--rnen-transition-base),
		background-color var(--rnen-transition-base),
		border-color var(--rnen-transition-base);
}

.rnen-contato__button--primary {
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	background: var(--rnen-contato-accent);
	border-color: var(--rnen-contato-accent);
}

.rnen-contato__button--primary:hover,
.rnen-contato__button--primary:focus-visible {
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	background: var(--rnen-contato-accent-dark);
	border-color: var(--rnen-contato-accent-dark);
}

.rnen-contato__button--secondary {
	color: var(--rnen-contato-accent);
	background: transparent;
	border-color: var(--rnen-contato-accent);
}

.rnen-contato__button--secondary:hover,
.rnen-contato__button--secondary:focus-visible {
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	background: var(--rnen-contato-accent);
}

.rnen-contato__button:focus-visible,
.rnen-contato__social-link:focus-visible {
	outline: var(--rnen-border-width) var(--rnen-border-style) var(--rnen-color-focus);
	outline-offset: var(--rnen-space-1);
}

.rnen-contato__map-frame {
	overflow: hidden;
	min-height: 22rem;
	margin-block-start: var(--rnen-space-10);
	background:
		linear-gradient(135deg, var(--rnen-contato-accent-soft), transparent),
		var(--rnen-contato-surface-raised);
	border: var(--rnen-border-width) var(--rnen-border-style) var(--wp--preset--color--neutral-200, var(--rnen-color-border));
	border-radius: var(--rnen-radius-lg);
	box-shadow: var(--rnen-shadow-sm);
}

.rnen-contato__map-iframe {
	display: block;
	width: 100%;
	min-height: 22rem;
	border: 0;
}

.rnen-contato__faq-list {
	display: grid;
	gap: var(--rnen-space-4);
	margin-block-start: var(--rnen-space-10);
	text-align: left;
}

.rnen-contato__faq-question {
	position: relative;
	padding: var(--rnen-space-5) var(--rnen-space-12) var(--rnen-space-5) var(--rnen-space-5);
	color: var(--rnen-contato-title-color);
	font-size: var(--rnen-font-size-lg);
	font-weight: var(--rnen-font-weight-semibold);
	line-height: var(--rnen-line-height-heading);
	cursor: pointer;
}

.rnen-contato__faq-question::marker {
	content: "";
}

.rnen-contato__faq-question::after {
	position: absolute;
	top: 50%;
	right: var(--rnen-space-5);
	width: var(--rnen-space-3);
	height: var(--rnen-space-3);
	content: "";
	border-right: var(--rnen-border-width) var(--rnen-border-style) currentcolor;
	border-bottom: var(--rnen-border-width) var(--rnen-border-style) currentcolor;
	transform: translateY(-65%) rotate(45deg);
	transition: transform var(--rnen-transition-base);
}

.rnen-contato__faq-item[open] .rnen-contato__faq-question::after {
	transform: translateY(-35%) rotate(225deg);
}

.rnen-contato__faq-question:hover,
.rnen-contato__faq-question:focus-visible {
	color: var(--rnen-contato-accent);
}

.rnen-contato__faq-question:focus-visible {
	outline: var(--rnen-border-width) var(--rnen-border-style) var(--rnen-color-focus);
	outline-offset: var(--rnen-space-1);
}

.rnen-contato__faq-answer {
	padding: 0 var(--rnen-space-5) var(--rnen-space-5);
	color: var(--rnen-contato-text-color);
	font-size: var(--rnen-font-size-md);
	line-height: var(--rnen-line-height-base);
}

.rnen-contato__faq-answer p {
	margin-block-end: 0;
}

.rnen-contato--cta {
	background: var(--wp--preset--color--primary-900, var(--rnen-color-primary-900));
}

.rnen-contato__cta-box {
	display: grid;
	justify-items: center;
	max-width: 54rem;
	text-align: center;
}

.rnen-contato__cta-title {
	margin-block-end: var(--rnen-space-5);
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	font-size: var(--rnen-font-size-4xl);
}

.rnen-contato__cta-text {
	max-width: 42rem;
	margin-block-end: var(--rnen-space-8);
	color: var(--wp--preset--color--primary-50, var(--rnen-color-primary-50));
}

.rnen-contato__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--rnen-space-3);
}

.rnen-contato--cta .rnen-contato__button--primary {
	color: var(--wp--preset--color--primary-900, var(--rnen-color-primary-900));
	background: var(--wp--preset--color--neutral-0, var(--rnen-color-neutral-0));
	border-color: var(--wp--preset--color--neutral-0, var(--rnen-color-neutral-0));
}

.rnen-contato--cta .rnen-contato__button--primary:hover,
.rnen-contato--cta .rnen-contato__button--primary:focus-visible {
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	background: transparent;
	border-color: var(--wp--preset--color--primary-100, var(--rnen-color-primary-100));
}

.rnen-contato--cta .rnen-contato__button--secondary {
	color: var(--wp--preset--color--neutral-0, var(--rnen-color-text-inverse));
	border-color: var(--wp--preset--color--primary-100, var(--rnen-color-primary-100));
}

.rnen-contato--cta .rnen-contato__button--secondary:hover,
.rnen-contato--cta .rnen-contato__button--secondary:focus-visible {
	color: var(--wp--preset--color--primary-900, var(--rnen-color-primary-900));
	background: var(--wp--preset--color--neutral-0, var(--rnen-color-neutral-0));
	border-color: var(--wp--preset--color--neutral-0, var(--rnen-color-neutral-0));
}

@media (max-width: 63.9375rem) {
	.rnen-contato {
		padding-block: var(--rnen-space-12);
	}

	.rnen-contato__hero-grid,
	.rnen-contato__form-grid,
	.rnen-contato__social-card,
	.rnen-contato__cards {
		grid-template-columns: 1fr;
	}

	.rnen-contato__social-nav {
		justify-content: flex-start;
	}

	.rnen-contato__hero-title {
		max-width: 14ch;
		font-size: var(--rnen-font-size-4xl);
	}

	.rnen-contato__hero-media,
	.rnen-contato__cards,
	.rnen-contato__form-wrapper {
		max-width: 42rem;
	}

	.rnen-contato__cards,
	.rnen-contato__form-wrapper {
		margin-inline: auto;
	}
}

@media (max-width: 35.9375rem) {
	.rnen-contato {
		padding-block: var(--rnen-space-10);
	}

	.rnen-contato__hero-title,
	.rnen-contato__section-title,
	.rnen-contato__cta-title {
		font-size: var(--rnen-font-size-3xl);
	}

	.rnen-contato__hero-text,
	.rnen-contato__section-text,
	.rnen-contato__cta-text {
		font-size: var(--rnen-font-size-md);
	}

	.rnen-contato__hero-media::before {
		inset: var(--rnen-space-4) calc(var(--rnen-space-4) * -1) calc(var(--rnen-space-4) * -1) var(--rnen-space-4);
	}

	.rnen-contato__form {
		grid-template-columns: 1fr;
	}

	.rnen-contato__social-card,
	.rnen-contato__form-wrapper,
	.rnen-contato__card {
		padding: var(--rnen-space-5);
	}

	.rnen-contato__actions {
		display: grid;
		width: 100%;
	}

	.rnen-contato__button {
		width: 100%;
	}
}
