/**
 * Variant CSS: offer--quad-card-grid
 * Layer 2 — Path B universal offer variant (authored 2026-06-10).
 *
 * Concept: EXACTLY FOUR services as a balanced 2×2 card matrix. Each cell is a
 * card carrying a large outlined ordinal in the corner + service title (h3) +
 * 2-3 line description + optional price pinned to the bottom edge. Symmetric
 * quadrants, resting elevation, hover lift + accent edge. The calm "four equal
 * pillars" layout — no single service dominates.
 *
 * Differentiator vs sibling offer variants:
 *   - icon-cards-3col / trio-accent-cards: 3-up rows, icon chips.
 *   - featured-plus-trio (count-4 sibling): asymmetric 1 large + 3 small.
 *   - four-compact-columns (count-4 sibling): single tight row, no cards.
 *   THIS one: full 2×2 matrix of equal numbered cards + price.
 *
 * Tokens: semantic only (Layer 2 API). Cards sit on --background-card so they
 * LIFT on dark themes; on light themes the border + resting shadow carry the
 * elevation. Ordinal = --accent outlined glyph (text-stroke fallback to fill).
 */

/* == Section shell == */
body.aibt-universal .universal-offer--quad-card-grid {
	background: var(--background);
	color: var(--text-primary);
	border-bottom: 1px solid var(--divider-primary);
}

/* Intro: constrained-layout direct children inherit `margin-inline:auto`.
   Pin flush-left and cap width so the kicker + headline share the quad grid's
   left edge (resetting the inherited centring margin in the process). */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__intro {
	margin-block: 0 clamp(2.5rem, 6vh, 4.5rem);
	margin-inline: 0 auto !important;
	max-width: 46ch;
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__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-md) 0 !important;
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 !important;
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__deck {
	font-family: var(--font-body) !important;
	font-size: var(--text-md) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--text-secondary) !important;
	margin: var(--space-md) 0 0 0 !important;
	max-width: 54ch;
}

/* == 2×2 grid == */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__quad {
	gap: clamp(1.1rem, 2vw, 1.75rem) !important;
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* Cell: vertical flex so the price anchors the bottom edge and paired cells in
   a row share an equal height regardless of copy length. */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell {
	display: flex !important;
	flex-direction: column;
	padding: clamp(1.6rem, 3vw, 2.5rem) !important;
	background: var(--background-card, var(--background)) !important;
	border: 1px solid var(--divider-primary);
	border-radius: var(--decor-radius, 0px);
	box-shadow: var(--decor-shadow, none);
	position: relative;
	overflow: hidden;
	transition:
		border-color var(--duration-fast) var(--ease-snappy),
		box-shadow var(--duration-fast) var(--ease-snappy),
		transform var(--duration-fast) var(--ease-snappy);
}

/* Accent left edge: hidden at rest, scales in from the top on hover so the cell
   reads as a deliberate, interactive surface. */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 3px;
	background: var(--accent);
	transform: scaleY(0);
	transform-origin: top center;
	transition: transform var(--duration-fast) var(--ease-snappy);
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell:hover {
	border-color: var(--accent);
	box-shadow: var(--decor-shadow-elevated, none);
	transform: translateY(-4px);
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell:hover::before {
	transform: scaleY(1);
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell:focus-within {
	border-color: var(--accent);
}

/* == Large outlined ordinal: the quadrant marker. Outlined (text-stroke) keeps
   it a quiet structural accent, not a loud filled number. Falls back to a faded
   accent fill where text-stroke is unsupported. == */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell-num {
	font-family: var(--font-display) !important;
	font-size: clamp(2.25rem, 4vw, 3rem) !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	letter-spacing: -0.02em !important;
	color: var(--accent) !important;
	opacity: 0.55;
	margin: 0 0 var(--space-md) 0 !important;
	-webkit-text-stroke: 1px var(--accent);
	-webkit-text-fill-color: transparent;
	transition: opacity var(--duration-fast) var(--ease-snappy);
}

body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell:hover .universal-offer__cell-num {
	opacity: 1;
}

/* == Cell title == */
body.aibt-universal .universal-offer--quad-card-grid h3.universal-offer__cell-title,
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell-title {
	font-family: var(--font-display) !important;
	font-weight: 600 !important;
	font-size: var(--text-xl) !important;
	color: var(--text-primary) !important;
	margin: 0 0 var(--space-xs) 0 !important;
	line-height: 1.2 !important;
	letter-spacing: -0.01em !important;
}

/* == Cell description == */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell-desc {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	line-height: var(--leading-normal) !important;
	color: var(--text-secondary) !important;
	margin: 0 !important;
	max-width: 40ch;
}

/* == Price: pinned to the cell's bottom edge via margin-top:auto so prices
   align across the matrix. Hairline rule above separates it from the copy. == */
body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell-price {
	font-family: var(--font-mono, var(--font-body)) !important;
	font-size: var(--text-sm) !important;
	font-weight: 600 !important;
	letter-spacing: 0.01em !important;
	color: var(--text-primary) !important;
	margin: auto 0 0 0 !important;
	padding-top: var(--space-md);
	margin-top: auto !important;
	border-top: 1px solid var(--divider-primary);
}

/* == Responsive == */
/* 641-959: keep the 2×2 grid but tighten gutters. */
@media (max-width: 959px) {
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__quad {
		gap: 1rem !important;
	}
}

/* ≤640: stack to a single column. */
@media (max-width: 640px) {
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__quad {
		grid-template-columns: minmax(0, 1fr) !important;
	}
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__kicker {
		letter-spacing: var(--tracking-wide) !important;
	}
}

/* == Motion respect == */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell,
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell::before,
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell-num {
		transition: none;
	}
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell:hover {
		transform: none;
	}
	body.aibt-universal .universal-offer--quad-card-grid .universal-offer__cell:hover::before {
		transform: scaleY(1);
	}
}

/* == Editor wrapper: hover-only states are inert in the editor; ensure the
   accent edge is not stuck visible and cells render at rest. == */
.editor-styles-wrapper .universal-offer--quad-card-grid .universal-offer__cell::before {
	transform: scaleY(0);
}
