/* ===========================================
   Listings Page - Premium Boutique Design
   Entry animations & luxury feel
   =========================================== */

@keyframes listingsReveal {
	from {
		opacity: 0;
		transform: translateY(15px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes filterSlideIn {
	from {
		opacity: 0;
		transform: translateX(-10px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes cardReveal {
	from {
		opacity: 0;
		transform: scale(0.96);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

.listings-container {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 48px;
	max-width: 100%;
	padding: var(--spacing-xl) 40px;
	animation: listingsReveal 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
}

/* ===========================================
   Sidebar - Elegant Filter Panel
   =========================================== */
.listings-sidebar {
	background: transparent;
	padding-right: var(--spacing-md);
	animation: filterSlideIn 0.5s ease 0.1s backwards;
}

/* ===========================================
   Page Header - Premium Typography
   =========================================== */
.page-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: var(--spacing-xl);
	padding-bottom: var(--spacing-lg);
	border-bottom: 1px solid var(--color-border);
	flex-wrap: wrap;
	gap: var(--spacing-md);
	position: relative;
	animation: listingsReveal 0.5s ease 0.15s backwards;
}

/* Decorative accent line */
.page-header::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 50px;
	height: 2px;
	background: linear-gradient(90deg, var(--color-accent), transparent);
}

.header-left .page-title {
	font-size: 1.5rem;
	margin: 0 0 6px 0;
	font-weight: 500;
	font-family: var(--font-heading);
	letter-spacing: -0.02em;
	display: flex;
	align-items: center;
	gap: 10px;
}

/* Decorative star */
.header-left .page-title::before {
	content: '✦';
	font-size: 0.6rem;
	color: var(--color-accent);
}

.header-left .result-count {
	font-size: 0.875rem;
	color: var(--color-text-light);
	margin: 0;
	display: flex;
	align-items: center;
	gap: 6px;
}

.header-left .result-count::before {
	content: '';
	width: 4px;
	height: 4px;
	background: var(--color-accent);
	border-radius: 50%;
}

.header-right {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

/* ===========================================
   Sort Dropdown - Refined Controls
   =========================================== */
.sort-dropdown {
	display: flex;
	align-items: center;
	gap: 10px;
}

.sort-label {
	font-size: 0.95rem;
	color: var(--color-text-light);
	white-space: nowrap;
	font-weight: 500;
	letter-spacing: 0.02em;
}

.sort-dropdown select {
	padding: 10px 36px 10px 14px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;
	background-size: 12px;
	font-size: 0.9rem;
	font-family: var(--font-primary);
	color: var(--color-text);
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	min-width: 170px;
	transition:
		border-color var(--transition-fast),
		box-shadow var(--transition-base);
}

.sort-dropdown select:hover {
	border-color: var(--color-accent);
}

.sort-dropdown select:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(212, 163, 115, 0.15);
}

/* ===========================================
   Grid Toggles - Elegant Icons
   =========================================== */
.collection-grid-buttons {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 4px;
	background: var(--color-surface);
	border-radius: var(--radius-md);
}

.collection-grid-buttons .cursor-pointer {
	cursor: pointer;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-sm);
	opacity: 0.5;
	transition:
		opacity var(--transition-fast),
		background var(--transition-base),
		transform var(--transition-bounce);
}

.collection-grid-buttons .cursor-pointer:hover {
	opacity: 0.8;
	background: rgba(255, 255, 255, 0.6);
}

.collection-grid-buttons .cursor-pointer.active {
	opacity: 1;
	background: #fff;
	box-shadow: 0 1px 3px rgba(86, 66, 51, 0.1);
}

.collection-grid-buttons svg {
	width: 18px;
	height: 18px;
	fill: var(--color-text);
}

/* ===========================================
   Filter Groups - Premium Accordion
   =========================================== */
.filter-group {
	margin-bottom: 0;
	padding: 18px 0;
	border-bottom: 1px solid var(--color-border);
	position: relative;
}

/* Staggered filter animations */
.filter-group:nth-child(1) { animation: filterSlideIn 0.4s ease 0.15s backwards; }
.filter-group:nth-child(2) { animation: filterSlideIn 0.4s ease 0.2s backwards; }
.filter-group:nth-child(3) { animation: filterSlideIn 0.4s ease 0.25s backwards; }
.filter-group:nth-child(4) { animation: filterSlideIn 0.4s ease 0.3s backwards; }
.filter-group:nth-child(5) { animation: filterSlideIn 0.4s ease 0.35s backwards; }

.filter-title {
	font-size: 0.95rem;
	margin: 0;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
	color: var(--color-primary);
	font-family: var(--font-heading);
	padding: 4px 0;
	transition: color var(--transition-fast);
}

.filter-title:hover {
	color: var(--color-accent);
}

.toggle-icon {
	font-size: 1.1rem;
	font-weight: 300;
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--color-surface);
	transition:
		transform var(--transition-bounce),
		background var(--transition-fast);
}

.filter-group.collapsed .toggle-icon {
	transform: rotate(-90deg);
}

.filter-title:hover .toggle-icon {
	background: rgba(212, 163, 115, 0.15);
}

.filter-content {
	margin-top: 16px;
	padding-left: 2px;
}

.category-list a {
	color: var(--color-text);
	display: block;
	padding: 6px 0;
	font-size: 0.9rem;
	position: relative;
	transition:
		color var(--transition-fast),
		padding-left var(--transition-bounce);
}

.category-list a::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 1px;
	background: var(--color-accent);
	transition: width var(--transition-base);
}

.category-list a:hover,
.category-list a.active {
	background: transparent;
	color: var(--color-accent);
	padding-left: 12px;
}

.category-list a:hover::before,
.category-list a.active::before {
	width: 8px;
}

.checkbox-label {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 10px;
	cursor: pointer;
	font-size: 0.9rem;
	color: var(--color-text);
	padding: 4px 0;
	transition: color var(--transition-fast);
}

.checkbox-label:hover {
	color: var(--color-primary);
}

.checkbox-label input[type="checkbox"],
.checkbox-label input[type="radio"] {
	width: 18px;
	height: 18px;
	accent-color: var(--color-primary);
	cursor: pointer;
}

.show-more-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 12px;
	font-size: 0.9rem;
	color: var(--color-text-light);
	text-decoration: none;
	font-weight: 500;
	letter-spacing: 0.02em;
	transition:
		color var(--transition-fast),
		gap var(--transition-bounce);
}

.show-more-link::after {
	content: '↓';
	font-size: 0.9em;
	transition: transform var(--transition-bounce);
}

.show-more-link:hover {
	color: var(--color-accent);
	gap: 8px;
}

.show-more-link:hover::after {
	transform: translateY(2px);
}

/* ===========================================
   Active Filters - Filter Tags Display
   =========================================== */
.active-filters {
	margin-bottom: var(--spacing-md);
	padding: var(--spacing-sm) 0;
	border-bottom: 1px solid var(--color-border);
}

.active-filters-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 10px;
}

.active-filters-title {
	font-size: 0.9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
}

.clear-all-filters {
	font-size: 0.9rem;
	color: var(--color-accent);
	text-decoration: none;
	font-weight: 500;
	transition: color var(--transition-fast);
}

.clear-all-filters:hover {
	color: var(--color-primary);
	text-decoration: underline;
}

.active-filters-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.active-filter-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-full);
	font-size: 0.9rem;
	color: var(--color-text);
}

.active-filter-tag .remove-filter,
.active-filter-tag .remove-filter-link {
	background: none;
	border: none;
	padding: 0;
	width: 16px;
	height: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	color: var(--color-text-light);
	cursor: pointer;
	border-radius: 50%;
	transition: all var(--transition-fast);
	text-decoration: none;
	line-height: 1;
}

.active-filter-tag .remove-filter:hover,
.active-filter-tag .remove-filter-link:hover {
	background: var(--color-accent);
	color: #fff;
}

/* ===========================================
   Filter Links - Pretty URL Navigation
   =========================================== */
a.filter-link.checkbox-label {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 10px;
	cursor: pointer;
	font-size: 0.9rem;
	color: var(--color-text);
	padding: 4px 0;
	text-decoration: none;
	transition: color var(--transition-fast);
}

a.filter-link.checkbox-label:hover {
	color: var(--color-primary);
}

a.filter-link.checkbox-label.active {
	color: var(--color-accent);
	font-weight: 500;
}

/* Custom radio/checkbox indicators for links */
.filter-radio,
.filter-checkbox {
	width: 18px;
	height: 18px;
	border: 2px solid var(--color-border);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all var(--transition-fast);
}

.filter-radio {
	border-radius: 50%;
}

.filter-checkbox {
	border-radius: 4px;
}

.filter-radio.checked,
.filter-checkbox.checked {
	border-color: var(--color-accent);
	background: var(--color-accent);
}

.filter-radio.checked::after {
	content: '';
	width: 8px;
	height: 8px;
	background: #fff;
	border-radius: 50%;
}

.filter-checkbox.checked::after {
	content: '✓';
	color: #fff;
	font-size: 12px;
	font-weight: bold;
}

a.filter-link.checkbox-label:hover .filter-radio,
a.filter-link.checkbox-label:hover .filter-checkbox {
	border-color: var(--color-accent);
}

/* ===========================================
   Color Filter - Visual Swatches
   =========================================== */
.color-filter-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
}

.color-filter-swatch {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	text-decoration: none;
	cursor: pointer;
	transition: transform var(--transition-bounce);
}

.color-filter-swatch:hover {
	transform: translateY(-2px);
}

.color-dot {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: 2px solid var(--color-border);
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	transition:
		border-color var(--transition-fast),
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
}

.color-filter-swatch:hover .color-dot {
	border-color: var(--color-accent);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.color-filter-swatch.active .color-dot {
	border-color: var(--color-primary);
	border-width: 3px;
	box-shadow: 0 2px 8px rgba(86, 66, 51, 0.2);
}

/* Checkmark for selected colors */
.color-check {
	display: none;
	font-size: 14px;
	font-weight: bold;
	color: #fff;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.color-filter-swatch.active .color-check {
	display: block;
	animation: checkBounce 0.3s ease;
}

/* Light colors need dark checkmark */
.color-dot.is-light .color-check {
	color: var(--color-primary);
	text-shadow: none;
}

/* White color special styling */
.color-dot[style*="background-color: #FFFFFF"],
.color-dot[style*="background-color: #ffffff"] {
	border-color: #ddd;
}

.color-filter-swatch.active .color-dot[style*="background-color: #FFFFFF"],
.color-filter-swatch.active .color-dot[style*="background-color: #ffffff"] {
	border-color: var(--color-primary);
}

/* Multicolor gradient */
.color-dot.is-multicolor {
	background: conic-gradient(
		#FF0000 0deg,
		#FF8000 45deg,
		#FFFF00 90deg,
		#00FF00 135deg,
		#00FFFF 180deg,
		#0000FF 225deg,
		#8000FF 270deg,
		#FF00FF 315deg,
		#FF0000 360deg
	) !important;
}

.color-filter-name {
	font-size: 0.7rem;
	color: var(--color-text-light);
	text-align: center;
	line-height: 1.2;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	transition: color var(--transition-fast);
}

.color-filter-swatch:hover .color-filter-name,
.color-filter-swatch.active .color-filter-name {
	color: var(--color-primary);
}

/* Bounce animation for checkmark */
@keyframes checkBounce {
	0% { transform: scale(0); }
	50% { transform: scale(1.3); }
	100% { transform: scale(1); }
}

/* Mobile Toggle */
.mobile-filter-toggle,
.filter-header-mobile {
	display: none;
}

/* ===========================================
   Grid & Card Styles - Luxury Product Cards
   =========================================== */
.listings-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
	margin-bottom: var(--spacing-xl);
	transition: all 0.3s ease;
}

.listings-grid.grid-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 32px;
}

.listings-grid.grid-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
}

.listings-grid.grid-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.listings-grid.grid-5 {
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 20px;
}

.listing-card {
	display: block;
	background: transparent;
	border: none;
	border-radius: 0;
	overflow: visible;
	text-decoration: none;
	transition: transform var(--transition-bounce);
	animation: cardReveal 0.5s ease backwards;
}

/* Staggered card animations */
.listing-card:nth-child(1) { animation-delay: 0.1s; }
.listing-card:nth-child(2) { animation-delay: 0.15s; }
.listing-card:nth-child(3) { animation-delay: 0.2s; }
.listing-card:nth-child(4) { animation-delay: 0.25s; }
.listing-card:nth-child(5) { animation-delay: 0.3s; }
.listing-card:nth-child(6) { animation-delay: 0.35s; }
.listing-card:nth-child(7) { animation-delay: 0.4s; }
.listing-card:nth-child(8) { animation-delay: 0.45s; }

.listing-card:hover {
	transform: translateY(-8px);
}

.listing-image {
	position: relative;
	width: 100%;
	padding-bottom: 133.3333%; /* Force 3:4 aspect ratio */
	height: 0;
	background: linear-gradient(135deg, var(--color-surface) 0%, #f5f5f5 100%);
	overflow: hidden;
	margin-bottom: 14px;
	border-radius: var(--radius-md);
	box-shadow: 0 2px 8px rgba(86, 66, 51, 0.06);
	transition: box-shadow var(--transition-base);
}

.listing-card:hover .listing-image {
	box-shadow:
		0 16px 32px rgba(86, 66, 51, 0.12),
		0 4px 12px rgba(86, 66, 51, 0.08);
}

/* Gradient overlay on hover */
.listing-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(86, 66, 51, 0.25) 0%,
		transparent 40%
	);
	opacity: 0;
	transition: opacity var(--transition-base);
	pointer-events: none;
}

.listing-card:hover .listing-image::after {
	opacity: 1;
}

.listing-image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition:
		transform var(--transition-slow),
		filter var(--transition-base);
}

.listing-card:hover .listing-image img {
	transform: scale(1.08);
	filter: brightness(1.02) saturate(1.05);
}

/* No image placeholder */
.listing-image .no-image {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-border) 100%);
}

.listing-image .no-image::before {
	content: '✦';
	font-size: 2rem;
	color: var(--color-accent);
	opacity: 0.3;
}

/* Favorites badge overlay */
.listing-favorites-badge {
	position: absolute;
	top: 10px;
	right: 10px;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.7rem;
	font-weight: 600;
	color: #e11d48;
	padding: 4px 8px;
	background: rgba(255, 255, 255, 0.95);
	border-radius: var(--radius-full);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	z-index: 2;
	transition: transform var(--transition-bounce), box-shadow var(--transition-base);
}

.listing-favorites-badge svg {
	width: 12px;
	height: 12px;
	color: #e11d48;
}

.listing-card:hover .listing-favorites-badge {
	transform: scale(1.05);
	box-shadow: 0 4px 12px rgba(225, 29, 72, 0.2);
}

.listing-price {
	display: none;
}

.listing-details {
	padding: 0 4px;
	text-align: center;
}

.listing-details h3 {
	font-size: 0.95rem;
	margin: 0 0 6px 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	color: var(--color-text);
	font-family: var(--font-heading);
	font-weight: 500;
	letter-spacing: -0.01em;
	transition: color var(--transition-fast);
}

.listing-card:hover .listing-details h3 {
	color: var(--color-primary);
}

.listing-meta {
	font-size: 0.9rem;
	color: var(--color-text-light);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
}

.listing-meta span {
	display: flex;
	align-items: center;
	gap: 4px;
}

/* Separator dot */
.listing-meta span:not(:last-child)::after {
	content: '·';
	margin-left: 4px;
	color: var(--color-border);
}

.listing-price-display {
	display: block;
	font-weight: 600;
	color: var(--color-primary);
	margin-top: 6px;
	font-size: 1rem;
	font-family: var(--font-heading);
	letter-spacing: -0.02em;
}

/* ===========================================
   Pagination - Elegant Navigation
   =========================================== */
.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6px;
	margin-top: var(--spacing-2xl);
	animation: listingsReveal 0.5s ease 0.5s backwards;
}

.pagination .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: var(--color-text);
	text-decoration: none;
	font-weight: 500;
	font-family: var(--font-heading);
	transition:
		background var(--transition-base),
		border-color var(--transition-fast),
		color var(--transition-fast),
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
}

.pagination .page-numbers:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
	transform: translateY(-2px);
}

.pagination .page-numbers.current {
	background: linear-gradient(135deg, var(--color-primary) 0%, #4a3729 100%);
	color: #ffffff;
	border-color: transparent;
	box-shadow: 0 4px 12px rgba(86, 66, 51, 0.2);
}

.pagination .prev,
.pagination .next {
	width: auto;
	padding: 0 16px;
	gap: 6px;
}

/* ===========================================
   Load More Button - Premium CTA
   =========================================== */
.load-more-container {
	text-align: center;
	margin-top: var(--spacing-2xl);
	padding: var(--spacing-xl) 0;
	animation: listingsReveal 0.5s ease 0.55s backwards;
}

#load-more-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 16px 40px;
	font-size: 0.95rem;
	font-weight: 500;
	font-family: var(--font-heading);
	border: 2px solid var(--color-primary);
	border-radius: var(--radius-md);
	background: transparent;
	color: var(--color-primary);
	position: relative;
	overflow: hidden;
	cursor: pointer;
	transition:
		background var(--transition-base),
		color var(--transition-fast),
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
}

/* Shimmer effect */
#load-more-btn::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(86, 66, 51, 0.1),
		transparent
	);
	transition: left 0.5s ease;
}

#load-more-btn:hover {
	background: var(--color-primary);
	color: #fff;
	transform: translateY(-3px);
	box-shadow:
		0 8px 20px rgba(86, 66, 51, 0.2),
		0 4px 8px rgba(86, 66, 51, 0.1);
}

#load-more-btn:hover::before {
	left: 100%;
}

#load-more-btn:active {
	transform: translateY(-1px);
}

#load-more-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

#load-more-btn i {
	font-size: 0.95rem;
	transition: transform var(--transition-bounce);
}

#load-more-btn:hover i {
	transform: rotate(180deg);
}

.load-more-count {
	margin-top: var(--spacing-md);
	font-size: 0.95rem;
	color: var(--color-text-light);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.load-more-count::before {
	content: '◆';
	font-size: 0.4rem;
	color: var(--color-accent);
}

/* ===========================================
   No Results - Elegant Empty State
   =========================================== */
.no-results {
	text-align: center;
	padding: 3.5rem 2rem;
	background: linear-gradient(
		165deg,
		rgba(212, 163, 115, 0.04) 0%,
		var(--color-surface) 35%,
		var(--color-surface) 65%,
		rgba(212, 163, 115, 0.06) 100%
	);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	position: relative;
	animation: noResultsFadeIn 0.6s ease-out backwards;
	overflow: hidden;
	max-width: 540px;
	margin: var(--spacing-lg) auto;
}

@keyframes noResultsFadeIn {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Subtle decorative border accent */
.no-results::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
	border-radius: 0 0 2px 2px;
}

/* Illustration container */
.no-results-illustration {
	margin-bottom: 1.5rem;
	animation: hangerSwing 3s ease-in-out infinite;
	transform-origin: 50% 0%;
}

@keyframes hangerSwing {
	0%, 100% { transform: rotate(-2deg); }
	50% { transform: rotate(2deg); }
}

.no-results-illustration svg {
	width: 100px;
	height: 100px;
	color: var(--color-accent);
	margin: 0 auto;
	display: block;
}

/* Sparkle animations */
.no-results-illustration .sparkle {
	animation: sparkle 2s ease-in-out infinite;
}

.no-results-illustration .sparkle-1 { animation-delay: 0s; }
.no-results-illustration .sparkle-2 { animation-delay: 0.5s; }
.no-results-illustration .sparkle-3 { animation-delay: 1s; }
.no-results-illustration .sparkle-4 { animation-delay: 1.5s; }

@keyframes sparkle {
	0%, 100% { opacity: 0.2; transform: scale(1); }
	50% { opacity: 0.6; transform: scale(1.3); }
}

.no-results h3 {
	font-size: 1.4rem;
	font-family: var(--font-heading);
	color: var(--color-text);
	margin: 0 0 0.5rem 0;
	font-weight: 600;
	letter-spacing: -0.01em;
}

.no-results > p {
	color: var(--color-text-light);
	margin: 0 0 1.75rem 0;
	font-size: 0.95rem;
	line-height: 1.5;
	max-width: 320px;
	margin-left: auto;
	margin-right: auto;
}

/* Suggestions section */
.no-results-suggestions {
	background: rgba(86, 66, 51, 0.03);
	border-radius: var(--radius-md);
	padding: 1rem 1.25rem;
	margin-bottom: 1.75rem;
	text-align: left;
	max-width: 340px;
	margin-left: auto;
	margin-right: auto;
}

.no-results-suggestions .suggestion-label {
	display: block;
	font-size: 0.9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	margin-bottom: 0.5rem;
}

.no-results-suggestions ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.no-results-suggestions li {
	position: relative;
	padding-left: 1.25rem;
	font-size: 0.875rem;
	color: var(--color-text);
	margin-bottom: 0.35rem;
	line-height: 1.45;
}

.no-results-suggestions li:last-child {
	margin-bottom: 0;
}

.no-results-suggestions li::before {
	content: '→';
	position: absolute;
	left: 0;
	color: var(--color-accent);
	font-size: 0.9rem;
}

/* CTA Button */
.no-results-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.875rem 1.75rem;
	background: var(--color-primary);
	color: #fff;
	font-size: 0.9rem;
	font-weight: 500;
	border-radius: var(--radius-full);
	text-decoration: none;
	transition: all 0.25s ease;
	box-shadow: 0 2px 8px rgba(86, 66, 51, 0.2);
}

.no-results-cta:hover {
	background: var(--color-secondary);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(86, 66, 51, 0.25);
}

.no-results-cta svg {
	transition: transform 0.25s ease;
}

.no-results-cta:hover svg {
	transform: translateX(3px);
}

/* ===========================================
   Accessibility - Reduced Motion
   =========================================== */
@media (prefers-reduced-motion: reduce) {
	.listings-container,
	.listings-sidebar,
	.page-header,
	.filter-group,
	.listing-card,
	.pagination,
	.load-more-container,
	.no-results,
	.no-results-illustration,
	.no-results-illustration .sparkle {
		animation: none !important;
	}

	#load-more-btn::before {
		display: none;
	}

	.listing-card:hover {
		transform: none;
	}

	.listing-image::after {
		display: none;
	}

	.no-results-cta:hover {
		transform: none;
	}
}

/* ===========================================
   Responsive - Tablet
   =========================================== */
@media (max-width: 992px) {
	.listings-container {
		grid-template-columns: minmax(0, 1fr);
		padding: 0 var(--spacing-md);
		gap: var(--spacing-md);
	}

	.listings-sidebar {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: #ffffff;
		z-index: 2000;
		padding: 0;
		overflow-y: auto;
		animation: slideIn 0.3s ease;
	}

	@keyframes slideIn {
		from {
			transform: translateX(-100%);
		}
		to {
			transform: translateX(0);
		}
	}

	.listings-sidebar.active {
		display: block;
	}

	.mobile-filter-toggle {
		display: inline-flex;
		align-items: center;
		gap: 8px;
		padding: 12px 18px;
		background: #fff;
		border: 1px solid var(--color-border);
		border-radius: var(--radius-md);
		font-size: 0.9rem;
		font-weight: 500;
		color: var(--color-text);
		cursor: pointer;
		transition:
			border-color var(--transition-fast),
			color var(--transition-fast),
			box-shadow var(--transition-base);
	}

	.mobile-filter-toggle:hover {
		border-color: var(--color-accent);
		color: var(--color-accent);
		box-shadow: 0 2px 8px rgba(86, 66, 51, 0.1);
	}

	.mobile-filter-toggle i {
		font-size: 1rem;
	}

	.filter-header-mobile {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: var(--spacing-md) var(--spacing-lg);
		border-bottom: 1px solid var(--color-border);
		background: linear-gradient(135deg, var(--color-surface) 0%, #fff 100%);
		position: sticky;
		top: 0;
		z-index: 10;
	}

	.filter-header-mobile h3 {
		margin: 0;
		font-size: 1.1rem;
		font-family: var(--font-heading);
		display: flex;
		align-items: center;
		gap: 8px;
	}

	.filter-header-mobile h3::before {
		content: '✦';
		font-size: 0.5rem;
		color: var(--color-accent);
	}

	.close-button {
		background: transparent !important;
		border: none !important;
		width: 44px;
		height: 44px;
		display: flex;
		align-items: center;
		justify-content: center;
		font-size: 1.5rem;
		cursor: pointer;
		border-radius: var(--radius-md);
		color: var(--color-text-light);
		transition: all 0.2s ease;
		box-shadow: none !important;
	}

	.close-button:hover {
		background: var(--color-surface) !important;
		color: var(--color-text);
		transform: none !important;
	}

	.listings-sidebar .filter-group {
		padding: var(--spacing-md) var(--spacing-lg);
		border-bottom: 1px solid var(--color-border);
		margin: 0;
		animation: none;
	}

	.listings-grid,
	.listings-grid.grid-2,
	.listings-grid.grid-3,
	.listings-grid.grid-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: var(--spacing-md);
		max-width: 100%;
		overflow: hidden;
	}

	/* Simplified card animations on tablet */
	.listing-card {
		animation-delay: 0s !important;
	}

	/* Simplified hover on tablet */
	.listing-image::after {
		display: none;
	}

	.page-header {
		flex-direction: column;
		gap: var(--spacing-sm);
		padding-bottom: var(--spacing-md);
	}

	.page-header::after {
		width: 40px;
	}

	.header-left .page-title {
		font-size: 1.3rem;
	}

	.header-right {
		width: 100%;
		justify-content: space-between;
	}

	.collection-grid-buttons {
		display: none;
	}

	.sort-dropdown select {
		min-width: 150px;
	}

	/* Pagination */
	.pagination {
		margin-top: var(--spacing-lg);
	}

	.pagination .page-numbers {
		width: 38px;
		height: 38px;
		font-size: 0.9rem;
	}
}

/* ===========================================
   Responsive - Mobile
   =========================================== */
@media (max-width: 768px) {
	.listings-container {
		padding: 0 15px;
	}

	.header-left .page-title {
		font-size: 1.2rem;
	}

	.header-left .page-title::before {
		font-size: 0.5rem;
	}

	.header-left .result-count {
		font-size: 0.9rem;
	}

	.listings-grid {
		gap: 12px;
	}

	.listing-image {
		border-radius: var(--radius-sm);
		margin-bottom: 10px;
	}

	.listing-details h3 {
		font-size: 0.95rem;
	}

	.listing-meta {
		font-size: 0.9rem;
	}

	.listing-price-display {
		font-size: 0.9rem;
	}

	/* Load More */
	.load-more-container {
		margin-top: var(--spacing-lg);
		padding: var(--spacing-md) 0;
	}

	#load-more-btn {
		width: 100%;
		padding: 14px 24px;
	}

	/* No results */
	.no-results {
		padding: 2.5rem 1.5rem;
		margin: var(--spacing-md) auto;
	}

	.no-results-illustration svg {
		width: 80px;
		height: 80px;
	}

	.no-results h3 {
		font-size: 1.25rem;
	}

	.no-results-suggestions {
		padding: 0.875rem 1rem;
	}
}

/* ===========================================
   Responsive - Small Mobile
   =========================================== */
@media (max-width: 480px) {
	.sort-label {
		display: none;
	}

	.sort-dropdown select {
		min-width: auto;
		width: 100%;
		font-size: 0.95rem;
		padding: 10px 32px 10px 12px;
	}

	.mobile-filter-toggle {
		padding: 10px 14px;
		font-size: 0.95rem;
	}

	.header-right {
		gap: var(--spacing-sm);
	}

	/* Page header adjustments */
	.page-header::after {
		width: 30px;
	}

	.header-left .page-title::before {
		display: none;
	}

	.listings-grid {
		gap: 8px;
	}

	.listing-image {
		margin-bottom: 8px;
		border-radius: 4px;
	}

	/* Smaller favorites badge on mobile */
	.listing-favorites-badge {
		top: 6px;
		right: 6px;
		padding: 3px 6px;
		font-size: 0.65rem;
		gap: 3px;
	}

	.listing-favorites-badge svg {
		width: 10px;
		height: 10px;
	}

	.listing-details {
		padding: 0 2px;
	}

	.listing-details h3 {
		font-size: 0.9rem;
		margin-bottom: 2px;
	}

	.listing-meta {
		font-size: 0.7rem;
		gap: 4px;
	}

	/* Simplify meta on small screens */
	.listing-meta span:not(:last-child)::after {
		display: none;
	}

	.listing-price-display {
		font-size: 0.95rem;
		margin-top: 2px;
	}

	.pagination .page-numbers {
		width: 34px;
		height: 34px;
		font-size: 0.9rem;
		border-radius: var(--radius-sm);
	}

	.no-results {
		padding: 2rem 1.25rem;
		border-radius: var(--radius-md);
	}

	.no-results-illustration {
		margin-bottom: 1rem;
	}

	.no-results-illustration svg {
		width: 70px;
		height: 70px;
	}

	.no-results h3 {
		font-size: 1.15rem;
	}

	.no-results > p {
		font-size: 0.875rem;
		margin-bottom: 1.25rem;
	}

	.no-results-suggestions {
		padding: 0.9rem;
	}

	.no-results-suggestions .suggestion-label {
		font-size: 0.7rem;
	}

	.no-results-suggestions li {
		font-size: 0.9rem;
	}

	.no-results-cta {
		padding: 0.9rem 1.5rem;
		font-size: 0.95rem;
		width: 100%;
		justify-content: center;
	}

	/* Load more button */
	#load-more-btn {
		font-size: 0.9rem;
		padding: 12px 20px;
	}
}