/**
 * contact.css — Contact page styles.
 *
 * Loaded by src/contact.njk via its `styles:` frontmatter array.
 *
 * Single section: CONTACT PAGE — the form + availability copy + the
 * Turnstile widget integration styling at `/contact/`.
 *
 * Extracted from src/assets/css/app.css CONTACT PAGE section as part
 * of #147 PR 2 — CSS file split: static pages. Content byte-for-byte
 * preserved.
 */

/* ─────────────────────────────────────────────────────────────────────
	CONTACT PAGE
	─────────────────────────────────────────────────────────────────────
	The /contact/ page. Markup in `src/contact.njk` (converted from
	the original src/contact.md during the #50 static-pages polish).
	Two-column layout: alt-contact-paths sidebar on the left, htmx-
	wired form on the right.

	Form wiring stays exactly as it was (htmx → /api/contact, handled
	by functions/api/contact.ts from #27, Turnstile via cf-turnstile
	div). Class names migrated from `.contact-*` to `.innov8-contact-*`
	for consistency with the rest of the static-pages set; styles
	moved from inline <style> in the original contact.md into the
	layered component vocabulary here.

	Class prefix: `innov8-contact-`.
	───────────────────────────────────────────────────────────────────── */

@layer components {
	.innov8-contact {
		position: relative;
		color: var(--fg-primary);
	}

	/* Hero header CSS lives in the PAGE HEADER PARTIAL block (in shared.css
		the ABOUT PAGE section) — `.innov8-page-header-*` rules serve
		about / services / recs / contact uniformly. The
		`.innov8-contact-availability-pill` lives inside the partial's
		`.innov8-page-header-extras` slot. */

	.innov8-contact-availability-pill {
		display: inline-flex;
	}

	/* ─── Form section — two-column layout ──────────────────────────── */
	.innov8-contact-form-section {
		padding: clamp(48px, 6vw, 80px) 0 clamp(72px, 9vw, 112px);
		background: var(--color-ink-950);
		border-top: 1px solid var(--border-subtle);
	}

	.innov8-contact-grid {
		display: grid;
		gap: clamp(32px, 4vw, 56px);
		grid-template-columns: 1fr;
		align-items: start;
	}

	@media (min-width: 880px) {
		.innov8-contact-grid {
			grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
		}
	}

	/* ─── Alternative-contact sidebar ───────────────────────────────── */
	.innov8-contact-alt {
		display: flex;
		flex-direction: column;
		gap: 20px;
	}

	@media (min-width: 880px) {
		.innov8-contact-alt {
			position: sticky;
			top: 140px; /* clear the floating nav */
		}
	}

	.innov8-contact-alt-title {
		margin: 0;
		font-family: var(--font-display);
		font-weight: 700;
		font-size: clamp(20px, 2vw, 26px);
		line-height: 1.2;
		letter-spacing: var(--tracking-snug);
		color: var(--fg-primary);
		text-transform: uppercase;
		text-wrap: balance;
	}

	.innov8-contact-alt-list {
		display: flex;
		flex-direction: column;
		gap: 16px;
		margin: 0;
		padding: 0;
		list-style: none;
	}

	.innov8-contact-alt-item {
		display: flex;
		flex-direction: column;
		gap: 4px;
	}

	.innov8-contact-alt-label {
		font-family: var(--font-mono);
		font-size: var(--text-overline);
		font-weight: 500;
		letter-spacing: 0.14em;
		text-transform: uppercase;
		color: var(--fg-tertiary);
	}

	.innov8-contact-alt-link {
		display: inline-flex;
		align-items: center;
		gap: 6px;
		font-family: var(--font-sans);
		font-size: var(--text-body);
		color: var(--accent-spark);
		text-decoration: none;
		transition: gap var(--duration-base) var(--ease-out);
	}

	.innov8-contact-alt-link:hover,
	.innov8-contact-alt-link:focus-visible {
		gap: 10px;
		outline: none;
	}

	.innov8-contact-alt-value {
		font-family: var(--font-sans);
		font-size: var(--text-body);
		color: var(--fg-secondary);
	}

	.innov8-contact-alt-fineprint {
		margin: 12px 0 0;
		font-family: var(--font-sans);
		font-size: var(--text-body-sm);
		line-height: var(--leading-base);
		color: var(--fg-muted);
		text-wrap: pretty;
	}

	/* ─── Form column ───────────────────────────────────────────────── */
	.innov8-contact-form-wrap {
		display: flex;
		flex-direction: column;
		gap: 20px;
	}

	.innov8-contact-response:empty {
		display: none;
	}

	.innov8-contact-form {
		display: flex;
		flex-direction: column;
		gap: 20px;
	}

	.innov8-contact-field {
		display: flex;
		flex-direction: column;
		gap: 8px;
	}

	.innov8-contact-label {
		font-family: var(--font-mono);
		font-size: var(--text-overline);
		font-weight: 500;
		letter-spacing: 0.14em;
		text-transform: uppercase;
		color: var(--fg-tertiary);
	}

	.innov8-contact-required {
		color: var(--accent-warm);
	}

	.innov8-contact-optional {
		text-transform: none;
		letter-spacing: 0;
		color: var(--fg-muted);
		font-size: 11px;
	}

	.innov8-contact-field input,
	.innov8-contact-field textarea {
		background-color: rgba(255, 255, 255, 0.04);
		border: 1px solid var(--border-default);
		border-radius: var(--radius-sm);
		color: var(--fg-primary);
		font-family: var(--font-sans);
		font-size: var(--text-body);
		padding: 12px 14px;
		transition:
			border-color var(--duration-base) var(--ease-out),
			background-color var(--duration-base) var(--ease-out);
	}

	.innov8-contact-field input:focus,
	.innov8-contact-field textarea:focus {
		outline: none;
		border-color: var(--accent-spark);
		background: rgba(255, 255, 255, 0.06);
	}

	.innov8-contact-field textarea {
		resize: vertical;
		min-height: 140px;
	}

	.innov8-contact-submit {
		align-self: flex-start;
	}

	.innov8-contact-fineprint {
		margin: 8px 0 0;
		font-size: var(--text-caption);
		line-height: var(--leading-base);
		color: var(--fg-muted);
		text-wrap: pretty;
	}

	/* ─── Server-rendered response states (htmx swap target) ────────── */
	.innov8-contact-success,
	.innov8-contact-error {
		padding: 20px 24px;
		border-radius: var(--radius-md);
		margin-bottom: 8px;
	}

	.innov8-contact-success {
		background: rgba(34, 201, 138, 0.1);
		border: 1px solid rgba(34, 201, 138, 0.3);
	}

	.innov8-contact-success h3 {
		font-family: var(--font-display);
		font-size: var(--text-h4);
		margin: 0 0 8px;
		color: var(--color-success);
	}

	.innov8-contact-error {
		background: rgba(255, 90, 106, 0.08);
		border: 1px solid rgba(255, 90, 106, 0.3);
	}

	.innov8-contact-error p {
		margin: 0;
		font-size: var(--text-body);
		color: var(--color-danger);
	}

	@media (prefers-reduced-motion: reduce) {
		.innov8-contact-alt-link,
		.innov8-contact-alt-link:hover,
		.innov8-contact-alt-link:focus-visible,
		.innov8-contact-field input,
		.innov8-contact-field textarea {
			transition: none;
			gap: 6px;
		}
	}
}
