/**
 * My Audiobook — Catalogue Layout Styles
 *
 * CSS for the catalogue-grid.php pattern (hbd-* classes).
 *
 * @package hoerbuchdaily
 * @version 1.0.0
 */

/* ─── Mini search bar ─── */
.hbd-mini-search {
	background: var(--wp--preset--color--surface, #1A1A2E);
	border-bottom: 1px solid var(--wp--preset--color--border, #2D2D4A);
	padding: 1rem clamp(1.5rem, 5vw, 3rem);
}

.hbd-mini-search__inner {
	display: flex;
	align-items: center;
	gap: 1rem;
	max-width: 700px;
	margin: 0 auto;
}

.hbd-mini-search__input {
	flex: 1;
	background: var(--wp--preset--color--background, #0F0F1A);
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 6px;
	color: var(--wp--preset--color--foreground, #E8E8F0);
	font-size: 0.9375rem;
	padding: 0.625rem 1rem;
	outline: none;
	transition: border-color 0.2s;
}

.hbd-mini-search__input:focus {
	border-color: var(--wp--preset--color--primary, #7C3AED);
}

.hbd-mini-search__input::placeholder {
	color: var(--wp--preset--color--foreground-light, #9CA3B0);
}

.hbd-mini-search__count {
	font-size: 0.8125rem;
	color: var(--wp--preset--color--accent, #D4A64B);
	white-space: nowrap;
	min-width: 80px;
	text-align: right;
}

/* ─── Catalogue layout (sidebar + grid) ─── */
.hbd-catalogue {
	display: flex;
	gap: 2rem;
	align-items: flex-start;
	padding: 2rem clamp(1.5rem, 5vw, 3rem);
	max-width: var(--wp--style--global--wide-size, 1400px);
	margin: 0 auto;
}

/* Mobile filter toggle */
.hbd-catalogue__filter-toggle {
	display: none;
	width: 100%;
	background: var(--wp--preset--color--surface, #1A1A2E);
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 6px;
	color: var(--wp--preset--color--foreground, #E8E8F0);
	cursor: pointer;
	font-size: 0.9375rem;
	font-weight: 600;
	padding: 0.75rem 1rem;
	text-align: left;
	margin-bottom: 1.5rem;
}

/* ─── Filter sidebar ─── */
.hbd-catalogue__filters {
	flex: 0 0 240px;
	position: sticky;
	top: 2rem;
	max-height: calc(100vh - 4rem);
	overflow-y: auto;
	scrollbar-width: thin;
}

.hbd-catalogue__filters-inner {
	background: var(--wp--preset--color--surface, #1A1A2E);
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 8px;
	padding: 1.25rem;
}

.hbd-filter-group {
	margin-bottom: 1.5rem;
}

.hbd-filter-group:last-child {
	margin-bottom: 0;
}

.hbd-filter-group__label {
	display: block;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent, #D4A64B);
	margin-bottom: 0.75rem;
}

.hbd-filter-group select {
	width: 100%;
	background: var(--wp--preset--color--background, #0F0F1A);
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 4px;
	color: var(--wp--preset--color--foreground, #E8E8F0);
	font-size: 0.875rem;
	padding: 0.5rem 0.75rem;
	cursor: pointer;
}

.hbd-filter-group input[type="text"] {
	width: 100%;
	background: var(--wp--preset--color--background, #0F0F1A);
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 4px;
	color: var(--wp--preset--color--foreground, #E8E8F0);
	font-size: 0.875rem;
	padding: 0.5rem 0.75rem;
	box-sizing: border-box;
	outline: none;
}

.hbd-filter-group input[type="text"]:focus {
	border-color: var(--wp--preset--color--primary, #7C3AED);
}

.hbd-filter-options {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	max-height: 200px;
	overflow-y: auto;
	scrollbar-width: thin;
}

.hbd-filter-option {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--wp--preset--color--foreground, #E8E8F0);
	cursor: pointer;
	padding: 0.25rem 0;
	line-height: 1.4;
}

.hbd-filter-option input {
	flex-shrink: 0;
	margin-top: 0.15em;
	accent-color: var(--wp--preset--color--primary, #7C3AED);
	cursor: pointer;
}

.hbd-filter-option__desc {
	display: block;
	font-size: 0.6875rem;
	color: var(--wp--preset--color--foreground-light, #9CA3B0);
	margin-top: 0.125rem;
}

.hbd-filter-clear {
	width: 100%;
	background: transparent;
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 4px;
	color: var(--wp--preset--color--foreground-light, #9CA3B0);
	cursor: pointer;
	font-size: 0.8125rem;
	padding: 0.5rem 0.75rem;
	text-align: center;
	transition: border-color 0.2s, color 0.2s;
	margin-top: 0.5rem;
}

.hbd-filter-clear:hover {
	border-color: var(--wp--preset--color--primary, #7C3AED);
	color: var(--wp--preset--color--foreground, #E8E8F0);
}

.hbd-filter-close {
	display: none;
	width: 100%;
	background: var(--wp--preset--color--primary, #7C3AED);
	border: none;
	border-radius: 6px;
	color: #fff;
	cursor: pointer;
	font-size: 0.9375rem;
	font-weight: 600;
	padding: 0.75rem 1rem;
	margin-top: 1rem;
	text-align: center;
}

/* ─── Grid content area ─── */
.hbd-catalogue__content {
	flex: 1;
	min-width: 0;
}

.hbd-catalogue__results-info {
	font-size: 0.8125rem;
	color: var(--wp--preset--color--foreground-light, #9CA3B0);
	margin-bottom: 1.25rem;
	min-height: 1.2em;
}

.hbd-catalogue__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 1.5rem;
}

.hbd-catalogue__pagination {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 2.5rem;
}

.hbd-catalogue__audible-cta {
	margin-top: 2.5rem;
	padding: 1rem 1.5rem;
	background: var(--wp--preset--color--surface, #1A1A2E);
	border: 1px solid var(--wp--preset--color--border, #2D2D4A);
	border-radius: 8px;
	text-align: center;
}

.hbd-catalogue__audible-cta a {
	color: var(--wp--preset--color--primary, #7C3AED);
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
}

.hbd-catalogue__audible-cta a:hover {
	text-decoration: underline;
}

/* ─── Mobile: overlay filter panel ─── */
@media (max-width: 768px) {
	.hbd-catalogue {
		flex-direction: column;
		padding: 1.5rem 1rem;
	}

	.hbd-catalogue__filter-toggle {
		display: block;
	}

	.hbd-catalogue__filters {
		position: fixed;
		top: 0;
		left: 0;
		width: 85vw;
		max-width: 320px;
		height: 100%;
		max-height: 100%;
		overflow-y: auto;
		background: var(--wp--preset--color--background, #0F0F1A);
		border-right: 1px solid var(--wp--preset--color--border, #2D2D4A);
		z-index: 9999;
		padding: 1.5rem 1.25rem;
		box-sizing: border-box;
		transform: translateX(-110%);
		transition: transform 0.3s ease;
	}

	.hbd-catalogue__filters.is-open {
		transform: translateX(0);
	}

	.hbd-catalogue__filters-inner {
		background: transparent;
		border: none;
		padding: 0;
	}

	.hbd-filter-close {
		display: block;
	}

	.hbd-catalogue__grid {
		grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
		gap: 1rem;
	}
}
