/* Contact patterns
---------------------------------------------------------------------------- */

.cn-contact-template,
.cn-contact-page {
	background: var(--cn-bg);
	color: var(--cn-text);
}

.cn-contact-page {
	overflow: hidden;
}

.cn-contact-hero,
.cn-contact-facts,
.cn-contact-form-section {
	margin-block: 0;
}

.cn-contact-hero > *,
.cn-contact-facts > *,
.cn-contact-form-section > * {
	margin-inline: 0 !important;
	max-width: none !important;
}

.cn-contact-hero__meta,
.cn-contact-hero__tags {
	align-items: center;
	color: var(--cn-text-muted);
	display: flex;
	gap: 0.7rem;
}

.cn-contact-hero__eyebrow,
.cn-contact-hero__availability,
.cn-contact-fact__label {
	font-family: var(--cn-font-mono);
	font-size: 0.8125rem;
	font-weight: 650;
	letter-spacing: 0;
	line-height: 1.2;
	text-transform: uppercase;
}

.cn-contact-hero__eyebrow,
.cn-contact-hero__availability {
	color: var(--cn-text-muted);
	margin: 0 !important;
}

.cn-contact-hero__eyebrow::after {
	color: var(--cn-border-strong);
	content: "/";
	margin-inline-start: 0.7rem;
}

.cn-contact-hero__title {
	color: var(--cn-text);
	font-size: clamp(3.25rem, 10vw, 8.75rem);
	font-weight: 650;
	letter-spacing: 0;
	line-height: 0.9;
	margin: clamp(1.35rem, 3vw, 2rem) 0 0;
	max-width: 10.8ch !important;
}

.cn-contact-hero__summary {
	color: var(--cn-text-muted);
	font-size: clamp(1.1rem, 1.9vw, 1.45rem);
	line-height: 1.45;
	margin-block-start: clamp(1.5rem, 3vw, 2.25rem);
	max-width: 54rem !important;
}

.cn-contact-hero__summary a {
	color: var(--cn-text);
	text-decoration-color: var(--cn-accent);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.16em;
}

.cn-contact-hero__summary a:hover,
.cn-contact-hero__summary a:focus-visible {
	color: var(--cn-accent);
}

.cn-contact-hero__tags {
	margin-block-start: clamp(1.35rem, 3vw, 2rem);
}

.cn-contact-hero__tags p {
	background: var(--cn-bg-card);
	color: var(--cn-text);
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 560;
	line-height: 1;
	margin: 0 !important;
	padding: 0.55rem 0.75rem;
}

.cn-contact-facts {
	border-block: 1px solid var(--cn-border);
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-block-start: clamp(2rem, 5vw, 4rem);
}

.cn-contact-fact {
	margin: 0 !important;
	min-width: 0;
	padding: clamp(1.1rem, 2.4vw, 1.6rem) clamp(1rem, 2vw, 1.35rem) clamp(1.1rem, 2.4vw, 1.6rem) 0 !important;
}

.cn-contact-fact + .cn-contact-fact {
	border-left: 1px solid var(--cn-border);
	padding-left: clamp(1rem, 2vw, 1.35rem) !important;
}

.cn-contact-fact__label,
.cn-contact-fact__value {
	margin: 0 !important;
}

.cn-contact-fact__label {
	color: var(--cn-text-muted);
}

.cn-contact-fact__value {
	color: var(--cn-text);
	font-size: 0.98rem;
	font-weight: 540;
	line-height: 1.45;
	margin-block-start: 0.55rem !important;
}

.cn-contact-form-section {
	margin-block-start: clamp(4rem, 8vw, 7rem);
}

.cn-contact-form-section__title {
	color: var(--cn-text);
	font-size: clamp(2.35rem, 5.8vw, 5rem);
	font-weight: 640;
	letter-spacing: 0;
	line-height: 0.95;
	margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
}

.cn-contact-form-block {
	margin: 0;
}

.cn-contact-form-block--editor {
	border: 1px solid var(--cn-border);
	color: var(--cn-text-muted);
	display: grid;
	font-size: 0.95rem;
	gap: 0.35rem;
	line-height: 1.35;
	padding: 1rem;
}

.cn-contact-form-block--editor strong {
	color: var(--cn-text);
}

.cn-contact-form-block--editor span {
	font-family: var(--cn-font-mono);
	font-size: 0.82rem;
	overflow-wrap: anywhere;
}

.cn-contact-page .wpcf7 {
	margin: 0;
}

.cn-contact-page .wpcf7 form {
	display: grid;
	gap: clamp(1rem, 2vw, 1.35rem);
	margin: 0;
}

.cn-contact-page .wpcf7 p {
	margin: 0;
}

.cn-contact-page .wpcf7 label {
	color: var(--cn-text);
	display: grid;
	font-size: 0.88rem;
	font-weight: 650;
	gap: 0.52rem;
	line-height: 1.2;
}

.cn-contact-page .wpcf7-form-control-wrap {
	display: block;
	position: relative;
}

.cn-contact-page .wpcf7 input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.cn-contact-page .wpcf7 select,
.cn-contact-page .wpcf7 textarea {
	background: var(--cn-bg-card);
	border: 1px solid var(--cn-border);
	border-radius: 0;
	box-shadow: none;
	color: var(--cn-text);
	font-size: 1rem;
	inline-size: 100%;
	line-height: 1.2;
	min-height: 3.35rem;
	padding: 0.9rem 1rem;
	transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, color 160ms ease;
}

.cn-contact-page .wpcf7 textarea {
	line-height: 1.55;
	min-height: clamp(10rem, 18vw, 14rem);
	resize: vertical;
}

.cn-contact-page .wpcf7 input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]):focus,
.cn-contact-page .wpcf7 select:focus,
.cn-contact-page .wpcf7 textarea:focus {
	background: var(--cn-bg-elevated);
	border-color: var(--cn-accent);
	box-shadow: inset 0 -2px 0 var(--cn-accent);
	outline: 0;
}

.cn-contact-page .wpcf7 input::placeholder,
.cn-contact-page .wpcf7 textarea::placeholder {
	color: var(--cn-text-muted);
	opacity: 0.68;
}

.cn-contact-page .wpcf7 input[type="submit"] {
	align-items: center;
	appearance: none;
	background: var(--cn-text);
	border: 1px solid var(--cn-text);
	border-radius: 0;
	color: var(--cn-bg);
	cursor: pointer;
	display: inline-flex;
	font-size: var(--wp--preset--font-size--x-small);
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0;
	line-height: 1;
	min-height: 3.45rem;
	padding: 0.9rem 1.2rem;
	text-transform: uppercase;
	transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
	width: 100%;
}

.cn-contact-page .wpcf7 input[type="submit"]:hover,
.cn-contact-page .wpcf7 input[type="submit"]:focus-visible {
	background: var(--cn-accent);
	border-color: var(--cn-accent);
	color: var(--cn-bg);
	transform: translateY(-1px);
}

.cn-contact-page .wpcf7-spinner {
	margin: 0.75rem 0 0;
}

.cn-contact-page .wpcf7-not-valid-tip {
	color: var(--cn-danger);
	font-size: 0.82rem;
	line-height: 1.35;
	margin-block-start: 0.4rem;
}

.cn-contact-page .wpcf7 form .wpcf7-response-output {
	border: 1px solid var(--cn-border);
	color: var(--cn-text-muted);
	font-size: 0.95rem;
	line-height: 1.45;
	margin: 0;
	padding: 0.9rem 1rem;
}

.cn-contact-page .wpcf7 form.sent .wpcf7-response-output {
	border-color: var(--cn-success);
	color: var(--cn-success);
}

.cn-contact-page .wpcf7 form.invalid .wpcf7-response-output,
.cn-contact-page .wpcf7 form.failed .wpcf7-response-output,
.cn-contact-page .wpcf7 form.aborted .wpcf7-response-output,
.cn-contact-page .wpcf7 form.spam .wpcf7-response-output {
	border-color: var(--cn-danger);
	color: var(--cn-danger);
}

.cn-contact-page__fallback {
	border-block: 1px solid var(--cn-border);
	color: var(--cn-text-muted);
	display: grid;
	gap: 1.25rem;
	padding-block: 1.25rem;
}

.cn-contact-page__fallback p {
	font-size: 1rem;
	line-height: 1.55;
	margin: 0;
}

.cn-contact-page__fallback .wp-block-buttons {
	margin: 0;
}

@media (max-width: 781px) {
	.cn-contact-page {
		padding-inline: var(--wp--preset--spacing--small) !important;
	}

	.cn-contact-hero__meta {
		align-items: flex-start;
		flex-direction: column;
		gap: 0.45rem;
	}

	.cn-contact-hero__eyebrow::after {
		content: none;
	}

	.cn-contact-facts {
		grid-template-columns: 1fr;
	}

	.cn-contact-fact,
	.cn-contact-fact + .cn-contact-fact {
		border-left: 0;
		padding-left: 0 !important;
	}

	.cn-contact-fact + .cn-contact-fact {
		border-top: 1px solid var(--cn-border);
	}
}
