:root {
  --primary: #7266b3;
  --primary-dark: #432e80;
  --secondary: #ac0b70;
  --accent: #84b631;
  --bg: #ffffff;
  --surface: #f5f3fb;
  --surface-alt: #f5f3fb;
  --text: #1f1d36;
  --heading: #7266b3;
  --muted: #6b6b7a;
  --border: #e7e4f5;
  --radius: 5px;
  --font-heading: Roboto, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  --font-body: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
  font-size: 16px;
}
a{color: var(--primary); text-decoration:none}
a:hover{color: var(--accent); text-decoration:underline}
.container{max-width: var(--content-max-width, 1280px); margin: 0 auto; padding: 0 24px}
.header{
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky; top:0; z-index:10;
}
.header .inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{font-weight:700; color: var(--heading); font-size: 18px; font-family: var(--font-heading)}
.nav{display:flex; gap:6px; flex-wrap: wrap}
.nav a{padding:8px 12px; border-radius: var(--radius); color: var(--text); font-size: 14px}
.nav a:hover{background: var(--surface-alt); text-decoration:none}
.nav a.active{background: var(--primary); color:#fff}
/* Старый .hero удалён — вместо него используется .site-hero (см. ниже) */
main.page{padding: 40px 0 64px}
h1,h2,h3,h4{font-family: var(--font-heading); color: var(--heading); line-height: 1.25; margin: 22px 0 12px}
h1{font-size: 30px}
h2{font-size: 24px}
h3{font-size: 20px}
p{margin: 12px 0}
.widget-heading h1,.widget-heading h2,.widget-heading h3{margin-top: 28px}
.widget-text{font-size: 16px}
/* Волна 12.1.8: span и li наследуют от своего абзаца (с data-style), 
 * не от корневого .widget-text. p/div убраны из селектора, чтобы
 * не перебивать [data-style="..."] темы (специфичность 0,1,1 выше чем 0,1,0) */
.widget-text span,.widget-text li{font-family: inherit; font-weight: inherit; line-height: inherit}
.widget-html img{max-width:100%; height:auto; border-radius: var(--radius)}
.widget-html ul,.widget-html ol{padding-left: 24px}
.widget-html a{color: var(--primary)}
.widget-image figure{margin: 20px 0; text-align:center}
.widget-image img{max-width:100%; height:auto; border-radius: var(--radius); box-shadow: 0 4px 14px rgba(0,0,0,0.08)}
.widget-image figcaption{color: var(--muted); font-size: 14px; margin-top: 8px}
.widget-gallery .grid{display:grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap:12px; margin: 16px 0}
.widget-gallery .grid a{display:block; overflow:hidden; border-radius: var(--radius); aspect-ratio: 4/3; background: var(--surface-alt)}
.widget-gallery .grid img{width:100%; height:100%; object-fit:cover; transition: transform .2s}
.widget-gallery .grid a:hover img{transform: scale(1.04)}
.widget-video figure{margin: 20px 0; text-align:center}
.widget-video .video-frame{position:relative; width:100%; border-radius: var(--radius); overflow:hidden; background:#000; box-shadow: 0 4px 14px rgba(0,0,0,0.08)}
.widget-video .video-frame iframe{position:absolute; inset:0; width:100%; height:100%; border:0}
.widget-video figcaption{color: var(--muted); font-size: 14px; margin-top: 8px}
.widget-button{margin: 16px 0}
.btn{display:inline-block; padding: 10px 20px; border-radius: var(--radius); font-weight: 500; font-size: 14px; cursor:pointer; transition: all .15s}
.btn.primary{background: var(--primary); color:#fff}
.btn.primary:hover{background: var(--primary-dark); text-decoration:none}
.btn.secondary{background: var(--surface-alt); color: var(--heading)}
.btn.secondary:hover{background: var(--border); text-decoration:none}
.btn.ghost{background:transparent; color: var(--primary); border:1px solid var(--primary)}
.btn.ghost:hover{background: var(--primary); color:#fff; text-decoration:none}
.widget-divider{border:0; border-top:1px solid var(--border); margin: 28px 0}
.widget-menu-h{display:flex; flex-wrap:wrap; gap:8px; padding:12px 0; margin:12px 0}
.widget-menu-h.align-left{justify-content:flex-start}
.widget-menu-h.align-center{justify-content:center}
.widget-menu-h.align-right{justify-content:flex-end}
.widget-menu-h.align-spread{justify-content:space-between}
.widget-menu-h a{padding:8px 14px; border-radius: var(--radius); color: var(--text); font-size: 14px; transition: all .15s}
.widget-menu-h.style-flat a:hover{background: var(--surface-alt); text-decoration:none}
/* Волна 12.1.8: !important чтобы фон пилюль не стирался inline-стилями темы */
.widget-menu-h.style-pills a{background: var(--surface-alt) !important; padding: 8px 14px !important; border-radius: var(--radius) !important}
.widget-menu-h.style-pills a:hover{background: var(--primary) !important; color:#fff !important; text-decoration:none}
.widget-menu-h.style-underline a{border-radius:0 !important; border-bottom: 2px solid transparent; padding: 8px 6px !important}
.widget-menu-h.style-underline a:hover{border-bottom-color: var(--primary); text-decoration:none}
.widget-menu-v{display:inline-flex; flex-direction:column; gap:4px; padding:12px 16px; background: var(--surface-alt); border-radius: var(--radius); min-width: 200px; margin: 12px 0}
.widget-menu-v .menu-title{font-weight:600; font-size:13px; color: var(--muted); margin-bottom:6px; text-transform:uppercase; letter-spacing:.5px}
.widget-menu-v a{padding:8px 12px; border-radius: 6px; color: var(--text); font-size: 14px; transition: all .15s}
.widget-menu-v a:hover{background: var(--surface); color: var(--primary); text-decoration:none}
.widget-columns{display:grid; gap: 24px; margin: 20px 0; align-items: start}
.widget-columns > .col{min-width:0}
@media (max-width: 768px){ .widget-columns{grid-template-columns: 1fr !important} }
.widget-form{margin: 20px 0; padding: 20px 22px; background: var(--surface); border:1px solid var(--border); border-radius: var(--radius)}
.widget-form h3.form-title{margin: 0 0 14px; font-size: 20px}
.widget-form .form-field{display:flex; flex-direction:column; gap:6px; margin: 0 0 14px}
.widget-form .form-field label{font-size: 14px; color: var(--heading); font-weight: 500}
.widget-form .form-field .req{color: #d22; margin-left: 3px}
.widget-form input[type=text],.widget-form input[type=email],.widget-form input[type=tel],.widget-form textarea,.widget-form select{
  width:100%; padding: 9px 12px; border:1px solid var(--border); border-radius: var(--radius); font: inherit;
  background: var(--bg); color: var(--text);
}
.widget-form input:focus,.widget-form textarea:focus,.widget-form select:focus{outline:none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(124,92,255,.15)}
.widget-form textarea{min-height: 90px; resize: vertical}
.widget-form .form-field.checkbox{flex-direction:row; align-items:center; gap:8px}
.widget-form .form-field.checkbox label{font-weight: 400}
.widget-form .hp{position:absolute; left:-9999px; top:-9999px; opacity:0; pointer-events:none}
.widget-form .form-submit{margin-top: 6px}
.widget-form .form-status{margin-top: 12px; padding: 10px 12px; border-radius: var(--radius); font-size: 14px; display:none}
.widget-form .form-status.success{display:block; background: #e8f7ec; color: #195a2b; border:1px solid #b7e4c1}
.widget-form .form-status.error{display:block; background: #fdecec; color: #841919; border:1px solid #f3bcbc}
.footer{padding: 28px 0; color: var(--muted); background: var(--surface); border-top: 1px solid var(--border); font-size: 14px; margin-top: 48px}
.footer .inner{display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px}
.home-grid{display:grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap:16px; margin: 24px 0}
.home-card{display:block; padding: 20px 22px; background: var(--surface); border:1px solid var(--border); border-radius: var(--radius); color: var(--heading); transition: all .15s}
.home-card:hover{border-color: var(--primary); box-shadow: 0 6px 18px rgba(0,0,0,.06); text-decoration:none; transform: translateY(-1px)}
.home-card h3{margin:0 0 6px; font-size: 18px}
.home-card p{margin:0; color: var(--muted); font-size: 14px}
@media (max-width: 640px){ main.page{padding: 24px 0 36px} }
/* Волна 8.7: контейнер виджетов с переменным gap */
.widgets-list{display:flex; flex-direction:column}
/* 9.4: сбрасываем margin виджетов, чтобы gap доминировал */
.widgets-list > *{margin:0 !important}
/* Волна 16.3: сброс верхнего/нижнего margin у ПЕРВОГО/ПОСЛЕДНЕГО элемента
   внутри каждого виджета — иначе внутренние margin заголовков (h1 22px,
   .widget-heading h1 28px), фигур изображений (figure 20px) и т. п. складываются
   с внешним gap и суммарный отступ становится больше заданного widget_gap_px.
   Волна 16.3.1: явно перечисляем типовые элементы (p, h1..h6, figure, ul, ol,
   blockquote, hr, pre) — иначе user-agent margins и кастомные правила темы
   с !important побеждают общий :first-child / :last-child селектор. */
.widgets-list > * > :first-child{margin-top:0 !important}
.widgets-list > * > :last-child{margin-bottom:0 !important}
.widgets-list > .widget > p:first-child,
.widgets-list > .widget > h1:first-child,
.widgets-list > .widget > h2:first-child,
.widgets-list > .widget > h3:first-child,
.widgets-list > .widget > h4:first-child,
.widgets-list > .widget > h5:first-child,
.widgets-list > .widget > h6:first-child,
.widgets-list > .widget > figure:first-child,
.widgets-list > .widget > ul:first-child,
.widgets-list > .widget > ol:first-child,
.widgets-list > .widget > blockquote:first-child,
.widgets-list > .widget > pre:first-child,
.widgets-list > .widget > hr:first-child{margin-top:0 !important}
.widgets-list > .widget > p:last-child,
.widgets-list > .widget > h1:last-child,
.widgets-list > .widget > h2:last-child,
.widgets-list > .widget > h3:last-child,
.widgets-list > .widget > h4:last-child,
.widgets-list > .widget > h5:last-child,
.widgets-list > .widget > h6:last-child,
.widgets-list > .widget > figure:last-child,
.widgets-list > .widget > ul:last-child,
.widgets-list > .widget > ol:last-child,
.widgets-list > .widget > blockquote:last-child,
.widgets-list > .widget > pre:last-child,
.widgets-list > .widget > hr:last-child{margin-bottom:0 !important}
/* Сам виджет тоже не должен иметь верхнего/нижнего margin, иначе они складываются с gap. */
.widgets-list > .widget,
.widgets-list > nav.widget,
.widgets-list > hr.widget{margin-top:0 !important; margin-bottom:0 !important}

/* ======= Волна 4.1: шапка ======= */
.top-meta-bar{
  background: var(--surface-alt);
  border-bottom: 1px solid var(--border);
  padding: 6px 0;
  font-size: 13px;
}
.top-meta-bar__inner{
  max-width: var(--content-max-width, 1280px); margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between;
}
/* Волна 12.1.1: название сайта в шапке без жирного начертания по умолчанию
   (ранее .top-meta-bar__name принуждал жирный, что перекрывало font_weight темы) */
.top-meta-bar__name{font-weight: inherit; color: inherit}
.top-meta-bar__meta{color: inherit; opacity: 0.9}

/* Волна 12.1.9: тонкая полоса в футере (site_name + meta) */
.footer__top-bar{
  background: transparent;
  border-bottom: 0;
  border-top: 1px solid var(--border);
  padding: 10px 0;
  margin: 0 0 16px 0;
  font-size: 13px;
}
.footer__top-bar .top-meta-bar__inner{
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

/* Волна 12.1.9.8: автоменю НАД header.
   Геометрия (gap, padding, radius, border_width) — из text_styles.menu
   через --menu-* (см. _build_menu_css_vars).
   Фоны пунктов (pills/flat) — из color_mapping через
   --menu-bg / --menu-bg-hover / --menu-bg-active (см. _build_color_css).
   Цвет текста — выворотка по WCAG-яркости фона
   (--menu-color / --menu-color-hover / --menu-color-active).
   Сам <nav> — прозрачный (наследует фон плашки под ним).
   Внутренние классы sam-* — не пересекаются с site-nav-* и widget-menu-h. */
.site-auto-menu{
  background: transparent;
  border-bottom: 1px solid var(--border);
  margin: 0;
  padding: 8px 0;
  position: relative;
  z-index: 20;
}
.site-auto-menu__inner{
  max-width: var(--content-max-width, 1280px);
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: var(--menu-gap);
}
/* Волна 13.1: бургер — без подложки, цвет наследуется от темы.
   Светлая тема: var(--primary). Тёмная тема (header на тёмном фоне):
   переопределяется через .site-auto-menu[data-theme-mode="dark"] ниже. */
.site-auto-menu .sam-burger{
  display: none;
  background: transparent;
  border: none;
  padding: 6px 8px;
  cursor: pointer;
  color: var(--primary);
  line-height: 0;
}
.site-auto-menu[data-theme-mode="dark"] .sam-burger{
  color: #ffffff;
}
.site-auto-menu .sam-burger svg{
  width: 28px;
  height: 28px;
  stroke: currentColor;
}
.site-auto-menu .sam-overlay{display: none}
.site-auto-menu .sam-close{display: none}
.site-auto-menu .sam-panel{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  background: transparent;
  position: static;
  box-shadow: none;
  gap: var(--menu-gap);
}
/* Общие стили пункта — a и span. Всё через переменные. */
.site-auto-menu .sam-panel > a,
.site-auto-menu .sam-panel > span{
  display: inline-block;
  width: auto;
  text-align: left;
  text-decoration: none;
  border: 0;
  transition: background .15s, color .15s, border-color .15s;
  padding: var(--menu-padding-y) var(--menu-padding-x);
}
.site-auto-menu .sam-panel > a{ cursor: pointer; }
.site-auto-menu .sam-panel > span.site-nav-current{ cursor: default; }

/* === PILLS: фон из mapping + радиус из text_styles + выворотка текста.
   !important — чтобы перебить inline style="color:..." от resolve_text_style. */
.site-auto-menu.style-pills .sam-panel > a,
.site-auto-menu.style-pills .sam-panel > span{
  border-radius: var(--menu-radius);
  background: var(--menu-bg) !important;
  color: var(--menu-color) !important;
}
.site-auto-menu.style-pills .sam-panel > a:hover{
  background: var(--menu-bg-hover) !important;
  color: var(--menu-color-hover) !important;
}
.site-auto-menu.style-pills .sam-panel > .site-nav-current{
  background: var(--menu-bg-active) !important;
  color: var(--menu-color-active) !important;
}

/* === FLAT: фон из mapping (без скругления) + выворотка текста. */
.site-auto-menu.style-flat .sam-panel > a,
.site-auto-menu.style-flat .sam-panel > span,
.site-auto-menu:not(.style-pills):not(.style-underline) .sam-panel > a,
.site-auto-menu:not(.style-pills):not(.style-underline) .sam-panel > span{
  background: var(--menu-bg) !important;
  color: var(--menu-color) !important;
}
.site-auto-menu.style-flat .sam-panel > a:hover,
.site-auto-menu:not(.style-pills):not(.style-underline) .sam-panel > a:hover{
  background: var(--menu-bg-hover) !important;
  color: var(--menu-color-hover) !important;
}
.site-auto-menu.style-flat .sam-panel > .site-nav-current,
.site-auto-menu:not(.style-pills):not(.style-underline) .sam-panel > .site-nav-current{
  background: var(--menu-bg-active) !important;
  color: var(--menu-color-active) !important;
}

/* === UNDERLINE: фона НЕТ (прозрачный), текст из .style-menu,
   линия цвета currentColor и толщины --menu-border-width. */
.site-auto-menu.style-underline .sam-panel > a,
.site-auto-menu.style-underline .sam-panel > span{
  border-radius: 0;
  background: transparent !important;
  border-bottom: var(--menu-border-width) solid transparent;
}
.site-auto-menu.style-underline .sam-panel > a:hover,
.site-auto-menu.style-underline .sam-panel > .site-nav-current{
  border-bottom-color: currentColor;
}
/* Волна 13.1: мобильный режим для планшета-портрета (≤1023px), не только для телефона. */
@media (max-width: 1023px){
  .site-auto-menu__inner{justify-content: flex-start !important}
  .site-auto-menu .sam-burger{display: inline-flex !important; align-items: center; justify-content: center}
  .site-auto-menu .sam-panel{
    display: none !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important; bottom: 0 !important;
    width: 80% !important;
    max-width: 320px !important;
    background: var(--surface) !important;
    z-index: 1001 !important;
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 48px 16px 16px !important;
    box-shadow: 2px 0 16px rgba(0,0,0,0.15) !important;
    overflow-y: auto !important;
  }
  .site-auto-menu .sam-overlay{
    display: none;
    position: fixed; top:0; left:0; right:0; bottom:0;
    background: rgba(0,0,0,0.35); z-index: 1000;
  }
  .site-auto-menu .sam-close{
    display: block;
    position: absolute; top: 8px; right: 12px;
    background: transparent; border: 0;
    font-size: 28px; line-height: 1;
    cursor: pointer; color: var(--text);
  }
  .site-auto-menu.open .sam-panel{display: flex !important}
  .site-auto-menu.open .sam-overlay{display: block !important}
}

.site-hero{
  position: relative;
  background-size: cover;
  background-position: center;
  padding: 48px 24px;
  display: flex;
  align-items: center;
}
.site-hero--plain{background: linear-gradient(135deg, var(--primary), var(--secondary))}
.site-hero__overlay{
  position: absolute; inset: 0;
  background: #000;
  pointer-events: none;
}
.site-hero__inner{
  position: relative;
  max-width: var(--content-max-width, 1280px); margin: 0 auto;
  width: 100%;
}
/* Волна 12.1.2: стиль H1 в hero берётся целиком из темы (.style-heading1).
   Здесь — только технические margin. Цвет и тень добавляются inline
   сервером, когда hero поверх картинки. */
/* Wave 16.4 (C1): базовый вариант — всегда центр (жёстко) */
.site-hero__title{ margin: 0; text-align: center; }
.site-hero--plain .site-hero__title{ color: #fff; }

/* .site-nav убран в Волне 6.1 — используйте виджет меню */

.breadcrumbs{
  max-width: var(--content-max-width, 1280px); margin: 0 auto; padding: 12px 24px;
  font-size: 14px; color: var(--muted);
  display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
}
.breadcrumbs a{color: var(--primary)}
.breadcrumbs a:hover{text-decoration: underline}
.breadcrumbs__sep{color: var(--muted); margin: 0 2px}
.breadcrumbs__current{color: var(--heading)}

/* Логотип-виджет */
.widget-logo{display:inline-flex; align-items:center; justify-content:center; flex-shrink:0}
.widget-logo img{display:block; width:100%; height:100%; object-fit:cover}

/* Code snippet */
pre.code-snippet{
  background: var(--surface-alt);
  padding: 16px 18px;
  border-radius: var(--radius);
  overflow: auto;
  font-size: 13px;
  line-height: 1.6;
  margin: 16px 0;
  border: 1px solid var(--border);
}
pre.code-snippet code{font-family: 'JetBrains Mono', 'Fira Code', 'Courier New', monospace}
.code-snippet-wrap{position:relative; margin: 16px 0}
.code-snippet-copy{
  position:absolute; top:8px; right:8px;
  padding:6px; font-size:12px; border-radius:6px;
  background:var(--surface); border:1px solid var(--border);
  cursor:pointer; color:var(--text); transition:all .15s;
  display:inline-flex; align-items:center; justify-content:center; line-height:1;
}
.code-snippet-copy:hover{background:var(--primary); color:#fff; border-color:var(--primary)}

/* Tabs виджет. Волна 12.1.9.9:
   тема приходит через .style-tabs на самой кнопке (аналогично меню).
   .tabs-btn здесь даёт только геометрию и состояния — без color/font-size/font-weight,
   чтобы не перебивать тему. Для сброса user-agent стилей <button> используем font:inherit. */
.widget-tabs{margin: 20px 0}
.tabs-list{display:flex; gap:0; border-bottom:2px solid var(--border); margin-bottom:0; padding:0; list-style:none}
.tabs-list--pills{gap:6px; border-bottom:none; margin-bottom:8px}
.tabs-btn{
  padding: 10px 20px; cursor:pointer;
  background:transparent; border:none;
  border-bottom: 2px solid transparent; margin-bottom:-2px;
  transition: all .15s; font:inherit; color:inherit;
}
.tabs-btn:hover{opacity:.8}
.tabs-btn.is-active{border-bottom-color:var(--primary)}
.tabs-list--pills .tabs-btn{border-radius:var(--radius); border:1px solid var(--border); margin-bottom:0}
.tabs-list--pills .tabs-btn.is-active{background:var(--primary); color:#fff !important; border-color:var(--primary)}
.tab-panels .tab-panel{display:none; padding:16px 0}
.tab-panels .tab-panel.is-active{display:block}

/* Embed виджет */
.widget-embed{margin: 16px 0}
.widget-embed iframe{border:0; width:100%; display:block; border-radius:var(--radius)}

/* ======= Волна 12.1.1: 2-колоночный виджет НАД hero-фоном ======= */
.site-title-full { display: inline; }
.site-title-short { display: none; }
.site-meta { display: inline; }
@media (max-width: 1023px) {
  .site-title-full { display: none; }
  .site-title-short { display: inline; }
  .site-meta { display: none; }
}
/* Волна 12.1.1: 2 колонки внутри hero (лого узкая + заголовок широкая) */
.site-header-columns { display: flex; gap: 24px; align-items: center; }
.site-header-col-narrow { flex: 0 0 auto; min-width: 80px; }
.site-header-col-wide { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
/* Wave 16.4 (C1): жёсткое выравнивание заголовка шапки по центру широкой колонки */
.site-header-col-wide .site-hero__title { margin: 0; text-align: center !important; }
.site-header-col-wide .site-title-full,
.site-header-col-wide .site-title-short,
.site-header-col-wide .site-meta { text-align: left; width: 100%; }
@media (max-width: 767px) {
  .site-header-columns { flex-direction: column; align-items: stretch; gap: 12px; }
  .site-header-col-narrow { width: 100%; text-align: center; }
  .site-header-col-wide { align-items: center; }
  .site-header-col-wide .site-title-full,
  .site-header-col-wide .site-title-short,
  .site-header-col-wide .site-meta { text-align: center; }
}

/* ======= Волна 12.2: адаптивное мобильное меню (гамбургер) ======= */
/* Десктоп (≥1024): меню развёрнуто, гамбургер скрыт */
.site-nav-burger, .site-nav-overlay, .site-nav-close { display: none; }
.site-nav-panel { display: flex; gap: 12px; position: static; background: transparent; box-shadow: none; padding: 0; }
/* Ссылка логотипа без декораций */
.site-logo-link { display: inline-flex; text-decoration: none; flex-shrink: 0; }
.site-logo-link:hover { text-decoration: none; }
/* Позиционирование шапки */
.site-header { position: relative; }

/* Планшет + горизонтальный телефон (568-1023): боковая панель справа */
@media (max-width: 1023px) and (min-width: 568px) {
  /* Волна 12.1.2: гамбургер — fixed в правом верхнем углу, белый,
     с тенью для читаемости на любом фоне (hero/картинка). */
  .site-nav-burger { display: inline-flex; position: fixed; right: 16px; top: 72px; z-index: 1001; background: rgba(0,0,0,0.25); border: none; cursor: pointer; padding: 10px; border-radius: 8px; color: #ffffff; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.35)); }
  .site-nav-burger svg { width: 28px; height: 28px; }
  .site-nav-panel {
    position: fixed; top: 0; right: 0; bottom: 0; width: 320px; max-width: 80vw;
    background: #fff; box-shadow: -4px 0 16px rgba(0,0,0,0.12); padding: 56px 20px 20px;
    flex-direction: column; align-items: stretch; gap: 8px;
    transform: translateX(100%); transition: transform 0.25s ease;
    z-index: 1002;
  }
  .site-nav.open .site-nav-panel { transform: translateX(0); }
  .site-nav.open .site-nav-overlay { display: block; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 1001; }
  .site-nav-close { display: inline-flex; position: absolute; right: 12px; top: 12px; background: none; border: none; font-size: 28px; cursor: pointer; padding: 4px 12px; }
}

/* Вертикальный телефон (<568): раскрытие вниз под шапкой */
@media (max-width: 567px) {
  /* Волна 12.1.2: та же позиция, что и на планшете (fixed на экране). */
  .site-nav-burger { display: inline-flex; position: fixed; right: 12px; top: 60px; z-index: 1001; background: rgba(0,0,0,0.25); border: none; cursor: pointer; padding: 10px; border-radius: 8px; color: #ffffff; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.35)); }
  .site-nav-burger svg { width: 28px; height: 28px; }
  .site-nav-panel {
    position: absolute; top: 100%; left: 0; right: 0;
    background: #fff; box-shadow: 0 4px 16px rgba(0,0,0,0.12); padding: 16px;
    flex-direction: column; align-items: stretch; gap: 8px;
    max-height: 0; overflow: hidden; transition: max-height 0.3s ease;
    z-index: 1001;
  }
  .site-nav.open .site-nav-panel { max-height: 80vh; overflow: auto; }
  .site-nav-close { display: none; }
}

/* Меню-пункты внутри панели на мобильном — вертикальные */
@media (max-width: 1023px) {
  .site-nav-panel > * { display: block; width: 100%; text-align: left; }
  .site-nav-panel a, .site-nav-panel button { padding: 12px 8px; border-radius: 6px; }
  .site-nav-panel a:hover { background: #f3f4f6; }
}

/* ======= Волна 12.3: колонки → стек на вертикальных экранах ======= */
@media (max-width: 767px) {
  .widget-columns {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
  }
  .widget-columns > * { width: 100% !important; }
  .site-header { flex-direction: column; align-items: stretch; }
  .site-header-row { flex-direction: column; gap: 12px; }
}