/*
Theme Name: Garaje Light
Theme URI: https://avtogaraj.ru/
Description: Лёгкая кастомная тема для авто-издания avtogaraj.ru. Светлый минимал «авто-глянец», mobile-first, системный шрифт, один акцент. Цель — Google PageSpeed (mobile) 90–100. Без jQuery/Google Fonts/слайдеров.
Author: avtogaraj
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: garaje_light
*/

/* ============================================================
   AVTOGARAJ — светлый минимал «авто-глянец»
   Mobile-first. Системный шрифт. Один акцент — гоночный красный.
   Брейкпоинты: 640px (планшет), 1024px (десктоп).
   ============================================================ */

:root{
  --bg:        #ffffff;
  --bg-soft:   #fafafa;
  --ink:       #111111;   /* графитовый основной текст */
  --ink-2:     #6a6a6a;   /* вторичный текст / мета */
  --ink-3:     #9a9a9a;   /* третичный */
  --line:      #e6e6e6;   /* тонкие разделители 1px */
  --line-soft: #efefef;
  --accent:    #e10600;   /* РОВНО один сигнальный цвет */
  --accent-ink:#ffffff;
  --ph:        #e9e9e9;   /* фон-заглушка под фото (нулевой CLS) */

  --sans: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", "Cascadia Mono", Menlo, Consolas, monospace;

  --wrap: 1180px;
  --pad:  16px;
  --header-h: 54px;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
html,body{ overflow-x:hidden; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.5;
  font-synthesis-weight:none;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; }
h1,h2,h3,h4,p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- утилиты ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--pad); }
.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }
.vh{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; }

/* Шильдик-метка рубрики — тонкий скос, моно-набор */
.kicker{
  display:inline-block;
  font-size:.7rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  color:var(--accent);
}
.plate{
  display:inline-block;
  background:var(--accent); color:var(--accent-ink);
  font-size:.7rem; font-weight:800; letter-spacing:.11em; text-transform:uppercase;
  padding:.42em .72em .38em;
  transform:skewX(-11deg);          /* тонкая диагональ авто-темы */
}
.plate > span{ display:inline-block; transform:skewX(11deg); }

/* ============================================================
   HEADER — тонкий, sticky, мобайл-бургер (CSS-only)
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--bg);
  border-bottom:1px solid var(--line);
}
.site-header::after{                 /* тонкая акцентная линия снизу */
  content:""; display:block; height:2px; background:var(--accent);
}
.header-bar{
  height:var(--header-h);
  display:flex; align-items:center; gap:14px;
}
.logo{
  font-weight:800; font-size:1.18rem; letter-spacing:-.01em;
  display:inline-flex; align-items:baseline;
  white-space:nowrap;
}
.logo b{ font-weight:800; }
.logo .dot{ color:var(--accent); }   /* акцентная деталь в лого */

/* бургер / поиск — тап-таргеты ≥44px */
.icon-btn{
  width:44px; height:44px; flex:0 0 44px;
  display:grid; place-items:center;
  background:none; border:0; cursor:pointer; color:var(--ink);
}
.icon-btn svg{ width:22px; height:22px; }

.burger{ margin-left:-10px; }        /* лого + бургер в одну компактную строку */
.search-btn{ margin-left:auto; }

/* off-canvas меню */
.nav-toggle{ position:absolute; opacity:0; width:1px; height:1px; }
.nav{
  position:fixed; inset:0 auto 0 0;
  width:min(80vw,320px);
  background:var(--bg);
  border-right:1px solid var(--line);
  transform:translateX(-100%);
  transition:transform .26s ease;
  z-index:70;
  padding:18px;
  display:flex; flex-direction:column;
  overflow-y:auto;
}
.nav__head{
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:14px; margin-bottom:8px; border-bottom:1px solid var(--line);
}
.nav__head .logo{ font-size:1.05rem; }
.nav a{
  display:block; padding:13px 4px; font-weight:600; font-size:1.05rem;
  border-bottom:1px solid var(--line-soft);
}
.nav a:hover{ color:var(--accent); }
.nav-scrim{
  position:fixed; inset:0; background:rgba(17,17,17,.42);
  opacity:0; visibility:hidden; transition:opacity .26s ease, visibility .26s;
  z-index:65; cursor:default;
}
.nav-toggle:checked ~ .nav{ transform:none; }
.nav-toggle:checked ~ .nav-scrim{ opacity:1; visibility:visible; }
.nav-toggle:focus-visible ~ .burger{ outline:2px solid var(--accent); outline-offset:2px; }

/* ============================================================
   РЕКЛАМНЫЕ СЛОТЫ MPSU — резерв высоты (нулевой CLS)
   ============================================================ */
.ad{ background:var(--bg-soft); display:grid; place-items:center; }
.ad__label{
  font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-3);
}
/* горизонтальный после хедера — на всю ширину вьюпорта */
.ad--leader{
  min-height:100px;                  /* резерв под моб. баннер */
  border-bottom:1px solid var(--line);
}
.ad--leader .ad-inner{ min-height:100px; display:grid; place-items:center; width:100%; }
/* прямоугольный в сайдбаре */
.ad--rect{ min-height:280px; border:1px solid var(--line); }
/* in-article */
.ad--inline{ min-height:120px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin:34px 0; }

/* ============================================================
   LAYOUT — mobile: одна колонка
   ============================================================ */
.layout{ display:grid; gap:34px; padding-block:26px 44px; }

/* ---------- HERO ---------- */
.hero__media{
  display:block;                         /* важно: aspect-ratio не работает на inline */
  position:relative;
  margin-inline:calc(-1 * var(--pad));   /* edge-to-edge на телефоне */
  aspect-ratio:16/10;
  background:var(--ph);
  overflow:hidden;
}
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__plate{ position:absolute; left:14px; top:14px; }
.hero__body{ padding-top:16px; }
.hero h1{
  font-size:clamp(1.7rem, 6.4vw, 3.1rem);
  font-weight:800; line-height:1.04; letter-spacing:-.018em;
  text-wrap:balance;
}
.hero h1 a:hover{ color:var(--accent); }
.hero__excerpt{ color:var(--ink-2); margin-top:12px; font-size:1.06rem; line-height:1.55; max-width:62ch; }
.meta{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; color:var(--ink-2); font-size:.82rem; margin-top:14px; }
.meta .sep{ color:var(--line); }

/* спек-полоска (моноширинные цифры) */
.specs{ display:flex; flex-wrap:wrap; gap:22px; margin-top:18px; padding-top:16px; border-top:1px solid var(--line); }
.spec{ display:flex; flex-direction:column; line-height:1; }
.spec__val{ font-family:var(--mono); font-weight:700; font-size:1.32rem; letter-spacing:-.01em; }
.spec__val small{ font-size:.62em; font-weight:600; color:var(--ink-2); margin-left:.18em; }
.spec__key{ font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-top:7px; }

/* ---------- КАРТОЧКИ ---------- */
.cards{ display:grid; gap:26px; }
.card a{ display:block; }                 /* ссылка-обёртка карточки — блок */
.card__media{ display:block; aspect-ratio:16/10; background:var(--ph); border-radius:10px; overflow:hidden; }
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.card:hover .card__media img{ transform:scale(1.03); }
.card__body{ padding-top:13px; }
.card h2,.card h3{ font-weight:700; font-size:1.22rem; line-height:1.2; letter-spacing:-.01em; margin-top:7px; text-wrap:pretty; }
.card a:hover h2, .card a:hover h3{ color:var(--accent); }
.card .meta{ margin-top:9px; }

/* ---------- ЛЕНТА (список) ---------- */
.lenta-title, .block-title{
  font-size:.82rem; font-weight:800; letter-spacing:.13em; text-transform:uppercase;
  display:flex; align-items:center; gap:10px; margin-bottom:6px;
}
.block-title::before{ content:""; width:18px; height:3px; background:var(--accent); display:inline-block; }
.lenta li{ border-top:1px solid var(--line); }
.lenta a{ display:flex; gap:16px; align-items:baseline; padding:16px 0; }
.lenta a:hover .lenta__h{ color:var(--accent); }
.lenta__date{ font-family:var(--mono); font-size:.74rem; color:var(--ink-3); flex:0 0 auto; padding-top:.18em; }
.lenta__h{ font-weight:600; font-size:1.06rem; line-height:1.3; }

/* ============================================================
   SIDEBAR — реклама + Популярное
   ============================================================ */
.popular .block-title{ margin-bottom:14px; }
.popular li{ border-top:1px solid var(--line); }
.popular li:first-child{ border-top:0; }
.pop-item{ display:grid; grid-template-columns:64px 1fr; gap:13px; padding:14px 0; align-items:start; }
.pop-item__media{ width:64px; height:64px; border-radius:8px; overflow:hidden; background:var(--ph); position:relative; }
.pop-item__media img{ width:100%; height:100%; object-fit:cover; }
.pop-item__num{
  position:absolute; left:0; top:0;
  font-family:var(--mono); font-size:.6rem; font-weight:700;
  background:var(--accent); color:#fff; padding:2px 5px;
}
.pop-item h4{ font-weight:600; font-size:.96rem; line-height:1.28; }
.pop-item:hover h4{ color:var(--accent); }
.pop-item .meta{ margin-top:6px; font-size:.74rem; }

/* ============================================================
   SINGLE — статья
   ============================================================ */
.article{ max-width:720px; }
.article__head .plate{ margin-bottom:16px; }
.article h1{
  font-size:clamp(1.8rem, 6.6vw, 2.9rem);
  font-weight:800; line-height:1.06; letter-spacing:-.018em; text-wrap:balance;
}
.article__byline{ display:flex; gap:10px; flex-wrap:wrap; color:var(--ink-2); font-size:.84rem; margin-top:16px; }
.article__byline b{ color:var(--ink); font-weight:600; }
.article__lead{
  margin:22px calc(-1 * var(--pad)) 0;   /* edge-to-edge лид-фото на телефоне */
  aspect-ratio:16/9; background:var(--ph); overflow:hidden; position:relative;
}
.article__lead img{ width:100%; height:100%; object-fit:cover; }
.article__caption{ font-size:.78rem; color:var(--ink-3); padding:9px var(--pad) 0; }

.prose{ font-size:1.13rem; line-height:1.68; margin-top:26px; }
.prose > * + *{ margin-top:1.15em; }
.prose p{ color:#1c1c1c; }
.prose .lead-p{ font-size:1.22rem; line-height:1.55; color:var(--ink); font-weight:500; }
.prose h2{ font-size:1.5rem; font-weight:800; letter-spacing:-.01em; margin-top:1.6em; line-height:1.2; }
.prose a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; }
.prose strong{ font-weight:700; }
.prose figure{ margin:1.6em calc(-1 * var(--pad)) 0; }
.prose figure img{ width:100%; aspect-ratio:16/9; object-fit:cover; background:var(--ph); }
.prose figcaption{ font-size:.78rem; color:var(--ink-3); padding:9px var(--pad) 0; }

/* врезка-цитата (без коробок-теней, тонкая акцентная линия сверху) */
.pullquote{ margin-top:1.6em; padding-top:18px; border-top:2px solid var(--accent); }
.pullquote p{ font-size:1.42rem; line-height:1.32; font-weight:700; letter-spacing:-.01em; }

/* таблица характеристик — моно-цифры */
.spec-table{ margin-top:1.6em; border-top:1px solid var(--ink); }
.spec-table .row{ display:flex; justify-content:space-between; gap:16px; padding:12px 0; border-bottom:1px solid var(--line); }
.spec-table .k{ color:var(--ink-2); font-size:.96rem; }
.spec-table .v{ font-family:var(--mono); font-weight:700; font-variant-numeric:tabular-nums; }

/* ---------- ПОХОЖИЕ ---------- */
.related{ margin-top:46px; padding-top:30px; border-top:1px solid var(--line); }
.related .block-title{ margin-bottom:20px; }
.related-grid{ display:grid; gap:24px; }

/* ============================================================
   ПАГИНАЦИЯ — кнопки 1·2·3 … (в стиле темы)
   ============================================================ */
.screen-reader-text{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; }
.pagination{ margin:42px auto 0; padding-top:28px; border-top:1px solid var(--line); }
.pagination .nav-links{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.pagination .page-numbers{
  min-width:46px; height:46px; padding:0 14px;
  display:inline-grid; place-items:center;
  border:1px solid var(--line); border-radius:9px;
  font-weight:700; font-variant-numeric:tabular-nums; color:var(--ink);
  transition:border-color .15s ease, color .15s ease;
}
.pagination a.page-numbers:hover{ border-color:var(--accent); color:var(--accent); }
.pagination .page-numbers.current{ background:var(--accent); border-color:var(--accent); color:#fff; }
.pagination .page-numbers.dots{ border:0; min-width:auto; padding:0 4px; color:var(--ink-3); }
.pagination .page-numbers.prev,
.pagination .page-numbers.next{ font-weight:600; }

/* ============================================================
   FOOTER — минимальный
   ============================================================ */
.site-footer{ border-top:1px solid var(--line); background:var(--bg-soft); margin-top:30px; }
.footer-inner{ padding-block:34px; display:flex; flex-direction:column; gap:18px; }
.footer-nav{ display:flex; flex-wrap:wrap; gap:8px 22px; }
.footer-nav a{ font-size:.92rem; color:var(--ink-2); }
.footer-nav a:hover{ color:var(--accent); }
.copy{ font-size:.8rem; color:var(--ink-3); }
.copy .mono{ color:var(--ink-2); }

/* ============================================================
   ≥ 640px — планшет
   ============================================================ */
@media (min-width:640px){
  :root{ --pad:24px; }
  .cards{ grid-template-columns:1fr 1fr; gap:30px 30px; }
  .hero__media{ margin-inline:0; border-radius:12px; aspect-ratio:16/9; }
  .hero__plate{ left:18px; top:18px; }
  .article__lead{ margin-inline:0; border-radius:12px; }
  .article__caption{ padding-inline:0; }
  .prose figure{ margin-inline:0; }
  .prose figure img{ border-radius:12px; }
  .prose figcaption{ padding-inline:0; }
  .related-grid{ grid-template-columns:1fr 1fr 1fr; }
  .footer-inner{ flex-direction:row; align-items:center; justify-content:space-between; }
}

/* ============================================================
   ≥ 1024px — десктоп: двухколоночный рефлоу через grid-areas
   ============================================================ */
@media (min-width:1024px){
  :root{ --pad:32px; --header-h:60px; }

  /* инлайн-навигация, прячем off-canvas механику */
  .burger{ display:none; }
  .nav-scrim{ display:none; }
  .nav{
    position:static; transform:none; width:auto; height:auto;
    border:0; padding:0; overflow:visible;
    flex-direction:row; align-items:center; gap:4px;
    margin-left:8px;
  }
  .nav__head{ display:none; }
  .nav a{ border:0; padding:10px 14px; font-size:.95rem; font-weight:600; }

  /* Главная: рефлоу — реклама и Популярное уезжают в правую колонку */
  .layout--home{
    grid-template-columns:minmax(0,1fr) 320px;
    column-gap:56px; row-gap:40px;
    align-items:start;
    grid-template-areas:
      "hero   ad"
      "cards1 pop"
      "cards2 pop"
      "lenta  pop";
  }
  .layout--home .hero    { grid-area:hero; }
  .layout--home .cards--1{ grid-area:cards1; }
  .layout--home .cards--2{ grid-area:cards2; }
  .layout--home .lenta   { grid-area:lenta; }
  .layout--home .ad--rect{ grid-area:ad; }
  .layout--home .popular { grid-area:pop; position:sticky; top:calc(var(--header-h) + 18px); align-self:start; }

  /* Статья: читаемая колонка + sticky-сайдбар */
  .layout--single{
    grid-template-columns:minmax(0,720px) 320px;
    column-gap:64px; row-gap:0;
    justify-content:center;
    align-items:start;
    grid-template-areas:
      "main ad"
      "main pop";
  }
  .layout--single .article{ grid-area:main; max-width:none; }
  .layout--single .ad--rect{ grid-area:ad; }
  .layout--single .popular { grid-area:pop; position:sticky; top:calc(var(--header-h) + 18px); align-self:start; }

  .hero h1{ line-height:1.02; }
  .hero__body{ padding-top:20px; }
  .related-grid{ grid-template-columns:1fr 1fr 1fr; }
}

/* доступность: уважать reduce-motion */
@media (prefers-reduced-motion:reduce){
  *{ transition:none !important; }
}
