/* ============================================================================
   Клуб Героев — РЕДИЗАЙН темы (этап 4).
   Светлая патриотичная палитра, серифные тёмно-синие заголовки + красные акценты.
   Шапка: фон-триколор во всю ширину (вариант 3 «насыщенный»), эмблема + название текстом.
   Заменяет агрегированный Drupal-CSS. Лайтбокс галереи — Colorbox (свой CSS отдельно).
   ============================================================================ */
:root{
  --red:#c8102e; --red-dk:#a00d24; --navy:#13294b; --blue:#0039A6; --link:#0a63b0;
  --menu:#d2e6f3; --paper:#fff; --mist:#f3f7fc; --line:#e6ecf3; --ink:#2b3442; --muted:#69748a;
  --serif:Georgia,'PT Serif','Times New Roman',serif;
  --sans:'Segoe UI',Roboto,Arial,Helvetica,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.6}
a{color:var(--link);text-decoration:none}
img{max-width:100%;height:auto}
h1,h2,h3,h4{margin:0}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%)}
#main-content{position:absolute}

/* центрирующий контейнер контента — фоны во всю ширину, содержимое ≤1180px */
.wrap{max-width:1180px;margin:0 auto;padding:0 30px}

/* ============================ ШАПКА (флаг в3) ============================ */
/* фон-триколор — во всю ширину; эмблема и название — внутри контейнера ≤1920 */
.header{position:relative;height:176px;overflow:hidden;background:#fff;
  background-image:url(../img/trikolor.webp);background-repeat:no-repeat;
  background-size:cover;background-position:center bottom}            /* вариант 3 «насыщенный» */
.header__inner{position:relative;height:100%;max-width:1180px;margin:0 auto;padding:0 30px}
.header__emblem{position:absolute;left:30px;top:50%;transform:translateY(-50%);z-index:3;display:block}
.header__emblem img{height:148px;width:auto;filter:drop-shadow(0 3px 8px rgba(0,0,0,.28))}
.brand{position:absolute;left:50%;top:50%;transform:translate(-44%,-50%);z-index:2;
  text-align:center;width:min(74%,1000px);color:var(--red);
  /* усиленное белое свечение — название читается на насыщенном флаге */
  text-shadow:0 0 5px #fff,0 0 11px #fff,0 0 17px #fff,0 0 26px #fff,0 0 38px #fff,0 0 52px rgba(255,255,255,.92),0 1px 2px rgba(0,0,0,.32)}
.brand__sub{display:block;font-size:17px;font-weight:600;letter-spacing:.2px;margin-bottom:4px}
.brand__name{display:block;font-size:25px;font-weight:800;line-height:1.22}
@media(max-width:1080px){.brand__sub{font-size:15px}.brand__name{font-size:21px}}

/* ============================ МЕНЮ (десктоп) ============================ */
.nav{background:var(--menu);border-bottom:1px solid #c4dcee}
/* меню — широкое (пункты в одну строку по центру); фон-полоса .nav и так во всю ширину */
.nav__inner{padding:0 20px;display:flex;align-items:center;justify-content:center}
.nav__inner>ul{list-style:none;margin:0;padding:0;display:flex;justify-content:center;flex-wrap:wrap;gap:2px}
.nav li{position:relative}
.nav a{display:block;font-size:13.5px;font-weight:700;color:var(--link);padding:13px 14px;white-space:nowrap;transition:background .15s,color .15s}
.nav__inner>ul>li>a:hover{background:rgba(255,255,255,.6)}
.nav .current-menu-item>a,.nav .current-menu-ancestor>a,.nav .current_page_item>a,.nav .current-menu-parent>a{color:var(--red)}
/* выпадающее подменю */
.nav ul ul{list-style:none;margin:0;padding:6px 0;position:absolute;left:0;top:100%;min-width:240px;
  background:#fff;border:1px solid var(--line);border-radius:0 0 9px 9px;box-shadow:0 14px 30px rgba(20,40,80,.16);
  display:block;opacity:0;visibility:hidden;transform:translateY(7px);transition:.16s;z-index:60}
.nav li:hover>ul{opacity:1;visibility:visible;transform:none}
.nav ul ul a{padding:9px 18px;font-weight:600;color:var(--navy);white-space:normal}
.nav ul ul a:hover{background:var(--mist);color:var(--red)}
/* стрелка у пунктов с подменю (десктоп) */
.nav__inner>ul>.menu-item-has-children>a{padding-right:11px}
.nav__inner>ul>.menu-item-has-children>a::after{content:"";display:inline-block;width:6px;height:6px;
  margin-left:7px;vertical-align:middle;position:relative;top:-2px;border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;transform:rotate(45deg);opacity:.6;transition:transform .18s,opacity .15s}
.nav__inner>ul>.menu-item-has-children:hover>a::after{transform:rotate(-135deg);top:1px;opacity:.95}
/* гамбургер — только на мобильном */
.kg-burger{display:none}

/* ============================ ХЛЕБНЫЕ КРОШКИ (приглушённые) ============================ */
.crumbs{background:var(--mist);border-bottom:1px solid var(--line)}
.crumbs .in{padding:9px 0;font-size:12px;color:#9aa6b6}
.crumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:center}
.crumbs li{display:flex;align-items:center}
.crumbs li+li::before{content:"/";margin:0 7px;color:#c6cfda}
.crumbs a{color:#8a96a6;font-weight:400}
.crumbs a:hover{color:var(--link)}
.crumbs .active{color:#7c8798;font-weight:400}

/* ============================ РАСКЛАДКА ВНУТРЕННИХ ============================ */
.layout{display:grid;grid-template-columns:1fr 264px;gap:44px;padding:34px 0 50px}
.layout--full{grid-template-columns:1fr}

/* ============================ ОБРАЩЕНИЕ ПРЕДСЕДАТЕЛЯ (главная) ============================ */
.address{background:linear-gradient(180deg,#fbfdff,var(--mist));border-bottom:1px solid var(--line)}
.address .in{display:grid;grid-template-columns:230px 1fr;gap:34px;align-items:center;padding:34px 0 38px}
.address__photo{border:5px solid #fff;border-radius:10px;overflow:hidden;box-shadow:0 8px 24px rgba(20,40,80,.18)}
.address__photo img{display:block;width:100%}
.eyebrow{font-size:12.5px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--red);margin:0 0 10px}
.address__quote{font-family:var(--serif);font-style:italic;font-size:25px;line-height:1.4;color:var(--navy);
  margin:0 0 14px;position:relative;padding-left:22px}
.address__quote::before{content:"“";position:absolute;left:-6px;top:-10px;font-size:54px;color:#c9d6e6;font-family:var(--serif)}
.address p{margin:0 0 16px;max-width:760px}
.sign{font-weight:800;color:var(--navy);font-size:16px}
.sign small{display:block;font-weight:500;color:var(--muted);font-size:13.5px;margin-top:2px}

/* ============================ заголовки секций (главная) ============================ */
.sec{padding:46px 0 8px}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 24px;gap:16px}
.sec-head h2{font-family:var(--serif);font-size:30px;color:var(--navy);margin:0;position:relative;padding-bottom:12px}
.sec-head h2::after{content:"";position:absolute;left:0;bottom:0;width:58px;height:4px;background:var(--red);border-radius:2px}
.sec-head .more{font-weight:700;color:var(--link);white-space:nowrap}
.sec-head .more:hover{color:var(--red)}

/* ====================== СОБЫТИЯ — слева 3 новости с фото, справа список ====================== */
.events-split{display:grid;grid-template-columns:1.62fr 1fr;gap:38px;align-items:start}

/* левая колонка — горизонтальные карточки с фото */
.events-main{display:flex;flex-direction:column;gap:18px}
.nrow{display:grid;grid-template-columns:212px 1fr;background:#fff;border:1px solid var(--line);border-radius:12px;
  overflow:hidden;transition:box-shadow .2s,transform .2s,border-color .2s}
.nrow:hover{box-shadow:0 12px 28px rgba(20,40,80,.12);transform:translateY(-2px);border-color:#d8e2ee}
/* картинка тянется на всю высоту карточки (без зазора под фото) */
.nrow__media{display:block;overflow:hidden;background:#eef2f6;min-height:154px}
.nrow__media img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.nrow:hover .nrow__media img{transform:scale(1.05)}
.nrow__body{padding:15px 18px;display:flex;flex-direction:column;justify-content:center}
.nrow__date{color:var(--red);font-weight:700;font-size:12px;margin:0 0 6px}
.nrow__body h3{margin:0 0 8px;font-family:var(--serif);font-size:17px;line-height:1.3}
.nrow__body h3 a{color:var(--navy)}.nrow__body h3 a:hover{color:var(--red)}
.nrow__body p{margin:0 0 9px;font-size:13.5px;color:#4a5466}
.nrow__more{font-weight:700;color:var(--red);font-size:13px;margin-top:auto}

/* правая колонка — список «Ещё события» */
.events-aside__h{font-family:var(--serif);font-size:18px;color:var(--navy);margin:0 0 4px;padding-bottom:10px;position:relative}
.events-aside__h::after{content:"";position:absolute;left:0;bottom:0;width:38px;height:3px;background:var(--red);border-radius:2px}
.chron{margin-top:8px;border-top:1px solid var(--line)}
.chron a{display:flex;flex-direction:column;gap:2px;padding:11px 10px;border-bottom:1px solid var(--line);
  border-left:3px solid transparent;color:var(--navy);font-weight:600;line-height:1.34;
  transition:background .15s,border-color .15s,color .15s}
.chron a:hover{background:var(--mist);border-left-color:var(--red);color:var(--red)}
.chron .d{color:var(--muted);font-weight:600;font-size:12px}

/* ============================ ПАРТНЁРЫ — лента внизу (главная) ============================ */
.partners{background:var(--mist);border-top:1px solid var(--line);margin-top:48px}
.partners .in{padding:40px 0 46px}
.logos{display:flex;flex-wrap:wrap;gap:22px;justify-content:center}
.logo{background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px 26px;height:118px;
  display:flex;align-items:center;justify-content:center;min-width:230px;transition:box-shadow .2s,transform .2s}
.logo:hover{box-shadow:0 10px 24px rgba(20,40,80,.12);transform:translateY(-2px)}
.logo img{max-height:78px;width:auto;object-fit:contain}

/* ============================ КОНТЕНТ (статья / страница) ============================ */
.content h1{font-family:var(--serif);font-size:33px;line-height:1.18;color:var(--navy);margin:0 0 6px}
.content .meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:13.5px;
  margin:0 0 22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.content .meta .date{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--red)}
.content .meta .tag{background:var(--mist);border:1px solid var(--line);border-radius:20px;padding:3px 12px;font-size:12.5px;font-weight:600;color:var(--navy)}
.content p{margin:0 0 17px;font-size:16px;line-height:1.72}
.content h2{font-family:var(--serif);font-size:24px;color:var(--navy);margin:34px 0 12px}
.content h3{font-size:19px;color:var(--navy);margin:26px 0 10px}
.content a:hover{color:var(--red);text-decoration:underline}
.content ul,.content ol{margin:0 0 17px;padding-left:22px}
.content li{margin:0 0 8px;font-size:16px}
.content img{border-radius:8px}
.content figure{margin:24px 0}
.content figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:9px;font-style:italic}
.content blockquote{margin:24px 0;padding:6px 0 6px 24px;border-left:4px solid var(--red);
  font-family:var(--serif);font-style:italic;font-size:19px;line-height:1.5;color:var(--navy)}
.content::after{content:"";display:table;clear:both}

/* ====================== список членов клуба (страница «Члены Клуба Героев») ====================== */
.kg-members ol{column-count:3;column-gap:40px;margin:0;padding:0 0 0 26px}
.kg-members li{break-inside:avoid;margin:0 0 9px;line-height:1.38}
.kg-members li a{color:var(--link);font-weight:600}
.kg-members li a:hover{color:var(--red)}
.kg-members li i{display:block;color:var(--muted);font-size:12.5px;font-weight:400}
@media(max-width:760px){.kg-members ol{column-count:2;column-gap:28px}}
@media(max-width:480px){.kg-members ol{column-count:1}}

/* ============================ ГЕРОЙ (chelovek) ============================ */
.hero-top{display:grid;grid-template-columns:230px 1fr;gap:32px;align-items:start;margin:0 0 26px;padding-bottom:26px;border-bottom:1px solid var(--line)}
.hero-portrait{border:5px solid #fff;border-radius:10px;overflow:hidden;box-shadow:0 8px 24px rgba(20,40,80,.18);background:#eef2f6}
.hero-portrait img{display:block;width:100%}
.hero-rank{display:inline-block;background:var(--red);color:#fff;font-size:12.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:6px 14px;border-radius:6px;margin:0 0 14px}
.hero-top h1{font-family:var(--serif);font-size:32px;line-height:1.16;color:var(--navy);margin:0 0 12px}
.hero-role{font-size:17px;color:var(--navy);font-weight:600;margin:0}
@media(max-width:560px){.hero-top{grid-template-columns:1fr;justify-items:center;text-align:center}.hero-portrait{max-width:220px}}

/* ============================ ФОТОГАЛЕРЕЯ (Drupal field_gallery → сетка) ============================ */
/* .field--name-field-gallery и .field__items — на ОДНОМ элементе (Drupal-разметка) */
.field--name-field-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:26px 0 8px}
.field--name-field-gallery .field__item{margin:0}
.field--name-field-gallery .field__item a{display:block;aspect-ratio:4/3;border-radius:9px;overflow:hidden;position:relative;border:1px solid var(--line)}
.field--name-field-gallery .field__item img{width:100%;height:100%;object-fit:cover;transition:transform .35s;border-radius:0}
.field--name-field-gallery .field__item a::after{content:"";position:absolute;inset:0;background:rgba(19,41,75,0);transition:background .25s}
.field--name-field-gallery .field__item a:hover img{transform:scale(1.06)}
.field--name-field-gallery .field__item a:hover::after{background:rgba(19,41,75,.14)}
@media(max-width:900px){.field--name-field-gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.field--name-field-gallery{grid-template-columns:repeat(2,1fr)}}

/* нативный блок «Галерея» (Gutenberg) — раскладку оставляем core, добавляем скругление/рамку/ховer под стиль темы */
.content .wp-block-gallery{margin:26px 0 8px}
.content .wp-block-gallery figure.wp-block-image{border:1px solid var(--line);border-radius:9px;overflow:hidden}
.content .wp-block-gallery figure.wp-block-image img{transition:transform .35s}
.content .wp-block-gallery figure.wp-block-image:hover img{transform:scale(1.05)}

/* ============================ ЛЕНТА СОБЫТИЙ (архив /news) ============================ */
.feed{display:flex;flex-direction:column;margin-top:24px}
.feed-item{display:grid;grid-template-columns:200px 1fr;gap:22px;padding:22px 0;border-bottom:1px solid var(--line);align-items:start}
.feed-item:first-child{padding-top:0}
.feed-thumb{aspect-ratio:16/11;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#eef2f6;display:block}
.feed-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.feed-item:hover .feed-thumb img{transform:scale(1.05)}
.feed-nothumb{background:var(--mist)}
.feed-date{color:var(--red);font-weight:700;font-size:12.5px;margin:0 0 7px}
.feed-item h3{margin:0 0 9px;font-size:20px;line-height:1.28;font-family:var(--serif)}
.feed-item h3 a{color:var(--navy)}.feed-item h3 a:hover{color:var(--red)}
.feed-item p{margin:0 0 10px;color:#4a5466;font-size:14.5px}
.feed-more{font-weight:700;color:var(--red);font-size:14px}
@media(max-width:560px){.feed-item{grid-template-columns:1fr}}

/* пагинация (bootstrap_barrio .pagination → новый вид) */
.pager{margin:34px 0 4px}
.pager .pagination{display:flex;justify-content:center;gap:7px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.pager .page-item .page-link,.pager .page-item span{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:8px;font-weight:700;font-size:14px;color:var(--link);background:#fff;padding:0 8px}
.pager .page-item a.page-link:hover{border-color:var(--red);color:var(--red)}
.pager .page-item.active .page-link{background:var(--navy);border-color:var(--navy);color:#fff}
/* WP-нативная пагинация (the_posts_pagination) — тот же вид */
.pagination .nav-links{display:flex;justify-content:center;gap:7px;flex-wrap:wrap}
.pagination .page-numbers{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:8px;font-weight:700;font-size:14px;color:var(--link);background:#fff;padding:0 8px}
.pagination a.page-numbers:hover{border-color:var(--red);color:var(--red)}
.pagination .page-numbers.current{background:var(--navy);border-color:var(--navy);color:#fff}

/* ============================ САЙДБАР «ПАРТНЁРЫ» ============================ */
.side .side-head{font-family:var(--serif);font-size:18px;color:var(--navy);margin:0 0 16px;padding-bottom:10px;position:relative}
.side .side-head::after{content:"";position:absolute;left:0;bottom:0;width:42px;height:3px;background:var(--red);border-radius:2px}
.side .plogo{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px;margin-bottom:14px;
  display:flex;align-items:center;justify-content:center;height:120px;transition:box-shadow .2s,transform .2s}
.side .plogo:hover{box-shadow:0 10px 22px rgba(20,40,80,.12);transform:translateY(-2px)}
.side .plogo img{max-height:84px;width:auto;object-fit:contain}

/* ============================ ФУТЕР ============================ */
.foot{border-top:4px solid var(--red);background:#eef2f6;color:#55606f;font-size:13.5px}
.foot .in{padding:26px 28px 28px;text-align:center}
.foot a{color:var(--link)}
.foot__copy b{color:var(--navy)}
.foot__copy a{display:inline-block}
.foot__made{margin-top:16px;padding-top:16px;border-top:1px solid #dde4ec;display:flex;justify-content:center}
.foot__made a{display:inline-flex;opacity:.88;transition:opacity .15s}
.foot__made a:hover{opacity:1}
.inrise-logo{height:30px;width:auto;display:block}

/* ============================ off-canvas (мобильное меню) ============================ */
.kg-offcanvas-backdrop{position:fixed;inset:0;background:rgba(13,24,43,.5);z-index:998;border:0}
.kg-offcanvas{position:fixed;top:0;left:0;width:300px;max-width:86%;height:100%;background:#fff;z-index:999;
  transform:translateX(-100%);transition:transform .28s ease;overflow-y:auto;box-shadow:6px 0 30px rgba(0,0,0,.25);padding:18px 0}
html.kg-menu-open .kg-offcanvas{transform:none}
.kg-offcanvas ul{list-style:none;margin:0;padding:0}
.kg-offcanvas a{display:block;padding:12px 22px;color:var(--navy);font-weight:600;border-bottom:1px solid #eef2f6}
.kg-offcanvas a:hover{background:var(--mist);color:var(--red)}
.kg-offcanvas .sub-menu{display:none;background:#f7fafd}
.kg-offcanvas .sub-menu a{padding-left:36px;font-weight:500;font-size:14px}
.kg-offcanvas .is-expanded>.sub-menu{display:block}
.kg-offcanvas .menu-item-has-children{position:relative}
.kg-offcanvas-caret{position:absolute;right:8px;top:6px;width:40px;height:34px;border:0;background:transparent;cursor:pointer}
.kg-offcanvas-caret::before{content:"";position:absolute;top:12px;left:14px;width:9px;height:9px;border-right:2px solid #7c8798;border-bottom:2px solid #7c8798;transform:rotate(45deg);transition:transform .2s}
.kg-offcanvas .is-expanded>.kg-offcanvas-caret::before{transform:rotate(-135deg);top:15px}

/* ============================ адаптив ============================ */
@media(max-width:900px){
  .events-split{grid-template-columns:1fr;gap:30px}
  .address .in{grid-template-columns:180px 1fr;gap:24px}
}
@media(max-width:880px){
  .layout{grid-template-columns:1fr;gap:30px}
  .side{border-top:1px solid var(--line);padding-top:24px}
  .side .plogos{display:flex;flex-wrap:wrap;gap:14px}
  .side .plogo{flex:1 1 180px;margin-bottom:0}
}
/* мобильное меню: прячем горизонтальную полосу, показываем гамбургер */
@media(max-width:992px){
  .nav__inner>ul{display:none}
  .nav__inner{justify-content:flex-end;padding:0 10px}
  .kg-burger{display:inline-flex;align-items:center;gap:9px;background:transparent;border:0;cursor:pointer;
    padding:11px 16px;color:var(--link);font-weight:700;font-size:14px}
  .kg-burger .bars{position:relative;width:22px;height:2px;background:var(--link);display:inline-block}
  .kg-burger .bars::before,.kg-burger .bars::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--link)}
  .kg-burger .bars::before{top:-7px}.kg-burger .bars::after{top:7px}
}
@media(max-width:640px){
  .header{height:158px}
  .header__emblem{left:50%;top:14px;transform:translateX(-50%)}.header__emblem img{height:62px}
  .brand{left:8px;right:8px;width:auto;top:auto;bottom:12px;transform:none;padding:0;white-space:normal}
  .brand__sub{font-size:10.5px}
  .brand__name{font-size:12px;line-height:1.32;overflow-wrap:break-word;word-break:break-word}
  .brand__name br{display:none}
  .nrow{grid-template-columns:1fr}
  .nrow__media{aspect-ratio:16/9}
  .address .in{grid-template-columns:1fr;justify-items:center;text-align:center}
  .address__photo{max-width:200px}
  .address__quote{padding-left:0}.address__quote::before{display:none}
  .sec-head{flex-wrap:wrap;gap:6px}
  .sec-head h2{font-size:24px}
  .logo{min-width:0;flex:1 1 140px}
  .content h1{font-size:26px}
  .wrap{padding:0 16px}
  .header__inner,.nav__inner{padding-left:16px;padding-right:16px}
}
