/* ========================================
   Filters Section: Genres & Years - RESPONSIVE
   ======================================== */

.section--filters-duo {
	padding: clamp(24px, 4vw, 48px) clamp(16px, 3vw, 32px);
	margin-bottom: clamp(24px, 4vw, 48px);
}

.filters-duo-container {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(clamp(300px, 45vw, 500px), 1fr));
	gap: clamp(12px, 2vw, 24px);
	width: 100%;
}

.filters-duo-column {
	display: flex;
	flex-direction: column;
	gap: clamp(8px, 1.5vw, 16px);
}

.filters-duo-header {
	padding-bottom: clamp(8px, 1.5vw, 16px);
	border-bottom: 2px solid rgba(255, 184, 28, 0.2);
}

.filters-duo-title {
	font-size: clamp(18px, 1.2vw, 32px);
	color: var(--color-text-primary);
	margin: 0;
	font-weight: var(--font-weight-bold);
	display: flex;
	align-items: center;
	gap: clamp(4px, 0.5vw, 8px);
}

.filters-duo-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(clamp(80px, 12vw, 120px), 1fr));
	gap: clamp(4px, 1vw, 12px);
	width: 100%;
}

.filter-badge {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(2px, 0.5vw, 4px);
	padding: clamp(6px, 0.8vw, 10px) clamp(10px, 1.2vw, 14px);
	border-radius: var(--radius-lg);
	border: 1px solid transparent;
	text-decoration: none;
	color: var(--color-text-primary);
	font-weight: var(--font-weight-semibold);
	font-size: clamp(11px, 0.8vw, 13px);
	transition: all 0.3s ease;
	cursor: pointer;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.filter-badge--genre {
	background: linear-gradient(135deg, rgba(246, 201, 78, 0.12), rgba(246, 201, 78, 0.06));
	border-color: rgba(246, 201, 78, 0.25);
	color: #f6c94e;
}

.filter-badge--genre:hover {
	background: linear-gradient(135deg, rgba(246, 201, 78, 0.18), rgba(246, 201, 78, 0.1));
	border-color: rgba(246, 201, 78, 0.4);
	box-shadow: 0 4px 12px rgba(246, 201, 78, 0.15);
	transform: translateY(-1px);
}

.filter-badge--year {
	background: linear-gradient(135deg, rgba(100, 180, 220, 0.12), rgba(100, 180, 220, 0.06));
	border-color: rgba(100, 180, 220, 0.25);
	color: #64b4dc;
	font-family: 'Courier New', monospace;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.5px;
}

.filter-badge--year:hover {
	background: linear-gradient(135deg, rgba(100, 180, 220, 0.18), rgba(100, 180, 220, 0.1));
	border-color: rgba(100, 180, 220, 0.4);
	box-shadow: 0 4px 12px rgba(100, 180, 220, 0.15);
	transform: translateY(-1px);
}

.filter-badge__count {
	display: none;
	align-items: center;
	justify-content: center;
	width: clamp(16px, 2vw, 22px);
	height: clamp(16px, 2vw, 22px);
	border-radius: 50%;
	background: rgba(255, 184, 28, 0.15);
	font-size: clamp(9px, 0.7vw, 11px);
	font-weight: var(--font-weight-bold);
}

.filter-badge--genre:hover .filter-badge__count {
	background: rgba(255, 184, 28, 0.3);
}

.no-items {
	color: var(--color-text-secondary);
	font-style: italic;
	padding: clamp(12px, 2vw, 24px) 0;
	text-align: center;
	grid-column: 1 / -1;
	margin: 0;
	font-size: clamp(12px, 0.9vw, 15px);
}

/* Responsive adjustments for tablets and below */
@media (max-width: 1023px) {
	.filters-duo-container {
		grid-template-columns: 1fr;
	}
	
	.filters-duo-grid {
		grid-template-columns: repeat(auto-fill, minmax(clamp(85px, 15vw, 110px), 1fr));
	}
}

@media (max-width: 767px) {
	.section--filters-duo {
		padding: clamp(16px, 3vw, 32px) clamp(12px, 2vw, 16px);
	}

	.filters-duo-grid {
		grid-template-columns: repeat(auto-fill, minmax(clamp(75px, 18vw, 100px), 1fr));
		gap: clamp(6px, 1vw, 12px);
	}

	.filter-badge {
		padding: clamp(4px, 0.8vw, 8px) clamp(8px, 1vw, 12px);
		font-size: clamp(10px, 0.8vw, 12px);
	}

	.filter-badge__count {
		width: clamp(14px, 2vw, 18px);
		height: clamp(14px, 2vw, 18px);
		font-size: clamp(8px, 0.6vw, 10px);
	}
}

@media (max-width: 479px) {
	.section--filters-duo {
		padding: clamp(12px, 2vw, 24px) clamp(8px, 2vw, 12px);
	}

	.filters-duo-container {
		gap: clamp(12px, 2vw, 16px);
	}

	.filters-duo-grid {
		grid-template-columns: repeat(auto-fill, minmax(clamp(65px, 20vw, 85px), 1fr));
		gap: clamp(4px, 1vw, 8px);
	}

	.filter-badge {
		padding: clamp(3px, 0.6vw, 6px) clamp(6px, 1vw, 8px);
		font-size: clamp(9px, 0.75vw, 11px);
		gap: clamp(2px, 0.3vw, 3px);
	}

	.filter-badge__count {
		width: clamp(12px, 1.5vw, 16px);
		height: clamp(12px, 1.5vw, 16px);
		font-size: clamp(7px, 0.5vw, 9px);
	}
}
