/* Catalog Builder — фронтовые стили каталога.
   Все цвета берутся из CSS-переменных, которые задаёт админ. */

.cb-catalog {
	--cb-cols: 3;
	box-sizing: border-box;
	background: var(--cb-bg, #f4f5fb);
	color: var(--cb-text, #1e1b39);
	padding: clamp(16px, 3vw, 32px);
	border-radius: calc(var(--cb-radius, 16px) + 6px);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	line-height: 1.5;
}

.cb-catalog *,
.cb-catalog *::before,
.cb-catalog *::after {
	box-sizing: border-box;
}

.cb-catalog__title {
	margin: 0 0 18px;
	font-size: clamp(22px, 3vw, 30px);
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--cb-text);
}

/* --- Фильтр-чипы --- */
.cb-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 22px;
}

.cb-filter__chip {
	appearance: none;
	border: 1px solid var(--cb-border);
	background: var(--cb-surface);
	color: var(--cb-muted);
	font: inherit;
	font-weight: 600;
	font-size: 14px;
	padding: 9px 16px;
	border-radius: 999px;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.cb-filter__chip:hover {
	transform: translateY(-1px);
	border-color: var(--cb-primary);
	color: var(--cb-text);
}

.cb-filter__chip.is-active {
	background: var(--cb-primary);
	border-color: var(--cb-primary);
	color: var(--cb-btn-text);
	box-shadow: 0 8px 18px -8px var(--cb-primary);
}

.cb-filter__count {
	font-size: 12px;
	background: rgba(127, 127, 127, .18);
	border-radius: 999px;
	padding: 1px 8px;
	line-height: 1.6;
}

.cb-filter__chip.is-active .cb-filter__count {
	background: rgba(255, 255, 255, .25);
}

/* --- Сетка --- */
.cb-grid {
	display: grid;
	grid-template-columns: repeat(var(--cb-cols, 3), minmax(0, 1fr));
	gap: 18px;
}

/* --- Карточка --- */
.cb-card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 14px;
	background: var(--cb-surface);
	border: 1px solid var(--cb-border);
	border-radius: var(--cb-radius, 16px);
	padding: 20px;
	overflow: hidden;
	transition: transform .18s ease, box-shadow .25s ease, border-color .2s ease;
	box-shadow: 0 1px 2px rgba(16, 18, 40, .04);
}

.cb-card:hover {
	transform: translateY(-3px);
	border-color: color-mix(in srgb, var(--cb-primary) 40%, var(--cb-border));
	box-shadow: 0 22px 40px -24px rgba(16, 18, 40, .45);
}

.cb-card--featured {
	border-color: var(--cb-primary);
	box-shadow: 0 18px 38px -22px var(--cb-primary);
}

.cb-card--featured::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: linear-gradient(90deg, var(--cb-primary), var(--cb-accent));
}

.cb-card__flag {
	position: absolute;
	top: 14px;
	right: -32px;
	transform: rotate(45deg);
	background: var(--cb-accent);
	color: #1b1b1b;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: .08em;
	padding: 4px 36px;
	box-shadow: 0 4px 10px -4px rgba(0, 0, 0, .4);
}

.cb-card__head {
	display: grid;
	grid-template-columns: 52px 1fr auto;
	align-items: center;
	gap: 12px;
}

.cb-card__logo {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	overflow: hidden;
	background: color-mix(in srgb, var(--cb-primary) 12%, var(--cb-surface));
	border: 1px solid var(--cb-border);
}

/* Логотип-картинка: без цветной заливки, только рамка (для прозрачных PNG). */
.cb-card__logo--img {
	background: var(--cb-surface);
}

.cb-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cb-card__initials {
	font-weight: 800;
	font-size: 18px;
	color: var(--cb-primary);
	letter-spacing: -.02em;
}

.cb-card__title {
	margin: 0;
	font-size: 17px;
	font-weight: 750;
	line-height: 1.2;
	color: var(--cb-text);
}

.cb-card__subtitle {
	margin: 2px 0 0;
	font-size: 13px;
	color: var(--cb-muted);
}

/* Рейтинг */
.cb-card__rating {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 2px;
}

.cb-card__stars {
	position: relative;
	display: inline-block;
	font-size: 13px;
	line-height: 1;
	letter-spacing: 1px;
	color: var(--cb-border);
}

.cb-card__stars-fill {
	position: absolute;
	inset: 0;
	overflow: hidden;
	white-space: nowrap;
	color: var(--cb-accent);
}

.cb-card__rating-num {
	font-size: 13px;
	font-weight: 800;
	color: var(--cb-text);
}

/* Оффер */
.cb-catalog .cb-card__offer {
	display: flex !important;
	justify-content: flex-start !important;
	text-align: left !important;
}

.cb-card__offer span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: color-mix(in srgb, var(--cb-accent) 16%, var(--cb-surface));
	color: color-mix(in srgb, var(--cb-accent) 75%, var(--cb-text));
	border: 1px dashed color-mix(in srgb, var(--cb-accent) 55%, transparent);
	font-weight: 700;
	font-size: 13px;
	padding: 6px 12px;
	border-radius: 10px;
}

.cb-card__offer span::before {
	content: "🎁";
	font-size: 13px;
}

.cb-card__desc {
	margin: 0;
	font-size: 14px;
	color: var(--cb-muted);
	flex: 1;
}

/* Метрики */
.cb-card__stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
	gap: 8px;
	margin: 0;
	padding: 12px;
	background: color-mix(in srgb, var(--cb-text) 4%, var(--cb-surface));
	border-radius: 12px;
}

.cb-catalog .cb-card__stat {
	margin: 0;
	text-align: left !important;
}

.cb-card__stat dt {
	font-size: 11px;
	color: var(--cb-muted);
	margin: 0 0 2px;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.cb-card__stat dd {
	margin: 0;
	font-size: 14px;
	font-weight: 800;
	color: var(--cb-text);
}

/* Теги */
.cb-catalog .cb-card__badges {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	justify-content: flex-start !important;
	align-content: flex-start;
	align-items: flex-start;
	text-align: left !important;
	width: 100% !important;
	gap: 6px;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.cb-catalog .cb-card__badges li {
	display: inline-flex;
	align-items: center;
	width: auto !important;
	float: none !important;
	font-size: 12px;
	color: var(--cb-muted);
	background: color-mix(in srgb, var(--cb-primary) 8%, var(--cb-surface));
	border: 1px solid var(--cb-border);
	padding: 3px 10px;
	border-radius: 999px;
	margin: 0 !important;
}

/* Кнопка */
.cb-card__foot {
	margin-top: auto;
}

.cb-card__cta {
	display: inline-flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--cb-primary);
	color: var(--cb-btn-text);
	font-weight: 700;
	font-size: 15px;
	text-decoration: none;
	padding: 12px 18px;
	border-radius: 12px;
	transition: background .2s ease, transform .12s ease, box-shadow .2s ease;
}

.cb-card__cta:hover {
	background: var(--cb-primary-hover);
	transform: translateY(-1px);
	box-shadow: 0 12px 22px -12px var(--cb-primary);
	color: var(--cb-btn-text);
}

.cb-card__cta:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--cb-primary) 45%, transparent);
	outline-offset: 2px;
}

.cb-card__cta-icon {
	width: 16px;
	height: 16px;
}

.cb-card__cta--disabled {
	opacity: .5;
	cursor: not-allowed;
}

/* Пусто */
.cb-empty {
	text-align: center;
	color: var(--cb-muted);
	padding: 40px 10px;
	font-size: 15px;
}

.cb-empty--hidden {
	display: none;
}

/* Анимация фильтрации */
.cb-card.is-hidden {
	display: none;
}

.cb-card.is-enter {
	animation: cb-pop .28s ease both;
}

@keyframes cb-pop {
	from { opacity: 0; transform: translateY(8px) scale(.98); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Адаптив */
@media (max-width: 980px) {
	.cb-catalog { --cb-cols: 2 !important; }
}

@media (max-width: 600px) {
	.cb-catalog { --cb-cols: 1 !important; padding: 14px; }
	.cb-card__head { grid-template-columns: 46px 1fr; }
	.cb-card__rating { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: flex-start; gap: 8px; }
}

@media (prefers-reduced-motion: reduce) {
	.cb-card, .cb-card__cta, .cb-filter__chip { transition: none; }
	.cb-card.is-enter { animation: none; }
}
