/**
 * Variant CSS: contact--map-overlay-card
 * Layer 2 — Path B contact map variants (2026-05-28).
 * Map fills the section; contact card floats over it.
 */

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

/* === Map fills section === */
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__map--fill {
	position: absolute;
	inset: 0;
	background-color: var(--background-alt);
	background-image:
		repeating-linear-gradient(0deg, transparent 0 46px, var(--divider-primary) 46px 47px),
		repeating-linear-gradient(90deg, transparent 0 46px, var(--divider-primary) 46px 47px);
	overflow: hidden;
	z-index: 0;
}
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__map-road {
	position: absolute; background: var(--divider-primary); opacity: 0.8;
}
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__map-road--a {
	width: 200%; height: 18px; top: 38%; left: -50%; transform: rotate(-14deg);
}
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__map-road--b {
	width: 18px; height: 200%; left: 72%; top: -50%; transform: rotate(10deg);
}
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__map-park {
	position: absolute; width: 200px; height: 130px; left: 58%; bottom: 16%;
	background: var(--accent); opacity: 0.12; border-radius: 46% 54% 50% 48%;
}
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__map-pin {
	position: absolute; left: 70%; top: 50%; transform: translate(-50%, -100%);
	color: var(--accent); z-index: 1; filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.3));
}

/* === Floating contact card === */
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__overlay {
	position: relative;
	z-index: 2;
	margin: clamp(var(--space-lg), 5vw, var(--space-2xl));
	max-width: 420px;
	background: var(--background);
	border: 1px 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--map-overlay-card .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--map-overlay-card .universal-contact__headline {
	font-family: var(--font-display) !important; color: var(--text-primary) !important;
	margin: 0 0 var(--space-md) 0 !important;
}
body.aibt-universal .universal-contact--map-overlay-card .universal-contact__details {
	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;
}
body.aibt-universal .universal-contact--map-overlay-card .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.4rem;
	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--map-overlay-card .wp-block-button.universal-contact__cta .wp-block-button__link:hover {
	background: var(--accent-hover); border-color: var(--accent-hover);
}

@media (max-width: 781px) {
	body.aibt-universal .universal-contact--map-overlay-card { min-height: 480px; }
	body.aibt-universal .universal-contact--map-overlay-card .universal-contact__overlay {
		margin: var(--space-md); max-width: none;
	}
}

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