/*
Theme Name: Millida Blog
Theme URI: https://millida.net/blog
Description: Игровой / Minecraft контент-хаб. Тёмная тема, palette синхронизирована с millida-centrum (Trade redesign 2026-05): зелёный градиент, Unbounded+Manrope, 160px decorative grid, glow CTA.
Author: Millida
Version: 0.5.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: millida-blog
*/

/* Подгружаем те же шрифты, что и millida-centrum */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;700;800&family=Unbounded:wght@500;600;700;800;900&display=swap');

/* ============================================================
   ДИЗАЙН-ТОКЕНЫ — синхронизированы с millida-centrum (Trade redesign 2026-05)
   ============================================================ */
:root,
[data-theme="dark"] {
  /* Surface (из styles/variables.scss проекта millida-centrum) */
  --color-surface-background:#1A1B1C;
  --color-surface-default:#212223;
  --color-surface-inset:#2E2F31;
  --color-surface-light:#3A3B3D;

  /* Совместимость со старыми токенами */
  --bg-primary:#212223;
  --bg-secondary:#1A1B1C;
  --bg-tertiary:#1A1B1C;
  --bg-header:rgba(26,27,28,.85);
  --card-bg:#212223;
  --card-bg-hover:#292A2B;

  /* Text */
  --text-primary:#FFFFFF;
  --text-secondary:#D9D9D9;
  --text-tertiary:#989898;

  /* Borders */
  --border-subtle:rgba(255,255,255,.06);
  --border-strong:rgba(255,255,255,.10);

  /* Primary — green gradient (Trade signature) */
  --color-primary:#5EC64D;
  --color-primary-deep:#11998E;
  --gradient-primary:linear-gradient(45deg,#11998E 0%,#5EC64D 100%);
  --gradient-primary-hover:linear-gradient(45deg,#0F8C82 0%,#54B544 100%);
  --gradient-highlight:linear-gradient(137deg,#0088CC 0%,#00B7FF 100%);
  --color-box-primary:rgba(94,198,77,.10);
  --shadow-glow-primary:0 8px 32px rgba(94,198,77,.25);

  /* Совместимость со старым accent */
  --accent:#5EC64D;
  --accent-hover:#11998E;
  --accent-2:#0088CC;
  --accent-gradient:var(--gradient-primary);

  /* Radii — Trade-style (cards 14, pills 26, big pills 41) */
  --radius-xs:6px;
  --radius-sm:10px;
  --radius-card:14px;
  --radius-lg:20px;
  --radius-pill:26px;
  --radius-pill-lg:41px;

  --maxw:1440px;
  --header-h:96px;

  /* Шрифты — те же что в millida-centrum */
  --font-family-heading:'Unbounded',Manrope,system-ui,'Segoe UI',Roboto,sans-serif;
  --font-family-base:'Manrope',system-ui,'Segoe UI',Roboto,sans-serif;
  --font:var(--font-family-base);

  /* Анимация */
  --ease-out-expo:cubic-bezier(0.19,1,0.22,1);
  --ease-swift:cubic-bezier(0.4,0,0.2,1);
  --duration-swift:180ms;
  --duration-smooth:280ms;
}
*,::after,::before{box-sizing:border-box;margin:0;padding:0;min-width:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;overflow-x:clip;scrollbar-color:var(--color-surface-inset) var(--color-surface-background);scrollbar-width:thin}

/* WebKit scrollbar — тонкий, hover-зелёный градиент (как в millida-centrum) */
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:var(--color-surface-background)}
::-webkit-scrollbar-thumb{background:var(--color-surface-inset);border:3px solid var(--color-surface-background);border-radius:999px;transition:background var(--duration-smooth) var(--ease-swift)}
::-webkit-scrollbar-thumb:hover,::-webkit-scrollbar-thumb:active{background:var(--gradient-primary)}

::selection{background:rgba(94,198,77,.3);text-shadow:none}
::-moz-selection{background:rgba(94,198,77,.3);text-shadow:none}

body{
  font-family:var(--font-family-base);
  background:var(--color-surface-background);
  color:var(--text-primary);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:16px;
  font-weight:500;
  overflow-x:clip;
  position:relative;
  min-height:100vh;
  text-rendering:optimizeLegibility;
  /* Компенсация fixed-хедера 96px (80px на мобайле) */
  padding-top:96px;
}
@media (max-width:768px){body{padding-top:80px}}

/* Декоративная сетка 160×160 на фоне, маска радиально к hero (как в millida-centrum) */
body::before{
  content:'';
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:160px 160px;
  mask-image:radial-gradient(ellipse 100% 80% at 50% 30%,#000 0%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 100% 80% at 50% 30%,#000 0%,transparent 80%);
}
@media (max-width:768px){body::before{background-size:120px 120px}}
body > *{position:relative;z-index:1}

/* Все заголовки — Unbounded 800 (как display в millida-centrum) */
h1,h2,h3,h4,h5,h6,.hero-title,.section-title{
  font-family:var(--font-family-heading);
  font-weight:800;
  letter-spacing:-.01em;
}
/* Диагностика горизонтального overflow: раскомментировать, виновник подсветится красным */
/* *{outline:1px solid rgba(255,0,0,.3) !important} */
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ============================================================
   ХЕДЕР — точная копия millida-centrum/Header.vue
   Fixed 96px (80px mobile), логотип слева, центральная навигация, auth справа.
   На scroll — background меняется на surface-default, padding сжимается.
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:30;
  width:100%;
  background:transparent;
  transition:background var(--duration-smooth) var(--ease-swift);
}
.site-header.is-scrolled{
  background:var(--color-surface-default);
  border-bottom:1px solid var(--border-subtle);
}
.site-header .inner{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1440px;margin-inline:auto;
  padding:32px 0;
  transition:padding var(--duration-smooth) var(--ease-swift);
}
.site-header.is-scrolled .inner{padding:16px 0}
@media (max-width:1536px){
  .site-header .inner{padding:24px 32px}
  .site-header.is-scrolled .inner{padding:16px 32px}
}
@media (max-width:768px){
  .site-header .inner{padding:16px 24px}
}

/* Логотип — точная копия components/icons/Millida.vue */
.brand-wrap{display:flex;align-items:center;flex-shrink:0;margin-right:48px}
.millida-logo{
  display:inline-flex;align-items:center;gap:12px;line-height:1;
  text-decoration:none;
}
.millida-logo__mark{
  width:36px;height:36px;flex-shrink:0;border-radius:8px;display:block;
  transition:transform var(--duration-smooth) var(--ease-out-expo),filter var(--duration-smooth) var(--ease-swift);
}
.millida-logo:hover .millida-logo__mark{transform:translateY(-1px) scale(1.04);filter:brightness(1.08)}
.millida-logo__text{
  font-family:'Unbounded',Manrope,system-ui,sans-serif;
  font-weight:500;font-size:22px;line-height:1;
  letter-spacing:.02em;text-transform:uppercase;
  color:var(--text-primary);white-space:nowrap;
}
.millida-logo__badge{
  font-family:'Caveat',cursive;
  font-weight:700;font-size:24px;line-height:1;
  color:var(--accent,#5EC64D);
  transform:rotate(-8deg) translate(-12px,4px);
  margin-left:-14px;
  white-space:nowrap;
  pointer-events:none;
  position:relative;
  z-index:1;
  text-shadow:
    0 1px 2px rgba(0,0,0,.55),
    0 4px 14px rgba(0,0,0,.35),
    0 0 18px rgba(61,217,100,.25);
}
@media (max-width:768px){
  .millida-logo__mark{width:30px;height:30px}
  .millida-logo__text{font-size:16px}
  .millida-logo__badge{font-size:16px}
  .millida-logo{gap:9px}
}
@media (max-width:380px){
  .millida-logo__badge{display:none}
}

/* Центральная навигация — абсолютно центрированная, как в Header.vue.
   На ширине <1280px перестаёт центрироваться и становится скроллящейся. */
.main-nav{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:flex;align-items:center;gap:2px;
  max-width:calc(100% - 480px); /* оставляем место под лого и actions */
}
@media (max-width:1279px){
  .main-nav{
    position:static;transform:none;
    overflow-x:auto;scrollbar-width:none;
    max-width:none;flex:1;margin:0 16px;
    justify-content:center;
  }
  .main-nav::-webkit-scrollbar{display:none}
}
@media (max-width:768px){.main-nav{display:none}}
.main-nav a{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:var(--radius-pill);
  font-family:var(--font-family-base);font-size:13.5px;font-weight:700;
  color:var(--text-primary);background:transparent;
  border:1px solid transparent;
  white-space:nowrap;
  transition:
    color var(--duration-smooth) var(--ease-swift),
    background-color var(--duration-smooth) var(--ease-swift),
    border-color var(--duration-smooth) var(--ease-swift),
    transform var(--duration-smooth) var(--ease-out-expo);
}
.main-nav a:hover,.main-nav a:focus-visible,.main-nav a.active{
  background:rgba(94,198,77,.12);
  border-color:rgba(94,198,77,.32);
  color:var(--text-primary);
}
.main-nav a:active{transform:scale(0.97);transition-duration:var(--duration-swift)}

/* Правая часть — actions */
.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}

/* ============================================================
   КНОПКИ — точная копия Button.vue из millida-centrum
   Сайз md = 48px высота, 14px радиус (не pill!), padding 0 24px.
   Сайз sm = 40px высота, 12px радиус.
   font-family:Manrope (var--font-bodyMd), weight:700.
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:16px;
  height:48px;padding:0 24px;
  border-radius:14px;border:0;
  font-family:var(--font-family-base);font-size:16px;line-height:24px;font-weight:700;
  letter-spacing:0;
  text-overflow:ellipsis;white-space:nowrap;
  cursor:pointer;overflow:hidden;text-align:center;position:relative;
  transition:
    background var(--duration-smooth) var(--ease-swift),
    border-color var(--duration-smooth) var(--ease-swift),
    transform var(--duration-swift) var(--ease-swift),
    box-shadow var(--duration-smooth) var(--ease-swift);
}
.btn.btn-sm{height:40px;padding:0 20px;border-radius:12px;font-size:14px;line-height:20px;gap:12px}

/* Primary — зелёный градиент */
.btn-primary{
  background:var(--gradient-primary);color:#fff;
  box-shadow:var(--shadow-glow-primary);
}
.btn-primary:hover{
  background:var(--gradient-primary-hover);
  box-shadow:0 12px 36px rgba(94,198,77,.35);
}
.btn-primary:active,.btn-primary:focus-visible{
  background:linear-gradient(45deg,#0C7B72 0%,#4AA33C 100%);
}

/* Default — surface + border */
.btn-default,.btn-ghost{
  background:var(--color-surface-default);color:var(--text-primary);
  border:1px solid var(--border-strong);
}
.btn-default:hover,.btn-ghost:hover{background:#292A2B;border-color:rgba(255,255,255,.15)}
.btn-default:active,.btn-ghost:active,.btn-default:focus-visible,.btn-ghost:focus-visible{
  background:var(--color-surface-inset);border-color:rgba(255,255,255,.20);
}

/* Inset */
.btn-inset{
  background:var(--color-surface-inset);color:var(--text-primary);
  border:1px solid var(--border-subtle);
}
.btn-inset:hover{background:#353638}
.btn-inset:active,.btn-inset:focus-visible{background:var(--color-surface-light)}

.btn:disabled{cursor:default;pointer-events:none;opacity:.5;user-select:none}

/* Icon-only кнопка — квадратная */
.icon-btn{
  width:48px;height:48px;min-width:48px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:14px;
  background:var(--color-surface-default);border:1px solid var(--border-strong);
  color:var(--text-primary);cursor:pointer;
  transition:background var(--duration-smooth) var(--ease-swift),
             border-color var(--duration-smooth) var(--ease-swift),
             transform var(--duration-swift) var(--ease-swift);
}
.icon-btn:hover{background:#292A2B;border-color:rgba(255,255,255,.15)}
.icon-btn:active{transform:scale(0.96)}
.icon-btn svg{display:block}
.nav-toggle{display:none}

/* Поиск в шапке */
.hsearch{display:flex;align-items:center;background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-pill);overflow:hidden}
.hsearch input{background:transparent;border:0;color:var(--text-primary);padding:8px 6px 8px 14px;font-family:var(--font);font-size:14px;width:150px;outline:none}
.hsearch input::placeholder{color:var(--text-tertiary)}
.hsearch button{display:flex;align-items:center;justify-content:center;background:transparent;border:0;color:var(--text-secondary);cursor:pointer;padding:0 12px 0 6px}
.hsearch button:hover{color:var(--accent)}
.hsearch:focus-within{border-color:var(--accent)}

/* Хлебные крошки (SILO + schema) */
.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;color:var(--text-tertiary);margin:8px 0 14px}
.breadcrumbs a{color:var(--text-secondary)}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs .sep{color:var(--text-tertiary)}
.breadcrumbs .current{color:var(--text-tertiary)}

/* Теги статьи */
.post-tags{margin:26px 0 0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px}
.post-tags .tags-label{color:var(--text-tertiary)}
.post-tags a{
  background:var(--card-bg);border:1px solid var(--border-subtle);
  padding:5px 12px;border-radius:var(--radius-pill);color:var(--text-secondary);
}
.post-tags a:hover{border-color:var(--accent);color:var(--text-primary)}

/* Интро-блок главной (слоган + кто мы — E-E-A-T, белый эквивалент) */
.home-intro{margin:34px 0 6px;max-width:880px}
.home-slogan{
  display:inline-block;font-family:"Caveat",cursive;font-weight:700;
  font-size:26px;line-height:1;color:var(--accent);transform:rotate(-5deg);
  margin-bottom:6px;
}
.home-intro h1{font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:4px 0 12px;font-family:"Unbounded",var(--font)}
.home-lead{font-size:16px;line-height:1.7;color:var(--text-secondary)}
.home-lead strong{color:var(--text-primary)}
@media(max-width:600px){
  .home-intro{margin:18px 0 4px}
  .home-intro h1{font-size:19px;margin:2px 0 8px}
  .home-slogan{font-size:16px;margin-bottom:2px}
  .home-lead{font-size:13.5px;line-height:1.55}
  .home-search{margin:14px 0 4px}
}

/* Баннер-строка CTA — точная копия components/content/index/PlatformBanner.vue */
.banner-container{
  width:100%;margin:22px 0 28px;
  display:flex;flex-wrap:wrap;gap:12px;
}
.banner-card{
  appearance:none;outline:none;text-decoration:none;
  display:inline-flex;align-items:center;gap:12px;
  height:56px;padding:0 28px;
  border:1px solid transparent;border-radius:var(--radius-pill);
  cursor:pointer;color:#fff;
  font:700 16px/1 var(--font-family-base),Manrope,sans-serif;
  transition:
    transform var(--duration-swift) var(--ease-swift),
    box-shadow var(--duration-smooth) var(--ease-swift),
    filter var(--duration-smooth) var(--ease-swift),
    background var(--duration-smooth) var(--ease-swift),
    border-color var(--duration-smooth) var(--ease-swift);
}
.banner-card__icon{width:22px;height:22px;flex-shrink:0}
.banner-card__text{line-height:1}
.banner-card:hover{transform:translateY(-1px)}
.banner-card:focus-visible{outline:2px solid var(--color-primary,#5EC64D);outline-offset:3px}

.banner-card--primary{background:var(--gradient-primary)}
.banner-card--primary:hover{box-shadow:var(--shadow-glow-primary);filter:brightness(1.05)}

.banner-card--telegram{background:linear-gradient(135deg,#2aabee,#229ed9)}
.banner-card--telegram:hover{box-shadow:0 8px 24px -10px rgba(42,171,238,.55);filter:brightness(1.05)}

.banner-card--discord,
.banner-card--vk{
  background:var(--color-surface-default);
  border:1px solid var(--border-subtle);
  color:var(--text-secondary);
}
.banner-card--discord:hover,
.banner-card--vk:hover{
  background:var(--color-surface-inset);
  border-color:var(--border-strong);
  color:var(--text-primary);
}
@media (max-width:480px){
  .banner-card{width:100%;justify-content:center;height:52px;padding:0 20px;font-size:15px}
}

/* Поиск — точная копия components/interactive/TextField.vue (вариант inset + isSearch) */
.home-search{margin:22px 0 8px}
.home-search form{
  display:flex;align-items:center;gap:12px;
  background:var(--color-surface-inset);
  border:1px solid transparent;
  border-radius:16px;
  padding:0 16px;
  height:48px;
  max-width:640px;
  transition:border-color var(--duration-smooth) var(--ease-swift);
}
.home-search form:focus-within{border-color:var(--color-primary,#5EC64D)}
.home-search .hs-ico{display:flex;color:var(--text-primary);opacity:.3;flex-shrink:0;transition:opacity var(--duration-smooth) var(--ease-swift)}
.home-search form:focus-within .hs-ico{opacity:1}
.home-search input{
  flex:1;background:transparent;border:0;outline:none;
  color:var(--text-primary);
  font-family:var(--font-family-base);font-size:16px;font-weight:500;
  height:100%;padding:0;min-width:0;
}
.home-search input::placeholder{color:var(--text-tertiary)}
.home-search button{
  flex-shrink:0;background:var(--gradient-primary);color:#fff;border:0;cursor:pointer;
  font-family:var(--font-family-base);font-weight:700;font-size:14px;line-height:20px;
  height:36px;padding:0 16px;border-radius:12px;
  box-shadow:var(--shadow-glow-primary);
  transition:background var(--duration-smooth) var(--ease-swift),box-shadow var(--duration-smooth) var(--ease-swift);
}
.home-search button:hover{background:var(--gradient-primary-hover);box-shadow:0 12px 36px rgba(94,198,77,.35)}
@media(max-width:600px){
  .home-search form{padding:0 12px;gap:10px}
  .home-search input{font-size:15px}
  .home-search button{padding:0 14px;font-size:13px}
}

/* ============================================================
   СЕТКА КАРТОЧЕК
   ============================================================ */
.section-head{
  display:flex;align-items:baseline;justify-content:space-between;
  margin:38px 0 18px;
}
.section-head h2{font-size:22px;font-weight:800;letter-spacing:-.02em}
.section-head a{font-size:14px;color:var(--accent);font-weight:600}

.card-grid{
  display:grid;gap:20px;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
}
.card{
  background:var(--card-bg);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-card);
  overflow:hidden;
  transition:.18s;
  display:flex;flex-direction:column;
}
.card:hover{background:var(--card-bg-hover);border-color:var(--border-strong);transform:translateY(-3px)}
.card .thumb{aspect-ratio:16/9;background:var(--bg-tertiary);overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}
.card .thumb::before{content:"";position:absolute;inset:0;background:var(--thumb-bg) center/cover no-repeat;filter:blur(26px) saturate(1.5) brightness(.85);transform:scale(1.25);z-index:0}
.card .thumb img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;transition:.3s;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45))}
.card:hover .thumb img{transform:scale(1.04)}
.card .body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.card .cat{
  align-self:flex-start;font-size:12px;font-weight:700;color:var(--accent);
  text-transform:uppercase;letter-spacing:.04em;
}
.card h3{font-size:17px;font-weight:700;line-height:1.35}
.card .excerpt{font-size:14px;color:var(--text-secondary);flex:1}
.card .meta{font-size:12px;color:var(--text-tertiary);margin-top:6px}

/* Большая карточка (hero) — картинка кадрируется, НЕ растягивается */
.hero-card{grid-column:1/-1;display:grid;grid-template-columns:1.4fr 1fr;min-height:340px}
.hero-card .thumb{aspect-ratio:auto;height:100%;min-height:340px}
.hero-card .thumb img{object-fit:cover}
.hero-card .body{justify-content:center;padding:36px}
.hero-card h3{font-size:30px;line-height:1.2}
@media(max-width:760px){.hero-card{grid-template-columns:1fr}.hero-card .thumb{min-height:220px;aspect-ratio:16/9}}

/* ============================================================
   СТАТЬЯ
   ============================================================ */
/* Раскладка чтения: статья + правый рельс-оглавление */
.reading-wrap{
  display:grid;grid-template-columns:minmax(0,760px) 250px;
  gap:48px;justify-content:center;align-items:start;
  max-width:1130px;margin:0 auto;padding:0 20px;
}
.reading-wrap .article{max-width:none;margin:40px 0}
.toc-rail{position:sticky;top:calc(var(--header-h) + 18px);align-self:start;margin-top:40px}
.toc-inner{
  border:1px solid var(--border-subtle);border-radius:var(--radius-card);
  background:var(--card-bg);padding:16px 16px 18px;
  max-height:calc(100vh - var(--header-h) - 48px);overflow:auto;
}
.toc-head{
  font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-tertiary);margin-bottom:12px;
}
.toc-nav a{
  display:block;font-size:13.5px;line-height:1.4;color:var(--text-secondary);
  padding:7px 10px;border-left:2px solid transparent;border-radius:0 6px 6px 0;
  transition:.15s;
}
.toc-nav a:hover{color:var(--text-primary);background:var(--card-bg-hover)}
.toc-nav a.lvl-3{padding-left:22px;font-size:12.5px;color:var(--text-tertiary)}
.toc-nav a.active{
  color:var(--accent);border-left-color:var(--accent);
  background:linear-gradient(90deg,rgba(94,198,77,.16),transparent);font-weight:600;
}
.article-body h2,.article-body h3{scroll-margin-top:calc(var(--header-h) + 16px)}
@media(max-width:1080px){
  .reading-wrap{grid-template-columns:minmax(0,760px)}
  .toc-rail{display:none}
}

.article{max-width:760px;margin:40px auto}
.article .cat{color:var(--accent);font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.04em}
.article h1{font-size:38px;font-weight:800;line-height:1.18;letter-spacing:-.02em;margin:12px 0 14px}
.article .meta{color:var(--text-tertiary);font-size:14px;margin-bottom:24px}
.article .cover{position:relative;border-radius:var(--radius-card);overflow:hidden;margin-bottom:30px;background:var(--bg-tertiary);display:flex;justify-content:center;max-height:520px}
.article .cover::before{content:"";position:absolute;inset:0;background:var(--thumb-bg) center/cover no-repeat;filter:blur(34px) saturate(1.5) brightness(.8);transform:scale(1.25);z-index:0}
.article .cover img{position:relative;z-index:1;max-height:520px;width:auto;max-width:100%;height:auto;object-fit:contain;display:block;filter:drop-shadow(0 8px 24px rgba(0,0,0,.5))}
.article-body img{max-width:100%;width:auto;height:auto;max-height:520px;object-fit:contain;display:block;margin:22px auto}
.article-figure{margin:28px 0;border-radius:16px;overflow:hidden;background:var(--color-surface-inset,var(--card-bg));border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;padding:12px}
.article-figure img{display:block;max-width:100%;width:auto;height:auto;max-height:720px;margin:0;border-radius:12px;object-fit:contain}
.article-figure figcaption{display:none}
.article-body p img{margin:22px auto}
.article-body{font-size:18px;line-height:1.75;color:var(--text-secondary)}
.article-body h2{font-size:26px;color:var(--text-primary);margin:38px 0 14px;font-weight:800}
.article-body h3{font-size:21px;color:var(--text-primary);margin:28px 0 12px;font-weight:700}
.article-body p{margin:0 0 18px}
.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article-body ul,.article-body ol{margin:0 0 18px 24px}
.article-body li{margin:6px 0}
.article-body img{border-radius:var(--radius-sm);margin:24px 0}
.article-body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.article-body th,.article-body td{border:1px solid var(--border-subtle);padding:10px 12px;text-align:left}
.article-body th{background:var(--card-bg);color:var(--text-primary)}
.article-body blockquote{
  border-left:3px solid var(--accent);padding:6px 18px;margin:22px 0;
  color:var(--text-primary);background:var(--card-bg);border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.article-body code{background:var(--card-bg);padding:2px 6px;border-radius:4px;font-size:.9em}

/* ============================================================
   CTA-БЛОК (воронка в Millida) — монетизация
   ============================================================ */
.cta{
  margin:40px 0;padding:28px 30px;
  background:linear-gradient(135deg,rgba(94,198,77,.18),rgba(0,177,233,.06));
  border:1px solid var(--accent);
  border-radius:var(--radius-card);
}
.cta h3{font-size:22px;font-weight:800;margin-bottom:8px}
.cta p{color:var(--text-secondary);margin-bottom:18px}
.cta .btn-row{display:flex;gap:12px;flex-wrap:wrap}

/* Related */
.related{margin:50px auto;max-width:1180px}

/* ============================================================
   ПОДВАЛ
   ============================================================ */
.site-footer{
  margin-top:60px;border-top:1px solid var(--border-subtle);
  background:var(--bg-tertiary);padding:40px 0;
}
.footer-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.footer-grid h4{font-size:15px;margin-bottom:12px}
.footer-grid a{display:block;color:var(--text-secondary);font-size:14px;padding:4px 0}
.footer-grid a:hover{color:var(--text-primary)}
.footer-bottom{margin-top:30px;color:var(--text-tertiary);font-size:13px;text-align:center}

/* Пагинация */
.pagination{display:flex;gap:8px;justify-content:center;margin:44px 0;flex-wrap:wrap}
.pagination a,.pagination span{
  padding:9px 15px;border-radius:var(--radius-sm);
  background:var(--card-bg);border:1px solid var(--border-subtle);font-weight:600;font-size:14px;
}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ============================================================
   КОММЕНТАРИИ
   ============================================================ */
.comments-area{max-width:760px;margin:50px auto 0}
.comments-area .comments-title,.comments-area #reply-title{font-size:22px;font-weight:800;margin-bottom:18px}
.comment-list{list-style:none;margin:0;padding:0}
.comment-list li{margin:0 0 16px}
.comment-body{
  background:var(--card-bg);border:1px solid var(--border-subtle);
  border-radius:var(--radius-card);padding:16px 18px;
}
.comment-author{font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.comment-author .avatar{border-radius:50%}
.comment-meta{color:var(--text-tertiary);font-size:12px;margin:2px 0 10px}
.comment-content{color:var(--text-secondary);font-size:15px}
.comment-content p{margin:0 0 8px}
.comment-list .children{list-style:none;margin:14px 0 0 26px;padding:0}
.comment-respond{
  margin-top:30px;background:var(--card-bg);border:1px solid var(--border-subtle);
  border-radius:var(--radius-card);padding:22px 24px;
}
.comment-form label{display:block;font-size:13px;color:var(--text-secondary);margin:10px 0 6px}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea{
  width:100%;background:var(--bg-tertiary);color:var(--text-primary);
  border:1px solid var(--border-subtle);border-radius:var(--radius-sm);
  padding:11px 13px;font-family:var(--font);font-size:15px;
}
.comment-form textarea{min-height:120px;resize:vertical}
.comment-form .form-submit{margin-top:16px}
.comment-form .submit{
  background:var(--accent);color:#fff;border:0;cursor:pointer;
  padding:11px 22px;border-radius:var(--radius-pill);font-weight:700;font-size:14px;
}
.comment-form .submit:hover{background:var(--accent-hover)}
.comment-form-cookies-consent{display:flex;align-items:center;gap:8px}
.comment-form-cookies-consent label{margin:0}
.comment-awaiting-moderation{color:var(--accent-2);font-size:13px;font-style:italic}
.comment-notes,.logged-in-as{color:var(--text-tertiary);font-size:13px}

/* ============================================================
   АДАПТИВ
   ============================================================ */
/* На средних — прячем строку поиска, чтобы меню точно влезло */
@media(max-width:1080px){
  .hsearch{display:none}
  .main-nav a{padding:8px 11px}
}
@media(max-width:880px){
  .nav-toggle{display:inline-flex;width:42px;height:42px;border-radius:12px;
    background:var(--color-surface-default);border:1px solid var(--border-strong);
    color:var(--text-primary);cursor:pointer;
    align-items:center;justify-content:center;
    transition:background var(--duration-smooth) var(--ease-swift),
               border-color var(--duration-smooth) var(--ease-swift);
  }
  .nav-toggle:hover{background:var(--color-surface-inset);border-color:rgba(255,255,255,.18)}
  .nav-toggle:active{transform:scale(0.96)}
  .main-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:var(--color-surface-default);
    border-top:1px solid var(--border-subtle);
    border-bottom:1px solid var(--border-subtle);
    padding:12px 20px;margin:0;gap:4px;
    overflow:visible;
  }
  .main-nav.open{display:flex}
  .main-nav a{padding:12px 16px;font-size:15px;border-radius:12px}
  .article h1{font-size:30px}
  .article-body{font-size:17px}
}
/* Телефоны */
@media(max-width:600px){
  .container{padding:0 14px}
  .reading-wrap{padding:0 14px}
  .reading-wrap .article{margin:24px 0}
  .article h1{font-size:25px}
  .article-body{font-size:16px}
  .article-body h2{font-size:22px}
  .article-body h3{font-size:18px}
  /* широкие таблицы — горизонтальный скролл вместо вылезания */
  .article-body table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .card-grid{grid-template-columns:1fr;gap:12px}
  /* Карточки на мобиле — компактнее */
  .card .body{padding:12px 14px 14px;gap:6px}
  .card h3{font-size:15px;line-height:1.3}
  .card .excerpt{font-size:13px;line-height:1.45}
  .card .meta{font-size:11px}
  .card .cat{font-size:11px}
  /* Первая карточка = как остальные */
  .hero-card{grid-template-columns:1fr;min-height:0}
  .hero-card .thumb{min-height:0;aspect-ratio:16/9}
  .hero-card .body{padding:12px 14px 14px}
  .hero-card h3{font-size:15px;line-height:1.3}
  .section-head{margin:20px 0 10px}
  .section-head h2{font-size:17px}
  .site-header .inner{gap:8px}
  .header-actions{gap:10px;margin-left:auto}
  .btn{padding:0 14px;height:40px;font-size:13px;border-radius:12px;gap:8px}
  .cta{padding:22px 18px}
}
/* Мобильная — прячем «Заказать скин», оставляем только бренд + бургер */
@media(max-width:880px){
  .header-actions .btn-primary{display:none}
}

/* ============================================================
   ПРЕЛОАДЕР (MC-кубики) — чистый CSS, без официальных ассетов
   ============================================================ */
.mb-preloader{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-primary);
  transition:opacity .35s ease,visibility 0s linear .35s;
}
.mb-preloader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
/* Inline SVG-иконка внутри кнопок (line-style, Lucide-like) */
.btn-ico{flex-shrink:0}

.mb-cubes{display:flex;gap:10px}
.mb-cube{
  width:28px;height:28px;display:block;
  image-rendering:pixelated;
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.25));
  animation:mb-bounce 1s infinite ease-in-out;
}
.mb-cube:nth-child(2){animation-delay:.12s}
.mb-cube:nth-child(3){animation-delay:.24s}
.mb-cube:nth-child(4){animation-delay:.36s}
@keyframes mb-bounce{
  0%,80%,100%{transform:translateY(0)}
  40%{transform:translateY(-14px)}
}
@media(prefers-reduced-motion:reduce){
  .mb-cube{animation:none}
}

/* Disclaimer Mojang */
.footer-disclaimer{
  margin-top:18px;padding-top:14px;
  border-top:1px solid var(--border-subtle);
  font-size:12px;line-height:1.5;color:var(--text-tertiary);
  max-width:760px;
}
