/**
 * Products Styles for Recocycle Plugin
 *
 * @package RECOCYCLE_PLUGIN
 */

/* Grid Layout */
.recocycle-products-grid {
	display: grid;
	gap: 24px;
}

@media (min-width: 769px) {

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

@media (max-width: 768px) {

	.recocycle-products-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}
}

/* Product Tag Chip */
.recocycle-product-tag-chip {
	padding: 4px 12px;
	border-radius: 4px;
	font-size: 16px;
	font-weight: 500;
	text-align: center;
	width: fit-content;
	min-width: 48px;
	cursor: default;
}

/* Product Card */
.recocycle-product-card {
	display: flex;
	flex-direction: column;
	gap: 16px;

	border: 1px solid #ddd;
	border-radius: 16px;

	padding: 24px;
	overflow: hidden;

	background-color: #fff;

	transition: all 300ms ease-in-out;
}

.recocycle-product-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
}

.recocycle-product-card .recocycle-product-image {
	width: 100%;
	aspect-ratio: 1/1;
	overflow: hidden;
	border-radius: 8px;
}

.recocycle-product-card .recocycle-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all 300ms ease-in-out;
}

.recocycle-product-card:hover .recocycle-product-image img {
	transform: scale(1.05);
}

.recocycle-product-card .recocycle-product-tag-chip {
	font-size: 14px;
}

.recocycle-product-card .recocycle-product-content {
	display: flex;
	flex-direction: column;
}

.recocycle-product-card .recocycle-product-title {
	font-size: 16px;
}

.recocycle-product-card .recocycle-product-title a {
	font-weight: 500;
	color: var(--e-global-color-text);
	text-decoration: none;
}

@media (max-width: 768px) {

	.recocycle-product-card {
		border-radius: 8px;
		padding: 8px;
		gap: 8px;
	}
}

/* Pagination */
.recocycle-pagination {
	margin-top: 40px;

	display: flex;
	justify-content: center;
	gap: 8px;
}

.recocycle-pagination .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;

	border: 1px solid var(--e-global-color-primary);
	border-radius: 4px;

	padding: 4px 8px;

	min-width: 32px;
	height: 32px;

	font-weight: 500;
	text-decoration: none;
	color: var(--e-global-color-primary);
	line-height: 1;

	transition: all 150ms ease-in-out;
}

.recocycle-pagination .page-numbers:not(.current):hover {
	background-color: var(--e-global-color-accent);
	border-color: var(--e-global-color-accent);
}

.recocycle-pagination .page-numbers.current {
	background-color: var(--e-global-color-primary);
	color: #fff;
	cursor: default;
}

/* Filters */
.recocycle-filters-wrapper {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

.recocycle-filter-block {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.recocycle-filter-block .recocycle-filter-title {
	font-size: 20px;
}

.recocycle-filter-block .recocycle-filter-list {
	list-style: none;
	padding: 0;

	display: flex;
	flex-direction: column;
	gap: 16px;
}

.recocycle-filter-item a {
	font-weight: 500;
	text-decoration: none;
	color: var(--e-global-color-text);
}

.recocycle-filter-item.active a {
	color: var(--e-global-color-primary);
	text-decoration: underline;
}

.recocycle-filters-wrapper .recocycle-clear-filters {
	color: var(--e-global-color-text);
	font-weight: 400;
	font-size: 14px;
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: 8px;
	width: fit-content;
}
