:root {
	--container-max: 1200px;
	--gap: 24px;
	--radius: 8px;
}

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 16px;
}

.contact-hero {
	padding: 40px 0 16px;
}
.contact-hero h1 {
	font-size: 36px;
	color: #51291E;
	margin-bottom: 8px;
}
.contact-hero .lead {
	color: #525356;
	font-size: 20px;
}

.contact-content {
	padding: 24px 0 48px;
}
.contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gap);
}
@media (min-width: 840px) {
	.contact-grid {
		grid-template-columns: 1.2fr 1fr;
	}
}

.contact-info, .contact-form {
	background: #fff;
	border-radius: var(--radius);
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
	padding: 16px;
}
.contact-info h2, .contact-form h2 {
	margin-bottom: 12px;
	font-size: 32px;
	color: #51291E;
}

.map iframe {
	width: 100%;
	height: 320px;
	border: 0;
	border-radius: var(--radius);
}

.map-link {
	margin-top: 8px;
}
.map-link a {
	color: var(--brown);
	text-decoration: underline;
}
.map-link a:hover {
	text-decoration: none;
}

.form-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 12px;
}
.form-field input,
.form-field textarea {
	border: 1px solid #ddd;
	border-radius: var(--radius);
	padding: 10px 12px;
	font-size: 1rem;
}
.form-field input:focus,
.form-field textarea:focus {
	outline: none;
	border-color: #999;
	box-shadow: 0 0 0 3px rgba(0,0,0,0.06);
}

.btn-primary {
	display: inline-block;
	background: var(--brown);
	color: #fff;
	border: none;
	border-radius: var(--radius);
	padding: 14px 16px;
	cursor: pointer;
}
.btn-primary:hover {
	background: #51291E;
}

.form-note {
	font-size: 0.9rem;
	color: #555;
	margin-top: 8px;
}

