/* =========================================================
   POKÉBOARD — ARCHIVE JSON CARTES
   Fichier : pb-json-archive.css
========================================================= */

/* =========================================================
   01. SCOPE / VARIABLES LOCALES
========================================================= */

.pb-json-archive {
	--pb-primary: var(--pkb-primary, var(--idd-color-primary, #fe0201));
	--pb-primary-hover: var(--pkb-primary-hover, var(--idd-color-primary-hover, #d40000));
	--pb-primary-soft: var(--pkb-primary-soft, #fff7f7);
	--pb-primary-border: var(--pkb-primary-border, rgba(254,2,1,.15));
	--pb-primary-ring: var(--pkb-primary-ring, rgba(254,2,1,.10));

	--pb-blue: var(--pkb-blue, #2a75bb);
	--pb-yellow: var(--pkb-yellow, #ffcb05);
	--pb-green: var(--pkb-green, #22c55e);
	--pb-orange: var(--pkb-orange, #f97316);

	--pb-bg: var(--pkb-bg, var(--idd-color-bg-alt, #f6f8fb));
	--pb-bg-soft: var(--pkb-bg-soft, var(--idd-color-bg-alt, #f7f9fc));
	--pb-surface: var(--pkb-surface, #ffffff);
	--pb-surface-soft: var(--pkb-surface-soft, var(--idd-color-bg-alt, #f3f4f6));
	--pb-surface-muted: var(--pkb-surface-muted, var(--idd-color-bg-alt, #f8fafc));
	--pb-surface-glass: var(--pkb-surface-glass, var(--idd-surface-glass-strong, rgba(255,255,255,.88)));
	--pb-surface-glass-strong: var(--pkb-surface-glass-strong, var(--idd-surface-glass-strong, rgba(255,255,255,.96)));

	--pb-text: var(--pkb-text, var(--idd-color-text, #111827));
	--pb-ink: var(--pkb-ink, var(--idd-color-bg-dark, #0f172a));
	--pb-muted: var(--pkb-muted, var(--idd-color-text-muted, #64748b));
	--pb-text-soft: var(--pkb-text-soft, var(--idd-color-text-muted, #475569));
	--pb-text-light: var(--pkb-text-light, var(--idd-color-text-muted, #94a3b8));
	--pb-text-invert: var(--pkb-text-invert, #ffffff);

	--pb-border: var(--pkb-border, rgba(15,23,42,.10));
	--pb-border-soft: var(--pkb-border-soft, rgba(15,23,42,.07));
	--pb-border-strong: var(--pkb-border-strong, rgba(15,23,42,.16));

	--pb-shadow-xs: var(--pkb-shadow-xs, 0 4px 12px rgba(15,23,42,.04));
	--pb-shadow-sm: var(--pkb-shadow-sm, 0 10px 24px rgba(15,23,42,.06));
	--pb-shadow-md: var(--pkb-shadow-md, 0 16px 42px rgba(15,23,42,.10));
	--pb-shadow-lg: var(--pkb-shadow-lg, 0 28px 70px rgba(15,23,42,.14));

	--pb-radius-sm: var(--pkb-radius-sm, 14px);
	--pb-radius: var(--pkb-radius-md, 18px);
	--pb-radius-lg: var(--pkb-radius-lg, 24px);
	--pb-radius-xl: var(--pkb-radius-xl, 28px);
	--pb-radius-2xl: var(--pkb-radius-2xl, 34px);
	--pb-radius-pill: var(--pkb-radius-pill, 999px);

	--pb-container-padding: var(--pkb-container-padding, 14px);
	--pb-gap: var(--pkb-gap, 18px);

	--pb-input-height: var(--pkb-input-height, 48px);
	--pb-btn-height: var(--pkb-btn-height, 46px);

	--pb-transition-fast: var(--pkb-transition-fast, .15s ease);
	--pb-transition: var(--pkb-transition, .22s ease);

	--pb-z-sticky: var(--pkb-z-sticky, 50);
	--pb-z-header: var(--pkb-z-header, 100);
	--pb-z-overlay: var(--pkb-z-overlay, 900);
	--pb-z-modal: var(--pkb-z-modal, 1000);

	position: relative;
}

/* =========================================================
   02. SEARCH STICKY
========================================================= */

.pb-json-search-shell {
	position: sticky;
	top: var(--pb-dynamic-sticky-top, var(--pkb-header-height, 78px));
	z-index: calc(var(--pb-z-header) + 10);
	margin: 0 0 24px;
	padding: 8px 0 14px;
	isolation: isolate;
}

.pb-json-search-card {
	background: var(--pb-surface-glass);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border: 1px solid var(--pb-border);
	border-radius: var(--pb-radius-xl);
	box-shadow: var(--pb-shadow-md);
	padding: 12px;
}

.pb-json-search-form {
	display: grid;
	gap: 12px;
}

.pb-json-search-main {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto auto;
	gap: 10px;
	align-items: center;
}

.pb-json-search-input-wrap {
	min-width: 0;
}

/* =========================================================
   03. INPUTS / SELECTS
========================================================= */

.pb-json-search-form input,
.pb-json-search-form select {
	width: 100%;
	min-height: var(--pb-input-height);
	border: 1px solid var(--pb-border-strong);
	border-radius: var(--pb-radius-sm);
	background: var(--pb-surface);
	color: var(--pb-text);
	padding: 0 14px;
	font-weight: 850;
	outline: none;
	box-shadow: none;
	transition:
		border-color var(--pb-transition-fast),
		box-shadow var(--pb-transition-fast),
		background var(--pb-transition-fast);
}

.pb-json-search-form input:focus,
.pb-json-search-form select:focus {
	border-color: var(--pb-primary-border);
	box-shadow: 0 0 0 4px var(--pb-primary-ring);
}

/* =========================================================
   04. BUTTONS
========================================================= */

.pb-json-submit,
.pb-json-filter-toggle,
.pb-json-filter-actions button,
.pb-json-filter-actions a,
.pb-json-mobile-filter-btn {
	min-height: var(--pb-input-height);
	border-radius: var(--pb-radius-sm);
	border: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 17px;
	font-weight: 950;
	text-decoration: none;
	cursor: pointer;
	white-space: nowrap;
	transition:
		background var(--pb-transition-fast),
		color var(--pb-transition-fast),
		border-color var(--pb-transition-fast),
		transform var(--pb-transition-fast),
		box-shadow var(--pb-transition-fast),
		opacity var(--pb-transition-fast);
}

.pb-json-submit,
.pb-json-filter-actions button,
.pb-json-mobile-filter-btn {
	background: var(--pb-primary);
	color: var(--pb-text-invert);
}

.pb-json-submit:hover,
.pb-json-filter-actions button:hover,
.pb-json-mobile-filter-btn:hover {
	background: var(--pb-primary-hover);
	color: var(--pb-text-invert);
	transform: translateY(-1px);
}

.pb-json-filter-toggle,
.pb-json-filter-actions a {
	background: var(--pb-surface-soft);
	color: var(--pb-text);
	border: 1px solid var(--pb-border);
}

.pb-json-filter-toggle:hover,
.pb-json-filter-actions a:hover {
	border-color: var(--pb-primary-border);
	color: var(--pb-primary);
}

.pb-json-filter-toggle.is-open {
	background: var(--pb-primary-soft);
	color: var(--pb-primary);
	border-color: var(--pb-primary-border);
}

.pb-json-filter-toggle strong {
	width: 22px;
	height: 22px;
	border-radius: var(--pb-radius-pill);
	background: var(--pb-surface);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

/* =========================================================
   05. FILTERS
========================================================= */

.pb-json-filters[hidden] {
	display: none !important;
}

.pb-json-filters {
	animation: pbJsonFiltersDown .18s ease-out;
}

@keyframes pbJsonFiltersDown {
	from {
		opacity: 0;
		transform: translateY(-6px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.pb-json-filters-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 10px;
}

.pb-json-filter-actions {
	display: flex;
	justify-content: flex-end;
	gap: 10px;
	margin-top: 12px;
}

.pb-json-mobile-bar,
.pb-json-mobile-overlay {
	display: none;
}

/* =========================================================
   06. ACTIVE FILTERS
========================================================= */

.pb-active-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	margin: -6px 0 24px;
	padding: 2px 2px 0;
}

.pb-active-filter {
	position: relative;
	overflow: hidden;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-height: 42px;
	padding: 0 14px 0 15px;
	border-radius: var(--pb-radius-pill);
	border: 1px solid var(--pb-primary-border);
	background: linear-gradient(180deg, var(--pb-surface-glass-strong), var(--pb-surface-muted));
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow:
		var(--pb-shadow-sm),
		inset 0 1px 0 var(--idd-surface-glass-strong, rgba(255,255,255,.85));
	color: var(--pb-text);
	font-size: 13px;
	font-weight: 850;
	letter-spacing: -.01em;
	cursor: pointer;
	transition:
		transform var(--pb-transition-fast),
		box-shadow var(--pb-transition-fast),
		border-color var(--pb-transition-fast),
		background var(--pb-transition-fast);
}

.pb-active-filter::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top left, rgba(254,2,1,.10), transparent 46%);
	opacity: .9;
	pointer-events: none;
}

.pb-active-filter:hover {
	transform: translateY(-1px);
	border-color: var(--pb-primary-border);
	box-shadow:
		var(--pb-shadow-md),
		inset 0 1px 0 var(--idd-surface-glass-strong, rgba(255,255,255,.9));
}

.pb-active-filter:active {
	transform: scale(.985);
}

.pb-active-filter span,
.pb-active-filter strong,
.pb-active-filter em {
	position: relative;
	z-index: 1;
}

.pb-active-filter span {
	color: var(--pb-muted);
	font-weight: 800;
}

.pb-active-filter strong {
	color: var(--pb-text);
	font-weight: 950;
	max-width: 180px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.pb-active-filter em {
	flex: 0 0 auto;
	width: 22px;
	height: 22px;
	border-radius: var(--pb-radius-pill);
	background: linear-gradient(180deg, rgba(254,2,1,.14), rgba(254,2,1,.15));
	color: var(--pb-primary-hover);
	font-style: normal;
	font-size: 13px;
	font-weight: 950;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: inset 0 1px 0 var(--idd-surface-glass-strong, rgba(255,255,255,.55));
	transition:
		background var(--pb-transition-fast),
		transform var(--pb-transition-fast);
}

.pb-active-filter:hover em {
	background: linear-gradient(180deg, rgba(254,2,1,.15), rgba(254,2,1,.18));
	transform: rotate(90deg);
}

/* =========================================================
   07. RESULTS HEAD
========================================================= */

.pb-results-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px;
	margin: 0 0 18px;
}

.pb-results-title-wrap h2 {
	margin: 0;
	font-size: clamp(22px, 2vw, 32px);
	font-weight: 950;
	color: var(--pb-text);
}

.pb-results-context {
	margin-top: 4px;
	color: var(--pb-muted);
	font-weight: 750;
}

.pb-results-count {
	min-height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--pb-radius-pill);
	padding: 0 14px;
	background: var(--pb-text);
	color: var(--pb-text-invert);
	font-weight: 950;
	white-space: nowrap;
}

/* =========================================================
   08. RESULTS / LOADER / EMPTY
========================================================= */

.pb-cards-grid.is-refreshing {
	opacity: .42;
	pointer-events: none;
	transition: opacity var(--pb-transition-fast);
}

.pb-json-loader {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	min-height: 70px;
	margin: 24px 0;
	font-weight: 950;
	color: var(--pb-muted);
}

.pb-json-loader span {
	width: 18px;
	height: 18px;
	border-radius: var(--pb-radius-pill);
	border: 3px solid rgba(100,116,139,.22);
	border-top-color: currentColor;
	animation: pbJsonSpin .8s linear infinite;
}

@keyframes pbJsonSpin {
	to {
		transform: rotate(360deg);
	}
}

.pb-json-loader[hidden],
.pb-json-empty[hidden],
.pb-infinite-end[hidden] {
	display: none !important;
}

.pb-json-empty {
	padding: 34px;
	border-radius: var(--pb-radius-xl);
	background: var(--pb-surface);
	border: 1px solid var(--pb-border);
	text-align: center;
	box-shadow: var(--pb-shadow-sm);
}

.pb-json-empty h3 {
	margin: 0 0 8px;
	font-size: 24px;
	font-weight: 950;
	color: var(--pb-text);
}

.pb-json-empty p {
	margin: 0;
	color: var(--pb-muted);
	font-weight: 750;
}

.pb-infinite-end {
	margin: 28px 0;
	text-align: center;
	color: var(--pb-muted);
	font-weight: 900;
}

.pb-infinite-sentinel {
	height: 90px;
}

/* =========================================================
   09. BANNIÈRE SET / CHAPITRE
========================================================= */

.pb-set-chapter {
	grid-column: 1 / -1;
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(280px, .9fr);
	gap: 18px;
	align-items: center;
	margin: 18px 0 10px;
	padding: 18px;
	border-radius: var(--pb-radius-xl);
	background:
		radial-gradient(circle at 0 0, rgba(254,2,1,.18), transparent 34%),
		linear-gradient(135deg, var(--pb-surface) 0%, var(--pb-surface-muted) 100%);
	border: 1px solid var(--pb-border);
	box-shadow: var(--pb-shadow-md);
}

.pb-set-chapter::before {
	content: "";
	position: absolute;
	inset: auto -80px -120px auto;
	width: 260px;
	height: 260px;
	border-radius: var(--pb-radius-pill);
	background: rgba(254,2,1,.08);
	pointer-events: none;
}

.pb-set-chapter-left {
	position: relative;
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
}

.pb-set-chapter-icon {
	width: 58px;
	height: 58px;
	border-radius: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--pb-text);
	color: var(--pb-text-invert);
	font-size: 24px;
	font-weight: 950;
	box-shadow: var(--pb-shadow-md);
	flex: 0 0 auto;
}

.pb-set-chapter-title-zone {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

/* Petit kicker au-dessus du nom du set : indique clairement
   que ce qui suit est un Set / Extension (et non une Série). */
.pb-set-chapter-kicker {
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	gap: 6px;
	padding: 4px 10px;
	background: linear-gradient(135deg, rgba(254,2,1,.10), rgba(240,165,0,.08));
	border: 1px solid rgba(254,2,1,.18);
	color: var(--pkb-primary, var(--idd-color-primary, #fe0201));
	border-radius: var(--pb-radius-pill);
	font-size: 10.5px;
	font-weight: 900;
	letter-spacing: .08em;
	text-transform: uppercase;
	line-height: 1;
}

.pb-set-chapter-title-zone strong {
	display: block;
	font-size: clamp(20px, 2vw, 30px);
	line-height: 1.05;
	font-weight: 950;
	color: var(--pb-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.pb-set-chapter-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 8px;
	align-items: center;
}

.pb-set-chapter-meta small {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 0 10px;
	border-radius: var(--pb-radius-pill);
	background: var(--pb-surface);
	border: 1px solid var(--pb-border-soft);
	color: var(--pb-muted);
	font-size: 12px;
	font-weight: 900;
}

/* Badge "Série" enrichi : label + valeur, pour bien distinguer le SET
   (titre principal) de la SÉRIE (regroupement parent). */
.pb-set-chapter-series-badge {
	gap: 0;
	padding: 0;
	overflow: hidden;
	border: 1px solid var(--pb-border-soft);
	background: var(--pb-surface);
}
.pb-set-chapter-series-badge__label {
	display: inline-flex;
	align-items: center;
	height: 28px;
	padding: 0 10px;
	background: rgba(15,23,42,.06);
	color: var(--pb-text);
	font-size: 11px;
	font-weight: 900;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.pb-set-chapter-series-badge__value {
	display: inline-flex;
	align-items: center;
	height: 28px;
	padding: 0 12px;
	color: var(--pb-text);
	font-size: 12.5px;
	font-weight: 800;
}

.pb-set-chapter-stats {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.pb-set-stat {
	padding: 12px;
	border-radius: 20px;
	background: var(--pb-surface-glass);
	border: 1px solid var(--pb-border-soft);
	box-shadow: var(--pb-shadow-xs);
}

.pb-set-stat span {
	display: block;
	color: var(--pb-muted);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.2;
}

.pb-set-stat strong {
	display: block;
	margin-top: 5px;
	color: var(--pb-text);
	font-size: 18px;
	font-weight: 950;
	line-height: 1.1;
}

.pb-set-stat em {
	display: inline-flex;
	margin-top: 7px;
	min-height: 24px;
	align-items: center;
	padding: 0 9px;
	border-radius: var(--pb-radius-pill);
	font-style: normal;
	font-size: 12px;
	font-weight: 950;
	background: var(--pb-surface-soft);
	color: var(--pb-text);
}

.pb-set-stat.is-filtered em {
	background: rgba(59,130,246,.12);
	color: var(--idd-color-info, #2563eb);
}

.pb-set-stat.is-imported em {
	background: rgba(16,185,129,.13);
	color: #059669;
}

.pb-set-stat.is-owned em {
	background: rgba(254,2,1,.12);
	color: var(--pb-primary-hover);
}

.pb-set-chapter-bars {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	position: relative;
}

.pb-set-chapter-bars > div {
	display: grid;
	gap: 6px;
}

.pb-set-chapter-bars span {
	font-size: 12px;
	font-weight: 950;
	color: var(--pb-muted);
}

.pb-set-chapter-bars i {
	display: block;
	overflow: hidden;
	height: 10px;
	border-radius: var(--pb-radius-pill);
	background: rgba(15,23,42,.08);
}

.pb-set-chapter-bars b {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, var(--pb-primary), var(--pb-orange));
	min-width: 4px;
}

/* =========================================================
   10. BANNIÈRE SET COMPACTE
========================================================= */

.pb-set-banner {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 18px;
	border-radius: 30px;
	overflow: hidden;
}

.pb-set-banner-top {
	display: flex;
	align-items: center;
	gap: 14px;
	min-height: 88px;
}

.pb-set-banner-icon {
	width: 140px;
	height: 88px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.pb-set-banner-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	display: block;
	filter: drop-shadow(0 8px 14px rgba(0,0,0,.12));
}

.pb-set-banner-head {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 10px;
}

.pb-set-banner-title {
	font-size: clamp(26px, 5vw, 38px);
	font-weight: 900;
	line-height: 1;
	margin: 0;
	color: var(--pb-text);
}

.pb-set-banner-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.pb-set-banner-meta span {
	min-height: 38px;
	display: inline-flex;
	align-items: center;
	padding: 0 14px;
	border-radius: var(--pb-radius-pill);
	background: var(--pb-surface-glass);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: var(--pb-text);
	font-size: 14px;
	font-weight: 700;
}

.pb-set-banner-kpis {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}

/* =========================================================
   11. RESPONSIVE DESKTOP / TABLETTE
========================================================= */

@media (max-width: 1280px) {
	.pb-json-filters-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

@media (max-width: 980px) {
	.pb-set-chapter {
		grid-template-columns: 1fr;
	}

	.pb-set-chapter-title-zone strong {
		white-space: normal;
	}
}

@media (max-width: 900px) {
	.pb-json-filters-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.pb-results-head {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* =========================================================
   12. MOBILE CATALOGUE
========================================================= */

@media (max-width: 760px) {
	.pb-json-archive {
		margin-top: 0;
		padding-top: 0;
	}

	.pb-json-archive .pb-page-head,
	.pb-json-archive .pb-results-title-wrap {
		display: none !important;
		height: 0 !important;
		min-height: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		overflow: hidden !important;
	}

	.pb-json-archive .pb-global-wrap {
		width: 100% !important;
		max-width: none !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		padding-top: 0 !important;
		padding-left: var(--pb-container-padding) !important;
		padding-right: var(--pb-container-padding) !important;
		box-sizing: border-box !important;
	}

	.pb-json-search-shell {
		position: sticky;
		top: var(--pb-dynamic-sticky-top, 0px);
		z-index: calc(var(--pb-z-header) + 20);
		margin: 0 calc(50% - 50vw) 14px;
		padding: 0;
		background: var(--pb-surface);
		border-bottom: 1px solid var(--pb-border-soft);
		box-shadow: var(--pb-shadow-sm);
	}

	.pb-json-search-card {
		border: 0 !important;
		border-radius: 0 !important;
		box-shadow: none !important;
		background: var(--pb-surface) !important;
		backdrop-filter: none !important;
		-webkit-backdrop-filter: none !important;
		padding: 0 !important;
	}

	.pb-json-search-form {
		gap: 0;
	}

	.pb-json-search-form.is-desktop-form .pb-json-filters,
	.pb-json-search-form.is-desktop-form .pb-json-submit {
		display: none !important;
	}

	.pb-json-search-main {
		display: grid;
		grid-template-columns: minmax(0, 1fr) 48px !important;
		gap: 8px !important;
		padding: 8px 10px !important;
		align-items: center;
		background: var(--pb-surface);
	}

	.pb-json-search-input-wrap {
		position: relative;
		min-width: 0;
	}

	.pb-json-search-input-wrap input[type="search"] {
		min-height: 52px !important;
		border: 0 !important;
		border-radius: 16px !important;
		box-shadow: none !important;
		background: #f5f5f5 !important;
		padding: 0 16px !important;
		font-size: 15px;
		font-weight: 850;
	}

	.pb-json-search-input-wrap input[type="search"]:focus {
		border: 0 !important;
		box-shadow: none !important;
	}

	.pb-json-search-form.is-desktop-form .pb-json-filter-toggle {
		display: inline-flex !important;
		width: 48px !important;
		height: 48px !important;
		min-height: 48px !important;
		padding: 0 !important;
		border-radius: 16px !important;
		background: var(--pb-primary) !important;
		color: var(--pb-text-invert) !important;
		border: 0 !important;
		box-shadow: 0 10px 24px rgba(254,2,1,.15);
	}

	.pb-json-search-form.is-desktop-form .pb-json-filter-toggle span {
		display: none !important;
	}

	.pb-json-search-form.is-desktop-form .pb-json-filter-toggle strong {
		width: auto !important;
		height: auto !important;
		background: transparent !important;
		color: inherit !important;
		font-size: 0 !important;
	}

	.pb-json-search-form.is-desktop-form .pb-json-filter-toggle strong::before {
		content: "☰";
		font-size: 22px;
		line-height: 1;
	}

	.pb-json-mobile-bar {
		display: none !important;
	}

	.pb-results-head {
		display: flex !important;
		justify-content: flex-end;
		align-items: center;
		margin: 0 0 12px !important;
		padding: 0 2px;
	}

	.pb-results-count {
		min-height: auto;
		padding: 0;
		background: transparent !important;
		color: var(--pb-text-light) !important;
		border-radius: 0;
		font-size: 12px;
		font-weight: 800;
		box-shadow: none;
	}

	.pb-json-results-section {
		width: 100% !important;
		max-width: none !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.pb-cards-grid {
		display: grid !important;
		width: 100% !important;
		max-width: none !important;
		margin: 0 !important;
		padding: 0 !important;
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 12px 8px !important;
		align-items: stretch;
	}

	.pb-card-result-wrap {
		min-width: 0 !important;
		width: 100% !important;
		max-width: none !important;
	}

	.pb-card-result-wrap > * {
		width: 100%;
		max-width: 100%;
	}

	.pb-set-chapter,
	.pb-json-empty,
	.pb-infinite-end,
	.pb-json-loader {
		grid-column: 1 / -1 !important;
	}

	.pb-active-filters,
	.pb-results-head {
		width: 100% !important;
		max-width: none !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
}

/* =========================================================
   13. MOBILE OVERLAY FILTRES
========================================================= */

@media (max-width: 760px) {
	.pb-json-mobile-overlay {
		position: fixed;
		inset: 0;
		z-index: 2147483647;
		display: none;
		padding: 0 !important;
		background: var(--pb-surface) !important;
		backdrop-filter: none !important;
		-webkit-backdrop-filter: none !important;
		align-items: stretch !important;
		justify-content: stretch !important;
	}

	.pb-json-mobile-overlay.is-open {
		display: block !important;
	}

	html.pb-json-filters-open,
	body.pb-json-filters-open {
		overflow: hidden !important;
		touch-action: none !important;
	}

	.pb-json-mobile-panel {
		width: 100% !important;
		height: 100dvh !important;
		max-height: none !important;
		border-radius: 0 !important;
		padding: 16px !important;
		background: var(--pb-surface);
		box-shadow: none !important;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
		animation: pbJsonPanelUp .2s ease-out;
	}

	@keyframes pbJsonPanelUp {
		from {
			opacity: 0;
			transform: translateY(24px);
		}

		to {
			opacity: 1;
			transform: translateY(0);
		}
	}

	.pb-json-mobile-head {
		position: sticky;
		top: 0;
		z-index: 5;
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: 12px;
		background: var(--pb-surface);
		margin: -16px -16px 16px;
		padding: 14px 16px;
		border-bottom: 1px solid var(--pb-border-soft);
	}

	.pb-json-mobile-head strong {
		font-size: 21px;
		font-weight: 950;
		color: var(--pb-text);
	}

	.pb-json-mobile-head button {
		width: 52px;
		height: 52px;
		padding: 0;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		border: 1px solid var(--pb-primary-border);
		border-radius: var(--pb-radius);
		background: linear-gradient(180deg, var(--pb-surface), var(--pb-surface-muted));
		box-shadow:
			var(--pb-shadow-sm),
			inset 0 1px 0 var(--idd-surface-glass-strong, rgba(255,255,255,.95));
		color: var(--pb-primary);
		font-size: 20px;
		font-weight: 1000;
		line-height: 1;
		cursor: pointer;
		transition:
			transform var(--pb-transition-fast),
			box-shadow var(--pb-transition-fast),
			background var(--pb-transition-fast),
			border-color var(--pb-transition-fast);
	}

	.pb-json-mobile-head button:hover,
	.pb-json-mobile-head button:active {
		transform: scale(.96);
		border-color: var(--pb-primary-border);
		background: linear-gradient(180deg, var(--pb-primary-soft), #ffecec);
		box-shadow:
			0 14px 32px rgba(254,2,1,.12),
			inset 0 1px 0 var(--idd-surface-glass-strong, rgba(255,255,255,.95));
	}

	.pb-json-mobile-head button span,
	.pb-json-mobile-head button i {
		line-height: 1;
	}

	.pb-json-search-form.is-mobile-form .pb-json-search-main {
		display: none;
	}

	.pb-json-search-form.is-mobile-form .pb-json-filters {
		display: block !important;
	}

	.pb-json-mobile-panel .pb-json-filters-grid,
	.pb-json-filters-grid,
	.pb-json-filter-actions,
	.pb-set-chapter-bars {
		grid-template-columns: 1fr !important;
	}

	.pb-json-mobile-panel .pb-json-filters-grid {
		gap: 10px;
	}

	.pb-json-mobile-panel input,
	.pb-json-mobile-panel select {
		border-radius: 12px;
	}

	.pb-json-filter-actions {
		display: grid;
		position: sticky;
		bottom: 0;
		background: var(--pb-surface);
		padding: 12px 0 0;
	}
}

/* =========================================================
   14. MOBILE SET CHAPTER
========================================================= */

@media (max-width: 760px) {
	.pb-set-chapter {
		width: 100% !important;
		max-width: none !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		box-sizing: border-box !important;
		gap: 14px;
		padding: 14px;
		border-radius: var(--pb-radius-lg);
	}

	.pb-set-chapter-left {
		align-items: flex-start;
	}

	.pb-set-chapter-icon {
		width: 48px;
		height: 48px;
		border-radius: 17px;
		font-size: 20px;
	}

	.pb-set-chapter-stats {
		display: grid !important;
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
		gap: 8px;
	}

	.pb-set-stat {
		min-width: 0;
		padding: 10px 7px;
		border-radius: 16px;
		text-align: center;
	}

	.pb-set-stat span {
		font-size: 10px;
		line-height: 1.1;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.pb-set-stat strong {
		font-size: 16px;
		margin-top: 4px;
	}

	.pb-set-stat em {
		min-height: 20px;
		padding: 0 7px;
		font-size: 10px;
		margin-top: 6px;
	}
}

/* =========================================================
   15. MOBILE ACTIVE FILTERS
========================================================= */

@media (max-width: 768px) {
	.pb-active-filters {
		gap: 8px;
		/* Sur mobile la barre de recherche desktop est masquée ; on ajoute
		   un espace clair entre le header de page et les badges actifs. */
		margin: 16px 0 18px;
		overflow-x: auto;
		flex-wrap: nowrap;
		padding-bottom: 4px;
		scrollbar-width: none;
	}

	.pb-active-filters::-webkit-scrollbar {
		display: none;
	}

	.pb-active-filter {
		min-height: 38px;
		padding: 0 13px;
		font-size: 12px;
		white-space: nowrap;
	}

	.pb-active-filter strong {
		max-width: 130px;
	}
}

/* =========================================================
   16. MOBILE SET BANNER COMPACTE
========================================================= */

@media (max-width: 640px) {
	.pb-set-banner {
		padding: 16px;
		gap: 12px;
	}

	.pb-set-banner-top {
		min-height: auto;
		align-items: center;
	}

	.pb-set-banner-icon {
		width: 110px;
		height: 70px;
	}

	.pb-set-banner-title {
		font-size: 30px;
	}

	.pb-set-banner-meta span {
		font-size: 13px;
		min-height: 34px;
		padding: 0 12px;
	}

	.pb-set-banner-kpis {
		gap: 10px;
	}
}

@media (max-width: 420px) {
	.pb-set-banner-top {
		gap: 10px;
	}

	.pb-set-banner-icon {
		width: 92px;
		height: 58px;
	}

	.pb-set-banner-title {
		font-size: 24px;
	}
}


/* =========================================================
   14. BANNIÈRE MOBILE FIXE (icônes uniquement) + MINI-MODALE RECHERCHE
   Cohérent avec /mes-collections-cartes-pokemon/
========================================================= */

.pb-catalog-mobile-bar {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 999980;
	padding: 8px 8px calc(8px + env(safe-area-inset-bottom, 0px));
	background: var(--pb-surface, #fff);
	border-top: 1px solid rgba(15, 23, 42, .08);
	box-shadow: 0 -4px 16px -8px rgba(15, 23, 42, .15);
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	gap: 6px;
}

.pb-catalog-mobile-bar__btn {
	flex: 1 1 0;
	min-width: 0;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	background: var(--pb-bg-soft, var(--idd-color-bg-alt, #f7f9fc));
	border: 0;
	border-radius: 12px;
	color: var(--pkb-primary, var(--idd-color-primary, #fe0201));
	cursor: pointer;
	transition: background .15s ease, color .15s ease;
	position: relative;
}
.pb-catalog-mobile-bar__btn svg {
	width: 22px; height: 22px;
	stroke: currentColor;
	fill: none;
	flex-shrink: 0;
}
.pb-catalog-mobile-bar__btn:hover { background: rgba(254,2,1, .10); }
.pb-catalog-mobile-bar__btn:active { transform: scale(.96); }

/* Bouton reset : style "alerte douce" pour bien identifier que c'est destructif */
.pb-catalog-mobile-bar__btn[data-pb-catalog-mobile-reset] {
	background: rgba(239, 68, 68, .08);
	color: var(--pkb-danger, var(--idd-color-primary, #ef4444));
}
.pb-catalog-mobile-bar__btn[data-pb-catalog-mobile-reset]:hover {
	background: rgba(239, 68, 68, .16);
}

/* Hidden attribute → display: none même si la classe a un display de surcharge.
   La croix reset n'est visible que quand JS retire hidden (filtre/recherche actif).
   Idem pour le badge compteur de filtres actifs sur l'icône Filtres. */
.pb-catalog-mobile-bar__btn[hidden],
.pb-catalog-mobile-bar__count[hidden] {
	display: none !important;
}

.pb-catalog-mobile-bar__count {
	position: absolute;
	top: 2px; right: 2px;
	min-width: 18px;
	height: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 5px;
	background: var(--pkb-danger, var(--idd-color-primary, #ef4444));
	color: #fff;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 800;
}

/* Mini-modale recherche qui descend depuis le haut */
.pb-catalog-search-modal {
	position: fixed;
	left: 0; right: 0;
	top: 0;
	z-index: 999992;
	padding: 12px 14px calc(12px + env(safe-area-inset-top, 0px));
	background: var(--pb-surface, #fff);
	border-bottom: 1px solid rgba(15, 23, 42, .08);
	box-shadow: 0 8px 24px -16px rgba(15, 23, 42, .25);
	transform: translateY(-110%);
	transition: transform .26s ease;
	display: none;
}
.pb-catalog-search-modal.is-open {
	transform: translateY(0);
}
.pb-catalog-search-modal__row {
	display: flex;
	align-items: center;
	gap: 8px;
}
.pb-catalog-search-modal__field {
	flex: 1;
	position: relative;
	display: flex;
	align-items: center;
}
.pb-catalog-search-modal__field svg {
	position: absolute;
	left: 12px;
	width: 16px; height: 16px;
	stroke: var(--pkb-primary, var(--idd-color-primary, #fe0201));
	fill: none;
	pointer-events: none;
}
.pb-catalog-search-modal__field input {
	width: 100%;
	min-height: 44px;
	padding: 0 14px 0 36px;
	background: var(--pb-bg-soft, var(--idd-color-bg-alt, #f7f9fc));
	border: 1px solid rgba(15, 23, 42, .08);
	border-radius: 12px;
	color: var(--pb-ink, var(--idd-color-bg-dark, #0f172a));
	font-size: 14px;
	font-weight: 600;
	outline: none;
}
.pb-catalog-search-modal__field input:focus {
	background: #fff;
	border-color: rgba(254,2,1, .40);
	box-shadow: 0 0 0 3px rgba(254,2,1, .10);
}
.pb-catalog-search-modal__close {
	flex: 0 0 auto;
	width: 44px; height: 44px;
	display: inline-flex;
	align-items: center; justify-content: center;
	background: rgba(254,2,1, .05);
	border: 0;
	border-radius: 12px;
	color: var(--pkb-danger, var(--idd-color-primary, #ef4444));
	font-size: 22px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
}

/* Affichage mobile : on montre la barre + la modale est rendue (mais cachée par transform) */
@media (max-width: 820px) {
	.pb-catalog-mobile-bar { display: flex; }
	.pb-catalog-search-modal { display: block; }

	/* Espace en bas pour ne pas masquer le dernier résultat sous la barre fixe */
	.pb-json-archive { padding-bottom: 80px; }

	/* On masque la barre de recherche desktop redondante quand on est sur mobile :
	   l'utilisateur passe par l'icône loupe → mini-modale. */
	.pb-json-search-shell { display: none; }
}

/* Quand un canvas global (menu principal, etc.) est ouvert, on neutralise
   notre barre fixe pour qu'elle ne déborde pas par-dessus le drawer. */
body.pkb-canvas-open .pb-catalog-mobile-bar,
body.pkb-canvas-open .pb-catalog-search-modal {
	visibility: hidden !important;
	pointer-events: none !important;
}