/* =====================================================================
   Брагинская ЦРБ — современная дизайн-система.
   Manrope · расширенная синяя палитра + акцент · мягкие тени · анимации.
   ===================================================================== */

/* ---------- Токены ---------- */
:root {
	/* Брендовый синий */
	--primary-50:  #eef5ff;
	--primary-100: #d9e8ff;
	--primary-200: #b6d2ff;
	--primary-400: #3b86e0;
	--primary:     #0b5cab;
	--primary-600: #0a4f93;
	--primary-700: #083c70;
	--primary-900: #062a4f;
	/* Акцент — медицинский бирюзовый и тёплый красный для тревожных блоков */
	--accent:      #00b5b8;
	--accent-600:  #009599;
	--danger:      #e23b3b;

	--ink:         #0f1d2e;   /* основной текст */
	--ink-soft:    #46586d;   /* вторичный текст */
	--ink-faint:   #7a8aa0;
	--line:        #e6edf5;   /* границы */
	--bg:          #f5f8fc;   /* фон страницы */
	--surface:     #ffffff;   /* карточки */

	--grad-hero:   linear-gradient(115deg, #0b5cab 0%, #0a4f93 45%, #00718f 100%);
	--grad-accent: linear-gradient(135deg, #0b5cab 0%, #00b5b8 100%);

	--font: "Manrope", "Segoe UI", Roboto, system-ui, sans-serif;

	--container: 1240px;
	--r-xl: 26px;
	--r-lg: 18px;
	--r:    14px;
	--r-sm: 10px;

	--sh-xs: 0 1px 2px rgba(13,40,80,.06);
	--sh-sm: 0 4px 14px rgba(13,40,80,.07);
	--sh-md: 0 12px 30px rgba(13,40,80,.10);
	--sh-lg: 0 24px 60px rgba(13,40,80,.16);
	--sh-primary: 0 14px 30px rgba(11,92,171,.30);

	--gap: 26px;
	--ease: cubic-bezier(.22,.61,.36,1);

	/* Сайт умеет обе схемы — браузеры телефонов не должны «затемнять» сами. */
	color-scheme: light dark;
}

/* ---------- База ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; max-width: 100%; }
body {
	margin: 0;
	font-family: var(--font);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--ink);
	background: var(--bg);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
.site-main { flex: 1 0 auto; }
.site-footer { flex-shrink: 0; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; transition: color .2s var(--ease); }
a:hover { color: var(--primary-700); }
h1,h2,h3,h4 { line-height: 1.18; letter-spacing: -.02em; color: var(--ink); margin: 0; font-weight: 800; }
p { margin: 0 0 1em; }
.icon { width: 1.25em; height: 1.25em; flex: none; vertical-align: middle; }

a:focus-visible, button:focus-visible, input:focus-visible, [tabindex]:focus-visible {
	outline: 3px solid var(--accent); outline-offset: 3px; border-radius: 4px;
}
/* Якорные ссылки (быстрая навигация на QR-страницах): цель не прячется под sticky-шапкой */
[id] { scroll-margin-top: 76px; }
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 22px; }

/* Защита от горизонтального переполнения (особенно на мобильном):
   grid/flex-элементы по умолчанию имеют min-width:auto и не сжимаются под
   контейнер при длинном контенте → контент уезжает/обрезается справа. */
.hero__inner > *, .layout > *, .about__top > *, .navbar__collapse > * { min-width: 0; }
.hero__title, .hero__lead, .page-hero__title, .article__title, .card__title, .section-title { overflow-wrap: break-word; word-break: break-word; }
/* Широкие таблицы — горизонтальная прокрутка внутри блока-обёртки (см. .wp-block-table ниже). */

.screen-reader-text {
	position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
	position: absolute; left: 14px; top: -60px; background: var(--primary); color: #fff;
	padding: 12px 20px; border-radius: var(--r); z-index: 9999; transition: top .25s var(--ease); font-weight: 700;
}
.skip-link:focus { top: 14px; }

/* ---------- Кнопки ---------- */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 9px;
	padding: 13px 22px; border-radius: 999px; font-weight: 700; font-size: .98rem;
	cursor: pointer; border: 0; line-height: 1.1; white-space: nowrap;
	transition: transform .2s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn--primary { background: var(--grad-accent); color: #fff; box-shadow: var(--sh-primary); }
.btn--primary:hover { color: #fff; box-shadow: 0 18px 38px rgba(11,92,171,.40); }
.btn--ghost { background: var(--primary-50); color: var(--primary-700); }
.btn--ghost:hover { background: var(--primary-100); color: var(--primary-700); }
.btn--white { background: #fff; color: var(--primary-700); box-shadow: var(--sh-sm); }
.btn--lg { padding: 16px 30px; font-size: 1.05rem; }

/* ---------- Верхняя панель ---------- */
.topbar { background: var(--primary-900); color: #c7d8ee; font-size: .85rem; }
.topbar a { color: #c7d8ee; }
.topbar a:hover { color: #fff; }
.topbar__inner { display: flex; justify-content: space-between; align-items: center; gap: 18px; min-height: 42px; }
.topbar__list { display: flex; gap: 22px; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.topbar__list a { font-weight: 600; }
.topbar__tools { display: flex; align-items: center; gap: 18px; }
.lang-switcher { display: flex; gap: 4px; list-style: none; margin: 0; padding: 0; }
.lang-switcher__item a, .lang-switcher__item span, .lang-switcher__item .lang-pill {
	display: block; padding: 4px 9px; border-radius: 7px; font-weight: 700; font-size: .8rem; color: #c7d8ee;
	background: none; border: 0; cursor: pointer; font-family: inherit; line-height: 1.2;
}
.lang-switcher__item .lang-pill:hover { color: #fff; }
.lang-switcher__item.is-current a, .lang-switcher__item.is-current span, .lang-switcher__item.is-current .lang-pill { background: var(--accent); color: #fff; }
/* Движок GTranslate скрыт — управляем своими пилюлями */
.lang-gt__engine { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
/* Убрать верхнюю плашку Google «Translated by» */
.skiptranslate iframe.skiptranslate { display: none !important; }
body { top: 0 !important; }
.a11y-toggle { display: inline-flex; align-items: center; gap: 7px; background: none; border: 0; cursor: pointer; color: #c7d8ee; font: inherit; font-weight: 600; }
.a11y-toggle:hover { color: #fff; }
.a11y-toggle .icon { width: 1.05rem; height: 1.05rem; }

/* ---------- Шапка ---------- */
.site-header { position: relative; z-index: 100; }
.header-main { background: var(--surface); border-bottom: 1px solid var(--line); }
.header-main__inner {
	display: grid; grid-template-columns: auto 1fr auto; gap: 34px; align-items: center; padding: 20px 22px;
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand__mark {
	width: 52px; height: 52px; border-radius: 15px; display: grid; place-items: center;
	background: var(--grad-accent); color: #fff; box-shadow: var(--sh-primary); flex: none;
}
.brand__mark .icon { width: 28px; height: 28px; }
.brand__text strong { display: block; font-size: .92rem; line-height: 1.3; text-transform: uppercase; letter-spacing: .01em; color: var(--ink); }
.brand__text span { font-size: .78rem; color: var(--ink-faint); }
.header-main__contacts { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; color: var(--ink-soft); }
.hc { margin: 0; display: flex; align-items: center; gap: 9px; white-space: nowrap; line-height: 1.25; }
.hc .icon { color: var(--accent); width: 1.05rem; height: 1.05rem; flex: none; }
.hc__label { color: var(--ink-soft); }
.hc a { font-weight: 700; color: var(--primary); letter-spacing: .01em; }
.hc a:hover { color: var(--primary-700); text-decoration: underline; }
.hc--address span { color: var(--ink-soft); }
.header-main__cta { display: flex; flex-direction: column; gap: 9px; }
.header-main__cta .btn { font-size: .9rem; padding: 11px 18px; }
.header-main__cta .btn--ghost .icon { color: var(--accent); }

/* ---------- Навигация (sticky) ---------- */
.navbar { background: var(--grad-hero); position: sticky; top: 0; z-index: 90; transition: box-shadow .3s var(--ease); }
.navbar.is-stuck { box-shadow: var(--sh-md); }
.navbar__inner { display: flex; align-items: center; gap: 18px; }
.navbar__collapse { display: flex; align-items: center; gap: 18px; flex: 1; min-width: 0; }
.navbar__extra { display: none; }
.navbar__list { display: flex; list-style: none; margin: 0; padding: 0; flex: 1; flex-wrap: wrap; min-width: 0; }
.navbar__list > li { position: relative; }
.navbar__list > li > a {
	display: flex; align-items: center; gap: 6px; color: #eaf3ff; padding: 17px 18px; font-weight: 700; font-size: .96rem; position: relative;
}
.navbar__list > li > a::after {
	content: ""; position: absolute; left: 18px; right: 18px; bottom: 10px; height: 3px; border-radius: 3px;
	background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--ease);
}
.navbar__list > li:hover > a, .navbar__list > li.current-menu-item > a { color: #fff; }
.navbar__list > li:hover > a::after, .navbar__list > li.current-menu-item > a::after { transform: scaleX(1); }
.navbar__list ul {
	display: block; position: absolute; top: 100%; left: 0; min-width: 250px; background: var(--surface);
	box-shadow: var(--sh-md); border-radius: var(--r); list-style: none; margin: 0; padding: 8px; z-index: 80;
	opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity .22s var(--ease), transform .22s var(--ease), visibility .22s var(--ease);
}
.navbar__list li:hover > ul, .navbar__list li:focus-within > ul { opacity: 1; visibility: visible; transform: translateY(0); }
/* Только длинные подменю 2-го уровня перетекают в колонки вбок (после ~5 пунктов).
   width:max-content — чтобы фон покрывал все колонки (иначе 2-я колонка «просвечивает»). */
.navbar__list > li > ul { display: flex; flex-flow: column wrap; align-content: flex-start; max-height: 340px; width: max-content; }
.navbar__list > li > ul > li { width: 246px; }
/* 3-й уровень (Онкоскрининги/Профилактика) — вбок, ОДНОЙ колонкой (пунктов немного). */
.navbar__list ul ul { top: -8px; left: 100%; }
.navbar__list ul li { position: relative; }
.navbar__list ul > li:has(> ul) > a::after { content: "›"; float: right; opacity: .6; }
.navbar__list ul a { display: block; padding: 11px 14px; color: var(--ink-soft); border-radius: var(--r-sm); font-weight: 600; }
.navbar__list ul a:hover { background: var(--primary-50); color: var(--primary-700); }
.navbar__search { display: flex; background: rgba(255,255,255,.14); border-radius: 999px; overflow: hidden; }
.navbar__search input { border: 0; background: transparent; padding: 10px 16px; color: #fff; width: 150px; }
.navbar__search input::placeholder { color: #cfe1f7; }
.navbar__search button { border: 0; background: transparent; color: #fff; padding: 0 14px; cursor: pointer; display: grid; place-items: center; }
/* Кнопка раскрытия подменю в мобильном меню (JS вставляет в пункты с детьми) */
.submenu-toggle {
	display: none; place-items: center; flex: none; width: 40px; height: 40px;
	background: rgba(255,255,255,.10); border: 0; border-radius: 10px; cursor: pointer; color: #dcebff;
	transition: background .2s var(--ease);
}
.submenu-toggle:hover { background: rgba(255,255,255,.2); color: #fff; }
.submenu-toggle svg { width: 18px; height: 18px; transition: transform .25s var(--ease); }
li.is-open > .submenu-toggle svg { transform: rotate(180deg); }

.navbar__toggle { display: none; background: rgba(255,255,255,.14); border: 0; cursor: pointer; padding: 11px; border-radius: 12px; color: #fff; }
.navbar__toggle .icon { width: 24px; height: 24px; }
.navbar__toggle .icon--x { display: none; }
.navbar__toggle[aria-expanded="true"] .icon--menu { display: none; }
.navbar__toggle[aria-expanded="true"] .icon--x { display: block; }

/* ---------- HERO (двухколоночный, со смыслом и поиском) ---------- */
.hero { position: relative; overflow: hidden; padding: 56px 0 92px; isolation: isolate; }
/* Мягкий «живой» фон: меш-градиент + органичные пятна */
.hero__bg { position: absolute; inset: 0; z-index: -2; background:
	radial-gradient(60% 70% at 12% 18%, rgba(0,181,184,.16), transparent 60%),
	radial-gradient(55% 65% at 88% 28%, rgba(11,92,171,.18), transparent 62%),
	linear-gradient(180deg, #f3f9ff 0%, var(--bg) 70%); }
.hero__blob { position: absolute; z-index: -1; border-radius: 50%; filter: blur(8px); opacity: .5; }
.hero__blob--1 { width: 360px; height: 360px; left: -90px; top: 30px; background: radial-gradient(circle at 30% 30%, rgba(0,181,184,.30), transparent 70%); animation: floaty 14s var(--ease) infinite alternate; }
.hero__blob--2 { width: 420px; height: 420px; right: -120px; bottom: -80px; background: radial-gradient(circle at 60% 40%, rgba(11,92,171,.22), transparent 70%); animation: floaty 18s var(--ease) infinite alternate-reverse; }
@keyframes floaty { to { transform: translate(28px, -22px) scale(1.08); } }

.hero__inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
.hero__kicker { display: inline-flex; align-items: center; gap: 9px; background: rgba(255,255,255,.7); backdrop-filter: blur(6px); border: 1px solid var(--line); padding: 7px 15px; border-radius: 999px; font-weight: 800; font-size: .8rem; letter-spacing: .04em; text-transform: uppercase; color: var(--primary-700); margin-bottom: 22px; }
.hero__kicker .icon { color: var(--accent-600); width: 1.05rem; height: 1.05rem; }
.hero__title { font-size: clamp(2.2rem, 5vw, 3.6rem); line-height: 1.05; letter-spacing: -.03em; margin-bottom: 18px; }
.hero__title span { background: var(--grad-accent); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero__lead { font-size: 1.12rem; color: var(--ink-soft); max-width: 38ch; margin-bottom: 26px; }
.hero__search { display: flex; gap: 8px; background: #fff; padding: 8px; border-radius: 999px; box-shadow: var(--sh-md); max-width: 460px; margin-bottom: 18px; }
.hero__search input { flex: 1; min-width: 0; border: 0; background: transparent; padding: 12px 18px; font: inherit; }
.hero__search input:focus { outline: none; }
.hero__search:focus-within { box-shadow: var(--sh-md), 0 0 0 3px rgba(0,181,184,.35); }
.hero__search button { border: 0; cursor: pointer; }
.hero__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 26px; }
.hero__trust { display: flex; gap: 22px; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; }
.hero__trust li { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: .9rem; color: var(--ink-soft); }
.hero__trust .icon { color: var(--accent-600); }

.hero__visual { position: relative; }
.hero__wrap { position: relative; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--sh-lg); transform: rotate(1.2deg); }
.hero__wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(6,42,79,.28)); pointer-events: none; }
/* Фиксированная пропорция слайдера: разные по размеру картинки не двигают вёрстку */
.hero__slider { position: relative; aspect-ratio: 1 / 1; background: linear-gradient(135deg, var(--primary-50), #fff); }
.hero__slide { position: absolute; inset: 0; }
.hero__slide[hidden] { display: none !important; }
.hero__slide > a { display: block; width: 100%; height: 100%; }
.hero__slide img { width: 100%; height: 100%; display: block; object-fit: contain; }
.hero__dots { position: absolute; left: 0; right: 0; bottom: 18px; display: flex; gap: 9px; justify-content: center; z-index: 3; }
.hero__dot { width: 10px; height: 10px; border-radius: 50%; border: 0; background: rgba(255,255,255,.55); cursor: pointer; transition: all .2s var(--ease); padding: 0; }
.hero__dot.is-active { background: #fff; width: 26px; border-radius: 6px; }
/* Плавающая «карточка-бейдж» поверх визуала */
.hero__badge { position: absolute; left: -26px; bottom: 30px; display: flex; align-items: center; gap: 13px; background: #fff; padding: 15px 20px; border-radius: var(--r-lg); box-shadow: var(--sh-lg); z-index: 4; }
.hero__badge .icon { width: 1.6rem; height: 1.6rem; }
.hero__badge-ic { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; background: rgba(0,181,184,.12); color: var(--accent-600); }
.hero__badge b { display: block; font-size: 1.05rem; line-height: 1.1; }
.hero__badge span { font-size: .8rem; color: var(--ink-faint); }

/* Органичный плавный переход к следующей секции */
.hero__curve { position: absolute; left: 0; right: 0; bottom: -1px; width: 100%; height: 70px; z-index: -1; color: var(--bg); }
@media (max-width: 960px) {
	.hero { padding: 40px 0 70px; }
	.hero__inner { grid-template-columns: 1fr; gap: 36px; }
	.hero__wrap { transform: none; }
	.hero__badge { left: 16px; }
}
@media (max-width: 560px) {
	.hero__search { max-width: 100%; }
	.hero__actions { flex-direction: column; align-items: stretch; }
	.hero__actions .btn { width: 100%; }
	.hero__title { font-size: 2rem; }
}

/* ---------- Быстрые действия ---------- */
.quick { margin-top: 6px; position: relative; z-index: 5; }
.quick__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.quick__card {
	display: flex; align-items: center; gap: 14px; background: var(--surface); padding: 18px 20px;
	border-radius: var(--r-lg); box-shadow: var(--sh-md); border: 1px solid var(--line);
	transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.quick__card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); color: inherit; }
.quick__icon { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; background: var(--primary-50); color: var(--primary); flex: none; }
.quick__icon .icon { width: 26px; height: 26px; }
.quick__card--accent .quick__icon { background: rgba(0,181,184,.12); color: var(--accent-600); }
.quick__card--danger .quick__icon { background: rgba(226,59,59,.10); color: var(--danger); }
.quick__title { display: block; font-weight: 800; font-size: 1rem; line-height: 1.25; }
.quick__sub { display: block; font-size: .8rem; color: var(--ink-faint); margin-top: 2px; }

/* ---------- Заголовки секций ---------- */
.section { padding: 56px 0; }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 30px; }
.section-kicker { display: inline-flex; align-items: center; gap: 8px; font-weight: 800; font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--accent-600); margin-bottom: 8px; }
.section-kicker::before { content: ""; width: 26px; height: 3px; border-radius: 3px; background: var(--accent); }
.section-title { font-size: clamp(1.6rem, 3vw, 2.1rem); }
.section-link { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; color: var(--primary); white-space: nowrap; }
.section-link:hover .icon { transform: translateX(4px); }
.section-link .icon { transition: transform .2s var(--ease); width: 1.1rem; height: 1.1rem; }

/* ---------- Сервисы ---------- */
.services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); grid-auto-rows: 1fr; }
.listing { padding-top: 36px; padding-bottom: 64px; }
.service-card {
	position: relative; display: flex; flex-direction: column; gap: 14px; background: var(--surface);
	border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; overflow: hidden;
	transition: transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease);
}
.service-card::before {
	content: ""; position: absolute; left: 0; top: 0; height: 4px; width: 100%; background: var(--grad-accent);
	transform: scaleX(0); transform-origin: left; transition: transform .3s var(--ease);
}
.service-card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: transparent; color: inherit; }
.service-card:hover::before { transform: scaleX(1); }
.service-card__icon { width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center; background: var(--primary-50); color: var(--primary); transition: all .3s var(--ease); }
.service-card:hover .service-card__icon { background: var(--grad-accent); color: #fff; transform: rotate(-6deg); }
.service-card__icon .icon { width: 28px; height: 28px; }
.service-card__title { font-weight: 800; font-size: 1.12rem; }
.service-card__more { margin-top: auto; display: inline-flex; align-items: center; gap: 6px; color: var(--primary); font-weight: 700; font-size: .9rem; }
.service-card:hover .service-card__more .icon { transform: translateX(4px); }
.service-card__more .icon { transition: transform .2s var(--ease); width: 1rem; height: 1rem; }

/* ---------- Полоса со статистикой ---------- */
.stats { background: var(--grad-hero); border-radius: var(--r-xl); padding: 44px; color: #fff; position: relative; overflow: hidden; }
.stats::after { content: ""; position: absolute; right: -60px; top: -60px; width: 260px; height: 260px; border-radius: 50%; background: rgba(255,255,255,.06); }
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; position: relative; }
.stat { text-align: center; }
.stat__num { font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 800; letter-spacing: -.03em; }
.stat__suffix { font-size: .6em; vertical-align: top; color: var(--accent); margin-left: 2px; }
.stat__label { color: #bcd6f3; font-weight: 600; font-size: .95rem; margin-top: 4px; }

/* ---------- Новости ---------- */
.news__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap); }
.card {
	background: var(--surface); border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line);
	display: flex; flex-direction: column; transition: transform .28s var(--ease), box-shadow .28s var(--ease);
}
.card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); }
.card__link { display: flex; flex-direction: column; height: 100%; color: inherit; }
.card__link:hover { color: inherit; }
.card__media { overflow: hidden; aspect-ratio: 16/10; background: var(--primary-50); }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.card:hover .card__media img { transform: scale(1.06); }
.card__body { padding: 18px 20px 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.card__date { display: inline-flex; align-items: center; gap: 7px; font-size: .8rem; color: var(--ink-faint); font-weight: 600; }
.card__date .icon { width: .95rem; height: .95rem; color: var(--accent-600); }
.card__title { font-size: 1.02rem; font-weight: 800; line-height: 1.3; }
.card--feature { grid-row: span 2; grid-column: span 2; }
.card--feature .card__media { aspect-ratio: 16/9; }
.card--feature .card__title { font-size: 1.5rem; }

/* ---------- Стрелки слайдеров ---------- */
.slider-arrow {
	width: 46px; height: 46px; border-radius: 50%; border: 0; cursor: pointer;
	background: rgba(255,255,255,.92); color: var(--primary); display: grid; place-items: center;
	box-shadow: var(--sh-sm); transition: background .2s var(--ease), box-shadow .2s var(--ease); flex: none;
}
.slider-arrow:hover { background: #fff; box-shadow: var(--sh-md); color: var(--primary-700); }
.slider-arrow .icon { width: 22px; height: 22px; }
.slider-arrow--prev .icon { transform: rotate(180deg); }
.carousel-nav { display: flex; gap: 8px; }
.carousel-nav .slider-arrow { background: var(--surface); border: 1px solid var(--line); }
.carousel-nav .slider-arrow:hover { border-color: var(--primary-200); }
/* стрелки главного баннера — поверх картинки */
.hero__wrap .slider-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 6; width: 42px; height: 42px; }
.hero__wrap .slider-arrow--prev { left: 12px; }
.hero__wrap .slider-arrow--next { right: 12px; }

/* ---------- Карусель ресурсов ---------- */
.res-carousel { position: relative; }
/* Вертикальный паддинг + отрицательный маргин: overflow-x:auto клипует и по
   вертикали, из-за чего карточка при hover (translateY(-4px) + тень) обрезалась сверху. */
.res-carousel__viewport { overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; -ms-overflow-style: none; scroll-behavior: smooth; padding: 10px 4px 14px; margin: -10px -4px -14px; }
.res-carousel__viewport::-webkit-scrollbar { display: none; }
.res-carousel__track { display: flex; gap: var(--gap); }
.res-carousel__item { flex: 0 0 calc((100% - (var(--pv) - 1) * var(--gap)) / var(--pv)); scroll-snap-align: start; }
@media (max-width: 900px) { .res-carousel { --pv: 3 !important; } }
@media (max-width: 640px) { .res-carousel { --pv: 2 !important; } }
@media (max-width: 430px) { .res-carousel { --pv: 1 !important; } }

/* ---------- Ресурсы ---------- */
.resources__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap); }
.resource { display: block; padding: 3px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); transition: all .25s var(--ease); overflow: hidden; }
.resource:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--primary-200); }
.resource img { width: 100%; height: 128px; object-fit: contain; border-radius: var(--r); background: #fff; display: block; }

/* ---------- Внутренние страницы ---------- */
.page-hero { background: var(--grad-hero); color: #fff; padding: 40px 0 30px; }
.page-hero .breadcrumbs__list { color: #bcd6f3; margin-bottom: 12px; }
.page-hero .breadcrumbs__list a, .page-hero .breadcrumbs__sep, .page-hero .breadcrumbs__item--current span { color: #dcebff; }
.page-hero__title { font-size: clamp(1.8rem, 4vw, 2.6rem); color: #fff; }

.layout { display: grid; grid-template-columns: 1fr 330px; gap: var(--gap); padding: 44px 22px 64px; max-width: var(--container); margin: 0 auto; }
.layout--full { grid-template-columns: 1fr; }
.layout--full .layout__content { max-width: none; margin: 0 auto; width: 100%; }
.layout__content { background: var(--surface); border-radius: var(--r-lg); padding: 38px; box-shadow: var(--sh-sm); border: 1px solid var(--line); }
.layout__sidebar { display: flex; flex-direction: column; gap: var(--gap); }
.side-banner img { width: 100%; border-radius: var(--r-lg); box-shadow: var(--sh-sm); }
.widget { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 22px; }
.widget__title { font-size: 1.1rem; margin-bottom: 12px; }

/* ---------- Хлебные крошки ---------- */
.breadcrumbs__list { display: flex; flex-wrap: wrap; gap: 9px; align-items: center; list-style: none; margin: 0 0 20px; padding: 0; font-size: .85rem; color: var(--ink-faint); }
.breadcrumbs__list a { color: var(--ink-soft); font-weight: 600; }
.breadcrumbs__home { display: inline-flex; }
.breadcrumbs__home .icon { width: 1rem; height: 1rem; }

/* ---------- Статья ---------- */
.article__head { margin-bottom: 22px; }
.article__title { font-size: clamp(1.6rem, 3.4vw, 2.3rem); margin-bottom: 12px; }
.article__date { display: inline-flex; align-items: center; gap: 8px; color: var(--ink-faint); font-weight: 600; font-size: .9rem; }
.article__date .icon { color: var(--accent-600); }
.article__media { margin: 22px 0; }
.article__media img { border-radius: var(--r-lg); width: 100%; box-shadow: var(--sh-sm); }
.article__body { font-size: 1.06rem; color: var(--ink-soft); }
.article__body h2, .article__body h3 { color: var(--ink); margin: 1.4em 0 .5em; }
.article__body a { font-weight: 600; text-decoration: underline; text-underline-offset: 3px; }
.article__body img { border-radius: var(--r); margin: 18px 0; }
/* Таблицы: колонки сохраняют читаемую ширину; если таблица шире экрана —
   горизонтальная прокрутка внутри обёртки .table-scroll (её ставит main.js),
   а НЕ сжатие столбцов и НЕ обрезка. */
.article__body table { width: 100%; border-collapse: collapse; margin: 18px 0; box-shadow: var(--sh-sm); }
.article__body th, .article__body td { padding: 11px 14px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--line); overflow-wrap: break-word; }
.article__body thead th, .article__body tr:first-child th { background: var(--primary); color: #fff; }
.article__body tbody tr:nth-child(even) { background: var(--primary-50); }
.article__foot { margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--line); }

/* Прокручиваемая обёртка таблиц (для блоков core/table и обёрнутых main.js
   обычных таблиц). Колонки сохраняют ширину (max-content), мелкие таблицы
   растягиваются на всю ширину (min-width:100%). Полоса прокрутки видимая. */
.article__body .table-scroll,
.article__body .wp-block-table { margin: 18px 0; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
.article__body .table-scroll table,
.article__body .wp-block-table table { display: table; width: 100% !important; min-width: 560px; max-width: none !important; margin: 0; }
.article__body .table-scroll::-webkit-scrollbar,
.article__body .wp-block-table::-webkit-scrollbar { height: 8px; }
.article__body .table-scroll::-webkit-scrollbar-thumb,
.article__body .wp-block-table::-webkit-scrollbar-thumb { background: var(--primary-200); border-radius: 4px; }
.article__body .wp-block-table figcaption { color: var(--ink-faint); font-size: .85rem; margin-top: 8px; }

/* Перенесённый контент с инлайн-стилями (страницы по QR-кодам): не вылезать
   за контейнер и аккуратно ужиматься на мобильном. */
.article__body [style] { max-width: 100% !important; box-sizing: border-box; }
.article__body [style*="grid"] { gap: 12px; }
@media (max-width: 700px) {
	.article__body [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
	.article__body [style*="padding"] { padding-left: 16px !important; padding-right: 16px !important; }
	.article__body [style*="font-size: 1.9rem"], .article__body [style*="font-size:1.9rem"] { font-size: 1.4rem !important; }
}

/* Сворачиваемый блок (core/details) — для графиков по месяцам и FAQ */
.article__body .wp-block-details { border: 1px solid var(--line); border-radius: var(--r); margin: 16px 0; background: var(--surface); box-shadow: var(--sh-xs); overflow: hidden; }
.article__body .wp-block-details > summary {
	cursor: pointer; list-style: none; padding: 16px 20px; font-weight: 800; color: var(--primary-700);
	display: flex; align-items: center; gap: 12px; background: var(--primary-50); user-select: none;
	transition: background .2s var(--ease);
}
.article__body .wp-block-details > summary:hover { background: var(--primary-100); }
.article__body .wp-block-details > summary::-webkit-details-marker { display: none; }
.article__body .wp-block-details > summary::before {
	content: ""; width: 11px; height: 11px; flex: none; border-right: 2.5px solid currentColor; border-bottom: 2.5px solid currentColor;
	transform: rotate(-45deg); transition: transform .25s var(--ease); margin-top: -3px;
}
.article__body .wp-block-details[open] > summary::before { transform: rotate(45deg); margin-top: 0; }
.article__body .wp-block-details[open] > summary { border-bottom: 1px solid var(--line); }
.article__body .wp-block-details > *:not(summary) { padding: 0 20px; }
.article__body .wp-block-details > .wp-block-table { padding: 16px 20px; margin: 0; }

/* Прикреплённые файлы (core/file) — карточка с иконкой формата и кнопкой */
.article__body .wp-block-file {
	display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
	background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
	padding: 14px 18px; margin: 12px 0; box-shadow: var(--sh-xs);
	transition: box-shadow .2s var(--ease), border-color .2s var(--ease);
}
.article__body .wp-block-file:hover { box-shadow: var(--sh-sm); border-color: var(--primary-200); }
.article__body .wp-block-file::before {
	content: attr(data-ext); flex: none; width: 46px; height: 46px; border-radius: 11px;
	display: grid; place-items: center; font-size: .62rem; font-weight: 800; letter-spacing: .03em;
	color: #fff; background: var(--primary); position: relative;
}
.article__body .wp-block-file.is-format-pdf::before { background: #d83a3a; }
.article__body .wp-block-file.is-format-doc::before,
.article__body .wp-block-file.is-format-docx::before { background: #2a6bd4; }
.article__body .wp-block-file.is-format-xls::before,
.article__body .wp-block-file.is-format-xlsx::before { background: #1f9d57; }
.article__body .wp-block-file > a:first-child {
	flex: 1; min-width: 200px; font-weight: 700; color: var(--ink); text-decoration: none; line-height: 1.3;
}
.article__body .wp-block-file > a:first-child:hover { color: var(--primary); }
.article__body .wp-block-file__button {
	background: var(--grad-accent) !important; color: #fff !important; border-radius: 999px !important;
	padding: 9px 20px; font-weight: 700; text-decoration: none; white-space: nowrap;
	transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.article__body .wp-block-file__button:hover { transform: translateY(-2px); box-shadow: var(--sh-primary); color: #fff !important; }

/* Видео в статьях: адаптивные embed (YouTube и т.п.) и блок «Видео» */
.article__body .wp-block-embed { margin: 22px 0; }
.article__body .wp-block-embed__wrapper { position: relative; }
.article__body .wp-block-embed.is-type-video .wp-block-embed__wrapper { padding-top: 56.25%; }
.article__body .wp-block-embed.is-type-video .wp-block-embed__wrapper > iframe,
.article__body .wp-block-embed.is-type-video .wp-block-embed__wrapper > video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; border-radius: var(--r); }
.article__body iframe, .article__body video { max-width: 100%; border-radius: var(--r); }
.article__body figure.wp-block-video video { width: 100%; height: auto; }

/* ---------- Страница «Об учреждении» ---------- */
.about { max-width: var(--container); margin: 0 auto; padding: 44px 22px 64px; }
.about__top { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--gap); margin-bottom: 18px; }
.about-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 32px; box-shadow: var(--sh-sm); }
.about-card__title { display: inline-flex; align-items: center; gap: 11px; color: var(--primary); font-size: 1.2rem; margin-bottom: 16px; }
.about-card__title .icon { width: 1.5rem; height: 1.5rem; color: var(--accent-600); }
.about-card__body { color: var(--ink-soft); }
.requisites { margin: 0; }
.requisites__row { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px dashed var(--line); }
.requisites__row:last-child { border-bottom: 0; }
.requisites__label { font-weight: 600; color: var(--ink-faint); min-width: 170px; margin: 0; }
.requisites__value { margin: 0; font-weight: 700; color: var(--ink); }

.timeline-section, .awards-section { margin-top: 44px; }
.timeline-section > .section-title, .awards-section > .section-title { margin-bottom: 26px; }
.timeline { list-style: none; margin: 0; padding: 0; position: relative; }
.timeline::before { content: ""; position: absolute; left: 7px; top: 10px; bottom: 10px; width: 2px; border-radius: 2px; background: linear-gradient(var(--primary), var(--accent)); }
.timeline__item { display: grid; grid-template-columns: 130px 1fr; gap: 22px; padding: 14px 0 14px 34px; position: relative; }
.timeline__item::before { content: ""; position: absolute; left: 0; top: 20px; width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 4px solid var(--primary); box-shadow: 0 0 0 4px var(--primary-50); box-sizing: border-box; }
.timeline__year { font-weight: 800; color: var(--primary); font-size: 1.02rem; }
.timeline__text { color: var(--ink-soft); }

.awards { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
.awards__item { display: flex; gap: 14px; align-items: flex-start; padding: 16px 18px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); transition: all .25s var(--ease); }
.awards__item:hover { box-shadow: var(--sh-sm); transform: translateX(4px); }
.awards__icon { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; background: rgba(217,158,0,.12); color: #d99e00; flex: none; }
.awards__icon .icon { width: 1.25rem; height: 1.25rem; }

/* ---------- Страница «Контакты» ---------- */
.contacts { max-width: var(--container); margin: 0 auto; padding: 44px 22px 64px; }
.contacts__grid { display: grid; grid-template-columns: 1fr 1.15fr; gap: var(--gap); align-items: start; }
.contacts__info { display: grid; gap: 16px; }
.contact-card { display: flex; gap: 16px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 22px 24px; box-shadow: var(--sh-sm); transition: box-shadow .25s var(--ease); }
.contact-card:hover { box-shadow: var(--sh-md); }
.contact-card__ic { width: 50px; height: 50px; flex: none; border-radius: 14px; display: grid; place-items: center; background: var(--primary-50); color: var(--primary); }
.contact-card__ic .icon { width: 26px; height: 26px; }
.contact-card__title { font-size: 1.05rem; margin-bottom: 6px; }
.contact-card p { margin: 3px 0; color: var(--ink-soft); }
.contact-card__link { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; margin-top: 6px; }
.contact-card__link .icon { width: 1rem; height: 1rem; transition: transform .2s var(--ease); }
.contact-card__link:hover .icon { transform: translateX(4px); }
.contacts__map { position: sticky; top: 90px; }
.map-frame { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-md); border: 1px solid var(--line); height: 460px; background: var(--primary-50); }
.map-frame iframe { display: block; width: 100%; height: 100%; }
.map-note { display: flex; gap: 12px; align-items: flex-start; margin-top: 16px; background: var(--primary-50); border-radius: var(--r); padding: 16px 18px; color: var(--ink-soft); }
.map-note .icon { color: var(--accent-600); flex: none; margin-top: 2px; }
@media (max-width: 860px) {
	.contacts__grid { grid-template-columns: 1fr; }
	.contacts__map { position: static; }
}

/* ---------- Пошаговый сценарий (паттерн «ЦРБ: шаги 1-2-3») ---------- */
.brg-steps ol { list-style: none; counter-reset: brg-step; margin: 18px 0 0; padding: 0; display: grid; gap: 12px; }
.brg-steps ol > li {
	counter-increment: brg-step; position: relative; padding: 16px 18px 16px 66px; margin: 0;
	background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--sh-xs);
}
.brg-steps ol > li::before {
	content: counter(brg-step); position: absolute; left: 16px; top: 14px;
	width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
	background: var(--grad-accent); color: #fff; font-weight: 800; font-size: 1rem;
}

/* ---------- Кнопки соцсетей ---------- */
.social-buttons { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0; }
.article__body .social-buttons a { text-decoration: none; }
.social-btn { display: inline-flex; align-items: center; gap: 9px; padding: 10px 18px; border-radius: 999px; color: #fff !important; font-weight: 700; font-size: .92rem; text-decoration: none; transition: transform .2s var(--ease), box-shadow .2s var(--ease), filter .2s var(--ease); }
.social-btn:hover { transform: translateY(-2px); box-shadow: var(--sh-md); filter: brightness(1.06); color: #fff !important; }
.social-btn .icon { width: 1.15rem; height: 1.15rem; }
.social-btn--telegram { background: #229ED9; }
.social-btn--vk { background: #0077FF; }
.social-btn--odnoklassniki { background: #EE8208; }
.social-btn--instagram { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.social-btn--facebook { background: #1877F2; }
.social-btn--youtube { background: #FF0000; }
.social-btn--viber { background: #7360F2; }

/* ---------- Карточки подстраниц (страницы-разделы) ---------- */
.subpages { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 26px; }
.subpage-card { display: flex; align-items: center; gap: 16px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 20px 22px; box-shadow: var(--sh-xs); transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease); }
.subpage-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--primary-200); }
.subpage-card__body { flex: 1; min-width: 0; }
.subpage-card__title { display: block; font-weight: 800; font-size: 1.08rem; color: var(--ink); }
.subpage-card:hover .subpage-card__title { color: var(--primary); }
.subpage-card__excerpt { display: block; margin-top: 4px; font-size: .9rem; color: var(--ink-faint); }
.subpage-card__arrow { flex: none; width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center; background: var(--primary-50); color: var(--primary); transition: all .22s var(--ease); }
.subpage-card:hover .subpage-card__arrow { background: var(--grad-accent); color: #fff; }
.subpage-card__arrow .icon { width: 1.2rem; height: 1.2rem; }
@media (max-width: 640px) { .subpages { grid-template-columns: 1fr; } }

/* ---------- Тест FINDRISK ---------- */
.findrisk { max-width: 820px; margin-inline: auto; }
.findrisk__result { display: flex; gap: 22px; align-items: center; border-radius: var(--r-lg); padding: 26px 28px; margin-bottom: 26px; color: #fff; }
.findrisk__result h3 { color: #fff; font-size: 1.4rem; margin-bottom: 6px; }
.findrisk__result p { margin: 0 0 12px; opacity: .95; }
.findrisk__result .btn--ghost { background: rgba(255,255,255,.2); color: #fff; }
.findrisk__score { flex: none; width: 120px; height: 120px; border-radius: 50%; background: rgba(255,255,255,.18); display: grid; place-content: center; text-align: center; font-size: 2.6rem; font-weight: 800; line-height: 1; }
.findrisk__score span { display: block; font-size: .8rem; font-weight: 600; opacity: .9; margin-top: 4px; }
.findrisk__result--low { background: linear-gradient(135deg,#16a34a,#15803d); }
.findrisk__result--slight { background: linear-gradient(135deg,#65a30d,#4d7c0f); }
.findrisk__result--moderate { background: linear-gradient(135deg,#d99e00,#b45309); }
.findrisk__result--high { background: linear-gradient(135deg,#ea580c,#c2410c); }
.findrisk__result--veryhigh { background: linear-gradient(135deg,#dc2626,#991b1b); }

.findrisk__form { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--sh-sm); }
.findrisk__hp { position: absolute; left: -9999px; }
.findrisk__name { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
.findrisk__name span { font-weight: 600; font-size: .9rem; color: var(--ink-soft); }
.findrisk__name input { padding: 12px 14px; border: 1px solid var(--line); border-radius: var(--r-sm); font: inherit; }
.findrisk__q { border: 0; border-top: 1px solid var(--line); margin: 0; padding: 20px 0 4px; }
.findrisk__q legend { font-weight: 700; font-size: 1.05rem; color: var(--ink); padding: 0; display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.findrisk__num { flex: none; width: 28px; height: 28px; border-radius: 50%; background: var(--grad-accent); color: #fff; display: grid; place-items: center; font-size: .85rem; }
.findrisk__opts { display: grid; gap: 10px; }
.findrisk__opt { display: flex; align-items: center; gap: 12px; padding: 12px 16px; border: 1px solid var(--line); border-radius: var(--r); cursor: pointer; transition: border-color .15s var(--ease), background .15s var(--ease); }
.findrisk__opt:hover { border-color: var(--primary-200); background: var(--primary-50); }
.findrisk__opt input { accent-color: var(--primary); }
.findrisk__opt span { flex: 1; }
.findrisk__opt i { font-style: normal; font-size: .8rem; font-weight: 700; color: var(--ink-faint); background: var(--bg); border-radius: 6px; padding: 2px 8px; }
.findrisk__opt:has(input:checked) { border-color: var(--primary); background: var(--primary-50); box-shadow: 0 0 0 1px var(--primary); }
.findrisk__form button { margin-top: 22px; }
.findrisk__disclaimer { margin: 12px 0 0; font-size: .82rem; color: var(--ink-faint); }
@media (max-width: 560px) { .findrisk__result { flex-direction: column; text-align: center; } }

/* ---------- Опрос о диабете (доп. к .findrisk) ---------- */
.diabetes-answers { max-width: 820px; margin: 0 auto 26px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); padding: 16px 20px; }
.diabetes-answers summary { cursor: pointer; font-weight: 700; color: var(--primary); }
.diabetes-answers ol { margin: 14px 0 0; padding-left: 22px; display: grid; gap: 12px; }
.diabetes-answers li { color: var(--ink-soft); }
.diabetes-answers li strong { color: var(--ink); }

/* ---------- Электронные обращения ---------- */
.appeals { max-width: 860px; margin-inline: auto; }
.appeals__notice { background: var(--primary-50); border-left: 5px solid var(--accent); border-radius: var(--r); padding: 20px 24px; margin-bottom: 24px; }
.appeals__notice strong { color: var(--danger); font-size: 1.05rem; }
.appeals__notice p { margin: 8px 0 0; color: var(--ink-soft); }
.appeals__result { display: flex; align-items: center; gap: 12px; border-radius: var(--r); padding: 16px 20px; margin-bottom: 20px; font-weight: 600; }
.appeals__result .icon { flex: none; width: 1.6rem; height: 1.6rem; }
.appeals__result--ok { background: rgba(0,181,184,.12); color: var(--accent-600); }
.appeals__result--err { background: rgba(226,59,59,.1); color: var(--danger); }
.appeals__form { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--sh-sm); }
.appeals__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.appeals__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 20px; }
.appeals__field { display: flex; flex-direction: column; gap: 6px; }
.appeals__field--full { grid-column: 1 / -1; }
.appeals__field > span { font-weight: 600; font-size: .9rem; color: var(--ink-soft); }
.appeals__field i { color: var(--danger); font-style: normal; }
.appeals__field input, .appeals__field select, .appeals__field textarea {
	width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: var(--r-sm); font: inherit; background: #fff; color: var(--ink);
}
.appeals__field input:focus, .appeals__field select:focus, .appeals__field textarea:focus { outline: none; border-color: var(--primary-200); box-shadow: 0 0 0 3px var(--primary-50); }
.appeals__consent { display: flex; align-items: flex-start; gap: 10px; font-size: .9rem; color: var(--ink-soft); }
.appeals__consent input { width: auto; margin-top: 3px; }
.appeals__hint { margin: 12px 0 0; font-size: .82rem; color: var(--ink-faint); }
@media (max-width: 640px) { .appeals__grid { grid-template-columns: 1fr; } }

/* ---------- Редактируемые области шапки/подвала ---------- */
.site-notice { background: var(--grad-accent); color: #fff; font-size: .92rem; }
.site-notice .container { padding-top: 8px; padding-bottom: 8px; }
.site-notice p { margin: 0; }
.site-notice a { color: #fff; text-decoration: underline; }
.footer-extra { border-top: 1px solid rgba(255,255,255,.12); }
.footer-extra .container { padding-top: 22px; padding-bottom: 22px; color: rgba(255,255,255,.85); }
.footer-extra a { color: #fff; }

/* ---------- Пагинация ---------- */
.pagination { margin-top: 36px; }
.pagination .nav-links { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; justify-content: center; }
.pagination .page-numbers { display: grid; place-items: center; min-width: 44px; height: 44px; padding: 0 12px; border-radius: var(--r-sm); background: var(--surface); border: 1px solid var(--line); font-weight: 700; color: var(--ink); text-decoration: none; transition: border-color .15s var(--ease), background .15s var(--ease); }
.pagination a.page-numbers:hover { border-color: var(--primary-200); background: var(--primary-50); }
.pagination .current { background: var(--grad-accent); color: #fff; border-color: transparent; }
.pagination .dots { background: transparent; border: 0; min-width: 24px; }
.pagination .prev, .pagination .next { font-weight: 600; }

/* ---------- Подвал ---------- */
.site-footer { background: var(--primary-900); color: #aac4e2; margin-top: 60px; }
.site-footer__inner { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--gap); padding: 56px 22px 40px; }
.site-footer__title { color: #fff; font-size: 1.05rem; margin-bottom: 16px; }
.site-footer p { display: flex; gap: 9px; align-items: flex-start; margin: 8px 0; }
.site-footer .icon { color: var(--accent); width: 1.05rem; height: 1.05rem; margin-top: 3px; }
.site-footer a { color: #aac4e2; }
.site-footer a:hover { color: #fff; }
.site-footer__menu { list-style: none; margin: 0; padding: 0; }
.site-footer__menu li { margin: 9px 0; }
.site-footer__menu a { display: inline-flex; align-items: center; gap: 8px; }
.site-footer__menu a::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.site-footer__bottom { background: rgba(0,0,0,.25); padding: 18px 0; font-size: .85rem; }
.site-footer__bottom .container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }

/* ---------- Формы ---------- */
.search-form { display: flex; gap: 10px; margin-top: 16px; max-width: 100%; }
.search-form__input { flex: 1 1 auto; min-width: 0; padding: 13px 18px; border: 1px solid var(--line); border-radius: 999px; font: inherit; }
.search-form__input:focus { border-color: var(--primary-200); outline: none; }
.search-form__submit { flex: none; padding: 13px 22px; border: 0; border-radius: 999px; background: var(--grad-accent); color: #fff; font-weight: 700; cursor: pointer; white-space: nowrap; }

/* ---------- Страница результатов поиска ---------- */
.search-page { max-width: 860px; }
.search-results { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.search-result { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 20px 24px; box-shadow: var(--sh-xs); transition: box-shadow .2s var(--ease), border-color .2s var(--ease); }
.search-result:hover { box-shadow: var(--sh-sm); border-color: var(--primary-200); }
.search-result__type { display: inline-block; font-size: .72rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: var(--accent-600); background: rgba(0,181,184,.1); padding: 3px 9px; border-radius: 6px; margin-bottom: 8px; }
.search-result__title { display: block; font-size: 1.15rem; font-weight: 800; color: var(--ink); }
.search-result__title:hover { color: var(--primary); }
.search-result__excerpt { margin: 6px 0 0; color: var(--ink-soft); }
.search-empty { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--sh-xs); }

/* ---------- «Поделиться» в статье ---------- */
.share { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; margin-bottom: 22px; }
.share__label { font-weight: 700; font-size: .9rem; color: var(--ink-soft); margin-right: 4px; }
.share__btn {
	width: 42px; height: 42px; border-radius: 50%; border: 0; cursor: pointer; padding: 0;
	display: grid; place-items: center; color: #fff; box-shadow: var(--sh-xs);
	transition: transform .2s var(--ease), box-shadow .2s var(--ease), filter .2s var(--ease);
}
.share__btn:hover { transform: translateY(-3px); box-shadow: var(--sh-md); filter: brightness(1.07); color: #fff; }
.share__btn .icon { width: 1.2rem; height: 1.2rem; }
.share__btn--telegram { background: #229ED9; }
.share__btn--viber { background: #7360F2; }
.share__btn--vk { background: #0077FF; }
.share__btn--odnoklassniki { background: #EE8208; }
.share__btn--copy, .share__btn--print { background: var(--primary-50); color: var(--primary); }
.share__btn--copy:hover, .share__btn--print:hover { background: var(--primary-100); color: var(--primary-700); }
.share__btn--copy .icon--check { display: none; }
.share__btn--copy.is-copied { background: var(--accent); color: #fff; }
.share__btn--copy.is-copied .icon--link { display: none; }
.share__btn--copy.is-copied .icon--check { display: block; }

/* ---------- Навигация между записями (пред./след.) ---------- */
.post-navigation .nav-links { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.post-navigation .nav-previous, .post-navigation .nav-next { min-width: 0; }
.post-navigation .nav-next { grid-column: 2; text-align: right; }
.post-navigation .nav-previous { grid-column: 1; }
.post-navigation a {
	display: block; height: 100%; background: var(--surface); border: 1px solid var(--line);
	border-radius: var(--r); padding: 14px 18px;
	transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease);
}
.post-navigation a:hover { border-color: var(--primary-200); box-shadow: var(--sh-sm); transform: translateY(-2px); }
.post-navigation .nav-hint { display: block; font-size: .75rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 4px; }
.post-navigation .nav-title { display: block; font-weight: 700; color: var(--ink); line-height: 1.35; font-size: .95rem; overflow-wrap: break-word; }
.post-navigation a:hover .nav-title { color: var(--primary); }
@media (max-width: 640px) {
	.post-navigation .nav-links { grid-template-columns: 1fr; }
	.post-navigation .nav-next { grid-column: 1; text-align: left; }
}

/* ---------- «Читайте также» ---------- */
.related { margin-top: 38px; padding-top: 28px; border-top: 1px solid var(--line); }
.related__title { font-size: 1.35rem; margin-bottom: 18px; }
.related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 860px) { .related__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .related__grid { grid-template-columns: 1fr; } }

/* ---------- Кнопка «Наверх» ---------- */
.to-top {
	position: fixed; right: 20px; bottom: 20px; z-index: 95;
	width: 48px; height: 48px; border-radius: 50%; border: 0; cursor: pointer;
	background: var(--grad-accent); color: #fff; box-shadow: var(--sh-primary);
	display: grid; place-items: center;
	opacity: 0; visibility: hidden; transform: translateY(14px);
	transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s var(--ease);
}
.to-top.is-visible { opacity: 1; visibility: visible; transform: none; }
.to-top:hover { filter: brightness(1.08); }
.to-top .icon { width: 1.35rem; height: 1.35rem; }

/* ---------- Анимация появления при скролле ---------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }

/* ---------- Адаптив ---------- */
@media (max-width: 1080px) {
	.header-main__inner { grid-template-columns: auto 1fr; gap: 22px; }
	.header-main__cta { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; }
	.header-main__cta .btn { flex: 1; }
}
@media (max-width: 960px) {
	.services__grid { grid-template-columns: repeat(2, 1fr); }
	.news__grid { grid-template-columns: repeat(2, 1fr); }
	.card--feature { grid-column: span 2; grid-row: auto; }
	.quick__grid { grid-template-columns: repeat(2, 1fr); }
	.stats__grid { grid-template-columns: repeat(2, 1fr); }
	.resources__grid { grid-template-columns: repeat(2, 1fr); }
	.layout { grid-template-columns: 1fr; }
	.about__top { grid-template-columns: 1fr; }
	.header-main__contacts { display: none; }
}
@media (max-width: 720px) {
	/* Верхняя панель уезжает в бургер */
	.topbar { display: none; }
	.navbar__inner { justify-content: space-between; gap: 12px; flex-wrap: wrap; }
	.navbar__toggle { display: grid; place-items: center; order: 2; }
	.navbar__collapse { display: none; flex-direction: column; align-items: stretch; width: 100%; order: 3; gap: 4px; padding: 8px 0 12px; }
	.navbar__collapse.is-open { display: flex; }
	.navbar__list { flex-direction: column; width: 100%; flex: none; }
	.navbar__list > li { display: flex; flex-wrap: wrap; align-items: center; border-bottom: 1px solid rgba(255,255,255,.08); }
	.navbar__list > li:last-child { border-bottom: 0; }
	.navbar__list > li > a { padding: 12px 6px; flex: 1; min-width: 0; }
	.navbar__list > li > a::after { display: none; }
	/* Подменю — аккордеон: свёрнуты, раскрываются кнопкой-шевроном (JS ставит .is-open). */
	.navbar__list ul, .navbar__list > li > ul { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: rgba(255,255,255,.08); border-radius: var(--r-sm); padding: 4px 0 4px 12px; margin: 0 0 8px; display: none; max-height: none; width: 100%; flex: none; }
	.navbar__list li.is-open > ul { display: block; }
	.navbar__list ul li, .navbar__list > li > ul > li { width: auto; display: flex; flex-wrap: wrap; align-items: center; }
	.navbar__list ul li > a { flex: 1; min-width: 0; }
	.navbar__list ul ul { left: auto; padding-left: 18px; background: rgba(255,255,255,.06); }
	.navbar__list ul a { color: #dcebff; padding: 9px 10px; }
	.navbar__list ul > li:has(> ul) > a::after { display: none; }
	.submenu-toggle { display: grid; }
	.navbar__search { display: flex; width: 100%; order: -1; margin-bottom: 6px; }
	.navbar__search input { width: 100%; }
	.navbar__extra { display: block; border-top: 1px solid rgba(255,255,255,.15); margin-top: 8px; padding-top: 12px; }
	.navbar__extra-list { list-style: none; margin: 0 0 12px; padding: 0; }
	.navbar__extra-list li a { display: block; color: #dcebff; padding: 8px 6px; font-weight: 600; }
	.navbar__extra-tools { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; padding: 4px 6px; }
	.navbar__extra-tools .a11y-toggle { color: #eaf3ff; }

	.quick { margin-top: 22px; }
	.quick__grid { grid-template-columns: 1fr; }
	.section { padding: 40px 0; }
	.timeline__item { grid-template-columns: 1fr; gap: 4px; }
	.site-footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
	.services__grid, .news__grid, .stats__grid, .resources__grid, .site-footer__inner { grid-template-columns: 1fr; }
	.card--feature { grid-column: auto; }
}

@media (max-width: 560px) {
	/* Компактнее CTA-кнопки шапки на телефоне — меньше места до контента */
	.header-main__inner { padding: 14px 22px; gap: 14px; }
	.header-main__cta { gap: 7px; }
	.header-main__cta .btn { font-size: .82rem; padding: 10px 14px; }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
	.reveal { opacity: 1; transform: none; }
}

/* ---------- Тёмная тема (prefers-color-scheme) ----------
   Телефоны с системной тёмной темой получают аккуратную фирменную схему,
   а не автоинверсию браузера. Светлая тема не меняется. Версия для
   слабовидящих (body.a11y-on) задаёт свои цвета поверх — приоритет за ней. */
@media (prefers-color-scheme: dark) {
	:root {
		--primary-50:  #1a2c46;
		--primary-100: #22395a;
		--primary-200: #35577f;
		--primary-400: #4f93e6;
		--primary:     #5aa2ef;
		--primary-600: #7cb5f3;
		--primary-700: #9ac7f7;
		--primary-900: #05192e;

		--accent:      #00b5b8;
		--accent-600:  #33cdd0;
		--danger:      #f26060;

		--ink:         #e9eff7;
		--ink-soft:    #b3c2d5;
		--ink-faint:   #7f92a9;
		--line:        #263850;
		--bg:          #0e1725;
		--surface:     #16243b;

		--sh-xs: 0 1px 2px rgba(0,0,0,.35);
		--sh-sm: 0 4px 14px rgba(0,0,0,.35);
		--sh-md: 0 12px 30px rgba(0,0,0,.45);
		--sh-lg: 0 24px 60px rgba(0,0,0,.55);
		--sh-primary: 0 14px 30px rgba(0,0,0,.5);
	}

	/* Герой: тёмный «живой» фон вместо светло-голубого */
	.hero__bg { background:
		radial-gradient(60% 70% at 12% 18%, rgba(0,181,184,.12), transparent 60%),
		radial-gradient(55% 65% at 88% 28%, rgba(79,147,230,.14), transparent 62%),
		linear-gradient(180deg, #101c30 0%, var(--bg) 70%); }
	.hero__kicker { background: rgba(22,36,59,.75); color: var(--primary-700); }
	.hero__search { background: var(--surface); }
	.hero__search input { color: var(--ink); }
	.hero__slider { background: linear-gradient(135deg, #1a2c46, #0e1725); }

	/* Белые кнопки/стрелки → тёмная поверхность */
	.btn--white { background: #22354f; color: #dbe9fb; }
	.slider-arrow { background: rgba(22,36,59,.92); color: #cfe1f7; }
	.slider-arrow:hover { background: #22354f; color: #fff; }

	/* Таблицы: шапка тёмно-синяя, а не осветлённый primary */
	.article__body thead th, .article__body tr:first-child th { background: #1c4979; }

	/* Поля форм */
	.appeals__field input, .appeals__field select, .appeals__field textarea,
	.findrisk__name input { background: var(--surface); color: var(--ink); }

	/* Логотипы информационных ресурсов остаются на белой плашке — это норма. */
}

/* ---------- Печать: чистый документ без «обвеса» ----------
   Люди печатают графики приёмов и контакты — на бумагу идёт только контент. */
@media print {
	.topbar, .header-main__cta, .navbar, .site-footer, .to-top, .share,
	.post-navigation, .related, .layout__sidebar, .skip-link, .site-notice,
	.a11y-panel, .hero__actions, .hero__search { display: none !important; }
	body { background: #fff; color: #000; }
	.page-hero { background: none; color: #000; padding: 0 0 10px; }
	.page-hero__title { color: #000; }
	.page-hero .breadcrumbs__list { display: none; }
	.layout, .layout__content { display: block; max-width: none; padding: 0; margin: 0; border: 0; box-shadow: none; }
	.article__body { color: #000; font-size: 11pt; }
	.article__body a { color: #000; text-decoration: underline; }
	.article__body .wp-block-details { border: 0; }
	.article__body .wp-block-details > summary::before { display: none; }
	.article__body .table-scroll, .article__body .wp-block-table { overflow: visible; }
	.article__body table { box-shadow: none; }
	.article__body thead th, .article__body tr:first-child th { background: #eee !important; color: #000 !important; }
	.article__body tbody tr:nth-child(even) { background: #f6f6f6 !important; }
}
