/* ============================================================
   Client Snapshot Block — Frontend Styles
   e9digital | style.css
   All selectors prefixed with .breakdance for specificity.
   ============================================================ */

.breakdance .e9-snapshot {
	/* ── Typography tokens ── */
	--snap-font-body:    var(--bde-body-font-family,    "Inter", sans-serif);
	--snap-font-heading: var(--bde-heading-font-family, "SpaceGrotesk", sans-serif);
	--snap-font-size:    var(--bde-base-font-size,      16px);

	/* ── Colour tokens ── */
	--snap-yellow:       var(--bde-palette-color-1-8f5dc3cd-f4db-4952-bbc3-199c73275f21, #F6DC3B);
	--snap-text:         var(--bde-body-text-color,     #000);
	--snap-heading:      var(--bde-headings-color,      #000);
	--snap-muted:        #5a5a5a;
	--snap-bg:           #fff;
	--snap-border:       var(--bde-palette-color-1-cbecefbf-8fcc-4cde-8923-d235fb07254f, #e7e7eb);
	--snap-label-bg:     #f5f5f5;
	--snap-label-text:   #3a3a3a;

	/* ── Motion ── */
	--snap-duration:     var(--bde-transition-duration, 300ms);
	--snap-ease:         ease;

	/* ── Shape ── */
	--snap-radius:       0;

	display: block;
	container-type: inline-size;
	margin-block: 2rem;
	font-family: var(--snap-font-body);
	font-size: var(--snap-font-size);
}

/* ── Card shell ─────────────────────────────────────────── */
.breakdance .e9-snapshot__card {
	margin: 0;
	border-radius: var(--snap-radius);
	overflow: hidden;
	background: var(--snap-bg);
	border: 1px solid var(--snap-border);
	transition:
		border-color var(--snap-duration) var(--snap-ease),
		box-shadow   var(--snap-duration) var(--snap-ease);
}

.breakdance .e9-snapshot__card:hover {
	border-color: #bbb;
	box-shadow: 0 4px 16px -2px rgba(0, 0, 0, 0.09);
}

/* ── Link — full card is one focusable target ───────────── */
.breakdance .e9-snapshot__link {
	display: block;
	color: inherit;
	text-decoration: none !important; /* override any global a{} styles */
}

.breakdance .e9-snapshot__link:hover,
.breakdance .e9-snapshot__link:focus,
.breakdance .e9-snapshot__link:focus-visible,
.breakdance .e9-snapshot__link:visited {
	text-decoration: none !important;
	color: inherit;
}

/* ADA: high-visibility focus ring */
.breakdance .e9-snapshot__link:focus-visible {
	outline: 3px solid var(--snap-yellow);
	outline-offset: 3px;
	border-radius: var(--snap-radius);
}

/* ── IMAGE WRAP ─────────────────────────────────────────── */
.breakdance .e9-snapshot__image-wrap {
	position: relative;
	overflow: hidden;
	display: block;
	aspect-ratio: 16 / 8;
	background: var(--snap-label-bg);
}

.breakdance .e9-snapshot__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform var(--snap-duration) var(--snap-ease);
}

.breakdance .e9-snapshot__link:hover .e9-snapshot__image,
.breakdance .e9-snapshot__link:focus-visible .e9-snapshot__image {
	transform: scale(1.03);
}

/* ── LANDSCAPE layout ───────────────────────────────────── */
@container (min-width: 540px) {
	.breakdance .e9-snapshot--landscape.has-image .e9-snapshot__link {
		display: grid;
		grid-template-columns: 260px 1fr;
		align-items: stretch;
	}

	.breakdance .e9-snapshot--landscape.has-image .e9-snapshot__image-wrap {
		aspect-ratio: unset;
		height: 100%;
		min-height: 180px;
	}
}

/* ── Body ───────────────────────────────────────────────── */
.breakdance .e9-snapshot__body {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
	padding: 1.5rem 1.75rem;
}

/* ── Label ──────────────────────────────────────────────── */
.breakdance .e9-snapshot__label {
	display: inline-block;
	font-family: var(--snap-font-body);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--snap-label-text);
	background: var(--snap-label-bg);
	border-radius: 3px;
	border: 1px solid var(--snap-border);
	padding: 3px 8px;
	line-height: 1.4;
}

/* ── Title ──────────────────────────────────────────────── */
.breakdance .e9-snapshot__title {
	font-family: var(--snap-font-heading);
	font-size: clamp(
		1.1rem,
		calc(var(--bde-base-font-size, 16px) * 1.5625),
		var(--bde-h4-font-size, 1.5625rem)
	);
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: -0.02em;
	color: var(--snap-heading);
	margin: 0;

	/* Force underline OFF — override any global heading or link styles */
	text-decoration: none !important;
}

.breakdance .e9-snapshot__link:hover .e9-snapshot__title,
.breakdance .e9-snapshot__link:focus-visible .e9-snapshot__title {
	text-decoration: underline !important;
	text-decoration-color: var(--snap-heading) !important;
	text-underline-offset: 3px;
}

/* ── Excerpt ────────────────────────────────────────────── */
.breakdance .e9-snapshot__excerpt {
	margin: 0;
	font-family: var(--snap-font-body);
	font-size: 0.875rem;
	line-height: 1.65;
	color: var(--snap-muted);
	text-decoration: none !important;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ── CTA ────────────────────────────────────────────────── */
.breakdance .e9-snapshot__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-family: var(--snap-font-body);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--snap-text);
	margin-top: 0.25rem;
	text-decoration: none !important;
	transition: gap var(--snap-duration) var(--snap-ease);
}

.breakdance .e9-snapshot__link:hover .e9-snapshot__cta,
.breakdance .e9-snapshot__link:focus-visible .e9-snapshot__cta {
	gap: 0.55rem;
}

.breakdance .e9-snapshot__arrow {
	flex-shrink: 0;
	transition: transform var(--snap-duration) var(--snap-ease);
}

.breakdance .e9-snapshot__link:hover .e9-snapshot__arrow,
.breakdance .e9-snapshot__link:focus-visible .e9-snapshot__arrow {
	transform: translateX(3px);
}

/* ── No image: yellow left accent stripe ────────────────── */
.breakdance .e9-snapshot.no-image .e9-snapshot__card {
	border-left: 4px solid var(--snap-yellow);
}

/* ── Wide alignment ─────────────────────────────────────── */
.breakdance .wp-block-e9-client-snapshot.alignwide {
	max-width: var(--bde-section-width, 1120px);
}

/* ── High-contrast / forced-colors (ADA) ───────────────── */
@media (forced-colors: active) {
	.breakdance .e9-snapshot__card {
		border: 2px solid ButtonText;
	}
	.breakdance .e9-snapshot__link:focus-visible {
		outline: 3px solid Highlight;
	}
}
