/* ===========================================================================
   FILTERS — Product listing filter sidebar
   Petz.gr

   !important needed on .collapse-title button, ::after pseudo — Modesy
   defines these at L7298-7393. Also needed on .custom-control-label,
   .filter-item base styles, filter chips, sort dropdown, mobile button.
   =========================================================================== */

/* ── Filter container ────────────────────────────────────── */

.product-filters-container {
	background: var(--petz-bg-white, #ffffff);
	border-radius: var(--petz-radius-lg, 16px);
	padding: 20px;
	box-shadow: var(--petz-shadow-sm, 0 2px 8px rgba(45,52,54,0.06));
	border: 1px solid var(--petz-border, #e8e4e0);
}

/* ── Location filter ─────────────────────────────────────── */

.filter-item-location {
	padding-bottom: 15px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.filter-item-location .title {
	margin-bottom: 12px;
}

.filter-location-group {
	margin-bottom: 8px;
}

/* ── Custom select dropdown (petz-exclusive, no !important) ── */

.filter-select {
	width: 100%;
	min-height: 44px;
	padding: 10px 16px;
	font-size: 0.9rem;
	font-weight: 500;
	line-height: 1.4;
	border: 1px solid var(--petz-border, #e8e4e0);
	border-radius: var(--petz-radius, 12px);
	background-color: var(--petz-bg-white, #ffffff);
	color: var(--petz-text-dark, #2d3436);
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23636e72' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 38px;
}

.filter-select:hover {
	border-color: var(--mds-color-main, var(--petz-primary, #4CAF50));
}

.filter-select:focus {
	outline: none;
	border-color: var(--mds-color-main, var(--petz-primary, #4CAF50));
	box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.12);
}

.filter-select:disabled {
	background-color: var(--petz-bg-page, #faf9f7);
	color: var(--petz-text-light, #b2bec3);
	cursor: not-allowed;
}

/* ── Filter items base ───────────────────────────────────── */

.product-filters .filter-item {
	margin-bottom: 6px;
	border: none;
	padding-bottom: 0;
	border-radius: 0;
	background: transparent;
	overflow: visible;
}

.product-filters .filter-item:last-child {
	margin-bottom: 0;
}

/* Extra spacing between filter TYPE groups (Category → Location → Custom Fields) */
.product-filters .filter-item-categories + .filter-item-location {
	margin-top: 14px !important;
}
.product-filters .filter-item-location + .filter-item {
	margin-top: 18px !important;
}
.product-filters .filter-item-keyword {
	margin-top: 18px !important;
}

.product-filters .filter-item-categories,
.product-filters .filter-item-location {
	border: none;
	background: transparent;
}

.product-filters .filter-item .title {
	font-weight: 600;
	color: var(--petz-text-dark, #2d3436);
}

/* ── Collapse button — !important needed (overrides Modesy L7310-7340) ── */

.product-filters .filter-item .collapse-title button i,
.product-filters .filter-item .collapse-title button svg,
.product-filters .filter-item .collapse-title button .icon,
.product-filters .filter-item .collapse-title button::before {
	display: none !important;
}

.product-filters .filter-item .collapse-title button {
	width: 100% !important;
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	min-height: 44px !important;
	padding: 0 14px !important;
	font-size: 0.9rem !important;
	font-weight: 600 !important;
	line-height: 44px !important;
	background: var(--petz-bg-white, #ffffff) !important;
	border: 1px solid var(--petz-border, #e8e4e0) !important;
	border-radius: var(--petz-radius, 12px) !important;
	color: var(--petz-text-dark, #2d3436) !important;
	text-align: left !important;
	cursor: pointer !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	box-shadow: none !important;
}

.product-filters .filter-item .collapse-title button:hover {
	border-color: var(--mds-color-main, var(--petz-primary, #4CAF50)) !important;
	background: var(--petz-bg-white, #ffffff) !important;
	box-shadow: 0 2px 6px rgba(76, 175, 80, 0.08) !important;
}

.product-filters .filter-item .collapse-title button:focus {
	outline: none !important;
	border-color: var(--mds-color-main, var(--petz-primary, #4CAF50)) !important;
}

/* Active filter indicator — green left border when section has selections */
.product-filters .filter-item .collapse-title button:not(.collapsed) {
	border-left: 3px solid var(--petz-primary, #4CAF50) !important;
}

/* Chevron arrow — !important needed (overrides Modesy ::after L7320) */
.product-filters .filter-item .collapse-title button::after {
	content: '' !important;
	display: block !important;
	width: 8px !important;
	height: 8px !important;
	border-right: 2px solid var(--petz-text-medium, #636e72) !important;
	border-bottom: 2px solid var(--petz-text-medium, #636e72) !important;
	border-top: none !important;
	border-left: none !important;
	background: transparent !important;
	transform: rotate(45deg) !important;
	transition: transform 0.25s ease !important;
	flex-shrink: 0 !important;
	margin-left: auto !important;
	position: static !important;
}

.product-filters .filter-item .collapse-title button.collapsed::after {
	transform: rotate(-45deg) !important;
}

/* ── Filter list ─────────────────────────────────────────── */

.product-filters .filter-item .filter-list {
	padding: 0;
	margin: 0;
	list-style: none;
}

.product-filters .filter-item .filter-list li {
	padding: 7px 10px;
	border-radius: 8px;
	cursor: pointer;
	transition: background 0.15s ease;
}

.product-filters .filter-item .filter-list li:hover {
	background-color: rgba(76, 175, 80, 0.06);
}

.product-filters .filter-item .filter-list-container {
	padding: 10px 12px 12px;
	border-top: none;
}

.product-filters .filter-item .filter-list.mds-scrollbar {
	max-height: 200px;
	overflow-y: auto;
}

/* Custom scrollbar for filter lists */
.product-filters .filter-item .filter-list.mds-scrollbar::-webkit-scrollbar {
	width: 5px;
}
.product-filters .filter-item .filter-list.mds-scrollbar::-webkit-scrollbar-track {
	background: transparent;
}
.product-filters .filter-item .filter-list.mds-scrollbar::-webkit-scrollbar-thumb {
	background: rgba(76, 175, 80, 0.25);
	border-radius: 10px;
}

/* ── Checkboxes — custom green ───────────────────────────── */

.product-filters .filter-item .custom-checkbox .custom-control-label {
	font-size: 0.875rem;
	color: var(--petz-text-dark, #2d3436);
	cursor: pointer;
	transition: color 0.15s ease;
	padding-left: 2px;
}

.product-filters .filter-item .custom-checkbox .custom-control-label::before {
	border-radius: 5px !important;
	border: 2px solid var(--petz-border, #e8e4e0) !important;
	width: 18px !important;
	height: 18px !important;
	transition: all 0.15s ease !important;
}

.product-filters .filter-item .custom-checkbox .custom-control-input:checked ~ .custom-control-label::before {
	background-color: var(--petz-primary, #4CAF50) !important;
	border-color: var(--petz-primary, #4CAF50) !important;
}

.product-filters .filter-item .custom-checkbox .custom-control-input:checked + .custom-control-label,
.product-filters .filter-item .custom-checkbox .custom-control-input:checked ~ .custom-control-label {
	color: var(--petz-primary, #4CAF50) !important;
	font-weight: 600 !important;
}

.product-filters .filter-item .custom-checkbox .custom-control-input:focus ~ .custom-control-label::before {
	box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.12) !important;
}

/* ── Search inputs inside filters ────────────────────────── */

.product-filters .filter-item .filter-search-input {
	margin-bottom: 8px;
	padding: 8px 12px;
	font-size: 0.85rem;
	border-radius: 8px;
	border: 1px solid var(--petz-border, #e8e4e0);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.product-filters .filter-item .filter-search-input:focus {
	outline: none;
	border-color: var(--petz-primary, #4CAF50);
	box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.12);
}

/* ── Price filter inputs ─────────────────────────────────── */

.product-filters .filter-item .inputs-filter-price .form-input {
	border: 1px solid var(--petz-border, #e8e4e0) !important;
	border-radius: 8px !important;
	height: 40px !important;
	font-size: 0.9rem !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.product-filters .filter-item .inputs-filter-price .form-input:focus {
	border-color: var(--petz-primary, #4CAF50) !important;
	box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.12) !important;
	outline: none !important;
}

/* ── Keyword filter button — green CTA ───────────────────── */

.product-filters .filter-item .btn-filter-product {
	display: block !important;
	width: 100% !important;
	margin-top: 10px !important;
	padding: 10px 16px !important;
	background: var(--petz-primary, #4CAF50) !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--petz-radius, 12px) !important;
	font-weight: 600 !important;
	font-size: 0.875rem !important;
	cursor: pointer !important;
	transition: background-color 0.2s ease, box-shadow 0.2s ease !important;
}

.product-filters .filter-item .btn-filter-product:hover {
	background: var(--petz-primary-hover, #43A047) !important;
	box-shadow: 0 4px 12px rgba(76, 175, 80, 0.25) !important;
}

.product-filters .filter-item .filter-list-categories-parent {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 6px 10px;
	border-radius: 10px;
	background: var(--petz-primary, #4CAF50);
	font-weight: 600;
	font-size: 0.8rem;
	color: #fff !important;
	text-decoration: none !important;
	margin-bottom: 8px;
	transition: all 0.2s ease;
}

.product-filters .filter-item .filter-list-categories-parent:hover {
	background: #1e8449;
	color: #fff !important;
	text-decoration: none !important;
}

.product-filters .filter-item .filter-list-categories li a {
	display: inline-block;
	padding: 6px 12px;
	background: #fff;
	border: 1px solid var(--petz-border, #e8e4e0);
	border-radius: 10px;
	color: var(--petz-text-dark, #2d3436);
	font-size: 0.8rem;
	font-weight: 500;
	text-decoration: none !important;
	transition: all 0.2s ease;
	white-space: nowrap;
}

.product-filters .filter-item .filter-list-categories li a:hover {
	background: var(--petz-primary, #4CAF50);
	border-color: var(--petz-primary, #4CAF50);
	color: #fff !important;
	text-decoration: none !important;
	transform: translateY(-1px);
	box-shadow: 0 2px 8px rgba(76, 175, 80, 0.2);
}

/* ===========================================================================
   FILTER CHIPS — Active filter tags above product grid
   !important needed — overrides Modesy style-2.6.css L7161-7227
   =========================================================================== */

.filter-reset-tag {
	display: inline-flex !important;
	align-items: center !important;
	border-radius: var(--petz-radius, 12px) !important;
	background-color: rgba(76, 175, 80, 0.08) !important;
	border: 1px solid rgba(76, 175, 80, 0.18) !important;
	min-height: 34px !important;
	transition: background-color 0.15s ease, border-color 0.15s ease !important;
}

.filter-reset-tag:hover {
	background-color: rgba(76, 175, 80, 0.14) !important;
	border-color: rgba(76, 175, 80, 0.3) !important;
}

.filter-reset-tag .left {
	display: flex !important;
	align-items: center !important;
}

.filter-reset-tag .left button {
	width: 22px !important;
	height: 22px !important;
	line-height: 22px !important;
	border-radius: 50% !important;
	background-color: rgba(76, 175, 80, 0.12) !important;
	color: var(--petz-primary, #4CAF50) !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 6px !important;
	font-size: 10px !important;
	transition: background-color 0.15s ease !important;
	cursor: pointer !important;
}

.filter-reset-tag .left button:hover {
	background-color: var(--petz-primary, #4CAF50) !important;
	color: #fff !important;
}

.filter-reset-tag .right {
	display: flex !important;
	flex-direction: column !important;
	padding: 4px 12px 4px 0 !important;
	vertical-align: middle !important;
}

.filter-reset-tag .right span {
	font-size: 11px !important;
	line-height: 14px !important;
	white-space: nowrap !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	max-width: 200px !important;
}

.filter-reset-tag .right .reset-tag-title {
	color: var(--petz-text-medium, #636e72) !important;
	font-weight: 500 !important;
}

.link-reset-filters {
	display: inline-flex !important;
	align-items: center !important;
	font-size: 0.8rem !important;
	font-weight: 600 !important;
	color: var(--petz-text-medium, #636e72) !important;
	white-space: nowrap !important;
	transition: color 0.15s ease !important;
}

.link-reset-filters:hover {
	color: var(--petz-primary, #4CAF50) !important;
	text-decoration: underline !important;
}

/* ===========================================================================
   SORT DROPDOWN — override Modesy defaults
   !important needed — overrides style-2.6.css L7230-7258
   =========================================================================== */

.product-sort-by .dropdown .btn {
	border: 1px solid var(--petz-border, #e8e4e0) !important;
	border-radius: var(--petz-radius, 12px) !important;
	padding: 8px 14px !important;
	font-size: 0.875rem !important;
	font-weight: 500 !important;
	color: var(--petz-text-dark, #2d3436) !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	background: var(--petz-bg-white, #fff) !important;
}

.product-sort-by .dropdown .btn:hover {
	border-color: var(--petz-primary, #4CAF50) !important;
	box-shadow: 0 2px 6px rgba(76, 175, 80, 0.08) !important;
}

.product-sort-by .dropdown .dropdown-menu {
	border-radius: var(--petz-radius, 12px) !important;
	border: 1px solid var(--petz-border, #e8e4e0) !important;
	box-shadow: var(--petz-shadow-card, 0 4px 20px rgba(76,175,80,0.08)) !important;
	padding: 6px !important;
	margin-top: 6px !important;
}

.product-sort-by .dropdown .dropdown-menu .dropdown-item {
	border-radius: 8px !important;
	padding: 8px 14px !important;
	font-size: 0.875rem !important;
	transition: background-color 0.15s ease !important;
}

.product-sort-by .dropdown .dropdown-menu .dropdown-item:hover,
.product-sort-by .dropdown .dropdown-menu .dropdown-item.active {
	background-color: rgba(76, 175, 80, 0.08) !important;
	color: var(--petz-primary, #4CAF50) !important;
}

/* ===========================================================================
   MOBILE — Filter button + sort bar
   !important needed — overrides style-2.6.css L7094-7143
   =========================================================================== */

.container-filter-products-mobile .btn-filter-products-mobile .btn {
	border-radius: var(--petz-radius, 12px) !important;
	border: 1px solid var(--petz-border, #e8e4e0) !important;
	background: var(--petz-bg-white, #fff) !important;
	color: var(--petz-text-dark, #2d3436) !important;
	font-weight: 500 !important;
	height: 44px !important;
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	transition: border-color 0.2s ease !important;
}

.container-filter-products-mobile .btn-filter-products-mobile .btn:hover {
	border-color: var(--petz-primary, #4CAF50) !important;
}

.container-filter-products-mobile .btn-filter-products-mobile .btn svg {
	fill: var(--petz-primary, #4CAF50) !important;
}

.container-filter-products-mobile .product-sort-by .dropdown .btn {
	border-radius: var(--petz-radius, 12px) !important;
	border: 1px solid var(--petz-border, #e8e4e0) !important;
	background: var(--petz-bg-white, #fff) !important;
	height: 44px !important;
	display: flex !important;
	align-items: center !important;
	font-weight: 500 !important;
}

/* Gap between the two mobile buttons */
.container-filter-products-mobile {
	gap: 8px;
}



/* ===========================================================================
   EMPTY STATE — "No products found"
   =========================================================================== */

.no-records-found {
	text-align: center;
	padding: 60px 20px;
	color: var(--petz-text-medium, #636e72);
	font-size: 1rem;
	font-style: italic;
}
