/*
Theme Name: ACIDLAB
Theme URI: https://acidlab.ru
Author: ACIDLAB Media
Description: Тёмный лабораторный терминальный стиль. Кислотно-жёлтые акценты, сетчатые текстуры, live-статистика. Русскоязычный журнал о закиси азота N₂O.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: acidlab
Tags: dark, magazine, news, sidebar, custom-logo, featured-images, translation-ready
*/

/* ============================================================
   ДИЗАЙН-СИСТЕМА
   ============================================================ */
:root {
  --bg:         #0e0e0e;
  --bg2:        #111111;
  --bg3:        #141414;
  --surface:    #161616;
  --border:     #1e1e1e;
  --border2:    #2a2a2a;

  --acid:       #c8f135;
  --acid-dim:   rgba(200,241,53,.1);
  --acid-text:  #0e0e0e;
  --orange:     #ff5000;
  --teal:       #00c8b4;
  --blue-cat:   #6496ff;
  --green-cat:  #50dc50;
  --red-cat:    #ff3232;

  --text:       #e8e8e0;
  --text-muted: #888880;
  --text-dim:   #444440;
  --text-ghost: #2a2a2a;

  --font-head:  'Archivo Black', 'Arial Black', sans-serif;
  --font-body:  'Archivo', 'Helvetica Neue', sans-serif;
  --font-mono:  'JetBrains Mono', 'Courier New', monospace;
  --font-disp:  'Bebas Neue', 'Impact', sans-serif;

  --sp-xs:  4px;  --sp-sm: 8px;  --sp-md: 16px;
  --sp-lg:  24px; --sp-xl: 40px; --sp-2xl: 64px;

  --container: 1260px;
  --sidebar:   280px;
  --radius:    3px;
  --ease:      cubic-bezier(.4,0,.2,1);
  --dur:       .2s;
  --transition: all var(--dur) var(--ease);
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { background:var(--bg); color:var(--text); font-family:var(--font-body); line-height:1.65; overflow-x:hidden; }
a { color:inherit; text-decoration:none; transition:var(--transition); }
img { max-width:100%; height:auto; display:block; }
ul,ol { padding-left:1.5rem; }
::selection { background:var(--acid); color:var(--acid-text); }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }
::-webkit-scrollbar-thumb:hover { background:var(--acid); }

/* ============================================================
   ТИПОГРАФИКА
   ============================================================ */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-head); line-height:1.15; color:var(--text); }
h1 { font-size:clamp(1.8rem,4vw,3rem); }
h2 { font-size:clamp(1.4rem,3vw,2rem); }
h3 { font-size:1.15rem; }

.mono { font-family:var(--font-mono); }
.label-acid {
  font-family:var(--font-mono);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--acid);
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container { max-width:var(--container); margin:0 auto; padding:0 20px; }

.site-content-area {
  display:grid;
  grid-template-columns:1fr var(--sidebar);
  gap:0;
  border-top:1px solid var(--border);
}

/* ============================================================
   ВЕРХНЯЯ ПОЛОСКА (TOPBAR)
   ============================================================ */
.topbar {
  background:var(--acid);
  padding:5px 0;
}
.topbar-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--sp-md);
}
.topbar-stats {
  display:flex;
  align-items:center;
  gap:var(--sp-md);
  font-family:var(--font-mono);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--acid-text);
}
.topbar-live {
  display:flex;
  align-items:center;
  gap:5px;
}
.topbar-live::before {
  content:'';
  width:6px; height:6px;
  background:var(--acid-text);
  border-radius:50%;
  animation:blink 1.2s step-end infinite;
}
@keyframes blink { 50% { opacity:0; } }

.topbar-date {
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.1em;
  color:rgba(14,14,14,.55);
}

/* ============================================================
   ШАПКА
   ============================================================ */
.site-header {
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:500;
}

.header-bar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:62px;
  gap:var(--sp-md);
}

/* Логотип */
.site-logo {
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.logo-box {
  width:40px; height:40px;
  border:2px solid var(--acid);
  border-radius:var(--radius);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  color:var(--acid);
  letter-spacing:.05em;
  flex-shrink:0;
}
.logo-name {
  font-family:var(--font-disp);
  font-size:2rem;
  letter-spacing:-.02em;
  color:var(--text);
  line-height:1;
}
.logo-name em { color:var(--acid); font-style:normal; }
.logo-sub {
  font-family:var(--font-mono);
  font-size:.55rem;
  color:var(--text-dim);
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-top:2px;
  display:block;
}

/* Навигация десктоп */
.primary-nav {
  display:flex;
  align-items:center;
  gap:0;
}
.primary-nav ul {
  display:flex;
  list-style:none;
  margin:0; padding:0;
  gap:0;
}
.primary-nav ul li { list-style:none; }
.primary-nav ul li a,
.primary-nav > a {
  display:block;
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-dim);
  padding:8px 12px;
  border-right:1px solid var(--border);
  transition:var(--transition);
  white-space:nowrap;
}
.primary-nav ul li:first-child a { border-left:1px solid var(--border); }
.primary-nav ul li a:hover,
.primary-nav ul li.current-menu-item > a,
.primary-nav ul li.current_page_item > a {
  color:var(--acid);
  background:var(--acid-dim);
}

/* Действия шапки */
.header-actions { display:flex; align-items:center; gap:var(--sp-sm); }

.btn-search-al {
  width:36px; height:36px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:none;
  color:var(--text-dim);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition:var(--transition);
}
.btn-search-al:hover { border-color:var(--acid); color:var(--acid); }

.btn-subscribe-al {
  font-family:var(--font-body);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:9px 16px;
  background:var(--acid);
  color:var(--acid-text);
  border:none;
  border-radius:var(--radius);
  cursor:pointer;
  transition:var(--transition);
}
.btn-subscribe-al:hover { opacity:.9; transform:translateY(-1px); }

/* Гамбургер */
.btn-hamburger-al {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:5px;
  z-index:1001;
  position:relative;
}
.btn-hamburger-al span {
  display:block;
  width:22px; height:2px;
  background:var(--text);
  border-radius:2px;
  transition:all .3s var(--ease);
  transform-origin:center;
}
.btn-hamburger-al.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.btn-hamburger-al.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.btn-hamburger-al.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Мобильное меню */
.mobile-overlay-al {
  display:none;
  position:fixed; inset:0;
  background:rgba(0,0,0,.8);
  z-index:998;
  backdrop-filter:blur(4px);
}
.mobile-overlay-al.open { display:block; }

.mobile-nav-al {
  position:fixed;
  top:0; left:0; right:0;
  background:var(--bg2);
  border-bottom:2px solid var(--acid);
  z-index:999;
  padding:70px 20px 24px;
  transform:translateY(-110%);
  transition:transform .35s var(--ease);
  box-shadow:0 16px 48px rgba(0,0,0,.8);
}
.mobile-nav-al.open { transform:translateY(0); }

.mobile-nav-al ul,
.mobile-nav-al .menu {
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:2px;
}
.mobile-nav-al ul li,
.mobile-nav-al .menu li { list-style:none; }
.mobile-nav-al ul li a,
.mobile-nav-al .menu li a {
  display:block;
  font-family:var(--font-disp);
  font-size:1.8rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--text-dim);
  padding:10px 16px;
  border-radius:var(--radius);
  border-left:3px solid transparent;
  transition:var(--transition);
}
.mobile-nav-al ul li a:hover,
.mobile-nav-al .menu li a:hover,
.mobile-nav-al ul li.current-menu-item a {
  color:var(--acid);
  background:var(--acid-dim);
  border-left-color:var(--acid);
}

/* ============================================================
   БЕГУЩАЯ СТРОКА
   ============================================================ */
.breaking-ticker-al {
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  padding:6px 0;
  overflow:hidden;
}
.ticker-inner-al {
  display:flex;
  align-items:center;
  gap:var(--sp-md);
}
.ticker-tag-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  background:var(--acid);
  color:var(--acid-text);
  padding:3px 10px;
  white-space:nowrap;
  flex-shrink:0;
}
.ticker-scroll-al {
  flex:1; overflow:hidden;
}
.ticker-inner-scroll {
  display:inline-flex;
  gap:40px;
  white-space:nowrap;
  animation:tickerAl 28s linear infinite;
}
.ticker-inner-scroll span {
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  color:var(--text-muted);
  display:flex;
  align-items:center;
  gap:6px;
}
.ticker-inner-scroll span::before {
  content:'//';
  color:var(--acid);
  font-family:var(--font-mono);
  font-weight:900;
  font-size:.65rem;
}
@keyframes tickerAl { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ============================================================
   ГЕРОЙ — АСИММЕТРИЧНАЯ СЕТКА
   ============================================================ */
.hero-al {
  border-bottom:1px solid var(--border);
  padding:var(--sp-lg) 0 0;
}

.hero-grid-al {
  display:grid;
  grid-template-columns:1fr 1px 320px;
  min-height:400px;
  gap:0;
}
.hero-rule-al { background:var(--border); }

.hero-lead-al {
  padding:0 var(--sp-lg) var(--sp-lg) 0;
  display:flex;
  flex-direction:column;
  gap:var(--sp-md);
}

.hero-idx {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-ghost);
  font-weight:700;
  letter-spacing:.12em;
}

.hero-kicker {
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
}

.hero-title-al {
  font-family:var(--font-head);
  font-size:clamp(1.6rem,3.5vw,2.6rem);
  color:var(--text);
  line-height:1.15;
}
.hero-title-al em { color:var(--acid); font-style:normal; }

.hero-excerpt-al {
  font-size:.95rem;
  color:var(--text-muted);
  line-height:1.65;
  max-width:540px;
}

.hero-meta-al {
  display:flex;
  gap:var(--sp-md);
  font-family:var(--font-mono);
  font-size:.62rem;
  color:var(--text-dim);
}
.hero-meta-al span::before { content:'› '; color:var(--acid); }

.hero-img-al {
  aspect-ratio:16/9;
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:var(--sp-md);
  position:relative;
}
.hero-img-al img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.hero-lead-al:hover .hero-img-al img { transform:scale(1.03); }
.hero-img-placeholder-al {
  width:100%;
  aspect-ratio:16/9;
  background:repeating-linear-gradient(0deg,transparent,transparent 23px,var(--border) 23px,var(--border) 24px),
             repeating-linear-gradient(90deg,transparent,transparent 23px,var(--border) 23px,var(--border) 24px);
  display:flex; align-items:center; justify-content:center;
  border-radius:var(--radius);
  margin-bottom:var(--sp-md);
}
.hero-img-placeholder-al span {
  font-family:var(--font-mono);
  font-size:.65rem;
  color:var(--text-ghost);
  letter-spacing:.2em;
  text-transform:uppercase;
}

.btn-read-al {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-body);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:10px 20px;
  border:1px solid var(--acid);
  color:var(--acid);
  border-radius:var(--radius);
  background:none;
  cursor:pointer;
  transition:var(--transition);
  width:fit-content;
}
.btn-read-al:hover { background:var(--acid); color:var(--acid-text); }

/* Боковые материалы */
.hero-aside-al {
  padding:0 0 var(--sp-lg) var(--sp-lg);
  display:flex;
  flex-direction:column;
}
.aside-item-al {
  padding:14px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:var(--transition);
}
.aside-item-al:first-child { padding-top:0; }
.aside-item-al:last-child { border-bottom:none; }
.aside-item-al:hover { padding-left:6px; }

.aside-num-al {
  font-family:var(--font-disp);
  font-size:2.5rem;
  color:var(--text-ghost);
  line-height:1;
  margin-bottom:-4px;
  transition:color var(--dur);
}
.aside-item-al:hover .aside-num-al { color:var(--acid); }

.aside-title-al {
  font-family:var(--font-body);
  font-size:.88rem;
  font-weight:700;
  color:var(--text-muted);
  line-height:1.4;
  transition:color var(--dur);
}
.aside-item-al:hover .aside-title-al { color:var(--text); }

.aside-meta-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-ghost);
  margin-top:4px;
  letter-spacing:.06em;
}

/* Нижняя полоска героя */
.hero-strip-al {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
  margin-top:var(--sp-lg);
}
.strip-item-al {
  padding:12px 0;
  border-right:1px solid var(--border);
  cursor:pointer;
  transition:background var(--dur);
}
.strip-item-al:last-child { border-right:none; }
.strip-item-al:hover { background:var(--bg2); }
.strip-cat-al {
  font-family:var(--font-mono);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:4px;
}
.strip-title-al {
  font-family:var(--font-body);
  font-size:.82rem;
  font-weight:700;
  color:var(--text-muted);
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* ============================================================
   КАТЕГОРИАЛЬНЫЕ БЕЙДЖИ
   ============================================================ */
.cat-badge-al {
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-family:var(--font-mono);
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:2px 8px;
  border-radius:2px;
}
.cat-badge-al::before { content:''; width:4px; height:4px; border-radius:50%; background:currentColor; opacity:.5; }

.cat-science    { background:rgba(100,150,255,.15); color:var(--blue-cat); }
.cat-motorsport { background:rgba(255,80,0,.15);    color:var(--orange); }
.cat-medical    { background:rgba(0,200,180,.15);   color:var(--teal); }
.cat-industry   { background:rgba(200,241,53,.15);  color:var(--acid); }
.cat-ecology    { background:rgba(80,220,80,.15);   color:var(--green-cat); }
.cat-breaking   { background:rgba(255,50,50,.15);   color:var(--red-cat); }
.cat-default    { background:var(--surface); color:var(--text-dim); }

/* ============================================================
   СЕКЦИОННЫЕ ЗАГОЛОВКИ
   ============================================================ */
.section-label-al {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:var(--sp-md);
}
.sec-line-al { flex:1; height:1px; background:var(--border); }
.sec-name-al {
  font-family:var(--font-mono);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--acid);
  white-space:nowrap;
}
.sec-count-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-ghost);
  white-space:nowrap;
}
.sec-more-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--acid);
  white-space:nowrap;
  transition:var(--transition);
}
.sec-more-al:hover { letter-spacing:.15em; }

/* ============================================================
   ТЕРМИНАЛЬНЫЙ РАЗДЕЛИТЕЛЬ
   ============================================================ */
.terminal-divider-al {
  background:var(--bg2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:8px var(--sp-md);
  font-family:var(--font-mono);
  font-size:.7rem;
  color:var(--text-dim);
  letter-spacing:.08em;
  display:flex;
  align-items:center;
  gap:8px;
  margin:var(--sp-lg) 0;
}
.terminal-divider-al::before { content:'$'; color:var(--acid); font-weight:900; }
.terminal-cursor-al {
  display:inline-block;
  width:6px; height:12px;
  background:var(--acid);
  animation:blink 1s step-end infinite;
  vertical-align:middle;
  margin-left:2px;
}

/* ============================================================
   КАРТОЧКИ СТАТЕЙ
   ============================================================ */
.news-grid-al {
  display:grid;
  gap:1px;
  background:var(--border);
  margin-bottom:1px;
}
.news-grid-3 { grid-template-columns:repeat(3,1fr); }
.news-grid-2 { grid-template-columns:repeat(2,1fr); }

.article-card-al {
  background:var(--bg);
  padding:var(--sp-md);
  cursor:pointer;
  transition:background var(--dur);
}
.article-card-al:hover { background:var(--bg2); }

.card-thumb-al {
  aspect-ratio:16/9;
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:10px;
  position:relative;
}
.card-thumb-al img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s var(--ease);
}
.article-card-al:hover .card-thumb-al img { transform:scale(1.05); }

.card-thumb-placeholder {
  width:100%; aspect-ratio:16/9;
  border-radius:var(--radius);
  margin-bottom:10px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono);
  font-size:.65rem;
  color:var(--text-ghost);
  letter-spacing:.15em;
}
.cp1 { background:repeating-linear-gradient(45deg,var(--bg),var(--bg) 4px,var(--bg3) 4px,var(--bg3) 5px); }
.cp2 { background:repeating-linear-gradient(-45deg,var(--bg),var(--bg) 4px,var(--bg3) 4px,var(--bg3) 5px); }
.cp3 { background:repeating-linear-gradient(0deg,var(--bg),var(--bg) 4px,var(--bg3) 4px,var(--bg3) 5px); }
.cp4 { background:repeating-linear-gradient(90deg,var(--bg),var(--bg) 4px,var(--bg3) 4px,var(--bg3) 5px); }
.cp5 { background:repeating-linear-gradient(30deg,var(--bg),var(--bg) 6px,var(--bg3) 6px,var(--bg3) 7px); }
.cp6 { background:repeating-linear-gradient(60deg,var(--bg),var(--bg) 6px,var(--bg3) 6px,var(--bg3) 7px); }

.card-title-al {
  font-family:var(--font-body);
  font-size:.92rem;
  font-weight:700;
  color:var(--text-muted);
  line-height:1.4;
  margin:6px 0;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  transition:color var(--dur);
}
.article-card-al:hover .card-title-al { color:var(--acid); }

.card-excerpt-al {
  font-size:.8rem;
  color:var(--text-dim);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  margin-bottom:8px;
}

.card-meta-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-ghost);
  display:flex;
  gap:10px;
  letter-spacing:.05em;
}
.card-meta-author { color:var(--text-dim); }

/* ============================================================
   ГЛАВНЫЙ КОНТЕНТ
   ============================================================ */
.main-content-al {
  min-width:0;
  padding:var(--sp-lg) var(--sp-lg) var(--sp-2xl) 0;
  border-right:1px solid var(--border);
}

/* ============================================================
   САЙДБАР
   ============================================================ */
.sidebar-al {
  padding:var(--sp-lg) 0 var(--sp-lg) var(--sp-lg);
  min-width:0;
}

.widget-al {
  margin-bottom:var(--sp-xl);
  padding-bottom:var(--sp-xl);
  border-bottom:1px solid var(--border);
}
.widget-al:last-child { border-bottom:none; }

.widget-title-al {
  font-family:var(--font-mono);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--acid);
  margin-bottom:var(--sp-md);
  display:flex;
  align-items:center;
  gap:8px;
}
.widget-title-al::before {
  content:'';
  width:14px; height:2px;
  background:var(--acid);
  border-radius:1px;
  flex-shrink:0;
}

/* ============================================================
   ВИДЖЕТ — LIVE СТАТИСТИКА
   ============================================================ */
.stats-grid-al {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  margin-bottom:10px;
}
.stat-box-al {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:10px;
}
.stat-val-al {
  font-family:var(--font-disp);
  font-size:1.5rem;
  color:var(--acid);
  line-height:1;
}
.stat-label-al {
  font-family:var(--font-mono);
  font-size:.58rem;
  color:var(--text-dim);
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-top:3px;
}
.stat-change-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  margin-top:2px;
}
.stat-up { color:var(--green-cat); }
.stat-down { color:var(--red-cat); }

/* Мини-график */
.mini-chart-al {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:10px;
}
.mini-chart-title {
  font-family:var(--font-mono);
  font-size:.58rem;
  color:var(--text-dim);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.chart-bars-al {
  display:flex;
  align-items:flex-end;
  gap:3px;
  height:48px;
}
.chart-bar-al {
  flex:1;
  background:var(--border);
  border-radius:1px 1px 0 0;
  cursor:pointer;
  transition:background var(--dur);
}
.chart-bar-al:hover,
.chart-bar-al.active { background:var(--acid); }
.chart-years {
  display:flex;
  justify-content:space-between;
  font-family:var(--font-mono);
  font-size:.55rem;
  color:var(--text-ghost);
  margin-top:4px;
  letter-spacing:.06em;
}

/* ============================================================
   ВИДЖЕТ — КАЛЬКУЛЯТОР
   ============================================================ */
.calc-widget-al {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
}
.calc-tabs-al {
  display:flex;
  gap:2px;
  background:var(--bg3);
  border-radius:var(--radius);
  padding:2px;
  margin-bottom:12px;
}
.calc-tab-al {
  flex:1;
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-align:center;
  padding:5px 3px;
  border-radius:2px;
  color:var(--text-dim);
  border:none;
  background:none;
  cursor:pointer;
  transition:var(--transition);
}
.calc-tab-al.active { background:var(--acid); color:var(--acid-text); }

.calc-label-al {
  font-family:var(--font-mono);
  font-size:.58rem;
  color:var(--text-dim);
  letter-spacing:.1em;
  text-transform:uppercase;
  display:block;
  margin-bottom:4px;
}
.calc-input-al {
  width:100%;
  padding:7px 10px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--acid);
  font-family:var(--font-mono);
  font-size:.9rem;
  outline:none;
  margin-bottom:8px;
  transition:border-color var(--dur);
}
.calc-input-al:focus { border-color:var(--acid); }

.calc-range-al {
  width:100%;
  margin-bottom:8px;
  accent-color:var(--acid);
  cursor:pointer;
}
.calc-result-al {
  background:var(--bg);
  border:1px solid var(--acid);
  border-radius:var(--radius);
  padding:8px 10px;
  margin-top:2px;
}
.calc-result-value {
  font-family:var(--font-disp);
  font-size:1.3rem;
  color:var(--acid);
  line-height:1;
}
.calc-result-label {
  font-family:var(--font-mono);
  font-size:.58rem;
  color:var(--text-dim);
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-top:2px;
}

/* ============================================================
   ВИДЖЕТ — ГОЛОСОВАНИЕ
   ============================================================ */
.poll-widget-al {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
}
.poll-question-al {
  font-family:var(--font-body);
  font-size:.88rem;
  font-weight:700;
  color:var(--text);
  margin-bottom:12px;
  line-height:1.45;
}
.poll-btn-al {
  width:100%;
  text-align:left;
  padding:8px 10px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
  font-family:var(--font-body);
  font-size:.82rem;
  font-weight:600;
  color:var(--text-muted);
  margin-bottom:5px;
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:all var(--dur);
}
.poll-btn-al:hover { border-color:var(--acid); color:var(--text); }
.poll-btn-al.voted { cursor:default; }
.poll-fill-al {
  position:absolute;
  left:0; top:0; bottom:0;
  background:var(--acid-dim);
  transition:width .4s var(--ease);
  pointer-events:none;
}
.poll-pct-al {
  float:right;
  font-family:var(--font-mono);
  font-size:.7rem;
  font-weight:700;
  color:var(--acid);
  display:none;
}
.poll-count-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-ghost);
  margin-top:8px;
  letter-spacing:.06em;
}

/* ============================================================
   ВИДЖЕТ — КАРУСЕЛЬ ФАКТОВ
   ============================================================ */
.facts-widget-al {
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  position:relative;
  min-height:120px;
}
.fact-value-al {
  font-family:var(--font-disp);
  font-size:1.8rem;
  color:var(--acid);
  line-height:1;
}
.fact-unit-al {
  font-family:var(--font-body);
  font-size:.75rem;
  color:var(--text-dim);
  font-weight:700;
}
.fact-name-al {
  font-family:var(--font-body);
  font-size:.88rem;
  font-weight:700;
  color:var(--text-muted);
  margin-top:4px;
}
.fact-desc-al {
  font-family:var(--font-body);
  font-size:.78rem;
  color:var(--text-dim);
  margin-top:4px;
  line-height:1.5;
}
.fact-bg-num {
  position:absolute;
  bottom:8px; right:12px;
  font-family:var(--font-disp);
  font-size:3rem;
  color:var(--border);
  line-height:1;
  pointer-events:none;
}
.facts-nav-al {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:12px;
}
.facts-btn-al {
  font-family:var(--font-mono);
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  background:none;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:4px 10px;
  color:var(--text-dim);
  cursor:pointer;
  transition:var(--transition);
}
.facts-btn-al:hover { border-color:var(--acid); color:var(--acid); }
.facts-dots {
  display:flex; gap:4px; align-items:center;
}
.facts-dot {
  width:4px; height:4px;
  border-radius:50%;
  background:var(--border);
  cursor:pointer;
  transition:all var(--dur);
}
.facts-dot.active { background:var(--acid); width:12px; border-radius:2px; }

/* ============================================================
   ВИДЖЕТ — ПОДПИСКА
   ============================================================ */
.subscribe-widget-al {
  background:var(--acid);
  border-radius:var(--radius);
  padding:16px;
}
.sub-title-al {
  font-family:var(--font-head);
  font-size:1rem;
  color:var(--acid-text);
  line-height:1.25;
  margin-bottom:6px;
}
.sub-desc-al {
  font-family:var(--font-body);
  font-size:.78rem;
  color:rgba(14,14,14,.6);
  line-height:1.55;
  margin-bottom:12px;
}
.sub-input-al {
  width:100%;
  padding:9px 12px;
  background:#fff;
  border:none;
  border-radius:var(--radius);
  color:var(--bg);
  font-family:var(--font-body);
  font-size:.88rem;
  outline:none;
  margin-bottom:7px;
}
.sub-input-al::placeholder { color:#888; }
.sub-btn-al {
  width:100%;
  padding:10px;
  background:var(--bg);
  color:var(--acid);
  border:none;
  border-radius:var(--radius);
  font-family:var(--font-mono);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  cursor:pointer;
  transition:opacity var(--dur);
}
.sub-btn-al:hover { opacity:.85; }

/* ============================================================
   ВИДЖЕТ — ТЕГИ
   ============================================================ */
.tags-cloud-al { display:flex; flex-wrap:wrap; gap:5px; }
.tag-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:600;
  letter-spacing:.08em;
  padding:4px 10px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text-dim);
  cursor:pointer;
  transition:var(--transition);
}
.tag-al:hover { border-color:var(--acid); color:var(--acid); background:var(--acid-dim); }

/* ============================================================
   ВИДЖЕТ — РУБРИКИ С ПРОГРЕСС-БАРАМИ
   ============================================================ */
.cat-bar-item-al { margin-bottom:10px; }
.cat-bar-row-al {
  display:flex;
  justify-content:space-between;
  font-family:var(--font-body);
  font-size:.82rem;
  font-weight:600;
  color:var(--text-muted);
  margin-bottom:4px;
}
.cat-bar-count-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-dim);
}
.cat-bar-track-al {
  height:3px;
  background:var(--border);
  border-radius:2px;
  overflow:hidden;
}
.cat-bar-fill-al {
  height:100%;
  border-radius:2px;
  width:0;
  transition:width 1.2s var(--ease);
}

/* ============================================================
   ПОИСК
   ============================================================ */
.search-form-al {
  display:flex;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color var(--dur);
}
.search-form-al:focus-within { border-color:var(--acid); }
.search-form-al input {
  flex:1;
  padding:9px 12px;
  background:var(--bg2);
  border:none;
  color:var(--text);
  font-family:var(--font-body);
  font-size:.88rem;
  outline:none;
}
.search-form-al input::placeholder { color:var(--text-dim); }
.search-form-al button {
  padding:9px 14px;
  background:var(--acid);
  border:none;
  color:var(--acid-text);
  font-family:var(--font-mono);
  font-size:.7rem;
  font-weight:700;
  cursor:pointer;
  transition:opacity var(--dur);
}
.search-form-al button:hover { opacity:.9; }

/* ============================================================
   ОДИНОЧНАЯ СТАТЬЯ
   ============================================================ */
.article-header-al { margin-bottom:var(--sp-xl); }

.article-title-al {
  font-family:var(--font-head);
  font-size:clamp(1.8rem,4vw,3rem);
  color:var(--text);
  line-height:1.15;
  margin:var(--sp-md) 0;
}

.article-byline-al {
  display:flex;
  align-items:center;
  gap:var(--sp-md);
  padding:var(--sp-md) 0;
  border-top:1px solid var(--acid);
  border-bottom:1px solid var(--border);
  margin-bottom:var(--sp-xl);
}
.byline-avatar {
  width:40px; height:40px;
  border-radius:50%;
  overflow:hidden;
  border:2px solid var(--border);
  flex-shrink:0;
}
.byline-name { font-family:var(--font-body); font-size:.9rem; font-weight:700; }
.byline-role {
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-dim);
  text-transform:uppercase;
  letter-spacing:.08em;
}
.article-stats-al {
  margin-left:auto;
  display:flex;
  gap:var(--sp-md);
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-dim);
}

.article-body-al {
  font-size:1rem;
  line-height:1.8;
  color:var(--text-muted);
}
.article-body-al h2 {
  font-family:var(--font-head);
  font-size:1.5rem;
  color:var(--text);
  margin:var(--sp-xl) 0 var(--sp-md);
  padding-bottom:var(--sp-sm);
  border-bottom:1px solid var(--border);
  position:relative;
}
.article-body-al h2::after {
  content:'';
  position:absolute;
  bottom:-1px; left:0;
  width:40px; height:2px;
  background:var(--acid);
}
.article-body-al h3 { font-size:1.1rem; color:var(--text); margin:var(--sp-lg) 0 var(--sp-sm); }
.article-body-al p { margin-bottom:var(--sp-md); }
.article-body-al blockquote {
  border-left:3px solid var(--acid);
  padding:var(--sp-md) var(--sp-lg);
  margin:var(--sp-xl) 0;
  background:var(--acid-dim);
  font-style:italic;
  font-size:1.05rem;
  color:var(--text);
}

/* ============================================================
   ФУТЕР
   ============================================================ */
.site-footer-al {
  background:var(--bg);
  border-top:1px solid var(--border);
  padding:var(--sp-2xl) 0 0;
  margin-top:var(--sp-2xl);
}
.footer-grid-al {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--sp-xl);
  margin-bottom:var(--sp-xl);
}
.footer-logo-al {
  font-family:var(--font-disp);
  font-size:2rem;
  letter-spacing:-.01em;
  color:var(--text);
  margin-bottom:var(--sp-sm);
}
.footer-logo-al em { color:var(--acid); font-style:normal; }
.footer-desc-al {
  font-family:var(--font-body);
  font-size:.85rem;
  color:var(--text-dim);
  line-height:1.65;
  margin-bottom:var(--sp-md);
  max-width:260px;
}
.footer-social-al { display:flex; gap:6px; flex-wrap:wrap; }
.footer-soc-btn {
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:6px 12px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text-dim);
  cursor:pointer;
  transition:var(--transition);
}
.footer-soc-btn:hover { border-color:var(--acid); color:var(--acid); }

.footer-col-title-al {
  font-family:var(--font-mono);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-ghost);
  margin-bottom:var(--sp-md);
}
.footer-links-al { list-style:none; padding:0; }
.footer-links-al li { margin-bottom:8px; }
.footer-links-al a {
  font-family:var(--font-body);
  font-size:.88rem;
  color:var(--text-dim);
  transition:color var(--dur);
}
.footer-links-al a:hover { color:var(--acid); }

.footer-bottom-al {
  border-top:1px solid var(--border);
  padding:var(--sp-md) 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-family:var(--font-mono);
  font-size:.6rem;
  color:var(--text-ghost);
  letter-spacing:.06em;
  flex-wrap:wrap;
  gap:8px;
}

/* ============================================================
   УТИЛИТЫ
   ============================================================ */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.btn-load-more-al {
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-mono);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:11px 24px;
  border:1px solid var(--acid);
  color:var(--acid);
  border-radius:var(--radius);
  background:none;
  cursor:pointer;
  transition:var(--transition);
  margin:var(--sp-xl) auto;
}
.btn-load-more-al:hover { background:var(--acid); color:var(--acid-text); }

/* Прогресс чтения */
.reading-progress-al {
  position:fixed;
  top:0; left:0;
  width:0%;
  height:3px;
  background:var(--acid);
  z-index:9999;
  transition:width .1s linear;
}

/* Пагинация */
.pagination { display:flex; align-items:center; justify-content:center; gap:6px; padding:var(--sp-xl) 0; }
.page-numbers {
  display:flex; align-items:center; justify-content:center;
  width:36px; height:36px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  font-family:var(--font-mono);
  font-size:.78rem;
  font-weight:700;
  color:var(--text-dim);
  transition:var(--transition);
}
.page-numbers:hover, .page-numbers.current { border-color:var(--acid); color:var(--acid); background:var(--acid-dim); }

/* WP-стандарт */
.alignleft  { float:left;  margin-right:var(--sp-lg); margin-bottom:var(--sp-sm); }
.alignright { float:right; margin-left:var(--sp-lg);  margin-bottom:var(--sp-sm); }
.aligncenter { text-align:center; margin:var(--sp-md) auto; }
.wp-caption-text { font-family:var(--font-mono); font-size:.62rem; color:var(--text-dim); text-align:center; margin-top:6px; }

/* ============================================================
   АДАПТИВ — ПЛАНШЕТ
   ============================================================ */
@media (max-width:1100px) {
  :root { --sidebar:240px; }
  .hero-grid-al { grid-template-columns:1fr; }
  .hero-rule-al { display:none; }
  .hero-aside-al { padding:var(--sp-lg) 0 0; flex-direction:row; flex-wrap:wrap; }
  .aside-item-al { flex:1 1 45%; padding:10px 8px; }
  .hero-strip-al { grid-template-columns:repeat(2,1fr); }
  .news-grid-3 { grid-template-columns:repeat(2,1fr); }
  .footer-grid-al { grid-template-columns:1fr 1fr; gap:var(--sp-lg); }
  .primary-nav ul li a { font-size:.72rem; padding:8px 9px; }
}

/* ============================================================
   АДАПТИВ — МОБИЛЬ
   ============================================================ */
@media (max-width:768px) {
  /* Шапка */
  .header-bar { height:58px; }
  .logo-name { font-size:1.6rem; }
  .logo-sub { display:none; }
  .primary-nav { display:none !important; }
  .btn-subscribe-al { display:none; }
  .btn-hamburger-al { display:flex; }

  /* Контент */
  .site-content-area { grid-template-columns:1fr; }
  .main-content-al { padding:var(--sp-lg) 0 var(--sp-xl); border-right:none; }
  .sidebar-al { padding:0 0 var(--sp-xl); border-top:1px solid var(--border); }

  /* Сетки */
  .news-grid-3, .news-grid-2 { grid-template-columns:1fr; }

  /* Герой */
  .hero-al { padding:var(--sp-md) 0 0; }
  .hero-grid-al { grid-template-columns:1fr; }
  .hero-rule-al { display:none; }
  .hero-lead-al { padding:0 0 var(--sp-lg); }
  .hero-aside-al { padding:var(--sp-md) 0 0; flex-direction:column; }
  .aside-item-al { flex:unset; }
  .hero-strip-al { grid-template-columns:1fr 1fr; }

  /* Футер */
  .footer-grid-al { grid-template-columns:1fr; gap:var(--sp-lg); }
  .footer-bottom-al { flex-direction:column; text-align:center; }

  /* Тикер */
  .ticker-inner-scroll { animation-duration:16s; }

  /* Статья */
  .article-byline-al { flex-wrap:wrap; }
  .article-stats-al { margin-left:0; width:100%; }
}

@media (max-width:400px) {
  .container { padding:0 12px; }
  .logo-name { font-size:1.4rem; }
  .logo-box { width:32px; height:32px; font-size:.5rem; }
  .hero-strip-al { grid-template-columns:1fr; }
}
