.contact-page {
	padding-top: 62px;
}

.contact-hero {
	width: min(100%, 860px);
	margin-inline: auto;
	text-align: center;
}

.contact-hero p {
	margin-bottom: 8px;
	color: var(--woodghar-primary-dark);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0;
}

.contact-hero h1 {
	margin-bottom: 16px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 54px;
	line-height: 1.04;
	font-weight: 500;
	letter-spacing: 0;
}

.contact-hero span {
	display: block;
	color: var(--woodghar-muted);
	font-size: 18px;
}

.contact-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 0.48fr);
	gap: 28px;
	margin-top: 50px;
}

.contact-form,
.contact-details {
	padding: 28px;
	border: 1px solid var(--woodghar-border);
	border-radius: var(--woodghar-radius);
	background: var(--woodghar-white);
	box-shadow: 0 18px 50px rgba(29, 44, 31, 0.06);
}

.contact-form {
	display: grid;
	gap: 16px;
}

.contact-form label {
	display: grid;
	gap: 7px;
	color: var(--woodghar-muted);
	font-weight: 700;
}

.contact-form button {
	min-height: 48px;
	border: 0;
	border-radius: var(--woodghar-radius);
	background: var(--woodghar-primary);
	color: var(--woodghar-white);
	font-weight: 800;
}

.contact-form p {
	min-height: 22px;
	margin: 0;
}

.contact-details {
	display: grid;
	align-content: start;
	gap: 12px;
}

.contact-details h2 {
	margin-bottom: 10px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 31px;
	line-height: 1.14;
	font-weight: 500;
	letter-spacing: 0;
}

.contact-details a {
	color: var(--woodghar-primary-dark);
	font-weight: 750;
	text-decoration: none;
}

.contact-map {
	display: grid;
	place-items: center;
	min-height: 360px;
	margin-top: 34px;
	padding: 30px;
	border-radius: var(--woodghar-radius);
	background:
		linear-gradient(135deg, rgba(33, 29, 23, 0.92), rgba(18, 59, 32, 0.82)),
		var(--woodghar-primary);
	color: var(--woodghar-white);
	text-align: center;
}

.contact-map p {
	margin-bottom: 8px;
	color: var(--woodghar-secondary);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0;
}

.contact-map h2 {
	width: min(100%, 680px);
	margin: 0;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 34px;
	line-height: 1.16;
	font-weight: 500;
	letter-spacing: 0;
}

.contact-faq {
	padding-top: 78px;
}

.contact-faq details {
	padding: 20px 0;
	border-top: 1px solid var(--woodghar-border);
}

.contact-faq details:last-child {
	border-bottom: 1px solid var(--woodghar-border);
}

.contact-faq summary {
	cursor: pointer;
	color: var(--woodghar-ink);
	font-size: 19px;
	font-weight: 800;
	letter-spacing: 0;
}

.contact-faq details p {
	margin: 12px 0 0;
	max-width: 780px;
}

@media (max-width: 860px) {
	.contact-layout {
		grid-template-columns: 1fr;
	}

	.contact-hero h1 {
		font-size: 38px;
	}
}

@media (max-width: 560px) {
	.contact-page {
		padding-top: 38px;
	}

	.contact-form,
	.contact-details {
		padding: 22px;
	}

	.contact-map h2 {
		font-size: 27px;
	}
}
