/* ============================================
   Custom Products Widget
   ============================================ */

.cp-products-wrapper {
	width: 100%;
}

.cp-products-grid {
	display: grid;
	gap: 30px;
}

.cp-products-grid.cp-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.cp-products-grid.cp-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.cp-products-grid.cp-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.cp-products-grid.cp-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.cp-products-grid.cp-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

/* Product Item */
.cp-product-item {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	height: 100%;
}

/* Product Info - flex grow to fill space */
.cp-product-info {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	width: 100%;
	padding: 15px 0;
}

.cp-product-title {
	flex-grow: 1;
}

/* Product Label */
.cp-product-label {
	display: inline-block;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding: 5px 15px;
	border-radius: 20px;
	margin-bottom: 15px;
	color: #d4a574;
	background-color: #fdf6f0;
}

/* Product Image */
.cp-product-image-wrapper {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.cp-product-image {
	display: block;
	position: relative;
	width: 100%;
	height: 300px;
	overflow: hidden;
	background-color: #f5f5f5;
}

.cp-product-image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	transition: opacity 0.4s ease;
}

/* Image Fit Modes */
.cp-image-fit-contain .cp-product-image img {
	object-fit: contain;
}

.cp-image-fit-cover .cp-product-image img {
	object-fit: cover;
}

.cp-image-fit-fill .cp-product-image img {
	object-fit: fill;
}

.cp-image-fit-none .cp-product-image img {
	object-fit: none;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.cp-product-image .cp-img-hover {
	opacity: 0;
}

.cp-product-item:hover .cp-product-image .cp-img-main {
	opacity: 0;
}

.cp-product-item:hover .cp-product-image .cp-img-hover {
	opacity: 1;
}

/* Wishlist Button */
.cp-wishlist-btn {
	position: absolute;
	top: 10px;
	right: 10px;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #ffffff;
	border-radius: 50%;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	z-index: 10;
}

.cp-product-item:hover .cp-wishlist-btn {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.cp-wishlist-btn svg {
	width: 20px;
	height: 20px;
	fill: none;
	stroke: #333;
	stroke-width: 2;
	transition: fill 0.2s ease, stroke 0.2s ease;
}

.cp-wishlist-btn:hover svg path {
	fill: #fbe5e7;
	stroke: #fbe5e7;
}

.cp-wishlist-btn.cp-wishlisted svg path {
	fill: #fbe5e7;
	stroke: #fbe5e7;
}

.cp-wishlist-btn.cp-wishlisted {
	opacity: 1 !important;
	visibility: visible !important;
	transform: translateY(0) !important;
}


.cp-product-title {
	margin: 0 0 10px 0;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.5;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.cp-product-title a {
	color: #333;
	text-decoration: none;
	transition: color 0.2s ease;
}

.cp-product-title a:hover {
	color: #000;
}

/* Product Price */
.cp-product-price {
	margin-bottom: 15px;
	font-size: 14px;
	font-weight: 500;
}

.cp-product-price,
.cp-product-price .price,
.cp-product-price .amount,
.cp-product-price span,
.cp-product-price bdi,
.cp-product-price ins,
.cp-product-price ins .amount,
.cp-product-price ins bdi {
	color: inherit !important;
}

.cp-product-price del,
.cp-product-price del .amount,
.cp-product-price del bdi,
.cp-product-price del span {
	color: #999 !important;
	margin-right: 8px;
}

.cp-product-price ins {
	text-decoration: none;
}

/* Add to Cart Button */
.cp-add-to-cart {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 12px 25px;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: #333;
	background-color: #fff;
	border: 1px solid #333;
	cursor: pointer;
	transition: color 0.3s ease, background-color 0.3s ease;
	box-sizing: border-box;
}

.cp-add-to-cart:hover {
	color: #fff;
	background-color: #333;
}

.cp-add-to-cart .cp-arrow-icon {
	width: 10px;
	height: 10px;
	margin-left: 5px;
	fill: currentColor;
	flex-shrink: 0;
}

/* No Products */
.cp-no-products {
	grid-column: 1 / -1;
	text-align: center;
	padding: 40px;
	color: #666;
}

/* Responsive - Tablet (768px - 1024px) */
@media (max-width: 1024px) and (min-width: 768px) {
	.cp-products-grid.cp-columns-tablet-1 {
		grid-template-columns: repeat(1, 1fr);
	}
	.cp-products-grid.cp-columns-tablet-2 {
		grid-template-columns: repeat(2, 1fr);
	}
	.cp-products-grid.cp-columns-tablet-3 {
		grid-template-columns: repeat(3, 1fr);
	}
	.cp-products-grid.cp-columns-tablet-4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* Responsive - Mobile (< 768px) */
@media (max-width: 767px) {
	.cp-products-grid.cp-columns-mobile-1 {
		grid-template-columns: repeat(1, 1fr);
	}
	.cp-products-grid.cp-columns-mobile-2 {
		grid-template-columns: repeat(2, 1fr);
	}
	.cp-products-grid.cp-columns-mobile-3 {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ========== Swiper Layout ========== */
.cp-layout-swiper .cp-swiper-container {
	position: relative;
	width: 100%;
}

.cp-layout-swiper .swiper {
	overflow: hidden;
	padding: 10px 0;
}

.cp-layout-swiper .swiper-wrapper {
	display: flex;
}

.cp-layout-swiper .swiper-slide {
	height: auto;
	box-sizing: border-box;
	flex-shrink: 0;
}

.cp-layout-swiper .swiper-slide.cp-product-item {
	height: auto;
	display: flex;
	flex-direction: column;
}

.cp-layout-swiper .cp-product-image-wrapper {
	width: 100%;
}

.cp-layout-swiper .cp-product-image {
	display: block;
	width: 100%;
	height: 300px;
	position: relative;
}

.cp-layout-swiper .cp-product-image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.cp-layout-swiper .swiper-button-prev,
.cp-layout-swiper .swiper-button-next {
	width: 44px;
	height: 44px;
	background-color: #fff;
	border-radius: 50%;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
	transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.cp-layout-swiper .swiper-button-prev:hover,
.cp-layout-swiper .swiper-button-next:hover {
	background-color: #333;
}

.cp-layout-swiper .swiper-button-prev:after,
.cp-layout-swiper .swiper-button-next:after {
	font-size: 16px;
	font-weight: 700;
	color: #333;
	transition: color 0.3s ease;
}

.cp-layout-swiper .swiper-button-prev:hover:after,
.cp-layout-swiper .swiper-button-next:hover:after {
	color: #fff;
}

.cp-layout-swiper .swiper-pagination {
	position: relative;
	margin-top: 20px;
}

.cp-layout-swiper .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background-color: #ccc;
	opacity: 1;
	transition: background-color 0.3s ease;
}

.cp-layout-swiper .swiper-pagination-bullet-active {
	background-color: #333;
}

@media (max-width: 768px) {
	.cp-layout-swiper .swiper-button-prev,
	.cp-layout-swiper .swiper-button-next {
		width: 36px;
		height: 36px;
	}

	.cp-layout-swiper .swiper-button-prev:after,
	.cp-layout-swiper .swiper-button-next:after {
		font-size: 14px;
	}
}
