/*
 * Contact page styles.
 *
 * Single section, white background, centred header above a two-column
 * grid (form left, details right at desktop; details above form on
 * mobile so visitors see contact info first).
 *
 * Page-scoped — no duplicated component rules.
 */

.mhg-contact {
	background-color: var(--mhg-color-white);
	padding: 5rem 0 6rem;
}

.mhg-contact__inner {
	width: 100%;
	max-width: var(--mhg-container-max);
	margin: 0 auto;
	padding: 0 var(--mhg-space-sm);
	box-sizing: border-box;
}

/* ============================================================
 * Centred header
 * ============================================================ */
.mhg-contact__header {
	text-align: center;
	margin: 0 auto var(--mhg-space-xl);
	max-width: 640px;
}

.mhg-contact__eyebrow {
	display: inline-block;
	margin: 0 0 var(--mhg-space-sm);
	font-family: var(--mhg-font-body);
	font-size: var(--mhg-font-size-eyebrow);
	font-weight: 600;
	color: var(--mhg-color-teal);
	text-transform: uppercase;
	letter-spacing: var(--mhg-letter-spacing-eyebrow);
}

.mhg-contact__heading {
	margin: 0 0 var(--mhg-space-sm);
	font-family: var(--mhg-font-heading);
	font-size: 2.25rem;
	color: var(--mhg-color-charcoal);
	line-height: 1.2;
}

.mhg-contact__rule {
	display: block;
	width: 48px;
	height: 3px;
	margin: 0 auto var(--mhg-space-md);
	background-color: var(--mhg-color-gold);
}

.mhg-contact__lede {
	margin: 0 auto;
	max-width: 520px;
	font-family: var(--mhg-font-body);
	font-weight: 300;
	font-size: var(--mhg-font-size-body);
	line-height: var(--mhg-line-height-body);
	color: #666;
}

/* ============================================================
 * Two-column body — form + details
 * Mobile-first: details first (visitor sees contact info first),
 * form second. Desktop reorders to form left / details right.
 * ============================================================ */
.mhg-contact__body {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--mhg-space-lg);
}

/* Mobile DOM order is form first (form is the primary action and stays
   first for screen-reader / no-CSS contexts). Visually we want contact
   details above the form on narrow viewports so visitors see the
   contact info first — use grid order to flip. Desktop resets to 0. */
.mhg-contact-details {
	order: -1;
}

/* ============================================================
 * Contact form
 * ============================================================ */
.mhg-contact-form {
	background-color: #f8f7f5;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: var(--mhg-radius-lg);
	padding: 2.5rem;
}

/* The form itself is rendered by Contact Form 7. CF7 wraps each field in
   a <p> with a <label> containing the input. We restyle that default
   markup here to match the previous static form. */
.mhg-contact-form .wpcf7-form {
	display: flex;
	flex-direction: column;
	gap: var(--mhg-space-sm);
}

.mhg-contact-form .wpcf7-form p {
	margin: 0;
}

.mhg-contact-form .wpcf7-form label {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	font-family: var(--mhg-font-body);
	font-size: 0.8rem;
	font-weight: 500;
	color: var(--mhg-color-charcoal);
}

.mhg-contact-form .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
}

.mhg-contact-form .wpcf7-form input[type="text"],
.mhg-contact-form .wpcf7-form input[type="email"],
.mhg-contact-form .wpcf7-form select,
.mhg-contact-form .wpcf7-form textarea {
	width: 100%;
	font-family: var(--mhg-font-body);
	font-size: 0.95rem;
	color: var(--mhg-color-charcoal);
	background-color: var(--mhg-color-white);
	border: 1px solid rgba(0, 0, 0, 0.12);
	border-radius: var(--mhg-radius-sm);
	padding: 0.65rem 0.85rem;
	box-sizing: border-box;
	transition: border-color var(--mhg-transition-fast);
}

.mhg-contact-form .wpcf7-form input:focus,
.mhg-contact-form .wpcf7-form select:focus,
.mhg-contact-form .wpcf7-form textarea:focus {
	border-color: var(--mhg-color-teal);
	outline: none;
}

.mhg-contact-form .wpcf7-form select {
	appearance: none;
	-webkit-appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--mhg-color-charcoal) 50%),
		linear-gradient(135deg, var(--mhg-color-charcoal) 50%, transparent 50%);
	background-position: calc(100% - 18px) calc(50% - 2px), calc(100% - 13px) calc(50% - 2px);
	background-size: 5px 5px, 5px 5px;
	background-repeat: no-repeat;
	padding-right: 2rem;
}

.mhg-contact-form .wpcf7-form textarea {
	resize: vertical;
	min-height: 140px;
}

.mhg-contact-form .wpcf7-submit {
	width: 100%;
	margin-top: var(--mhg-space-sm);
	padding: 0.95rem 1.5rem;
	font-family: var(--mhg-font-body);
	font-size: var(--mhg-font-size-button);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: var(--mhg-letter-spacing-button);
	color: var(--mhg-color-white);
	background-color: var(--mhg-color-teal);
	border: 1px solid var(--mhg-color-teal);
	border-radius: var(--mhg-radius-sm);
	cursor: pointer;
	transition: background-color var(--mhg-transition-fast),
		border-color var(--mhg-transition-fast);
}

.mhg-contact-form .wpcf7-submit:hover,
.mhg-contact-form .wpcf7-submit:focus {
	background-color: var(--mhg-color-teal-dark);
	border-color: var(--mhg-color-teal-dark);
	outline: none;
}

/* CF7 response messages and validation tips */
.mhg-contact-form .wpcf7-response-output {
	margin: var(--mhg-space-sm) 0 0;
	padding: 0.85rem 1rem;
	border-radius: var(--mhg-radius-sm);
	font-size: 0.95rem;
}

.mhg-contact-form .wpcf7 form.sent .wpcf7-response-output {
	color: var(--mhg-color-teal-dark);
	background-color: rgba(26, 92, 92, 0.08);
	border: 1px solid rgba(26, 92, 92, 0.2);
}

.mhg-contact-form .wpcf7 form.failed .wpcf7-response-output,
.mhg-contact-form .wpcf7 form.aborted .wpcf7-response-output,
.mhg-contact-form .wpcf7 form.invalid .wpcf7-response-output,
.mhg-contact-form .wpcf7 form.unaccepted .wpcf7-response-output,
.mhg-contact-form .wpcf7 form.spam .wpcf7-response-output {
	color: #8a1a1a;
	background-color: rgba(138, 26, 26, 0.06);
	border: 1px solid rgba(138, 26, 26, 0.2);
}

.mhg-contact-form .wpcf7-not-valid-tip {
	margin-top: 0.3rem;
	font-size: 0.85rem;
	color: #8a1a1a;
}

.mhg-contact-form .wpcf7-spinner {
	margin-left: 0.5rem;
	vertical-align: middle;
}

/* ============================================================
 * Contact details sidebar
 * ============================================================ */
.mhg-contact-details {
	display: flex;
	flex-direction: column;
	gap: var(--mhg-space-md);
}

.mhg-contact-details__heading {
	margin: 0 0 var(--mhg-space-sm);
	font-family: var(--mhg-font-body);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--mhg-color-charcoal);
	text-transform: uppercase;
	letter-spacing: var(--mhg-letter-spacing-eyebrow);
}

.mhg-contact-details__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--mhg-space-sm);
}

.mhg-contact-details__item {
	display: flex;
	align-items: center;
	gap: 0.85rem;
}

.mhg-contact-details__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: #f8f7f5;
	color: var(--mhg-color-teal);
}

.mhg-contact-details__icon svg {
	width: 18px;
	height: 18px;
	display: block;
}

.mhg-contact-details__link,
.mhg-contact-details__text {
	font-family: var(--mhg-font-body);
	font-size: 0.95rem;
	color: var(--mhg-color-charcoal);
	text-decoration: none;
}

.mhg-contact-details__link:hover,
.mhg-contact-details__link:focus {
	color: var(--mhg-color-teal);
}

.mhg-contact-details__response {
	background-color: #f8f7f5;
	border-left: 3px solid var(--mhg-color-gold);
	border-radius: var(--mhg-radius-sm);
	padding: var(--mhg-space-md);
	margin-top: var(--mhg-space-sm);
}

.mhg-contact-details__response-body {
	margin: 0;
	font-family: var(--mhg-font-body);
	font-weight: 300;
	font-size: 0.9rem;
	line-height: var(--mhg-line-height-body);
	color: #555;
}

/* ============================================================
 * Tablet+ — form left, details right
 * Mobile keeps the source order (details above, form below) thanks
 * to grid order: at ≥768 we explicitly flip them.
 * ============================================================ */
@media (min-width: 768px) {
	.mhg-contact {
		padding: 5rem 0 6rem;
	}

	.mhg-contact__inner {
		padding: 0 var(--mhg-space-md);
	}

	.mhg-contact__heading {
		font-size: 2.75rem;
	}

	.mhg-contact__body {
		grid-template-columns: 1.2fr 1fr;
		gap: var(--mhg-space-xl);
		align-items: flex-start;
	}

	/* Reset the mobile `order: -1` on details and place via grid columns. */
	.mhg-contact-form {
		order: 0;
		grid-column: 1;
	}

	.mhg-contact-details {
		order: 0;
		grid-column: 2;
	}
}
