/*
Theme Name: МолекулаN₂O
Theme URI: https://mastodonsocial.ru
Author: МолекулаN₂O
Description: Тёплый пастельный журнал о закиси азота. Асимметричная плиточная раскладка, горизонтальная лента новостей, уютная палитра. Кардинально отличается от стандартных новостных шаблонов.
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: mol-n2o
Tags: magazine, light, pastel, warm, sidebar, masonry, custom-logo, featured-images, translation-ready
*/

/* ============================================================
   ДИЗАЙН-СИСТЕМА
   ============================================================ */
:root {
  --cream:       #f7f4ef;
  --paper:       #fdf9f4;
  --white:       #ffffff;
  --warm-line:   #e8e2d9;
  --warm-line2:  #f0ebe3;
  --warm-bg:     #fdf6f0;
  --warm-deep:   #fdf0e8;

  --ink:         #2d2620;
  --ink-soft:    #5a4a3d;
  --ink-muted:   #8c7d72;
  --ink-faint:   #a89880;
  --ink-ghost:   #c5bdb5;

  --terra:       #d4845a;
  --terra-light: #fde8df;
  --terra-text:  #8b4a2f;
  --mint:        #3a9e72;
  --mint-light:  #e0f5ee;
  --mint-text:   #1a6b4a;
  --sky:         #4a7ab5;
  --sky-light:   #e0edf8;
  --sky-text:    #1a4d7a;
  --lav:         #7a68b5;
  --lav-light:   #eeeaf8;
  --lav-text:    #4a3a8a;
  --rose:        #c05880;
  --rose-light:  #fce8ef;
  --rose-text:   #8a2a4a;
  --amber-c:     #c08030;
  --amber-light: #fef4e0;
  --amber-text:  #7a4e00;

  --font-serif:  'Lora', 'Georgia', serif;
  --font-sans:   'DM Sans', 'Helvetica Neue', sans-serif;
  --font-mono:   'DM Mono', 'Courier New', monospace;
  --font-disp:   'Playfair Display', 'Georgia', serif;

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

  --container: 1240px;
  --sidebar:   260px;
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;
  --ease: cubic-bezier(.4,0,.2,1);
  --dur:  .22s;
  --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(--cream); color:var(--ink); font-family:var(--font-sans); 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(--terra); color:#fff; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--cream); }
::-webkit-scrollbar-thumb { background:var(--ink-ghost); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--terra); }

/* ============================================================
   ТИПОГРАФИКА
   ============================================================ */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-disp); line-height:1.2; color:var(--ink); font-weight:700; }
h1 { font-size:clamp(1.8rem,4vw,2.8rem); font-style:italic; }
h2 { font-size:clamp(1.3rem,2.5vw,1.9rem); }
h3 { font-size:1.1rem; font-family:var(--font-sans); font-weight:700; }

/* ============================================================
   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;
}

/* ============================================================
   КАТЕГОРИАЛЬНЫЕ БЕЙДЖИ
   ============================================================ */
.cat-pill {
  display:inline-block;
  font-family:var(--font-sans);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:3px 10px;
  border-radius:20px;
  line-height:1.4;
}
.cat-apply    { background:var(--terra-light); color:var(--terra-text); }
.cat-safety   { background:var(--amber-light); color:var(--amber-text); }
.cat-tech     { background:var(--mint-light);  color:var(--mint-text); }
.cat-climate  { background:var(--sky-light);   color:var(--sky-text); }
.cat-history  { background:var(--rose-light);  color:var(--rose-text); }
.cat-interview{ background:var(--lav-light);   color:var(--lav-text); }
.cat-default  { background:var(--warm-line);   color:var(--ink-muted); }

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

.header-top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0 10px;
  gap:var(--sp-md);
}

.header-left { display:flex; align-items:center; gap:var(--sp-sm); min-width:100px; }
.header-right { display:flex; align-items:center; gap:var(--sp-sm); justify-content:flex-end; min-width:100px; }

/* Логотип */
.site-logo { text-align:center; flex:1; display:block; }
.logo-main {
  font-family:var(--font-disp);
  font-size:2rem;
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.02em;
  line-height:1;
  font-style:italic;
}
.logo-main em { color:var(--terra); font-style:normal; }
.logo-tagline {
  font-family:var(--font-sans);
  font-size:.58rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--ink-faint);
  display:block;
  margin-top:3px;
}

/* Кнопки шапки */
.btn-search-mol {
  width:34px; height:34px;
  border:1px solid var(--warm-line);
  border-radius:50%;
  background:none;
  color:var(--ink-faint);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition:var(--transition);
  font-size:.95rem;
}
.btn-search-mol:hover { border-color:var(--terra); color:var(--terra); }

.btn-subscribe-mol {
  font-family:var(--font-sans);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:8px 16px;
  background:var(--terra);
  color:#fff;
  border:none;
  border-radius:20px;
  cursor:pointer;
  transition:var(--transition);
  white-space:nowrap;
}
.btn-subscribe-mol:hover { background:var(--terra-text); transform:translateY(-1px); }

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

/* Навигация */
.header-nav {
  border-top:1px solid var(--warm-line2);
  padding:5px 0;
  display:flex;
  justify-content:center;
  gap:0;
  overflow-x:auto;
  scrollbar-width:none;
}
.header-nav::-webkit-scrollbar { display:none; }

.nav-pill {
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.05em;
  color:var(--ink-faint);
  padding:6px 14px;
  border-radius:20px;
  white-space:nowrap;
  cursor:pointer;
  transition:var(--transition);
  display:block;
}
.nav-pill:hover,
.nav-pill.active { background:var(--warm-bg); color:var(--terra); }

/* WordPress nav menu */
.header-nav ul { display:flex; gap:0; list-style:none; margin:0; padding:0; }
.header-nav ul li { list-style:none; }
.header-nav ul li a { @extend .nav-pill; }
.header-nav ul li.current-menu-item > a,
.header-nav ul li.current_page_item > a { background:var(--warm-bg); color:var(--terra); }

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

.mobile-nav-mol {
  position:fixed;
  top:0; left:0; right:0;
  background:var(--white);
  border-bottom:2px solid var(--terra);
  z-index:999;
  padding:72px 20px 20px;
  transform:translateY(-110%);
  transition:transform .35s var(--ease);
  box-shadow:0 8px 32px rgba(45,38,32,.15);
}
.mobile-nav-mol.open { transform:translateY(0); }

.mobile-nav-mol ul,
.mobile-nav-mol .menu {
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:2px;
}
.mobile-nav-mol ul li,
.mobile-nav-mol .menu li { list-style:none; }
.mobile-nav-mol ul li a,
.mobile-nav-mol .menu li a {
  display:block;
  font-family:var(--font-disp);
  font-size:1.5rem;
  font-style:italic;
  color:var(--ink-muted);
  padding:10px 16px;
  border-radius:var(--r-sm);
  border-left:3px solid transparent;
  transition:var(--transition);
}
.mobile-nav-mol ul li a:hover,
.mobile-nav-mol .menu li.current-menu-item a {
  color:var(--terra);
  background:var(--warm-bg);
  border-left-color:var(--terra);
}

/* ============================================================
   БЕГУЩАЯ СТРОКА
   ============================================================ */
.ticker-mol {
  background:var(--warm-bg);
  border-bottom:1px solid var(--warm-line);
  padding:7px 0;
  overflow:hidden;
}
.ticker-inner-mol {
  display:flex;
  align-items:center;
  gap:var(--sp-md);
}
.ticker-badge-mol {
  font-family:var(--font-sans);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  background:var(--terra);
  color:#fff;
  padding:3px 12px;
  border-radius:20px;
  white-space:nowrap;
  flex-shrink:0;
}
.ticker-scroll-mol { flex:1; overflow:hidden; }
.ticker-scroll-inner {
  display:inline-flex;
  gap:36px;
  white-space:nowrap;
  animation:tickerMol 26s linear infinite;
}
.ticker-scroll-inner span {
  font-family:var(--font-sans);
  font-size:.8rem;
  color:var(--ink-faint);
  display:flex; align-items:center; gap:6px;
}
.ticker-scroll-inner span::before {
  content:'◦';
  color:var(--terra);
  font-size:.8rem;
}
@keyframes tickerMol { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ============================================================
   ПЛИТОЧНЫЙ ГЕРОЙ (MASONRY)
   ============================================================ */
.masonry-hero {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:3px;
  background:var(--warm-line);
  border-bottom:3px solid var(--warm-line);
}

/* Большая плитка — левая (2 строки) */
.tile-main {
  grid-column:1;
  grid-row:1 / 3;
  background:var(--white);
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
}
.tile-main:hover .tile-img img { transform:scale(1.03); }
.tile-main:hover .tile-title { color:var(--terra); }

/* Маленькие плитки */
.tile-sm {
  background:var(--white);
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
}
.tile-sm:hover .tile-img img { transform:scale(1.05); }
.tile-sm:hover .tile-h3 { color:var(--terra); }

/* Нижний ряд правой части (2 плитки в 1 ячейке) */
.tile-row-pair {
  grid-column:2 / 4;
  grid-row:2;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3px;
  background:var(--warm-line);
}

.tile-img {
  overflow:hidden;
  position:relative;
}
.tile-img img {
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease);
  display:block;
}
.tile-placeholder {
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-sans);
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--ink-ghost);
}
.tile-placeholder.h-hero { height:200px; }
.tile-placeholder.h-sm   { height:120px; }
.tile-placeholder.h-mini { height:90px; }
.tile-placeholder.bg-terra  { background:var(--warm-deep); }
.tile-placeholder.bg-mint   { background:#edf8f3; }
.tile-placeholder.bg-sky    { background:#edf3fb; }
.tile-placeholder.bg-amber  { background:#fef4e0; }
.tile-placeholder.bg-rose   { background:#fceef4; }
.tile-placeholder.bg-lav    { background:#f2eef8; }

.tile-body { padding:16px; }
.tile-body-sm { padding:12px; }

.tile-title {
  font-family:var(--font-disp);
  font-size:1.2rem;
  font-weight:700;
  font-style:italic;
  color:var(--ink);
  line-height:1.3;
  margin:8px 0;
  transition:color var(--dur);
}
.tile-h3 {
  font-family:var(--font-sans);
  font-size:.9rem;
  font-weight:700;
  color:var(--ink);
  line-height:1.4;
  margin:6px 0 4px;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  transition:color var(--dur);
}
.tile-excerpt {
  font-size:.82rem;
  color:var(--ink-muted);
  line-height:1.6;
  margin-bottom:10px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.tile-meta {
  font-family:var(--font-sans);
  font-size:.65rem;
  color:var(--ink-ghost);
  display:flex;
  gap:10px;
}

/* Цветные плитки */
.tile-colored { background:var(--warm-deep); }

/* ============================================================
   ЛЕНТА НОВОСТЕЙ (горизонтальные карточки)
   ============================================================ */
.feed-list {
  display:flex;
  flex-direction:column;
  margin-bottom:var(--sp-xl);
}
.feed-item {
  display:grid;
  grid-template-columns:90px 1fr;
  gap:var(--sp-md);
  padding:var(--sp-md) 0;
  border-bottom:1px solid var(--warm-line2);
  cursor:pointer;
  transition:background var(--dur);
  border-radius:0;
}
.feed-item:first-child { padding-top:0; }
.feed-item:last-child  { border-bottom:none; }
.feed-item:hover { background:var(--warm-bg); margin:0 -20px; padding-left:20px; padding-right:20px; border-radius:var(--r-md); }

.feed-thumb {
  border-radius:var(--r-md);
  overflow:hidden;
  flex-shrink:0;
  align-self:start;
}
.feed-thumb img { width:90px; height:62px; object-fit:cover; display:block; border-radius:var(--r-md); }
.feed-thumb-ph {
  width:90px; height:62px;
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-sans);
  font-size:.6rem;
  font-weight:600;
  letter-spacing:.1em;
  color:var(--ink-ghost);
}

.feed-title {
  font-family:var(--font-sans);
  font-size:.9rem;
  font-weight:700;
  color:var(--ink);
  line-height:1.4;
  margin:5px 0 4px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  transition:color var(--dur);
}
.feed-item:hover .feed-title { color:var(--terra); }
.feed-meta {
  font-family:var(--font-sans);
  font-size:.62rem;
  color:var(--ink-ghost);
  display:flex;
  gap:8px;
}
.feed-author { color:var(--ink-faint); font-weight:600; }

/* ============================================================
   ФИЧА-СТАТЬЯ (большой горизонтальный баннер)
   ============================================================ */
.feature-banner {
  display:grid;
  grid-template-columns:1fr 180px;
  gap:var(--sp-lg);
  padding:var(--sp-lg);
  background:var(--warm-bg);
  border-radius:var(--r-lg);
  margin-bottom:var(--sp-xl);
  cursor:pointer;
  transition:background var(--dur);
  border:1px solid var(--warm-line);
}
.feature-banner:hover { background:var(--warm-deep); }

.feature-banner h2 {
  font-size:1.2rem;
  margin:8px 0;
  line-height:1.35;
}
.feature-banner:hover h2 { color:var(--terra); }

.feature-excerpt {
  font-size:.82rem;
  color:var(--ink-muted);
  line-height:1.65;
  margin-bottom:10px;
}
.feature-meta {
  font-family:var(--font-sans);
  font-size:.65rem;
  color:var(--ink-ghost);
  display:flex; gap:10px;
}

.feature-img-wrap {
  border-radius:var(--r-md);
  overflow:hidden;
  align-self:stretch;
}
.feature-img-wrap img { width:100%; height:100%; object-fit:cover; }
.feature-img-ph {
  width:100%; height:100%; min-height:100px;
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-sans);
  font-size:.65rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-ghost);
}

/* ============================================================
   МОЗАИКА (разная высота)
   ============================================================ */
.mosaic-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-md);
  margin-bottom:var(--sp-xl);
}

.mosaic-card {
  background:var(--white);
  border:1px solid var(--warm-line);
  border-radius:var(--r-lg);
  overflow:hidden;
  cursor:pointer;
  transition:all var(--dur);
}
.mosaic-card:hover { border-color:var(--warm-line2); transform:translateY(-2px); box-shadow:0 4px 16px rgba(45,38,32,.08); }

.mosaic-thumb { overflow:hidden; }
.mosaic-thumb img { width:100%; object-fit:cover; transition:transform .4s var(--ease); }
.mosaic-card:hover .mosaic-thumb img { transform:scale(1.04); }
.mosaic-thumb-ph {
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-sans); font-size:.65rem; font-weight:600;
  letter-spacing:.12em; color:var(--ink-ghost);
}
.mosaic-thumb-ph.h-lg { height:120px; }
.mosaic-thumb-ph.h-sm { height:80px; }

.mosaic-body { padding:12px; }
.mosaic-title {
  font-family:var(--font-sans);
  font-size:.88rem;
  font-weight:700;
  color:var(--ink);
  line-height:1.4;
  margin:5px 0 4px;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  transition:color var(--dur);
}
.mosaic-card:hover .mosaic-title { color:var(--terra); }
.mosaic-meta { font-family:var(--font-sans); font-size:.62rem; color:var(--ink-ghost); }

/* ============================================================
   ЗАГОЛОВКИ СЕКЦИЙ
   ============================================================ */
.sec-head-mol {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:var(--sp-md);
  padding-bottom:var(--sp-sm);
}
.sec-rule { flex:1; height:1px; background:var(--warm-line); }
.sec-title-mol {
  font-family:var(--font-sans);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--terra);
  white-space:nowrap;
}
.sec-count-mol {
  font-family:var(--font-sans);
  font-size:.62rem;
  color:var(--ink-ghost);
  white-space:nowrap;
}
.sec-more-mol {
  font-family:var(--font-sans);
  font-size:.65rem;
  font-weight:600;
  letter-spacing:.06em;
  color:var(--ink-ghost);
  white-space:nowrap;
  transition:color var(--dur);
}
.sec-more-mol:hover { color:var(--terra); }

/* ============================================================
   ОСНОВНОЙ КОНТЕНТ
   ============================================================ */
.main-content-mol {
  padding:var(--sp-lg) var(--sp-lg) var(--sp-2xl) 0;
  min-width:0;
  border-right:1px solid var(--warm-line);
}

/* Кнопки */
.btn-load-mol {
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:11px 24px;
  border:1.5px solid var(--terra);
  color:var(--terra);
  border-radius:20px;
  background:none;
  cursor:pointer;
  margin:0 auto;
  transition:var(--transition);
}
.btn-load-mol:hover { background:var(--terra); color:#fff; }

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

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

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

/* ============================================================
   ВИДЖЕТ — МОЛЕКУЛА N₂O
   ============================================================ */
.molecule-widget-mol {
  background:var(--warm-bg);
  border-radius:var(--r-lg);
  padding:var(--sp-md);
  text-align:center;
}
.mol-diagram { margin:0 auto var(--sp-sm); }
.mol-name-w {
  font-family:var(--font-disp);
  font-size:1rem;
  font-weight:700;
  font-style:italic;
  color:var(--ink);
  margin-bottom:2px;
}
.mol-name-w em { color:var(--terra); font-style:normal; }
.mol-formula {
  font-family:var(--font-mono);
  font-size:.65rem;
  color:var(--ink-faint);
  letter-spacing:.1em;
  margin-bottom:var(--sp-md);
}
.mol-props-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
.mol-prop-box {
  background:var(--white);
  border-radius:var(--r-md);
  padding:8px;
  text-align:center;
  border:1px solid var(--warm-line);
}
.mol-prop-val {
  font-family:var(--font-sans);
  font-size:.95rem;
  font-weight:700;
  color:var(--ink);
  line-height:1;
}
.mol-prop-lbl {
  font-family:var(--font-sans);
  font-size:.6rem;
  color:var(--ink-ghost);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-top:2px;
}

/* ============================================================
   ВИДЖЕТ — ЦИТАТА ДНЯ
   ============================================================ */
.quote-widget-mol {
  background:var(--warm-deep);
  border-radius:var(--r-lg);
  padding:var(--sp-md);
  position:relative;
}
.quote-mark-mol {
  font-family:var(--font-disp);
  font-size:3rem;
  color:var(--terra-light);
  line-height:1;
  margin-bottom:-12px;
}
.quote-text-mol {
  font-family:var(--font-serif);
  font-size:.9rem;
  font-style:italic;
  color:var(--ink-soft);
  line-height:1.65;
  position:relative;
}
.quote-source-mol {
  font-family:var(--font-sans);
  font-size:.65rem;
  color:var(--ink-ghost);
  margin-top:var(--sp-sm);
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* ============================================================
   ВИДЖЕТ — ОПРОС
   ============================================================ */
.poll-widget-mol {
  background:var(--white);
  border:1px solid var(--warm-line);
  border-radius:var(--r-lg);
  padding:var(--sp-md);
}
.poll-q-mol {
  font-family:var(--font-sans);
  font-size:.88rem;
  font-weight:700;
  color:var(--ink);
  margin-bottom:var(--sp-md);
  line-height:1.45;
}
.poll-btn-mol {
  width:100%;
  text-align:left;
  padding:8px 12px;
  background:var(--warm-bg);
  border:1px solid var(--warm-line);
  border-radius:var(--r-md);
  font-family:var(--font-sans);
  font-size:.82rem;
  font-weight:600;
  color:var(--ink-soft);
  margin-bottom:6px;
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
}
.poll-btn-mol:hover { border-color:var(--terra); color:var(--terra); background:var(--warm-deep); }
.poll-fill-mol {
  position:absolute; left:0; top:0; bottom:0;
  background:rgba(212,132,90,.12);
  transition:width .4s var(--ease);
  pointer-events:none;
}
.poll-pct-mol {
  float:right;
  font-weight:700;
  color:var(--terra);
  display:none;
}
.poll-count-mol {
  font-family:var(--font-sans);
  font-size:.65rem;
  color:var(--ink-ghost);
  margin-top:8px;
}

/* ============================================================
   ВИДЖЕТ — ТРЕНДЫ
   ============================================================ */
.trend-item-mol {
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 0;
  border-bottom:1px solid var(--warm-line2);
  cursor:pointer;
  transition:var(--transition);
}
.trend-item-mol:last-child { border-bottom:none; }
.trend-item-mol:hover { padding-left:6px; }
.trend-num-mol {
  font-family:var(--font-disp);
  font-size:1.6rem;
  color:var(--warm-line);
  line-height:1;
  flex-shrink:0;
  width:28px;
  transition:color var(--dur);
}
.trend-item-mol:hover .trend-num-mol { color:var(--terra); }
.trend-title-mol {
  font-family:var(--font-sans);
  font-size:.82rem;
  font-weight:700;
  color:var(--ink-soft);
  line-height:1.4;
  transition:color var(--dur);
}
.trend-item-mol:hover .trend-title-mol { color:var(--terra); }
.trend-cat-mol { font-family:var(--font-sans); font-size:.62rem; color:var(--ink-ghost); margin-top:2px; }

/* ============================================================
   ВИДЖЕТ — ПОСЛЕДНИЕ ПОСТЫ
   ============================================================ */
.recent-post-mol {
  display:flex;
  gap:10px;
  padding:9px 0;
  border-bottom:1px solid var(--warm-line2);
  cursor:pointer;
  transition:var(--transition);
}
.recent-post-mol:last-child { border-bottom:none; }
.recent-post-mol:hover { padding-left:6px; }
.recent-thumb-mol {
  width:52px; height:52px;
  border-radius:var(--r-md);
  overflow:hidden;
  flex-shrink:0;
}
.recent-thumb-mol img { width:100%; height:100%; object-fit:cover; }
.recent-thumb-ph {
  width:52px; height:52px;
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  font-size:.6rem; font-weight:600; color:var(--ink-ghost); font-family:var(--font-sans);
}
.recent-title-mol {
  font-family:var(--font-sans);
  font-size:.82rem;
  font-weight:600;
  color:var(--ink);
  line-height:1.4;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  transition:color var(--dur);
}
.recent-post-mol:hover .recent-title-mol { color:var(--terra); }
.recent-date-mol { font-family:var(--font-sans); font-size:.62rem; color:var(--ink-ghost); margin-top:3px; }

/* ============================================================
   ВИДЖЕТ — ПОДПИСКА
   ============================================================ */
.subscribe-widget-mol {
  background:var(--ink);
  border-radius:var(--r-lg);
  padding:var(--sp-lg);
}
.sub-title-mol {
  font-family:var(--font-disp);
  font-size:1.1rem;
  font-style:italic;
  color:#fff;
  line-height:1.3;
  margin-bottom:6px;
}
.sub-title-mol em { color:#e8a87a; font-style:normal; }
.sub-desc-mol {
  font-family:var(--font-sans);
  font-size:.78rem;
  color:rgba(255,255,255,.5);
  line-height:1.55;
  margin-bottom:var(--sp-md);
}
.sub-input-mol {
  width:100%;
  padding:10px 14px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r-md);
  color:#fff;
  font-family:var(--font-sans);
  font-size:.88rem;
  outline:none;
  margin-bottom:8px;
  transition:border-color var(--dur);
}
.sub-input-mol:focus { border-color:var(--terra); }
.sub-input-mol::placeholder { color:rgba(255,255,255,.3); }
.sub-btn-mol {
  width:100%;
  padding:10px;
  background:var(--terra);
  color:#fff;
  border:none;
  border-radius:var(--r-md);
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  transition:opacity var(--dur);
}
.sub-btn-mol:hover { opacity:.9; }

/* ============================================================
   ВИДЖЕТ — ТЕГИ
   ============================================================ */
.tags-cloud-mol { display:flex; flex-wrap:wrap; gap:6px; }
.tag-mol {
  font-family:var(--font-sans);
  font-size:.65rem;
  font-weight:600;
  padding:4px 12px;
  border:1px solid var(--warm-line);
  border-radius:20px;
  color:var(--ink-faint);
  cursor:pointer;
  transition:var(--transition);
}
.tag-mol:hover { border-color:var(--terra); color:var(--terra); background:var(--warm-bg); }

/* ============================================================
   ПРОГРЕСС ЧТЕНИЯ
   ============================================================ */
.reading-progress-mol {
  position:fixed;
  top:0; left:0;
  width:0%;
  height:3px;
  background:var(--terra);
  z-index:9999;
  transition:width .1s linear;
}

/* ============================================================
   СТАТЬЯ (SINGLE)
   ============================================================ */
.article-header-mol { margin-bottom:var(--sp-xl); }
.article-title-mol {
  font-family:var(--font-disp);
  font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:700;
  font-style:italic;
  color:var(--ink);
  line-height:1.2;
  margin:var(--sp-md) 0;
}
.article-subtitle-mol {
  font-size:1.05rem;
  color:var(--ink-muted);
  font-style:italic;
  line-height:1.6;
  margin-bottom:var(--sp-lg);
  font-family:var(--font-serif);
}
.article-byline-mol {
  display:flex;
  align-items:center;
  gap:var(--sp-md);
  padding:var(--sp-md) 0;
  border-top:2px solid var(--terra);
  border-bottom:1px solid var(--warm-line);
  margin-bottom:var(--sp-xl);
  flex-wrap:wrap;
}
.byline-avatar-mol { width:42px; height:42px; border-radius:50%; overflow:hidden; border:2px solid var(--warm-line); flex-shrink:0; }
.byline-name-mol { font-family:var(--font-sans); font-size:.9rem; font-weight:700; }
.byline-role-mol { font-family:var(--font-sans); font-size:.62rem; color:var(--ink-ghost); text-transform:uppercase; letter-spacing:.08em; }
.article-stats-mol {
  margin-left:auto;
  font-family:var(--font-sans);
  font-size:.65rem;
  color:var(--ink-ghost);
  display:flex; gap:var(--sp-md);
}
.article-body-mol {
  font-size:1.05rem;
  line-height:1.8;
  color:var(--ink-soft);
  font-family:var(--font-serif);
}
.article-body-mol h2 { font-family:var(--font-disp); font-size:1.5rem; font-style:italic; margin:var(--sp-xl) 0 var(--sp-md); color:var(--ink); }
.article-body-mol h3 { font-family:var(--font-sans); font-size:1.1rem; font-weight:700; margin:var(--sp-lg) 0 var(--sp-sm); }
.article-body-mol p { margin-bottom:var(--sp-md); }
.article-body-mol blockquote {
  border-left:3px solid var(--terra);
  padding:var(--sp-md) var(--sp-lg);
  margin:var(--sp-xl) 0;
  background:var(--warm-bg);
  font-style:italic;
  font-size:1.05rem;
  border-radius:0 var(--r-md) var(--r-md) 0;
}

/* ============================================================
   ФУТЕР
   ============================================================ */
.site-footer-mol {
  background:var(--ink);
  color:rgba(255,255,255,.5);
  padding:var(--sp-2xl) 0 0;
  margin-top:var(--sp-2xl);
}
.footer-grid-mol {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--sp-xl);
  margin-bottom:var(--sp-xl);
}
.footer-logo-mol {
  font-family:var(--font-disp);
  font-size:1.6rem;
  font-style:italic;
  color:#fff;
  margin-bottom:var(--sp-sm);
}
.footer-logo-mol em { color:#e8a87a; font-style:normal; }
.footer-desc-mol { font-family:var(--font-sans); font-size:.82rem; line-height:1.65; margin-bottom:var(--sp-md); max-width:260px; }
.footer-social-mol { display:flex; gap:6px; flex-wrap:wrap; }
.footer-soc-btn-mol {
  font-family:var(--font-sans);
  font-size:.62rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:6px 12px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:20px;
  color:rgba(255,255,255,.4);
  cursor:pointer;
  transition:var(--transition);
}
.footer-soc-btn-mol:hover { border-color:#e8a87a; color:#e8a87a; }
.footer-col-title-mol { font-family:var(--font-sans); font-size:.6rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.25); margin-bottom:var(--sp-md); }
.footer-links-mol { list-style:none; padding:0; }
.footer-links-mol li { margin-bottom:8px; }
.footer-links-mol a { font-family:var(--font-sans); font-size:.88rem; color:rgba(255,255,255,.45); transition:color var(--dur); }
.footer-links-mol a:hover { color:#e8a87a; }
.footer-bottom-mol {
  border-top:1px solid rgba(255,255,255,.08);
  padding:var(--sp-md) 0;
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-sans); font-size:.65rem; letter-spacing:.05em;
  flex-wrap:wrap; gap:8px;
}

/* ============================================================
   ПАГИНАЦИЯ
   ============================================================ */
.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(--warm-line);
  border-radius:50%;
  font-family:var(--font-sans); font-size:.8rem; font-weight:700;
  color:var(--ink-faint);
  transition:var(--transition);
}
.page-numbers:hover,.page-numbers.current { border-color:var(--terra); color:var(--terra); background:var(--warm-bg); }

/* 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-sans); font-size:.65rem; color:var(--ink-ghost); text-align:center; margin-top:6px; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ============================================================
   АДАПТИВ — ПЛАНШЕТ
   ============================================================ */
@media (max-width:1100px) {
  :root { --sidebar:220px; }
  .masonry-hero { grid-template-columns:1fr 1fr; }
  .tile-main { grid-column:1 / 3; grid-row:1; }
  .tile-row-pair { grid-column:1 / 3; grid-row:3; }
  .footer-grid-mol { grid-template-columns:1fr 1fr; gap:var(--sp-lg); }
  .mosaic-grid { grid-template-columns:1fr 1fr; }
}

@media (max-width:768px) {
  /* Шапка */
  .header-top { padding:10px 0 8px; }
  .logo-main { font-size:1.5rem; }
  .logo-tagline { display:none; }
  .btn-subscribe-mol { display:none; }
  .btn-hamburger-mol { display:flex; }
  .header-nav { display:none; }

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

  /* Герой */
  .masonry-hero { grid-template-columns:1fr; }
  .tile-main,.tile-sm { grid-column:auto; grid-row:auto; }
  .tile-row-pair { grid-column:auto; grid-row:auto; grid-template-columns:1fr 1fr; }

  /* Контент */
  .feature-banner { grid-template-columns:1fr; }
  .feature-img-wrap { display:none; }
  .mosaic-grid { grid-template-columns:1fr; }

  /* Лента */
  .feed-item:hover { margin:0; padding-left:0; padding-right:0; }

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

@media (max-width:400px) {
  .container { padding:0 12px; }
  .logo-main { font-size:1.3rem; }
  .tile-row-pair { grid-template-columns:1fr; }
}

/* ============================================================
   КОММЕНТАРИИ — СТИЛИЗАЦИЯ ПОД ТЕМУ МолекулаN₂O
   ============================================================ */

/* Заголовок секции комментариев */
.comments-area {
  margin-top: var(--sp-2xl);
  padding-top: var(--sp-xl);
  border-top: 2px solid var(--warm-line);
}

.comments-title,
.comment-reply-title {
  font-family: var(--font-disp);
  font-style: italic;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: var(--sp-lg);
}

.comment-reply-title {
  font-size: 1.2rem;
  margin-bottom: var(--sp-md);
}

/* Список комментариев */
.comment-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-xl);
}

.comment-list .children {
  list-style: none;
  padding-left: var(--sp-xl);
  margin-top: var(--sp-md);
  border-left: 2px solid var(--warm-line);
}

/* Одиночный комментарий */
.comment-body {
  background: var(--white);
  border: 1px solid var(--warm-line);
  border-radius: var(--r-lg);
  padding: var(--sp-lg);
  margin-bottom: var(--sp-md);
  transition: border-color var(--dur);
}

.comment-body:hover {
  border-color: var(--terra);
}

/* Шапка комментария */
.comment-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
  margin-bottom: var(--sp-md);
}

.comment-author {
  display: flex;
  align-items: center;
  gap: 10px;
}

.comment-author img {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid var(--warm-line);
  flex-shrink: 0;
}

.comment-author .fn {
  font-family: var(--font-sans);
  font-size: .92rem;
  font-weight: 700;
  color: var(--ink);
  font-style: normal;
}

.comment-author .url {
  color: var(--terra);
}

.comment-metadata {
  margin-left: auto;
}

.comment-metadata a {
  font-family: var(--font-sans);
  font-size: .65rem;
  color: var(--ink-ghost);
  letter-spacing: .04em;
  transition: color var(--dur);
}

.comment-metadata a:hover {
  color: var(--terra);
}

/* Текст комментария */
.comment-content {
  font-family: var(--font-serif);
  font-size: .95rem;
  color: var(--ink-soft);
  line-height: 1.75;
}

.comment-content p {
  margin-bottom: var(--sp-sm);
}

.comment-content p:last-child {
  margin-bottom: 0;
}

/* Комментарий на модерации */
.comment-awaiting-moderation {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: .7rem;
  font-weight: 600;
  background: var(--amber-light);
  color: var(--amber-text);
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: var(--sp-sm);
  font-style: normal;
}

/* Ссылка «Ответить» */
.reply {
  margin-top: var(--sp-sm);
}

.comment-reply-link {
  font-family: var(--font-sans);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  border: 1px solid var(--warm-line);
  border-radius: 20px;
  padding: 4px 12px;
  display: inline-block;
  transition: var(--transition);
}

.comment-reply-link:hover {
  border-color: var(--terra);
  color: var(--terra);
  background: var(--warm-bg);
}

/* Нет комментариев */
.no-comments {
  font-family: var(--font-sans);
  font-size: .9rem;
  color: var(--ink-ghost);
  text-align: center;
  padding: var(--sp-xl);
  background: var(--warm-bg);
  border-radius: var(--r-lg);
  margin-bottom: var(--sp-xl);
}

/* ============================================================
   ФОРМА ДОБАВЛЕНИЯ КОММЕНТАРИЯ
   ============================================================ */
.comment-respond {
  background: var(--warm-bg);
  border: 1px solid var(--warm-line);
  border-radius: var(--r-lg);
  padding: var(--sp-xl);
  margin-top: var(--sp-xl);
}

.comment-notes {
  font-family: var(--font-sans);
  font-size: .8rem;
  color: var(--ink-ghost);
  margin-bottom: var(--sp-lg);
}

.comment-notes .required {
  color: var(--terra);
}

/* Поля формы */
.comment-form-comment label,
.comment-form-author label,
.comment-form-email label,
.comment-form-url label {
  display: block;
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 6px;
}

.comment-form-comment textarea,
.comment-form-author input,
.comment-form-email input,
.comment-form-url input {
  width: 100%;
  padding: 10px 14px;
  background: var(--white);
  border: 1.5px solid var(--warm-line);
  border-radius: var(--r-md);
  font-family: var(--font-sans);
  font-size: .9rem;
  color: var(--ink);
  outline: none;
  transition: border-color var(--dur);
  resize: vertical;
}

.comment-form-comment textarea {
  min-height: 120px;
  line-height: 1.65;
}

.comment-form-comment textarea:focus,
.comment-form-author input:focus,
.comment-form-email input:focus,
.comment-form-url input:focus {
  border-color: var(--terra);
  box-shadow: 0 0 0 3px rgba(212,132,90,.1);
}

/* Сетка для имя/email/сайт */
.comment-form-author,
.comment-form-email,
.comment-form-url,
.comment-form-comment {
  margin-bottom: var(--sp-md);
}

/* Чекбокс «запомнить» */
.comment-form-cookies-consent {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: var(--sp-lg);
}

.comment-form-cookies-consent input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin-top: 2px;
  accent-color: var(--terra);
  flex-shrink: 0;
}

.comment-form-cookies-consent label {
  font-family: var(--font-sans);
  font-size: .78rem;
  color: var(--ink-muted);
  line-height: 1.5;
}

/* Кнопка отправки */
.form-submit {
  margin: 0;
}

.form-submit #submit {
  font-family: var(--font-sans);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 12px 28px;
  background: var(--terra);
  color: #fff;
  border: none;
  border-radius: 20px;
  cursor: pointer;
  transition: var(--transition);
}

.form-submit #submit:hover {
  background: var(--terra-text);
  transform: translateY(-1px);
}

/* Обязательные поля */
.required {
  color: var(--terra);
  font-weight: 700;
}

/* Нумерация комментариев */
ol.comment-list {
  counter-reset: none;
}