/* ЦАРМО — дизайн-система (v2, презентационная) */
:root{
  --navy:#1A2C5B;          /* глубокий индиго-навy (кольцо логотипа) */
  --navy-2:#1F6FB2;        /* ссылки/ховер (синий из логотипа) */
  --navy-900:#111E40;      /* самый тёмный (hero, footer) */
  --accent:#C7A24B;        /* ЗОЛОТО — основной акцент (официальность) */
  --accent-2:#E3C77E;      /* светлое золото (на тёмном) */
  --teal:#17A2C6;          /* бирюза из логотипа (доп. цвет) */
  --teal-2:#5FC8DD;        /* светлая бирюза */
  --grad:linear-gradient(90deg, var(--accent), var(--teal));       /* золото→бирюза (тонкие акценты) */
  --grad-135:linear-gradient(135deg, var(--teal), var(--accent));  /* бирюза→золото */
  --ink:#1B2733;
  --muted:#54636F;
  --line:#E5E7E1;
  --line-2:#EFF0EC;
  --bg:#FFFFFF;
  --bg-page:#F7F7F3;       /* тёплый «бумажный» фон страницы (под золото) */
  --bg-soft:#F1F2EC;       /* секции-подложки */
  --bg-gold:#FBF4E3;       /* мягкое золотое поле (акцентные подложки) */
  --bg-teal:#E5F3F8;       /* мягкое бирюзовое поле */
  --head-font:"PT Serif", Georgia, serif;
  --body-font:"PT Sans", system-ui, sans-serif;
  --maxw:1200px;
  --radius:14px;
  --radius-sm:10px;
  --sh-sm:0 1px 2px rgba(18,52,80,.05), 0 2px 8px rgba(18,52,80,.04);
  --sh-md:0 6px 20px rgba(18,52,80,.09);
  --sh-lg:0 18px 48px rgba(18,52,80,.16);
  --t:.2s cubic-bezier(.4,0,.2,1);
}
body.f-inter{--head-font:"Inter",system-ui,sans-serif;--body-font:"Inter",system-ui,sans-serif;}
body.f-golos{--head-font:"Golos Text",system-ui,sans-serif;--body-font:"Golos Text",system-ui,sans-serif;}
body.f-pt{--head-font:"PT Serif",Georgia,serif;--body-font:"PT Sans",system-ui,sans-serif;}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body-font);color:var(--ink);background:var(--bg-page);line-height:1.65;font-size:17.5px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--head-font);color:var(--navy);line-height:1.18;margin:0 0 .4em;letter-spacing:-.01em}
a{color:var(--navy-2);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--navy)}
img{max-width:100%;display:block}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:2px;border-radius:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.btn{display:inline-flex;align-items:center;gap:9px;background:var(--navy);color:#fff;padding:14px 28px;border-radius:10px;font-weight:700;border:0;cursor:pointer;font-family:var(--body-font);font-size:16.5px;transition:transform var(--t),box-shadow var(--t),background var(--t);box-shadow:0 6px 16px rgba(18,52,80,.18)}
.btn:hover{background:var(--navy-2);color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px rgba(18,52,80,.26)}
.btn.ghost{background:transparent;color:var(--navy);border:1.5px solid rgba(18,52,80,.35);box-shadow:none}
.btn.ghost:hover{border-color:var(--navy);background:rgba(18,52,80,.04);color:var(--navy)}

/* иконки */
.ico{width:22px;height:22px;flex:0 0 auto;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* ── утилитарная панель ── */
.utility{background:var(--navy-900);color:#c2cfda;font-size:15px;border-bottom:1px solid rgba(255,255,255,.06)}
.utility .wrap{display:flex;align-items:center;justify-content:space-between;height:44px;gap:16px}
.utility a{color:#c2cfda}
.utility .u-right{display:flex;align-items:center;gap:8px}
.lang{display:inline-flex;gap:2px;margin-left:8px;border:1px solid rgba(255,255,255,.18);border-radius:8px;overflow:hidden}
.lang a{padding:6px 12px;color:#c2cfda;font-weight:700;font-size:14px;letter-spacing:.02em}
.lang a.active{background:var(--accent);color:var(--navy-900)}
.lang a:hover:not(.active){background:rgba(255,255,255,.08);color:#fff}
.tool{background:none;border:0;color:#c2cfda;cursor:pointer;font:inherit;font-size:15px;padding:6px 8px;border-radius:7px;display:inline-flex;align-items:center;gap:6px;transition:background var(--t),color var(--t)}
.tool:hover{color:#fff;background:rgba(255,255,255,.08)}

/* ── шапка ── */
header.site{background:rgba(255,255,255,.92);backdrop-filter:saturate(1.6) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;transition:box-shadow var(--t)}
header.site.scrolled{box-shadow:0 4px 20px rgba(18,52,80,.08)}
.head-row{display:flex;align-items:center;gap:16px;padding:16px 0}
.emblem{width:56px;height:56px;flex:0 0 auto;display:block}
.emblem img{width:100%;height:100%;object-fit:contain;display:block}
.org{font-family:var(--head-font);font-weight:700;color:var(--navy);font-size:18px;line-height:1.2;max-width:500px;min-width:0}
.org small{display:block;font-family:var(--body-font);font-weight:400;color:var(--muted);font-size:13.5px;margin-top:4px;letter-spacing:0}
nav.main{margin-left:auto;flex:0 0 auto}
nav.main ul{list-style:none;display:flex;gap:2px;margin:0;padding:0}
nav.main a{display:block;white-space:nowrap;color:var(--ink);font-weight:600;font-size:15.5px;padding:8px 12px;border-radius:9px;position:relative;transition:color var(--t),background var(--t)}
nav.main a:hover{color:var(--navy);background:var(--bg-soft)}
nav.main a.active{color:var(--navy)}
nav.main a.active::after{content:"";position:absolute;left:12px;right:12px;bottom:3px;height:2px;background:var(--grad);border-radius:2px}

/* мобильное меню */
.menu-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:10px;width:46px;height:46px;cursor:pointer;color:var(--navy);align-items:center;justify-content:center}
.menu-toggle .ico{width:24px;height:24px}
.mobile-nav{position:fixed;inset:0;background:rgba(12,36,54,.5);backdrop-filter:blur(2px);z-index:60;opacity:0;visibility:hidden;transition:opacity var(--t)}
.mobile-nav.open{opacity:1;visibility:visible}
.mobile-nav .panel{position:absolute;top:0;right:0;height:100%;width:min(82vw,340px);background:#fff;box-shadow:var(--sh-lg);transform:translateX(100%);transition:transform var(--t);padding:22px;display:flex;flex-direction:column;gap:6px;overflow:auto}
.mobile-nav.open .panel{transform:none}
.mobile-nav .panel a{padding:14px 14px;border-radius:10px;color:var(--ink);font-weight:600;font-size:17.5px}
.mobile-nav .panel a:hover,.mobile-nav .panel a.active{background:var(--bg-soft);color:var(--navy)}
.mobile-nav .close{align-self:flex-end;background:none;border:0;cursor:pointer;color:var(--muted);padding:8px;margin-bottom:6px}

/* ── hero ── */
.hero{position:relative;overflow:hidden;color:#fff;background:
  radial-gradient(120% 120% at 88% -10%, rgba(23,162,198,.30), transparent 46%),
  radial-gradient(90% 90% at -5% 120%, rgba(199,162,75,.16), transparent 52%),
  linear-gradient(118deg, var(--navy) 0%, var(--navy-900) 100%)}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M30 0l30 30-30 30L0 30z' fill='none' stroke='%23ffffff' stroke-opacity='0.05'/%3E%3C/svg%3E")}
.hero::after{content:"";position:absolute;right:-140px;top:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(95,200,221,.18),transparent 70%)}
.hero .wrap{position:relative;z-index:1;padding:88px 28px 92px}
.hero .kicker{display:inline-flex;align-items:center;gap:10px;color:var(--accent-2);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:14px;margin-bottom:22px}
.hero .kicker::before{content:"";width:34px;height:3px;border-radius:2px;background:var(--grad);display:inline-block}
.hero h1{color:#fff;font-size:clamp(30px,4.2vw,46px);max-width:30ch;letter-spacing:-.015em;line-height:1.18;text-wrap:balance}
.hero p{color:#d6e0ea;max-width:60ch;font-size:19px;margin:22px 0 34px}
.hero .btns{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn.ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.hero .btn.ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.hero-orb{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:430px;height:430px;opacity:.55;pointer-events:none;z-index:0}
.hero-orb circle,.hero-orb ellipse,.hero-orb line{fill:none;stroke-width:1.3}
@media(max-width:900px){.hero-orb{display:none}}

/* компактный hero внутренних страниц */
.page-hero{position:relative;overflow:hidden;color:#fff;background:
  radial-gradient(120% 140% at 92% -30%, rgba(23,162,198,.24), transparent 50%),
  linear-gradient(118deg, var(--navy) 0%, var(--navy-900) 100%)}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.45;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M30 0l30 30-30 30L0 30z' fill='none' stroke='%23ffffff' stroke-opacity='0.05'/%3E%3C/svg%3E")}
.page-hero .wrap{position:relative;z-index:1;padding:46px 28px 50px}
.page-hero h1{color:#fff;font-size:clamp(26px,3.4vw,38px);margin:0}
.breadcrumb{font-size:15px;color:#b8c8d5;margin-bottom:14px;display:flex;gap:8px;align-items:center}
.breadcrumb a{color:#b8c8d5}
.breadcrumb a:hover{color:#fff}

/* ── секции ── */
section{padding:72px 0}
section.tight{padding:48px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:34px;gap:20px}
.sec-head h2{font-size:clamp(24px,2.6vw,32px);margin:0;position:relative;padding-left:18px}
.sec-head h2::before{content:"";position:absolute;left:0;top:.1em;bottom:.1em;width:5px;border-radius:3px;background:var(--grad)}
.sec-head a{font-weight:700;white-space:nowrap;color:var(--navy-2);font-size:16px}
.sec-head a:hover{color:var(--navy)}
.grid{display:grid;gap:24px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

.card{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--sh-sm);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;border-radius:var(--radius) var(--radius) 0 0;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.card:hover{box-shadow:var(--sh-md);transform:translateY(-3px);border-color:#D7DEE6}
.card:hover::before{transform:scaleX(1)}

/* ── новости ── */
.news .grid .card{display:flex;flex-direction:column}
.tag{display:inline-flex;align-items:center;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#0E7490;background:var(--bg-teal);padding:6px 12px;border-radius:30px;margin-bottom:14px;align-self:flex-start}
.tag.ann{color:#8a6d1f;background:var(--bg-gold)}
time{display:block;color:var(--muted);font-size:15px;margin-bottom:8px;font-variant-numeric:tabular-nums}
.news h3{font-size:19px;line-height:1.32}
.news h3 a{color:var(--navy)}
.news h3 a:hover{color:var(--navy-2)}

/* ── направления ── */
.activity{background:var(--bg-soft)}
.activity .card{position:relative;padding-top:30px}
.activity .card .num{position:absolute;top:18px;right:24px;font-family:var(--head-font);font-size:46px;font-weight:700;color:var(--accent);opacity:.16;line-height:1}
.activity .actico{width:50px;height:50px;border-radius:12px;background:var(--bg-gold);color:var(--navy);display:grid;place-items:center;margin-bottom:16px}
.activity .actico .ico{width:26px;height:26px;stroke:var(--navy)}
.activity h3{font-size:19.5px;margin-bottom:10px}
.activity p{color:var(--muted);font-size:16.5px;margin:0}

/* ── быстрые ссылки ── */
.quick .grid a{display:flex;flex-direction:column;gap:10px;min-height:148px;background:linear-gradient(150deg,var(--navy),var(--navy-900));color:#fff;border-radius:var(--radius);padding:24px;font-weight:700;position:relative;overflow:hidden;transition:transform var(--t),box-shadow var(--t)}
.quick .grid a:hover{transform:translateY(-3px);box-shadow:var(--sh-md);color:#fff}
.quick .grid a::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--grad)}
.quick .grid a .ico{width:26px;height:26px;stroke:var(--accent-2);margin-bottom:auto}
.quick .grid a strong{font-size:17.5px}
.quick .grid a span{font-size:15px;font-weight:400;color:#c2cfda}
.quick .grid a::after{content:"→";position:absolute;right:22px;bottom:20px;color:var(--accent-2);font-size:18px;transition:transform var(--t)}
.quick .grid a:hover::after{transform:translateX(4px)}

/* ── раскладка контент + сайдбар ── */
.layout{display:grid;gap:48px}
.layout.with-side{grid-template-columns:1fr 280px}
aside.side{position:sticky;top:104px;align-self:start}
aside.side h4{font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:14px}
aside.side ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
aside.side a{display:block;padding:11px 16px;border-radius:10px;color:var(--ink);font-weight:600;font-size:16px;border-left:3px solid transparent;transition:background var(--t),border-color var(--t),color var(--t)}
aside.side a:hover{background:var(--bg-soft)}
aside.side a.active{background:var(--bg-gold);border-left-color:var(--accent);color:var(--navy)}

/* ── текстовый контент ── */
.prose{font-size:17.5px;color:#27333E}
.prose h2{font-size:25px;margin-top:1.5em}
.prose h3{font-size:19.5px;margin-top:1.3em;color:var(--navy)}
.prose p{margin:0 0 1.05em}
.prose ul{padding-left:20px}
.prose li{margin:.4em 0}

/* карточка персоны (директор) */
.person{display:grid;grid-template-columns:180px 1fr;gap:30px;align-items:start;margin:.4em 0 .2em;padding:24px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--sh-sm)}
.person .photo{width:180px;height:216px;border-radius:12px;background:linear-gradient(160deg,#21506f,var(--navy-900));display:grid;place-items:center;color:var(--accent-2);font-family:var(--head-font);font-size:46px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.person .role{color:var(--accent);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}

/* ── документы ── */
.doc-cat{margin:0 0 14px;font-size:22px}
.doc-list{list-style:none;margin:0 0 36px;padding:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg);box-shadow:var(--sh-sm)}
.doc-list li{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--line-2);transition:background var(--t)}
.doc-list li:last-child{border-bottom:0}
.doc-list li:hover{background:var(--bg-soft)}
.doc-list .ic{flex:0 0 auto;width:42px;height:50px;background:#FCEDED;color:#C0392B;border-radius:8px;display:grid;place-items:center;font-size:12.5px;font-weight:800;letter-spacing:.03em}
.doc-list .ic.doc{background:#EAF1F7;color:var(--navy-2)}
.doc-list .t{flex:1;font-weight:600;font-size:16.5px;color:var(--ink)}
.doc-list .meta{color:var(--muted);font-size:14px;white-space:nowrap}
.doc-list a.dl{font-weight:700;font-size:15.5px;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;color:var(--navy-2)}
.doc-list a.dl:hover{color:var(--navy)}

/* ── вкладки-фильтр ── */
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.tabs button{border:1px solid var(--line);background:var(--bg);border-radius:30px;padding:10px 20px;font:inherit;font-size:15.5px;font-weight:600;cursor:pointer;color:var(--ink);transition:all var(--t)}
.tabs button:hover{border-color:#C9D3DD}
.tabs button.active{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:0 4px 12px rgba(18,52,80,.2)}

/* ── список новостей ── */
.news-list{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg);box-shadow:var(--sh-sm)}
.news-list .row{display:grid;grid-template-columns:128px 1fr;gap:24px;padding:24px;border-bottom:1px solid var(--line-2);transition:background var(--t)}
.news-list .row:last-child{border-bottom:0}
.news-list .row:hover{background:var(--bg-soft)}
.news-list .row time{margin:0;font-size:15px;padding-top:2px}
.news-list .row h3{font-size:20px;margin:.15em 0 .35em}
.news-list .row p{margin:0;color:var(--muted);font-size:16px}

/* ── госуслуги ── */
.svc .card{display:flex;flex-direction:column;gap:10px}
.svc .card .num{width:46px;height:46px;border-radius:12px;background:var(--bg-gold);color:var(--navy);display:grid;place-items:center;font-family:var(--head-font);font-weight:700;font-size:20px;margin-bottom:6px}
.svc .card h3{font-size:18.5px;margin:0}
.svc .card p{margin:0;color:var(--muted);font-size:16px;flex:1}
.svc .card a.go{font-weight:700;font-size:15.5px;margin-top:8px;color:var(--navy-2);display:inline-flex;gap:6px;align-items:center}
.svc .card a.go:hover{color:var(--navy)}

/* ── FAQ ── */
.faq details{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;background:var(--bg);overflow:hidden;box-shadow:var(--sh-sm);transition:box-shadow var(--t)}
.faq details[open]{box-shadow:var(--sh-md)}
.faq summary{cursor:pointer;padding:20px 24px;font-weight:700;color:var(--navy);list-style:none;display:flex;justify-content:space-between;gap:16px;font-family:var(--head-font);font-size:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:24px;line-height:1;transition:transform var(--t)}
.faq details[open] summary::after{content:"–"}
.faq .answer{padding:0 24px 20px;color:#27333E;font-size:16.5px}

/* ── галерея ── */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gallery .ph{aspect-ratio:4/3;border-radius:var(--radius);background:linear-gradient(160deg,#e4ebf1,#cdd9e2);display:grid;place-items:center;color:var(--navy);font-size:15px;font-weight:600;text-align:center;padding:12px;box-shadow:var(--sh-sm);transition:transform var(--t),box-shadow var(--t)}
.gallery .ph:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}

/* ── карта сайта ── */
.sitemap{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.sitemap h3{font-size:18.5px;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--bg-gold)}
.sitemap ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.sitemap a{font-size:16px}

/* ── форма ── */
.form{display:grid;gap:18px;max-width:560px}
.form label{font-weight:600;font-size:15.5px;display:block;margin-bottom:7px;color:var(--ink)}
.form input,.form textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:16.5px;background:#fff;transition:border-color var(--t),box-shadow var(--t)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--navy-2);box-shadow:0 0 0 3px rgba(30,86,128,.12)}
.form textarea{min-height:140px;resize:vertical}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.info-list li{display:flex;flex-direction:column;gap:3px}
.info-list b{color:var(--muted);font-size:13.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.info-list span{font-size:17px}

/* ── подвал ── */
footer{background:var(--navy-900);color:#aebecb;font-size:15.5px;padding:0 0 28px;margin-top:20px}
footer .wrap{padding-top:54px;position:relative}
footer .wrap::before{content:"";position:absolute;top:0;left:28px;right:28px;height:3px;background:linear-gradient(90deg,var(--accent),var(--teal) 50%,transparent 85%);border-radius:3px}
footer h4{color:#fff;font-family:var(--head-font);font-size:17.5px;margin:0 0 16px}
footer a{color:#aebecb}
footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:40px}
.foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:38px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:14.5px;color:#8597a6}
footer .socials{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
footer .socials a{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border:1px solid rgba(255,255,255,.18);border-radius:30px;color:#d3dde6;font-weight:600;font-size:15px}
footer .socials a:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.4)}
footer .socials .ico{width:18px;height:18px;stroke:var(--accent-2)}
.socials-light{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.socials-light a{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border:1px solid var(--line);border-radius:30px;color:var(--navy);font-weight:600;font-size:15px;background:#fff;transition:all var(--t)}
.socials-light a:hover{border-color:var(--accent);background:var(--bg-gold)}
.socials-light .ico{width:18px;height:18px;stroke:var(--accent)}

/* ── версия для слабовидящих ── */
body.a11y{--bg:#fff;--bg-page:#fff;--bg-soft:#fff;--bg-gold:#fff;--ink:#000;--navy:#000;--navy-2:#000;--navy-900:#000;--muted:#1a1a1a;--line:#000;font-size:21px}
body.a11y .hero,body.a11y .page-hero{background:#000}
body.a11y .hero::before,body.a11y .page-hero::before,body.a11y .hero::after{display:none}
body.a11y .card,body.a11y .quick .grid a,body.a11y .doc-list,body.a11y .news-list,body.a11y .faq details{border:1.5px solid #000;box-shadow:none}
body.a11y .quick .grid a{background:#000}

/* ── панель выбора шрифта ── */
.fontbar{position:fixed;right:18px;bottom:18px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-lg);padding:14px 16px;z-index:50;font-size:14.5px}
.fontbar b{display:block;color:var(--navy);margin-bottom:9px;font-family:var(--body-font)}
.fontbar button{display:block;width:100%;text-align:left;margin:5px 0;padding:9px 13px;border:1px solid var(--line);border-radius:9px;background:#fff;cursor:pointer;font:inherit;font-size:14px;transition:all var(--t)}
.fontbar button:hover{border-color:#C9D3DD}
.fontbar button.active{border-color:var(--accent);background:var(--bg-gold);color:var(--navy);font-weight:600}

/* ── адаптив ── */
@media(max-width:1080px){
  nav.main{display:none}
  .menu-toggle{display:inline-flex}
}
@media(max-width:980px){
  .g4{grid-template-columns:1fr 1fr}
  .layout.with-side{grid-template-columns:1fr}
  aside.side{position:static}
  .contact-grid{grid-template-columns:1fr;gap:32px}
}
@media(max-width:780px){
  .g3{grid-template-columns:1fr 1fr}
  .gallery,.sitemap{grid-template-columns:1fr 1fr}
  section{padding:52px 0}
  .hero .wrap{padding:64px 28px}
}
@media(max-width:560px){
  .wrap{padding:0 18px}
  .g3,.g4,.gallery,.sitemap,.foot-grid{grid-template-columns:1fr}
  .org{font-size:15.5px}.org small{display:none}
  .person{grid-template-columns:1fr}
  .person .photo{width:100%;height:200px}
  .news-list .row{grid-template-columns:1fr;gap:8px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:8px}
}
[hidden]{display:none!important}
