/* ============================================================
   haval-auto.com — Design System
   Clean, near-monochrome, data-first expert reference.
   Sparing Haval-red accent. Soft cards, neat shadows.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Golos+Text:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  /* surfaces */
  --bg:        oklch(0.984 0.003 255);
  --surface:   #ffffff;
  --surface-2: oklch(0.974 0.004 255);
  --surface-3: oklch(0.962 0.005 255);
  --border:    oklch(0.918 0.005 258);
  --border-strong: oklch(0.862 0.007 258);

  /* ink */
  --ink:   oklch(0.235 0.013 268);
  --ink-2: oklch(0.435 0.013 268);
  --ink-3: oklch(0.560 0.011 268);
  --ink-4: oklch(0.680 0.009 268);

  /* accent — Haval red, used sparingly */
  --accent:      oklch(0.555 0.205 26);
  --accent-ink:  oklch(0.495 0.210 27);
  --accent-soft: oklch(0.962 0.030 25);
  --accent-line: oklch(0.880 0.060 25);

  /* semantic */
  --good:      oklch(0.560 0.120 156);
  --good-soft: oklch(0.960 0.035 156);
  --warn:      oklch(0.640 0.140 58);
  --warn-soft: oklch(0.962 0.045 75);
  --info:      oklch(0.560 0.110 250);

  --radius-xl: 20px;
  --radius-lg: 16px;
  --radius:    12px;
  --radius-sm: 9px;

  --shadow-xs: 0 1px 2px rgba(17,19,26,.05);
  --shadow-sm: 0 1px 2px rgba(17,19,26,.04), 0 1px 3px rgba(17,19,26,.05);
  --shadow:    0 2px 4px rgba(17,19,26,.04), 0 6px 16px rgba(17,19,26,.06);
  --shadow-lg: 0 12px 32px rgba(17,19,26,.09), 0 3px 8px rgba(17,19,26,.05);

  --maxw: 1240px;
  --font: 'Golos Text', system-ui, -apple-system, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;

  --header-h: 64px;
  --anchor-h: 56px;
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font); font-size:16px; line-height:1.55;
  font-feature-settings:"ss01","cv01";
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,p,figure,ul,ol{ margin:0; }
ul,ol{ padding:0; list-style:none; }
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; cursor:pointer; border:none; background:none; }
table{ border-collapse:collapse; width:100%; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; border-radius:4px; }
::selection{ background:var(--accent-soft); }

/* ---------- layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding:54px 0; }
.section--tight{ padding:36px 0; }
.stack{ display:flex; flex-direction:column; }
.row{ display:flex; align-items:center; }
.spread{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.grow{ flex:1; }
.muted{ color:var(--ink-3); }
.hr{ height:1px; background:var(--border); border:0; margin:0; }

/* ---------- typography ---------- */
.eyebrow{
  font-family:var(--mono); font-size:11.5px; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink-4);
}
.display{ font-size:clamp(30px,4vw,46px); font-weight:700; line-height:1.05; letter-spacing:-.02em; }
.h-section{ font-size:clamp(22px,2.6vw,30px); font-weight:700; letter-spacing:-.015em; line-height:1.1; }
.h-card{ font-size:18px; font-weight:600; letter-spacing:-.01em; }
.lead{ font-size:18px; color:var(--ink-2); line-height:1.55; }
.small{ font-size:13.5px; }
.tiny{ font-size:12px; }
.mono{ font-family:var(--mono); font-feature-settings:"tnum"; }
.num{ font-variant-numeric:tabular-nums; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:24px; flex-wrap:wrap; }
.section-head p{ color:var(--ink-3); max-width:62ch; margin-top:8px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:44px; padding:0 18px; border-radius:var(--radius-sm);
  font-weight:600; font-size:14.5px; letter-spacing:-.005em;
  background:var(--surface); color:var(--ink); border:1px solid var(--border-strong);
  transition:background .15s, border-color .15s, transform .06s, box-shadow .15s;
  white-space:nowrap;
}
.btn:hover{ background:var(--surface-2); border-color:var(--ink-4); }
.btn:active{ transform:translateY(1px); }
.btn--primary{ background:var(--ink); color:#fff; border-color:var(--ink); }
.btn--primary:hover{ background:#000; border-color:#000; }
.btn--accent{ background:var(--accent); color:#fff; border-color:var(--accent); }
.btn--accent:hover{ background:var(--accent-ink); border-color:var(--accent-ink); }
.btn--ghost{ background:transparent; border-color:transparent; }
.btn--ghost:hover{ background:var(--surface-2); }
.btn--sm{ height:36px; padding:0 14px; font-size:13.5px; }
.btn svg{ width:17px; height:17px; }

/* ---------- chips / pills ---------- */
.chip{
  display:inline-flex; align-items:center; gap:7px;
  height:36px; padding:0 14px; border-radius:999px;
  border:1px solid var(--border-strong); background:var(--surface);
  font-size:14px; font-weight:500; color:var(--ink-2);
  transition:background .14s, border-color .14s, color .14s;
}
.chip:hover{ border-color:var(--ink-4); color:var(--ink); }
.chip[aria-pressed="true"], .chip.is-active{
  background:var(--ink); color:#fff; border-color:var(--ink);
}
.chip{ white-space:nowrap; }
.chip svg{ width:16px; height:16px; opacity:.7; flex:none; }
.chip-row{ display:flex; flex-wrap:wrap; gap:9px; }

.tag{
  display:inline-flex; align-items:center; gap:6px;
  padding:3px 9px; border-radius:6px; font-size:12px; font-weight:600;
  background:var(--surface-2); color:var(--ink-2); border:1px solid var(--border); white-space:nowrap;
}
.tag--accent{ background:var(--accent-soft); color:var(--accent-ink); border-color:var(--accent-line); }
.tag--good{ background:var(--good-soft); color:var(--good); border-color:color-mix(in oklch,var(--good) 30%, white); }
.tag--warn{ background:var(--warn-soft); color:oklch(0.5 0.13 58); border-color:color-mix(in oklch,var(--warn) 30%, white); }
.tag--live{ }
.dot{ width:7px; height:7px; border-radius:50%; background:var(--good); box-shadow:0 0 0 3px var(--good-soft); }

/* ---------- cards ---------- */
.card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-sm);
}
.card--pad{ padding:22px; }
.card--hover{ transition:box-shadow .18s, border-color .18s, transform .18s; }
.card--hover:hover{ box-shadow:var(--shadow); border-color:var(--border-strong); transform:translateY(-2px); }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--surface) 86%, transparent);
  backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid var(--border);
}
.site-header .wrap{ height:var(--header-h); display:flex; align-items:center; gap:18px; }
.brand{ display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:-.02em; font-size:17px; }
.brand .mark{
  width:30px; height:30px; border-radius:8px; background:var(--ink); color:#fff;
  display:grid; place-items:center; font-weight:800; font-size:15px; letter-spacing:-.04em;
}
.brand .mark span{ color:var(--accent); }
.brand .tld{ color:var(--ink-4); font-weight:500; }
.main-nav{ display:flex; align-items:center; gap:2px; margin-left:6px; }
.main-nav a{
  padding:8px 12px; border-radius:8px; font-size:14.5px; font-weight:500; color:var(--ink-2);
  transition:background .14s, color .14s;
}
.main-nav a:hover{ background:var(--surface-2); color:var(--ink); }
.main-nav a.is-active{ color:var(--ink); font-weight:600; }
.header-search{
  margin-left:auto; display:flex; align-items:center; gap:9px;
  height:40px; padding:0 12px; min-width:240px;
  background:var(--surface-2); border:1px solid var(--border); border-radius:10px;
  color:var(--ink-3); transition:border-color .15s, background .15s;
}
.header-search:focus-within{ border-color:var(--ink-4); background:var(--surface); }
.header-search svg{ width:17px; height:17px; flex:none; }
.header-search input{ border:0; background:none; outline:none; font:inherit; font-size:14px; color:var(--ink); width:100%; }
.header-search kbd{
  font-family:var(--mono); font-size:11px; color:var(--ink-4);
  border:1px solid var(--border-strong); border-radius:5px; padding:1px 6px; background:var(--surface);
}
.hmenu-btn{ display:none; margin-left:auto; width:40px; height:40px; border-radius:9px; border:1px solid var(--border); background:var(--surface); }

/* ---------- breadcrumbs ---------- */
.crumbs{ display:flex; flex-wrap:wrap; align-items:center; gap:7px; font-size:13px; color:var(--ink-3); }
.crumbs a:hover{ color:var(--ink); }
.crumbs .sep{ color:var(--ink-4); }
.crumbs [aria-current]{ color:var(--ink-2); font-weight:500; }

/* ---------- image placeholder ---------- */
.thumb{
  position:relative; border-radius:var(--radius); overflow:hidden;
  background:
    linear-gradient(135deg, var(--surface-2), var(--surface-3));
  border:1px solid var(--border);
  display:grid; place-items:center; color:var(--ink-4);
  aspect-ratio:16/10;
}
.thumb::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(45deg, oklch(0.93 0.005 255) 25%, transparent 25%, transparent 75%, oklch(0.93 0.005 255) 75%);
  background-size:14px 14px; background-position:0 0,7px 7px; opacity:.35;
}
.thumb svg{ position:relative; width:46%; max-width:150px; opacity:.5; }
.thumb .ph-label{
  position:absolute; bottom:10px; right:11px; font-family:var(--mono);
  font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-4); white-space:nowrap;
  background:color-mix(in srgb,var(--surface) 80%, transparent); padding:2px 7px; border-radius:5px;
}
/* реальное фото поверх заглушки (подставляется из assets/models/<slug>.webp) */
.thumb .thumb-photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; }
.thumb.has-photo::before{ display:none; }
.thumb.has-photo svg{ display:none; }
.thumb.has-photo .ph-label{ display:none; }

/* ---------- data tables ---------- */
.table-wrap{ overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--surface); box-shadow:var(--shadow-sm); -webkit-overflow-scrolling:touch; }
table.data{ font-size:14.5px; min-width:560px; }
table.data thead th{
  text-align:left; font-weight:600; font-size:12px; letter-spacing:.04em; text-transform:uppercase;
  color:var(--ink-3); padding:14px 16px; background:var(--surface-2); border-bottom:1px solid var(--border);
  white-space:nowrap;
}
table.data tbody td, table.data tbody th{ padding:14px 16px; border-bottom:1px solid var(--border); vertical-align:middle; text-align:left; }
table.data tbody tr:last-child td, table.data tbody tr:last-child th{ border-bottom:0; }
table.data tbody tr:hover{ background:var(--surface-2); }
table.data .row-label{ font-weight:600; color:var(--ink); }
table.data .val{ font-variant-numeric:tabular-nums; }
table.data .secondary{ color:var(--ink-3); font-size:13px; }
.price{ font-family:var(--mono); font-weight:600; font-variant-numeric:tabular-nums; white-space:nowrap; }
.tbd{ color:var(--ink-4); font-style:normal; }
.tbd::after{ content:" уточняется"; font-size:12px; color:var(--ink-4); }
.dash{ color:var(--border-strong); }

/* spec list (label : value) */
.spec-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:0; border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; background:var(--surface); }
.spec-grid .spec{ padding:15px 18px; border-bottom:1px solid var(--border); border-right:1px solid var(--border); }
.spec-grid .spec .k{ font-size:12.5px; color:var(--ink-3); margin-bottom:3px; }
.spec-grid .spec .v{ font-weight:600; font-variant-numeric:tabular-nums; }

/* key-fact stat cards */
.facts{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; }
.fact{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:15px 16px; box-shadow:var(--shadow-xs); }
.fact .k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); margin-bottom:7px; }
.fact .v{ font-size:21px; font-weight:700; letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.fact .u{ font-size:13px; color:var(--ink-3); font-weight:500; }

/* ---------- pros / cons ---------- */
.proscons{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.pc{ border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; background:var(--surface); }
.pc h4{ display:flex; align-items:center; gap:9px; font-size:15px; margin-bottom:14px; }
.pc ul li{ display:flex; gap:10px; padding:8px 0; font-size:14.5px; color:var(--ink-2); border-top:1px solid var(--border); }
.pc ul li:first-child{ border-top:0; }
.pc .ic{ flex:none; width:18px; height:18px; margin-top:2px; }
.pc--pro .ic{ color:var(--good); }
.pc--con .ic{ color:var(--accent); }

/* fit-for / not-for */
.fit{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fit .col{ padding:20px; border-radius:var(--radius-lg); border:1px solid var(--border); }
.fit .col h4{ font-size:15px; margin-bottom:12px; display:flex; gap:8px; align-items:center; }
.fit .col li{ padding:7px 0; color:var(--ink-2); font-size:14.5px; display:flex; gap:9px; }
.fit .yes{ background:var(--good-soft); border-color:color-mix(in oklch,var(--good) 22%, white); }
.fit .no{ background:var(--surface-2); }

/* ---------- callout / short answer ---------- */
.answer{
  border:1px solid var(--border-strong); border-radius:var(--radius-lg);
  background:var(--surface); padding:22px 24px; box-shadow:var(--shadow-sm);
  position:relative; border-left:3px solid var(--ink);
}
.answer .lbl{ display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.answer p{ font-size:16.5px; color:var(--ink); line-height:1.6; }
.answer p + p{ margin-top:10px; }
.note{
  display:flex; gap:12px; padding:14px 16px; border-radius:var(--radius);
  background:var(--warn-soft); border:1px solid color-mix(in oklch,var(--warn) 25%, white);
  font-size:13.5px; color:oklch(0.42 0.08 60);
}
.note svg{ flex:none; width:18px; height:18px; color:var(--warn); margin-top:1px; }
.note--info{ background:var(--surface-2); border-color:var(--border); color:var(--ink-2); }
.note--info svg{ color:var(--info); }

/* ---------- FAQ accordion ---------- */
.faq{ border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--surface); overflow:hidden; box-shadow:var(--shadow-sm); }
.faq-item{ border-bottom:1px solid var(--border); }
.faq-item:last-child{ border-bottom:0; }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:18px 20px; text-align:left; font-weight:600; font-size:15.5px; }
.faq-q:hover{ background:var(--surface-2); }
.faq-q .ic{ flex:none; width:20px; height:20px; color:var(--ink-3); transition:transform .2s; }
.faq-item.open .faq-q .ic{ transform:rotate(45deg); color:var(--accent); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .26s ease; }
.faq-a-inner{ padding:0 20px 18px; color:var(--ink-2); font-size:14.5px; line-height:1.6; max-width:74ch; }

/* ---------- anchor (sticky model nav) ---------- */
.anchorbar{ position:sticky; top:var(--header-h); z-index:40; background:color-mix(in srgb,var(--surface) 90%, transparent); backdrop-filter:blur(10px); border-bottom:1px solid var(--border); }
.anchorbar .wrap{ height:var(--anchor-h); display:flex; align-items:center; gap:4px; overflow-x:auto; scrollbar-width:none; }
.anchorbar .wrap::-webkit-scrollbar{ display:none; }
.anchorbar a{ padding:7px 13px; border-radius:8px; font-size:13.5px; font-weight:500; color:var(--ink-3); white-space:nowrap; transition:background .14s,color .14s; }
.anchorbar a:hover{ background:var(--surface-2); color:var(--ink); }
.anchorbar a.is-active{ background:var(--ink); color:#fff; }

/* ---------- model card ---------- */
.model-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.mcard{ display:flex; flex-direction:column; overflow:hidden; }
.mcard .thumb{ border-radius:0; border-left:0; border-right:0; border-top:0; aspect-ratio:16/10; }
.mcard .mbody{ padding:18px; display:flex; flex-direction:column; gap:14px; flex:1; }
.mcard .mtop{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.mcard h3{ font-size:18px; font-weight:700; letter-spacing:-.01em; }
.mcard .mcat{ font-size:12.5px; color:var(--ink-3); margin-top:2px; }
.mcard .mprice{ text-align:right; }
.mcard .mprice .from{ font-size:11px; color:var(--ink-4); }
.mcard .mprice .val{ font-family:var(--mono); font-weight:600; font-size:15px; }
.mcard .mspecs{ display:grid; grid-template-columns:1fr 1fr; gap:9px 14px; padding:13px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.mcard .mspecs .s{ display:flex; flex-direction:column; }
.mcard .mspecs .s .k{ font-size:11px; color:var(--ink-4); }
.mcard .mspecs .s .v{ font-size:13.5px; font-weight:600; font-variant-numeric:tabular-nums; }
.mcard .mfit{ font-size:13px; color:var(--ink-2); line-height:1.45; }
.mcard .mfit b{ color:var(--ink); font-weight:600; }
.mcard .mcta{ margin-top:auto; display:flex; gap:8px; }

/* ---------- list rows (guides, problems, articles) ---------- */
.linklist{ border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--surface); overflow:hidden; box-shadow:var(--shadow-sm); }
.linkrow{ display:flex; align-items:center; gap:14px; padding:15px 18px; border-bottom:1px solid var(--border); transition:background .14s; }
.linkrow:last-child{ border-bottom:0; }
.linkrow:hover{ background:var(--surface-2); }
.linkrow .lr-ic{ flex:none; width:38px; height:38px; border-radius:9px; background:var(--surface-2); border:1px solid var(--border); display:grid; place-items:center; color:var(--ink-3); }
.linkrow .lr-ic svg{ width:18px; height:18px; }
.linkrow .lr-main{ flex:1; min-width:0; }
.linkrow .lr-title{ display:block; font-weight:600; font-size:14.5px; }
.linkrow .lr-sub{ display:block; font-size:12.5px; color:var(--ink-3); margin-top:1px; }
.linkrow .lr-meta{ font-size:12px; color:var(--ink-4); white-space:nowrap; }
.linkrow .lr-arrow{ color:var(--ink-4); flex:none; }

/* review cards */
.reviews{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:14px; }
.review{ padding:18px; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); box-shadow:var(--shadow-xs); }
.review .rhead{ display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.review .av{ width:34px; height:34px; border-radius:50%; background:var(--surface-3); border:1px solid var(--border); display:grid; place-items:center; font-weight:700; font-size:13px; color:var(--ink-2); }
.review .rname{ font-weight:600; font-size:14px; }
.review .rmeta{ font-size:11.5px; color:var(--ink-4); }
.review p{ font-size:13.8px; color:var(--ink-2); line-height:1.55; }
.stars{ display:inline-flex; gap:1px; color:var(--accent); }
.stars svg{ width:14px; height:14px; }

/* rating summary */
.rating-sum{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; padding:20px; border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--surface); box-shadow:var(--shadow-sm); }
.rating-sum .big{ font-size:44px; font-weight:800; letter-spacing:-.03em; line-height:1; }
.rating-sum .bars{ flex:1; min-width:200px; display:flex; flex-direction:column; gap:5px; }
.rating-sum .bar{ display:flex; align-items:center; gap:10px; font-size:12px; color:var(--ink-3); }
.rating-sum .bar .track{ flex:1; height:7px; border-radius:4px; background:var(--surface-3); overflow:hidden; }
.rating-sum .bar .fill{ height:100%; background:var(--ink); border-radius:4px; }

/* updated meta */
.updated{ display:inline-flex; align-items:center; gap:8px; font-size:12.5px; color:var(--ink-3); }
.updated svg{ width:15px; height:15px; color:var(--ink-4); }
.editorial{ display:flex; align-items:center; gap:11px; padding:12px 16px; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface-2); font-size:13px; color:var(--ink-2); }
.editorial .badge{ width:32px; height:32px; border-radius:8px; background:var(--surface); border:1px solid var(--border); display:grid; place-items:center; color:var(--good); flex:none; }

/* ---------- selector tool ---------- */
.selector{ display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:14px; }
.selcard{ padding:18px; border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--surface); box-shadow:var(--shadow-xs); transition:box-shadow .16s,transform .16s,border-color .16s; }
.selcard:hover{ box-shadow:var(--shadow); transform:translateY(-2px); border-color:var(--border-strong); }
.selcard .ic{ width:40px; height:40px; border-radius:10px; background:var(--surface-2); border:1px solid var(--border); display:grid; place-items:center; color:var(--ink-2); margin-bottom:12px; }
.selcard .ic svg{ width:20px; height:20px; }
.selcard h4{ font-size:15.5px; margin-bottom:4px; }
.selcard p{ font-size:13px; color:var(--ink-3); }

/* ---------- footer ---------- */
.site-footer{ background:var(--surface); border-top:1px solid var(--border); margin-top:40px; }
.footer-top{ display:grid; grid-template-columns:1.6fr repeat(4,1fr); gap:32px; padding:48px 0 40px; }
.footer-col h5{ font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-4); margin-bottom:14px; font-family:var(--mono); font-weight:500; }
.footer-col a{ display:block; font-size:14px; color:var(--ink-2); padding:5px 0; }
.footer-col a:hover{ color:var(--ink); }
.footer-about p{ font-size:13.5px; color:var(--ink-3); line-height:1.6; max-width:36ch; margin-top:14px; }
.footer-legal{ border-top:1px solid var(--border); padding:18px 0; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:12.5px; color:var(--ink-4); }
.footer-legal .disclaimer{ max-width:70ch; }

/* ---------- related child pages ---------- */
.childgrid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:12px; }
.childcard{ display:flex; align-items:center; gap:12px; padding:14px 16px; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); box-shadow:var(--shadow-xs); transition:background .14s,border-color .14s,transform .14s; }
.childcard:hover{ background:var(--surface-2); border-color:var(--border-strong); transform:translateY(-1px); }
.childcard .ci{ width:34px; height:34px; border-radius:8px; background:var(--surface-2); border:1px solid var(--border); display:grid; place-items:center; color:var(--ink-3); flex:none; }
.childcard .ci svg{ width:17px; height:17px; }
.childcard .ct{ display:block; font-size:13.5px; font-weight:600; }
.childcard .cs{ display:block; font-size:11.5px; color:var(--ink-4); margin-top:1px; }

/* ---------- compare table ---------- */
.cmp{ font-size:14px; min-width:640px; }
.cmp th, .cmp td{ padding:13px 16px; border-bottom:1px solid var(--border); text-align:left; }
.cmp thead th{ background:var(--surface-2); font-size:13px; }
.cmp thead th.modelcol{ text-transform:none; letter-spacing:0; font-size:14.5px; font-weight:700; color:var(--ink); }
.cmp tbody th{ font-weight:500; color:var(--ink-3); font-size:13px; white-space:nowrap; }
.cmp td{ font-variant-numeric:tabular-nums; font-weight:600; }
.cmp td.best{ color:var(--accent-ink); }
.cmp .winbadge{ font-size:10px; font-family:var(--mono); color:var(--accent-ink); margin-left:6px; }

/* ---------- misc ---------- */
.divider-label{ display:flex; align-items:center; gap:14px; color:var(--ink-4); font-size:12px; }
.divider-label::before,.divider-label::after{ content:""; height:1px; background:var(--border); flex:1; }
.pillstat{ display:inline-flex; align-items:center; gap:7px; padding:5px 11px; border-radius:999px; background:var(--surface-2); border:1px solid var(--border); font-size:12.5px; color:var(--ink-2); }
.scrim{ display:none; }

/* ---------- ad slots (Yandex RTB / РСЯ) ---------- */
.ad-slot{ margin:30px auto; text-align:center; max-width:var(--maxw); }
.ad-slot .ad-label{ display:block; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-4); margin-bottom:7px; }
.ad-slot > div[id^="yandex_rtb"]{ min-height:90px; }
.ad-slot--feed{ margin:36px auto; }
.ad-slot--feed > div[id^="yandex_rtb"]{ min-height:200px; }
.ad-slot--inwrap{ padding-left:24px; padding-right:24px; }

/* anchor offset for in-page links */
[id]{ scroll-margin-top:calc(var(--header-h) + var(--anchor-h) + 16px); }

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .footer-top{ grid-template-columns:1fr 1fr 1fr; }
  .footer-about{ grid-column:1 / -1; }
}
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr !important; }
  #guides.wrap{ grid-template-columns:1fr !important; }
  .title-grid{ grid-template-columns:1fr !important; }
  .ov-grid{ grid-template-columns:1fr !important; }
  .price-aux{ grid-template-columns:1fr !important; }
}
@media (max-width:880px){
  .main-nav{ display:none; }
  .header-search{ min-width:0; flex:1; }
  .hmenu-btn{ display:grid; place-items:center; }
  .proscons,.fit{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  .wrap{ padding:0 16px; }
  .section{ padding:40px 0; }
  .footer-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .header-search kbd{ display:none; }
  .facts{ grid-template-columns:1fr 1fr; }
}
