/* ==========================================================================
	 LIGHTBOX MODULE STYLES (clb- NAMESPACED)
	 ========================================================================= */

/* --- Lightbox Trigger Overlay Button --- */
.cic-lightbox-trigger-btn {
	position: absolute !important;
	top: 16px !important;
	right: 16px !important;
	width: 42px !important;
	height: 42px !important;
	border-radius: 8px !important;
	background-color: rgba(255, 255, 255, 0.85) !important;
	border: 1px solid #e5e7eb !important;
	color: #1f2937 !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	z-index: 10 !important;
	opacity: 0.5 !important;
	padding: 0 !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
	transform: none !important;
	transition: opacity 0.2s ease, background-color 0.2s, color 0.2s, border-color 0.2s !important;
}

.cic-lightbox-trigger-btn svg {
	width: 20px !important;
	height: 20px !important;
}

.cic-lightbox-trigger-btn:hover,
.cic-lightbox-trigger-btn:focus-visible,
.cic-lightbox-trigger-btn:active {
	opacity: 1 !important;
	background-color: #2563eb !important;
	color: #ffffff !important;
	border-color: #2563eb !important;
	position: absolute !important;
	top: 16px !important;
	right: 16px !important;
	padding: 0 !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
	transform: none !important;
}

/* --- Fullscreen Lightbox Stage UI --- */
.clb-lightbox-overlay {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100vw !important;
	height: 100vh !important;
	background-color: rgba(10, 10, 12, 0.98) !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
	z-index: 2000 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease, cursor 0.2s ease !important;
	touch-action: none;
}

.clb-lightbox-overlay.clb-active {
	opacity: 1 !important;
	pointer-events: auto !important;
}

.clb-lightbox-stage {
	position: relative !important;
	width: 90% !important;
	max-width: 1100px !important;
	height: 75vh !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.clb-lightbox-image {
	position: absolute !important;
	max-width: 100% !important;
	max-height: 100% !important;
	object-fit: contain !important;
	border-radius: 4px !important;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5) !important;
	user-select: none !important;
	opacity: 0;
	transform: scale(0.98) !important;
	z-index: 1 !important;
	transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1), transform 0.8s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.clb-lightbox-image.clb-active {
	opacity: 1 !important;
	transform: scale(1) !important;
	z-index: 2 !important;
}

/* Control Headers */
.clb-lightbox-controls {
	position: absolute !important;
	top: 20px !important;
	right: 20px !important;
	display: flex !important;
	gap: 12px !important;
	z-index: 2010 !important;
	transition: opacity 0.3s ease !important;
}

.clb-lightbox-btn {
	background: rgba(255, 255, 255, 0.1) !important;
	border: 1px solid rgba(255, 255, 255, 0.15) !important;
	color: #ffffff !important;
	width: 44px !important;
	height: 44px !important;
	border-radius: 50% !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
	box-shadow: none !important;
	transform: none !important;
	transition: background-color 0.2s, color 0.2s, transform 0.2s, opacity 0.3s ease !important;
}

.clb-lightbox-controls .clb-lightbox-btn:hover {
	transform: scale(1.05) !important;
}

.clb-lightbox-btn:active,
.clb-lightbox-btn:focus {
	padding: 0 !important;
	box-shadow: none !important;
}

.clb-lightbox-btn svg {
	width: 20px !important;
	height: 20px !important;
	fill: currentColor !important;
}

/* Navigation Arrow Layout */
.clb-lightbox-nav {
	position: absolute !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	width: 50px !important;
	height: 50px !important;
	font-size: 1.4rem !important;
	z-index: 2010 !important;
	padding: 0 !important;
	border-radius: 50% !important;
	border: 1px solid rgba(255, 255, 255, 0.15) !important;
	box-shadow: none !important;
	transition: opacity 0.3s ease, background-color 0.2s, color 0.2s !important;
}

.clb-lightbox-nav:hover,
.clb-lightbox-nav:active,
.clb-lightbox-nav:focus-visible {
	background-color: #2563eb !important;
	color: #ffffff !important;
	transform: translateY(-50%) !important;
	padding: 0 !important;
}

.clb-lightbox-nav.clb-prev { left: 24px !important; }
.clb-lightbox-nav.clb-next { right: 24px !important; }

/* Status Counter Text Node */
.clb-lightbox-counter {
	position: absolute !important;
	bottom: 24px !important;
	color: rgba(255, 255, 255, 0.7) !important;
	font-size: 0.95rem !important;
	letter-spacing: 0.05em !important;
	font-weight: 500 !important;
	z-index: 2010 !important;
	transition: opacity 0.3s ease !important;
}

/* --- High-Specificity Auto-Hide Enforcements --- */
.clb-lightbox-overlay.clb-hide-controls {
	cursor: none !important;
}

.clb-lightbox-overlay.clb-hide-controls .clb-lightbox-controls,
.clb-lightbox-overlay.clb-hide-controls .clb-lightbox-nav,
.clb-lightbox-overlay.clb-hide-controls .clb-lightbox-counter {
	opacity: 0 !important;
	pointer-events: none !important;
}