/* devops-new — современная тема, палитра Editorial / devops.org.ru */

:root {
	--color-accent: #f56a6a;
	--color-accent-hover: #ff7b7b;
	--color-accent-dark: #e85555;
	--color-accent-soft: rgba(245, 106, 106, 0.12);
	--color-accent-glow: rgba(245, 106, 106, 0.35);
	--color-text: #3d4449;
	--color-muted: #7f888f;
	--color-border: rgba(210, 215, 217, 0.85);
	--color-bg: #f8f9fa;
	--color-bg-elevated: #ffffff;
	--color-sidebar: #f0f2f4;
	--color-surface: #eff1f2;
	--color-tag-cat: #7ec699;
	--font-sans: "DM Sans", "Open Sans", system-ui, sans-serif;
	--font-serif: "Roboto Slab", Georgia, serif;
	--font-mono: "JetBrains Mono", "SF Mono", Consolas, monospace;
	--sidebar-width: 22rem;
	--content-pad-x: 2rem;
	--radius-sm: 0.5rem;
	--radius: 0.75rem;
	--radius-lg: 1.125rem;
	--shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
	--shadow-md: 0 8px 24px rgba(15, 23, 42, 0.08);
	--shadow-lg: 0 16px 48px rgba(15, 23, 42, 0.1);
	--code-bg: #161b22;
	--code-text: #e6edf3;
	--transition: 0.32s cubic-bezier(0.4, 0, 0.2, 1);
	/* Обложка: полоска ~250–300px, адаптивно */
	--cover-strip-height: clamp(15.625rem, 20vw, 18.75rem);
}

@media (max-width: 736px) {
	:root { --cover-strip-height: clamp(13rem, 38vw, 16.5rem); }
}

@media (max-width: 1100px) {
	:root { --content-pad-x: 0.5rem; }
}

@media (min-width: 1481px) { :root { --sidebar-width: 24rem; } }
@media (min-width: 1681px) { :root { --sidebar-width: 26rem; } }

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

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	background: var(--color-bg);
	background-image:
		radial-gradient(ellipse 120% 80% at 100% -20%, var(--color-accent-soft), transparent 55%),
		radial-gradient(ellipse 80% 50% at 0% 100%, rgba(126, 198, 153, 0.08), transparent 50%);
	background-attachment: fixed;
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: 16px;
	font-weight: 400;
	line-height: 1.65;
	margin: 0;
}

#wrapper.site-layout {
	animation: site-content-fade-in 0.35s ease;
}

@keyframes site-content-fade-in {
	from { opacity: 0; }
	to { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
	#wrapper.site-layout {
		animation: none;
	}
}

::selection {
	background: var(--color-accent-soft);
	color: var(--color-text);
}

a {
	border-bottom: none;
	color: var(--color-accent);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:hover { color: var(--color-accent-hover); }

img { height: auto; max-width: 100%; }

/* --- Layout --- */
#wrapper.site-layout {
	display: grid;
	grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
	min-height: 100vh;
	transition: grid-template-columns var(--transition);
}

body.sidebar-collapsed #wrapper.site-layout {
	grid-template-columns: 0 minmax(0, 1fr);
}

#sidebar.site-sidebar {
	background: linear-gradient(180deg, #f6f7f9 0%, var(--color-sidebar) 40%, #ebedf0 100%);
	border-right: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	overflow: visible;
	position: relative;
	z-index: 200;
}

#sidebar.site-sidebar::before {
	background: linear-gradient(180deg, var(--color-accent) 0%, transparent 100%);
	content: "";
	height: 4px;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 3;
}

#sidebar > .inner {
	flex: 1 1 auto;
	min-height: 0;
	overflow-x: visible;
	overflow-y: auto;
	padding: 1.75em 1.25em 1em;
	-webkit-overflow-scrolling: touch;
}

body.sidebar-collapsed #sidebar > .inner,
body.sidebar-collapsed #sidebar .sidebar-footer {
	visibility: hidden;
}

/* Плавающая кнопка меню */
.sidebar-toggle {
	-webkit-tap-highlight-color: transparent;
	align-items: center;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	box-shadow: var(--shadow-md);
	color: var(--color-text);
	cursor: pointer;
	display: flex;
	height: 2.75rem;
	justify-content: center;
	padding: 0;
	position: absolute;
	right: -1.375rem;
	top: 0.75rem;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
	width: 2.75rem;
	z-index: 210;
}

.sidebar-toggle .label {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

.sidebar-toggle-icon::before {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f0c9";
	font-size: 1rem;
}

.sidebar-toggle:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
	box-shadow: 0 6px 20px var(--color-accent-glow);
	color: #fff;
	transform: scale(1.06);
}

body.sidebar-collapsed .sidebar-toggle {
	right: auto;
	left: 0.75rem;
}

/* Main */
#main.site-main {
	min-width: 0;
}

#main > .inner {
	margin: 0;
	max-width: none;
	overflow: visible;
	padding: 0 var(--content-pad-x) 3rem;
	width: 100%;
}

.site-header {
	align-items: center;
	backdrop-filter: blur(12px);
	background: rgba(248, 249, 250, 0.85);
	border-bottom: 1px solid var(--color-border);
	display: flex;
	flex-wrap: wrap;
	gap: 0.75em 1em;
	justify-content: space-between;
	margin: 0 calc(-1 * var(--content-pad-x)) 2rem;
	overflow: visible;
	padding: 1rem var(--content-pad-x);
	position: sticky;
	top: 0;
	z-index: 50;
}

.header-icons {
	overflow: visible;
}

.site-header .header-search-item {
	align-items: center;
	display: flex;
	flex-shrink: 0;
	overflow: visible;
	position: relative;
}

.header-icons li {
	overflow: visible;
}

body.header-scrolled .site-header {
	box-shadow: var(--shadow-sm);
}

.site-brand {
	border: 0;
	color: var(--color-text);
	font-family: var(--font-serif);
	font-size: 1.1em;
	font-weight: 700;
	letter-spacing: -0.02em;
}

.site-brand:hover { color: var(--color-accent); }

body.sidebar-collapsed .site-brand {
	margin-left: 2rem;
}

.header-icons {
	display: flex;
	gap: 0.25em;
	list-style: none;
	margin: 0;
	padding: 0;
}

.header-icons a,
.header-icon-btn {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: var(--radius-sm);
	color: var(--color-muted);
	cursor: pointer;
	display: inline-flex;
	font-size: 1.05em;
	height: 2.25rem;
	justify-content: center;
	padding: 0;
	transition: background 0.2s ease, color 0.2s ease;
	width: 2.25rem;
}

.header-icons a:hover,
.header-icon-btn:hover,
.header-search-toggle[aria-expanded="true"] {
	background: var(--color-accent-soft);
	color: var(--color-accent);
}

.header-icons .label,
.header-icon-btn .label {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

/* Панель поиска — под иконкой, не обрезается краем колонки */
.header-search-panel {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-lg);
	margin: 0;
	min-width: min(20rem, calc(100vw - 2rem));
	opacity: 0;
	overflow: visible;
	padding: 0.4rem;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: calc(100% + 0.45rem);
	transform: translateY(0.35rem);
	transition:
		opacity 0.22s ease,
		transform 0.22s ease,
		visibility 0.22s ease;
	visibility: hidden;
	width: min(22rem, calc(100vw - 2rem));
	z-index: 300;
}

.header-search-panel.is-open {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
	visibility: visible;
}

.header-search-panel .plugin-label,
.header-search-panel h2,
.header-search-panel .sr-only,
.header-search-panel .visually-hidden {
	border: 0 !important;
	clip: rect(0 0 0 0) !important;
	height: 1px !important;
	margin: -1px !important;
	overflow: hidden !important;
	padding: 0 !important;
	position: absolute !important;
	white-space: nowrap !important;
	width: 1px !important;
}

.header-search-panel .plugin-content,
.header-search-panel .search-plugin-form,
.header-search-panel form {
	display: block;
	margin: 0;
	position: relative;
	width: 100%;
}

.header-search-panel .search-plugin-form::before,
.header-search-panel form::before {
	color: var(--color-muted);
	content: "\f002";
	font-family: "Font Awesome 5 Free";
	font-size: 0.9em;
	font-weight: 900;
	left: 0.75em;
	line-height: 1;
	opacity: 0.55;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
}

.header-search-panel .search-plugin-form input[type="search"],
.header-search-panel .search-plugin-form input[type="text"],
.header-search-panel input[type="text"],
.header-search-panel input[type="search"] {
	-webkit-appearance: none;
	appearance: none;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-sizing: border-box;
	color: var(--color-text);
	display: block;
	flex: none;
	font-family: var(--font-sans);
	font-size: 0.95em;
	height: auto;
	line-height: 1.4;
	margin: 0;
	max-width: none;
	min-height: 2.75rem;
	padding: 0.6em 0.85em 0.6em 2.25rem;
	pointer-events: auto;
	position: relative;
	width: 100%;
	z-index: 1;
}

.header-search-panel .search-plugin-form input[type="search"]:focus,
.header-search-panel .search-plugin-form input[type="text"]:focus,
.header-search-panel input[type="text"]:focus,
.header-search-panel input[type="search"]:focus {
	border-color: rgba(245, 106, 106, 0.55);
	box-shadow: 0 0 0 3px var(--color-accent-soft);
	outline: none;
}

.header-search-panel .search-plugin-form button {
	display: none;
}

/* Поиск только в шапке — убрать из сайдбара */
#sidebar #search,
#sidebar .plugin-search {
	display: none !important;
}

.icon::before,
.icons a::before {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	display: inline-block;
	font-family: "Font Awesome 5 Free";
	font-style: normal;
	font-weight: 900;
	line-height: 1;
	text-rendering: auto;
}

.icon.brands::before,
.icons a.brands::before {
	font-family: "Font Awesome 5 Brands";
	font-weight: 400;
}

/* Sidebar */
.sidebar-profile {
	align-items: center;
	display: flex;
	flex-direction: column;
	margin-bottom: 1.5em;
	overflow: hidden;
	text-align: center;
}

.sidebar-avatar {
	border: 3px solid var(--color-bg-elevated);
	border-radius: 50%;
	border-bottom: none !important;
	box-shadow: var(--shadow-md), 0 0 0 4px var(--color-accent-soft);
	display: block;
	line-height: 0;
	margin-bottom: 0.75em;
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.sidebar-avatar img {
	border-radius: 50%;
	display: block;
	height: 120px;
	object-fit: cover;
	width: 120px;
}

.sidebar-avatar:hover {
	border-color: rgba(255, 120, 45, 0.75);
	box-shadow:
		var(--shadow-lg),
		0 0 0 4px rgba(255, 120, 45, 0.55),
		0 0 20px rgba(255, 130, 50, 0.28);
	transform: translateY(-2px);
}

@media (min-width: 1101px) {
	.sidebar-profile {
		overflow: visible;
	}
}

.sidebar-title {
	font-family: var(--font-serif);
	font-size: 1.35em;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 0 0 0.2em;
}

.sidebar-slogan {
	color: var(--color-muted);
	font-size: 0.9em;
	margin: 0 0 0.85em;
}

.social-icons {
	display: flex;
	flex-wrap: nowrap;
	gap: clamp(0.2em, 2vw, 0.4em);
	justify-content: center;
	list-style: none;
	margin: 0 auto;
	max-width: 100%;
	overflow: visible;
	padding: 0;
	width: 100%;
}

.social-icons li {
	flex: 1 1 0;
	margin: 0;
	max-width: 2.65rem;
	min-width: 0;
	overflow: visible;
	padding: 0;
}

.social-icons a {
	align-items: center;
	aspect-ratio: 1;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: 50%;
	border-bottom: none !important;
	box-shadow: var(--shadow-sm);
	color: var(--color-muted);
	display: inline-flex;
	flex: 1 1 auto;
	font-size: 0;
	height: auto;
	justify-content: center;
	line-height: 0;
	margin: 0 auto;
	max-width: 2.65rem;
	min-width: 2rem;
	overflow: visible;
	position: relative;
	transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
	width: 100%;
}

.social-icons a::before {
	font-size: 1.1rem;
	line-height: 1;
	z-index: 1;
}

.social-icons a[data-tooltip]::after {
	background: linear-gradient(135deg, #3d4449 0%, #2a2f33 100%);
	border-radius: var(--radius-sm);
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.22);
	color: #fff;
	content: attr(data-tooltip);
	font-family: var(--font-sans);
	font-size: 0.72rem;
	font-weight: 600;
	left: 50%;
	letter-spacing: 0.03em;
	line-height: 1.25;
	opacity: 0;
	padding: 0.4em 0.7em;
	pointer-events: none;
	position: absolute;
	bottom: calc(100% + 0.5rem);
	transform: translateX(-50%) translateY(4px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
	visibility: hidden;
	white-space: nowrap;
	z-index: 25;
}

.social-icons .label {
	border: 0;
	clip: rect(0, 0, 0, 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

.social-icons a:hover,
.social-icons a:focus-visible {
	background: var(--color-accent);
	border-color: var(--color-accent);
	box-shadow: 0 4px 14px var(--color-accent-glow);
	color: #fff;
	transform: translateY(-3px) scale(1.05);
}

.social-icons a:hover::after,
.social-icons a:focus-visible::after {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
	visibility: visible;
}

#sidebar .plugin {
	margin-bottom: 1.35em;
}

#sidebar .plugin h2,
#sidebar .plugin-label {
	border-bottom: 0 !important;
	display: block;
	font-size: 0.72em !important;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin: 0 0 0.65em !important;
	padding: 0 0 0.45em !important;
	position: relative;
	text-transform: uppercase;
}

#sidebar .plugin h2::after,
#sidebar .plugin-label::after {
	background: linear-gradient(90deg, var(--color-accent), transparent);
	border-radius: 2px;
	content: "";
	display: block;
	height: 3px;
	margin-top: 0.4em;
	width: 2.5rem;
}

/* Ссылки в сайдбаре: категории и статические страницы */
#sidebar .plugin-categories .plugin-content,
#sidebar .plugin-static-pages .plugin-content,
#sidebar .plugin-menu .plugin-content {
	margin: 0;
}

#sidebar .plugin-categories ul,
#sidebar .plugin-static-pages ul,
#sidebar .plugin-menu ul.menu,
#sidebar .plugin-menu ul.submenu {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

#sidebar .plugin-categories ul li,
#sidebar .plugin-static-pages ul li,
#sidebar .plugin-menu ul.menu > li,
#sidebar .plugin-menu ul.submenu li {
	border-top: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}

#sidebar .plugin-static-pages ul li.subpage {
	margin-left: 0 !important;
	padding-left: 0.35rem;
}

#sidebar .plugin-menu ul.menu > li:has(.submenu) {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

#sidebar .plugin-categories ul a,
#sidebar .plugin-static-pages ul a,
#sidebar .plugin-menu a.page-title,
#sidebar .plugin-menu ul.menu > li > a {
	align-items: center;
	background: var(--color-bg-elevated);
	border: 1px solid transparent;
	border-bottom: none !important;
	border-radius: var(--radius-sm);
	color: var(--color-text);
	display: flex;
	font-size: 0.9em !important;
	font-weight: 500;
	gap: 0.55em;
	line-height: 1.35;
	padding: 0.55em 0.7em !important;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

#sidebar .plugin-categories ul a::before,
#sidebar .plugin-static-pages ul a::before,
#sidebar .plugin-menu a.page-title::before,
#sidebar .plugin-menu ul.menu > li > a::before {
	color: var(--color-accent);
	flex-shrink: 0;
	font-family: "Font Awesome 5 Free";
	font-size: 0.85em;
	font-weight: 900;
	opacity: 0.85;
}

#sidebar .plugin-categories ul a::before {
	content: "\f07b";
}

/* Статические страницы — иконка по умолчанию (документ) */
#sidebar .plugin-static-pages ul a::before,
#sidebar .plugin-menu a.page-title::before,
#sidebar .plugin-menu ul.menu > li > a::before {
	content: "\f15c";
}

#sidebar .plugin-static-pages a.sidebar-menu-about::before,
#sidebar .plugin-static-pages ul a[href*="/about"]::before,
#sidebar .plugin-static-pages ul a[href*="/ob-mne"]::before,
#sidebar .plugin-static-pages ul a[href*="/obo-mne"]::before,
#sidebar .plugin-menu a.sidebar-menu-about::before,
#sidebar .plugin-menu ul.menu > li > a[href*="/about"]::before,
#sidebar .plugin-menu ul.menu > li > a[href*="/ob-mne"]::before,
#sidebar .plugin-menu ul.menu > li > a[href*="/obo-mne"]::before {
	content: "\f007";
}

#sidebar .plugin-static-pages a.sidebar-menu-contact::before,
#sidebar .plugin-static-pages ul a[href*="/contact"]::before,
#sidebar .plugin-static-pages ul a[href*="/kontakt"]::before,
#sidebar .plugin-static-pages ul a[href*="/kontakty"]::before,
#sidebar .plugin-menu a.sidebar-menu-contact::before,
#sidebar .plugin-menu ul.menu > li > a[href*="/contact"]::before,
#sidebar .plugin-menu ul.menu > li > a[href*="/kontakt"]::before,
#sidebar .plugin-menu ul.menu > li > a[href*="/kontakty"]::before {
	content: "\f0e0";
}

#sidebar .plugin-categories ul a::after,
#sidebar .plugin-static-pages ul a::after,
#sidebar .plugin-menu a.page-title::after,
#sidebar .plugin-menu ul.menu > li > a::after {
	color: var(--color-muted);
	content: "\f054";
	flex-shrink: 0;
	font-family: "Font Awesome 5 Free";
	font-size: 0.65em;
	font-weight: 900;
	margin-left: auto;
	opacity: 0.45;
	transition: opacity 0.2s ease, transform 0.2s ease, color 0.2s ease;
}

#sidebar .plugin-categories ul a:hover,
#sidebar .plugin-static-pages ul a:hover,
#sidebar .plugin-menu a.page-title:hover,
#sidebar .plugin-menu ul.menu > li > a:hover {
	background: var(--color-accent-soft);
	border-color: rgba(245, 106, 106, 0.25);
	box-shadow: var(--shadow-sm);
	color: var(--color-accent-dark);
	padding-left: 0.7em !important;
	transform: translateX(2px);
}

#sidebar .plugin-categories ul a:hover::after,
#sidebar .plugin-static-pages ul a:hover::after,
#sidebar .plugin-menu a.page-title:hover::after,
#sidebar .plugin-menu ul.menu > li > a:hover::after {
	color: var(--color-accent);
	opacity: 1;
	transform: translateX(2px);
}

/* Подзаголовок группы (plugin-menu, legacy) */
#sidebar .plugin-menu span.category-name {
	color: var(--color-muted) !important;
	display: block;
	font-size: 0.72em;
	font-weight: 600;
	letter-spacing: 0.06em;
	margin: 0.15em 0 0;
	opacity: 1 !important;
	padding: 0 0.15em;
	text-transform: uppercase;
}

/* Теги в сайдбаре */
#sidebar .plugin-tags .plugin-content {
	margin: 0;
}

#sidebar .plugin-tags ul {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

#sidebar .plugin-tags ul li {
	border: 0;
	display: inline-block;
	margin: 0;
}

#sidebar .plugin-tags a {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border) !important;
	border-bottom: none !important;
	border-radius: 999px !important;
	color: var(--color-text) !important;
	display: inline-block;
	font-size: 0.78em !important;
	font-weight: 600;
	height: auto !important;
	line-height: 1.35 !important;
	margin: 0 !important;
	padding: 0.38em 0.85em !important;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

#sidebar .plugin-tags a::before {
	display: none !important;
}

#sidebar .plugin-tags a[data-tooltip] {
	position: relative;
}

#sidebar .plugin-tags a[data-tooltip]::after {
	background: linear-gradient(135deg, #3d4449 0%, #2a2f33 100%);
	border-radius: var(--radius-sm);
	bottom: calc(100% + 0.45rem);
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.22);
	color: #fff;
	content: attr(data-tooltip);
	display: block !important;
	font-family: var(--font-sans);
	font-size: 0.72rem;
	font-weight: 600;
	left: 50%;
	letter-spacing: 0.02em;
	line-height: 1.3;
	max-width: 14rem;
	opacity: 0;
	padding: 0.4em 0.65em;
	pointer-events: none;
	position: absolute;
	text-align: center;
	transform: translateX(-50%) translateY(4px);
	transition: opacity 0.2s ease, transform 0.2s ease;
	white-space: nowrap;
	z-index: 30;
}

#sidebar .plugin-tags a[data-tooltip]:hover::after,
#sidebar .plugin-tags a[data-tooltip]:focus-visible::after {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

#sidebar .plugin-tags a:hover {
	background: var(--color-accent) !important;
	border-color: var(--color-accent) !important;
	box-shadow: 0 4px 12px var(--color-accent-glow);
	color: #fff !important;
	transform: translateY(-2px);
}

#sidebar .sidebar-footer {
	flex-shrink: 0;
	margin-top: auto;
	padding: 0.75rem 1.15rem 1.35rem;
	position: relative;
	width: 100%;
}

#sidebar .sidebar-footer::before {
	background: linear-gradient(90deg, transparent, var(--color-border) 20%, var(--color-border) 80%, transparent);
	content: "";
	height: 1px;
	left: 1rem;
	position: absolute;
	right: 1rem;
	top: 0;
}

#sidebar .sidebar-footer .copyright {
	align-items: center;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.92) 0%, rgba(239, 241, 242, 0.98) 100%);
	border: 1px solid rgba(210, 215, 217, 0.65);
	border-radius: var(--radius);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.85),
		var(--shadow-sm);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.78em;
	gap: 0.4rem 0.55rem;
	justify-content: center;
	line-height: 1.4;
	margin: 0;
	padding: 0.75rem 0.95rem;
	text-align: center;
}

#sidebar .sidebar-footer .copyright-link {
	border: 0;
	color: var(--color-text);
	font-weight: 600;
	letter-spacing: -0.01em;
	transition: color 0.2s ease, text-shadow 0.2s ease;
}

#sidebar .sidebar-footer .copyright-link:hover {
	color: var(--color-accent);
	text-shadow: 0 0 20px var(--color-accent-soft);
}

#sidebar .sidebar-footer .copyright-sep {
	background: linear-gradient(180deg, var(--color-accent), var(--color-tag-cat));
	border-radius: 50%;
	flex-shrink: 0;
	height: 0.3rem;
	opacity: 0.65;
	width: 0.3rem;
}

#sidebar .sidebar-footer .copyright-years {
	color: var(--color-muted);
	font-size: 0.92em;
	font-variant-numeric: tabular-nums;
	font-weight: 500;
	letter-spacing: 0.03em;
	white-space: nowrap;
}

#sidebar .sidebar-footer .copyright-symbol {
	color: var(--color-accent-dark);
	font-weight: 700;
	margin-right: 0.1em;
	opacity: 0.85;
}

/* --- Аккордеон (fast.menu.php) --- */
.accordion-block {
	margin: 0 0 1.25rem;
}

#main > .inner > .accordion-block:first-child {
	margin-top: 0;
}

.site-header + .accordion-block {
	margin-top: -0.75rem;
}

.accordion-block .accordion {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius-lg) !important;
	box-shadow: var(--shadow-sm) !important;
	color: var(--color-text);
	cursor: pointer;
	font-family: var(--font-sans);
	font-size: 0.92em;
	font-weight: 600;
	letter-spacing: 0.02em;
	margin: 0;
	outline: none !important;
	padding: 1em 3rem 1em 1.15em !important;
	position: relative;
	text-align: left;
	transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, color 0.3s ease, transform 0.2s ease;
	width: 100%;
}

.accordion-block .accordion-label {
	display: block;
}

.accordion-block .accordion::after {
	content: "\f078";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 0.85em;
	position: absolute;
	right: 1.15em;
	top: 50%;
	transform: translateY(-50%);
	transition: transform 0.3s ease;
}

.accordion-block .accordion:hover {
	border-color: rgba(245, 106, 106, 0.45) !important;
	box-shadow: var(--shadow-md) !important;
	transform: translateY(-1px);
}

.accordion-block .accordion.active {
	background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
	border-color: transparent !important;
	border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
	box-shadow: 0 8px 28px var(--color-accent-glow) !important;
	color: #fff;
}

.accordion-block .accordion.active::after {
	content: "\f077";
	transform: translateY(-50%) rotate(0deg);
}

.accordion-block .panel {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: 0 0 var(--radius-lg) var(--radius-lg);
	border-top: 0;
	box-shadow: var(--shadow-sm);
	margin: 0;
	max-height: 0;
	overflow: hidden;
	padding: 0;
	transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1), padding 0.35s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.accordion-block .accordion:not(.active) + .panel {
	border-color: transparent;
	box-shadow: none;
}

.accordion-block .accordion.active + .panel {
	padding: 0;
}

.cheatsheet-accordion .accordion {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 1rem;
}

.cheatsheet-accordion .accordion-meta {
	display: none;
}

.cheatsheet-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	padding: 1.15rem 1.15rem 1.25rem;
}

.cheatsheet-col {
	background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-elevated) 100%);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	min-width: 0;
	padding: 0.95rem 0.9rem 1rem;
}

.cheatsheet-col-head {
	align-items: center;
	border-bottom: 1px solid var(--color-border);
	display: flex;
	gap: 0.55rem;
	margin: 0 0 0.85rem;
	padding: 0 0 0.75rem;
}

.cheatsheet-col-icon {
	align-items: center;
	background: var(--color-accent-soft);
	border-radius: var(--radius-sm);
	color: var(--color-accent);
	display: inline-flex;
	flex-shrink: 0;
	font-size: 0.95rem;
	height: 2rem;
	justify-content: center;
	width: 2rem;
}

.cheatsheet-col--cicd .cheatsheet-col-icon {
	background: rgba(126, 198, 153, 0.14);
	color: #5a9e76;
}

.cheatsheet-col--k8s .cheatsheet-col-icon {
	background: rgba(121, 184, 255, 0.14);
	color: #4a8fd4;
}

.cheatsheet-col-title {
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.2;
	margin: 0;
	text-transform: uppercase;
}

.cheatsheet-list {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.cheatsheet-list li {
	margin: 0;
}

.cheatsheet-item {
	align-items: center;
	border: 1px solid transparent;
	border-radius: var(--radius-sm);
	color: var(--color-text);
	display: flex;
	font-size: 0.75rem;
	font-weight: 600;
	gap: 0.5rem;
	letter-spacing: 0.05em;
	line-height: 1.35;
	text-transform: uppercase;
	min-height: 2.1rem;
	padding: 0.4rem 0.55rem;
	text-decoration: none;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.cheatsheet-item::before {
	background: var(--color-accent);
	border-radius: 50%;
	content: "";
	flex-shrink: 0;
	height: 6px;
	width: 6px;
}

.cheatsheet-col--cicd .cheatsheet-item::before {
	background: var(--color-tag-cat);
}

.cheatsheet-col--k8s .cheatsheet-item::before {
	background: #79b8ff;
}

a.cheatsheet-item:hover,
a.cheatsheet-item:focus-visible {
	background: var(--color-accent-soft);
	border-color: rgba(245, 106, 106, 0.25);
	color: var(--color-accent-dark);
	transform: translateX(3px);
}

.cheatsheet-col--cicd a.cheatsheet-item:hover,
.cheatsheet-col--cicd a.cheatsheet-item:focus-visible {
	background: rgba(126, 198, 153, 0.12);
	border-color: rgba(126, 198, 153, 0.35);
	color: #3d7a58;
}

.cheatsheet-col--k8s a.cheatsheet-item:hover,
.cheatsheet-col--k8s a.cheatsheet-item:focus-visible {
	background: rgba(121, 184, 255, 0.12);
	border-color: rgba(121, 184, 255, 0.35);
	color: #2f6fad;
}

.cheatsheet-item.is-plain {
	background: var(--color-surface);
	border-color: var(--color-border);
	color: var(--color-muted);
	cursor: default;
	font-weight: 500;
}

.cheatsheet-item.is-plain::before {
	background: var(--color-muted);
	opacity: 0.45;
}

.cheatsheet-item.is-external::after {
	color: var(--color-muted);
	content: "\f35d";
	flex-shrink: 0;
	font-family: "Font Awesome 5 Free";
	font-size: 0.72em;
	font-weight: 900;
	margin-left: auto;
	opacity: 0.65;
}

/* Линия под аккордеоном — убрать hr и лишние разделители */
.accordion-block + hr,
.accordion-block hr,
.panel + hr,
.accordion + .panel + hr,
.post-content > .panel + hr,
.hero-body > .panel + hr {
	border: 0 !important;
	display: none !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}

.accordion-block .panel .divTable { display: table; width: 100%; }
.accordion-block .panel .divTableBody { display: table-row-group; }
.accordion-block .panel .divTableRow { display: table-row; }
.accordion-block .panel .divTableCell,
.accordion-block .panel .divTableHead {
	display: table-cell;
	padding: 0.65em 0.85em;
	vertical-align: top;
}

.accordion-block .panel .divTableCell strong {
	color: var(--color-accent);
	font-size: 0.82em;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* --- Статья --- */
.article-page {
	--article-pad: clamp(1.25rem, 3vw, 2rem);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	margin-bottom: 2rem;
	overflow: hidden;
	padding: var(--article-pad);
}

.article-page::before {
	background: linear-gradient(90deg, var(--color-accent), var(--color-tag-cat));
	content: "";
	display: block;
	height: 4px;
	margin: calc(-1 * var(--article-pad)) calc(-1 * var(--article-pad)) 1.5rem;
	width: calc(100% + 2 * var(--article-pad));
}

.article-eyebrow {
	color: var(--color-accent);
	font-size: 0.75em;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin: 0 0 0.5em;
	text-transform: uppercase;
}

.article-title {
	font-family: var(--font-serif);
	font-size: clamp(1.65rem, 4vw, 2.35rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.2;
	margin: 0;
}

/* Статья без обложки — отступ между заголовком и текстом */
.article-page--no-cover .article-header,
.article-page:not(:has(.article-cover)) .article-header {
	margin-bottom: 1.75rem;
}

.article-page--no-cover .post-content,
.article-page:not(:has(.article-cover)) .post-content {
	margin-top: 0;
	padding-top: 0;
}

.article-page:not(.article-page--no-cover) .article-cover,
.article-page:has(.article-cover) .article-cover {
	border: 0;
	border-bottom: 1px solid var(--color-border);
	border-radius: 0;
	box-shadow: none;
	height: var(--cover-strip-height);
	isolation: isolate;
	line-height: 0;
	margin: 2rem calc(-1 * var(--article-pad)) 2rem;
	overflow: hidden;
	position: relative;
	width: calc(100% + 2 * var(--article-pad));
}

.article-cover::before {
	border-radius: inherit;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 2;
}

.article-cover::after {
	background:
		linear-gradient(
			105deg,
			rgba(245, 106, 106, 0.1) 0%,
			transparent 42%,
			transparent 58%,
			rgba(126, 198, 153, 0.08) 100%
		),
		linear-gradient(180deg, transparent 55%, rgba(61, 68, 73, 0.06) 100%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 1;
}

.article-cover-link {
	cursor: zoom-in;
	display: block;
	height: 100%;
	overflow: hidden;
	width: 100%;
}

.article-cover-link:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 3px;
}

.article-cover img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
	width: 100%;
}

.article-cover-link:hover img,
.article-cover-link:focus-visible img {
	transform: scale(1.045);
}

@media (prefers-reduced-motion: reduce) {
	.article-cover img {
		transition: none;
	}

	.article-cover-link:hover img,
	.article-cover-link:focus-visible img {
		transform: none;
	}
}

.post-content {
	color: var(--color-text);
	font-size: 1.0625em;
	line-height: 1.75;
	max-width: none;
	overflow-wrap: break-word;
	width: 100%;
}

.post-content > :first-child { margin-top: 0; }
.post-content > :last-child { margin-bottom: 0; }
.post-content p { margin: 0 0 1em; }

.post-content h2,
.post-content h3,
.post-content h4 {
	font-family: var(--font-serif);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.3;
	margin: 1.75em 0 0.6em;
	padding-top: 0.25em;
	position: relative;
}

.post-content h2 {
	font-size: 1.5em;
	padding-left: 0.85em;
}

.post-content h2::before {
	background: var(--color-accent);
	border-radius: 2px;
	content: "";
	height: 1.1em;
	left: 0;
	position: absolute;
	top: 0.35em;
	width: 4px;
}

.post-content h3 {
	font-size: 1.22em;
	padding-left: 0.85em;
}

.post-content h3::before {
	background: var(--color-tag-cat);
	border-radius: 2px;
	content: "";
	height: 1.1em;
	left: 0;
	position: absolute;
	top: 0.35em;
	width: 4px;
}

.post-content h4 { font-size: 1.05em; }

.post-content a {
	border-bottom: 1px solid rgba(245, 106, 106, 0.35);
}

.post-content a:hover { border-bottom-color: var(--color-accent); }

.post-content hr {
	border: 0;
	height: 1px;
	background: linear-gradient(90deg, var(--color-border), transparent);
	margin: 1.5em 0;
}

.post-content ul, .post-content ol {
	margin: 0.65em 0 1em;
	padding-left: 1.35em;
}

.post-content li { margin: 0.2em 0; line-height: 1.6; }
.post-content li > p { margin: 0; }
.post-content li > p + p { margin-top: 0.4em; }

.post-content blockquote {
	background: var(--color-accent-soft);
	border: 0;
	border-left: 4px solid var(--color-accent);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	margin: 1.25em 0;
	padding: 0.5rem;
}

.post-content blockquote > :first-child {
	margin-top: 0;
}

.post-content blockquote > :last-child {
	margin-bottom: 0;
}

.post-content table {
	border-collapse: separate;
	border-spacing: 0;
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-sm);
	margin: 1.25em 0;
	overflow: hidden;
	width: 100%;
}

.post-content th,
.post-content td {
	border: 1px solid var(--color-border);
	padding: 0.55em 0.75em;
}

.post-content th {
	background: var(--color-surface);
	font-weight: 600;
}

.post-content :not(pre) > code {
	background: var(--color-accent-soft);
	border-radius: 0.35em;
	color: var(--color-accent-dark);
	font-family: var(--font-mono);
	font-size: 0.88em;
	padding: 0.15em 0.45em;
}

/* Блоки кода — на всю ширину, тулбар отдельно от текста */
.post-content .code-block {
	background: var(--code-bg);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--radius);
	box-shadow: var(--shadow-md);
	margin: 1.5em 0;
	max-width: none;
	overflow: hidden;
	width: 100%;
}

.code-block-toolbar {
	align-items: center;
	background: linear-gradient(180deg, #2a3038 0%, #23282f 100%);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	display: flex;
	gap: 0.75rem;
	justify-content: space-between;
	min-height: 2.35rem;
	padding: 0 0.65rem 0 0.85rem;
}

.code-block-toolbar::before {
	background: rgba(245, 106, 106, 0.55);
	border-radius: 50%;
	content: "";
	flex-shrink: 0;
	height: 0.4rem;
	margin-right: 0.45rem;
	width: 0.4rem;
}

.code-block-toolbar:not(:has(.code-block-lang)) .code-copy-btn {
	margin-left: auto;
}

.code-block-lang {
	color: #9da7b3;
	flex: 1;
	font-family: var(--font-mono);
	font-size: 0.72em;
	font-weight: 600;
	letter-spacing: 0.06em;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	text-transform: uppercase;
	white-space: nowrap;
}

.post-content .code-block pre {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	color: var(--code-text);
	font-family: var(--font-mono);
	font-size: 0.86em;
	line-height: 1.65;
	margin: 0;
	overflow-x: auto;
	padding: 1rem 1.1rem 1.1rem;
	position: static;
	-webkit-overflow-scrolling: touch;
}

.post-content .code-block pre code {
	background: transparent;
	color: inherit;
	display: block;
	padding: 0;
}

/* Статические страницы (About, Contacts…) — компактные блоки кода */
.view-static .post-content .code-block,
.article-page--static .post-content .code-block {
	display: block;
	max-width: 100%;
	width: fit-content;
}

.view-static .post-content .code-block pre,
.article-page--static .post-content .code-block pre {
	width: auto;
	max-width: 100%;
}

.post-content pre .hljs-comment,
.post-content pre .comment,
.post-content pre code .cm { color: #8b949e; font-style: italic; }
.post-content pre .hljs-keyword,
.post-content pre .keyword,
.post-content pre code .k { color: #ff8a8a; }
.post-content pre .hljs-string,
.post-content pre .string,
.post-content pre code .s { color: #7ec699; }
.post-content pre .hljs-number,
.post-content pre .number,
.post-content pre code .m { color: #e3b76a; }
.post-content pre .hljs-built_in,
.post-content pre .function,
.post-content pre code .nf { color: #79b8ff; }
.post-content pre .hljs-variable,
.post-content pre .variable,
.post-content pre code .nv { color: #d2a8ff; }
.post-content pre .hljs-attr,
.post-content pre code .na { color: #ffa657; }

.code-copy-btn {
	align-items: center;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius-sm);
	color: #e6edf3;
	cursor: pointer;
	display: inline-flex;
	flex-shrink: 0;
	font-size: 0.8em;
	height: 1.75rem;
	justify-content: center;
	margin: 0;
	padding: 0 0.55em;
	position: static;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
	width: 1.75rem;
}

.code-copy-btn:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: #fff;
	transform: scale(1.06);
}

.code-copy-btn.is-copied {
	background: #3d8f5f;
	border-color: #357a52;
	color: #fff;
}

/* Категория и теги внизу статьи — одна строка */
.article-meta {
	border-top: 1px solid var(--color-border);
	margin-top: 2rem;
	padding: 1.5rem 0 1.25rem;
	width: 100%;
}

.article-meta-row {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem 0.55rem;
}

.article-meta-category {
	background: linear-gradient(135deg, var(--color-tag-cat), #5fad82);
	border-radius: 999px;
	box-shadow: 0 2px 10px rgba(126, 198, 153, 0.28);
	color: #fff;
	flex-shrink: 0;
	font-size: 0.72em;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.2;
	padding: 0.45em 1em;
	text-transform: uppercase;
	white-space: nowrap;
}

.article-meta-sep {
	background: var(--color-muted);
	border-radius: 50%;
	flex-shrink: 0;
	height: 0.35rem;
	opacity: 0.4;
	width: 0.35rem;
}

.article-meta-tags {
	align-items: center;
	display: flex;
	flex: 1 1 auto;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0;
	min-width: 0;
	padding: 0;
}

.article-meta-tags li {
	margin: 0;
	padding: 0;
}

.article-meta-tag {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-bottom: none !important;
	border-radius: 999px;
	color: var(--color-muted);
	display: inline-block;
	font-size: 0.78em;
	font-weight: 600;
	line-height: 1.35;
	padding: 0.38em 0.9em;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
	white-space: nowrap;
}

.article-meta-tag:hover {
	background: var(--color-accent-soft);
	border-color: rgba(245, 106, 106, 0.45);
	box-shadow: 0 2px 8px var(--color-accent-glow);
	color: var(--color-accent-dark);
}

/* Кнопки */
.button, a.button {
	background: transparent;
	border: 2px solid var(--color-accent) !important;
	border-radius: 999px !important;
	color: var(--color-accent) !important;
	display: inline-block;
	font-size: 0.78em;
	font-weight: 700;
	letter-spacing: 0.06em;
	padding: 0.7em 1.6em;
	text-transform: uppercase;
	transition: background 0.25s ease, color 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease;
}

.button:hover, a.button:hover {
	background: var(--color-accent) !important;
	box-shadow: 0 6px 20px var(--color-accent-glow);
	color: #fff !important;
	transform: translateY(-2px);
}

.button.primary, a.button.primary {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border-color: transparent !important;
	color: #fff !important;
}

.button.primary:hover {
	box-shadow: 0 10px 28px var(--color-accent-glow);
}

.button.small { font-size: 0.72em; padding: 0.55em 1.2em; }

/* Главная — hero */
.hero-post,
.post-card {
	position: relative;
}

.post-admin-edit {
	align-items: center;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-sm);
	color: var(--color-muted);
	display: inline-flex;
	font-size: 0.85rem;
	height: 2rem;
	justify-content: center;
	line-height: 1;
	opacity: 0.88;
	position: absolute;
	right: 0.75rem;
	text-decoration: none;
	top: 0.75rem;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
	width: 2rem;
	z-index: 4;
}

.post-admin-edit .icon {
	font-size: 0.9rem;
	pointer-events: none;
}

.post-admin-edit:hover,
.post-admin-edit:focus-visible {
	background: var(--color-accent);
	border-color: var(--color-accent);
	box-shadow: 0 4px 14px var(--color-accent-glow);
	color: #fff;
	opacity: 1;
	transform: translateY(-1px);
}

.post-card:hover .post-admin-edit {
	opacity: 1;
}

.post-admin-edit--hero {
	right: 1rem;
	top: 1rem;
}

.hero-post {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	display: grid;
	gap: 0;
	margin-bottom: 2.5rem;
	overflow: hidden;
}

.hero-cover {
	height: var(--cover-strip-height);
	line-height: 0;
	margin: 0;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.hero-cover::after {
	background: linear-gradient(180deg, transparent 40%, rgba(15, 23, 42, 0.55) 100%);
	content: "";
	inset: 0;
	position: absolute;
}

.hero-cover img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
	width: 100%;
}

.hero-post:hover .hero-cover img {
	transform: scale(1.04);
}

.hero-content { padding: clamp(1.25rem, 3vw, 2rem); }

.hero-badge {
	background: var(--color-accent-soft);
	border-radius: 999px;
	color: var(--color-accent-dark);
	display: inline-block;
	font-size: 0.72em;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0 0 0.75em;
	padding: 0.35em 0.85em;
	text-transform: uppercase;
}

.hero-post h1 {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.15;
	margin: 0 0 0.45em;
}

.hero-post h1 a { border: 0; color: var(--color-text); }
.hero-post h1 a:hover { color: var(--color-accent); }

.hero-desc {
	color: var(--color-muted);
	font-size: 1.05em;
	margin: 0 0 1em;
}

.hero-more {
	display: flex;
	justify-content: flex-end;
	margin: 1.25em 0 0;
}

.post-card-more {
	align-self: flex-end;
	display: flex;
	flex-shrink: 0;
	justify-content: flex-end;
	margin: auto 0 0;
	padding-top: 1em;
	text-align: right;
	width: 100%;
}

.post-card-more .button {
	margin: 0;
}

/* Карточки постов */
.post-list .posts {
	display: grid;
	gap: 1.25rem;
}

.post-card {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 0;
	overflow: hidden;
	transition: box-shadow 0.3s ease, transform 0.3s ease, border-color 0.3s ease;
}

.post-card > .post-admin-edit {
	z-index: 6;
}

.post-card:hover {
	border-color: rgba(245, 106, 106, 0.35);
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

/* Без обложки — тонкая цветная полоска вместо «пустого» верха */
.post-card-accent {
	background: linear-gradient(90deg, var(--color-accent) 0%, #ff9a8b 45%, var(--color-tag-cat) 100%);
	flex-shrink: 0;
	height: 4px;
}

/* Мини-карточки: обложка только на странице статьи, не в ленте */
.post-list .post-card .post-card-media,
.post-list .post-card .post-card-thumb,
.post-list .post-card .post-card-image {
	display: none !important;
}

.post-card .post-excerpt img,
.post-card .post-excerpt figure,
.post-card .post-excerpt picture,
.post-card .post-excerpt .image,
.post-card .post-excerpt span.image {
	display: none !important;
}

/* legacy: превью обложки в карточке (если осталась старая разметка на NFS) */
.post-card-media {
	border: 0;
	display: block;
	flex-shrink: 0;
	height: var(--cover-strip-height);
	line-height: 0;
	overflow: hidden;
	position: relative;
}

.post-card-media::after {
	background: linear-gradient(
		180deg,
		transparent 0%,
		transparent 45%,
		rgba(255, 255, 255, 0.12) 100%
	);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 1;
}

.post-card-media img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
	width: 100%;
}

.post-card:hover .post-card-media img {
	transform: scale(1.05);
}

.post-card-body {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	min-height: 0;
	padding: 1.2rem 1.35rem 1.35rem;
}

.post-card h3 {
	font-family: var(--font-serif);
	font-size: clamp(1.35rem, 2.8vw, 1.85rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.25;
	margin: 0 0 0.5em;
}

.post-card h3 a { border: 0; color: var(--color-text); }
.post-card h3 a:hover { color: var(--color-accent); }

.post-excerpt {
	color: var(--color-muted);
	flex: 1 1 auto;
	font-size: 0.95em;
	min-height: 0;
}

.post-card-body > .post-excerpt > :last-child {
	margin-bottom: 0;
}

@media (min-width: 1500px) {
	.post-list .posts {
		align-items: stretch;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.35rem;
	}

	.post-card-body {
		display: grid;
		flex: 1 1 auto;
		grid-template-rows: auto minmax(0, 1fr) auto;
		min-height: 0;
	}

	.post-excerpt {
		align-self: start;
		min-height: 0;
	}

	.post-card-more {
		align-self: end;
		justify-self: end;
		margin: 0;
		padding-top: 1.15rem;
		width: auto;
	}

	.post-card-more .button {
		margin-left: 0;
	}
}

.paginator {
	margin-top: 2.5rem;
	text-align: center;
}

.paginator .pagination {
	align-items: center;
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.75rem 1.25rem;
	justify-content: center;
	list-style: none;
	margin: 0 auto;
	max-width: 100%;
	padding: 0;
}

.paginator .pagination-item {
	list-style: none;
	margin: 0;
	padding: 0;
}

.paginator .pagination-numbers {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
}

.paginator .pagination-numbers li {
	margin: 0;
	padding: 0;
}

.paginator .pagination-btn,
.paginator .pagination-page {
	align-items: center;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-bottom: none !important;
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-sm);
	color: var(--color-text);
	display: inline-flex;
	font-size: 0.82em;
	font-weight: 600;
	gap: 0.4em;
	justify-content: center;
	line-height: 1;
	min-height: 2.35rem;
	min-width: 2.35rem;
	padding: 0.5em 0.85em;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.paginator .pagination-page {
	padding: 0.5em 0.65em;
}

.paginator .pagination-btn:hover,
.paginator .pagination-page:hover {
	background: var(--color-accent-soft);
	border-color: rgba(245, 106, 106, 0.35);
	color: var(--color-accent-dark);
	transform: translateY(-1px);
}

.paginator .pagination-page.is-active {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border-color: transparent;
	box-shadow: 0 4px 14px var(--color-accent-glow);
	color: #fff;
	cursor: default;
}

.paginator .pagination-btn.is-disabled {
	background: var(--color-surface);
	border-color: var(--color-border);
	box-shadow: none;
	color: var(--color-muted);
	cursor: not-allowed;
	opacity: 0.55;
	pointer-events: none;
	transform: none;
}

.paginator .pagination-btn-label {
	letter-spacing: 0.02em;
}

@media (max-width: 480px) {
	.paginator .pagination-btn-label {
		border: 0;
		clip: rect(0 0 0 0);
		height: 1px;
		margin: -1px;
		overflow: hidden;
		padding: 0;
		position: absolute;
		width: 1px;
	}

	.paginator .pagination-btn,
	.paginator .pagination-page {
		min-width: 2.15rem;
		padding: 0.5em 0.65em;
	}
}

.empty-feed {
	color: var(--color-muted);
	text-align: center;
	padding: 3rem 1rem;
}

/* Mobile */
@media (max-width: 1100px) {
	#wrapper.site-layout,
	body.sidebar-collapsed #wrapper.site-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	#sidebar.site-sidebar {
		border-right: 0;
		height: 0;
		left: 0;
		max-height: none;
		min-height: 0;
		overflow: visible;
		pointer-events: none;
		position: fixed;
		right: 0;
		top: 0;
		transition: box-shadow 0.4s ease;
		width: 100%;
		/* Выше .site-header (50 + backdrop-filter), иначе кнопка меню не видна */
		z-index: 10005;
	}

	/* Закрытое меню: скрыть контент, кнопку «гамбургер» не обрезать (overflow у родителя) */
	#sidebar.site-sidebar:not(.is-mobile-open) {
		background: transparent;
		border: 0;
		box-shadow: none;
		height: 0;
		overflow: visible;
	}

	#sidebar.site-sidebar:not(.is-mobile-open)::before {
		display: none;
	}

	#sidebar.site-sidebar:not(.is-mobile-open) > .inner,
	#sidebar.site-sidebar:not(.is-mobile-open) .sidebar-footer {
		display: none !important;
		visibility: hidden;
	}

	#sidebar.site-sidebar.is-mobile-open {
		pointer-events: auto;
		z-index: 10020;
	}

	#sidebar.site-sidebar:not(.is-mobile-open) .sidebar-toggle {
		opacity: 1;
		pointer-events: auto;
		visibility: visible;
	}

	#sidebar.site-sidebar.is-mobile-open {
		box-shadow: var(--shadow-lg);
		display: flex;
		flex-direction: column;
		height: 100dvh;
		max-height: 100dvh;
		min-height: 100dvh;
		overflow: hidden;
	}

	#sidebar.site-sidebar.is-mobile-open > .inner {
		flex: 1 1 auto;
		min-height: 0;
		overflow-x: hidden;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}

	#sidebar.site-sidebar.is-mobile-open .sidebar-footer {
		flex-shrink: 0;
	}

	.sidebar-toggle {
		border-radius: var(--radius-sm);
		box-shadow: var(--shadow-sm);
		height: 2.75rem;
		left: var(--content-pad-x);
		position: fixed;
		right: auto;
		top: 0.625rem;
		width: 2.75rem;
		z-index: 10030;
	}

	body.layout-mobile .site-header {
		align-items: center;
		flex-wrap: nowrap;
		gap: 0.5rem;
		justify-content: flex-start;
		min-height: 3.25rem;
		padding-left: calc(var(--content-pad-x) + 2.75rem + 0.65rem);
	}

	body.layout-mobile .site-header .site-brand {
		color: var(--color-text);
		display: block !important;
		flex: 1 1 auto;
		font-size: 1.02rem;
		line-height: 1.25;
		min-width: 0;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	body.layout-mobile .site-header .site-brand strong {
		font-weight: 700;
	}

	body.layout-mobile .site-header .header-icons {
		flex: 0 0 auto;
		margin-left: auto;
	}

	body.sidebar-mobile-open::before {
		backdrop-filter: blur(4px);
		background: rgba(15, 23, 42, 0.45);
		content: "";
		inset: 0;
		position: fixed;
		z-index: 10000;
	}

	body.sidebar-mobile-open { overflow: hidden; }

	/* Теги — те же чипы, что на десктопе (без отдельной рамки/скролла) */
	#sidebar .plugin-tags .plugin-content {
		background: transparent;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		margin: 0;
		max-height: none;
		overflow: visible;
		padding: 0;
	}

	#sidebar .plugin-tags a {
		-webkit-tap-highlight-color: transparent;
	}

	#sidebar .plugin-tags a:active {
		background: var(--color-accent) !important;
		border-color: var(--color-accent) !important;
		color: #fff !important;
		transform: scale(0.97);
	}

	.article-page { border-radius: var(--radius); }

	.panel .divTable,
	.panel .divTableBody,
	.panel .divTableRow,
	.panel .divTableCell {
		display: block;
		width: 100% !important;
		text-align: left !important;
	}

	.cheatsheet-grid {
		grid-template-columns: 1fr;
		padding: 1rem;
	}
}

@media (max-width: 736px) {
	.sidebar-avatar img { height: 96px; width: 96px; }
	.post-content { font-size: 1em; }
	.post-content .code-block pre { font-size: 0.78em; }

	.header-search-panel {
		min-width: min(16rem, calc(100vw - 2 * var(--content-pad-x) - 1rem));
		width: min(18rem, calc(100vw - 2 * var(--content-pad-x) - 1rem));
	}

	.post-card-body {
		padding: 1rem 1.1rem 1.1rem;
	}

}

/* Lightbox — галерея статьи, пропорции, подпись в одну строку */
.lightboxOverlay {
	background: rgba(15, 23, 42, 0.94) !important;
	display: none !important;
	opacity: 1 !important;
}

.lightboxOverlay[style*="display: block"],
.lightboxOverlay[style*="display:block"] {
	align-items: center !important;
	display: flex !important;
	justify-content: center !important;
}

.lightbox {
	left: 50% !important;
	margin: 0 !important;
	max-width: 96vw;
	padding: 0 !important;
	position: fixed !important;
	right: auto !important;
	top: 50% !important;
	transform: translate(-50%, -50%) !important;
	width: auto !important;
	z-index: 10000 !important;
}

.lightbox .lb-outerContainer {
	background: transparent;
	border-radius: var(--radius);
	height: auto !important;
	margin: 0 auto;
	max-height: calc(100vh - 3.25rem) !important;
	max-width: 100vw !important;
	width: auto !important;
}

.lightbox .lb-container {
	padding: 0;
}

.lightbox .lb-image {
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-lg);
	display: block !important;
	max-height: calc(100vh - 3.25rem) !important;
	max-width: 100vw !important;
	object-fit: contain;
}

.lightbox .lb-dataContainer {
	background: transparent;
	height: 0;
	margin: 0;
	overflow: visible;
	padding: 0;
	pointer-events: none;
	position: static;
	width: 100%;
}

.lightbox .lb-data {
	height: 0;
	overflow: visible;
	position: static;
	width: 100%;
}

.lightbox .lb-data .lb-details {
	bottom: max(1.25rem, env(safe-area-inset-bottom, 0px));
	left: 50%;
	max-width: min(92vw, 48rem);
	pointer-events: none;
	position: fixed;
	transform: translateX(-50%);
	width: 100%;
	z-index: 10002;
}

.lightbox .lb-data .lb-caption {
	color: #f1f3f5;
	display: block;
	font-family: var(--font-sans);
	font-size: clamp(0.85rem, 2.2vw, 0.95rem);
	font-weight: 500;
	line-height: 1.35;
	overflow: hidden;
	padding: 0.5rem 1rem;
	text-align: center;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.lightbox .lb-data .lb-number {
	display: none !important;
}

.lightbox .lb-close {
	background: rgba(255, 255, 255, 0.14) !important;
	border-radius: 50%;
	filter: none !important;
	height: 2.75rem !important;
	opacity: 1 !important;
	pointer-events: auto;
	position: fixed !important;
	right: max(1rem, env(safe-area-inset-right, 0px)) !important;
	top: max(1rem, env(safe-area-inset-top, 0px)) !important;
	transition: background 0.2s ease, transform 0.2s ease;
	width: 2.75rem !important;
	z-index: 10003 !important;
}

.lightbox .lb-close:hover,
.lightbox .lb-close:focus-visible {
	background: rgba(255, 255, 255, 0.24) !important;
	transform: scale(1.06);
}

.lightbox .lb-nav a.lb-prev,
.lightbox .lb-nav a.lb-next {
	opacity: 0.92;
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.lightbox .lb-nav a.lb-prev {
	left: max(0.5rem, env(safe-area-inset-left, 0px)) !important;
}

.lightbox .lb-nav a.lb-next {
	right: max(0.5rem, env(safe-area-inset-right, 0px)) !important;
}

.lightbox .lb-nav a.lb-prev:hover,
.lightbox .lb-nav a.lb-next:hover {
	opacity: 1;
}

.post-content a[data-lightbox] img {
	cursor: zoom-in;
	transition: box-shadow 0.25s ease;
}

.post-content a[data-lightbox]:hover img,
.post-content a[data-lightbox]:focus-visible img {
	box-shadow: 0 8px 28px rgba(15, 23, 42, 0.12);
}

.article-cover a[data-lightbox] img {
	cursor: zoom-in;
}

/* ── Комментарии (pluginComments / Snicker) ── */
.article-page #comments.blc-front,
.article-page #comments.snicker-comments,
.article-page #disqus_thread {
	margin-top: 2.75rem;
	max-width: none;
	width: 100%;
}

.article-page #comments.blc-front,
.article-page #comments.snicker-comments {
	background:
		linear-gradient(165deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 249, 250, 0.98) 55%, rgba(245, 106, 106, 0.04) 100%);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	color: var(--color-text);
	font-family: var(--font-sans);
	margin-top: 2.75rem;
	padding: clamp(1.35rem, 3vw, 2rem);
	position: relative;
}

.article-page #comments.blc-front::before,
.article-page #comments.snicker-comments::before {
	background: linear-gradient(90deg, var(--color-accent), var(--color-tag-cat));
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
	content: "";
	height: 4px;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.article-page .blc-front__title {
	align-items: center;
	color: var(--color-text);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--font-serif);
	font-size: clamp(1.25rem, 2.8vw, 1.55rem);
	font-weight: 700;
	gap: 0.65rem;
	letter-spacing: -0.03em;
	line-height: 1.25;
	margin: 0.35rem 0 1.5rem;
}

.article-page .comments-title-badge {
	align-items: center;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border-radius: 999px;
	box-shadow: 0 4px 14px var(--color-accent-glow);
	color: #fff;
	display: inline-flex;
	flex-shrink: 0;
	font-family: var(--font-sans);
	font-size: 0.82rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 2rem;
	min-width: 2rem;
	padding: 0 0.55rem;
}

.article-page .blc-front__title .blc-icon {
	color: var(--color-accent);
	flex-shrink: 0;
	height: 1.35rem;
	stroke: var(--color-accent);
	width: 1.35rem;
}

.article-page .blc-alert {
	border-radius: var(--radius);
	font-size: 0.9em;
	line-height: 1.5;
	margin-bottom: 1.25rem;
	padding: 0.9rem 1.1rem 0.9rem 2.75rem;
	position: relative;
}

.article-page .blc-alert::before {
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	left: 1rem;
	position: absolute;
	top: 0.95rem;
}

.article-page .blc-alert--success {
	background: rgba(126, 198, 153, 0.14);
	border: 1px solid rgba(126, 198, 153, 0.4);
	color: #2d6a4a;
}

.article-page .blc-alert--success::before {
	color: #3d7a58;
	content: "\f058";
}

.article-page .blc-alert--error {
	background: var(--color-accent-soft);
	border: 1px solid rgba(245, 106, 106, 0.38);
	color: var(--color-accent-dark);
}

.article-page .blc-alert--error::before {
	color: var(--color-accent);
	content: "\f06a";
}

.article-page .blc-front__list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-bottom: 2rem;
}

.article-page .blc-front__comment {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	display: grid;
	gap: 0.5rem 1rem;
	grid-template-columns: 3.25rem minmax(0, 1fr);
	padding: 0;
	position: relative;
}

.article-page .blc-front__comment::after {
	display: none;
}

.article-page .blc-front__avatar {
	align-items: center;
	background: linear-gradient(
		145deg,
		hsl(var(--avatar-hue, 8), 72%, 58%) 0%,
		hsl(var(--avatar-hue, 8), 65%, 42%) 100%
	);
	border: 3px solid var(--color-bg-elevated);
	border-radius: 50%;
	box-shadow: 0 4px 14px hsla(var(--avatar-hue, 8), 55%, 40%, 0.35);
	color: #fff;
	display: flex;
	flex-shrink: 0;
	font-family: var(--font-sans);
	font-size: 1.1rem;
	font-weight: 700;
	grid-column: 1;
	grid-row: 1 / span 2;
	height: 3.25rem;
	justify-content: center;
	line-height: 1;
	margin-top: 0.15rem;
	width: 3.25rem;
}

.article-page .blc-front__comment-header {
	align-items: center;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius) var(--radius) var(--radius-sm) var(--radius-sm);
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 0.65rem;
	grid-column: 2;
	margin: 0;
	padding: 0.55rem 0.85rem;
}

.article-page .blc-front__author {
	color: var(--color-text);
	font-size: 0.92rem;
	font-weight: 700;
}

.article-page .blc-front__date {
	background: var(--color-surface);
	border-radius: 999px;
	color: var(--color-muted);
	font-size: 0.72rem;
	font-variant-numeric: tabular-nums;
	padding: 0.2em 0.55em;
}

.article-page .blc-front__date::before {
	content: "\f017\00a0";
	font-family: "Font Awesome 5 Free";
	font-weight: 400;
	opacity: 0.75;
}

.article-page .blc-front__content {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg);
	box-shadow: var(--shadow-sm);
	color: var(--color-text);
	font-size: 0.96rem;
	grid-column: 2;
	line-height: 1.7;
	margin: 0;
	padding: 1rem 1.1rem 1.05rem;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.article-page .blc-front__comment:hover .blc-front__content {
	border-color: rgba(245, 106, 106, 0.28);
	box-shadow: var(--shadow-md);
}

.article-page .blc-front__content p {
	margin: 0 0 0.65em;
}

.article-page .blc-front__content p:last-child {
	margin-bottom: 0;
}

.article-page .blc-front__content a {
	border-bottom: 1px solid rgba(245, 106, 106, 0.35);
	color: var(--color-accent-dark);
	text-decoration: none;
}

.article-page .blc-front__content a:hover {
	border-bottom-color: var(--color-accent);
	color: var(--color-accent);
}

.article-page .blc-front__content code {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-family: var(--font-mono);
	font-size: 0.86em;
	padding: 0.15em 0.45em;
}

.article-page .blc-front__empty {
	background: var(--color-bg-elevated);
	border: 1px dashed rgba(245, 106, 106, 0.28);
	border-radius: var(--radius-lg);
	color: var(--color-muted);
	font-size: 0.95rem;
	line-height: 1.55;
	margin-bottom: 1.75rem;
	padding: 1.5rem 1.25rem;
	text-align: center;
}

.article-page .blc-front__empty::before {
	color: var(--color-accent);
	content: "\f4ad";
	display: block;
	font-family: "Font Awesome 5 Free";
	font-size: 1.65rem;
	font-weight: 400;
	margin-bottom: 0.65rem;
	opacity: 0.65;
}

.article-page .blc-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
	justify-content: center;
	margin: 0.25rem 0 1.85rem;
}

.article-page .blc-pagination__btn {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	color: var(--color-text);
	cursor: pointer;
	font-family: var(--font-sans);
	font-size: 0.84rem;
	font-weight: 600;
	min-height: 2.5rem;
	min-width: 2.5rem;
	padding: 0 0.65rem;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.article-page .blc-pagination__btn:hover:not(:disabled) {
	border-color: rgba(245, 106, 106, 0.4);
	box-shadow: var(--shadow-sm);
	color: var(--color-accent);
	transform: translateY(-1px);
}

.article-page .blc-pagination__btn.is-active {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border-color: transparent;
	box-shadow: 0 6px 18px var(--color-accent-glow);
	color: #fff;
}

.article-page .blc-pagination__btn:disabled {
	cursor: not-allowed;
	opacity: 0.45;
}

.article-page .blc-front__form-wrap {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	padding: clamp(1.2rem, 2.5vw, 1.65rem);
}

.article-page .blc-front__form-title {
	align-items: center;
	color: var(--color-text);
	display: flex;
	font-family: var(--font-serif);
	font-size: 1.15rem;
	font-weight: 700;
	gap: 0.6rem;
	letter-spacing: -0.02em;
	margin: 0 0 1.25rem;
}

.article-page .comments-form-icon {
	align-items: center;
	background: var(--color-accent-soft);
	border-radius: var(--radius-sm);
	color: var(--color-accent);
	display: inline-flex;
	flex-shrink: 0;
	font-size: 0.95rem;
	height: 2.25rem;
	justify-content: center;
	width: 2.25rem;
}

.article-page .blc-front__field {
	margin-bottom: 1rem;
}

.article-page .blc-front__field label {
	color: var(--color-text);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.8rem;
	font-weight: 600;
	gap: 0.35rem;
	letter-spacing: 0.03em;
	margin-bottom: 0.45rem;
	text-transform: uppercase;
}

.article-page .blc-front__field label.confirm__sending,
.article-page .blc-front__field label.blc-front__checkbox-label {
	margin-bottom: 0.5rem;
	text-transform: none;
}

.article-page .blc-required {
	color: var(--color-accent);
	font-weight: 700;
}

.article-page .blc-md-hint {
	color: var(--color-muted);
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0;
	text-transform: none;
}

.article-page .blc-md-hint code {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-muted);
	font-size: 0.92em;
	padding: 0.1em 0.35em;
}

.article-page .blc-front__field input[type="text"],
.article-page .blc-front__field input[type="email"],
.article-page .blc-front__field textarea {
	-webkit-appearance: none;
	appearance: none;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-sizing: border-box;
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: 0.96rem;
	line-height: 1.5;
	padding: 0.7em 0.95em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	width: 100%;
}

.article-page .blc-front__field input[type="text"]:focus,
.article-page .blc-front__field input[type="email"]:focus,
.article-page .blc-front__field textarea:focus {
	background: #fff;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px var(--color-accent-soft);
	outline: none;
}

.article-page .blc-front__field textarea {
	min-height: 9.5rem;
	resize: vertical;
}

.article-page .blc-front__checkbox-label {
	align-items: flex-start;
	cursor: pointer;
	display: flex;
	flex-wrap: wrap;
	font-size: 0.9rem;
	font-weight: 500;
	gap: 0.55rem;
	letter-spacing: 0;
	line-height: 1.45;
	text-transform: none;
}

.article-page .blc-front__checkbox-label input[type="checkbox"] {
	accent-color: var(--color-accent);
	flex-shrink: 0;
	height: 1.1rem;
	margin: 0.15rem 0 0;
	width: 1.1rem;
}

.article-page .blc-char-count {
	color: var(--color-muted);
	font-size: 0.78rem;
	margin-top: 0.4rem;
	text-align: right;
}

.article-page .blc-front__field altcha-widget {
	display: block;
	margin-top: 0.35rem;
	max-width: 100%;
}

.article-page .blc-front__actions {
	border-top: 1px solid var(--color-border);
	display: flex;
	justify-content: flex-end;
	margin-top: 0.5rem;
	padding-top: 1.15rem;
}

.article-page .blc-btn-submit {
	align-items: center;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border: 0;
	border-radius: 999px;
	box-shadow: 0 8px 24px var(--color-accent-glow);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--font-sans);
	font-size: 0.88rem;
	font-weight: 700;
	gap: 0.5rem;
	letter-spacing: 0.02em;
	padding: 0.8em 1.55em;
	text-transform: none;
	transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.article-page .blc-btn-submit:hover {
	background: linear-gradient(135deg, var(--color-accent-hover), var(--color-accent));
	box-shadow: 0 12px 30px var(--color-accent-glow);
	transform: translateY(-2px);
}

.article-page .blc-btn-submit:active {
	transform: translateY(0);
}

@media (max-width: 736px) {
	.article-page #comments.blc-front {
		padding: 1.1rem;
	}

	.article-page .blc-front__comment {
		grid-template-columns: 2.65rem minmax(0, 1fr);
	}

	.article-page .blc-front__avatar {
		font-size: 0.95rem;
		height: 2.65rem;
		width: 2.65rem;
	}

	.article-page .blc-front__actions {
		justify-content: stretch;
	}

	.article-page .blc-btn-submit {
		justify-content: center;
		width: 100%;
	}
}

/* Snicker — карточки комментариев */
.article-page #comments.snicker-comments {
	--snicker-reply-step: clamp(0.65rem, 2vw, 1rem);
	display: flex;
	flex-direction: column;
	padding-top: clamp(1.35rem, 3vw, 2rem);
}

/* В разметке Snicker форма выше списка — показываем: заголовок → карточки → форма */
.article-page #comments.snicker-comments > .comments-section-head {
	order: 1;
}

.article-page #comments.snicker-comments > .snicker-comments-list {
	order: 2;
}

.article-page #comments.snicker-comments > .snicker-comments-form,
.article-page #comments.snicker-comments > #comments-form {
	order: 3;
}

.article-page #comments.snicker-comments .comments-section-head {
	margin: 0.35rem 0 1.35rem;
}

.article-page #comments.snicker-comments .comments-section-title {
	align-items: center;
	color: var(--color-text);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--font-serif);
	font-size: clamp(1.25rem, 2.8vw, 1.55rem);
	font-weight: 700;
	gap: 0.65rem;
	letter-spacing: -0.03em;
	line-height: 1.25;
	margin: 0;
}

.article-page #comments.snicker-comments .snicker-comments-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-bottom: 1.25rem;
}

.article-page #comments.snicker-comments .snicker-comments-list .comment {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	margin: 0 !important;
	max-width: 100%;
	overflow: hidden;
	padding: 0;
	position: relative;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	width: 100%;
}

/* Ответ на комментарий — сдвиг карточки вправо (не влево) */
.article-page #comments.snicker-comments .snicker-comments-list .comment.snicker-comment--reply {
	border-left: 3px solid rgba(245, 106, 106, 0.45);
	margin-left: calc(var(--snicker-reply-step) * var(--snicker-depth, 1)) !important;
	margin-right: 0;
	max-width: none;
	width: auto;
}

.article-page #comments.snicker-comments .snicker-comments-list .comment:hover {
	border-color: rgba(245, 106, 106, 0.28);
	box-shadow: var(--shadow-md);
}

.article-page #comments.snicker-comments .snicker-comments-list .comment.new-comment {
	border-color: rgba(245, 106, 106, 0.45);
	box-shadow: 0 0 0 3px var(--color-accent-soft), var(--shadow-md);
}

.article-page #comments.snicker-comments .snicker-comments-list .comment.snicker-comment--pending {
	background: linear-gradient(165deg, #fffdf8 0%, var(--color-bg-elevated) 72%);
	border-color: rgba(245, 158, 11, 0.42);
	box-shadow: 0 4px 18px rgba(245, 158, 11, 0.1);
}

.article-page #comments.snicker-comments .snicker-comment-body.table,
.article-page #comments.snicker-comments .snicker-comments-list .comment > .table {
	align-items: flex-start;
	border: 0;
	display: flex;
	gap: 1rem;
	padding: 1.1rem 1.2rem 0.9rem;
	width: 100%;
}

.article-page #comments.snicker-comments .snicker-comments-list .comment .table-cell {
	display: block;
	padding: 0;
	vertical-align: top;
	width: auto;
}

.article-page #comments.snicker-comments .comment-avatar {
	flex: 0 0 3.35rem;
	padding: 0 !important;
	position: relative;
	width: 3.35rem;
}

.article-page #comments.snicker-comments .comment-avatar img {
	border: 3px solid var(--color-bg-elevated);
	border-radius: 50%;
	box-shadow: 0 4px 14px rgba(15, 23, 42, 0.12);
	display: block;
	height: 3.35rem;
	object-fit: cover;
	width: 3.35rem;
}

.article-page #comments.snicker-comments .comment-avatar .blc-front__avatar,
.article-page #comments.snicker-comments .snicker-comment-avatar-fallback {
	align-items: center;
	background: linear-gradient(
		145deg,
		hsl(var(--avatar-hue, 8), 72%, 58%) 0%,
		hsl(var(--avatar-hue, 8), 65%, 42%) 100%
	);
	border: 3px solid var(--color-bg-elevated);
	border-radius: 50%;
	box-shadow: 0 4px 14px hsla(var(--avatar-hue, 8), 55%, 40%, 0.35);
	color: #fff;
	display: flex;
	flex-shrink: 0;
	font-family: var(--font-sans);
	font-size: 1.15rem;
	font-weight: 700;
	height: 3.35rem;
	justify-content: center;
	line-height: 1;
	width: 3.35rem;
}

.article-page #comments.snicker-comments .comment-content {
	flex: 1 1 auto;
	min-width: 0;
	padding: 0 !important;
}

.article-page #comments.snicker-comments .comment-meta,
.article-page #comments.snicker-comments .snicker-comment-meta {
	margin: 0 0 0.55rem;
	padding: 0;
}

.article-page #comments.snicker-comments .comment-title {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	font-size: 1rem;
	font-weight: 700;
	gap: 0.5rem;
	line-height: 1.35;
	margin: 0 0 0.45rem;
}

.article-page #comments.snicker-comments .snicker-comment-moderation-badge,
.article-page #comments.snicker-comments .comment-moderation.snicker-comment-moderation-badge {
	align-items: center;
	background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
	border-radius: 999px;
	box-shadow: 0 2px 10px rgba(217, 119, 6, 0.28);
	color: #fff;
	display: inline-flex;
	flex-shrink: 0;
	font-family: var(--font-sans);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1;
	margin: 0;
	padding: 0.28rem 0.55rem;
	text-transform: uppercase;
	vertical-align: middle;
	white-space: nowrap;
}

.article-page #comments.snicker-comments .snicker-comment-meta-line {
	align-items: baseline;
	color: var(--color-muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.88rem;
	gap: 0.2rem 0.35rem;
	line-height: 1.45;
}

.article-page #comments.snicker-comments .snicker-comment-meta-line .snicker-comment-moderation-badge {
	margin-left: 0.15rem;
}

.article-page #comments.snicker-comments .snicker-comment-meta-prefix {
	color: var(--color-muted);
	font-weight: 500;
}

.article-page #comments.snicker-comments .meta-author,
.article-page #comments.snicker-comments .snicker-comment-author {
	color: var(--color-text);
	font-size: 0.95rem;
	font-weight: 700;
}

.article-page #comments.snicker-comments .snicker-comment-meta-sep {
	color: var(--color-muted);
	font-weight: 400;
	opacity: 0.65;
}

.article-page #comments.snicker-comments .meta-date,
.article-page #comments.snicker-comments .snicker-comment-date {
	color: var(--color-muted);
	font-size: 0.88rem;
	font-variant-numeric: tabular-nums;
	font-weight: 500;
}

.article-page #comments.snicker-comments .comment-comment {
	color: var(--color-text);
	font-size: 0.96rem;
	line-height: 1.7;
	margin: 0;
	padding: 0;
}

.article-page #comments.snicker-comments .comment-comment p {
	margin: 0 0 0.65em;
}

.article-page #comments.snicker-comments .comment-comment p:last-child {
	margin-bottom: 0;
}

.article-page #comments.snicker-comments .comment-action,
.article-page #comments.snicker-comments .snicker-comment-actions {
	background: var(--color-surface);
	border-top: 1px solid var(--color-border);
	margin: 0;
	padding: 0.65rem 1.2rem;
}

.article-page #comments.snicker-comments .comment-action > .table,
.article-page #comments.snicker-comments .snicker-comment-actions > .table {
	align-items: center;
	display: flex;
	gap: 0.75rem;
	justify-content: space-between;
	margin: 0;
	padding: 0;
	width: 100%;
}

.article-page #comments.snicker-comments .comment-action .table-cell,
.article-page #comments.snicker-comments .snicker-comment-actions .table-cell {
	display: block;
	padding: 0;
	width: auto;
}

.article-page #comments.snicker-comments .snicker-comment-votes {
	align-items: center;
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.article-page #comments.snicker-comments .comment-action a.action-like,
.article-page #comments.snicker-comments .comment-action a.action-dislike,
.article-page #comments.snicker-comments .snicker-comment-votes a {
	align-items: center;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	color: var(--color-muted);
	cursor: pointer;
	display: inline-flex;
	font-size: 0;
	gap: 0.35rem;
	height: 2.35rem;
	justify-content: center;
	line-height: 1;
	min-width: 2.35rem;
	opacity: 1;
	padding: 0 0.65rem;
	text-decoration: none;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.article-page #comments.snicker-comments .comment-action a.action-like > *,
.article-page #comments.snicker-comments .comment-action a.action-dislike > * {
	pointer-events: none;
}

.article-page #comments.snicker-comments .comment-action a.action-like .icon,
.article-page #comments.snicker-comments .comment-action a.action-dislike .icon {
	font-size: 0.95rem;
}

.article-page #comments.snicker-comments .comment-action a.action-like .snicker-vote-count,
.article-page #comments.snicker-comments .comment-action a.action-dislike .snicker-vote-count {
	color: inherit;
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 700;
	margin: 0;
}

.article-page #comments.snicker-comments .comment-action a.action-like {
	border-color: rgba(40, 167, 69, 0.35);
	color: #2d6a4a;
}

.article-page #comments.snicker-comments .comment-action a.action-like:hover,
.article-page #comments.snicker-comments .comment-action a.action-like.active {
	background: rgba(40, 167, 69, 0.12);
	border-color: #28a745;
	color: #1e5631;
}

.article-page #comments.snicker-comments .comment-action a.action-dislike {
	border-color: rgba(220, 53, 69, 0.32);
	color: #a63d4a;
}

.article-page #comments.snicker-comments .comment-action a.action-dislike:hover,
.article-page #comments.snicker-comments .comment-action a.action-dislike.active {
	background: rgba(220, 53, 69, 0.1);
	border-color: #dc3545;
	color: #8b2635;
}

.article-page #comments.snicker-comments .comment-action a.action-reply,
.article-page #comments.snicker-comments .snicker-comment-reply {
	align-items: center;
	background: linear-gradient(135deg, var(--color-accent-soft), rgba(126, 198, 153, 0.12));
	border: 1px solid rgba(245, 106, 106, 0.28);
	border-radius: 999px;
	color: var(--color-accent-dark) !important;
	display: inline-flex;
	font-family: var(--font-sans);
	font-size: 0.84rem;
	font-weight: 600;
	gap: 0.45rem;
	line-height: 1.2;
	margin-left: auto;
	opacity: 1;
	padding: 0.55em 1.05em;
	text-decoration: none;
	text-shadow: none;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.article-page #comments.snicker-comments .comment-action a.action-reply:hover,
.article-page #comments.snicker-comments .snicker-comment-reply:hover {
	background: var(--color-accent-soft);
	border-color: var(--color-accent);
	color: var(--color-accent) !important;
	transform: translateY(-1px);
}

.article-page #comments.snicker-comments .comment-action a.action-reply .icon {
	font-size: 0.9rem;
}

.article-page #comments.snicker-comments .no-comments {
	background: var(--color-bg-elevated);
	border: 1px dashed rgba(245, 106, 106, 0.28);
	border-radius: var(--radius-lg);
	color: var(--color-muted);
	font-size: 0.95rem;
	line-height: 1.55;
	margin-bottom: 1.75rem;
	padding: 1.5rem 1.25rem;
	text-align: center;
}

.article-page #comments.snicker-comments .snicker-comments-form {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	margin-top: 0.25rem;
	padding: clamp(1.2rem, 2.5vw, 1.65rem);
}

.article-page #comments.snicker-comments .comments-form-title {
	align-items: center;
	color: var(--color-text);
	display: flex;
	font-family: var(--font-serif);
	font-size: 1.15rem;
	font-weight: 700;
	gap: 0.6rem;
	margin: 0 0 1.15rem;
}

.article-page #comments.snicker-comments .comment-form .table,
.article-page #comments.snicker-comments .comment-footer .table {
	display: grid;
	gap: 0.85rem;
	width: 100%;
}

.article-page #comments.snicker-comments .comment-header .table {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.article-page #comments.snicker-comments .comment-form .table-cell,
.article-page #comments.snicker-comments .comment-footer .table-cell {
	display: block;
	width: 100%;
}

.article-page #comments.snicker-comments .comment-form input[type="text"],
.article-page #comments.snicker-comments .comment-form input[type="email"],
.article-page #comments.snicker-comments .comment-form textarea {
	-webkit-appearance: none;
	appearance: none;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-sizing: border-box;
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: 0.96rem;
	line-height: 1.5;
	padding: 0.7em 0.95em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	width: 100%;
}

.article-page #comments.snicker-comments .comment-form input:focus,
.article-page #comments.snicker-comments .comment-form textarea:focus {
	background: #fff;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px var(--color-accent-soft);
	outline: none;
}

.article-page #comments.snicker-comments .comment-form textarea {
	min-height: 9.5rem;
	resize: vertical;
}

.article-page #comments.snicker-comments .comment-form .comment-reply {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--color-accent);
	border-radius: var(--radius-sm);
	margin: 0 0 1rem;
	padding: 0.85rem 1rem 0.9rem;
	position: relative;
}

.article-page #comments.snicker-comments .comment-form .comment-reply .reply-title {
	color: var(--color-muted);
	font-size: 0.82rem;
	font-weight: 600;
	margin: 0 0 0.45rem;
}

.article-page #comments.snicker-comments .comment-form .comment-reply .reply-content {
	color: var(--color-text);
	font-size: 0.9rem;
	line-height: 1.55;
	opacity: 0.9;
}

.article-page #comments.snicker-comments .comment-form .comment-reply .reply-cancel {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: 50%;
	color: var(--color-muted);
	display: inline-block;
	font-size: 0;
	height: 1.65rem;
	position: absolute;
	right: 0.65rem;
	text-decoration: none;
	top: 0.65rem;
	width: 1.65rem;
}

.article-page #comments.snicker-comments .comment-form .comment-reply .reply-cancel::before {
	content: "\f00d";
	font-family: "Font Awesome 5 Free";
	font-size: 0.75rem;
	font-weight: 900;
	left: 50%;
	line-height: 1;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
}

.article-page #comments.snicker-comments .snicker-comment-altcha {
	margin-top: 0.75rem;
}

.article-page #comments.snicker-comments .snicker-altcha-label {
	color: var(--color-text-muted);
	display: block;
	font-size: 0.9rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.article-page #comments.snicker-comments .snicker-altcha-required {
	color: var(--color-accent);
}

.article-page #comments.snicker-comments .snicker-comment-altcha altcha-widget {
	--altcha-max-width: 100%;
	display: block;
	width: 100%;
}

.article-page #comments.snicker-comments .snicker-comment-altcha .altcha,
.article-page #comments.snicker-comments .snicker-comment-altcha .altcha-main {
	max-width: 100%;
}

.article-page #comments.snicker-comments .comment-footer {
	border-top: 1px solid var(--color-border);
	margin-top: 1rem;
	padding-top: 1.1rem;
}

.article-page #comments.snicker-comments .comment-footer .table {
	justify-items: end;
}

.article-page #comments.snicker-comments .comment-footer button,
.article-page #comments.snicker-comments .comment-footer button[name="snicker"] {
	align-items: center;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border: 0;
	border-radius: 999px;
	box-shadow: 0 8px 24px var(--color-accent-glow);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--font-sans);
	font-size: 0.88rem;
	font-weight: 700;
	gap: 0.5rem;
	padding: 0.8em 1.55em;
}

.article-page #comments.snicker-comments .comment-footer button:hover {
	background: linear-gradient(135deg, var(--color-accent-hover), var(--color-accent));
	box-shadow: 0 12px 30px var(--color-accent-glow);
	transform: translateY(-2px);
}

@media (min-width: 1200px) {
	.article-page #comments.snicker-comments {
		--snicker-reply-step: 1rem;
	}
}

@media (max-width: 736px) {
	.article-page #comments.snicker-comments {
		--snicker-reply-step: clamp(0.5rem, 3.5vw, 0.85rem);
		padding: 1.1rem;
	}

	.article-page #comments.snicker-comments .comment-header .table {
		grid-template-columns: 1fr;
	}

	.article-page #comments.snicker-comments .comment-action > .table,
	.article-page #comments.snicker-comments .snicker-comment-actions > .table {
		align-items: stretch;
		flex-direction: column;
	}

	.article-page #comments.snicker-comments .comment-action a.action-reply,
	.article-page #comments.snicker-comments .snicker-comment-reply {
		justify-content: center;
		margin-left: 0;
		width: 100%;
	}

	.article-page #comments.snicker-comments .comment-footer button {
		justify-content: center;
		width: 100%;
	}
}

/* --- Контакты (contact-telegram) --- */
.article-page--contacts .contact-section {
	margin-top: 0.5rem;
	max-width: none;
	width: 100%;
}

.article-page--contacts .contact-form-lead,
.article-page--contacts .contact-section > .contact-form-lead {
	background: linear-gradient(135deg, var(--color-accent-soft) 0%, rgba(126, 198, 153, 0.1) 100%);
	border: 1px solid rgba(245, 106, 106, 0.2);
	border-radius: var(--radius-lg);
	color: var(--color-text);
	font-size: 1.02em;
	line-height: 1.65;
	margin: 0 0 1.25rem;
	max-width: none;
	padding: 1rem 1.15rem;
	width: 100%;
}

.article-page--contacts .contact-form-lead strong {
	color: var(--color-accent-dark);
}

.article-page--contacts .contact-form-card {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	overflow: hidden;
	width: 100%;
}

.article-page--contacts .contact-form-card-head {
	align-items: center;
	background: linear-gradient(135deg, rgba(245, 106, 106, 0.08) 0%, rgba(126, 198, 153, 0.06) 100%);
	border-bottom: 1px solid var(--color-border);
	display: flex;
	gap: 0.85rem;
	padding: 1.1rem 1.25rem;
}

.article-page--contacts .contact-form-card-icon {
	align-items: center;
	background: linear-gradient(135deg, #2aabee 0%, #229ed9 100%);
	border-radius: var(--radius);
	box-shadow: 0 6px 18px rgba(34, 158, 217, 0.35);
	color: #fff;
	display: inline-flex;
	flex-shrink: 0;
	font-size: 1.15rem;
	height: 2.75rem;
	justify-content: center;
	width: 2.75rem;
}

.article-page--contacts .contact-form-card-title {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: 0;
}

.article-page--contacts .contact-form-card-subtitle {
	color: var(--color-muted);
	font-size: 0.82rem;
	margin: 0.2rem 0 0;
}

.article-page--contacts form.contact-telegram {
	margin: 0;
	padding: 1.15rem 1.25rem 1.35rem;
}

.article-page--contacts .contact-form-fields {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.article-page--contacts .contact-form-grid {
	display: grid;
	gap: 0.85rem 1rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.article-page--contacts .form-group {
	margin: 0;
}

.article-page--contacts .contact-form-group--hidden {
	display: none !important;
}

.article-page--contacts .contact-form-group--full {
	grid-column: 1 / -1;
}

.article-page--contacts .contact-field-label {
	color: var(--color-muted);
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0 0 0.4rem;
	text-transform: uppercase;
}

.article-page--contacts .form-control {
	appearance: none;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
	color: var(--color-text);
	display: block;
	font-family: var(--font-sans);
	font-size: 0.95rem;
	line-height: 1.45;
	padding: 0.65rem 0.8rem;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	width: 100%;
}

.article-page--contacts textarea.form-control {
	min-height: 8.5rem;
	resize: vertical;
}

.article-page--contacts .form-control:hover {
	border-color: rgba(245, 106, 106, 0.35);
}

.article-page--contacts .form-control:focus {
	background: var(--color-bg-elevated);
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px var(--color-accent-soft);
	outline: none;
}

.article-page--contacts .form-control::placeholder {
	color: var(--color-muted);
	opacity: 0.75;
}

.article-page--contacts .contact-form-altcha {
	display: block !important;
	margin-top: 0.35rem;
}

.article-page--contacts .contact-altcha-label {
	color: var(--color-text);
	display: block;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	margin-bottom: 0.5rem;
	text-transform: uppercase;
}

.article-page--contacts .contact-required {
	color: var(--color-accent);
	font-weight: 700;
}

.article-page--contacts .contact-form-altcha altcha-widget {
	--altcha-max-width: 100%;
	display: block;
	margin-top: 0.25rem;
	max-width: 100%;
	min-height: 4.25rem;
	width: 100%;
}

.article-page--contacts .contact-form-altcha .altcha,
.article-page--contacts .contact-form-altcha .altcha-main {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
	max-width: 100%;
	width: 100%;
}

.article-page--contacts .contact-alert {
	border-radius: var(--radius);
	font-size: 0.92rem;
	line-height: 1.5;
	margin-bottom: 1rem;
	padding: 0.85rem 1rem;
}

.article-page--contacts .contact-alert--success {
	background: rgba(126, 198, 153, 0.14);
	border: 1px solid rgba(126, 198, 153, 0.4);
	color: #2d6a4a;
}

.article-page--contacts .contact-alert--error {
	background: var(--color-accent-soft);
	border: 1px solid rgba(245, 106, 106, 0.38);
	color: var(--color-accent-dark);
}

.article-page--contacts .contact-form-actions {
	border-top: 1px solid var(--color-border);
	display: flex;
	justify-content: flex-end;
	margin-top: 1.15rem;
	padding-top: 1.15rem;
}

.article-page--contacts .contact-form-submit,
.article-page--contacts .btn.btn-primary {
	align-items: center;
	background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
	border: 0;
	border-radius: 999px;
	box-shadow: 0 8px 24px var(--color-accent-glow);
	color: #fff !important;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--font-sans);
	font-size: 0.9rem;
	font-weight: 600;
	gap: 0.5rem;
	letter-spacing: 0.02em;
	line-height: 1.2;
	padding: 0.75em 1.45em;
	transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.article-page--contacts .contact-form-submit:hover,
.article-page--contacts .btn.btn-primary:hover {
	background: linear-gradient(135deg, var(--color-accent-hover), var(--color-accent));
	box-shadow: 0 12px 28px var(--color-accent-glow);
	transform: translateY(-2px);
}

.article-page--contacts .contact-form-submit:focus-visible,
.article-page--contacts .btn.btn-primary:focus-visible {
	outline: none;
	box-shadow:
		0 0 0 3px var(--color-bg-elevated),
		0 0 0 5px var(--color-accent),
		0 10px 24px var(--color-accent-glow);
}

@media (max-width: 860px) {
	.article-page--contacts .contact-form-grid {
		grid-template-columns: 1fr;
	}
}

/* Кнопка «Наверх» — только desktop */
.scroll-to-top {
	align-items: center;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border: 0;
	border-radius: 50%;
	bottom: 1.75rem;
	box-shadow: 0 8px 28px var(--color-accent-glow);
	color: #fff;
	cursor: pointer;
	display: none;
	height: 3rem;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	right: 1.75rem;
	transform: translateY(0.75rem) scale(0.92);
	transition:
		opacity 0.28s ease,
		transform 0.28s ease,
		box-shadow 0.28s ease,
		background 0.2s ease;
	width: 3rem;
	z-index: 90;
}

.scroll-to-top.is-visible {
	display: inline-flex;
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0) scale(1);
}

.scroll-to-top:hover {
	background: linear-gradient(135deg, var(--color-accent-hover), var(--color-accent));
	box-shadow: 0 12px 32px var(--color-accent-glow);
	transform: translateY(-3px) scale(1.04);
}

.scroll-to-top:focus-visible {
	outline: none;
	box-shadow:
		0 0 0 3px var(--color-bg),
		0 0 0 5px var(--color-accent),
		0 10px 28px var(--color-accent-glow);
}

.scroll-to-top .icon {
	font-size: 1rem;
	line-height: 1;
}

@media (max-width: 1100px) {
	.scroll-to-top {
		display: none !important;
	}
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
	}
	html { scroll-behavior: auto; }

	.scroll-to-top.is-visible {
		transition: none;
	}
}
