.contact-section {
	padding-block: var(--space-7);
	background: var(--color-bg);
}

.contact {
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
	gap: clamp(var(--space-6), 6vw, var(--space-8));
	align-items: start;
}

.contact > * {
	min-width: 0;
}

.contact__form .wpcf7-form-control-wrap {
	display: block;
}

.contact__info {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
	padding: clamp(var(--space-5), 4vw, var(--space-7));
	background: var(--color-bg-soft);
	border-radius: var(--radius-md);
}

.contact__title {
	color: var(--color-text);
	font-size: clamp(2rem, 3.4vw, 2.75rem);
	font-weight: 800;
	line-height: 1.15;
}

.contact__content {
	color: var(--color-text);
	font-size: 1.0625rem;
	line-height: 1.55;
}

.contact__content p {
	margin-bottom: 1em;
}

.contact__content p:last-child {
	margin-bottom: 0;
}

.contact__content a {
	color: var(--color-active);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.contact__content a:hover,
.contact__content a:focus-visible {
	color: var(--color-active-dark);
}

.contact__form {
	padding: clamp(var(--space-5), 4vw, var(--space-7));
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
}

/* Contact Form 7 styling -------------------------------------------------- */

.contact__form .wpcf7-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.contact__form p {
	margin: 0;
}

.contact__form label {
	display: flex;
	flex-direction: column;
	gap: 6px;
	color: var(--color-text);
	font-size: 0.95rem;
	font-weight: 600;
}

.contact__form .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-acceptance):not([type="checkbox"]):not([type="radio"]) {
	width: 100%;
	padding: 12px 14px;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font: inherit;
	font-weight: 400;
	line-height: 1.4;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact__form textarea.wpcf7-form-control {
	min-height: 140px;
	resize: vertical;
}

.contact__form .wpcf7-form-control:not(.wpcf7-submit):focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(139, 31, 79, 0.15);
}

.contact__form .wpcf7-submit {
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 14px 30px;
	border: 0;
	border-radius: var(--radius-pill);
	background: var(--color-active);
	color: var(--color-white);
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.2;
	cursor: pointer;
	transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.contact__form .wpcf7-submit:hover,
.contact__form .wpcf7-submit:focus-visible {
	background: var(--color-active-dark);
}

.contact__form .wpcf7-submit:active {
	transform: translateY(1px);
}

.contact__form .wpcf7-not-valid-tip {
	margin-top: 4px;
	color: var(--color-accent);
	font-size: 0.85rem;
	font-weight: 600;
}

.contact__form .wpcf7-response-output {
	margin: var(--space-4) 0 0;
	padding: 12px 16px;
	border-radius: var(--radius-sm);
	font-size: 0.95rem;
}

@media (max-width: 899px) {
	.contact {
		grid-template-columns: 1fr;
		gap: var(--space-5);
	}
}

@media (max-width: 639px) {
	.contact-section {
		padding-block: var(--space-6);
	}

	.contact__form .wpcf7-submit {
		width: 100%;
		min-height: 48px;
		padding: 12px 22px;
		font-size: 1rem;
	}
}
