/**
 * Variant CSS: contact--dark-split-map-form
 * Layer 2 — Path B contact role (2026-06-06).
 * Dark full-bleed band: CSS faux-map tile (left) + compact form (right).
 * KI-020-safe: all foreground on dark uses --text-on-dark; accent via lift.
 */

body.aibt-universal .universal-contact--dark-split-map-form {
	background: var(--background-dark, #141414);
	color: var(--text-on-dark, #fff);
	padding-block: calc(clamp(var(--space-xl), 7vw, var(--space-2xl)) * var(--density, 1));
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__cols {
	gap: clamp(var(--space-lg), 4vw, var(--space-2xl));
	align-items: stretch;
}

/* ---- Map column (CSS faux-map tile) ---- */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__mapcol {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map {
	position: relative;
	flex: 1 1 auto;
	min-height: 340px;
	overflow: hidden;
	border-radius: var(--decor-radius);
	/* Themed map base: subtle land tint derived from accent so it never clashes. */
	background:
		color-mix(in srgb, var(--accent) 8%, #0d0d0d);
	border: 1px solid color-mix(in srgb, var(--text-on-dark, #fff) 14%, transparent);
}

/* Roads: thin light strokes crossing the tile. */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-road {
	position: absolute;
	background: color-mix(in srgb, var(--text-on-dark, #fff) 16%, transparent);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-road--a {
	left: 0;
	right: 0;
	top: 38%;
	height: 10px;
	transform: rotate(-4deg);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-road--b {
	top: 0;
	bottom: 0;
	left: 30%;
	width: 9px;
	transform: rotate(3deg);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-road--c {
	left: 0;
	right: 0;
	bottom: 22%;
	height: 6px;
	transform: rotate(2deg);
	background: color-mix(in srgb, var(--text-on-dark, #fff) 10%, transparent);
}

/* City blocks: faint filled rectangles. */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-block {
	position: absolute;
	background: color-mix(in srgb, var(--text-on-dark, #fff) 6%, transparent);
	border-radius: 3px;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-block--1 {
	left: 8%;
	top: 12%;
	width: 18%;
	height: 18%;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-block--2 {
	right: 12%;
	bottom: 30%;
	width: 22%;
	height: 22%;
}

/* Park: accent-tinted patch for a touch of colour. */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-park {
	position: absolute;
	left: 40%;
	bottom: 10%;
	width: 24%;
	height: 26%;
	border-radius: 50% 40% 45% 55%;
	background: color-mix(in srgb, var(--accent) 24%, transparent);
}

/* Pin: accent fill, centred. */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-pin {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -100%);
	color: var(--accent);
	filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.45));
	line-height: 0;
	z-index: 2;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map-cap {
	margin: 0 !important;
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	line-height: var(--leading-relaxed) !important;
	color: color-mix(in srgb, var(--text-on-dark, #fff) 78%, transparent) !important;
}

/* ---- Form column ---- */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__formcol {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__kicker {
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-widest) !important;
	text-transform: uppercase !important;
	/* Accent lift so it reads as accent yet stays legible on the dark band. */
	color: color-mix(in srgb, var(--accent) 62%, var(--on-dark, #fff)) !important;
	margin: 0 0 var(--space-sm) 0 !important;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__headline {
	font-family: var(--font-display) !important;
	color: var(--text-on-dark, #fff) !important;
	margin: 0 0 var(--space-sm) 0 !important;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__headline em {
	font-style: normal;
	/* Emphasized word: accent lift (never raw --accent which may be too dark on the band). */
	color: color-mix(in srgb, var(--accent) 60%, var(--on-dark, #fff));
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__deck {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	line-height: var(--leading-relaxed) !important;
	color: color-mix(in srgb, var(--text-on-dark, #fff) 80%, transparent) !important;
	margin: 0 0 var(--space-lg) 0 !important;
	max-width: 46ch;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__form {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

/* Two-up field row collapses on narrow screens. */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field-row {
	display: flex;
	gap: var(--space-md);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field-row .universal-contact__field {
	flex: 1 1 0;
	min-width: 0;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field label {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: 600;
	color: color-mix(in srgb, var(--text-on-dark, #fff) 88%, transparent);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field input,
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field textarea {
	width: 100%;
	box-sizing: border-box;
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--text-on-dark, #fff);
	/* Slightly raised surface vs the band so inputs read as fields, KI-020-safe. */
	background: color-mix(in srgb, var(--text-on-dark, #fff) 7%, transparent);
	border: 1px solid color-mix(in srgb, var(--text-on-dark, #fff) 20%, transparent);
	border-radius: var(--decor-radius);
	padding: 0.9rem 1.1rem;
	transition: border-color var(--duration-fast) var(--ease-default), background var(--duration-fast) var(--ease-default);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field input::placeholder,
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field textarea::placeholder {
	color: color-mix(in srgb, var(--text-on-dark, #fff) 48%, transparent);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field input:hover,
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field textarea:hover {
	border-color: color-mix(in srgb, var(--text-on-dark, #fff) 34%, transparent);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field input:focus,
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field textarea:focus {
	border-color: color-mix(in srgb, var(--accent) 60%, var(--on-dark, #fff));
	background: color-mix(in srgb, var(--text-on-dark, #fff) 11%, transparent);
}

/* Keyboard focus ring (visible above the soft :focus affordance). */
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field input:focus-visible,
body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field textarea:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 2px;
	border-color: color-mix(in srgb, var(--accent) 60%, var(--on-dark, #fff));
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field textarea {
	resize: vertical;
	min-height: 110px;
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__submit {
	align-self: flex-start;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 1.02rem;
	letter-spacing: var(--tracking-wide);
	color: var(--cta-text-primary);
	background: var(--cta-bg-primary);
	border: 1px solid var(--cta-bg-primary);
	border-radius: var(--decor-radius);
	padding: 1.05rem 2.3rem;
	min-height: var(--target-min, 44px);
	cursor: pointer;
	margin-top: var(--space-2xs);
	transition: background var(--duration-fast) var(--ease-default), border-color var(--duration-fast) var(--ease-default), transform var(--duration-fast) var(--ease-default);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__submit:hover {
	background: var(--accent-hover);
	border-color: var(--accent-hover);
	transform: translateY(-2px);
}

body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__submit:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 2px;
}

/* ---- Responsive ---- */
@media (max-width: 781px) {
	body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__map {
		min-height: 240px;
	}
	body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__field-row {
		flex-direction: column;
		gap: var(--space-md);
	}
}

/* Cap letter-spacing on small screens (A5). */
@media (max-width: 640px) {
	body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__kicker {
		letter-spacing: var(--tracking-wider) !important;
	}
}

@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-contact--dark-split-map-form .universal-contact__submit:hover {
		transform: none;
	}
}
