/* ==========================================================================
	 1. CORE BASE & RESET STYLES
	 ========================================================================== */

.cic-container {
	width: 100%;
	max-width: 1200px;
}

.cic-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.cic-gallery {
	display: flex;
	flex-direction: column;
	gap: 20px;
	border-radius: 12px;
}

/* ==========================================================================
	 2. MAIN IMAGE VIEWPORT SECTION
	 ========================================================================== */
.cic-main-display {
	position: relative;
	width: 100%;
	height: 450px;
	border-radius: 8px;
	overflow: hidden;
	background-color: #e4e4e7;
	touch-action: pan-y;
	user-select: none;
}

.cic-main-display img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	pointer-events: none;
}

/* ==========================================================================
	 3. NAVIGATION BUTTONS (BASE CONFIGURATION)
	 ========================================================================== */
.cic-nav-btn {
	position: absolute !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	padding: 0 !important;
	border-radius: 50% !important;
	background-color: #ffffff !important;
	border: 1px solid #d1d5db !important;
	color: #1f2937 !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
	z-index: 10 !important;
	transition: background-color 0.2s, color 0.2s, border-color 0.2s, opacity 0.2s ease !important;
}

.cic-prev-btn { left: 12px !important; }
.cic-next-btn { right: 12px !important; }

.cic-main-nav-btn {
	width: 40px !important;
	height: 40px !important;
	font-size: 1rem !important;
}

.cic-carousel-nav-btn {
	width: 36px !important;
	height: 36px !important;
	font-size: 0.9rem !important;
}

/* ==========================================================================
	 4. UNIFIED SEMI-TRANSPARENT HOVER MATRIX
	 ========================================================================== */
.cic-main-nav-btn,
.cic-carousel-nav-btn,
.cic-lightbox-trigger-btn {
	opacity: 0.5 !important;
	pointer-events: auto !important;
}

.cic-main-nav-btn:hover,
.cic-carousel-nav-btn:hover,
.cic-lightbox-trigger-btn:hover,
.cic-main-nav-btn:focus-visible,
.cic-carousel-nav-btn:focus-visible,
.cic-lightbox-trigger-btn:focus-visible,
.cic-main-nav-btn:active,
.cic-carousel-nav-btn:active,
.cic-lightbox-trigger-btn:active {
	opacity: 1 !important;
	background-color: #2563eb !important;
	border-color: #2563eb !important;
	color: #ffffff !important;
	padding: 0 !important;
}

.cic-nav-btn:active {
	position: absolute !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.cic-main-nav-btn:disabled,
.cic-carousel-nav-btn:disabled {
	opacity: 0.15 !important;
	cursor: not-allowed !important;
	box-shadow: none !important;
	border-color: #e5e7eb !important;
	background-color: #f3f4f6 !important;
	color: #9ca3af !important;
	pointer-events: none !important;
}

/* ==========================================================================
	 5. CAROUSEL & THUMBNAIL TRACK SECTION
	 ========================================================================== */
.cic-carousel-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
}

.cic-carousel-window {
	width: 100%;
	overflow: hidden;
	touch-action: pan-y;
	user-select: none;
}

.cic-carousel-track {
	display: flex;
	will-change: transform;
	cursor: grab;
}

.cic-carousel-track:active {
	cursor: grabbing;
}

.cic-carousel-item {
	position: relative !important;
	top: 0 !important;
	left: 0 !important;
	height: 100px !important;
	border: 4px solid transparent !important;
	border-radius: 6px !important;
	overflow: hidden !important;
	cursor: pointer !important;
	background: none !important;
	padding: 0 !important;
	box-shadow: none !important;
	transform: none !important;
	transition: border-color 0.2s ease !important;
}

.cic-carousel-item:active,
.cic-carousel-item:hover,
.cic-carousel-item:focus {
	position: relative !important;
	top: 0 !important;
	left: 0 !important;
	padding: 0 !important;
	background: none !important;
	box-shadow: none !important;
	transform: none !important;
}

.cic-carousel-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	pointer-events: none;
}

.cic-carousel-item.cic-active {
	border-color: #2563eb !important;
	border-radius: 12px !important;
	outline: none !important;
}

.cic-carousel-item:focus-visible,
.cic-nav-btn:focus-visible {
	outline: 3px solid #db2777;
	outline-offset: 2px;
}