/**
 * Variant CSS: before-after--diagonal-reveal
 *
 * One frame, two photos joined by a diagonal seam. The "after" image is clipped
 * to the upper-right triangle and drop-shadowed along the cut so the seam reads
 * as depth; "Przed" / "Po" chips sit in their respective triangles. Native
 * Gutenberg: two editable wp:image blocks stacked in a position:relative stage.
 */

body.aibt-universal .universal-before-after--diagonal-reveal {
	text-align: center;
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__intro {
	margin: 0 auto var(--space-xl, 3rem) auto;
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__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-before-after--diagonal-reveal .universal-before-after__headline {
	font-family: var(--font-display) !important;
	color: var(--ink) !important;
	margin: 0 !important;
}

/* Stage — holds the two overlapping images + the two corner chips. */
body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__stage {
	position: relative;
	aspect-ratio: 16 / 10;
	border-radius: var(--decor-radius, 12px);
	overflow: hidden;
	background: var(--background-alt, #ececec);
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__img {
	position: absolute !important;
	inset: 0;
	margin: 0 !important;
	width: 100%;
	height: 100%;
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-slow, 900ms) var(--ease-elegant, ease);
}

/* Gentle paired zoom on hover — tactile "real result" cue (reduced-motion is
   handled globally by the skeleton). */
body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__stage:hover .universal-before-after__img img {
	transform: scale(1.03);
}

/* "After" occupies the upper-right triangle; the drop-shadow follows the clip
   edge (clip-path is honoured by filter) to give the seam visible depth. */
body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__img--reveal {
	clip-path: polygon(42% 0, 100% 0, 100% 100%, 58% 100%);
	filter: drop-shadow(-7px 0 11px rgba(0, 0, 0, 0.32));
	z-index: 1;
}

/* Corner chips — readable on any photo via translucent backdrop. */
body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__label {
	position: absolute;
	z-index: 2;
	margin: 0 !important;
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 700 !important;
	letter-spacing: var(--tracking-wider) !important;
	text-transform: uppercase !important;
	padding: 0.4rem 0.95rem;
	border-radius: 999px;
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	line-height: 1.1;
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__label--before {
	left: var(--space-md, 1.25rem);
	bottom: var(--space-md, 1.25rem);
	color: #ffffff;
	background: rgba(18, 18, 20, 0.62);
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__label--after {
	right: var(--space-md, 1.25rem);
	top: var(--space-md, 1.25rem);
	color: var(--cta-text-primary, #ffffff);
	background: var(--accent);
}

body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__caption {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--ink) !important;
	opacity: 0.72;
	max-width: 52ch;
	margin: var(--space-lg, 2rem) auto 0 auto !important;
}

/* Mobile: a square stage keeps the near-vertical diagonal balanced on a narrow
   viewport, and the chips stay clear of the seam. */
@media (max-width: 640px) {
	body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__stage {
		aspect-ratio: 1 / 1;
	}
	body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__label {
		font-size: 0.7rem !important;
		padding: 0.35rem 0.75rem;
	}
	/* Cap wide uppercase tracking on small screens (A5 — wide tracking hurts
	   small text). Kicker = 0.24em, labels = 0.12em — both above the 0.1em floor. */
	body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__kicker,
	body.aibt-universal .universal-before-after--diagonal-reveal .universal-before-after__label {
		letter-spacing: 0 !important;
	}
}

/* A8/A9 left-shift fix (2026-06-08): centered intro element(s) were max-width-capped by
   WP constrained layout but pinned left by horizontal margin:0. Force margin-inline:auto.
   Section class doubled -> specificity (0,4,1) beats h2.__headline-style rules; harmless on
   already-centered elements (auto margins compute to 0). Only left/right are overridden. */
body.aibt-universal .universal-before-after--diagonal-reveal.universal-before-after--diagonal-reveal .universal-before-after__kicker,
body.aibt-universal .universal-before-after--diagonal-reveal.universal-before-after--diagonal-reveal .universal-before-after__headline { margin-inline: auto !important; }
/* NOTE: __label is position:absolute (a corner "PRZED/PO" badge), intentionally off-centre —
   not part of this fix. */
