/* Резонанс — стили под дизайн-схему zenitra.life.
 *
 * Правила (см. /design/):
 *   • острые углы — карточки/панели/модалки `var(--card-radius)=6px`, чипы `var(--pill-radius)=4px`
 *   • lowercase заголовки и UI-надписи
 *   • 4 металла — gold/silver/copper/patina; gold — default
 *   • точка-буллет `.` перед заголовком карточки (цвет = золото)
 *   • paper только точечно — для важных блоков (форма создания, прикреплённый расчёт)
 *   • плоский поток вокруг paper-блоков, чтобы было что выделять
 *
 * Прибиваемся к CSS-переменным main.css; .btn/.panel/.status-badge не переопределяем.
 */

/* ─── Layout: одноколоночник внутри .zn-main ─────────────────────────── */
/* Категории живут в верхней полосе фильтров (_filter_bar.html), отдельный
   правый сайдбар убрали как дублирующий — лента занимает всю ширину. */
.rz-layout {
	display: block;
	width: 100%;          /* ширину задаёт общий .zn-main-inner (единая для всех страниц) */
	padding: 8px 0 64px;
}
.rz-main-col { min-width: 0; width: 100%; }

/* ─── Шапка раздела ──────────────────────────────────────────────────── */
.rz-header { margin-bottom: 24px; }
.rz-h1 {
	font-size: var(--fs-display);
	font-weight: 300;
	margin: 0 0 8px;
	color: var(--text);
	text-transform: lowercase;
	letter-spacing: 0.01em;
}
.rz-h1::before {
	content: '. ';
	color: var(--accent);
	font-weight: 500;
}
.rz-sub {
	color: var(--text-dim);
	margin: 0;
	max-width: 60ch;
	line-height: 1.55;
	font-size: var(--fs-small);
}

/* ─── Filter bar — стиль .back-link, как в дизайн-системе ────────────── */
.rz-filterbar {
	display: flex; flex-wrap: wrap; gap: 6px;
	margin: 20px 0 4px;
}
.rz-filter, .rz-filter-disabled {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 7px 14px;
	border-radius: var(--pill-radius);
	font-size: var(--fs-small);
	color: var(--text-dim);
	text-transform: lowercase;
	transition: all .15s ease;
	white-space: nowrap;
	border: 1px solid transparent;
}
.rz-filter:hover { color: var(--text); background: var(--bg-card); }
.rz-filter.is-active {
	color: var(--accent);
	background: rgba(199, 155, 102, 0.08);
	border-color: rgba(199, 155, 102, 0.3);
}
.rz-filter-disabled { opacity: 0.4; cursor: not-allowed; }

.rz-subfilterbar {
	display: flex; flex-wrap: wrap; gap: 6px;
	margin: 4px 0 18px;
	padding: 0 2px;
}
.rz-subfilter, .rz-subfilter-back {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 4px 10px;
	border-radius: var(--pill-radius);
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: lowercase;
	border: 1px solid transparent;
}
.rz-subfilter:hover { color: var(--text); }
.rz-subfilter.is-active {
	color: var(--accent);
	border-color: var(--accent);
}
.rz-subfilter-back:hover { color: var(--accent); }

/* ─── Hero-плашка на странице автора (расширенный баннер) ───────────── */
.rz-author-hero {
	display: flex; flex-direction: column;
	gap: 16px;
	margin: 12px 0 20px;
	padding: 20px 22px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
}
.rz-author-hero-top {
	display: flex; align-items: flex-start; justify-content: space-between;
	gap: 14px; flex-wrap: wrap;
}
.rz-author-hero-chip { flex: 1 1 auto; min-width: 0; }
/* В hero автор крупнее, чем в ленте — как на странице поста. */
.rz-author-hero-chip .rz-author-avatar { width: 64px; height: 64px; font-size: 1.3rem; }
.rz-author-hero-chip .rz-author-name { font-size: var(--fs-h3); }
.rz-author-hero-chip .rz-author { gap: 14px; }
.rz-author-hero-follow { flex: 0 0 auto; }

.rz-author-hero-bio {
	margin: 0;
	color: var(--text);
	font-size: var(--fs-body);
	line-height: 1.55;
	max-width: 60ch;
}
.rz-author-hero-bio-empty {
	color: var(--text-mute);
	font-style: italic;
	font-size: var(--fs-small);
}

/* Нижний блок с уровнем и счётчиками: 2-колоночный, прогресс слева, статы справа. */
.rz-author-hero-stats {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 20px 32px;
	padding-top: 14px;
	border-top: 1px dashed rgba(255, 255, 255, 0.06);
}
@media (max-width: 600px) {
	.rz-author-hero-stats { grid-template-columns: 1fr; gap: 16px; }
}

.rz-author-hero-level { min-width: 0; }
.rz-author-hero-level-head {
	display: flex; flex-wrap: wrap; align-items: baseline;
	gap: 6px 10px;
	margin-bottom: 10px;
}
.rz-author-hero-level-cap {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--text-mute);
}
.rz-author-hero-level-num {
	font-size: 1.4rem;
	color: var(--gold);
	font-variant-numeric: tabular-nums;
	font-weight: 500;
	line-height: 1;
}
.rz-author-hero-level-title {
	font-size: var(--fs-body);
	color: var(--patina);
	text-transform: lowercase;
	letter-spacing: 0.02em;
}

/* Прогресс-бар до следующего уровня — тонкая полоска patina на dim-фоне. */
.rz-author-hero-level-progress { max-width: 360px; }
.rz-author-hero-level-bar {
	height: 4px;
	background: rgba(255, 255, 255, 0.05);
	border-radius: 2px;
	overflow: hidden;
}
.rz-author-hero-level-fill {
	height: 100%;
	background: var(--patina);
	border-radius: 2px;
	transition: width .35s ease;
	box-shadow: 0 0 6px rgba(107, 155, 133, 0.45);
}
.rz-author-hero-level-progress-cap {
	font-size: var(--fs-micro);
	text-transform: lowercase;
	letter-spacing: 0.02em;
	margin-top: 6px;
	font-variant-numeric: tabular-nums;
}

/* Счётчики в правой колонке: 3 строки key/value, выровненные по правому краю. */
.rz-author-hero-counts {
	display: flex; flex-direction: column;
	gap: 6px;
	margin: 0;
	text-align: right;
}
.rz-author-hero-count {
	display: flex; align-items: baseline; justify-content: flex-end;
	gap: 8px;
}
.rz-author-hero-count dt {
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: lowercase;
	letter-spacing: 0.02em;
	order: 2;                       /* лейбл справа от числа */
}
.rz-author-hero-count dd {
	margin: 0;
	font-size: var(--fs-body);
	color: var(--text);
	font-variant-numeric: tabular-nums;
	font-weight: 500;
	min-width: 24px;
	order: 1;
}
@media (max-width: 600px) {
	.rz-author-hero-counts { text-align: left; }
	.rz-author-hero-count { justify-content: flex-start; }
}

.rz-follow-form { display: inline-flex; }
.rz-follow {
	background: var(--accent);
	color: #1a1a1a;
	border: 1px solid var(--accent);
	padding: 7px 16px;
	border-radius: var(--pill-radius);
	font-size: var(--fs-small);
	text-transform: lowercase;
	cursor: pointer;
	font-family: inherit;
	letter-spacing: 0.02em;
	transition: all .15s;
}
.rz-follow:hover { filter: brightness(1.1); }
.rz-follow.is-following {
	background: transparent;
	color: var(--text-dim);
	border-color: var(--border-2);
}
.rz-follow.is-following:hover {
	color: var(--copper);
	border-color: var(--copper);
	background: rgba(184, 117, 83, 0.05);
}

/* ─── Пустое состояние (подписок ещё нет, авторы скрыты) ──────────────── */
.rz-empty {
	padding: 24px 22px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	color: var(--text-dim);
	font-size: var(--fs-small);
	text-transform: lowercase;
	margin: 8px 0 16px;
}

/* ─── Лента — плоские карточки на --bg-card ──────────────────────────── */
.rz-feed { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }

.rz-card {
	background: var(--bg-card);
	border-radius: var(--card-radius);
	padding: 20px 22px;
	transition: background .15s;
}
.rz-card:hover { background: var(--bg-card-hover); }

.rz-card-head {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px; margin-bottom: 12px;
}
.rz-card-time {
	font-size: var(--fs-micro); color: var(--text-mute);
	text-transform: lowercase;
	white-space: nowrap;
}
.rz-card-time:hover { color: var(--accent); }

.rz-card-body { display: block; color: inherit; }
.rz-card-cover {
	margin-bottom: 12px;
	border-radius: var(--card-radius);
	overflow: hidden;
	aspect-ratio: 2 / 1;
	background: var(--bg-2);
}
.rz-card-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

.rz-card-title {
	font-size: var(--fs-h3);
	font-weight: 500;
	margin: 0 0 6px;
	color: var(--text);
	line-height: 1.35;
	letter-spacing: 0.3px;
}
.rz-card-title::before {
	content: '.';
	color: var(--accent);
	margin-right: 6px;
	font-weight: 700;
}
.rz-card:hover .rz-card-title::before { color: var(--copper); }
.rz-card-lead {
	margin: 0;
	color: var(--text-dim);
	line-height: 1.55;
	font-size: var(--fs-small);
	display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}

.rz-card-attachments { margin: 14px 0 4px; display: flex; flex-direction: column; gap: 8px; }

.rz-card-foot {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px; margin-top: 14px; flex-wrap: wrap;
}
.rz-card-tags { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.rz-card-actions {
	display: flex; gap: 16px;
	color: var(--text-mute);
	font-size: var(--fs-micro);
}
.rz-action { display: inline-flex; align-items: center; gap: 4px; }
.rz-action-mute { opacity: 0.6; }

/* ─── Чипы (теги и категории) — .role-tag-стиль ──────────────────────── */
.rz-tag {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 3px 9px;
	border-radius: var(--pill-radius);
	background: transparent;
	color: var(--text-dim);
	font-size: var(--fs-micro);
	text-transform: lowercase;
	border: 1px solid var(--border);
	letter-spacing: 0.02em;
}
.rz-tag:hover { color: var(--accent); border-color: rgba(199,155,102,0.4); }
.rz-tag-cat {
	background: rgba(199, 155, 102, 0.12);
	color: var(--gold);
	border-color: rgba(199, 155, 102, 0.35);
}
.rz-tag-cat:hover { color: var(--gold); border-color: var(--gold); }
.rz-tag-mute {
	color: var(--text-mute);
	border-color: transparent;
}

/* ─── Author chip ────────────────────────────────────────────────────── */
.rz-author {
	display: flex; align-items: center; gap: 10px;
	color: var(--text);
	text-decoration: none;
}
.rz-author:hover .rz-author-name { color: var(--accent); }
/* Обёртка: position-контейнер для аватара + SVG-ринга поверх.
   Размер не фиксируем — auto по child-аватару (он используется с разными
   размерами: 28 в reply, 36 в ленте, 64 в hero, и т.д.). */
.rz-author-avatar-wrap {
	position: relative;
	flex-shrink: 0;
	display: inline-flex;
	line-height: 0;        /* убираем baseline-щель внизу */
}
.rz-author-avatar {
	position: relative;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: linear-gradient(135deg, #2a2a2a, #1a1a1a);
	color: var(--text-dim);
	font-weight: 500; font-size: var(--fs-small);
	display: flex; align-items: center; justify-content: center;
	overflow: hidden;
	border: 1px solid var(--border);
}
.rz-author-avatar img { width: 100%; height: 100%; object-fit: cover; }

/* SVG-ринг с 6-сегментной шкалой уровня резонатора. Лежит абсолютом
   поверх аватара, заметно крупнее (явный «воздух» между ним и аватаром),
   pointer-events:none чтобы не перехватывать клики. */
.zn-avatar-ring {
	position: absolute;
	inset: -7px;            /* визуальный отступ от аватара */
	width: calc(100% + 14px);
	height: calc(100% + 14px);
	pointer-events: none;
}
.rz-author-text {
	display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.rz-author-name {
	font-weight: 500;
	font-size: var(--fs-small);
	color: var(--text);
	display: inline-flex; align-items: center; gap: 6px;
	letter-spacing: 0.02em;
}
.rz-badge {
	font-size: var(--fs-micro);
	padding: 1px 6px;
	border-radius: var(--pill-radius);
	background: rgba(199, 155, 102, 0.15);
	color: var(--gold);
	border: 1px solid rgba(199, 155, 102, 0.4);
}
.rz-author-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.rz-chip {
	font-size: var(--fs-micro);
	padding: 1px 7px;
	border-radius: var(--pill-radius);
	color: var(--text-mute);
	text-transform: lowercase;
	letter-spacing: 0.02em;
}
.rz-chip-hd { color: var(--silver); }
.rz-chip-astro { color: var(--patina); }
.rz-chip-meta { color: var(--text-mute); }

/* ─── Прикреплённый расчёт — paper-блок (важный) ─────────────────────── */
.rz-attach {
	background: #141414;
	border-radius: var(--card-radius);
	padding: 12px 16px;
	position: relative;
	overflow: hidden;
	box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
.rz-attach::after {
	content: "";
	position: absolute; inset: 0;
	background-image:
		radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.04), transparent 60%),
		radial-gradient(circle at 70% 80%, rgba(0, 0, 0, 0.2), transparent 70%);
	mix-blend-mode: overlay;
	pointer-events: none;
}
.rz-attach > * { position: relative; z-index: 1; }
.rz-attach-label {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--gold);
	margin-bottom: 6px;
	font-weight: 500;
}
.rz-attach-row { display: flex; align-items: center; gap: 12px; }
.rz-attach-avatar {
	width: 34px; height: 34px;
	border-radius: 50%;
	background: linear-gradient(135deg, #2a2218, #1a1a1a);
	color: var(--gold);
	font-weight: 500;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
	border: 1px solid rgba(199, 155, 102, 0.3);
}
.rz-attach-avatar-pair {
	border: 0; background: none;
	display: flex; gap: 0;
}
.rz-attach-avatar-pair span {
	width: 32px; height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, #2a2218, #1a1a1a);
	color: var(--gold);
	display: flex; align-items: center; justify-content: center;
	font-weight: 500;
	border: 1px solid rgba(199, 155, 102, 0.3);
}
.rz-attach-avatar-pair span + span { margin-left: -8px; }
.rz-attach-body { min-width: 0; }
.rz-attach-name {
	font-weight: 500;
	color: var(--text);
	font-size: var(--fs-small);
}
.rz-attach-sub {
	color: var(--text-dim);
	font-size: var(--fs-micro);
	text-transform: lowercase;
}

/* ─── Правый сайдбар ─────────────────────────────────────────────────── */
.rz-rightbar {
	align-self: start;
	display: flex; flex-direction: column;
	gap: 28px;
}
.rz-rb-block { padding-bottom: 4px; }
.rz-rb-title {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--text-mute);
	margin: 0 0 12px;
	font-weight: 500;
}

.rz-rb-cats {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column;
}
.rz-rb-cat-link {
	display: flex; align-items: center; gap: 8px;
	padding: 6px 0;
	color: var(--text-dim);
	font-size: var(--fs-small);
	text-transform: lowercase;
	text-decoration: none;
	letter-spacing: 0.01em;
}
.rz-rb-cat-link:hover { color: var(--text); }
.rz-rb-cat-link.is-active { color: var(--accent); }
.rz-rb-cat-icon { width: 18px; text-align: center; flex-shrink: 0; }
.rz-rb-topics {
	list-style: none; padding: 0 0 6px 26px; margin: 0;
	display: flex; flex-direction: column;
}
.rz-rb-topic {
	display: block; padding: 3px 0;
	color: var(--text-mute);
	font-size: var(--fs-micro);
	text-transform: lowercase;
	text-decoration: none;
}
.rz-rb-topic:hover { color: var(--text-dim); }
.rz-rb-topic.is-active { color: var(--accent); }

.rz-rb-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.rz-rb-tag {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 3px 9px;
	border-radius: var(--pill-radius);
	color: var(--text-dim);
	font-size: var(--fs-micro);
	text-transform: lowercase;
	border: 1px solid var(--border);
	text-decoration: none;
	letter-spacing: 0.02em;
}
.rz-rb-tag:hover { color: var(--accent); border-color: rgba(199,155,102,0.4); }
.rz-rb-tag.is-active {
	color: var(--accent);
	border-color: var(--accent);
	background: rgba(199, 155, 102, 0.08);
}
.rz-rb-tag-count {
	color: var(--text-mute);
	margin-left: 2px;
}

/* ─── Loader infinite-scroll ─────────────────────────────────────────── */
.rz-loader {
	padding: 24px;
	text-align: center;
	color: var(--text-mute);
	font-size: var(--fs-micro);
	text-transform: lowercase;
}
.rz-loader-pulse { animation: rz-pulse 1.4s ease-in-out infinite; }
@keyframes rz-pulse { 0%, 100% { opacity: 0.3; } 50% { opacity: 1; } }
.rz-end {
	padding: 32px;
	text-align: center;
	font-size: var(--fs-micro);
	text-transform: lowercase;
}

/* ─── Страница поста: split-layout (пост слева, комментарии справа) ─── */
.rz-post-page {
	margin: 0 0 64px;
}
.rz-back-top { display: inline-block; margin-bottom: 18px; }

.rz-post-split {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 32px;
	align-items: start;
}
@media (max-width: 980px) {
	.rz-post-split {
		grid-template-columns: 1fr;
		gap: 28px;
	}
}

.rz-post {
	min-width: 0;
	margin: 0;
	color: var(--text);
}
.rz-back {
	font-size: var(--fs-small);
	display: inline-block;
	margin-bottom: 18px;
	text-transform: lowercase;
	color: var(--text-dim);
	text-decoration: none;
}
.rz-back:hover { color: var(--accent); }
.rz-post-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.rz-post-cover {
	margin: 0 0 22px;
	border-radius: var(--card-radius);
	overflow: hidden;
	aspect-ratio: 2/1;
	background: var(--bg-2);
}
.rz-post-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rz-post-title {
	font-size: var(--fs-display);
	font-weight: 300;
	margin: 0 0 12px;
	line-height: 1.25;
	letter-spacing: 0.01em;
	color: var(--text);
}
.rz-post-title::before {
	content: '. ';
	color: var(--accent);
	font-weight: 500;
}
.rz-post-lead {
	font-size: var(--fs-h3);
	color: var(--text-dim);
	margin: 0 0 24px;
	line-height: 1.55;
	font-weight: 300;
}
.rz-post-author-row {
	padding: 16px 0;
	border-top: 1px solid var(--border);
}

/* Хаб-плашка info-строки поста. Двухуровневая:
   1) верх — автор слева, actions (+ резонанс, скрыть) справа
   2) низ — тонкая meta-строка (дата · категория · топик), выровненная
   под именем автора через padding-left = ширина аватара + gap. */
.rz-post-info {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 0 0 20px;
	padding: 14px 18px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
}
.rz-post-info-top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: nowrap;          /* действия всегда в правом верхнем углу;
	                               автор сжимается (min-width:0), чипы внутри
	                               него переносятся (.rz-author-chips flex-wrap). */
}
.rz-post-info-author { flex: 1 1 auto; min-width: 0; }
/* В info-блоке поста автор крупнее, чем в ленте — это hero-зона страницы. */
.rz-post-info-author .rz-author-avatar { width: 52px; height: 52px; font-size: 1.1rem; }
.rz-post-info-author .rz-author-name { font-size: var(--fs-body); }
.rz-post-info-author .rz-author { gap: 12px; }
.rz-post-info-actions {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	gap: 10px;
}
.rz-post-info-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px 10px;
	padding-left: 0;               /* бейджи слева, под аватаром */
	font-size: var(--fs-small);
	color: var(--text-dim);
}
.rz-post-info-meta .rz-post-date {
	margin-left: auto;             /* дата публикации прижата вправо */
	color: var(--text-mute);
	text-transform: lowercase;
	letter-spacing: 0.02em;
	font-variant-numeric: tabular-nums;
}
.rz-post-info-sep { color: var(--text-mute); }
/* На узких экранах padding-left убираем — meta встаёт под автором без отступа. */
@media (max-width: 600px) {
	.rz-post-info-meta { padding-left: 0; }
	/* Действия (резонанс/скрыть) переносим на строку ниже — иначе они
	   зажимают имя автора в узкий столбец, и оно ломается по словам.
	   Автор получает всю ширину строки, действия прижаты вправо снизу. */
	.rz-post-info-top { flex-wrap: wrap; }
	.rz-post-info-actions { margin-left: auto; }
}

.rz-post-body { font-size: var(--fs-body); line-height: 1.7; }
.rz-post-body .rz-p { margin: 0 0 14px; }
.rz-post-body .rz-h {
	margin: 28px 0 10px;
	line-height: 1.3;
	font-weight: 500;
	color: var(--text);
	letter-spacing: 0.2px;
}
.rz-post-body .rz-h2 { font-size: var(--fs-h2); }
.rz-post-body .rz-h3 { font-size: var(--fs-h3); }
.rz-post-body .rz-h4 { font-size: var(--fs-body); font-weight: 500; }
.rz-post-body .rz-h::before {
	content: '. ';
	color: var(--accent);
	font-weight: 700;
}
.rz-post-body .rz-list { padding-left: 1.4em; margin: 0 0 14px; }
.rz-post-body .rz-list li { margin-bottom: 4px; }
.rz-post-body .rz-quote {
	margin: 18px 0;
	padding: 14px 20px;
	border-left: 2px solid var(--accent);
	background: var(--bg-card);
	border-radius: 0 var(--card-radius) var(--card-radius) 0;
}
.rz-post-body .rz-quote-text {
	font-style: italic;
	color: var(--text);
}
.rz-post-body .rz-quote-cite {
	display: block;
	margin-top: 6px;
	color: var(--text-mute);
	font-size: var(--fs-small);
	font-style: normal;
}
.rz-post-body .rz-delim {
	border: 0; height: 1px;
	margin: 32px auto;
	max-width: 120px;
	background: var(--border-2);
}
.rz-post-body .rz-figure { margin: 22px 0; }
.rz-post-body .rz-figure img {
	width: 100%;
	border-radius: var(--card-radius);
	display: block;
}
.rz-post-body .rz-figure figcaption {
	color: var(--text-mute);
	font-size: var(--fs-micro);
	text-align: center;
	margin-top: 8px;
	text-transform: lowercase;
}
.rz-post-body a {
	color: var(--accent);
	text-decoration: underline;
	text-decoration-color: rgba(199,155,102,0.35);
	text-underline-offset: 2px;
}
.rz-post-body a:hover { text-decoration-color: var(--accent); }
.rz-post-body code {
	background: var(--bg-2);
	padding: 1px 6px;
	border-radius: var(--pill-radius);
	font-family: ui-monospace, 'Menlo', monospace;
	font-size: 0.92em;
	color: var(--text);
}
.rz-post-body mark {
	background: rgba(199,155,102,0.2);
	color: inherit;
	padding: 0 3px;
	border-radius: 2px;
}

.rz-post-tags {
	margin: 32px 0 12px;
	display: flex; flex-wrap: wrap; gap: 6px;
}
.rz-post-actions {
	display: flex; align-items: center; gap: 16px;
	padding: 16px 0;
	border-top: 1px solid var(--border);
}
.rz-comments-stub {
	margin: 32px 0;
	text-align: center;
	padding: 28px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	color: var(--text-mute);
	font-size: var(--fs-small);
	text-transform: lowercase;
}

/* ─── Комментарии (правая половина страницы поста) ──────────────────── */
.rz-comments {
	min-width: 0;
	display: flex; flex-direction: column;
	gap: 16px;
	/* Комменты идут естественным потоком вниз без sticky/max-height —
	   прокрутка только страничная, не внутренняя. */
}

.rz-comments-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.rz-comments-title {
	font-size: var(--fs-h3);
	font-weight: 500;
	margin: 0;
	color: var(--text);
	text-transform: lowercase;
	letter-spacing: 0.2px;
}
.rz-comments-title::before {
	content: '.';
	color: var(--accent);
	font-weight: 700;
	margin-right: 4px;
}
.rz-comments-count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 22px; height: 22px;
	padding: 0 7px;
	margin-left: 6px;
	background: var(--bg-2);
	color: var(--text-dim);
	border-radius: var(--pill-radius);
	font-size: var(--fs-micro);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	letter-spacing: 0.04em;
	vertical-align: 2px;
}

.rz-comments-list {
	display: flex; flex-direction: column;
	gap: 10px;
}
.rz-comments-empty {
	padding: 20px 16px;
	text-align: center;
	font-size: var(--fs-small);
	text-transform: lowercase;
}
.rz-comments-locked {
	padding: 14px 16px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	font-size: var(--fs-small);
	text-align: center;
	text-transform: lowercase;
}

.rz-comment {
	background: var(--bg-card);
	border-radius: var(--card-radius);
	padding: 12px 14px 14px;
	padding-right: 84px;            /* место под corner с большим [+] и [×] */
	position: relative;
	transition: background .12s;
}
.rz-comment:hover { background: var(--bg-card-hover); }
.rz-comment.is-hidden { opacity: 0.6; border-left: 3px solid var(--copper); padding-left: 11px; }
.rz-comment.is-hidden-by-author { opacity: 0.85; border-left-color: var(--text-mute); }

.rz-comment-head {
	display: flex; align-items: center;
	gap: 8px; margin-bottom: 8px;
}
.rz-comment-head .rz-author-avatar { width: 28px; height: 28px; }
.rz-comment-head .rz-author-name { font-size: var(--fs-small); }
.rz-comment-head .rz-author-chips { gap: 3px; }
.rz-comment-head .rz-chip { font-size: 0.66rem; padding: 0 5px; }
.rz-comment-time {
	font-size: 0.72rem;
	color: var(--text-mute);
	text-transform: lowercase;
	white-space: nowrap;
}
.rz-comment-corner .rz-comment-time { margin-right: 4px; }
.rz-comment-body {
	font-size: var(--fs-small);
	line-height: 1.55;
	color: var(--text);
	word-wrap: break-word;
}
.rz-comment-placeholder {
	font-size: var(--fs-small);
	color: var(--text-mute);
	font-style: italic;
	padding: 4px 0;
}

/* ── Corner-actions: большой [+] и маленький [×] в правом верхнем углу ── */
.rz-comment-corner {
	position: absolute;
	top: 8px; right: 10px;
	display: flex; align-items: center; gap: 8px;
	z-index: 1;
}
.rz-comment-flag {
	font-size: var(--fs-micro);
	color: var(--copper);
	text-transform: lowercase;
	margin-top: 6px;
}
.rz-comment-del {
	position: absolute; top: 8px; right: 8px;
	margin: 0;
}
.rz-comment-del-btn {
	background: transparent;
	border: 0;
	color: var(--text-mute);
	cursor: pointer;
	width: 22px; height: 22px;
	border-radius: 50%;
	font-size: 1rem;
	line-height: 1;
	opacity: 0;
	transition: opacity .15s, color .15s, background .15s;
}
.rz-comment:hover .rz-comment-del-btn { opacity: 1; }
.rz-comment-del-btn:hover {
	color: var(--copper);
	background: rgba(184, 117, 83, 0.12);
}

/* «+ N» лайк коммента — главное действие, заметная капсула.
   default: gold-обводка → hover/liked: full patina. */
.rz-clike-form { display: inline-flex; margin: 0; }
.rz-clike {
	display: inline-flex; align-items: center; gap: 6px;
	background: transparent;
	border: 1px solid rgba(199, 155, 102, 0.35);
	color: var(--gold);
	padding: 5px 12px;
	border-radius: var(--pill-radius);
	font-family: inherit;
	font-size: var(--fs-small);
	font-weight: 500;
	line-height: 1;
	cursor: pointer;
	transition: all .12s;
	letter-spacing: 0.02em;
}
.rz-clike:hover {
	color: var(--patina);
	border-color: var(--patina);
	background: rgba(107, 155, 133, 0.06);
}
.rz-clike.is-liked {
	color: #1a1a1a;
	border-color: var(--patina);
	background: var(--patina);
}
.rz-clike-icon { font-weight: 700; font-size: 1rem; line-height: 1; }
.rz-clike-count { font-variant-numeric: tabular-nums; }

/* Мьютед-вариант: для автора (нельзя лайкнуть себя) и для гостя */
.rz-clike-mute {
	cursor: default;
	color: var(--text-mute);
	border-color: var(--border);
}
.rz-clike-mute:hover {
	color: var(--text-mute);
	border-color: var(--border);
	background: transparent;
}

/* «×» удалить/скрыть — мини, слева от плюса, ненавязчиво */
.rz-comment-corner .rz-comment-del { position: static; margin: 0; }
.rz-comment-corner .rz-comment-del-btn {
	opacity: 0.5;
	width: 22px; height: 22px;
	font-size: 1rem;
	border: 0;
	background: transparent;
	color: var(--text-mute);
	cursor: pointer;
	border-radius: 50%;
	transition: opacity .12s, color .12s, background .12s;
}
.rz-comment-corner .rz-comment-del-btn:hover {
	opacity: 1;
	color: var(--copper);
	background: rgba(184, 117, 83, 0.12);
}

/* ─── Модалка жалобы ──────────────────────────────────────────────── */
.rz-report-card { max-width: 480px; }
.rz-report-card .modal-sub {
	font-size: var(--fs-small);
	margin: 6px 0 16px;
}

.rz-report-reasons {
	display: flex; flex-direction: column;
	gap: 4px;
	border: 0;
	padding: 0;
	margin: 0 0 14px;
}
.rz-report-reason {
	display: flex; align-items: center; gap: 10px;
	padding: 8px 12px;
	border-radius: var(--pill-radius);
	cursor: pointer;
	font-size: var(--fs-small);
	color: var(--text-dim);
	transition: background .1s, color .1s;
}
.rz-report-reason:hover { background: var(--bg-2); color: var(--text); }
.rz-report-reason input[type=radio] {
	accent-color: var(--copper);
	margin: 0;
}
.rz-report-reason:has(input:checked) {
	background: rgba(184, 117, 83, 0.08);
	color: var(--text);
}

.rz-report-message {
	width: 100%;
	background: var(--bg-2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: var(--card-radius);
	padding: 10px 12px;
	font-family: inherit;
	font-size: var(--fs-small);
	resize: vertical;
	min-height: 60px;
	line-height: 1.5;
	margin-bottom: 14px;
}
.rz-report-message:focus { outline: none; border-color: var(--accent); }

.rz-report-actions {
	display: flex; justify-content: space-between;
	gap: 10px;
}
.rz-report-ack {
	padding: 16px;
	background: rgba(107, 155, 133, 0.1);
	color: var(--patina);
	border-radius: var(--card-radius);
	text-align: center;
	font-size: var(--fs-small);
}
.rz-report-ack-wrap { padding: 8px 0; }

/* ─── Страница жалоб (staff) ─────────────────────────────────────── */
.rz-report-card-mod {
	background: var(--bg-card);
	border-radius: var(--card-radius);
	padding: 18px 22px 18px 26px;
	position: relative;
	overflow: hidden;
	display: flex; flex-direction: column;
	gap: 12px;
}
.rz-report-card-mod::before {
	content: ""; position: absolute;
	left: 0; top: 0; bottom: 0; width: 3px;
	background: var(--copper);
}
.rz-report-mod-head {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px;
}
.rz-report-target { padding: 2px 0; }
.rz-report-target-label {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 4px;
}
.rz-report-target-link {
	color: var(--accent);
	font-size: var(--fs-small);
	text-transform: lowercase;
}
.rz-report-target-link:hover { text-decoration: underline; }
.rz-report-target-body {
	background: var(--bg-2);
	border-left: 2px solid var(--border-2);
	margin: 8px 0;
	padding: 10px 14px;
	font-size: var(--fs-small);
	color: var(--text-dim);
	line-height: 1.55;
	font-style: italic;
}
.rz-report-target-meta { font-size: var(--fs-micro); }

.rz-report-message-block {
	background: var(--bg-2);
	border-radius: var(--card-radius);
	padding: 10px 14px;
	font-size: var(--fs-small);
	color: var(--text);
}
.rz-report-message-label {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 4px;
}

.rz-report-reporter { padding: 4px 0; }
.rz-report-actions-mod {
	display: flex; gap: 8px;
	flex-wrap: wrap;
	border-top: 1px solid var(--border);
	padding-top: 12px;
}
.rz-report-actions-mod .btn { padding: 6px 14px; font-size: var(--fs-small); }

/* Форма нового комментария */
.rz-comment-form {
	display: flex; flex-direction: column; gap: 10px;
	padding-top: 12px;
	border-top: 1px solid var(--border);
}
.rz-comment-input {
	background: var(--bg-2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: var(--card-radius);
	padding: 10px 12px;
	font-family: inherit;
	font-size: var(--fs-small);
	resize: vertical;
	min-height: 70px;
	line-height: 1.5;
}
.rz-comment-input:focus {
	outline: none;
	border-color: var(--accent);
}
.rz-comment-form-actions {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px;
}
.rz-comment-form-hint { font-size: var(--fs-micro); }

/* ── Ответы (2-й уровень) — без фона, разделены линией ─────────────── */
.rz-replies {
	display: flex; flex-direction: column;
	gap: 0;
	margin: 12px 0 0 16px;
}
.rz-replies:empty { display: none; }

.rz-reply {
	background: transparent;
	border-radius: 0;
	padding: 10px 0;
	padding-right: 78px;
	position: relative;
	font-size: var(--fs-small);
}
.rz-reply + .rz-reply {
	border-top: 1px dashed var(--border);
}
.rz-reply:hover { background: transparent; }
.rz-reply.is-hidden { opacity: 0.6; }
.rz-reply.is-hidden-by-author { opacity: 0.85; }

/* corner в reply сидит сверху-справа, но в общем потоке (без bg) */
.rz-reply .rz-comment-corner { top: 8px; right: 0; }
.rz-reply .rz-comment-head { margin-bottom: 4px; }
.rz-reply .rz-comment-head .rz-author-avatar { width: 22px; height: 22px; }
.rz-reply .rz-comment-head .rz-author-name { font-size: var(--fs-micro); }
.rz-reply .rz-comment-head .rz-author-chips { display: none; }
.rz-reply .rz-comment-time { font-size: 0.68rem; }
.rz-reply .rz-comment-body { font-size: var(--fs-small); }

/* Мини-плашка ответа под скрытым родителем */
.rz-reply-orphan {
	font-size: var(--fs-micro);
	color: var(--text-mute);
	font-style: italic;
	margin-top: 4px;
}

.rz-reply .rz-comment-head { margin-bottom: 6px; }
.rz-reply .rz-comment-time { font-size: 0.7rem; }
.rz-reply .rz-comment-body { font-size: var(--fs-small); }
.rz-reply .rz-author-avatar { width: 28px; height: 28px; }
.rz-reply .rz-author-name { font-size: var(--fs-micro); }
.rz-reply .rz-author-chips { display: none; }   /* в ответах не нужны эзо-чипы */

/* «ответить» — pill-кнопка под комментарием, выраженно но компактно */
.rz-reply-toggle {
	display: inline-flex; align-items: center;
	gap: 4px;
	background: transparent;
	border: 1px solid var(--border-2);
	color: var(--text-dim);
	font-family: inherit;
	font-size: var(--fs-micro);
	text-transform: lowercase;
	padding: 4px 12px;
	margin: 12px 0 0 0;
	cursor: pointer;
	letter-spacing: 0.02em;
	border-radius: var(--pill-radius);
	transition: all .12s;
}
.rz-reply-toggle:hover {
	color: var(--accent);
	border-color: var(--accent);
	background: rgba(199, 155, 102, 0.06);
}
.rz-reply-toggle::before { content: '› '; }

/* Свернуть/показать ответы в ветке. */
.rz-replies-toggle {
	background: none;
	border: 0;
	padding: 3px 0;
	margin: 2px 0 6px;
	color: var(--text-mute);
	font: inherit;
	font-size: var(--fs-small);
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: color 0.12s;
}
.rz-replies-toggle::before { content: '↳ '; }
.rz-replies-toggle:hover { color: var(--accent); }

/* Фильтр сортировки комментов: новые / популярные. */
.rz-comment-filter {
	display: flex;
	gap: 6px;
	margin: 0;
	flex: 0 0 auto;
}
.rz-comment-filter button {
	background: none;
	border: 0;
	padding: 4px 10px;
	border-radius: var(--pill-radius);
	color: var(--text-mute);
	font: inherit;
	font-size: var(--fs-small);
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: color 0.12s, background 0.12s;
}
.rz-comment-filter button:hover { color: var(--text); }
.rz-comment-filter button.is-active {
	color: var(--accent);
	background: rgba(199, 155, 102, 0.08);
}

/* Сабформа ответа */
.rz-reply-form {
	display: flex; flex-direction: column;
	gap: 8px;
	margin: 8px 0 0 16px;
}
.rz-reply-input {
	background: var(--bg-2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: var(--card-radius);
	padding: 8px 10px;
	font-family: inherit;
	font-size: var(--fs-small);
	resize: vertical;
	min-height: 50px;
	line-height: 1.5;
}
.rz-reply-input:focus { outline: none; border-color: var(--accent); }
.rz-reply-form-actions { display: flex; gap: 8px; }
.rz-reply-form-actions .btn { padding: 5px 12px; font-size: var(--fs-micro); }

/* «+ N» голос одобрения — главная кнопка под постом.
   Цвет patina (#6b9b85, наш бренд-зелёный из 4 металлов = success/одобрение).
   Outline по умолчанию, заполненная капсула когда голос отдан. */
.rz-like-form { display: inline-flex; }
.rz-like {
	background: transparent;
	border: 1px solid var(--patina);
	cursor: pointer;
	color: var(--patina);
	padding: 6px 14px;
	border-radius: var(--pill-radius);
	display: inline-flex; align-items: center; gap: 8px;
	font-size: var(--fs-small);
	font-weight: 500;
	text-transform: lowercase;
	letter-spacing: 0.02em;
	transition: all .15s;
	font-family: inherit;
}
.rz-like:hover {
	background: rgba(107, 155, 133, 0.12);
}
.rz-like.is-liked {
	background: var(--patina);
	color: #1a1a1a;
	border-color: var(--patina);
}
.rz-like.is-liked:hover {
	filter: brightness(1.1);
}
.rz-like-icon {
	font-size: 1rem;
	line-height: 1;
	font-weight: 700;
}
.rz-like-count {
	font-variant-numeric: tabular-nums;
}

/* ─── Редактор поста ─────────────────────────────────────────────────── */
.rz-editor-page {
	max-width: 760px;
	margin: 0 auto 64px;
}
.rz-editor-head {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px; margin-bottom: 24px; flex-wrap: wrap;
}
.rz-editor-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.rz-save-state {
	font-size: var(--fs-micro);
	text-transform: lowercase;
	color: var(--text-mute);
}

.rz-editor-form { display: flex; flex-direction: column; gap: 14px; }

.rz-title-input, .rz-lead-input {
	background: transparent;
	border: 0;
	outline: none;
	color: var(--text);
	width: 100%;
	font-family: inherit;
}
.rz-title-input {
	font-size: var(--fs-display);
	font-weight: 300;
	line-height: 1.25;
	padding: 2px 0;
	letter-spacing: 0.01em;
}
.rz-title-input::placeholder { color: var(--text-mute); }
.rz-lead-input {
	font-size: var(--fs-h3);
	font-weight: 300;
	color: var(--text-dim);
	resize: vertical;
	padding: 4px 0 12px;
	line-height: 1.55;
}

/* ── Теги-чипы под заголовком ──────────────────────────────────────── */
.rz-tags {
	display: flex; flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	padding: 4px 0 6px;
	border-bottom: 1px solid var(--border);
	cursor: text;
	min-height: 32px;
}
.rz-tag-chip {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 2px 4px 2px 9px;
	border-radius: var(--pill-radius);
	background: rgba(199, 155, 102, 0.1);
	color: var(--gold);
	font-size: var(--fs-micro);
	text-transform: lowercase;
	letter-spacing: 0.02em;
	border: 1px solid rgba(199, 155, 102, 0.3);
	line-height: 1.4;
}
.rz-tag-chip button {
	background: none; border: 0; cursor: pointer;
	color: var(--text-mute);
	width: 16px; height: 16px;
	padding: 0;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%;
	font-size: 0.85em;
	line-height: 1;
}
.rz-tag-chip button:hover { color: var(--copper); background: rgba(184, 117, 83, 0.15); }
.rz-tag-input {
	flex: 1;
	min-width: 200px;
	background: transparent;
	border: 0; outline: none;
	color: var(--text-dim);
	font-family: inherit;
	font-size: var(--fs-small);
	padding: 4px 2px;
	text-transform: lowercase;
}
.rz-tag-input::placeholder { color: var(--text-mute); }

/* ── Тонкая полоса категория + тема ───────────────────────────────── */
.rz-tax-row {
	display: flex; flex-wrap: wrap;
	gap: 24px;
	padding: 6px 0 10px;
}
.rz-tax-lbl {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--text-mute);
	white-space: nowrap;
	margin-right: 8px;
}

/* Кастомный дропдаун — нативный <select> рисует панель в стиле ОС
   (белый фон, синяя подсветка). Делаем свой через Alpine, чтобы держать
   дизайн-схему: dark paper, золото на hover, точка-буллет у выбранного. */
.rz-dd {
	position: relative;
	display: inline-flex; align-items: baseline;
}
.rz-dd-trigger {
	display: inline-flex; align-items: center; gap: 6px;
	background: transparent;
	border: 0;
	color: var(--text-dim);
	font-family: inherit;
	font-size: var(--fs-small);
	cursor: pointer;
	padding: 4px 2px;
	text-transform: lowercase;
}
.rz-dd-trigger:hover { color: var(--text); }
.rz-dd-trigger.is-open { color: var(--accent); }
.rz-dd-trigger.is-disabled { color: var(--text-mute); cursor: not-allowed; }
.rz-dd-trigger.is-disabled:hover { color: var(--text-mute); }
.rz-dd-value.is-empty { color: var(--text-mute); }
.rz-dd-caret {
	font-size: 0.7em;
	color: var(--text-mute);
	transition: transform .15s;
}
.rz-dd-trigger.is-open .rz-dd-caret { transform: rotate(180deg); color: var(--accent); }

.rz-dd-panel {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	z-index: 30;
	min-width: 220px;
	max-height: 320px;
	overflow-y: auto;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.45);
	padding: 6px 0;
	margin: 0;
	list-style: none;
}
.rz-dd-opt {
	display: flex; align-items: center; gap: 10px;
	padding: 8px 14px;
	color: var(--text-dim);
	font-size: var(--fs-small);
	cursor: pointer;
	text-transform: lowercase;
	letter-spacing: 0.01em;
	transition: background .12s, color .12s;
}
.rz-dd-opt:hover {
	background: var(--bg-card-hover);
	color: var(--text);
}
.rz-dd-opt.is-selected {
	color: var(--accent);
	background: rgba(199, 155, 102, 0.06);
}
.rz-dd-opt.is-selected::before {
	content: '.';
	color: var(--accent);
	font-weight: 700;
	margin-right: -4px;
}
.rz-dd-opt-mute { color: var(--text-mute); font-style: italic; }
.rz-dd-icon { width: 18px; text-align: center; flex-shrink: 0; }

[x-cloak] { display: none !important; }

.rz-editor-host {
	background: transparent;
	border-radius: 0;
	padding: 4px 0 4px 44px;  /* левый отступ оставляем под EditorJS «+» и «≡» */
	min-height: 320px;
	color: var(--text);
	position: relative;
}
.rz-editor-host .codex-editor__redactor { padding-bottom: 60px !important; }
.rz-editor-host .ce-block__content,
.rz-editor-host .ce-toolbar__content { max-width: 100% !important; }
.rz-editor-host .ce-block { font-size: var(--fs-body); line-height: 1.65; }
.rz-editor-host .ce-header { color: var(--text); }
.rz-editor-host h2.ce-header { font-size: var(--fs-h2); font-weight: 500; }
.rz-editor-host h3.ce-header { font-size: var(--fs-h3); font-weight: 500; }

/* EditorJS-«+» и «≡» по умолчанию мелкие/серые и видны только при hover —
   делаем заметными: золотая обводка, больше, всегда видны. */
.rz-editor-host .ce-toolbar__plus,
.rz-editor-host .ce-toolbar__settings-btn {
	color: var(--gold) !important;
	background: rgba(199, 155, 102, 0.08) !important;
	border: 1px solid rgba(199, 155, 102, 0.35) !important;
	border-radius: var(--pill-radius) !important;
	width: 28px !important;
	height: 28px !important;
	opacity: 1 !important;
	visibility: visible !important;
	transition: all .15s !important;
}
.rz-editor-host .ce-toolbar__plus:hover,
.rz-editor-host .ce-toolbar__settings-btn:hover {
	background: rgba(199, 155, 102, 0.2) !important;
	border-color: var(--gold) !important;
	color: var(--copper) !important;
}
.rz-editor-host .ce-toolbar__plus svg,
.rz-editor-host .ce-toolbar__settings-btn svg {
	width: 16px; height: 16px;
}
/* Тулбар всегда виден — не только когда блок пустой/в фокусе */
.rz-editor-host .ce-toolbar { opacity: 1 !important; }
.rz-editor-host .ce-toolbar__actions { opacity: 1 !important; visibility: visible !important; }

.rz-editor-hint {
	font-size: var(--fs-micro);
	margin-top: 8px;
	color: var(--text-mute);
}

/* ── Quick-add панель: «+ заголовок», «+ текст», «+ картинка», … ──── */
.rz-add-bar {
	display: flex; flex-wrap: wrap;
	gap: 6px;
	padding: 14px 0 4px;
	border-top: 1px dashed var(--border);
	margin-top: 8px;
}
.rz-add-btn {
	background: transparent;
	color: var(--text-dim);
	border: 1px solid var(--border);
	padding: 6px 12px;
	border-radius: var(--pill-radius);
	font-family: inherit;
	font-size: var(--fs-small);
	text-transform: lowercase;
	cursor: pointer;
	letter-spacing: 0.02em;
	transition: all .15s;
}
.rz-add-btn:hover {
	color: var(--accent);
	border-color: rgba(199, 155, 102, 0.4);
}
.rz-add-btn-accent {
	color: var(--gold);
	border-color: rgba(199, 155, 102, 0.3);
	background: rgba(199, 155, 102, 0.06);
}
.rz-add-btn-accent:hover {
	color: var(--copper);
	border-color: var(--copper);
	background: rgba(184, 117, 83, 0.08);
}
.rz-add-btn-mute {
	color: var(--text-mute);
	border-style: dashed;
}
.rz-add-btn-mute:hover {
	color: var(--text-dim);
}

/* Chart block внутри редактора */
.rz-chartblock {
	border: 1px dashed var(--border-2);
	border-radius: var(--card-radius);
	padding: 14px 16px;
	background: var(--bg-2);
	margin: 8px 0;
}
.rz-chartblock-preview {
	border-style: solid;
	border-color: rgba(199,155,102,0.35);
	background: rgba(199,155,102,0.04);
}
.rz-chartblock-head {
	font-size: var(--fs-micro);
	color: var(--gold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 10px;
	font-weight: 500;
}
.rz-chartblock-locked {
	margin: 6px 0 10px;
	padding: 12px 14px;
	background: rgba(199, 155, 102, 0.06);
	border: 1px solid rgba(199, 155, 102, 0.18);
	border-radius: var(--card-radius);
	font-size: var(--fs-small);
}
.rz-chartblock-locked-title { color: var(--gold); margin-bottom: 4px; }
.rz-chartblock-locked-sub { font-size: var(--fs-micro); line-height: 1.5; }
.rz-chartblock-list { display: flex; flex-direction: column; gap: 6px; }
.rz-chartblock-item {
	display: flex; align-items: center; gap: 12px;
	padding: 8px 12px;
	border-radius: var(--pill-radius);
	background: var(--bg-card);
	border: 1px solid transparent;
	cursor: pointer; text-align: left;
	color: var(--text);
	font-family: inherit;
	transition: all .15s;
}
.rz-chartblock-item:hover {
	border-color: var(--accent);
	background: var(--bg-card-hover);
}
.rz-chartblock-avatar {
	width: 34px; height: 34px;
	border-radius: 50%;
	background: linear-gradient(135deg, #2a2a2a, #1a1a1a);
	color: var(--text-dim);
	display: flex; align-items: center; justify-content: center;
	font-weight: 500; flex-shrink: 0;
	border: 1px solid var(--border);
}
.rz-chartblock-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.rz-chartblock-name {
	color: var(--text);
	display: flex; align-items: center; gap: 8px;
	font-size: var(--fs-small);
}
.rz-chartblock-tag {
	font-size: var(--fs-micro);
	color: var(--text-mute);
	padding: 1px 6px;
	border-radius: var(--pill-radius);
	background: var(--bg-2);
	text-transform: lowercase;
}
.rz-chartblock-sub {
	color: var(--text-dim);
	font-size: var(--fs-micro);
}
.rz-chartblock-compat-toggle {
	margin-top: 10px;
	background: none; border: 0; cursor: pointer;
	color: var(--text-dim);
	font-family: inherit;
	padding: 6px 8px;
	font-size: var(--fs-small);
	text-transform: lowercase;
}
.rz-chartblock-compat-toggle:hover { color: var(--accent); }
.rz-chartblock-soon { padding-top: 6px; font-size: var(--fs-micro); }
.rz-chartblock-preview-row { display: flex; align-items: center; gap: 12px; }
.rz-chartblock-change {
	margin-left: auto;
	background: none;
	border: 1px solid var(--border-2);
	color: var(--text-mute);
	cursor: pointer;
	padding: 4px 10px;
	border-radius: var(--pill-radius);
	font-family: inherit;
	font-size: var(--fs-micro);
	text-transform: lowercase;
}
.rz-chartblock-change:hover { color: var(--accent); border-color: var(--accent); }

/* ─── Шаг 2: выбор вью (полный паспорт / одна из 6 систем) ─────────── */
.rz-chartblock-subhead {
	font-size: var(--fs-small);
	margin: -4px 0 12px;
}
.rz-chartblock-view-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 6px;
}
@media (min-width: 640px) {
	.rz-chartblock-view-list { grid-template-columns: 1fr 1fr; }
}
.rz-chartblock-view-item {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	padding: 10px 14px;
	background: var(--bg-card);
	border: 1px solid transparent;
	border-radius: var(--pill-radius);
	color: var(--text);
	font-family: inherit;
	font-size: var(--fs-small);
	text-align: left;
	cursor: pointer;
	transition: border-color 0.18s ease, background 0.18s ease;
}
.rz-chartblock-view-item:hover {
	border-color: var(--accent);
	background: var(--bg-card-hover);
}
.rz-chartblock-view-item.is-primary { border-color: rgba(199, 155, 102, 0.45); }
.rz-chartblock-view-item.is-primary:hover { border-color: var(--accent); }
.rz-chartblock-view-label { font-weight: 500; color: var(--text); }
.rz-chartblock-view-desc { font-size: var(--fs-micro); }

.rz-chartblock-back {
	margin-top: 12px;
	background: transparent;
	border: 0;
	color: var(--text-mute);
	font: inherit;
	font-size: var(--fs-micro);
	cursor: pointer;
	padding: 4px 0;
	text-transform: lowercase;
}
.rz-chartblock-back:hover { color: var(--text); }

/* ═════════════════════════════════════════════════════════════════════
   Дашборд → вкладка «резонанс»
   ═════════════════════════════════════════════════════════════════════ */

.dash-rz-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 28px;
	align-items: start;
}
.dash-rz-main { min-width: 0; display: flex; flex-direction: column; gap: 28px; }
.dash-rz-side { position: sticky; top: 16px; }

@media (max-width: 920px) {
	.dash-rz-grid { grid-template-columns: 1fr; }
	.dash-rz-side { position: static; }
}

/* ── 3-колоночный layout: [сила | посты | комменты]; подписки во всю ширину ── */
.dash-rz-stack {
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr) minmax(0, 1fr);
	gap: 20px;
	align-items: start;
}
/* Колонки стека не должны тащить верхний margin от .panel (40px) — иначе
   отступ от секции «подписки» до «силы резонанса» больше, чем до неё сверху.
   Вертикальный ритм задаёт grid gap + margin секции подписок. */
.dash-rz-stack > section { margin-top: 0; }
/* Заголовки колонок — единая высота, чтобы контент стартовал в одной строке */
.dash-rz-stack > section > h2 {
	margin: 0 0 14px;
	min-height: 32px;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}
/* Каждый блок стека получает 1-строчный section-explainer (правило проекта).
   min-height удерживает выравнивание даже если на узкой колонке текст
   переносится на 2 строки. */
.dash-rz-stack > section > .section-explainer {
	min-height: 2.7em;
	margin: -6px 0 14px;
}
@media (max-width: 1100px) {
	.dash-rz-stack {
		grid-template-columns: 280px minmax(0, 1fr);
	}
	/* На двух колонках: сила слева, посты справа, активность — на всю ширину под ними. */
	.dash-rz-stack > section:nth-child(3) {
		grid-column: 2 / -1;
	}
}
@media (max-width: 720px) {
	.dash-rz-stack { grid-template-columns: 1fr; }
	.dash-rz-stack > section { grid-column: auto; }
}

/* Paper-карта внутри section.panel — режем дефолтный margin от .panel,
   иначе она проседает на 40px ниже соседних колонок. */
.dash-rz-stack > section > .dash-rz-rating { margin: 0 !important; }

/* Paper-карточка — узкая колонка слева, всё вертикально. */
.dash-rz-rating-row {
	display: flex; flex-direction: column;
	gap: 14px;
}
.dash-rz-rating-breakdown {
	border-top: 1px solid var(--border);
	padding-top: 12px;
	margin: 0;
}
.dash-rz-rating-grid {
	display: flex !important;
	flex-direction: column;
	gap: 5px;
}

/* Счётчик возле заголовка ("мои посты 5") */
.dash-rz-count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 22px; height: 22px;
	padding: 0 7px;
	margin-left: 6px;
	background: var(--bg-2);
	color: var(--text-dim);
	border-radius: var(--pill-radius);
	font-size: var(--fs-micro);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	letter-spacing: 0.04em;
	vertical-align: 2px;
}

/* ── Список моих постов: плоские row-карточки.
   Морфология синхронизирована с .dash-rz-activity-row — единый визуальный
   язык: bg-card + 6px радиус + 2px border-left разных цветов по статусу. */
.dash-rz-posts {
	display: flex; flex-direction: column;
	gap: 8px;
	margin-top: 14px;
}
.dash-rz-post {
	display: flex; flex-direction: column;
	gap: 6px;
	padding: 12px 16px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	border-left: 2px solid transparent;
	color: inherit;
	transition: background .12s, border-color .12s;
}
/* Цвет границы по статусу — те же 4 металла, что и везде. */
.dash-rz-post.is-published    { border-left-color: var(--patina); }
.dash-rz-post.is-pending,
.dash-rz-post.is-rejected,
.dash-rz-post.is-hidden-flag  { border-left-color: var(--copper); }
.dash-rz-post.is-draft        { border-left-color: var(--border-2); }
.dash-rz-post:hover           { background: var(--bg-card-hover); }

.dash-rz-post-meta {
	display: flex; flex-wrap: wrap;
	align-items: center; gap: 8px;
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: lowercase;
}
.dash-rz-post-cat { color: var(--text-dim); }
.dash-rz-post-time { font-variant-numeric: tabular-nums; }

.dash-rz-post-title {
	font-size: var(--fs-h3);
	font-weight: 500;
	color: var(--text);
	letter-spacing: 0.2px;
	line-height: 1.35;
}
.dash-rz-post:hover .dash-rz-post-title { color: var(--accent); }

.dash-rz-post-counters {
	display: flex; flex-wrap: wrap; gap: 4px 14px;
	font-size: var(--fs-micro);
	color: var(--text-dim);
	text-transform: lowercase;
	font-variant-numeric: tabular-nums;
}

/* ── Компактный список моих комментов в дашборде ──────────────────── */
.dash-rz-comments-head {
	display: flex; align-items: center;
	gap: 12px; flex-wrap: wrap;
}
.dash-rz-comments-h2 {
	margin: 0 !important;
	flex: 0 0 auto;
}
/* sort-кнопки сразу после заголовка, без растягивания */
.dash-rz-comments-head .dash-rz-sort { flex: 0 0 auto; }

.dash-rz-sort {
	display: inline-flex; gap: 0;
	background: var(--bg-2);
	border-radius: var(--pill-radius);
	padding: 2px;
}
.dash-rz-sort button {
	background: transparent;
	border: 0;
	color: var(--text-mute);
	font-family: inherit;
	font-size: var(--fs-micro);
	text-transform: lowercase;
	padding: 5px 12px;
	border-radius: var(--pill-radius);
	cursor: pointer;
	letter-spacing: 0.02em;
	transition: all .12s;
}
.dash-rz-sort button:hover { color: var(--text); }
.dash-rz-sort button.is-active {
	background: var(--bg-card);
	color: var(--accent);
}

/* Flex-список: через order сортируется CSS-перменными `--ord-date`/`--ord-likes`. */
.dash-rz-comments-flex {
	display: flex; flex-direction: column;
	margin-top: 12px;
	border-top: 1px solid var(--border);
}
.dash-rz-comments-flex.is-sort-date  .dash-rz-comment-row { order: var(--ord-date); }
.dash-rz-comments-flex.is-sort-likes .dash-rz-comment-row { order: var(--ord-likes); }

.dash-rz-comment-row {
	display: grid;
	grid-template-columns: 16px minmax(0, 1fr) auto auto;
	gap: 10px;
	align-items: baseline;
	padding: 7px 4px;
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid var(--border);
	font-size: var(--fs-small);
	transition: background .1s;
}
.dash-rz-comment-row:hover { background: var(--bg-card); }

.dash-rz-comment-kind {
	color: var(--text-mute);
	font-size: 0.85rem;
	text-align: center;
}
.dash-rz-comment-row-body {
	color: var(--text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.dash-rz-comment-row-likes {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: var(--fs-micro);
	color: var(--patina);
	white-space: nowrap;
}
.dash-rz-comment-row-time {
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: lowercase;
	white-space: nowrap;
	min-width: 70px;
	text-align: right;
}

/* ── mini-stats: разбивка лайков под главным числом ────────────────── */
.dash-rz-stats-mini {
	margin-top: 10px;
	gap: 4px;
}
.dash-rz-stats-mini .dash-rz-stat dt,
.dash-rz-stats-mini .dash-rz-stat dd {
	font-size: var(--fs-micro);
}
.dash-rz-stats-mini .dash-rz-stat dd { color: var(--text-dim); }

/* ── Подписки: плотный grid из author-chip ─────────────────────────── */
.dash-rz-subs {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 12px;
	margin-top: 14px;
}

/* Подписки одной прокручиваемой строкой со стрелками (страница «мой резонанс»).
   Стрелки — в правом верхнем углу секции, трек на всю ширину: чипы выровнены
   по левому краю с заголовком и колонками ниже. */
.rz-subs-section { position: relative; }
.rz-subs-nav {
	position: absolute;
	top: 0;
	right: 0;
	display: flex;
	gap: 8px;
}
.rz-subs-track {
	display: flex;
	flex-wrap: nowrap;          /* одна строка */
	gap: 18px;
	overflow-x: auto;
	scroll-behavior: smooth;
	margin-top: 12px;
	padding: 2px 0;             /* без горизонтального — чипы вровень с заголовком */
	scrollbar-width: none;      /* управление стрелками — полосу прячем */
}
.rz-subs-track::-webkit-scrollbar { display: none; }
.rz-subs-track > .rz-author { flex: 0 0 auto; }   /* чипы не сжимаются */
.rz-subs-arrow {
	flex: 0 0 auto;
	width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--border-2);
	border-radius: 50%;
	background: transparent;
	color: var(--text-dim);
	font-size: 1.3rem;
	line-height: 1;
	cursor: pointer;
	transition: color 0.18s ease, border-color 0.18s ease, opacity 0.18s ease;
}
.rz-subs-arrow:hover:not(:disabled) { color: var(--text); border-color: var(--accent); }
.rz-subs-arrow:disabled { opacity: 0.25; cursor: default; }

/* ── Paper-карточка рейтинга справа ────────────────────────────────── */
.dash-rz-rating {
	padding: 24px 26px !important;
	text-align: left;
}
.dash-rz-rating-label {
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 4px;
}
.dash-rz-rating-label::before {
	content: '';
}
.dash-rz-rating-value {
	font-size: 2.6rem;
	font-weight: 300;
	color: var(--gold);
	line-height: 1;
	letter-spacing: -0.01em;
	margin: 2px 0 4px;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.dash-rz-rating-cap {
	font-size: var(--fs-small);
	text-transform: lowercase;
}
.dash-rz-rating-divider {
	height: 1px;
	background: var(--border);
	margin: 18px 0;
}
.dash-rz-stats {
	display: flex; flex-direction: column;
	gap: 6px;
	margin: 0;
}
.dash-rz-stat {
	display: flex; justify-content: space-between; align-items: baseline;
	gap: 12px;
}
.dash-rz-stat dt {
	color: var(--text-dim);
	font-size: var(--fs-small);
	text-transform: lowercase;
	margin: 0;
}
.dash-rz-stat dd {
	margin: 0;
	color: var(--text);
	font-size: var(--fs-body);
	font-weight: 500;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.dash-rz-stat dd.copper { color: var(--copper); }

.dash-rz-cta {
	display: block;
	margin-top: 20px;
	text-align: center;
	text-decoration: none;
}

/* Nav-CTA для «+ написать» в сайдбаре */
.zn-nav-link-cta { color: var(--accent); }
.zn-nav-link-cta:hover { color: var(--copper); }
.zn-nav-link-mod { color: var(--patina); }
.zn-nav-link-mod:hover { color: var(--gold); }

/* Точка-индикатор «есть новое» в боковой навигации (рядом с «дашборд»),
   видна на любой странице. Цвет — медь: CTA/hot, чтобы цеплять взгляд. */
.zn-nav-dot {
	display: inline-block;
	width: 7px; height: 7px;
	margin-left: 6px;
	border-radius: 50%;
	background: var(--copper);
	box-shadow: 0 0 6px rgba(184, 117, 83, 0.55);
	vertical-align: middle;
	transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════════════════════════
   Activity — единая лента комментариев (я ↔ мне) во вкладке Резонанс
   ═══════════════════════════════════════════════════════════════════ */

/* Бейдж «N новых» в самом табе — кричит, чтобы юзер заметил вкладку. */
.dash-tab-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	padding: 0 6px;
	margin-left: 4px;
	border-radius: 9px;
	background: var(--copper);
	color: #1a1a1a;
	font-size: 0.72rem;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	line-height: 1;
	vertical-align: middle;
	transform: translateY(-1px);
}

/* Шапка блока активности: заголовок слева + filter-чипы справа. */
.dash-rz-activity-head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 8px;
}
.dash-rz-activity-filter { flex: 0 0 auto; }

/* «+N новое» рядом со счётчиком в заголовке — короткий медный тег. */
.dash-rz-activity-fresh-tag {
	font-size: 0.7rem;
	color: var(--copper);
	background: rgba(184, 117, 83, 0.12);
	border: 1px solid rgba(184, 117, 83, 0.35);
	padding: 2px 8px;
	border-radius: var(--pill-radius);
	margin-left: 8px;
	text-transform: lowercase;
	letter-spacing: 0.02em;
	font-weight: 500;
	vertical-align: middle;
}
.dash-rz-count.is-fresh { color: var(--copper); }

/* Лента — плоские row-карточки. */
.dash-rz-activity {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 12px;
}
/* Кнопка «загрузить ещё» — по центру под списком активности. */
.dash-rz-activity-more {
	align-self: center;
	margin-top: 6px;
	padding: 9px 22px;
	background: transparent;
	border: 1px solid var(--border-2);
	border-radius: 8px;
	color: var(--text-dim);
	font: inherit;
	font-size: 0.84rem;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: color 0.18s ease, border-color 0.18s ease;
}
.dash-rz-activity-more:hover { color: var(--text); border-color: var(--accent); }

.dash-rz-activity-row {
	display: block;
	padding: 12px 16px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	border-left: 2px solid transparent;
	color: var(--text);
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s;
}
.dash-rz-activity-row:hover { background: var(--bg-card-hover); }

/* Исходящее («я →») — спокойное серебро на hover, без border-line по умолчанию. */
.dash-rz-activity-row.is-mine:hover { border-left-color: var(--silver); }

/* Входящее («X →») — золото на hover. */
.dash-rz-activity-row.is-incoming:hover { border-left-color: var(--gold); }

/* Свежее входящее — постоянная тёплая медная подсветка. */
.dash-rz-activity-row.is-new {
	border-left-color: var(--copper);
	background: linear-gradient(90deg,
		rgba(184, 117, 83, 0.06),
		var(--bg-card) 80px);
}
.dash-rz-activity-row.is-new:hover {
	background: linear-gradient(90deg,
		rgba(184, 117, 83, 0.1),
		var(--bg-card-hover) 80px);
}

.dash-rz-activity-body { min-width: 0; }

.dash-rz-activity-head-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-bottom: 4px;
	font-size: var(--fs-small);
}

/* Тэг «я → пост Х» / «X → ответил тебе» — собран inline-flex чтобы стрелка не отрывалась. */
.dash-rz-activity-tag {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	flex-wrap: wrap;
}
/* «я» / имя автора — главное действующее лицо. */
.dash-rz-activity-who {
	font-weight: 500;
	font-size: var(--fs-small);
}
.dash-rz-activity-row.is-mine .dash-rz-activity-who { color: var(--silver); }
.dash-rz-activity-row.is-incoming .dash-rz-activity-who { color: var(--gold); }

/* Стрелка → между «кто» и «куда/кому». */
.dash-rz-activity-arrow {
	color: var(--text-mute);
	font-size: var(--fs-small);
}

/* «прокомментировал твой пост» / «ответил тебе» / «пост свой» — описание действия. */
.dash-rz-activity-target {
	font-size: var(--fs-small);
	color: var(--text);
	letter-spacing: 0.01em;
}

/* Маленькая медная точка «новое» в строке — дублирует визуальный сигнал. */
.dash-rz-activity-dot {
	display: inline-block;
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--copper);
	box-shadow: 0 0 5px rgba(184, 117, 83, 0.6);
}

.dash-rz-activity-text {
	color: var(--text-dim);
	font-size: var(--fs-small);
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.dash-rz-activity-foot {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	margin-top: 6px;
	font-size: var(--fs-micro);
	text-transform: lowercase;
}
.dash-rz-activity-post {
	color: var(--text-mute);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 60%;
}
.dash-rz-activity-time {
	color: var(--text-mute);
	flex-shrink: 0;
	font-variant-numeric: tabular-nums;
}

/* ─── Страница модерации (staff only) ────────────────────────────────── */
.rz-mod-page {
	max-width: 1100px;
	margin: 0 auto 64px;
}
.rz-mod-head { margin-bottom: 32px; }
.rz-mod-section { margin-top: 32px; }
.rz-mod-h2 {
	font-size: var(--fs-h2);
	font-weight: 400;
	margin: 0 0 14px;
	color: var(--text);
	text-transform: lowercase;
	letter-spacing: 0.01em;
}
.rz-mod-h2::before {
	content: '.';
	color: var(--accent);
	margin-right: 4px;
	font-weight: 700;
}
.rz-mod-count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 24px; height: 24px;
	padding: 0 7px;
	margin-left: 8px;
	background: var(--patina);
	color: #1a1a1a;
	border-radius: var(--pill-radius);
	font-size: var(--fs-micro);
	font-weight: 500;
	vertical-align: middle;
}

.rz-mod-list {
	display: flex; flex-direction: column;
	gap: 16px;
}

/* Просторная карточка: cover | content | actions
   Левая полоса 3px = индикатор состояния по дизайн-схеме:
   • copper (медь) — требует внимания (AI отметил, мат)
   • patina (патина) — AI одобрил, ждёт ручного подтверждения
   • silver (--border-2) — без вердикта (ещё не проверен / ошибка / skipped) */
.rz-mod-card {
	display: grid;
	grid-template-columns: 200px minmax(0, 1fr) 180px;
	gap: 28px;
	align-items: start;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	padding: 22px 26px 22px 30px;
	transition: background .12s;
	position: relative;
	overflow: hidden;
}
.rz-mod-card::before {
	content: "";
	position: absolute;
	left: 0; top: 0; bottom: 0;
	width: 3px;
	background: var(--border-2);
}
.rz-mod-card.is-flagged::before   { background: var(--copper); }
.rz-mod-card.is-profanity::before { background: var(--copper); }
.rz-mod-card.is-passed::before    { background: var(--patina); }
.rz-mod-card.is-mute::before      { background: var(--border-2); }
.rz-mod-card:hover { background: var(--bg-card-hover); }

.rz-mod-card-cover {
	width: 200px; height: 140px;
	border-radius: var(--card-radius);
	overflow: hidden;
	background: var(--bg-2);
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.rz-mod-card-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rz-mod-card-cover-empty {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	color: var(--text-mute);
	font-size: 3rem; font-weight: 300;
	background: linear-gradient(135deg, var(--bg-card), var(--bg-2));
}

.rz-mod-card-body {
	min-width: 0;
	display: flex; flex-direction: column;
	gap: 10px;
}
.rz-mod-card-meta {
	display: flex; flex-wrap: wrap;
	align-items: center; gap: 8px;
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: lowercase;
}
.rz-mod-card-author { color: var(--text-dim); }
.rz-mod-card-time { color: var(--text-mute); }
.rz-mod-card-title {
	font-size: var(--fs-h2);
	font-weight: 500;
	color: var(--text);
	letter-spacing: 0.2px;
	line-height: 1.3;
	text-decoration: none;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.rz-mod-card-title:hover { color: var(--accent); }
.rz-mod-card-title::before {
	content: '.';
	color: var(--accent);
	margin-right: 6px;
	font-weight: 700;
}
.rz-mod-card-desc {
	font-size: var(--fs-small);
	color: var(--text-dim);
	margin: 0;
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.rz-mod-ai-hint {
	font-size: var(--fs-small);
	color: var(--text-mute);
	padding: 8px 12px;
	background: rgba(184, 117, 83, 0.06);
	border-left: 2px solid var(--copper);
	border-radius: 0 var(--pill-radius) var(--pill-radius) 0;
}
.rz-mod-ai-hint strong { color: var(--copper); font-weight: 500; }

.rz-mod-card-actions {
	display: flex; flex-direction: column;
	gap: 10px;
	align-items: stretch;
	flex-shrink: 0;
}
.rz-mod-card-actions .btn {
	white-space: nowrap;
	width: 100%;
	padding: 10px 14px;
}
.rz-mod-card-open {
	margin-top: 4px;
	text-align: center;
	font-size: var(--fs-micro);
	color: var(--text-mute);
	text-transform: lowercase;
}
.rz-mod-card-open:hover { color: var(--accent); }

.rz-mod-card-reject {
	grid-column: 1 / -1;
	display: flex; flex-direction: column;
	gap: 10px;
	padding-top: 8px;
	border-top: 1px solid var(--border);
	margin-top: 6px;
}

/* ── Инлайн-редактор категории / темы внутри карточки ──────────────── */
.rz-mod-tax {
	display: flex; align-items: center; flex-wrap: wrap;
	gap: 8px;
	padding-top: 4px;
}
.rz-mod-tax-view {
	display: flex; align-items: center; flex-wrap: wrap;
	gap: 8px;
}
.rz-mod-tax-edit {
	background: transparent;
	border: 0;
	color: var(--text-mute);
	font-family: inherit;
	font-size: var(--fs-micro);
	text-transform: lowercase;
	cursor: pointer;
	padding: 2px 6px;
	border-radius: var(--pill-radius);
}
.rz-mod-tax-edit:hover { color: var(--accent); }

.rz-mod-cat-warn {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: var(--fs-micro);
	color: var(--copper);
	background: rgba(184, 117, 83, 0.08);
	border: 1px solid rgba(184, 117, 83, 0.35);
	padding: 2px 8px;
	border-radius: var(--pill-radius);
	text-transform: lowercase;
}

.rz-mod-tax-edit-form {
	display: flex; flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	width: 100%;
}
.rz-mod-tax-edit-form select {
	background: var(--bg-2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: var(--pill-radius);
	padding: 6px 10px;
	font-family: inherit;
	font-size: var(--fs-small);
}
.rz-mod-tax-save, .rz-mod-tax-cancel {
	background: transparent;
	border: 1px solid var(--border-2);
	color: var(--text-dim);
	padding: 5px 12px;
	border-radius: var(--pill-radius);
	font-family: inherit;
	font-size: var(--fs-small);
	cursor: pointer;
	text-transform: lowercase;
}
.rz-mod-tax-save { color: var(--patina); border-color: var(--patina); }
.rz-mod-tax-save:hover { background: rgba(107, 155, 133, 0.1); }
.rz-mod-tax-cancel:hover { color: var(--text); border-color: var(--text-dim); }

/* Мобилки — карточка сворачивается в стопку */
@media (max-width: 760px) {
	.rz-mod-card {
		grid-template-columns: 1fr;
		padding: 18px 20px;
	}
	.rz-mod-card-cover {
		width: 100%;
		height: 180px;
	}
	.rz-mod-card-actions { flex-direction: row; }
	.rz-mod-card-actions .btn { width: auto; flex: 1; }
}

.rz-mod-form { display: inline-flex; margin: 0; }

/* ── Бейджи AI-статусов ──────────────────────────────────────────────── */
.rz-badge-ok, .rz-badge-flag, .rz-badge-mute, .rz-badge-prof {
	display: inline-flex; align-items: center;
	font-size: var(--fs-micro);
	padding: 1px 7px;
	border-radius: var(--pill-radius);
	letter-spacing: 0.02em;
	text-transform: lowercase;
}
.rz-badge-ok {
	background: rgba(107, 155, 133, 0.12);
	color: var(--patina);
	border: 1px solid rgba(107, 155, 133, 0.4);
}
.rz-badge-flag {
	background: rgba(184, 117, 83, 0.14);
	color: var(--copper);
	border: 1px solid rgba(184, 117, 83, 0.5);
}
.rz-badge-mute {
	background: var(--bg-2);
	color: var(--text-mute);
	border: 1px solid var(--border);
}
.rz-badge-prof {
	background: rgba(184, 117, 83, 0.18);
	color: var(--copper);
	border: 1px solid var(--copper);
	font-weight: 500;
}

/* На мобильных карточка перевёрстывается в стопку */
@media (max-width: 720px) {
	.rz-mod-card {
		grid-template-columns: 1fr;
	}
	.rz-mod-card-cover {
		width: 100%;
		height: 140px;
	}
	.rz-mod-card-actions {
		flex-direction: row;
	}
	.rz-mod-card-actions .btn { flex: 1; }
}

.rz-mod-rejected {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: 8px;
}
.rz-mod-rejected li {
	padding: 8px 14px;
	background: var(--bg-card);
	border-radius: var(--card-radius);
	border-left: 3px solid var(--copper);
	font-size: var(--fs-small);
}
.rz-mod-rejected a { color: var(--text-dim); }
.rz-mod-rejected a:hover { color: var(--accent); }

/* AI-плашка внутри карточки модерации и панели поста */
.rz-mod-ai {
	background: rgba(184, 117, 83, 0.08);
	border-left: 3px solid var(--copper);
	border-radius: var(--card-radius);
	padding: 8px 14px;
	margin: 8px 0;
	font-size: var(--fs-small);
	color: var(--text-dim);
	line-height: 1.5;
}
.rz-mod-ai strong { color: var(--copper); }
.rz-mod-ai-err {
	background: rgba(184, 117, 83, 0.06);
	border-color: var(--text-mute);
	color: var(--text-mute);
}
.rz-mod-ai-skip {
	background: var(--bg-2);
	border-color: var(--border-2);
	color: var(--text-mute);
	font-size: var(--fs-micro);
}

/* Форма отклонения с textarea */
.rz-mod-reject-form {
	display: flex; flex-direction: column;
	gap: 10px;
	margin-top: 12px;
}
.rz-mod-reason-input {
	width: 100%;
	background: var(--bg-2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: var(--pill-radius);
	padding: 8px 12px;
	font-family: inherit;
	font-size: var(--fs-small);
	resize: vertical;
}
.rz-mod-reason-input:focus {
	outline: none;
	border-color: var(--accent);
}
.rz-mod-reject-actions { display: flex; gap: 8px; }

/* Панель модератора на странице поста */
.rz-mod-panel {
	background: var(--bg-card);
	border-radius: var(--card-radius);
	border-left: 3px solid var(--copper);
	padding: 16px 20px;
	margin: 18px 0;
}
.rz-mod-panel-head {
	display: flex; align-items: center; gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}
.rz-mod-tag {
	font-size: var(--fs-micro);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--copper);
	padding: 2px 8px;
	border-radius: var(--pill-radius);
	background: rgba(184, 117, 83, 0.12);
	border: 1px solid rgba(184, 117, 83, 0.4);
}
.rz-mod-panel-actions {
	display: flex; gap: 10px;
	flex-wrap: wrap;
	align-items: flex-start;
}
.rz-mod-banner {
	padding: 10px 14px;
	border-radius: var(--card-radius);
	font-size: var(--fs-small);
}
.rz-mod-banner-ok {
	background: rgba(107, 155, 133, 0.12);
	color: var(--patina);
	border-left: 3px solid var(--patina);
}
.rz-mod-banner-no {
	background: rgba(184, 117, 83, 0.12);
	color: var(--copper);
	border-left: 3px solid var(--copper);
}

/* Плашки автору на странице его поста */
.rz-author-notice {
	padding: 12px 18px;
	border-radius: var(--card-radius);
	margin: 18px 0;
	font-size: var(--fs-small);
	line-height: 1.5;
}
.rz-author-notice-rejected {
	background: rgba(184, 117, 83, 0.1);
	border-left: 3px solid var(--copper);
	color: var(--text-dim);
}
.rz-author-notice-rejected strong { color: var(--copper); }
.rz-author-notice-pending {
	background: rgba(184, 193, 203, 0.07);
	border-left: 3px solid var(--silver);
	color: var(--text-dim);
}
.rz-author-notice-hidden {
	background: rgba(184, 117, 83, 0.08);
	border-left: 3px solid var(--copper);
	color: var(--text-dim);
}
.rz-author-notice-hidden strong { color: var(--copper); }
/* Cross-sell вариант — золотой, мягкий, без алярма (это не предупреждение,
   это «возможность»). Используется в посте/редакторе для не-подписчиков. */
.rz-author-notice-cross-sell {
	background: rgba(199, 155, 102, 0.07);
	border-left: 3px solid var(--gold);
	color: var(--text-dim);
}
.rz-author-notice-cross-sell strong { color: var(--gold); }

/* ── Кнопка «скрыть/показать» для модератора на странице поста ──────── */
.rz-post-author-row {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px; flex-wrap: wrap;
}
.rz-hide-form { display: inline-flex; }
.rz-hide {
	background: transparent;
	color: var(--text-dim);
	border: 1px solid var(--border-2);
	padding: 6px 14px;
	border-radius: var(--pill-radius);
	font-family: inherit;
	font-size: var(--fs-small);
	text-transform: lowercase;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: all .15s;
}
.rz-hide:hover {
	color: var(--copper);
	border-color: var(--copper);
}
.rz-hide.is-hidden {
	color: var(--patina);
	border-color: var(--patina);
	background: rgba(107, 155, 133, 0.08);
}
.rz-hide.is-hidden:hover {
	background: rgba(107, 155, 133, 0.18);
}
.rz-author-notice-reason {
	margin-top: 6px;
	color: var(--text);
	font-style: italic;
}
.rz-author-notice-hint {
	margin-top: 6px;
	color: var(--text-mute);
	font-size: var(--fs-micro);
}
.rz-author-notice-cta {
	display: inline-block;
	margin-top: 12px;
	text-decoration: none;
}

.rz-author-notice-actions {
	display: flex;
	gap: 10px;
	margin-top: 12px;
	flex-wrap: wrap;
	align-items: center;
}

.rz-delete-form { display: inline-flex; margin: 0; }
.rz-delete {
	/* outline-вариант, на hover → копер: удаление = горячее действие */
}
.rz-delete:hover {
	color: var(--copper) !important;
	border-color: var(--copper) !important;
	background: rgba(184, 117, 83, 0.06);
}
