/* =========================================================
   Metroport – Lista kanałów TV
   Stylistyka inspirowana czystymi siatkami kart (play.pl)
   ========================================================= */

.mpch-app {
	--mpch-accent: #6f2da8;          /* fiolet w klimacie play */
	--mpch-accent-2: #9b4dff;
	--mpch-accent-3: #6f2da8;
	--mpch-bg: #ffffff;
	--mpch-bg-soft: #f5f6fa;
	--mpch-card: #ffffff;
	--mpch-border: #e7e8ef;
	--mpch-text: #1c1d2b;
	--mpch-text-soft: #6b6d80;
	--mpch-hd: #00b894;
	--mpch-radius: 14px;
	--mpch-shadow: 0 2px 10px rgba(28, 29, 43, .06);
	--mpch-shadow-hover: 0 8px 28px color-mix(in srgb, var(--mpch-accent) 18%, transparent);

	max-width: 1180px;
	margin: 0 auto;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--mpch-text);
	box-sizing: border-box;
}

.mpch-app *,
.mpch-app *::before,
.mpch-app *::after {
	box-sizing: border-box;
}

/* ---------- Zakładki pakietów (dwie linie) ---------- */
.mpch-tabs-block {
	margin-bottom: 18px;
	padding-bottom: 14px;
	border-bottom: 2px solid var(--mpch-border);
}

.mpch-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

/* Druga linia (rozszerzone) – lekki odstęp i subtelne odróżnienie. */
.mpch-tabs-ext {
	margin-top: 8px;
}

.mpch-tab {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border: 1.5px solid var(--mpch-border);
	background: var(--mpch-bg);
	color: var(--mpch-text);
	padding: 7px 12px;
	border-radius: 10px;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	transition: all .18s ease;
	white-space: nowrap;
}

/* Rozszerzone zakładki nieco mniejsze i stonowane, by hierarchia była czytelna. */
.mpch-tabs-ext .mpch-tab {
	font-size: 12px;
	padding: 6px 10px;
	border-style: dashed;
	color: var(--mpch-text-soft);
}

.mpch-tab:hover {
	border-color: var(--mpch-accent-2);
	color: var(--mpch-accent);
}

.mpch-tabs-ext .mpch-tab:hover {
	border-style: solid;
}

.mpch-tab.is-active {
	background: linear-gradient(135deg, var(--mpch-accent), var(--mpch-accent-2));
	border-color: transparent;
	color: #fff;
	box-shadow: 0 4px 16px color-mix(in srgb, var(--mpch-accent) 30%, transparent);
}

.mpch-tabs-ext .mpch-tab.is-active {
	border-style: solid;
	color: #fff;
}

.mpch-tab-count {
	font-size: 11px;
	font-weight: 700;
	padding: 1px 6px;
	border-radius: 999px;
	background: var(--mpch-bg-soft);
	color: var(--mpch-text-soft);
	min-width: 20px;
	text-align: center;
}

.mpch-tab.is-active .mpch-tab-count {
	background: rgba(255, 255, 255, .25);
	color: #fff;
}

/* ---------- Pasek narzędzi ---------- */
.mpch-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	align-items: center;
	margin-bottom: 18px;
}

/* hide_controls="yes" – pasek narzędzi i elementy sterujące całkowicie ukryte. */
.mpch-app.mpch-no-controls .mpch-toolbar,
.mpch-app.mpch-no-controls .mpch-tabs-block,
.mpch-app.mpch-no-controls .mpch-cats,
.mpch-app.mpch-no-controls .mpch-searchbar {
	display: none !important;
}

/* Filtr "tylko gwarantowane". */
.mpch-guar-toggle {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 13.5px;
	font-weight: 700;
	color: var(--mpch-text);
	cursor: pointer;
	border: 1.5px solid var(--mpch-border);
	border-radius: 999px;
	padding: 7px 14px 7px 11px;
	user-select: none;
	transition: border-color .15s ease, background .15s ease;
}

.mpch-guar-toggle:hover {
	border-color: #f5a623;
}

.mpch-guar-toggle input {
	margin: 0;
	cursor: pointer;
	accent-color: #f5a623;
}

.mpch-guar-star {
	color: #f5a623;
	font-size: 15px;
	line-height: 1;
}

/* Przełącznik "bez kategorii" / "ukryj niedostępne". */
.mpch-flat-toggle,
.mpch-unavail-toggle {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 13.5px;
	font-weight: 700;
	color: var(--mpch-text);
	cursor: pointer;
	border: 1.5px solid var(--mpch-border);
	border-radius: 999px;
	padding: 7px 14px;
	user-select: none;
	transition: border-color .15s ease;
}

.mpch-flat-toggle:hover,
.mpch-unavail-toggle:hover {
	border-color: var(--mpch-accent-2);
}

.mpch-flat-toggle input,
.mpch-unavail-toggle input {
	margin: 0;
	cursor: pointer;
	accent-color: var(--mpch-accent);
}

/* Przełącznik "Porównaj pakiety". */
.mpch-compare-toggle {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 13.5px;
	font-weight: 700;
	color: var(--mpch-text);
	cursor: pointer;
	border: 1.5px solid var(--mpch-border);
	border-radius: 999px;
	padding: 7px 14px;
	user-select: none;
	transition: border-color .15s ease, background .15s ease;
}

.mpch-compare-toggle:hover {
	border-color: var(--mpch-accent);
}

.mpch-compare-toggle input {
	margin: 0;
	cursor: pointer;
	accent-color: var(--mpch-accent);
}

/* Pasek wyszukiwarki (pod kategoriami). */
.mpch-searchbar {
	margin-bottom: 18px;
}

.mpch-search {
	position: relative;
	flex: 1 1 100%;
	min-width: 220px;
}

.mpch-search input {
	width: 100%;
	padding: 13px 44px 13px 44px;
	border: 1.5px solid var(--mpch-border);
	border-radius: 999px;
	font-size: 15px;
	color: var(--mpch-text);
	background: var(--mpch-bg);
	transition: border-color .2s, box-shadow .2s;
	outline: none;
}

.mpch-search input:focus {
	border-color: var(--mpch-accent-2);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--mpch-accent-2) 22%, transparent);
}

.mpch-search svg {
	position: absolute;
	left: 15px;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: 18px;
	color: var(--mpch-text-soft);
	pointer-events: none;
}

/* Przycisk czyszczenia pola wyszukiwania (X). */
.mpch-search-clear {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 26px;
	height: 26px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: var(--mpch-bg-soft);
	color: var(--mpch-text-soft);
	border-radius: 999px;
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	transition: background .15s ease, color .15s ease;
}

.mpch-search-clear:hover {
	background: color-mix(in srgb, var(--mpch-accent) 14%, transparent);
	color: var(--mpch-accent);
}

.mpch-search-clear[hidden] {
	display: none;
}

/* ---------- Pigułki kategorii ---------- */
.mpch-cats {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	margin-bottom: 20px;
}

.mpch-cat {
	border: 1.5px solid var(--mpch-border);
	background: var(--mpch-bg);
	color: var(--mpch-text-soft);
	padding: 6px 12px;
	border-radius: 999px;
	font-size: 12.5px;
	font-weight: 600;
	cursor: pointer;
	transition: all .18s ease;
	white-space: nowrap;
	text-transform: capitalize;
}

.mpch-cat:hover {
	border-color: var(--mpch-accent-2);
	color: var(--mpch-accent);
}

.mpch-cat.is-active {
	background: linear-gradient(135deg, var(--mpch-accent), var(--mpch-accent-2));
	border-color: transparent;
	color: #fff;
	box-shadow: 0 4px 14px color-mix(in srgb, var(--mpch-accent) 30%, transparent);
}

.mpch-cat .mpch-cat-count {
	font-size: 13px;
	font-weight: 700;
	opacity: .85;
	margin-left: 6px;
	padding: 1px 7px;
	border-radius: 999px;
	background: color-mix(in srgb, currentColor 12%, transparent);
}

.mpch-cat.is-active .mpch-cat-count {
	background: color-mix(in srgb, #ffffff 25%, transparent);
	opacity: 1;
}

/* ---------- Przełącznik widoku (kafelki / tabela) ---------- */
.mpch-viewtoggle {
	display: inline-flex;
	margin-left: auto;
	border: 1.5px solid var(--mpch-border);
	border-radius: 999px;
	padding: 3px;
	background: var(--mpch-bg);
	gap: 2px;
}

.mpch-viewbtn {
	border: none;
	background: transparent;
	color: var(--mpch-text-soft);
	font-size: 13.5px;
	font-weight: 700;
	padding: 7px 16px;
	border-radius: 999px;
	cursor: pointer;
	transition: all .15s ease;
}

.mpch-viewbtn:hover {
	color: var(--mpch-accent);
}

.mpch-viewbtn.is-active {
	background: linear-gradient(135deg, var(--mpch-accent), var(--mpch-accent-2));
	color: #fff;
}

/* ---------- Widok tabeli (styl Toya) ---------- */
.mpch-tablewrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border: 1px solid var(--mpch-border);
	border-radius: var(--mpch-radius);
}

.mpch-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
	min-width: 560px;
}

.mpch-table th,
.mpch-table td {
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid var(--mpch-border);
}

.mpch-table thead th {
	position: sticky;
	top: 0;
	background: var(--mpch-bg-soft);
	font-size: 12.5px;
	font-weight: 800;
	color: var(--mpch-text);
	z-index: 2;
	white-space: nowrap;
}

.mpch-th-lcn {
	width: 52px;
	text-align: center !important;
	vertical-align: bottom;
	padding-bottom: 10px !important;
}

/* Kolumna nazwy kanału zajmuje całą dostępną szerokość. */
.mpch-th-ch {
	width: 100%;
	vertical-align: bottom;
	padding-bottom: 10px !important;
}

/* Wąskie kolumny pakietów z nagłówkiem pisanym pionowo.
   Stała wysokość komórki + wyrównanie do dołu => wszystkie nazwy kończą się na tej samej linii. */
.mpch-th-pkg {
	width: 1%;
	height: 170px;
	padding: 14px 4px 10px !important;
	vertical-align: bottom;
	text-align: center !important;
}

.mpch-th-pkg span {
	display: inline-block;
	writing-mode: vertical-rl;
	transform: rotate(180deg);
	font-size: 11.5px;
	font-weight: 700;
	line-height: 1.1;
	white-space: nowrap;
	text-align: left;
}

.mpch-trow-cat td {
	background: color-mix(in srgb, var(--mpch-accent) 8%, #ffffff);
	font-weight: 800;
	font-size: 14px;
	color: var(--mpch-text);
	padding: 8px 12px;
}

/* W tabeli nazwa kategorii to zwykły tekst (bez „zakładki" z gridu). */
.mpch-trow-cat .mpch-section-name {
	background: none;
	border: none;
	padding: 0;
	border-radius: 0;
	color: var(--mpch-accent);
	font-size: 14px;
}

.mpch-trow-cat .mpch-section-count {
	margin-left: 8px;
	font-size: 12px;
	font-weight: 700;
	color: var(--mpch-text-soft);
	background: var(--mpch-bg);
	padding: 1px 8px;
	border-radius: 999px;
}

.mpch-trow {
	cursor: pointer;
	transition: background .12s ease;
}

.mpch-trow:hover {
	background: var(--mpch-bg-soft);
}

.mpch-trow:focus-visible {
	outline: 2px solid var(--mpch-accent-2);
	outline-offset: -2px;
}

.mpch-td-lcn {
	text-align: center;
	width: 52px;
	font-weight: 800;
	font-size: 14px;
}

.mpch-td-lcn span {
	display: inline-block;
	background: var(--mpch-accent-3);
	color: #fff;
	padding: 3px 7px;
	border-radius: 6px;
	min-width: 30px;
}

.mpch-td-ch {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 220px;
}

.mpch-td-logo {
	flex: 0 0 64px;
	width: 64px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border-radius: 6px;
}

.mpch-td-logo img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.mpch-td-noimg {
	font-weight: 800;
	color: var(--mpch-accent);
	font-size: 18px;
}

.mpch-td-name {
	font-weight: 600;
	color: var(--mpch-text);
	font-size: 14.5px;
}

.mpch-inline-hd {
	font-size: 10px;
	font-weight: 800;
	background: var(--mpch-hd);
	color: #fff;
	padding: 1px 5px;
	border-radius: 4px;
	vertical-align: middle;
}

.mpch-inline-guar {
	color: #f5a623;
	font-size: 13px;
}

.mpch-td-pkg {
	text-align: center;
	width: 1%;
	padding-left: 6px;
	padding-right: 6px;
}

/* Osobna kolumna "gwarantowany". */
.mpch-th-guar span {
	color: #f5a623;
}

.mpch-td-guar {
	text-align: center;
	width: 1%;
	padding-left: 6px;
	padding-right: 6px;
}

.mpch-guar-mark {
	color: #f5a623;
	font-size: 15px;
	line-height: 1;
}

.mpch-check {
	color: var(--mpch-hd);
	font-weight: 800;
	font-size: 16px;
}

.mpch-nocheck {
	color: var(--mpch-border);
}

/* ---------- Eksport PDF ---------- */
.mpch-export-bar {
	display: flex;
	justify-content: flex-end;
	padding: 14px 12px;
	border-top: 1px solid var(--mpch-border);
	background: var(--mpch-bg-soft);
	position: sticky;
	left: 0;
}

.mpch-export-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border: 1.5px solid var(--mpch-accent);
	background: var(--mpch-accent);
	color: #fff;
	font-size: 13.5px;
	font-weight: 700;
	padding: 9px 16px;
	border-radius: 10px;
	cursor: pointer;
	transition: opacity .15s ease, transform .15s ease;
}

.mpch-export-btn:hover {
	opacity: .9;
	transform: translateY(-1px);
}

.mpch-export-btn:disabled {
	opacity: .6;
	cursor: default;
	transform: none;
}

.mpch-trow.is-dimmed .mpch-td-logo img {
	filter: grayscale(1);
	opacity: .4;
}

.mpch-trow.is-dimmed .mpch-td-name,
.mpch-trow.is-dimmed .mpch-td-lcn {
	opacity: .5;
}

/* ---------- Sekcje kategorii (pionowo) ---------- */
.mpch-sections {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.mpch-section {
	scroll-margin-top: 16px;
}

.mpch-section-title {
	display: flex;
	align-items: flex-end;
	gap: 10px;
	margin: 0 0 16px;
	padding-bottom: 0;
	border-bottom: 2px solid color-mix(in srgb, var(--mpch-accent) 22%, transparent);
}

.mpch-section-name {
	position: relative;
	font-size: 16px;
	font-weight: 800;
	color: var(--mpch-accent);
	text-transform: capitalize;
	background: color-mix(in srgb, var(--mpch-accent) 10%, #ffffff);
	padding: 8px 16px;
	border-radius: 10px 10px 0 0;
	border: 1px solid color-mix(in srgb, var(--mpch-accent) 18%, transparent);
	border-bottom: none;
	line-height: 1.2;
}

.mpch-section-count {
	font-size: 14.5px;
	font-weight: 800;
	color: var(--mpch-accent);
	background: color-mix(in srgb, var(--mpch-accent) 12%, #ffffff);
	padding: 3px 11px;
	border-radius: 999px;
	margin-bottom: 6px;
	margin-left: auto;
	white-space: nowrap;
}

/* ---------- Siatka kart ---------- */
.mpch-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(var(--mpch-tile, 110px), 1fr));
	gap: 14px;
}

.mpch-card {
	position: relative;
	background: var(--mpch-card);
	border: 1px solid var(--mpch-border);
	border-radius: var(--mpch-radius);
	padding: 22px 16px 16px;
	text-align: center;
	cursor: pointer;
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
	box-shadow: var(--mpch-shadow);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	aspect-ratio: 1 / 1;
}

.mpch-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--mpch-shadow-hover);
	border-color: transparent;
}

.mpch-card:focus-visible {
	outline: 3px solid var(--mpch-accent-2);
	outline-offset: 2px;
}

.mpch-logo-wrap {
	width: 100%;
	flex: 1 1 auto;
	min-height: 0;
	margin-top: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mpch-logo-wrap img {
	max-width: 88%;
	max-height: 100%;
	object-fit: contain;
}

.mpch-logo-fallback {
	width: 100%;
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	font-weight: 700;
	color: var(--mpch-accent);
	background: var(--mpch-bg-soft);
	border-radius: 10px;
	padding: 6px;
	line-height: 1.15;
}

.mpch-card-name {
	flex: 0 0 auto;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.2;
	color: var(--mpch-text);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Kanał spoza aktywnego pakietu – rozjaśniony, wtopiony w tło, nieklikalny. */
.mpch-card.is-dimmed {
	background: var(--mpch-bg);
	box-shadow: none;
	border-color: color-mix(in srgb, var(--mpch-border) 45%, transparent);
}

.mpch-card.is-dimmed .mpch-logo-wrap img {
	filter: grayscale(1);
	opacity: .22;
	transition: filter .18s ease, opacity .18s ease;
}

.mpch-card.is-dimmed .mpch-card-name {
	color: var(--mpch-text-soft);
	opacity: .45;
}

.mpch-card.is-dimmed .mpch-card-nr {
	background: var(--mpch-text-soft);
	opacity: .35;
}

.mpch-card.is-dimmed .mpch-badge-hd,
.mpch-card.is-dimmed .mpch-badge-guar {
	background: var(--mpch-text-soft);
	opacity: .35;
}

.mpch-card.is-dimmed .mpch-logo-fallback {
	color: var(--mpch-text-soft);
	opacity: .4;
}

/* Kanał spoza aktywnego pakietu – wyszarzony i NIEklikalny: brak reakcji na hover. */
.mpch-card.is-dimmed {
	cursor: default;
}

.mpch-card.is-dimmed:hover {
	transform: none;
	box-shadow: none;
	border-color: color-mix(in srgb, var(--mpch-border) 45%, transparent);
}

.mpch-card.is-dimmed:hover .mpch-logo-wrap img {
	filter: grayscale(1);
	opacity: .22;
}

.mpch-card.is-dimmed:hover .mpch-card-name {
	opacity: .45;
}

.mpch-badges {
	position: absolute;
	top: 8px;
	right: 8px;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 4px;
	z-index: 1;
}

.mpch-badge-hd {
	background: var(--mpch-hd);
	color: #fff;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: .5px;
	padding: 3px 7px;
	border-radius: 6px;
	line-height: 1;
}

.mpch-badge-guar {
	background: #f5a623;
	color: #fff;
	font-size: 11px;
	font-weight: 800;
	line-height: 1;
	padding: 3px 6px;
	border-radius: 6px;
}

.mpch-card-nr {
	position: absolute;
	top: 8px;
	left: 8px;
	background: var(--mpch-accent-3);
	color: #fff;
	font-size: 16px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: .3px;
	padding: 5px 9px;
	border-radius: 8px;
	min-width: 26px;
	text-align: center;
}

/* Gwiazdka gwarancji w miejscu LCN (gdy LCN jest ukryty). */
.mpch-card-nr-guar {
	background: #f5a623;
	color: #fff;
	font-size: 15px;
	padding: 5px 8px;
}

/* ---------- Brak wyników / błąd / ładowanie ---------- */
.mpch-empty,
.mpch-error,
.mpch-loading {
	padding: 28px;
	text-align: center;
	color: var(--mpch-text-soft);
	background: var(--mpch-bg-soft);
	border-radius: var(--mpch-radius);
	font-size: 15px;
}

.mpch-error {
	color: #b23b3b;
	background: #fdeaea;
}

/* ---------- Modal ze szczegółami ---------- */
.mpch-modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(20, 18, 30, .55);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	z-index: 99999;
	opacity: 0;
	visibility: hidden;
	transition: opacity .2s ease, visibility .2s ease;
	backdrop-filter: blur(2px);
}

.mpch-modal-overlay.is-open {
	opacity: 1;
	visibility: visible;
}

.mpch-modal {
	background: #fff;
	border-radius: 18px;
	max-width: 520px;
	width: 100%;
	max-height: 86vh;
	overflow-y: auto;
	padding: 28px;
	position: relative;
	box-shadow: 0 24px 60px rgba(0, 0, 0, .35);
	transform: translateY(14px) scale(.98);
	transition: transform .22s ease;
}

.mpch-modal-overlay.is-open .mpch-modal {
	transform: translateY(0) scale(1);
}

.mpch-modal-close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 36px;
	height: 36px;
	border: none;
	background: var(--mpch-bg-soft);
	border-radius: 50%;
	cursor: pointer;
	font-size: 20px;
	line-height: 1;
	color: var(--mpch-text-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .15s, color .15s;
}

.mpch-modal-close:hover {
	background: #ececf3;
	color: var(--mpch-text);
}

.mpch-modal-head {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-bottom: 18px;
	padding-right: 36px;
}

.mpch-modal-logo {
	width: 160px;
	height: 100px;
	flex: 0 0 160px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 1px solid var(--mpch-border);
	border-radius: 12px;
	padding: 10px;
}

.mpch-modal-logo img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.mpch-modal-title h3 {
	margin: 0 0 6px;
	font-size: 21px;
	line-height: 1.2;
	color: var(--mpch-text);
}

.mpch-modal-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
}

.mpch-tag {
	font-size: 11.5px;
	font-weight: 700;
	padding: 3px 9px;
	border-radius: 6px;
	background: var(--mpch-bg-soft);
	color: var(--mpch-text-soft);
	text-transform: capitalize;
}

.mpch-tag.is-hd {
	background: var(--mpch-hd);
	color: #fff;
}

.mpch-tag.is-guar {
	background: #f5a623;
	color: #fff;
}

.mpch-tag.is-nr {
	background: var(--mpch-accent-3);
	color: #fff;
	font-size: 18px;
	font-weight: 800;
	padding: 4px 12px;
	letter-spacing: .5px;
}

.mpch-modal-desc {
	font-size: 14.5px;
	line-height: 1.6;
	color: #44465a;
	margin-bottom: 20px;
}

.mpch-modal-section-title {
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .6px;
	color: var(--mpch-text-soft);
	margin: 0 0 10px;
}

.mpch-pkg-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.mpch-pkg-chip {
	font-size: 13px;
	font-weight: 600;
	padding: 7px 13px;
	border-radius: 999px;
	background: linear-gradient(135deg, color-mix(in srgb, var(--mpch-accent) 10%, transparent), color-mix(in srgb, var(--mpch-accent-2) 14%, transparent));
	color: var(--mpch-accent);
	border: 1px solid color-mix(in srgb, var(--mpch-accent-2) 25%, transparent);
}

/* ---------- Responsywność ---------- */
@media (max-width: 640px) {
	.mpch-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 10px;
	}

	.mpch-card-nr {
		font-size: 14px;
	}

	.mpch-toolbar {
		gap: 10px;
	}

	.mpch-viewtoggle {
		margin-left: 0;
		width: 100%;
		justify-content: center;
	}

	.mpch-viewbtn {
		flex: 1;
	}

	.mpch-tabs {
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: thin;
		padding-bottom: 12px;
	}

	.mpch-tab {
		flex: 0 0 auto;
	}

	.mpch-modal {
		padding: 22px 18px;
	}

	.mpch-modal-head {
		flex-direction: column;
		text-align: center;
	}

	.mpch-modal-logo {
		flex: 0 0 auto;
	}

	.mpch-modal-tags {
		justify-content: center;
	}
}

/* Dostępność: redukcja ruchu */
@media (prefers-reduced-motion: reduce) {
	.mpch-card,
	.mpch-modal,
	.mpch-modal-overlay {
		transition: none;
	}
}
