/* ============================================================
   VINOACCS · Design System · CHROME
   Header + Footer — общие компоненты для всех страниц сайта.
   Подключается ПОСЛЕ system.css, ПЕРЕД page-стилями.

   Зависит от: tokens.css (переменные)
   Структура файла:
     1. TOPBAR         — верхняя utility-полоса (RU/EN, контакты)
     2. HEADER         — лого по центру (desktop)
     3. NAV            — каталог-кнопка + категории
     4. MEGA PANEL     — выпадающее меню каталога
     5. SEARCH PANEL   — выезжающий поиск
     6. M-HEADER       — мобильная/планшетная шапка (бургер + лого + иконки)
     7. M-DRAWER       — выезжающее мобильное меню
     8. CHROME @media  — desktop/mobile переключение
     9. FOOTER         — тёмный остров + bottom-bar
============================================================ */


/* ════════════════════════════════════════════════════
   1. TOPBAR — utility bar with secondary nav + actions
════════════════════════════════════════════════════ */

.topbar{
  background:var(--bg);
  font-size:12px; color:var(--text-3);
  border-bottom:1px solid var(--border);
}
.topbar-inner{
  max-width:var(--max); margin:0 auto;
  padding:10px var(--side);
  display:flex; align-items:center; gap:24px;
}
.topbar-nav{ display:flex; gap:26px; }
.topbar-nav a{
  position:relative;
  color:var(--text-2);
  font-size:13px;
  padding:2px 0;
  transition:color .3s var(--ease-soft);
}
.topbar-nav a::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-1px;
  height:1px; background:var(--accent);
  transform:scaleX(0); transform-origin:left center;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.topbar-nav a:hover{ color:var(--accent); }
.topbar-nav a:hover::after{ transform:scaleX(1); }
.topbar-spacer{ flex:1; }
.topbar-lang{
  display:inline-flex; align-items:center;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.05em;
  background:var(--bg-warm);
  border-radius:var(--r-pill);
  padding:3px;
  gap:0;
  position:relative;
}
.topbar-lang::before{
  content:""; position:absolute;
  top:3px; bottom:3px;
  width:calc(50% - 3px);
  background:var(--bg);
  border-radius:var(--r-pill);
  box-shadow:0 1px 2px rgba(40,35,30,0.06);
  transition:transform .42s var(--ease-soft);
  z-index:0;
}
.topbar-lang[data-active="ru"]::before{ transform:translateX(0); left:3px; }
.topbar-lang[data-active="en"]::before{ transform:translateX(100%); left:3px; }
.topbar-lang a{
  position:relative; z-index:1;
  color:var(--text-3);
  padding:4px 10px;
  border-radius:var(--r-pill);
  transition:color .35s var(--ease-soft);
  line-height:1;
}
.topbar-lang a.is-active{ color:var(--text-2); font-weight:500; background:transparent; }
.topbar-lang a:not(.is-active){ color:var(--text-2); }
.topbar-lang a:hover{ color:var(--accent); }
.topbar-lang .sep{ display:none; }

.topbar-actions{
  display:flex; align-items:center; gap:10px;
  padding-left:14px; margin-left:0;
  border-left:none;
}
.topbar-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px;
  color:var(--text-2);
  position:relative;
  transition:color var(--dur-sm);
}
.topbar-icon:hover{ color:var(--accent); }
.topbar-icon svg{
  width:20px; height:20px;
  stroke-width:1.25;
  transition:transform .4s var(--ease-soft);
}
.topbar-icon:hover svg{ transform:translateY(-1px); }
.topbar-icon .badge{
  position:absolute; top:2px; right:0;
  min-width:14px; height:14px; padding:0 3px 0 3px;
  border-radius:8px;
  background:var(--accent); color:#fff;
  font-family:var(--font-mono);
  font-size:9px; font-weight:500; line-height:1;
  display:flex; align-items:center; justify-content:center;
  box-sizing:border-box;
  border:1.5px solid var(--bg);
  font-feature-settings:"tnum" 1;
  transform:translate(50%, -50%);
  transform-origin:center;
}
.topbar-icon .badge::before{
  content:""; display:inline-block; height:9px; width:0;
}
.topbar-icon[data-count="0"] .badge{ display:none; }


/* ════════════════════════════════════════════════════
   2. HEADER — только логотип по центру (desktop)
════════════════════════════════════════════════════ */

.header{
  background:var(--bg);
}
.header-inner{
  max-width:var(--max); margin:0 auto;
  padding:24px var(--side) 14px;
  display:flex; align-items:center; justify-content:center;
}
.logo{
  font-family:var(--font-sans); font-weight:500;
  letter-spacing:var(--ls-logo); font-size:28px;
  color:var(--text-2); text-align:center;
}


/* ════════════════════════════════════════════════════
   3. NAV — каталог-кнопка + категории
════════════════════════════════════════════════════ */

.nav{
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:relative;
  z-index:35;
  padding:0 var(--side);
}
.nav-inner{
  max-width:980px; margin:0 auto;
  padding:0;
  display:flex; align-items:stretch;
}
.nav-catalog{
  display:inline-flex; align-items:center; gap:10px;
  background:var(--accent); color:#fff;
  height:42px; padding:0 22px;
  font-family:var(--font-sans); font-size:14px; font-weight:500;
  letter-spacing:0;
  border:none;
  border-radius:var(--r-pill);
  margin:10px 28px 10px 0;
  cursor:pointer;
  transition:background var(--dur-sm);
}
.nav-catalog:hover,
.nav-catalog.is-open{ background:var(--accent-active); }
.nav-catalog svg{ width:12px; height:12px; transition:transform var(--dur-sm) var(--ease-apple); }
.nav-catalog.is-open svg{ transform:rotate(180deg); }

.nav-list{
  display:flex; align-items:stretch; gap:0;
}
.nav-item{
  display:inline-flex; align-items:center;
  padding:10px 16px;
  font-size:14px; color:var(--text-2);
  transition:color .3s var(--ease-soft);
  position:relative;
}
.nav-item::after{
  content:"";
  position:absolute; left:16px; right:16px; bottom:6px;
  height:1px; background:var(--accent);
  transform:scaleX(0); transform-origin:left center;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.nav-item:hover{ color:var(--accent); }
.nav-item:hover::after{ transform:scaleX(1); }
.nav-item.is-active{ color:var(--accent); }
.nav-item.is-active::after{ transform:scaleX(1); }


/* ════════════════════════════════════════════════════
   4. MEGA PANEL — выпадающее меню каталога
════════════════════════════════════════════════════ */

.mega{
  position:absolute; left:0; right:0; top:100%;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:var(--float-2);
  z-index:30;
  opacity:0; visibility:hidden; transform:translateY(-12px) scale(0.985);
  transform-origin:top center;
  transition:opacity .55s cubic-bezier(.22,1,.36,1),
             transform .55s cubic-bezier(.22,1,.36,1),
             visibility .55s linear;
}
.mega.is-open{
  opacity:1; visibility:visible; transform:translateY(0) scale(1);
  transition:opacity .5s cubic-bezier(.22,1,.36,1),
             transform .55s cubic-bezier(.22,1,.36,1),
             visibility 0s linear;
}
.mega-inner{
  max-width:var(--max); margin:0 auto;
  padding:24px var(--side) 28px;
  display:grid; grid-template-columns: 240px 280px 1fr;
  gap:0;
  min-height:440px;
}
.mega-col{ position:relative; }
.mega-col + .mega-col{ border-left:1px solid var(--border); padding-left:24px; }
.mega-col-head{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--text-3); padding:6px 14px 14px;
}
.mega-list{ display:flex; flex-direction:column; }
.mega-cat{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px; border-radius:var(--r-sm);
  font-size:14px; color:var(--text);
  cursor:pointer;
  transition:background var(--dur-xs), color var(--dur-xs);
}
.mega-cat:hover,
.mega-cat.is-active{
  background:var(--accent-tint);
  color:var(--accent-active);
}
.mega-cat .count{
  font-family:var(--font-mono); font-size:11px;
  color:var(--text-3); font-weight:400;
}
.mega-cat.is-active .count{ color:var(--accent); }
.mega-cat-arrow{ width:10px; height:10px; opacity:.4; transition:opacity var(--dur-xs); }
.mega-cat.is-active .mega-cat-arrow{ opacity:1; color:var(--accent); }

.mega-sub{
  display:flex; align-items:center;
  padding:9px 14px; border-radius:var(--r-sm);
  font-size:13px; color:var(--text-2);
  cursor:pointer;
  transition:background var(--dur-xs), color var(--dur-xs);
}
.mega-sub:hover,
.mega-sub.is-active{
  background:var(--bg-warm);
  color:var(--accent-active);
}
.mega-sub-all{
  margin-top:6px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent);
  border-top:1px dashed var(--border);
  padding-top:14px; margin-top:14px;
}
.mega-sub-all:hover{ color:var(--accent-active); background:transparent; }

.mega-preview{
  margin-left:24px;
  background:var(--surface);
  border-radius:var(--r-md);
  padding:24px;
  display:grid; grid-template-rows:1fr auto;
  gap:18px;
  position:relative;
  overflow:hidden;
}
.mega-preview-img{
  position:relative;
  display:flex; align-items:center; justify-content:center;
  min-height:220px;
}
.mega-preview-img img{
  max-height:240px; max-width:80%;
  object-fit:contain;
  transition:opacity .25s var(--ease-soft);
}
.mega-preview-img img.fade-out{ opacity:0; }
.mega-preview-info{
  border-top:1px solid var(--border);
  padding-top:16px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:18px;
}
.mega-preview-info .label{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--text-3); margin-bottom:6px;
}
.mega-preview-info .title{
  font-size:18px; font-weight:400; color:var(--text); line-height:1.2;
  letter-spacing:var(--ls-tight);
}
.mega-preview-info .desc{
  font-size:13px; color:var(--text-2); line-height:1.45;
  margin-top:6px; max-width:38ch;
}
.mega-preview-cta{
  flex:0 0 auto;
  display:inline-flex; align-items:center; gap:8px;
  height:36px; padding:0 16px; border-radius:var(--r-pill);
  background:var(--accent); color:#fff;
  font-size:13px; font-weight:500;
  transition:background var(--dur-sm);
}
.mega-preview-cta:hover{ background:var(--accent-active); }
.mega-preview-cta svg{ width:12px; height:12px; }

.mega-scroll{
  max-height:440px; overflow-y:auto;
  padding-right:6px;
  scrollbar-width:thin; scrollbar-color: var(--border-2) transparent;
}
.mega-scroll::-webkit-scrollbar{ width:6px; }
.mega-scroll::-webkit-scrollbar-thumb{ background:var(--border-2); border-radius:3px; }

.mega-backdrop{
  position:fixed; inset:0;
  background:rgba(253,252,250,0.30);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  opacity:0; visibility:hidden;
  transition:opacity .4s var(--ease-soft), visibility .4s var(--ease-soft);
  z-index:20;
}
.mega-backdrop.is-open{ opacity:1; visibility:visible; }


/* ════════════════════════════════════════════════════
   5. SEARCH PANEL — выезжающий поиск
════════════════════════════════════════════════════ */

.search-panel{
  position:fixed; left:0; right:0; top:0;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:var(--float-2);
  z-index:40;
  opacity:0; visibility:hidden; transform:translateY(-12px);
  transition:opacity .55s cubic-bezier(.22,1,.36,1),
             transform .55s cubic-bezier(.22,1,.36,1),
             visibility .55s linear;
}
.search-panel.is-open{
  opacity:1; visibility:visible; transform:translateY(0);
  transition:opacity .5s cubic-bezier(.22,1,.36,1),
             transform .55s cubic-bezier(.22,1,.36,1),
             visibility 0s linear;
}
.search-inner{
  max-width:var(--max); margin:0 auto;
  padding:28px var(--side) 32px;
}
.search-field{
  display:flex; align-items:center; gap:14px;
  padding:0 4px 16px;
  border-bottom:1px solid var(--border);
}
.search-field svg{ width:18px; height:18px; color:var(--text-3); flex:0 0 auto; }
.search-field input{
  flex:1; border:none; outline:none; background:transparent;
  font-family:var(--font-sans); font-size:22px; font-weight:300;
  color:var(--text); letter-spacing:-0.01em;
  padding:6px 0;
}
.search-field input::placeholder{ color:var(--text-3); font-weight:300; }
.search-hint{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--text-3); white-space:nowrap;
}
.search-hint kbd{
  font-family:var(--font-mono); font-size:10px;
  padding:2px 6px; border-radius:4px;
  background:var(--bg-warm); color:var(--text-2);
  border:1px solid var(--border);
  margin-right:4px;
}
.search-close{
  width:32px; height:32px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  background:transparent; border:none; cursor:pointer;
  color:var(--text-3);
  transition:color .3s var(--ease-soft), background .3s var(--ease-soft);
}
.search-close:hover{ color:var(--accent); background:var(--bg-warm); }
.search-close svg{ width:14px; height:14px; }
.search-results{
  margin-top:20px;
  display:grid; grid-template-columns: 2fr 1fr; gap:32px;
}
.search-col-head{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--text-3); margin-bottom:14px;
}
.search-products{ display:flex; flex-direction:column; gap:2px; }
.search-product{
  display:grid; grid-template-columns:48px 1fr auto; gap:14px;
  align-items:center; padding:10px 12px; border-radius:var(--r-sm);
  transition:background .25s var(--ease-soft); cursor:pointer;
}
.search-product:hover{ background:var(--bg-warm); }
.search-product-img{
  width:48px; height:48px; border-radius:var(--r-sm);
  background:var(--bg-warm);
  display:flex; align-items:center; justify-content:center;
}
.search-product-img img{ max-width:80%; max-height:80%; object-fit:contain; }
.search-product-name{ font-size:14px; color:var(--text); line-height:1.3; }
.search-product-meta{
  font-family:var(--font-mono); font-size:11px;
  color:var(--text-3); margin-top:2px; letter-spacing:.04em;
}
.search-product-price{
  font-family:var(--font-mono); font-size:12px;
  color:var(--text-2); white-space:nowrap;
}
.search-cats{ display:flex; flex-direction:column; gap:4px; }
.search-cat{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-radius:var(--r-sm);
  color:var(--text-2); font-size:14px;
  transition:background .25s var(--ease-soft), color .25s var(--ease-soft);
}
.search-cat:hover{ background:var(--bg-warm); color:var(--accent); }
.search-cat .count{ font-family:var(--font-mono); font-size:11px; color:var(--text-3); }


/* ════════════════════════════════════════════════════
   6. M-HEADER — мобильная/планшетная шапка
   (бургер + лого + 2 иконки). Visible через @media ниже.
════════════════════════════════════════════════════ */

.m-header{
  display:none;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:25;
}
.m-header-inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:var(--m-header-padding);
  min-height:var(--m-header-min-h);
}
.m-burger{ justify-self:start; }
.m-actions{ justify-self:end; }
.m-burger{
  width:var(--m-tap-target); height:var(--m-tap-target); margin-left:-10px;
  display:inline-flex; align-items:center; justify-content:center;
  background:transparent; border:none; cursor:pointer;
  color:var(--text-2);
}
.m-burger:focus{ outline:none; }
.m-burger svg{ width:var(--m-icon-svg-size); height:var(--m-icon-svg-size); }
.m-logo{
  flex:1;
  font-family:var(--font-sans); font-weight:500;
  letter-spacing:var(--ls-logo); font-size:var(--m-logo-size);
  color:var(--text-2);
  text-align:center;
}
.m-actions{
  display:flex; align-items:center; gap:4px;
  margin-right:-10px;
}
.m-icon{
  width:var(--m-tap-target); height:var(--m-tap-target);
  display:inline-flex; align-items:center; justify-content:center;
  background:transparent; border:none; cursor:pointer;
  color:var(--text-2);
  position:relative;
  transition:color var(--dur-sm);
}
.m-icon:focus{ outline:none; }
.m-icon:focus-visible{ outline:1px solid var(--accent); outline-offset:2px; border-radius:8px; }
.m-icon:hover{ color:var(--accent); }
.m-icon svg{ width:var(--m-icon-svg-size); height:var(--m-icon-svg-size); stroke-width:1.25; }
.m-icon .badge{
  position:absolute; top:6px; right:4px;
  min-width:14px; height:14px; padding:0 3px;
  border-radius:8px;
  background:var(--accent); color:#fff;
  font-family:var(--font-mono);
  font-size:9px; font-weight:500; line-height:1;
  display:flex; align-items:center; justify-content:center;
  box-sizing:border-box;
  border:1.5px solid var(--bg);
  font-feature-settings:"tnum" 1;
}
.m-icon[data-count="0"] .badge{ display:none; }


/* ════════════════════════════════════════════════════
   7. M-DRAWER — выезжающее мобильное меню (multi-level)
════════════════════════════════════════════════════ */

.m-drawer{
  position:fixed; inset:0;
  background:var(--bg);
  z-index:50;
  transform:translateX(-100%);
  transition:transform .5s cubic-bezier(.22,1,.36,1);
  display:flex; flex-direction:column;
}
.m-drawer.is-open{ transform:translateX(0); }
.m-drawer-backdrop{
  position:fixed; inset:0;
  background:rgba(28,24,21,0.42);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
  opacity:0; visibility:hidden;
  transition:opacity .45s var(--ease-soft), visibility .45s var(--ease-soft);
  z-index:45;
}
.m-drawer-backdrop.is-open{ opacity:1; visibility:visible; }
.m-drawer-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 18px;
  border-bottom:1px solid var(--border);
  min-height:48px;
}
.m-drawer-title{
  font-family:var(--font-sans); font-weight:500;
  letter-spacing:var(--ls-logo); font-size:16px;
  color:var(--text-2);
}
.m-drawer-back{
  display:flex; align-items:center; gap:8px;
  background:transparent; border:none; cursor:pointer;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--text-3);
  padding:6px 0;
}
.m-drawer-back svg{ width:12px; height:12px; }
.m-drawer-close{
  width:36px; height:36px; margin-right:-10px;
  display:inline-flex; align-items:center; justify-content:center;
  background:transparent; border:none; cursor:pointer;
  color:var(--text-3);
}
.m-drawer-close svg{ width:14px; height:14px; }
.m-drawer-body{
  flex:1; overflow-y:auto;
  position:relative;
}
.m-drawer-pane{
  position:absolute; inset:0;
  overflow-y:auto;
  transition:transform .42s cubic-bezier(.22,1,.36,1), opacity .35s var(--ease-soft);
}
.m-drawer-pane.is-hidden-left{ transform:translateX(-30%); opacity:0; pointer-events:none; }
.m-drawer-pane.is-hidden-right{ transform:translateX(30%); opacity:0; pointer-events:none; }
.m-drawer-section{ padding:14px 18px 4px; }
.m-drawer-h{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--text-3);
  margin-bottom:6px;
}
.m-drawer-cat{
  display:grid; grid-template-columns:32px 1fr auto; align-items:center; gap:12px;
  padding:6px 18px;
  font-size:14.5px; color:var(--text);
  border-bottom:1px solid var(--border);
  cursor:pointer; user-select:none;
}
.m-drawer-cat-img{
  width:32px; height:32px;
  background:var(--bg-warm); border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.m-drawer-cat-img img{ max-width:78%; max-height:78%; object-fit:contain; }
.m-drawer-cat-meta{ display:flex; align-items:center; gap:8px; }
.m-drawer-cat:hover{ background:var(--bg-warm); color:var(--accent); }
.m-drawer-cat .count{
  font-family:var(--font-mono); font-size:11px; color:var(--text-3);
}
.m-drawer-cat svg{ width:10px; height:10px; opacity:.5; }

.m-drawer-cta{
  margin:10px 18px 4px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:var(--accent); color:#fff;
  padding:12px 18px; border-radius:var(--r-pill);
  font-size:14px; font-weight:500;
  min-height:44px;
  transition:background var(--dur-sm);
}
.m-drawer-cta:hover{ background:var(--accent-active); }
.m-drawer-cta svg{ width:14px; height:14px; }
.m-drawer-sub{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px;
  font-size:14.5px; color:var(--text-2);
  border-bottom:1px solid var(--border);
}
.m-drawer-sub:hover{ background:var(--bg-warm); color:var(--accent); }
.m-drawer-sub-all{
  color:var(--accent); font-weight:500;
  font-family:var(--font-mono); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase;
}
.m-drawer-nav{
  padding:2px 18px 6px;
  display:grid; grid-template-columns:1fr 1fr; gap:0 14px;
}
.m-drawer-nav a{
  padding:9px 0;
  font-size:14px; color:var(--text-2);
  display:flex; align-items:center; min-height:40px;
}
.m-drawer-nav a:hover{ color:var(--accent); }
.m-drawer-nav--single{ grid-template-columns:1fr; }
.m-drawer-contact{ padding:2px 18px 6px; display:flex; flex-direction:column; gap:0; }
.m-drawer-contact-row{
  display:grid; grid-template-columns:28px 1fr; gap:12px; align-items:center;
  padding:9px 0;
  color:var(--text); transition:color var(--dur-sm);
}
.m-drawer-contact-row:hover{ color:var(--accent); }
.m-drawer-contact-icon{
  width:28px; height:28px; border-radius:var(--r-sm);
  background:var(--bg-warm); color:var(--accent);
  display:inline-flex; align-items:center; justify-content:center;
}
.m-drawer-contact-icon svg{ width:13px; height:13px; }
.m-drawer-contact-text{ display:flex; flex-direction:column; gap:1px; font-size:13.5px; }
.m-drawer-contact-sub{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-3);
}
.m-drawer-foot{
  padding:12px 18px 16px;
  border-top:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  gap:14px;
}
.m-drawer-lang{
  display:inline-flex; align-items:center;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.05em;
  background:var(--bg-warm);
  border-radius:var(--r-pill);
  padding:3px;
}
.m-drawer-lang a{
  padding:6px 14px; border-radius:var(--r-pill);
  color:var(--text-2); min-height:32px; display:inline-flex; align-items:center;
}
.m-drawer-lang a.is-active{ background:var(--bg); color:var(--text); font-weight:500; }


/* ════════════════════════════════════════════════════
   8. CHROME RESPONSIVE — переключение Desktop ↔ Mobile/Tablet
   На планшете и мобильном (≤1024px) показываем m-header (бургер).
   Десктопный topbar/header/nav (≥1025px) — стандартный вид.
════════════════════════════════════════════════════ */

@media (max-width: 1024px) {
  .topbar, .header, .nav { display: none; }
  .m-header { display: block; }
}

/* Mobile-переменные перенесены в tokens.css (единый источник правды) */


/* ════════════════════════════════════════════════════
   9. FOOTER — dark island + bottom-bar
════════════════════════════════════════════════════ */

.footer{
  background:var(--bg);
  border-top:none;
  padding:32px var(--side) 40px;
}
.footer-inner{
  max-width:var(--max); margin:0 auto;
  background:var(--bg-dark);
  border-radius:var(--footer-inner-radius);
  padding:var(--footer-inner-padding);
  display:grid; grid-template-columns:1fr 1fr 1fr 1fr;
  gap:var(--footer-inner-gap);
  position:relative; overflow:hidden; isolation:isolate;
}
.footer-inner::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(135deg,
      rgba(70,59,84,0.50) 0%,
      rgba(35,32,28,0.55) 70%,
      rgba(35,32,28,0.85) 100%),
    radial-gradient(60% 80% at 28% 30%, rgba(126,108,137,0.22) 0%, rgba(126,108,137,0) 70%),
    radial-gradient(ellipse 720px 360px at 92% -10%, rgba(233,205,172,0.10), transparent 60%);
  pointer-events:none; z-index:-1;
}
.footer-h{
  font-family:var(--font-mono); font-size:var(--footer-h-size); letter-spacing:.18em; text-transform:uppercase;
  color:var(--ambient); margin-bottom:var(--footer-h-mb);
}
.footer-list{ display:flex; flex-direction:column; gap:var(--footer-list-gap); }
.footer-list a{
  font-size:var(--footer-list-size); color:rgba(253,252,250,0.82);
  transition: color var(--dur-sm) var(--ease-soft),
              transform var(--dur-md) var(--ease-apple);
  width:fit-content;
}
.footer-list a:hover{
  color:#c4a7e0;             /* лавандовый — светлый плам на тёмном */
  transform:translateX(4px); /* лёгкий сдвиг вправо */
}

.footer-bottom-wrap{
  max-width:var(--max); margin:12px auto 0;
  background:var(--bg-dark);
  border-radius:var(--footer-inner-radius);
  padding:0 32px;
  position:relative; overflow:hidden;
  isolation:isolate;
}
.footer-bottom-wrap::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(135deg,
      rgba(70,59,84,0.40) 0%,
      rgba(35,32,28,0.55) 70%,
      rgba(35,32,28,0.85) 100%);
  pointer-events:none;
}
.footer-bottom{
  margin-top:0; border-top:none;
  padding:22px 0;
  display:flex; justify-content:space-between; align-items:center; gap:24px;
  font-size:var(--footer-bottom-size); color:rgba(255,255,255,0.5);
  flex-wrap:wrap;
}
.footer-bottom-left{ display:flex; gap:18px; flex-wrap:wrap; }
.footer-bottom-left a{ color:rgba(255,255,255,0.5); transition:color var(--dur-sm); }
.footer-bottom-left a:hover{ color:#b89adb; }
.footer-lang{
  display:flex; gap:6px; align-items:center;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.05em;
}
.footer-lang a{
  color:rgba(255,255,255,0.45);
  padding:4px 8px; border-radius:var(--r-sm);
  transition:color var(--dur-sm), background var(--dur-sm);
}
.footer-lang a.is-active{ color:rgba(255,255,255,0.95); background:rgba(255,255,255,0.06); }
.footer-lang a:hover{ color:#b89adb; }
.footer-lang .sep{ color:rgba(255,255,255,0.25); }


/* ──── FOOTER · Mobile (≤767px) — layout-only ──── */
/* Размеры (padding, gap, font-size) — через --footer-* переменные в tokens.css */
@media (max-width: 767px) {
  .footer-inner { grid-template-columns: 1fr 1fr; }  /* 4 → 2 колонки */
  .footer-bottom {
    padding: 18px 8px;
    flex-direction: column; align-items: flex-start;
  }
  .footer-bottom > span { order: 1; opacity: 0.7; }
  .footer-lang { order: 2; margin-top: -4px; }
  .footer-bottom-left {
    order: 3; gap: 14px; padding-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    width: 100%;
  }
  .footer-bottom-left a { font-size: 11px; opacity: 0.75; }
}
