/**
 * Full case study body — prototype .wrap rail (max 1200 + gutter), one shell.
 * Matches .site-header__inner / .cluster-hero__content left edge.
 * Layout blocks are read-only: no hover lift on columns, groups, text, or media.
 */

/* Universal: no false “clickable” hover on narrative shells (work full case pages) */
@media (prefers-reduced-motion: no-preference) {
	main.studio-case .studio-case__body :is(
		.wp-block-column,
		.wp-block-group,
		.wp-block-columns,
		.wp-block-image,
		.wp-block-image figure,
		.wp-block-image img,
		.cs-case-media,
		.cs-case-media__video,
		.wp-block-html,
		.cs-callout,
		.cs-insight-rows,
		.cs-insight-row,
		.cs-outcomes,
		.cs-outcome,
		.cs-stack,
		.cs-stack-row,
		.cs-ph,
		.cs-body,
		.cs-title,
		.cs-num,
		.cs-lorena-demo,
		.cs-lorena-demo__main,
		.cs-lorena-demo__actions,
		.bridge-visual,
		.bridge-visual__trigger
	) {
		transition: none !important;
	}

	main.studio-case .studio-case__body :is(
		.wp-block-column,
		.wp-block-group,
		.wp-block-columns,
		.wp-block-image,
		.wp-block-image figure,
		.bridge-visual
	):hover {
		transform: none !important;
		box-shadow: none !important;
		filter: none !important;
	}

	/* Inline videos are not cards — keep full brightness; do not strip feature shadow */
	main.studio-case .studio-case__body .cs-case-media:hover,
	main.studio-case .studio-case__body .cs-case-media:focus-within,
	main.studio-case .studio-case__body .cs-case-media__video:hover {
		transform: none !important;
		filter: none !important;
		opacity: 1 !important;
	}
}

main.studio-case {
	padding-bottom: var(--wp--preset--spacing--70, 6rem);
}

main.studio-case > .studio-case__body.alignfull {
	margin-inline: 0 !important;
	width: 100%;
	max-width: none;
}

/* Single content shell — same math as prototype .wrap */
.studio-case__body .wp-block-post-content,
.studio-case__body .entry-content {
	--studio-shell-max: calc(
		var(--studio-wide-size, 1200px) + var(--wp--style--root--padding-left, 1.5rem)
			+ var(--wp--style--root--padding-right, 1.5rem)
	);
	box-sizing: border-box;
	width: 100%;
	max-width: var(--studio-shell-max) !important;
	margin-inline: auto !important;
	padding-inline: var(--wp--style--root--padding-left, 1.5rem)
		var(--wp--style--root--padding-right, 1.5rem) !important;
	overflow-x: visible;
}

/* Sections fill shell — no extra horizontal inset */
.studio-case .cs-section,
.studio-case__body .wp-block-columns.cs-section,
.studio-case__body .wp-block-group.cs-section {
	padding-block: var(--wp--preset--spacing--55, 3rem) !important;
	padding-inline: 0 !important;
	box-sizing: border-box;
	width: 100%;
	max-width: none !important;
	margin-inline: 0 !important;
}

/* Strip WP constrained-layout global padding from inner section body */
.studio-case__body .cs-section__body.has-global-padding {
	padding-inline: 0 !important;
}

.studio-case__body .wp-block-post-content > .wp-block-columns,
.studio-case__body .wp-block-post-content > .wp-block-group,
.studio-case__body .wp-block-post-content > .wp-block-html {
	margin-inline: 0 !important;
	max-width: none !important;
}

/* Engagement meta — mirrors bridge overview stack (ROLE / SCOPE / CONTEXT / YEARS) */
.studio-case__body .studio-case__meta {
	padding-block: var(--wp--preset--spacing--50, 2.5rem) var(--wp--preset--spacing--45, 2rem) !important;
	/* Single rule below: .cs-section + .cs-section border-top on the next section (no border-bottom here). */
}

.studio-case__body .studio-case__meta .cs-stack {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	column-gap: clamp(2rem, 5vw, 4rem);
	row-gap: 0.65rem;
}

.studio-case__body .studio-case__meta .cs-stack-row {
	grid-template-columns: minmax(0, 6.5rem) minmax(0, 1fr);
}

.studio-case__body .wp-block-columns.cs-section > .wp-block-column {
	min-width: 0;
	max-width: none;
}

/* Inline column media (replaces static image in two-col sections).
   No hero scrim, grain, or pseudo overlays — full-brightness product demo. */
.studio-case__body .cs-case-media {
	position: relative;
	margin: 0;
	border-radius: 4px;
	background: #fff;
}

.studio-case__body .cs-case-media::before,
.studio-case__body .cs-case-media::after {
	content: none !important;
	display: none !important;
}

.studio-case__body .cs-case-media__video {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
	border-radius: 4px;
	cursor: pointer;
}

/* Custom poster overlay — replaces native poster attr for Chrome compatibility */
.studio-case__body .cs-case-media__poster {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 4px;
	z-index: 2;
	pointer-events: none;
	transition: opacity 0.3s ease;
}

.studio-case__body .cs-case-media__poster.is-hidden {
	opacity: 0;
}

/* Canvas fallback for Chrome hardware decode failures */
.studio-case__body .cs-case-media__canvas {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 4px;
	cursor: pointer;
}

/* Ambient product loops (e.g. Sparrow panel) — no controls chrome */
.studio-case__body .cs-case-media--feature .cs-case-media__video:not([controls]) {
	background: var(--studio-cream, #f3efe8);
	object-fit: contain;
}

/* Not a lightbox thumbnail — no zoom affordance or WP core lightbox chrome */
.studio-case__body .cs-case-media,
.studio-case__body .cs-case-media__video {
	cursor: default;
}

.studio-case__body .cs-case-media .wp-lightbox-container,
.studio-case__body .wp-lightbox-container.cs-case-media {
	cursor: default;
}

.studio-case__body .cs-case-media .wp-lightbox-container button,
.studio-case__body .wp-lightbox-container.cs-case-media button {
	display: none !important;
}

/* Native control chrome — visible against light backgrounds */
.studio-case__body .cs-case-media__video::-webkit-media-controls-enclosure {
	background: rgba(0, 0, 0, 0.06);
}

.studio-case__body .cs-case-media__video::-webkit-media-controls-panel {
	background-image: linear-gradient(transparent, rgba(0, 0, 0, 0.15));
}

.studio-case__body .cs-case-media--feature:hover,
.studio-case__body .cs-case-media--feature:focus-within {
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 16px 48px rgba(44, 95, 110, 0.14) !important;
}

/* Play button affordance — injected by chrome-video-fix.js for feature videos */
.studio-case__body .cs-case-media__play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.92);
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.18);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 3;
	pointer-events: none;
	transition: opacity 0.25s ease, transform 0.25s ease;
}

.studio-case__body .cs-case-media__play::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 0 10px 18px;
	border-color: transparent transparent transparent rgba(20, 20, 20, 0.82);
	margin-left: 4px;
}

.studio-case__body .cs-case-media--feature:hover .cs-case-media__play {
	transform: translate(-50%, -50%) scale(1.08);
}

.studio-case__body .cs-case-media__poster.is-hidden ~ .cs-case-media__play {
	opacity: 0;
	pointer-events: none;
}

.studio-case__body .cs-case-media .wp-element-caption {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	color: var(--wp--preset--color--muted);
	text-align: center;
	margin-top: 0.75rem;
	letter-spacing: 0.02em;
}

/* Featured inline video — centered, wider than column rail (e.g. Sparrow §04 demo) */
.studio-case__body .cs-case-media--feature {
	box-sizing: border-box;
	width: 100%;
	max-width: min(56rem, 100%);
	margin: var(--wp--preset--spacing--55, 3rem) auto;
	padding: 1rem;
	border: 1px solid rgba(26, 26, 26, 0.1);
	border-radius: 6px;
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 16px 48px rgba(44, 95, 110, 0.14);
}

.studio-case__body .cs-case-media--feature .wp-element-caption {
	font-size: 0.8rem;
	margin-top: 1rem;
}

@media (min-width: 783px) {
	.studio-case__body .cs-case-media--feature {
		margin-block: var(--wp--preset--spacing--60, 4rem);
		padding: var(--wp--preset--spacing--50, 2.5rem);
	}

	.studio-case__body .cs-case-media--feature .wp-element-caption {
		margin-top: 1.25rem;
	}
}

/* Inline hosted prototype (app.feedback-loupe.com — embed allowed from studio) */
.studio-case__body .cs-prototype-embed {
	box-sizing: border-box;
	width: 100%;
	max-width: 24rem;
	margin-inline: auto;
	text-align: center;
}

.studio-case__body .cs-prototype-embed--wide {
	max-width: none;
	text-align: left;
	margin-top: 0;
}

.studio-case__body .cs-prototype-embed--wide .cs-prototype-embed__shell {
	border-radius: 6px;
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 30px 80px -30px rgba(10, 10, 10, 0.25);
}

.studio-case__body .cs-prototype-embed--wide .cs-prototype-embed__frame {
	min-height: 520px;
	height: min(78vh, 720px);
}

.studio-case__body .cs-prototype-embed__label {
	font-family: var(--wp--preset--font-family--mono, ui-monospace, monospace);
	font-size: 0.68rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--muted);
	margin: 0 0 0.65rem;
}

.studio-case__body .cs-prototype-embed__shell {
	border-radius: 1.25rem;
	overflow: hidden;
	border: 1px solid rgba(26, 26, 26, 0.12);
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 16px 48px rgba(44, 95, 110, 0.14);
	background: #0a1628;
}

.studio-case__body .cs-prototype-embed__frame {
	display: block;
	width: 100%;
	height: min(78vh, 720px);
	min-height: 520px;
	border: 0;
	background: #0a1628;
}

.studio-case__body .cs-prototype-embed__note {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	line-height: 1.45;
	color: var(--wp--preset--color--muted);
	margin: 0.75rem 0 0;
}

.studio-case__body .cs-prototype-embed__note a {
	color: var(--studio-teal, #2c5f6e);
}

/* Inline app frame — full-bleed iframe within a cs-section */
.cs-prototype-frame {
	width: 100%;
	overflow: hidden;
	border-radius: 6px;
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 30px 80px -30px rgba(10, 10, 10, 0.22);
}

.cs-prototype-frame iframe {
	display: block;
	width: 100%;
	border: 0;
}

/* Featured pilot — product anchor → workshop span → walkthrough video */
.studio-case__body #pilot .cs-pilot-discovery,
.studio-case__body #pilot .cs-pilot-walkthrough {
	margin-top: var(--wp--preset--spacing--60, 3rem);
}

.studio-case__body #pilot .cs-pilot-discovery .cs-body,
.studio-case__body #pilot .cs-pilot-walkthrough .cs-body {
	max-width: 58ch;
	margin-bottom: var(--wp--preset--spacing--40, 1.5rem);
}

.studio-case__body #pilot .bridge-visual--span {
	margin: 0;
	max-width: none;
}

/* Workshop board — native resolution (no upscale past 1024px) */
.studio-case__body #pilot .bridge-visual--span.bridge-visual--intrinsic {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.studio-case__body #pilot .bridge-visual--span.bridge-visual--intrinsic .bridge-visual__trigger,
.studio-case__body #pilot .bridge-visual--span.bridge-visual--intrinsic img {
	width: auto;
	max-width: min(100%, 1024px);
	height: auto;
	margin-inline: auto;
}

.studio-case__body #pilot .cs-case-media--column {
	margin: 0;
	max-width: none;
	padding: 1rem;
}

.studio-case__body #pilot .cs-case-media--column .cs-case-media__video {
	max-height: min(72vh, 640px);
}

.studio-case__body #pilot .cs-case-media--column .cs-prototype-launch-wrap {
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
	text-align: center;
}

/* Product proof — bridge-visual + lightbox (same component as work bridges) */
.studio-case__body .bridge-visual {
	margin: 0;
	border-radius: 6px;
	overflow: visible;
	background: #fff;
	border: 1px solid rgba(26, 26, 26, 0.1);
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 12px 40px rgba(44, 95, 110, 0.12);
	padding: 1rem;
	box-sizing: border-box;
}

.studio-case__body .bridge-visual--zoomable .bridge-visual__trigger {
	border-radius: 4px;
	width: 100%;
}

.studio-case__body .bridge-visual img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
}

.studio-case__body .bridge-visual__caption {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	line-height: 1.35;
	color: var(--wp--preset--color--muted);
	margin: 0.65rem 0 0;
	letter-spacing: 0.02em;
}

.studio-case__body .cs-figure-grid {
	margin-top: var(--wp--preset--spacing--50, 2.5rem);
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
	align-items: start;
}

.studio-case__body .cs-figure-grid--single {
	grid-template-columns: minmax(0, 1fr);
	max-width: 36rem;
}

.studio-case__body .cs-figure-grid--triple {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	max-width: none;
	width: 100%;
	gap: 1rem;
	align-items: start;
}

.studio-case__body .cs-figure-grid--triple .bridge-visual {
	margin: 0;
}

.studio-case__body .cs-figure-grid--triple .bridge-visual img {
	display: block;
	width: 100%;
	height: auto;
}

.studio-case__body .cs-img-original {
	width: 100%;
	height: auto;
	max-width: 523px;
}

.studio-case__body #strategy .cs-visual-stack {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.studio-case__body #strategy .bridge-visual {
	margin: 0;
}

.studio-case__body #strategy .cs-img-original {
	width: 100%;
	height: auto;
	max-width: 100%;
}

.studio-case__body .cs-figure-grid-caption {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	color: var(--wp--preset--color--muted);
	text-align: center;
	margin: 0.5rem 0 0;
	letter-spacing: 0.02em;
	line-height: 1.35;
}

/* Concept sub-sections — copy left, visual right (within full-width HTML block) */
.studio-case__body #concepts .cs-concept-row {
	display: grid;
	grid-template-columns: 1fr minmax(0, 44%);
	gap: 2rem 3rem;
	align-items: start;
}

.studio-case__body #concepts .cs-concept-row__copy,
.studio-case__body #concepts .cs-concept-row__visual {
	min-width: 0;
}

.studio-case__body #concepts .cs-concept-row__visual .cs-prototype-launch-wrap {
	margin-top: 0;
}

@media (max-width: 782px) {
	.studio-case__body #concepts .cs-concept-row {
		grid-template-columns: 1fr;
	}
}

/* Full width — copy + inline galleries span the content shell (no narrow text column). */
.studio-case__body .cs-section--full-width .cs-body,
.studio-case__body .cs-section--full-width .cs-title,
.studio-case__body .cs-section--full-width .cs-stack,
.studio-case__body .cs-section--full-width .cs-outcomes-stack,
.studio-case__body #capture .cs-body,
.studio-case__body #capture .cs-title,
.studio-case__body #ml-loop .cs-body,
.studio-case__body #ml-loop .cs-title,
.studio-case__body #pilot .cs-body,
.studio-case__body #pilot .cs-title,
.studio-case__body #pivot .cs-body,
.studio-case__body #pivot .cs-title,
.studio-case__body #problem .cs-body,
.studio-case__body #problem .cs-title,
.studio-case__body #process .cs-body,
.studio-case__body #process .cs-title,
.studio-case__body #artifacts .cs-body,
.studio-case__body #artifacts .cs-title,
.studio-case__body #solution .cs-body,
.studio-case__body #solution .cs-title,
.studio-case__body #reflection .cs-body,
.studio-case__body #reflection .cs-title {
	max-width: none;
}

/* #pilot uses wp-block-columns — override the column constraint */
.studio-case__body #pilot > .wp-block-columns {
	display: block !important;
	max-width: none !important;
}

.studio-case__body #pilot > .wp-block-columns > .wp-block-column {
	max-width: none !important;
	flex-basis: 100% !important;
	width: 100% !important;
}

/* #solution — override wp-block-group content width */
.studio-case__body #solution .cs-body,
.studio-case__body #solution .cs-title {
	max-width: none !important;
}

.studio-case__body #solution.is-layout-flow > * {
	max-width: none !important;
}

/* §05 Accuracy Loop — screenshot left, steps right */
.studio-case__body .cs-ml-loop-grid {
	margin-top: var(--wp--preset--spacing--50, 2.5rem);
	display: grid;
	grid-template-columns: minmax(0, min(20rem, 32%)) minmax(0, 1.55fr);
	gap: 2rem 2.75rem;
	align-items: start;
}

.studio-case__body .cs-ml-loop-grid__steps {
	min-width: 0;
}

.studio-case__body .cs-ml-loop-grid__steps .cs-pipeline {
	margin-top: 0;
}

.studio-case__body .cs-ml-loop-grid__steps .cs-pipeline-note {
	margin-top: 1.5rem;
	max-width: none;
}

.studio-case__body .cs-ml-loop-grid__figure {
	margin: 0;
	width: 100%;
	max-width: min(20rem, 100%);
	justify-self: start;
}

.studio-case__body .cs-ml-loop-grid__figure img,
.studio-case__body .cs-ml-loop-grid__figure .bridge-visual__trigger {
	width: 100%;
	max-width: 100%;
	height: auto;
}

@media (max-width: 960px) {
	.studio-case__body .cs-ml-loop-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

.studio-case__body .cs-section--full-width .cs-outcomes-stack {
	width: 100%;
}

.studio-case__body .cs-section--full-width .cs-figure-grid,
.studio-case__body .cs-section--full-width .cs-figure-grid--single {
	max-width: none;
	width: 100%;
}

.studio-case__body .cs-section--full-width .cs-persona-gallery {
	max-width: none;
	width: 100%;
	margin-inline: 0;
	text-align: left;
}

.studio-case__body .cs-section--full-width .cs-persona-gallery__lede {
	text-align: left;
}

.studio-case__body .cs-section--full-width .bridge-visual--span {
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
}

/* Compact persona thumbs — secondary gallery; captions in lightbox only */
.studio-case__body .cs-persona-gallery {
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
	margin-inline: auto;
	max-width: 34rem;
	text-align: center;
}

.studio-case__body .cs-persona-gallery__lede {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.8rem;
	line-height: 1.45;
	color: var(--wp--preset--color--muted);
	margin: 0 0 0.75rem;
	text-align: center;
}

.studio-case__body .cs-persona-gallery__hint {
	font-style: italic;
}

.studio-case__body .cs-persona-gallery__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.6rem;
	align-items: start;
}

.studio-case__body .cs-persona-gallery .bridge-visual {
	margin: 0;
	padding: 0.35rem;
	border-radius: 4px;
	background: var(--wp--preset--color--base, #faf9f7);
	border: 1px solid rgba(44, 95, 110, 0.1);
	box-shadow: none;
}

.studio-case__body .cs-persona-gallery .bridge-visual--zoomable .bridge-visual__trigger {
	border-radius: 3px;
}

.studio-case__body .cs-persona-gallery .bridge-visual img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 5 / 4;
	object-fit: cover;
	object-position: top center;
}

.studio-case__body .cs-persona-gallery .bridge-visual__caption {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
}

/* Case study carousel — personas (column) or design-kit frames (full shell) */
.studio-case__body .cs-persona-carousel {
	position: relative;
	width: 100%;
}

.studio-case__body .cs-persona-carousel--full {
	width: 100%;
	max-width: none;
	margin-top: var(--wp--preset--spacing--50, 2.5rem);
}

.studio-case__body .cs-persona-carousel--full .cs-persona-carousel__viewport {
	border-radius: 4px;
}

.studio-case__body .cs-persona-carousel--full .bridge-visual {
	width: 100%;
	max-width: none;
}

.studio-case__body .cs-persona-carousel--full .bridge-visual img {
	display: block;
	width: 100%;
	height: auto;
	max-height: min(85vh, 56rem);
	margin-inline: auto;
	object-fit: contain;
	object-position: top center;
}

.studio-case__body .cs-persona-carousel--full .cs-figure-grid-caption {
	margin-top: 0.5rem;
}

.studio-case__body .cs-persona-carousel__viewport {
	overflow: hidden;
	border-radius: 4px;
}

.studio-case__body .cs-persona-carousel__track {
	display: flex;
	width: 100%;
	transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
	will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
	.studio-case__body .cs-persona-carousel__track {
		transition: none;
	}
}

.studio-case__body .cs-persona-carousel__slide {
	flex: 0 0 100%;
	min-width: 0;
	margin: 0;
}

.studio-case__body .cs-persona-carousel__slide .bridge-visual {
	margin: 0;
}

.studio-case__body .cs-persona-carousel__slide[aria-hidden='true'] .bridge-visual__caption {
	visibility: hidden;
}

.studio-case__body .cs-persona-carousel__controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.65rem;
	margin-top: 0.75rem;
}

.studio-case__body .cs-persona-carousel__btn {
	appearance: none;
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	padding: 0;
	border: 1px solid rgba(44, 95, 110, 0.22);
	border-radius: 999px;
	background: var(--wp--preset--color--base, #faf9f7);
	color: var(--wp--preset--color--contrast, #1a1a1a);
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 1.1rem;
	line-height: 1;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease;
}

.studio-case__body .cs-persona-carousel__btn:hover:not(:disabled),
.studio-case__body .cs-persona-carousel__btn:focus-visible {
	border-color: rgba(44, 95, 110, 0.45);
	color: var(--wp--preset--color--accent, #2c5f6e);
	outline: none;
}

.studio-case__body .cs-persona-carousel__btn:disabled {
	opacity: 0.35;
	cursor: default;
}

.studio-case__body .cs-persona-carousel__dots {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.studio-case__body .cs-persona-carousel__dot {
	appearance: none;
	width: 0.45rem;
	height: 0.45rem;
	padding: 0;
	border: none;
	border-radius: 999px;
	background: rgba(44, 95, 110, 0.25);
	cursor: pointer;
	transition: transform 0.15s ease, background-color 0.15s ease;
}

.studio-case__body .cs-persona-carousel__dot.is-active,
.studio-case__body .cs-persona-carousel__dot[aria-selected='true'] {
	background: var(--wp--preset--color--accent, #2c5f6e);
	transform: scale(1.15);
}

.studio-case__body .cs-persona-carousel__dot:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent, #2c5f6e);
	outline-offset: 2px;
}

.studio-case__body .cs-persona-carousel__status {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	font-variant-numeric: tabular-nums;
	color: var(--wp--preset--color--muted);
	min-width: 3.25rem;
	text-align: center;
}

/* Technical detail accordion — expandable architecture callout */
.studio-case__body .cs-tech-detail {
	margin: var(--wp--preset--spacing--50, 2.5rem) 0 var(--wp--preset--spacing--40, 1.5rem);
	border: 1px solid rgba(44, 95, 110, 0.15);
	border-radius: 4px;
	background: var(--wp--preset--color--base, #faf9f7);
	box-shadow: 0 1px 2px rgba(14, 26, 31, 0.04);
	overflow: hidden;
}

.studio-case__body .cs-tech-detail > summary {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: var(--wp--preset--spacing--35, 1.25rem) var(--wp--preset--spacing--40, 1.5rem);
	cursor: pointer;
	list-style: none;
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	transition: background 0.15s ease;
	user-select: none;
}

.studio-case__body .cs-tech-detail > summary::-webkit-details-marker {
	display: none;
}

.studio-case__body .cs-tech-detail > summary::before {
	content: '▸';
	font-size: 0.75rem;
	line-height: 1;
	color: var(--wp--preset--color--accent, #2c5f6e);
	transition: transform 0.2s ease;
}

.studio-case__body .cs-tech-detail[open] > summary::before {
	transform: rotate(90deg);
}

.studio-case__body .cs-tech-detail > summary:hover {
	background: rgba(44, 95, 110, 0.04);
}

.studio-case__body .cs-tech-detail > summary .cs-tech-detail__label {
	flex: 1 1 auto;
}

.studio-case__body .cs-tech-detail > summary .cs-tech-detail__hint {
	font-size: 0.72rem;
	font-weight: 400;
	letter-spacing: 0.02em;
	text-transform: none;
	color: var(--wp--preset--color--muted, #6b6560);
}

.studio-case__body .cs-tech-detail__body {
	padding: 0 var(--wp--preset--spacing--40, 1.5rem) var(--wp--preset--spacing--40, 1.5rem);
	border-top: 1px solid rgba(44, 95, 110, 0.1);
}

.studio-case__body .cs-tech-detail__row {
	display: grid;
	grid-template-columns: 7.5rem 1fr;
	gap: 0.5rem 1.25rem;
	padding: var(--wp--preset--spacing--30, 1rem) 0;
	border-bottom: 1px solid rgba(14, 26, 31, 0.06);
	align-items: baseline;
}

.studio-case__body .cs-tech-detail__row:last-child {
	border-bottom: none;
}

.studio-case__body .cs-tech-detail__key {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent, #2c5f6e);
}

.studio-case__body .cs-tech-detail__val {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	line-height: 1.5;
	color: var(--wp--preset--color--contrast, #1a1a1a);
}

.studio-case__body .cs-tech-detail__val .cs-tech-detail__placeholder {
	color: var(--wp--preset--color--muted, #6b6560);
	font-style: italic;
}

@media (max-width: 640px) {
	.studio-case__body .cs-tech-detail__row {
		grid-template-columns: 1fr;
		gap: 0.25rem;
	}
}

/* Lorena live-demo CTA — standout panel in §04 The Solution */
.studio-case__body .cs-lorena-demo {
	position: relative;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: var(--wp--preset--spacing--40, 1.5rem);
	margin: var(--wp--preset--spacing--50, 2.5rem) 0 var(--wp--preset--spacing--40, 1.5rem);
	padding: var(--wp--preset--spacing--45, 2rem) var(--wp--preset--spacing--50, 2.5rem);
	background: linear-gradient(
		165deg,
		var(--wp--preset--color--base) 0%,
		var(--studio-cream, #f3efe8) 100%
	);
	border: 1px solid rgba(44, 95, 110, 0.18);
	border-radius: 6px;
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.05),
		0 16px 48px rgba(44, 95, 110, 0.1);
	max-width: none;
}

.studio-case__body .cs-lorena-demo__main,
.studio-case__body .cs-lorena-demo__actions {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.studio-case__body .cs-lorena-demo__main {
	flex: 1 1 auto;
	justify-content: center;
	gap: var(--wp--preset--spacing--30, 1rem);
}

.studio-case__body .cs-lorena-demo__actions {
	flex: 0 0 auto;
	justify-content: center;
	gap: var(--wp--preset--spacing--25, 0.75rem);
}

@media (min-width: 783px) {
	.studio-case__body .cs-lorena-demo {
		flex-direction: row;
		align-items: stretch;
		gap: var(--wp--preset--spacing--55, 3rem);
		padding: var(--wp--preset--spacing--55, 3rem) var(--wp--preset--spacing--50, 2.5rem);
	}

	.studio-case__body .cs-lorena-demo__actions {
		flex: 0 0 min(18rem, 34%);
		padding-left: var(--wp--preset--spacing--50, 2.5rem);
		border-left: 1px solid rgba(44, 95, 110, 0.14);
	}

	.studio-case__body .cs-lorena-demo__cta {
		margin: 0;
	}

	.studio-case__body .cs-lorena-demo__link {
		width: 100%;
		justify-content: center;
	}

	.studio-case__body .cs-lorena-demo__note {
		text-align: center;
	}
}

.studio-case__body .cs-lorena-demo::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	border-radius: 6px 6px 0 0;
	background: linear-gradient(
		90deg,
		var(--studio-teal, #2c5f6e) 0%,
		var(--studio-teal-light, #3d7a8c) 100%
	);
}

.studio-case__body .cs-lorena-demo__tier {
	display: inline-block;
	margin: 0 0 var(--wp--preset--spacing--30, 1rem);
	padding: 0.22rem 0.6rem;
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent);
	background: color-mix(in srgb, var(--wp--preset--color--accent) 10%, var(--wp--preset--color--base));
	border-radius: 2px;
}

.studio-case__body .cs-lorena-demo__title {
	font-family: var(--wp--preset--font-family--serif, Fraunces, serif);
	font-size: clamp(1.35rem, 3.2vw, 1.85rem);
	font-weight: 400;
	line-height: 1.2;
	letter-spacing: -0.02em;
	color: var(--wp--preset--color--contrast);
	margin: 0 0 var(--wp--preset--spacing--30, 1rem);
	max-width: none;
}

.studio-case__body .cs-lorena-demo__lede {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--wp--preset--color--muted);
	margin: 0;
	max-width: none;
}

.studio-case__body .cs-lorena-demo__cta {
	margin: 0 0 var(--wp--preset--spacing--25, 0.75rem);
	padding: 0;
}

.studio-case__body .cs-lorena-demo__note {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	line-height: 1.4;
	color: var(--wp--preset--color--muted);
	margin: 0;
	letter-spacing: 0.02em;
}

.studio-case .cs-callout {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin: 0 !important;
	padding: 3rem var(--wp--preset--spacing--50, 2.5rem) !important;
	border-radius: 4px;
}

.studio-case .cs-callout .cs-callout-title {
	max-width: none;
}

.studio-case .cs-next {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin: 0 !important;
	padding-block: 3rem var(--wp--preset--spacing--60, 4rem) !important;
	padding-inline: 0 !important;
	display: flex;
	justify-content: flex-end;
	border-top: 1px solid rgba(26, 26, 26, 0.08);
}

.studio-case .cs-next.cs-next--split {
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
}

.studio-case .cs-next-group {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem 2rem;
	align-items: baseline;
}

.studio-case .cs-external-refs a,
.studio-case .cs-figure-grid-caption a,
.studio-case .bridge-visual__caption a,
.studio-case .cs-surface-body a {
	color: var(--studio-teal, #2c5f6e);
}

.studio-case .cs-external-refs a:hover,
.studio-case .cs-figure-grid-caption a:hover,
.studio-case .bridge-visual__caption a:hover,
.studio-case .cs-surface-body a:hover {
	color: var(--studio-teal-light, #3d7a8c);
}

.studio-case .cs-thumb-row .bridge-visual {
	margin: 0;
	padding: 0.35rem;
}

.studio-case .cs-thumb-row .bridge-visual img {
	width: 100%;
	height: auto;
	display: block;
}

.studio-case .cs-figure-grid .bridge-visual img {
	width: 100%;
	height: auto;
}

.studio-case .cs-related {
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
}

.studio-case .cs-related a {
	color: var(--studio-teal, #2c5f6e);
}

.studio-case__body:has(.cs-gate) {
	background: var(--wp--preset--color--base);
}

.studio-case__body .post-password-form.cs-gate {
	margin: 0 !important;
	width: 100%;
	max-width: none;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding: var(--wp--preset--spacing--60) 0 var(--wp--preset--spacing--70) !important;
	box-sizing: border-box;
}

.studio-case__body .cs-gate__panel {
	max-width: min(42rem, 100%);
}

@media (max-width: 782px) {
	main.studio-case {
		overflow-x: clip;
	}

	.studio-case .cs-section,
	.studio-case__body .wp-block-columns.cs-section,
	.studio-case__body .wp-block-group.cs-section {
		padding-block: var(--wp--preset--spacing--50, 2.5rem) !important;
	}

	.studio-case__body .wp-block-columns.cs-section,
	.studio-case__body .wp-block-group.cs-section > .wp-block-columns {
		grid-template-columns: 1fr !important;
		gap: var(--wp--preset--spacing--50, 2.5rem) !important;
	}

	main.studio-case .cs-title {
		font-size: clamp(1.45rem, 5.5vw, 2rem);
		line-height: 1.15;
	}

	main.studio-case .cs-body,
	main.studio-case .cs-insight-body,
	main.studio-case .cs-outcome-body {
		max-width: none;
	}

	main.studio-case .cs-insight-row {
		grid-template-columns: 1fr;
		gap: 1rem;
		padding: 1.5rem 0;
	}

	main.studio-case .cs-insight-rows {
		margin-top: var(--wp--preset--spacing--50, 2.5rem);
	}

	main.studio-case .cs-outcome {
		grid-template-columns: 1fr;
		gap: 0.5rem;
		padding: 1.5rem 0;
	}

	main.studio-case .cs-stack-row {
		grid-template-columns: minmax(0, 7.5rem) minmax(0, 1fr);
		gap: 0.35rem 0.75rem;
		align-items: start;
		word-break: break-word;
	}

	.studio-case__body .studio-case__meta .cs-stack {
		grid-template-columns: 1fr;
	}

	.studio-case .cs-callout {
		margin-inline: 0 !important;
		padding: 2rem var(--wp--preset--spacing--40, 1.5rem) !important;
	}

	.studio-case .cs-callout .cs-callout-title {
		font-size: clamp(1.2rem, 4.5vw, 1.65rem);
	}

	.studio-case__body .wp-block-image figure {
		min-height: 0;
	}

	.studio-case__body .cs-case-media__video {
		max-width: 100%;
	}

	.studio-case__body .cs-case-media--feature {
		margin: var(--wp--preset--spacing--50, 2.5rem) auto;
		padding: 0.75rem;
	}

	.studio-case__body .cs-prototype-embed {
		max-width: 100%;
	}

	.studio-case__body .cs-prototype-embed__frame {
		min-height: 420px;
		height: min(70dvh, 640px);
	}

	.studio-case__body .bridge-visual {
		padding: 0.75rem;
	}

	.studio-case__body .bridge-visual__caption {
		white-space: normal;
		overflow: visible;
		text-overflow: unset;
	}

	.studio-case__body .cs-figure-grid,
	.studio-case__body .cs-figure-grid--triple {
		grid-template-columns: 1fr;
		gap: var(--wp--preset--spacing--40, 1.5rem);
	}

	.studio-case__body .cs-persona-gallery__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 0.5rem;
	}

	.studio-case__body .cs-lorena-demo {
		padding: var(--wp--preset--spacing--40, 1.5rem) var(--wp--preset--spacing--40, 1.5rem);
		margin-inline: 0;
	}

	.studio-case__body .cs-lorena-demo__actions {
		padding-left: 0;
		border-left: none;
	}

	.studio-case__body .cs-lorena-demo__link {
		width: 100%;
		justify-content: center;
		font-size: 1rem;
		padding: 1rem 1.35rem;
	}

	.studio-case .cs-next {
		justify-content: flex-start;
		flex-wrap: wrap;
		gap: 0.65rem 1.25rem;
		padding-block: var(--wp--preset--spacing--50, 2.5rem)
			var(--wp--preset--spacing--55, 3rem) !important;
		font-size: var(--wp--preset--font-size--small, 0.875rem);
	}

	.studio-case .cs-next.cs-next--split {
		flex-direction: column;
		align-items: flex-start;
	}

	.studio-case__body .post-password-form.cs-gate {
		padding: var(--wp--preset--spacing--50, 2.5rem) 0 var(--wp--preset--spacing--60, 4rem) !important;
	}

	.cs-gate__row {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.studio-case__body .cs-gate input[type='password'],
	.cs-gate input[type='password'] {
		width: 100%;
		min-width: 0;
		box-sizing: border-box;
	}

	.cs-gate input[type='submit'] {
		width: 100%;
		box-sizing: border-box;
		text-align: center;
	}

	.cs-gate__request-row {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.cs-gate__request-panel input[type='text'],
	.cs-gate__request-panel input[type='email'] {
		width: 100%;
		min-width: 0;
		box-sizing: border-box;
	}

	.cs-gate__request-submit {
		width: 100%;
		box-sizing: border-box;
		text-align: center;
	}
}

@media (max-width: 480px) {
	main.studio-case .cs-stack-row {
		grid-template-columns: 1fr;
	}

	main.studio-case .cs-stack-key {
		display: block;
		margin-bottom: 0.1rem;
	}
}

/* Greenridge §03 — thumb grid + HQ strip (app-v1 case study) */
.studio-case .thumb-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 12px;
	margin: 1.75rem 0 0.75rem;
}

.studio-case .thumb-grid--prominent {
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(12px, 2vw, 18px);
	margin: 1.75rem 0 0.75rem;
}

.studio-case .thumb {
	margin: 0;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid rgba(26, 26, 26, 0.1);
	background: #fff;
	box-shadow:
		0 1px 2px rgba(26, 26, 26, 0.06),
		0 12px 40px rgba(44, 95, 110, 0.1);
}

.studio-case .thumb img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
}

.studio-case .thumb--large .thumb img {
	aspect-ratio: 390 / 844;
	object-fit: cover;
	object-position: top center;
}

.studio-case .thumb figcaption {
	padding: 8px 10px;
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--wp--preset--color--muted);
	border-top: 1px solid rgba(26, 26, 26, 0.1);
	text-align: center;
}

.studio-case .thumb--large .thumb {
	border-radius: 6px;
}

@media (max-width: 900px) {
	.studio-case .thumb-grid--prominent {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 520px) {
	.studio-case .thumb-grid--prominent {
		grid-template-columns: 1fr;
	}
}

/* HQ clipboard → app snapshot */
.studio-case .case-study-hq-visual-wrap {
	--hq-forest-900: #0a2418;
	--hq-forest-800: #1a4d35;
	--hq-forest-700: var(--studio-teal, #2c5f6e);
	--hq-sage-50: #e8f4ea;
	--hq-cream-warm: #f3efe8;
	--hq-muted: var(--wp--preset--color--muted, #5c5c5c);
	--hq-line: rgba(26, 26, 26, 0.1);
	--hq-line-strong: rgba(26, 26, 26, 0.16);
	--hq-shadow-soft: 0 12px 40px rgba(44, 95, 110, 0.12);
	margin-top: var(--wp--preset--spacing--50, 2.5rem);
	width: 100%;
	max-width: none;
}

.studio-case .case-study-hq-visual-wrap .hq-visual {
	container-type: inline-size;
	container-name: hq-explainer;
	width: 100%;
}

.studio-case .hq-visual__link {
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: 1.35rem 2rem 1.4rem;
	background: linear-gradient(145deg, rgba(232, 244, 234, 0.5) 0%, rgba(253, 252, 248, 0.9) 100%);
	border: 1px solid var(--hq-line);
	border-radius: 6px;
	box-shadow: var(--hq-shadow-soft);
	color: inherit;
	text-decoration: none;
	cursor: pointer;
}

.studio-case .hq-visual__link:focus-visible {
	outline: 3px solid var(--hq-forest-700);
	outline-offset: 3px;
}

.studio-case .hq-visual__strip {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 1.5rem;
	width: 100%;
}

.studio-case .hq-visual__photo {
	flex: 0 0 auto;
	margin: 0;
	text-align: left;
}

.studio-case .hq-visual__photo img {
	width: auto;
	max-width: min(200px, 28vw);
	height: auto;
	border-radius: 12px;
	border: 1px solid var(--hq-line-strong);
	box-shadow: 0 12px 28px rgba(10, 36, 24, 0.14);
	vertical-align: middle;
	background: #2a2419;
}

.studio-case .hq-visual__bridge {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.2rem;
	color: var(--hq-forest-700);
	min-width: 2rem;
}

.studio-case .hq-visual__bridge svg {
	width: 28px;
	height: 28px;
	flex-shrink: 0;
}

.studio-case .hq-visual__bridge span {
	font-size: 0.62rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	white-space: nowrap;
	color: var(--hq-forest-800);
}

.studio-case .hq-mini-app {
	flex: 0 0 auto;
	width: min(360px, 38vw);
	max-width: 100%;
	border-radius: 12px;
	border: 1px solid var(--hq-line-strong);
	background: #fff;
	overflow: hidden;
	box-shadow: 0 8px 22px rgba(10, 36, 24, 0.08);
}

.studio-case .hq-mini-app__chrome {
	padding: 0.45rem 0.65rem;
	font-size: 0.68rem;
	font-weight: 750;
	letter-spacing: 0.02em;
	color: var(--hq-forest-900);
	background: linear-gradient(180deg, var(--hq-sage-50), #fff);
	border-bottom: 1px solid var(--hq-line);
}

.studio-case .hq-mini-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.72rem;
	line-height: 1.35;
}

.studio-case .hq-mini-table th,
.studio-case .hq-mini-table td {
	padding: 0.45rem 0.5rem;
	text-align: left;
	border-bottom: 1px solid var(--hq-line);
}

.studio-case .hq-mini-table th {
	font-size: 0.62rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--hq-muted);
	background: rgba(238, 248, 241, 0.65);
}

.studio-case .hq-mini-table tr:last-child td {
	border-bottom: none;
}

.studio-case .hq-mini-table .pill {
	display: inline-block;
	padding: 0.12rem 0.38rem;
	border-radius: 999px;
	font-size: 0.65rem;
	font-weight: 750;
}

.studio-case .hq-mini-table .pill--open {
	background: rgba(34, 120, 72, 0.14);
	color: var(--hq-forest-800);
}

.studio-case .hq-mini-table .pill--taken {
	background: rgba(180, 90, 40, 0.12);
	color: #7a4020;
}

.studio-case .hq-mini-app__note {
	margin: 0;
	padding: 0.45rem 0.55rem 0.55rem;
	font-size: 0.65rem;
	line-height: 1.45;
	color: var(--hq-muted);
	background: var(--hq-cream-warm);
	border-top: 1px solid var(--hq-line);
}

.studio-case .cs-hq-visual-caption {
	margin-top: 0.875rem;
	max-width: none;
	font-size: 0.92rem;
	color: var(--wp--preset--color--muted);
}

@container hq-explainer (max-width: 380px) {
	.studio-case .case-study-hq-visual-wrap .hq-visual__strip {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.studio-case .case-study-hq-visual-wrap .hq-visual__photo {
		text-align: center;
	}

	.studio-case .case-study-hq-visual-wrap .hq-visual__bridge svg {
		transform: rotate(90deg);
	}

	.studio-case .case-study-hq-visual-wrap .hq-mini-app {
		width: 100%;
		max-width: 340px;
	}
}

@media (max-width: 560px) {
	.studio-case .hq-visual__link {
		padding: 1.25rem 1.5rem 1.3rem;
	}

	.studio-case .case-study-hq-visual-wrap .hq-visual__strip {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.studio-case .case-study-hq-visual-wrap .hq-visual__photo {
		text-align: center;
	}

	.studio-case .case-study-hq-visual-wrap .hq-visual__bridge svg {
		transform: rotate(90deg);
	}

	.studio-case .case-study-hq-visual-wrap .hq-mini-app {
		width: 100%;
		max-width: 340px;
	}
}

/* ─── Podcast callout ─────────────────────────────────── */

.studio-case .cs-podcast-callout {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	border-left: 3px solid var(--studio-teal, #2c5f6e);
	padding: 1.25rem 1.5rem;
	margin-top: var(--wp--preset--spacing--50, 2.5rem);
	margin-bottom: var(--wp--preset--spacing--40, 1.5rem);
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
}

.studio-case .cs-podcast-callout__cover {
	flex-shrink: 0;
	width: 120px;
	height: 120px;
	border-radius: 4px;
	overflow: hidden;
}

.studio-case .cs-podcast-callout__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.studio-case .cs-podcast-callout__body {
	flex: 1;
	min-width: 0;
}

.studio-case .cs-podcast-callout__label {
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--muted, #6b6560);
	margin: 0 0 0.35rem;
}

.studio-case .cs-podcast-callout__title {
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	margin: 0 0 0.25rem;
}

.studio-case .cs-podcast-callout__meta {
	font-size: 0.82rem;
	color: var(--wp--preset--color--muted, #6b6560);
	margin: 0 0 0.5rem;
}

.studio-case .cs-podcast-callout__lede {
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	margin: 0 0 0.75rem;
}

.studio-case .cs-podcast-callout__link {
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--studio-teal, #2c5f6e);
	text-decoration: none;
	border-bottom: 1px solid rgba(44, 95, 110, 0.35);
	padding-bottom: 1px;
	transition: border-color 0.2s ease, color 0.2s ease;
}

.studio-case .cs-podcast-callout__link:hover {
	border-color: var(--studio-teal, #2c5f6e);
	color: var(--wp--preset--color--contrast, #1a1a1a);
}

@media (max-width: 480px) {
	.studio-case .cs-podcast-callout {
		flex-direction: column;
		gap: 0.75rem;
	}

	.studio-case .cs-podcast-callout__cover {
		width: 60px;
		height: 60px;
	}
}

/* ─── Product card (prominent external link with OG thumbnail) ── */

.studio-case .cs-product-card {
	margin-bottom: var(--wp--preset--spacing--40, 1.5rem);
}

.studio-case .cs-product-card__link {
	display: block;
	border: 1px solid rgba(14, 26, 31, 0.1);
	border-radius: 6px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	max-width: 480px;
}

.studio-case .cs-product-card__link:hover {
	border-color: var(--studio-teal, #2c5f6e);
	box-shadow: 0 2px 8px rgba(44, 95, 110, 0.1);
}

.studio-case .cs-product-card__thumb {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1200 / 630;
	object-fit: cover;
}

.studio-case .cs-product-card__body {
	display: block;
	padding: 0.75rem 1rem;
	font-family: var(--wp--preset--font-family--sans, 'Source Sans 3', sans-serif);
}

.studio-case .cs-product-card__label {
	display: block;
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--muted, #6b6560);
	margin-bottom: 0.2rem;
}

.studio-case .cs-product-card__title {
	display: block;
	font-size: 1rem;
	font-weight: 600;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	margin-bottom: 0.15rem;
}

.studio-case .cs-product-card__url {
	display: block;
	font-size: 0.8rem;
	color: var(--wp--preset--color--muted, #6b6560);
}

/* ─── Inline small image (within full-width sections) ─── */

.studio-case .bridge-visual--inline-sm {
	max-width: 360px;
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
	margin-bottom: 0;
}

.studio-case .bridge-visual--inline-sm img {
	border-radius: 4px;
}

/* ─── Column split overrides ─────────────────────────── */

.studio-case .cs-section--65-35 {
	gap: var(--wp--preset--spacing--50, 2.5rem);
}

.studio-case .cs-section--65-35 > .wp-block-column:first-child {
	flex-basis: 70% !important;
	flex-grow: 0 !important;
	max-width: 70% !important;
}

.studio-case .cs-section--65-35 > .wp-block-column:last-child {
	flex-basis: 30% !important;
	flex-grow: 0 !important;
	max-width: 30% !important;
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
}
