.page-contact-us {
	background: var(--color-bg);
	color: var(--color-text);
	padding-top: clamp(4.5rem, 8vw, 7rem);
	padding-bottom: clamp(3.5rem, 7vw, 6rem);
}

.contact-shell {
	width: min(100% - 3rem, var(--container));
	max-width: var(--container);
	margin-inline: auto;
}

.contact-header {
	text-align: center;
	margin-bottom: clamp(2rem, 4vw, 4rem);
	display: grid;
	justify-items: center;
	gap: 0.75rem;
}

.contact-header h1 {
	font-size: clamp(2.4rem, 11vw, 8rem);
	line-height: 0.86;
	letter-spacing: -0.05em;
	text-transform: uppercase;
	color: var(--color-text);
	text-shadow: 0 0 24px color-mix(in srgb, var(--color-primary) 30%, transparent);
}

.contact-header p {
	max-width: 65ch;
	font: 400 clamp(0.92rem, 1.9vw, 1.1rem)/1.7 "Inter", sans-serif;
	color: color-mix(in srgb, var(--color-text-muted) 82%, var(--color-text));
}

.contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 3vw, 2.5rem);
	margin-bottom: clamp(2rem, 6vw, 3.5rem);
}

.contact-form-wrap {
	background: var(--color-surface-low);
	padding: clamp(1.2rem, 4vw, 3rem) clamp(1.2rem, 4vw, 3rem) clamp(1rem, 2.6vw, 1.9rem);
	border: 1px solid color-mix(in srgb, var(--color-outline-variant) 28%, transparent);
	box-shadow: var(--shadow-ambient);
}

.contact-form {
	display: grid;
	gap: 1.15rem;
}

.contact-form-status {
	margin: 0 0 1rem;
	padding: 0.85rem 1rem;
	border-radius: 0.8rem;
	font: 700 0.75rem/1.4 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border: 1px solid transparent;
}

.contact-form-status--success {
	background: color-mix(in srgb, #0f3d2e 72%, var(--color-surface-low));
	color: #d9f6ea;
	border-color: color-mix(in srgb, #1f6f52 60%, transparent);
}

.contact-form-status--error {
	background: color-mix(in srgb, #3d0f1b 72%, var(--color-surface-low));
	color: #ffd6de;
	border-color: color-mix(in srgb, #7a1f35 60%, transparent);
}

.field-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}

.field {
	display: grid;
	gap: 0.5rem;
	padding-bottom: 2rem;
}

.field label {
	font: 700 0.66rem/1 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: color-mix(in srgb, var(--color-text-muted) 76%, var(--color-text));
}

.field input,
.field select,
.field textarea {
	width: 100%;
	border: 1px solid transparent;
	outline: none;
	background: var(--color-surface-lowest);
	padding: 0.95rem 1rem;
	font: 600 0.88rem/1.4 "Inter", sans-serif;
	color: var(--color-text);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.field input::placeholder,
.field textarea::placeholder {
	color: color-mix(in srgb, var(--color-text-muted) 60%, transparent);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.field select {
	appearance: none;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	cursor: pointer;
}

.field textarea {
	resize: vertical;
	min-height: 7rem;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
	border-color: color-mix(in srgb, var(--color-primary) 60%, transparent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.contact-submit {
	border: 0;
	padding: 1rem 1.2rem;
	font: 800 0.9rem/1 "Epilogue", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: #fff;
	background: linear-gradient(135deg, var(--color-primary), var(--color-primary-strong));
	cursor: pointer;
	transition: transform 0.2s ease, filter 0.2s ease;
}

.contact-submit:hover {
	filter: brightness(1.08);
	transform: translateY(-1px);
}

.contact-submit:active {
	transform: scale(0.98);
}

.contact-meta {
	display: grid;
	gap: 1.1rem;
	align-content: start;
}

.contact-whatsapp-card {
	margin-top: 0.2rem;
	background: var(--color-surface-low);
	border: 1px solid color-mix(in srgb, var(--color-outline-variant) 28%, transparent);
	padding: 1rem;
	display: grid;
	gap: 0.75rem;
	justify-items: center;
	text-align: center;
	color: inherit;
	text-decoration: none;
	cursor: pointer;
}

.contact-whatsapp-head {
	display: grid;
	justify-items: center;
	gap: 0.2rem;
}

.contact-whatsapp-head .material-symbols-outlined {
	font-size: 1.35rem;
	color: var(--color-primary);
}

.contact-whatsapp-head h4 {
	font-size: 1.05rem;
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.contact-whatsapp-head p,
.contact-whatsapp-note {
	margin: 0;
	font: 700 0.56rem/1.2 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: color-mix(in srgb, var(--color-text-muted) 84%, var(--color-text));
}

.contact-whatsapp-qr {
	width: min(12rem, 100%);
	aspect-ratio: 1 / 1;
	background: var(--color-surface-lowest);
	border: 1px dashed color-mix(in srgb, var(--color-outline-variant) 42%, transparent);
	display: grid;
	place-items: center;
}

.contact-whatsapp-qr img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

.meta-card {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	padding: 1rem 0.6rem;
	transition: background-color 0.2s ease;
}

.meta-card:hover {
	background: color-mix(in srgb, var(--color-surface) 75%, transparent);
}

.meta-icon {
	width: 2.7rem;
	height: 2.7rem;
	border-radius: 999px;
	display: grid;
	place-items: center;
	background: var(--color-surface);
	color: var(--color-primary);
	transition: background-color 0.2s ease, color 0.2s ease;
	flex-shrink: 0;
}

.meta-card:hover .meta-icon {
	background: var(--color-primary);
	color: #fff;
}

.meta-card h4 {
	font-size: 1.05rem;
	margin-bottom: 0.35rem;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.meta-card p {
	font-size: 0.92rem;
	line-height: 1.7;
	color: color-mix(in srgb, var(--color-text-muted) 86%, var(--color-text));
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.contact-map {
	margin-top: 0.8rem;
}

.map-panel {
	position: relative;
	min-height: clamp(16rem, 43vw, 25rem);
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-outline-variant) 28%, transparent);
	background: var(--color-surface-lowest);
	box-shadow: var(--shadow-ambient);
}

.map-panel::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		linear-gradient(
			160deg,
			color-mix(in srgb, var(--color-primary) 14%, transparent) 0%,
			transparent 45%
		),
		linear-gradient(
			360deg,
			color-mix(in srgb, var(--color-primary-strong) 16%, transparent) 0%,
			transparent 55%
		);
	mix-blend-mode: multiply;
}

.map-embed {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	filter: saturate(0.85) hue-rotate(-6deg) contrast(1.08) brightness(0.96);
}

html[data-theme="dark"] .map-panel::after {
	background:
		linear-gradient(
			155deg,
			color-mix(in srgb, var(--color-primary) 22%, transparent) 0%,
			transparent 52%
		),
		linear-gradient(
			360deg,
			color-mix(in srgb, var(--color-primary-strong) 48%, transparent) 0%,
			transparent 58%
		);
	mix-blend-mode: screen;
}

html[data-theme="dark"] .map-embed {
	filter: saturate(0.82) hue-rotate(-8deg) contrast(1.12) brightness(0.86);
}

[data-reveal] {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.65s ease, transform 0.65s ease;
}

[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (min-width: 920px) {
	.contact-grid {
		grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
		gap: clamp(1.4rem, 3vw, 3rem);
	}

	.field-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
