/* ─────────────────────────────────────────────
   PK Photo Showcase — Elementor Widget Styles
   ───────────────────────────────────────────── */

.pk-showcase {
	position: relative;
	width: 100%;
	box-sizing: border-box;
}

/* ── Texture overlay (currency guilloche) ─── */

.pk-showcase__texture {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	background-image:
		repeating-linear-gradient(
			90deg,
			rgba(184, 150, 62, 0.35) 0px,
			transparent 1px,
			transparent 11px
		),
		repeating-linear-gradient(
			0deg,
			rgba(184, 150, 62, 0.25) 0px,
			transparent 1px,
			transparent 11px
		),
		repeating-linear-gradient(
			45deg,
			transparent 0px,
			transparent 7px,
			rgba(184, 150, 62, 0.15) 7px,
			rgba(184, 150, 62, 0.15) 8px
		),
		repeating-linear-gradient(
			-45deg,
			transparent 0px,
			transparent 7px,
			rgba(184, 150, 62, 0.15) 7px,
			rgba(184, 150, 62, 0.15) 8px
		);
	opacity: 0.05;
}

/* Subtle inner vignette for framed feel */
.pk-showcase::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	box-shadow: inset 0 0 60px rgba(0, 0, 0, 0.2);
}

/* Keep content above overlays */
.pk-showcase__divider,
.pk-showcase__heading,
.pk-showcase__grid,
.pk-showcase__footer {
	position: relative;
	z-index: 1;
}

/* ── Divider lines ────────────────────────── */

.pk-showcase__divider {
	display: block;
	height: 1px;
	width: 60%;
	margin: 0 auto;
	opacity: 0.5;
}

.pk-showcase__divider--top {
	margin-bottom: 20px;
}

.pk-showcase__divider--bottom {
	margin-top: 16px;
}

/* ── Heading ──────────────────────────────── */

.pk-showcase__heading {
	text-align: center;
	margin: 0 0 20px;
	text-transform: uppercase;
}

/* ── Grid container ───────────────────────── */

.pk-showcase__grid {
	display: grid;
	max-width: 1140px;
	margin: 0 auto;
}

/* ─── Layout: 1 photo — full width ────────── */

.pk-showcase--count-1 .pk-showcase__grid {
	grid-template-columns: 1fr;
}

/* ─── Layout: 2 photos — equal split ─────── */

.pk-showcase--count-2 .pk-showcase__grid {
	grid-template-columns: 1fr 1fr;
}

/* ─── Layout: 3 photos — large left + 2 stacked right */

.pk-showcase--count-3 .pk-showcase__grid {
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
}

.pk-showcase--count-3 .pk-showcase__featured {
	grid-row: 1 / -1;
}

/* ─── Layout: 4+ photos — large left + grid right */

.pk-showcase--count-4 .pk-showcase__grid,
.pk-showcase--count-5 .pk-showcase__grid,
.pk-showcase--count-6 .pk-showcase__grid {
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
}

.pk-showcase--count-4 .pk-showcase__featured,
.pk-showcase--count-5 .pk-showcase__featured,
.pk-showcase--count-6 .pk-showcase__featured {
	grid-row: 1 / -1;
}

/* ── Cell (the <a> wrapper) — border lives here ── */

.pk-showcase__cell {
	position: relative;
	display: block;
	overflow: hidden;
	text-decoration: none;
	line-height: 0;
	border-style: solid;
	border-width: 2px;
	border-color: #B8963E;
	border-radius: 4px;
}

/* ── Image — !important overrides Elementor global img resets ── */

.pk-showcase__img {
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
	object-position: center center !important;
	display: block !important;
	border: none !important;
	transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.pk-showcase__cell:hover .pk-showcase__img {
	transform: scale(1.04);
}

/* ── Caption overlay (works on ALL images) ── */

.pk-showcase__caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 8px 12px;
	font-family: "Poppins", sans-serif;
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	color: #E8E3D5;
	background: linear-gradient(transparent, rgba(0, 0, 0, 0.6));
	opacity: 0;
	transform: translateY(4px);
	transition: opacity 0.3s ease, transform 0.3s ease;
	line-height: 1.4;
}

.pk-showcase__cell:hover .pk-showcase__caption {
	opacity: 1;
	transform: translateY(0);
}

/* "Always visible" caption mode */
.pk-showcase--captions-visible .pk-showcase__caption {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

/* ── Zoom icon overlay ────────────────────── */

.pk-showcase__zoom {
	position: absolute;
	top: 8px;
	right: 8px;
	width: 26px;
	height: 26px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.4);
	border-radius: 50%;
	color: #E8E3D5;
	font-size: 11px;
	opacity: 0;
	transform: scale(0.8);
	transition: opacity 0.25s ease, transform 0.25s ease;
	pointer-events: none;
}

.pk-showcase__cell:hover .pk-showcase__zoom {
	opacity: 1;
	transform: scale(1);
}

/* ── Footer caption ───────────────────────── */

.pk-showcase__footer {
	text-align: center;
	margin: 12px 0 0;
	font-style: italic;
}

/* ── Responsive: tablet (≤ 1024px) ────────── */

@media (max-width: 1024px) {
	.pk-showcase__grid {
		height: auto !important;
	}

	.pk-showcase--count-3 .pk-showcase__grid,
	.pk-showcase--count-4 .pk-showcase__grid,
	.pk-showcase--count-5 .pk-showcase__grid,
	.pk-showcase--count-6 .pk-showcase__grid {
		grid-template-columns: 1fr 1fr;
		grid-template-rows: auto;
	}

	.pk-showcase--count-3 .pk-showcase__featured,
	.pk-showcase--count-4 .pk-showcase__featured,
	.pk-showcase--count-5 .pk-showcase__featured,
	.pk-showcase--count-6 .pk-showcase__featured {
		grid-column: 1 / -1;
		grid-row: auto;
		min-height: 220px;
	}

	.pk-showcase__thumb {
		min-height: 180px;
	}
}

/* ── Responsive: mobile (≤ 767px) ─────────── */

@media (max-width: 767px) {
	.pk-showcase__heading {
		font-size: 18px !important;
		letter-spacing: 3px !important;
		margin-bottom: 14px;
	}

	.pk-showcase__grid {
		grid-template-columns: 1fr !important;
		grid-template-rows: auto !important;
		height: auto !important;
	}

	.pk-showcase__cell {
		grid-column: auto !important;
		grid-row: auto !important;
		min-height: 200px;
	}

	.pk-showcase__caption {
		opacity: 1 !important;
		transform: translateY(0) !important;
	}

	.pk-showcase__zoom {
		opacity: 1;
		transform: scale(1);
	}

	.pk-showcase__footer {
		font-size: 11px !important;
		margin-top: 10px;
	}

	.pk-showcase__divider--top {
		margin-bottom: 14px;
	}
}
