/**
 * taxonomy-catalog_cat (Phase 0) — стилі сторінки рубрики каталогу.
 *
 * Розширює catalog.css (.cat-* tokens). Власний namespace .cat-tax-* щоб не
 * конфліктувати ні з single-catalog (.cat-hero, .cat-card), ні з category.php
 * (.cat-hero-c).
 */

/* ---------------------------- LAYOUT ---------------------------- */

.cat-tax {
	max-width: 1320px;
	margin: 0 auto;
	padding: 8px 28px 40px;
	min-height: 60vh;
}
@media (max-width: 720px) {
	.cat-tax { padding: 8px 16px 32px; }
}

.cat-tax .cat-crumbs {
	max-width: none;
	padding: 16px 0 0;
}

/* ---------------------------- HERO ---------------------------- */

.cat-tax__hero {
	position: relative;
	margin: 16px 0 22px;
	padding: 26px 28px 24px;
	border-radius: var(--radius-lg);
	background: var(--paper-2);
	overflow: hidden;
	color: var(--ink);
}
.cat-tax__hero.has-cover {
	color: #fff;
	background: var(--ink);
	min-height: 240px;
	display: flex;
	align-items: flex-end;
	padding: 32px;
}
.cat-tax__hero.has-cover::before {
	content: '';
	position: absolute; inset: 0;
	background-image: var(--cover);
	background-size: cover;
	background-position: center;
	z-index: 0;
}
.cat-tax__hero.has-cover::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(14,14,15,.15) 0%, rgba(14,14,15,.65) 70%, rgba(14,14,15,.78) 100%);
	z-index: 0;
}
.cat-tax__hero-inner { position: relative; z-index: 1; width: 100%; }

.cat-tax__hero-top {
	display: flex; gap: 18px;
	align-items: flex-start;
	justify-content: space-between;
	flex-wrap: wrap;
}
.cat-tax__title {
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 700;
	font-size: 36px;
	letter-spacing: -.015em;
	line-height: 1.08;
	margin: 0;
	flex: 1 1 0;
	min-width: 0;
	color: inherit;
}
.cat-tax__hero.has-cover .cat-tax__title { color: #fff; }
.cat-tax__page {
	display: inline-block;
	font-weight: 500;
	font-size: .55em;
	color: var(--muted);
	margin-left: 6px;
	letter-spacing: 0;
}
.cat-tax__hero.has-cover .cat-tax__page { color: rgba(255,255,255,.7); }
.cat-tax__add { flex-shrink: 0; }
.cat-tax__hero.has-cover .cat-tax__add { background: var(--yellow); color: var(--ink); }

.cat-tax__lead {
	margin: 14px 0 0;
	max-width: 720px;
	font-size: 15px;
	line-height: 1.55;
	color: var(--ink-2);
}
.cat-tax__lead > :first-child { margin-top: 0; }
.cat-tax__lead > :last-child  { margin-bottom: 0; }
.cat-tax__lead p { margin: 0 0 .6em; }
.cat-tax__hero.has-cover .cat-tax__lead { color: rgba(255,255,255,.92); }

.cat-tax__hero-meta {
	display: flex; gap: 18px; flex-wrap: wrap;
	margin-top: 16px;
	font-size: 13px;
	color: var(--muted);
}
.cat-tax__hero.has-cover .cat-tax__hero-meta { color: rgba(255,255,255,.78); }
.cat-tax__hero-meta b { color: var(--ink); font-weight: 700; }
.cat-tax__hero.has-cover .cat-tax__hero-meta b { color: #fff; }
.cat-tax__count, .cat-tax__pinned { display: inline-flex; align-items: center; gap: 6px; }
.cat-tax__pinned svg { opacity: .7; }

@media (max-width: 720px) {
	.cat-tax__hero { padding: 20px 18px; min-height: 0; }
	.cat-tax__hero.has-cover { min-height: 180px; padding: 22px 18px; }
	.cat-tax__title { font-size: 26px; }
	.cat-tax__hero-top { gap: 12px; }
	.cat-tax__add { height: 38px; padding: 0 12px; font-size: 13px; }
}

/* ---------------------------- SPONSORED (Phase 3 slot #1 zachepa) ---------------------------- */

.cat-tax__sponsored {
	position: relative;
	margin: 0 0 22px;
	padding: 0 0 4px;
	background: transparent;
}
.cat-tax__sponsored-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 10px;
}
.cat-tax__sponsored-title {
	display: inline-flex; align-items: center; gap: 8px;
	margin: 0;
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 600;
	font-size: 12.5px;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--ink);
}
.cat-tax__sponsored-title svg { color: var(--yellow-deep); }
.cat-tax__sponsored-label {
	font-family: 'Manrope', system-ui, sans-serif;
	font-size: 10.5px;
	color: var(--muted-2);
	font-weight: 500;
	letter-spacing: .06em;
	text-transform: uppercase;
}

.cat-tax__sponsored-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (max-width: 720px) {
	.cat-tax__sponsored-grid { grid-template-columns: 1fr; gap: 10px; }
}
.cat-tax__sponsored-card {
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.cat-tax__sponsored-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-2);
	border-color: var(--line-strong);
}
.cat-tax__sponsored-link { display: block; color: inherit; text-decoration: none; }
.cat-tax__sponsored-thumb {
	position: relative;
	height: 96px;
	background: var(--paper-2);
	display: flex; align-items: center; justify-content: center;
	overflow: hidden;
	border-bottom: 1px solid var(--line);
}
.cat-tax__sponsored-thumb img {
	max-width: 55%;
	max-height: 70%;
	object-fit: contain;
}
.cat-tax__sponsored-thumb-fallback { color: var(--muted-2); }
.cat-tax__sponsored-tag {
	position: absolute;
	top: 6px; right: 6px;
	padding: 1px 6px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 700;
	font-size: 9px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--muted);
	background: rgba(255,255,255,.85);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	border: 1px solid var(--line);
	border-radius: 3px;
	z-index: 2;
}
.cat-tax__sponsored-body { padding: 10px 12px 12px; }
.cat-tax__sponsored-eyebrow {
	display: inline-flex; align-items: center; gap: 5px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: .07em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0 0 4px;
}
.cat-tax__sponsored-eyebrow::before {
	content: "";
	width: 3px; height: 3px;
	border-radius: 50%;
	background: var(--yellow-deep);
	flex: 0 0 auto;
}
.cat-tax__sponsored-name {
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 700;
	font-size: 13px;
	color: var(--ink);
	margin: 0 0 4px;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cat-tax__sponsored-card:hover .cat-tax__sponsored-name { color: var(--red); }
.cat-tax__sponsored-meta {
	display: flex; align-items: center; flex-wrap: wrap; gap: 4px 6px;
	font-size: 11.5px;
	color: var(--muted);
}
.cat-tax__sponsored-rating {
	color: var(--yellow-deep);
	font-weight: 700;
}
.cat-tax__sponsored-rating--empty { color: var(--muted-2); }
.cat-tax__sponsored-sep { color: var(--muted-2); }

/* ---------------------------- FILTERS ---------------------------- */

.cat-tax__filters {
	display: grid; gap: 8px;
	margin: 0 0 22px;
	padding: 14px 16px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.cat-tax__filter-row {
	display: flex; gap: 12px;
	align-items: flex-start;
	flex-wrap: wrap;
}
.cat-tax__filter-label {
	flex-shrink: 0;
	padding-top: 4px;
	font-size: 11.5px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--muted);
}
.cat-tax__chips { display: flex; flex-wrap: wrap; gap: 6px; }
.cat-tax__chips .cat-chip {
	height: 28px;
	padding: 0 12px;
	gap: 6px;
}
.cat-tax__chips .cat-chip.is-on {
	background: var(--ink); color: var(--paper); border-color: var(--ink);
}
.cat-tax__chips .cat-chip.is-on:hover { background: var(--ink-2); }
.cat-tax__chips .cat-chip--reset {
	background: transparent;
	color: var(--red-deep);
	border-color: var(--red-soft);
}
.cat-tax__chips .cat-chip--reset:hover { background: var(--red-soft); }
.cat-chip__n {
	font-size: 11px;
	font-weight: 700;
	color: var(--muted);
	margin-left: 2px;
}
.cat-tax__chips .cat-chip.is-on .cat-chip__n { color: rgba(255,255,255,.65); }
.cat-tax__filter-dot {
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--green);
}

@media (max-width: 720px) {
	.cat-tax__filters { padding: 10px 12px; }
	.cat-tax__filter-row { gap: 8px; }
	.cat-tax__filter-label { font-size: 10.5px; padding-top: 6px; }
}

/* ---------------------------- 2-COL LAYOUT ---------------------------- */

.cat-tax__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 420px;
	gap: 28px;
	align-items: start;
}
.cat-tax__main { min-width: 0; }
.cat-tax__side {
	position: sticky;
	top: calc(var(--header-h) + var(--quick-h) + 16px);
	align-self: start;
	height: calc(100vh - var(--header-h) - var(--quick-h) - 32px);
	min-height: 480px;
	max-height: 820px;
}
@media (max-width: 1100px) {
	.cat-tax__layout { grid-template-columns: minmax(0, 1fr) 360px; }
}
@media (max-width: 980px) {
	.cat-tax__layout { grid-template-columns: 1fr; gap: 18px; }
	.cat-tax__side {
		position: static;
		height: auto;
		min-height: 0;
		max-height: none;
		order: -1;
	}
}

/* ---------------------------- LIST ---------------------------- */

.cat-tax__list {
	list-style: none;
	padding: 0;
	margin: 0 0 22px;
	display: grid;
	gap: 14px;
}

/* ---- CARD ---- */

.cat-tax__card {
	display: grid;
	grid-template-columns: 132px minmax(0, 1fr) auto;
	gap: 18px;
	padding: 16px 18px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease, background .15s ease;
	scroll-margin-top: calc(var(--header-h) + var(--quick-h) + 8px);
}
.cat-tax__card:hover {
	border-color: var(--line-strong);
	box-shadow: var(--shadow-2);
	transform: translateY(-1px);
}
.cat-tax__card.is-vip {
	background: linear-gradient(180deg, var(--yellow-soft), var(--paper));
	border-color: var(--yellow-deep);
}
.cat-tax__card.is-vip:hover {
	box-shadow: 0 6px 20px rgba(244,193,0,.22);
	border-color: var(--yellow-deep);
}
.cat-tax__card.is-active {
	border-color: var(--ink);
	box-shadow: 0 0 0 2px var(--ink);
}
.cat-tax__card.is-ad { /* зачепа під Phase 3 (ads/) — поки візуально як VIP */
	background: linear-gradient(180deg, var(--yellow-soft), var(--paper));
	border-color: var(--yellow-deep);
}

/* MEDIA — лого + бейджі поверх */
.cat-tax__card-media {
	position: relative;
	width: 132px;
	height: 132px;
	flex-shrink: 0;
}
.cat-tax__card-logo {
	display: flex; align-items: center; justify-content: center;
	width: 132px; height: 132px;
	border-radius: 14px;
	overflow: hidden;
	background: var(--paper-2);
	background-image:
		repeating-linear-gradient(135deg, rgba(14,14,15,.05) 0 8px, transparent 8px 16px);
}
.cat-tax__card-logo img {
	width: 100%; height: 100%;
	object-fit: contain;
	padding: 6px;
	box-sizing: border-box;
}
.cat-tax__card-logo-fallback {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 800;
	font-size: 48px;
	color: var(--ink-2);
	background: linear-gradient(135deg, var(--yellow-soft), var(--paper-2));
}

.cat-tax__card-tag {
	position: absolute;
	top: 8px; left: 8px;
	padding: 3px 8px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 800;
	font-size: 10px;
	letter-spacing: .08em;
	color: #fff;
	background: var(--ink);
	border-radius: 6px;
	z-index: 2;
}
.cat-tax__card-tag--pro      { background: var(--yellow-deep); color: var(--ink); }
.cat-tax__card-tag--business { background: var(--ink); color: var(--paper); }
.cat-tax__card-tag--vip      { background: linear-gradient(135deg, var(--yellow-deep), var(--red)); color: #fff; }
.cat-tax__card-tag--ad       { background: var(--ink); color: var(--paper); }

.cat-tax__card-photos {
	position: absolute;
	top: 8px; right: 8px;
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 3px 7px;
	font-size: 11px;
	font-weight: 700;
	color: #fff;
	background: rgba(14,14,15,.62);
	border-radius: 6px;
	z-index: 2;
}
.cat-tax__card-photos svg { opacity: .8; }

/* BODY */
.cat-tax__card-body { min-width: 0; align-self: center; }

.cat-tax__card-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	margin-bottom: 6px;
}

.cat-tax__card-title {
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 700;
	font-size: 19px;
	letter-spacing: -.005em;
	line-height: 1.2;
	margin: 0 0 8px;
	color: var(--ink);
}
.cat-tax__card-title a { color: inherit; }
.cat-tax__card-title a:hover { color: var(--red); }
.cat-tax__card-subtitle {
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 500;
	font-size: 14px;
	color: var(--muted);
	margin-left: 8px;
	letter-spacing: 0;
}

.cat-tax__card-meta {
	display: flex; flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	font-size: 13.5px;
	color: var(--ink-2);
	margin-bottom: 6px;
}
.cat-tax__card-rating {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.cat-tax__card-star { color: var(--yellow-deep); }
.cat-tax__card-rating b { color: var(--ink); font-weight: 700; }
.cat-tax__card-rating-n { color: var(--muted); font-size: 12.5px; }

.cat-tax__card-open {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
}
.cat-tax__card-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	display: inline-block;
}
.cat-tax__card-open.is-open  { color: var(--green); }
.cat-tax__card-open.is-open  .cat-tax__card-dot { background: var(--green); }
.cat-tax__card-open.is-closed { color: var(--muted); }
.cat-tax__card-open.is-closed .cat-tax__card-dot { background: var(--muted-2); }

.cat-tax__card-loc {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13.5px;
	color: var(--ink-2);
	margin-bottom: 8px;
}
.cat-tax__card-loc b { color: var(--ink); font-weight: 600; }
.cat-tax__card-loc .cat-tax__card-ico { color: var(--muted-2); flex-shrink: 0; }

.cat-tax__card-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.cat-tax__card-chip {
	height: 26px;
	padding: 0 11px;
	font-size: 12.5px;
	background: var(--paper-2);
}

/* ASIDE — actions */
.cat-tax__card-aside {
	display: grid;
	grid-template-columns: auto;
	align-content: center;
	justify-items: end;
	gap: 8px;
	min-width: 168px;
}
.cat-tax__card-fav {
	width: 38px; height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--muted-2);
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 999px;
	transition: color .15s ease, background .15s ease, border-color .15s ease, transform .1s ease;
	cursor: pointer;
	justify-self: end;
}
.cat-tax__card-fav:hover { color: var(--red); border-color: var(--red-soft); }
.cat-tax__card-fav.is-on {
	color: var(--red);
	background: var(--red-soft);
	border-color: var(--red-soft);
}
.cat-tax__card-fav.is-on svg { fill: var(--red); }
.cat-tax__card-fav:active { transform: scale(.93); }

.cat-tax__card-promo {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	height: 32px;
	padding: 0 12px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 800;
	font-size: 13px;
	color: var(--ink);
	background: var(--yellow);
	border-radius: 999px;
	box-shadow: 0 2px 0 var(--yellow-deep);
}

.cat-tax__card-call {
	height: 38px;
	padding: 0 16px;
	font-size: 13.5px;
	width: 168px;
	justify-content: center;
}
/* phone-reveal button — у card layout показуємо тільки masked-номер (без "· показати"),
   яскраво-жовта pill сама сигналізує клікабельність. Після reveal — повний номер. */
.cat-tax__card-call.cat-phone__reveal .cat-phone__cta { display: none; }
.cat-tax__card-call .cat-phone__masked {
	font-weight: 700;
	letter-spacing: 0.2px;
}
.cat-tax__card-call--revealed { letter-spacing: 0.2px; font-weight: 700; }
.cat-tax__card-details {
	height: 38px;
	padding: 0 16px;
	font-size: 13.5px;
	width: 168px;
	justify-content: center;
	gap: 6px;
}

@media (max-width: 980px) {
	.cat-tax__card { grid-template-columns: 100px minmax(0, 1fr) auto; gap: 14px; }
	.cat-tax__card-media { width: 100px; height: 100px; }
	.cat-tax__card-logo  { width: 100px; height: 100px; }
	.cat-tax__card-logo-fallback { font-size: 32px; }
	.cat-tax__card-aside { min-width: 0; }
	.cat-tax__card-call,
	.cat-tax__card-details { width: 138px; }
}

@media (max-width: 720px) {
	.cat-tax__card {
		grid-template-columns: 78px minmax(0, 1fr);
		grid-template-rows: auto auto;
		gap: 12px;
		padding: 14px;
	}
	.cat-tax__card-media { width: 78px; height: 78px; }
	.cat-tax__card-logo  { width: 78px; height: 78px; border-radius: 12px; }
	.cat-tax__card-logo-fallback { font-size: 24px; }
	.cat-tax__card-tag { font-size: 9px; padding: 2px 6px; top: 6px; left: 6px; }
	.cat-tax__card-photos { font-size: 10px; padding: 2px 5px; top: 6px; right: 6px; }
	.cat-tax__card-title { font-size: 17px; }
	.cat-tax__card-subtitle { display: block; margin: 2px 0 0; font-size: 13px; }
	.cat-tax__card-aside {
		grid-column: 1 / -1;
		grid-template-columns: auto auto 1fr;
		justify-items: stretch;
		align-items: center;
	}
	.cat-tax__card-fav { justify-self: start; }
	.cat-tax__card-call,
	.cat-tax__card-details { width: auto; flex: 1 1 0; min-width: 0; padding: 0 12px; }
	.cat-tax__card-details { grid-column: 3; }
	.cat-tax__card-call    { grid-column: 2; }
}

/* ---------------------------- SHOW MORE ---------------------------- */

.cat-tax__show-more-wrap {
	display: grid;
	gap: 8px;
	justify-items: center;
	margin: 8px 0 18px;
}
.cat-tax__show-more {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	height: 46px;
	padding: 0 24px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 700;
	font-size: 14px;
	color: var(--ink);
	background: var(--paper);
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	cursor: pointer;
	transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.cat-tax__show-more:hover:not(:disabled):not(.is-depleted) {
	background: var(--paper-2);
	border-color: var(--ink);
}
.cat-tax__show-more:active:not(:disabled) { transform: scale(.98); }
.cat-tax__show-more:disabled,
.cat-tax__show-more.is-depleted {
	opacity: .55;
	cursor: not-allowed;
}
.cat-tax__show-more.is-depleted svg { display: none; }
.cat-tax__show-more-spinner {
	width: 14px; height: 14px;
	border: 2px solid var(--line-strong);
	border-top-color: var(--ink);
	border-radius: 50%;
	animation: cat-tax-spin .8s linear infinite;
	display: none;
}
.cat-tax__show-more.is-loading .cat-tax__show-more-spinner { display: inline-block; }
.cat-tax__show-more.is-loading svg { display: none; }
@keyframes cat-tax-spin {
	to { transform: rotate(360deg); }
}
.cat-tax__show-more-info {
	margin: 0;
	font-size: 13px;
	color: var(--muted);
}
.cat-tax__show-more-info b { color: var(--ink); font-weight: 700; }

/* ---------------------------- PAGER ---------------------------- */

.cat-tax__pager {
	display: flex; flex-wrap: wrap; gap: 6px;
	justify-content: center;
	margin: 6px 0 24px;
}
.cat-tax__pager .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 38px; height: 38px;
	padding: 0 12px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 700;
	font-size: 14px;
	color: var(--ink-2);
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 999px;
	transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.cat-tax__pager .page-numbers:hover {
	background: var(--paper-2);
	border-color: var(--line-strong);
}
.cat-tax__pager .page-numbers.current {
	background: var(--ink); color: var(--paper); border-color: var(--ink);
}
.cat-tax__pager .page-numbers.dots {
	border-color: transparent;
	background: transparent;
	color: var(--muted);
}

/* ---------------------------- EMPTY ---------------------------- */

.cat-tax__empty {
	display: grid; gap: 10px;
	justify-items: center;
	text-align: center;
	padding: 48px 16px;
	color: var(--muted);
	background: var(--paper-2);
	border-radius: var(--radius);
	margin-bottom: 22px;
}
.cat-tax__empty svg { color: var(--muted-2); }
.cat-tax__empty .cat-section__title { margin: 0; color: var(--ink); }
.cat-tax__empty p { margin: 0 0 6px; max-width: 420px; }

/* ---------------------------- ABOUT ---------------------------- */

.cat-tax__about {
	margin: 8px 0 0;
	padding: 22px 0 0;
	border-top: 1px solid var(--line);
}
.cat-tax__about-body {
	font-family: 'Lora', Georgia, serif;
	font-size: 15px;
	line-height: 1.65;
	color: var(--ink-2);
	max-width: 760px;
}
.cat-tax__about-body p { margin: 0 0 12px; }
.cat-tax__about-body a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--yellow-deep); text-underline-offset: 3px; }
.cat-tax__about-body a:hover { color: var(--red); }

/* ---------------------------- THEMATIC RUBRICS (bottom) ---------------------------- */

.cat-tax__rubrics {
	margin: 32px 0 8px;
	padding: 26px 28px;
	background: var(--paper-2);
	border-radius: var(--radius-lg);
}
.cat-tax__rubrics .cat-section__title {
	margin-bottom: 18px;
}
.cat-tax__rubrics-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 8px;
}
.cat-tax__rubric {
	display: block;
}
.cat-tax__rubric a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 12px 16px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 14px;
	color: var(--ink);
	font-weight: 600;
	font-size: 14px;
	transition: border-color .15s ease, background .15s ease, transform .1s ease;
}
.cat-tax__rubric a:hover {
	background: var(--yellow-soft);
	border-color: var(--yellow-deep);
	transform: translateY(-1px);
}
.cat-tax__rubric.is-active a {
	background: var(--ink);
	color: var(--paper);
	border-color: var(--ink);
}
.cat-tax__rubric-n {
	font-size: 12px;
	color: var(--muted);
	font-weight: 700;
	background: var(--paper-2);
	padding: 1px 7px;
	border-radius: 999px;
	flex-shrink: 0;
}
.cat-tax__rubric.is-active .cat-tax__rubric-n {
	background: rgba(255,255,255,.12);
	color: rgba(255,255,255,.85);
}

@media (max-width: 720px) {
	.cat-tax__rubrics { padding: 20px 18px; }
	.cat-tax__rubrics-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
}

/* ---------------------------- MAP (sticky right) ---------------------------- */

.cat-tax__map-wrap {
	display: flex;
	flex-direction: column;
	height: 100%;
	background: var(--paper-2);
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow-1);
}
.cat-tax__map-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
	padding: 14px 16px;
	background: var(--paper);
	border-bottom: 1px solid var(--line);
}
.cat-tax__map-title {
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: -.005em;
	margin: 0;
	color: var(--ink);
	display: inline-flex;
	align-items: center;
	gap: 7px;
	min-width: 0;
}
.cat-tax__map-title svg { color: var(--red); flex-shrink: 0; }

.cat-tax__map-toggle {
	display: none;
	height: 32px;
	padding: 0 12px;
	font-size: 12px;
	font-weight: 700;
	color: var(--ink);
	background: var(--paper-2);
	border-radius: 999px;
	border: 1px solid var(--line-strong);
	transition: background .15s ease;
	flex-shrink: 0;
}
.cat-tax__map-toggle:hover { background: var(--paper-3); }
.cat-tax__map-toggle .when-open  { display: none; }
.cat-tax__map-toggle .when-closed { display: inline; }
.cat-tax__map-wrap.is-open .cat-tax__map-toggle .when-open { display: inline; }
.cat-tax__map-wrap.is-open .cat-tax__map-toggle .when-closed { display: none; }

.cat-tax__map {
	flex: 1 1 auto;
	width: 100%;
	min-height: 360px;
	background: var(--paper-2);
	background-image:
		repeating-linear-gradient(135deg, rgba(14,14,15,.04) 0 8px, transparent 8px 16px);
}
.cat-tax__map-nojs {
	margin: 0; padding: 24px 16px;
	font-size: 13px; color: var(--muted); text-align: center;
}

@media (max-width: 980px) {
	.cat-tax__map-toggle { display: inline-flex; align-items: center; }
	.cat-tax__map { display: none; min-height: 300px; height: 320px; }
	.cat-tax__map-wrap.is-open .cat-tax__map { display: block; }
}

/* ---------------------------- LEAFLET PIN — у catalog.css (.cat-tax-pin*) ---------------------------- */

/* Leaflet popup */
.cat-tax-popup {
	display: grid;
	grid-template-columns: 48px minmax(0, 1fr);
	gap: 10px;
	min-width: 200px;
}
.cat-tax-popup__logo {
	width: 48px; height: 48px;
	border-radius: 10px;
	overflow: hidden;
	background: var(--paper-2);
	display: flex; align-items: center; justify-content: center;
}
.cat-tax-popup__logo img { width: 100%; height: 100%; object-fit: contain; padding: 4px; box-sizing: border-box; }
.cat-tax-popup__letter {
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 800;
	font-size: 22px;
	color: var(--ink-2);
	background: linear-gradient(135deg, var(--yellow-soft), var(--paper-2));
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
}
.cat-tax-popup__title {
	font-family: 'Unbounded', system-ui, sans-serif;
	font-weight: 700;
	font-size: 13px;
	color: var(--ink);
	margin: 0 0 2px;
	line-height: 1.25;
}
.cat-tax-popup__title a { color: inherit; }
.cat-tax-popup__title a:hover { color: var(--red); }
.cat-tax-popup__addr {
	font-size: 11.5px;
	color: var(--muted);
	line-height: 1.35;
}

/* ---------------------------- DARK MODE ---------------------------- */

body[data-theme="dark"] .cat-tax__hero       { background: var(--paper-2); }
body[data-theme="dark"] .cat-tax__sponsored  { background: transparent; }
body[data-theme="dark"] .cat-tax__sponsored-card { background: var(--paper-3); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__sponsored-thumb { background: var(--paper-2); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__sponsored-tag {
	background: rgba(20,20,22,.7);
	border-color: var(--line);
	color: var(--muted-2);
}
body[data-theme="dark"] .cat-tax__filters    { background: var(--paper-2); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__card       { background: var(--paper-2); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__card.is-vip,
body[data-theme="dark"] .cat-tax__card.is-ad {
	background: linear-gradient(180deg, rgba(244,193,0,.12), var(--paper-2));
	border-color: var(--yellow-deep);
}
body[data-theme="dark"] .cat-tax__card-logo { background: var(--paper-3); }
body[data-theme="dark"] .cat-tax__card-fav  { background: var(--paper-3); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__map-wrap  { background: var(--paper-3); }
body[data-theme="dark"] .cat-tax__map-head  { background: var(--paper-2); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__pager .page-numbers { background: var(--paper-2); border-color: var(--line); color: var(--ink-2); }
body[data-theme="dark"] .cat-tax__pager .page-numbers.current { background: var(--paper); color: var(--ink); border-color: var(--paper); }
body[data-theme="dark"] .cat-tax__empty     { background: var(--paper-2); }
body[data-theme="dark"] .cat-tax__rubrics   { background: var(--paper-2); }
body[data-theme="dark"] .cat-tax__rubric a  { background: var(--paper-3); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__rubric a:hover { background: rgba(244,193,0,.15); }
body[data-theme="dark"] .cat-tax__show-more { background: var(--paper-2); border-color: var(--line); }

/* ---------------------------- TOOLBAR (Phase 4 §S1, 4.5b) ---------------------------- */

.cat-tax__toolbar{
	display: flex; flex-wrap: wrap;
	align-items: center; justify-content: space-between;
	gap: 12px;
	margin: 16px 0 8px;
	padding: 10px 14px;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.cat-tax__sort{ display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cat-tax__sort-label{ font-size: 13px; font-weight: 600; color: var(--muted); }
.cat-tax__sort-wrap{ position: relative; display: inline-flex; align-items: center; }
.cat-tax__sort-select{
	appearance: none;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 8px 36px 8px 16px;
	font: inherit; font-weight: 600; font-size: 13px;
	color: var(--ink);
	cursor: pointer;
}
.cat-tax__sort-select:focus{ border-color: var(--line-strong); outline: none; }
.cat-tax__sort-chev{
	position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
	pointer-events: none; color: var(--muted);
}
.cat-tax__view{
	display: inline-flex;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 3px;
}
.cat-tax__view-btn{
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 12px;
	border-radius: 999px;
	color: var(--muted); text-decoration: none;
	font-weight: 600; font-size: 13px;
	transition: background .15s, color .15s;
}
.cat-tax__view-btn:hover{ color: var(--ink-2); }
.cat-tax__view-btn.is-on{
	background: var(--ink); color: var(--paper);
}
.cat-tax__view-btn svg{ flex: 0 0 auto; }

/* ---------------------------- MAP VIEW (повноекранна мапа) ---------------------------- */

.cat-tax--view-map .cat-tax__layout{
	grid-template-columns: 1fr;
	gap: 18px;
}
.cat-tax--view-map .cat-tax__main{ display: none; }
.cat-tax--view-map .cat-tax__side{
	position: static;
	height: calc(100vh - var(--header-h) - var(--quick-h) - 60px);
	min-height: 600px;
	max-height: none;
	order: 0;
}
.cat-tax--view-map .cat-tax__map-wrap{ height: 100%; display: flex; flex-direction: column; }
.cat-tax--view-map .cat-tax__map{ flex: 1; min-height: 480px; height: auto !important; display: block !important; }

@media (max-width: 720px){
	.cat-tax__toolbar{ padding: 8px 10px; }
	.cat-tax__sort-label{ display: none; }
	.cat-tax__view-btn span{ display: none; }
	.cat-tax__view-btn{ padding: 6px 10px; }
}

body[data-theme="dark"] .cat-tax__toolbar{ background: var(--paper-2); border-color: var(--line); }
body[data-theme="dark"] .cat-tax__sort-select{ background: var(--paper-3); border-color: var(--line); color: var(--ink); }
body[data-theme="dark"] .cat-tax__view{ background: var(--paper-3); border-color: var(--line); }

/* ---------------------------- CROSS-TAX (Phase 4 §S2, 4.6) ---------------------------- */

.cat-cross__intro{
	font-size: 16px; line-height: 1.55; max-width: 760px;
	color: var(--ink-2);
}
.cat-cross__fallbacks{
	margin-top: 28px;
	padding: 18px 20px;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.cat-cross__block + .cat-cross__block{ margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line); }
.cat-cross__sub-title{
	display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
	font-size: 16px; font-weight: 700;
	margin: 14px 0 8px;
}
.cat-cross__sub-title a{ color: var(--ink); text-decoration: none; }
.cat-cross__sub-title a:hover{ color: var(--red); }
.cat-cross__sub-more{ font-size: 13px; font-weight: 600; color: var(--ink-3); }
.cat-cross__sub-more:hover{ color: var(--red); }
.cat-tax__list--mini{ margin-top: 8px; }
.cat-tax__list--mini > li{ padding: 8px 0; }

.cat-cross__news{
	list-style: none; padding: 0; margin: 8px 0 0;
	display: grid; gap: 8px;
}
.cat-cross__news a{
	display: flex; gap: 12px; align-items: center;
	padding: 8px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 12px;
	color: var(--ink); text-decoration: none;
}
.cat-cross__news a:hover{ border-color: var(--line-strong); }
.cat-cross__news-thumb{
	flex: 0 0 56px; width: 56px; height: 56px;
	border-radius: 8px; overflow: hidden; background: var(--paper-2);
}
.cat-cross__news-thumb img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.cat-cross__news-body{ display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.cat-cross__news-t{ font-weight: 600; font-size: 14px; line-height: 1.3; }
.cat-cross__news time{ color: var(--muted); font-size: 11px; }

.cat-cross__internal{
	margin-top: 28px;
	padding: 18px 20px;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.cat-cross__internal-row + .cat-cross__internal-row{ margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line); }
.cat-cross__internal-h{
	font-size: 14px; font-weight: 700; margin: 0 0 10px;
	color: var(--ink-2);
}
.cat-cross__chips{
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 6px;
}
.cat-cross__chips a{
	display: inline-block;
	padding: 6px 12px; border-radius: 999px;
	background: var(--paper); border: 1px solid var(--line);
	color: var(--ink-2); text-decoration: none;
	font-weight: 600; font-size: 12.5px;
}
.cat-cross__chips a:hover{ background: var(--yellow-soft); border-color: var(--yellow); color: var(--ink); }

.cat-cross__faq{
	margin-top: 28px;
	padding: 18px 20px;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.cat-cross__faq-list{ margin: 0; padding: 0; }
.cat-cross__faq-item{
	border-bottom: 1px solid var(--line);
	padding: 8px 0;
}
.cat-cross__faq-item:last-child{ border-bottom: 0; }
.cat-cross__faq-item summary{
	list-style: none;
	cursor: pointer;
	font-weight: 700; font-size: 15px;
	padding: 6px 0;
	position: relative; padding-right: 24px;
}
.cat-cross__faq-item summary::-webkit-details-marker{ display:none; }
.cat-cross__faq-item summary::after{
	content: '+';
	position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-weight: 700; font-size: 18px; color: var(--muted);
}
.cat-cross__faq-item[open] summary::after{ content: '−'; }
.cat-cross__faq-a{ padding: 6px 0 4px; color: var(--ink-3); font-size: 14px; line-height: 1.55; }

body[data-theme="dark"] .cat-cross__fallbacks,
body[data-theme="dark"] .cat-cross__internal,
body[data-theme="dark"] .cat-cross__faq{ background: var(--paper-2); border-color: var(--line); }
body[data-theme="dark"] .cat-cross__news a,
body[data-theme="dark"] .cat-cross__chips a{ background: var(--paper-3); border-color: var(--line); }
