/**
 * Variant CSS: contact--big-map-full-bleed
 * Layer 2 — Path B contact role (2026-06-06).
 * Full-bleed faux map (pure CSS — grid streets + roads + park + water + pulsing pin,
 * no embed, no API key). A floating contact card sits asymmetrically over it.
 * EVERY selector scoped to .universal-contact--big-map-full-bleed (no global leak).
 */

body.aibt-universal .universal-contact--big-map-full-bleed {
	position: relative;
	padding: 0 !important;          /* override skeleton section padding — map is full-bleed */
	min-height: 600px;
	display: flex;
	align-items: center;
	overflow: hidden;
	background: var(--background-alt);
}

/* === Faux map fills the section === */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
	background-color: var(--background-alt);
	/* Street grid baked as repeating hairlines (two scales for depth). */
	background-image:
		repeating-linear-gradient(0deg, transparent 0 78px, color-mix(in srgb, var(--ink) 9%, transparent) 78px 79px),
		repeating-linear-gradient(90deg, transparent 0 78px, color-mix(in srgb, var(--ink) 9%, transparent) 78px 79px),
		repeating-linear-gradient(0deg, transparent 0 26px, color-mix(in srgb, var(--ink) 4%, transparent) 26px 27px),
		repeating-linear-gradient(90deg, transparent 0 26px, color-mix(in srgb, var(--ink) 4%, transparent) 26px 27px);
}

/* Water body — soft accent-tinted blob bottom-left. */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-water {
	position: absolute;
	left: -8%;
	bottom: -14%;
	width: 46%;
	height: 58%;
	background: color-mix(in srgb, var(--accent) 14%, transparent);
	border-radius: 48% 52% 60% 40% / 56% 44% 56% 44%;
}

/* Park / green space — top-right. */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-park {
	position: absolute;
	right: 6%;
	top: 10%;
	width: 240px;
	height: 170px;
	max-width: 30vw;
	background: color-mix(in srgb, var(--accent) 11%, transparent);
	border-radius: 46% 54% 50% 48% / 52% 48% 52% 48%;
}

/* === Roads (heavier strokes than the grid) === */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-road {
	position: absolute;
	background: color-mix(in srgb, var(--ink) 13%, transparent);
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-road--h1 {
	width: 200%; height: 22px; top: 34%; left: -50%;
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-road--h2 {
	width: 200%; height: 14px; top: 70%; left: -50%;
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-road--v1 {
	width: 18px; height: 200%; left: 64%; top: -50%;
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-road--diag {
	width: 220%; height: 16px; top: 48%; left: -60%; transform: rotate(-26deg);
}

/* === Pin + pulse === */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-pin {
	position: absolute;
	left: 66%;
	top: 44%;
	transform: translate(-50%, -100%);
	color: var(--accent);
	z-index: 1;
	filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.28));
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-pulse {
	position: absolute;
	left: 50%;
	bottom: -6px;
	width: 24px;
	height: 24px;
	transform: translateX(-50%);
	border-radius: var(--decor-radius-pill);
	background: color-mix(in srgb, var(--accent) 35%, transparent);
	animation: ucbmfb-pulse 2.4s var(--ease-default) infinite;
}
@keyframes ucbmfb-pulse {
	0%   { transform: translateX(-50%) scale(0.6); opacity: 0.7; }
	70%  { transform: translateX(-50%) scale(2.6); opacity: 0; }
	100% { transform: translateX(-50%) scale(2.6); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-pulse {
		animation: none;
	}
}

/* === Floating contact card === */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__card {
	position: relative;
	z-index: 2;
	margin: clamp(var(--space-lg), 5vw, var(--space-2xl));
	margin-right: auto;          /* anchor card to the left — asymmetric over the map */
	max-width: 440px;
	background: color-mix(in srgb, var(--background) 90%, transparent);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	border: var(--decor-border-width) solid var(--divider-primary);
	border-radius: var(--decor-radius);
	box-shadow: var(--decor-shadow-elevated);
	padding: clamp(var(--space-lg), 4vw, var(--space-xl));
}

body.aibt-universal .universal-contact--big-map-full-bleed .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;
	color: var(--accent) !important;
	margin: 0 0 var(--space-sm) 0 !important;
}

body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 0 var(--space-sm) 0 !important;
}

body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__deck {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--text-secondary) !important;
	margin: 0 0 var(--space-lg) 0 !important;
}

/* === Detail rows (label | value) === */
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__rows {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin: 0 0 var(--space-lg) 0;
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__row {
	display: flex;
	flex-wrap: nowrap;
	align-items: baseline;
	gap: var(--space-md);
	padding: var(--space-sm) 0;
	border-top: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__row:last-child {
	border-bottom: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__row-label {
	flex: 0 0 auto;
	min-width: 84px;
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	color: var(--text-muted) !important;
	margin: 0 !important;
}
body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__row-value {
	flex: 1 1 auto;
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	color: var(--text-primary) !important;
	margin: 0 !important;
}

/* === CTA === */
body.aibt-universal .universal-contact--big-map-full-bleed .wp-block-button.universal-contact__cta .wp-block-button__link {
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 1.02rem;
	letter-spacing: var(--tracking-wide);
	padding: 1rem 2.2rem;
	color: var(--cta-text-primary);
	background: var(--cta-bg-primary);
	border: var(--decor-border-width) solid var(--cta-border-primary);
	border-radius: var(--decor-radius);
	min-height: var(--target-min);
	display: inline-flex;
	align-items: center;
	transition: background var(--duration-fast) var(--ease-snappy), border-color var(--duration-fast) var(--ease-snappy);
}
body.aibt-universal .universal-contact--big-map-full-bleed .wp-block-button.universal-contact__cta .wp-block-button__link:hover {
	background: var(--accent-hover);
	border-color: var(--accent-hover);
}

/* === Mobile === */
@media (max-width: 781px) {
	body.aibt-universal .universal-contact--big-map-full-bleed {
		min-height: 0;
		display: block;
	}
	/* Map becomes a capped band above the card instead of a full backdrop,
	   so the card text never overlaps the busy grid on narrow screens. */
	body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map {
		position: relative;
		height: 240px;
		inset: auto;
	}
	body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__card {
		margin: 0;
		max-width: none;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		-webkit-backdrop-filter: none;
		backdrop-filter: none;
		background: var(--background);
		padding: clamp(var(--space-lg), 7vw, var(--space-xl)) var(--space-md);
	}
	body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__map-park {
		max-width: 40vw;
	}
}

/* Cap letter-spacing on small screens (avoids cramped uppercase). */
@media (max-width: 640px) {
	body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__kicker {
		letter-spacing: var(--tracking-wider) !important;
	}
	body.aibt-universal .universal-contact--big-map-full-bleed .universal-contact__row-label {
		letter-spacing: 0 !important;
	}
}
