/**
 * Variant CSS: pricing--quad-tier-ramp
 * Layer 2 — Path B pricing role (brief-bound, Element Count 4, 2026-06-10).
 *
 * Four tiers in a row arranged as an ascending ramp left→right, dedicated to
 * exactly four priced services. A subtle step ramp (rising height via a small
 * upward offset, strengthening border + shadow) implies a "good / better /
 * best / max" progression; each card carries a step number, name, large price
 * and a one-line tagline, with the top tier (DOM :last-child) the most
 * emphasised (accent border + filled step badge). Distinct from
 * tiers-quartet-row, which presents four EQUAL cards with no hierarchy. NO
 * feature lists. At 4-up the cards pin to a quarter width; tablet drops to a
 * 2×2 and resets the ramp offsets; mobile stacks to one column. Scoped to the
 * variant class.
 *
 * The step number is driven by a section-level counter in DOM order so it stays
 * correct (1-4) even if the loader renumbers tiers.
 */

body.aibt-universal .universal-pricing--quad-tier-ramp {
	background: var(--background);
	color: var(--text-primary);
	counter-reset: aibt-ramp;
}

/* ── Intro ─────────────────────────────────────────────────────── */
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__intro {
	margin-bottom: var(--space-7);
}

body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__kicker {
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 600 !important;
	letter-spacing: 0.16em !important;
	text-transform: uppercase !important;
	color: var(--accent) !important;
	margin: 0 0 var(--space-3) 0 !important;
}

body.aibt-universal .universal-pricing--quad-tier-ramp h2.universal-pricing__headline,
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 !important;
	max-width: 20ch;
}

body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__deck {
	font-family: var(--font-body) !important;
	font-size: var(--text-lg) !important;
	line-height: 1.6 !important;
	color: var(--text-secondary) !important;
	margin: var(--space-4) 0 0 0 !important;
	max-width: 54ch;
}

/* ── The ramp row ──────────────────────────────────────────────── */
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tiers {
	gap: var(--space-4);
	/* Align cards to the bottom so the rising upward offsets read as a ramp. */
	align-items: flex-end;
}

/* Base card. */
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier {
	counter-increment: aibt-ramp;
	position: relative;
	background: var(--background-alt);
	border: 1px solid var(--divider-primary);
	border-radius: var(--decor-radius);
	box-shadow: var(--decor-shadow);
	padding: var(--space-6) var(--space-5) var(--space-5) var(--space-5);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	transition: transform var(--duration-fast) var(--ease-standard),
		border-color var(--duration-fast) var(--ease-standard),
		box-shadow var(--duration-fast) var(--ease-standard);
}

/* Step badge at the top of each card — outline by default. */
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier::before {
	content: counter(aibt-ramp);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.2em;
	height: 2.2em;
	font-family: var(--font-display);
	font-size: var(--text-sm);
	font-weight: 700;
	color: var(--accent);
	background: var(--accent-fade, transparent);
	border: 1px solid var(--divider-accent, var(--accent));
	border-radius: var(--radius-pill);
	font-variant-numeric: tabular-nums;
}

body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:hover {
	transform: translateY(-3px);
	border-color: var(--accent);
	box-shadow: var(--decor-shadow-elevated, var(--decor-shadow));
}

body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
}

body.aibt-universal .universal-pricing--quad-tier-ramp h3.universal-pricing__tier-name,
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier-name {
	font-family: var(--font-display) !important;
	font-size: var(--text-lg) !important;
	font-weight: 600 !important;
	line-height: 1.2 !important;
	color: var(--text-primary) !important;
	margin: var(--space-2) 0 0 0 !important;
}

/* Price — the hero. Font capped + keep-all so a long text price ("wycena
   indywidualna") wraps at the space rather than breaking mid-word against the
   base.css overflow-wrap floor. */
body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier-price {
	font-family: var(--font-display) !important;
	font-size: clamp(1.5rem, 2.6vw, 1.9rem) !important;
	font-weight: 700 !important;
	line-height: 1.04 !important;
	letter-spacing: -0.02em !important;
	color: var(--accent) !important;
	margin: var(--space-1) 0 0 0 !important;
	font-variant-numeric: tabular-nums;
	overflow-wrap: normal;
	word-break: keep-all;
}

body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier-price span {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: 400;
	letter-spacing: 0;
	color: var(--text-muted);
}

body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier-tagline {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	line-height: 1.5 !important;
	color: var(--text-secondary) !important;
	margin: var(--space-2) 0 0 0 !important;
}

/* ── Desktop: pin quarters + apply the ascending ramp ──────────── */
@media (min-width: 960px) {
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier {
		flex: 1 1 calc((100% - 3 * var(--space-4)) / 4);
		max-width: calc((100% - 3 * var(--space-4)) / 4);
	}

	/* Rising offset + growing emphasis from tier 1 → tier 4. */
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(1) {
		transform: translateY(0);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(2) {
		transform: translateY(-12px);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(3) {
		transform: translateY(-24px);
		box-shadow: var(--decor-shadow-elevated, var(--decor-shadow));
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4) {
		transform: translateY(-36px);
		border-color: var(--accent);
		box-shadow: var(--decor-shadow-elevated, var(--decor-shadow));
	}

	/* Keep the hover lift relative to each card's ramp offset. */
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(1):hover {
		transform: translateY(-3px);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(2):hover {
		transform: translateY(-15px);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(3):hover {
		transform: translateY(-27px);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4):hover {
		transform: translateY(-39px);
	}

	/* Top tier — filled step badge to crown the ramp. */
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4)::before {
		color: var(--on-accent, #ffffff);
		background: var(--accent);
		border-color: var(--accent);
	}
}

/* ── Tablet: 2×2, reset the ramp offsets (they don't read across rows) ── */
@media (min-width: 641px) and (max-width: 959px) {
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tiers {
		flex-wrap: wrap;
		align-items: stretch;
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier {
		flex-basis: calc(50% - (var(--space-4) / 2));
		max-width: calc(50% - (var(--space-4) / 2));
		transform: none;
	}
	/* Keep the top tier visibly crowned even without the ramp offset. */
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4) {
		border-color: var(--accent);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4)::before {
		color: var(--on-accent, #ffffff);
		background: var(--accent);
		border-color: var(--accent);
	}
}

/* ── Mobile: single column stack, no ramp ──────────────────────── */
@media (max-width: 640px) {
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tiers {
		flex-wrap: wrap;
		align-items: stretch;
		gap: var(--space-4);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier {
		flex-basis: 100%;
		max-width: 100%;
		transform: none;
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4) {
		border-color: var(--accent);
	}
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier:nth-child(4)::before {
		color: var(--on-accent, #ffffff);
		background: var(--accent);
		border-color: var(--accent);
	}
	/* A5: drop the wide tracking on the uppercase kicker at narrow widths. */
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__kicker {
		letter-spacing: 0 !important;
	}
}

/* Respect reduced-motion — keep the static ramp offsets, kill hover transition. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-pricing--quad-tier-ramp .universal-pricing__tier {
		transition: none;
	}
}
