/*
 * Reusable artist-facing media showcase.
 *
 * The block presents a composed gallery experience without requiring editors
 * to manage carousel or lightbox markup by hand.
 */

.entry-content .isjac-media-showcase,
.editor-styles-wrapper .isjac-media-showcase {
	padding-top: var(--isjac-section-lg);
	padding-bottom: var(--isjac-section-lg);
	background: var(--isjac-surface-tinted);
	overflow: hidden;
}

.entry-content .isjac-media-showcase__inner,
.editor-styles-wrapper .isjac-media-showcase__inner {
	width: min(1280px, calc(100vw - (2 * var(--isjac-space-6))));
	margin-inline: auto;
}

.entry-content .isjac-media-showcase__header,
.editor-styles-wrapper .isjac-media-showcase__header {
	display: grid;
	gap: var(--isjac-space-2);
	max-width: 760px;
	margin-bottom: var(--isjac-space-6);
}

.entry-content .isjac-media-showcase__eyebrow,
.editor-styles-wrapper .isjac-media-showcase__eyebrow {
	margin: 0;
	font-family: var(--isjac-font-mono);
	font-size: var(--isjac-font-size-xs);
	font-weight: var(--isjac-font-weight-medium);
	letter-spacing: var(--isjac-eyebrow-letter-spacing);
	text-transform: uppercase;
	color: var(--isjac-color-accent);
}

.entry-content .isjac-media-showcase__header h2,
.editor-styles-wrapper .isjac-media-showcase__header h2 {
	margin: 0;
	font-size: var(--isjac-font-size-display);
	line-height: var(--isjac-line-height-tight);
	color: var(--isjac-color-ink);
}

.entry-content .isjac-media-showcase__body,
.editor-styles-wrapper .isjac-media-showcase__body {
	margin: 0;
	max-width: 62ch;
	color: var(--isjac-text-muted);
}

.entry-content .isjac-media-showcase__stage,
.editor-styles-wrapper .isjac-media-showcase__stage {
	position: relative;
	overflow: hidden;
	border-radius: var(--isjac-radius-md);
	box-shadow: var(--isjac-shadow-card);
	background: var(--isjac-color-ink);
}

.entry-content .isjac-media-showcase__open,
.editor-styles-wrapper .isjac-media-showcase__open {
	display: block;
	width: 100%;
	padding: 0;
	border: 0;
	color: var(--isjac-color-paper);
	background: transparent;
	cursor: zoom-in;
}

.entry-content .isjac-media-showcase__open img,
.editor-styles-wrapper .isjac-media-showcase__open img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

.entry-content .isjac-media-showcase__caption,
.editor-styles-wrapper .isjac-media-showcase__caption {
	position: absolute;
	right: var(--isjac-space-4);
	bottom: var(--isjac-space-4);
	max-width: min(42ch, calc(100% - (2 * var(--isjac-space-4))));
	padding: var(--isjac-space-2) var(--isjac-space-3);
	border-radius: var(--isjac-radius-sm);
	font-size: var(--isjac-font-size-sm);
	line-height: var(--isjac-line-height-base);
	color: var(--isjac-color-paper);
	background: color-mix(in srgb, var(--isjac-color-ink) 86%, transparent);
}

.entry-content .isjac-media-showcase__nav {
	position: absolute;
	top: 50%;
	width: 2.75rem;
	height: 2.75rem;
	border: 1px solid color-mix(in srgb, var(--isjac-color-paper) 50%, transparent);
	border-radius: 999px;
	background: color-mix(in srgb, var(--isjac-color-ink) 62%, transparent);
	transform: translateY(-50%);
	cursor: pointer;
}

.entry-content .isjac-media-showcase__nav::before {
	content: "";
	position: absolute;
	inset: 50% auto auto 50%;
	width: 0.7rem;
	height: 0.7rem;
	border-top: 2px solid var(--isjac-color-paper);
	border-left: 2px solid var(--isjac-color-paper);
}

.entry-content .isjac-media-showcase__nav--previous {
	left: var(--isjac-space-4);
}

.entry-content .isjac-media-showcase__nav--previous::before {
	transform: translate(-35%, -50%) rotate(-45deg);
}

.entry-content .isjac-media-showcase__nav--next {
	right: var(--isjac-space-4);
}

.entry-content .isjac-media-showcase__nav--next::before {
	transform: translate(-65%, -50%) rotate(135deg);
}

.entry-content .isjac-media-showcase__rail,
.editor-styles-wrapper .isjac-media-showcase__rail {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: var(--isjac-space-3);
	margin-top: var(--isjac-space-3);
}

.entry-content .isjac-media-showcase__thumb,
.editor-styles-wrapper .isjac-media-showcase__thumb {
	padding: 0;
	overflow: hidden;
	border: 2px solid transparent;
	border-radius: var(--isjac-radius-sm);
	background: transparent;
	box-shadow: var(--isjac-shadow-card);
	cursor: pointer;
}

.entry-content .isjac-media-showcase__thumb[aria-current],
.entry-content .isjac-media-showcase__thumb:focus-visible {
	border-color: var(--isjac-color-accent);
	outline: none;
}

.entry-content .isjac-media-showcase__thumb img,
.editor-styles-wrapper .isjac-media-showcase__thumb img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.entry-content .isjac-media-showcase__dialog {
	width: min(1180px, calc(100vw - (2 * var(--isjac-space-5))));
	padding: var(--isjac-space-4);
	border: 0;
	border-radius: var(--isjac-radius-md);
	background: var(--isjac-color-paper);
	box-shadow: var(--isjac-shadow-overlay);
}

.entry-content .isjac-media-showcase__dialog::backdrop {
	background: color-mix(in srgb, var(--isjac-color-ink) 78%, transparent);
}

.entry-content .isjac-media-showcase__dialog img {
	display: block;
	width: 100%;
	max-height: 78vh;
	object-fit: contain;
}

.entry-content .isjac-media-showcase__dialog p {
	margin: var(--isjac-space-3) 0 0;
	color: var(--isjac-text-muted);
}

.entry-content .isjac-media-showcase__close {
	float: right;
	margin-bottom: var(--isjac-space-3);
}

.editor-styles-wrapper .isjac-media-showcase__empty {
	padding: var(--isjac-space-6);
	border: 1px dashed var(--isjac-color-rule);
	border-radius: var(--isjac-radius-md);
	color: var(--isjac-text-muted);
}

.components-panel .isjac-media-showcase-editor-image {
	display: grid;
	gap: var(--isjac-space-2);
	padding-block: var(--isjac-space-3);
	border-top: 1px solid var(--isjac-color-rule);
}

.components-panel .isjac-media-showcase-editor-image__header {
	display: flex;
	gap: var(--isjac-space-2);
	align-items: center;
	justify-content: space-between;
	font-size: var(--isjac-font-size-sm);
	font-weight: var(--isjac-font-weight-medium);
	color: var(--isjac-color-ink);
}

.components-panel .isjac-media-showcase-editor-image__actions {
	display: flex;
	gap: var(--isjac-space-1);
	align-items: center;
}

.components-panel .isjac-media-showcase-editor-image img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: var(--isjac-radius-sm);
	object-fit: cover;
}

@media (max-width: 768px) {
	.entry-content .isjac-media-showcase__inner,
	.editor-styles-wrapper .isjac-media-showcase__inner {
		width: calc(100vw - (2 * var(--isjac-space-4)));
	}

	.entry-content .isjac-media-showcase__rail,
	.editor-styles-wrapper .isjac-media-showcase__rail {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}
