/* ========================================================================
   CORNETA v2 — main stylesheet
   Перенесено 1-в-1 из design-prototype/index.html (Этап 1).
   На Этапе 4 разобьём по слоям (tokens / reset / components / sections).
   ======================================================================== */

/* Inter + JetBrains Mono — локальные woff2 файлы (issue #22).
   Лицензия: SIL Open Font License 1.1 (OFL).
   Inter: github.com/rsms/inter (v4.0)
   JetBrains Mono: github.com/JetBrains/JetBrainsMono (v2.304)
   Копии лицензий: assets/fonts/OFL-Inter.txt, OFL-JetBrainsMono.txt */

@font-face {
  font-family: 'Inter';
  src: url('../fonts/Inter.woff2') format('woff2-variations'),
       url('../fonts/Inter.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('../fonts/Inter-Italic.woff2') format('woff2-variations'),
       url('../fonts/Inter-Italic.woff2') format('woff2');
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/JetBrainsMono-400.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/JetBrainsMono-500.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

/* === DESIGN TOKENS === */
:root {
  --bg: #FFFFFF;
  --bg-soft: #F8FAFC;
  --bg-dark: #0A1628;
  --surface: #FFFFFF;
  --border: #E2E8F0;
  --border-strong: #CBD5E1;
  --text: #0F172A;
  --text-mute: #475569;
  --text-dim: #94A3B8;
  --link: #2563EB;
  --link-hover: #1D4ED8;
  --accent: #F97316;
  --accent-hover: #EA580C;
  --success: #059669;
  --warning: #D97706;
  --danger: #DC2626;

  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --fs-xs: 12px;
  --fs-sm: 14px;
  --fs-base: 16px;
  --fs-lg: 18px;
  --fs-xl: 22px;
  --fs-2xl: 28px;
  --fs-3xl: 36px;
  --fs-4xl: 48px;

  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px; --s-5: 20px;
  --s-6: 24px; --s-8: 32px; --s-10: 40px; --s-12: 48px; --s-16: 64px; --s-20: 80px;

  --max-w: 1280px;
  --radius-sm: 6px;
  --radius: 10px;
  --radius-lg: 14px;

  --shadow-sm: 0 1px 2px rgba(15,23,42,0.06);
  --shadow:    0 2px 8px rgba(15,23,42,0.08);
  --shadow-md: 0 4px 16px rgba(15,23,42,0.10);
  --shadow-lg: 0 12px 32px rgba(15,23,42,0.12);

  --t: 160ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* === RESET === */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: 1.55;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  max-width: 100%;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--link); text-decoration: none; transition: color var(--t); }
a:hover { color: var(--link-hover); }
button { font: inherit; cursor: pointer; border: none; background: none; }
h1, h2, h3, h4 { margin: 0; line-height: 1.2; letter-spacing: -0.01em; font-weight: 700; }
h1 { font-size: clamp(24px, 3.5vw, 36px); font-weight: 800; letter-spacing: -0.02em; }
h2 { font-size: clamp(20px, 2.8vw, 28px); }
h3 { font-size: var(--fs-lg); }
p { margin: 0; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--s-5);
}
@media (min-width: 768px) { .container { padding: 0 var(--s-8); } }

/* Для shop / category / cart — расширенный контейнер на больших экранах */
body.woocommerce .cv2-shop .container,
body.woocommerce-cart .container,
body.woocommerce-account .container {
  max-width: 1600px;
}
@media (min-width: 1700px) {
  body.woocommerce .cv2-shop .container,
  body.woocommerce-cart .container,
  body.woocommerce-account .container {
    max-width: 1760px;
  }
}

/* Header / Topbar / Urgent / Nav / Footer — синхронны с shop-контейнером */
.topbar .container,
.urgent-bar .container,
.header .container,
.nav .container,
.footer .container {
  max-width: 1600px;
}
@media (min-width: 1700px) {
  .topbar .container,
  .urgent-bar .container,
  .header .container,
  .nav .container,
  .footer .container {
    max-width: 1760px;
  }
}

/* === BUTTONS === */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s-2);
  padding: 12px 20px;
  border-radius: var(--radius);
  font-weight: 600; font-size: var(--fs-sm);
  transition: all var(--t);
  min-height: 44px;
  white-space: nowrap;
}
.btn-primary {
  background: var(--accent); color: #fff;
  box-shadow: 0 1px 0 rgba(255,255,255,0.15) inset, 0 4px 10px rgba(249,115,22,0.35);
}
.btn-primary:hover { background: var(--accent-hover); color: #fff; transform: translateY(-1px); }
.btn-secondary {
  background: var(--surface); color: var(--text); border: 1px solid var(--border-strong);
}
.btn-secondary:hover { background: var(--bg-soft); border-color: var(--text); color: var(--text); }
.btn-ghost { color: var(--text); }
.btn-ghost:hover { background: var(--bg-soft); color: var(--text); }
.btn-lg { padding: 14px 28px; min-height: 52px; font-size: var(--fs-base); border-radius: var(--radius); }
.btn-block { width: 100%; }

/* === TOPBAR === */
.topbar { background: var(--bg-dark); color: #CBD5E1; font-size: var(--fs-xs); padding: 8px 0; }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); flex-wrap: wrap; }
.topbar a { color: #E2E8F0; }
.topbar a:hover { color: #fff; }
.topbar-left { display: flex; gap: var(--s-5); flex-wrap: wrap; }
.topbar-left b { color: #fff; font-weight: 600; }
.topbar-right { display: flex; gap: var(--s-5); }
.icon { width: 14px; height: 14px; vertical-align: -2px; }
@media (max-width: 768px) {
  .topbar-right { display: none; }
  /* На mobile оставляем только телефон, остальные строки скрываем */
  .topbar-left > span:nth-child(2),
  .topbar-left > span:nth-child(3) { display: none; }
}

/* === HEADER === */
.header {
  background: #fff; border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 50;
  transition: box-shadow var(--t);
}
.header.scrolled { box-shadow: var(--shadow); }
.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-6);
  height: 64px;
}
.logo { display: flex; align-items: center; gap: var(--s-3); }
.logo-mark {
  width: 32px; height: 32px;
  background: linear-gradient(135deg, var(--bg-dark), var(--link));
  border-radius: 8px;
  display: grid; place-items: center;
  color: #fff; font-weight: 800; font-size: 14px; letter-spacing: -0.02em;
}
.logo-text { font-weight: 800; font-size: var(--fs-lg); letter-spacing: -0.02em; color: var(--text); }
.logo-tagline { display: none; font-size: var(--fs-xs); color: var(--text-mute); margin-top: -2px; }
@media (min-width: 768px) { .logo-tagline { display: block; } }

.search-form { position: relative; max-width: 560px; width: 100%; }
.search-form input {
  width: 100%; padding: 10px 40px 10px 38px;
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  font-size: var(--fs-sm); background: var(--bg-soft);
  transition: all var(--t);
}
.search-form input:focus {
  outline: none; border-color: var(--link); background: #fff;
  box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}
.search-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--text-dim); }
.search-form button {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  background: var(--text); color: #fff; padding: 6px 10px; border-radius: 6px;
  font-size: var(--fs-xs); font-weight: 600;
}

.header-actions { display: flex; gap: var(--s-2); align-items: center; }
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--radius); color: var(--text);
  position: relative;
}
.icon-btn:hover { background: var(--bg-soft); color: var(--text); }
.cart-count {
  position: absolute; top: 4px; right: 4px;
  background: var(--accent); color: #fff;
  font-size: 10px; font-weight: 700; padding: 1px 5px; border-radius: 8px;
  line-height: 1;
}
.menu-toggle { display: none; }
@media (max-width: 880px) {
  .menu-toggle { display: inline-flex; }
  .search-form { display: none; }
}

/* === NAV === */
.nav {
  background: #fff; border-bottom: 1px solid var(--border);
  position: sticky; top: 64px; z-index: 49;
}
.nav-inner { display: flex; gap: var(--s-5); align-items: center; height: 48px; }
@media (max-width: 980px) {
  .nav-inner { overflow-x: auto; overflow-y: visible; }
}
.nav a {
  color: var(--text); font-weight: 500; font-size: var(--fs-sm);
  padding: 8px 0; white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color var(--t), border-color var(--t);
}
.nav a:hover { color: var(--link); border-bottom-color: var(--link); }
.nav a.active { color: var(--link); border-bottom-color: var(--link); }
.nav .catalog-trigger {
  background: var(--text); color: #fff; padding: 8px 16px; border-radius: var(--radius);
  font-weight: 600; height: 36px; display: inline-flex; align-items: center; gap: 6px;
}
.nav .catalog-trigger:hover { background: var(--link); color: #fff; border: none; }
@media (max-width: 880px) {
  .nav { top: 64px; }
  .nav .catalog-trigger { display: none; }
}

/* === HERO V3 — точно как в /proto/home.html === */
.cv2-hero {
  position: relative;
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  color: #fff;
  overflow: hidden;
  padding: 64px 0 72px;
}
.cv2-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 75% 50%, rgba(249,115,22,0.15), transparent 60%),
    url('/wp-content/uploads/2026/05/hero/cylinders.webp') no-repeat right center / contain;
  opacity: 0.6;
  pointer-events: none;
}
.cv2-hero-inner {
  position: relative;
  z-index: 1;
  /* max-width унаследован от .container (1280px) — чтобы выравнивалось с .cv2-metrics ниже */
}
@media (max-width: 768px) {
  .cv2-hero { padding: 56px 0 64px; }
  .cv2-hero::after { background-image: radial-gradient(ellipse at 75% 50%, rgba(249,115,22,0.15), transparent 60%); }
}
.cv2-hero-eyebrow {
  display: inline-block;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: #cbd5e1;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 99px;
  margin-bottom: 24px;
}
.cv2-hero-title {
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: #fff;
  margin: 0 0 20px;
  max-width: 880px;
}
.cv2-hero-accent { color: var(--accent); }
.cv2-hero-brands { white-space: nowrap; }
.cv2-hero-lead {
  font-size: clamp(16px, 1.6vw, 20px);
  color: #cbd5e1;
  max-width: 640px;
  margin: 0 0 32px;
  line-height: 1.5;
}
.cv2-hero-ctas {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
  margin-bottom: 0;
}
.cv2-hero-ctas .btn-lg {
  min-width: 240px;
  justify-content: center;
  text-align: center;
}
@media (max-width: 480px) {
  .cv2-hero-ctas { flex-direction: column; align-items: stretch; }
  .cv2-hero-ctas .btn-lg { min-width: 0; width: 100%; }
}
.cv2-hero-cta-ghost {
  background: rgba(255,255,255,0.08);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.18);
}
.cv2-hero-cta-ghost:hover { background: rgba(255,255,255,0.14); color: #fff; }
.cv2-hero-cta-phone {
  background: #fff;
  color: #0d2546 !important;
  font-weight: 700;
}
.cv2-hero-cta-phone:hover { background: #f3f4f6; color: #0d2546; }

/* /opt/ teaser strip — between top-products and features */
.cv2-opt-teaser { padding: 0 0 var(--s-12); }
.cv2-opt-teaser-inner {
  background: linear-gradient(90deg, #fff7ed, #fff);
  border: 1px solid #fed7aa;
  border-radius: 12px;
  padding: 20px 26px;
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}
.cv2-opt-teaser-icon { font-size: 36px; flex-shrink: 0; }
.cv2-opt-teaser-text { flex: 1; min-width: 240px; }
.cv2-opt-teaser-text h3 { font-size: 18px; color: #c2410c; margin: 0 0 4px; font-weight: 700; }
.cv2-opt-teaser-text p { font-size: 14px; color: #4b5563; margin: 0; }
.cv2-opt-teaser .btn-primary { background: #c2410c; flex-shrink: 0; }
.cv2-opt-teaser .btn-primary:hover { background: #9a330a; }
@media (max-width: 640px) {
  .cv2-opt-teaser-inner { padding: 18px; }
  .cv2-opt-teaser-text h3 { font-size: 16px; }
}

/* Inline analog search card */
.cv2-hero-search {
  background: rgba(255,255,255,0.95);
  color: var(--text);
  padding: 10px;
  border-radius: var(--radius);
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
  max-width: 620px;
  margin-top: 18px;
}
.cv2-hero-search-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  display: block;
  margin-bottom: 8px;
}
.cv2-hero-search-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}
.cv2-hero-search-row input {
  flex: 1 1 200px;
  min-width: 0;
  padding: 14px 16px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-base);
  font-family: var(--font-mono);
  background: #f8fafc;
}
.cv2-hero-search-row .btn {
  white-space: nowrap;
  flex-shrink: 0;
}
@media (max-width: 480px) {
  .cv2-hero-search-row { flex-direction: column; }
  .cv2-hero-search-row input { flex: 0 0 auto; width: 100%; }
  .cv2-hero-search-row .btn { width: 100%; }
}
.cv2-hero-search-row input:focus {
  outline: none;
  border-color: var(--accent);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(249,115,22,0.12);
}
.cv2-hero-search-hint {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  margin: var(--s-2) 0 0;
}

/* === METRICS strip (sub-hero) === */
.cv2-metrics {
  background: #fff;
  border-bottom: 1px solid var(--border);
  padding: 24px 0;
}
.cv2-metrics-inner {
  display: flex;
  gap: var(--s-10);
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.cv2-metric { display: flex; flex-direction: column; gap: 2px; }
.cv2-metric-num {
  font-size: clamp(22px, 2.5vw, 32px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.1;
}
.cv2-metric-lbl {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  font-weight: 500;
}
.cv2-metric--today .cv2-metric-num { color: var(--success); font-size: var(--fs-lg); }
.cv2-metric-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--success);
  margin-right: 4px;
  vertical-align: middle;
}
/* Белый ввоз — ярко-оранжевый акцент */
.cv2-metric--gtd {
  background: #fff7ed;
  border: 2px solid #f97316;
  border-radius: 10px;
  padding: 10px 14px;
  text-decoration: none !important;
  transition: all 0.2s;
}
.cv2-metric--gtd:hover { background: #ffedd5; border-color: #ea580c; }
.cv2-metric--gtd .cv2-metric-num { color: #ea580c; font-size: var(--fs-lg); font-weight: 700; }
.cv2-metric--gtd .cv2-metric-lbl { color: #1a1a1a; font-weight: 600; }

/* === TRUST BAR === */
.trust-bar { background: var(--bg-soft); border-bottom: 1px solid var(--border); padding: var(--s-5) 0; }
.trust-grid { display: grid; gap: var(--s-5); grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .trust-grid { grid-template-columns: repeat(4, 1fr); } }
.trust-item { display: flex; gap: var(--s-3); align-items: flex-start; }
.trust-icon {
  flex-shrink: 0; width: 36px; height: 36px;
  background: #EFF6FF; color: var(--link); border-radius: var(--radius);
  display: grid; place-items: center;
}
.trust-title { font-weight: 600; font-size: var(--fs-sm); }
.trust-desc { font-size: var(--fs-xs); color: var(--text-mute); margin-top: 2px; }

/* trust-grid--5 — версия с 5 ячейками (когда есть GTD-блок) */
@media (min-width: 1024px) { .trust-grid--5 { grid-template-columns: repeat(5, 1fr); } }

/* Белый ввоз — оранжевый акцент */
.trust-item--gtd {
  background: #fff7ed;
  border: 2px solid #f97316;
  border-radius: 10px;
  padding: 12px 14px;
  text-decoration: none !important;
  transition: all 0.2s;
  color: inherit;
}
.trust-item--gtd:hover { background: #ffedd5; border-color: #ea580c; }
.trust-item--gtd .trust-icon { background: #fed7aa; color: #ea580c; }
.trust-item--gtd .trust-title { color: #ea580c; }
.trust-item--gtd .trust-desc { color: #1a1a1a; font-weight: 500; }

/* === SECTION === */
.section { padding: var(--s-16) 0; }
.section-soft { background: var(--bg-soft); }
.section-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: var(--s-8); gap: var(--s-4); flex-wrap: wrap; }
.section-head h2 { letter-spacing: -0.02em; }
.section-head p { color: var(--text-mute); margin-top: var(--s-2); }
.see-all { color: var(--link); font-weight: 600; font-size: var(--fs-sm); display: inline-flex; align-items: center; gap: 4px; }

/* === CATEGORIES V3 === */
.cv2-section-cats { padding: var(--s-12) 0; background: var(--bg); }
.cv2-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: var(--s-4);
  flex-wrap: wrap;
  margin-bottom: var(--s-8);
}
.cv2-section-title {
  font-size: clamp(24px, 2.8vw, 36px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0;
}
.cv2-section-sub {
  color: var(--text-mute);
  font-size: var(--fs-base);
  margin: 6px 0 0;
}
.cv2-section-link {
  color: var(--accent);
  font-weight: 600;
  font-size: var(--fs-sm);
}
.cv2-section-link:hover { color: var(--accent-hover); }

.cv2-cats {
  display: grid;
  gap: var(--s-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .cv2-cats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .cv2-cats { grid-template-columns: repeat(4, 1fr); } }

.cv2-cat {
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--t);
  display: flex;
  flex-direction: column;
  color: var(--text);
}
.cv2-cat:hover {
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(15,23,42,0.08);
  color: var(--text);
}
.cv2-cat-tag {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  background: var(--accent);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 700;
  padding: 4px 9px;
  border-radius: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.cv2-cat-img {
  aspect-ratio: 4/3;
  background: var(--bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cv2-cat-img img {
  width: 80%;
  height: 80%;
  object-fit: contain;
}
.cv2-cat-img-fallback {
  font-size: 48px;
  opacity: 0.4;
}
.cv2-cat-body {
  padding: var(--s-4) var(--s-5) var(--s-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cv2-cat-name {
  font-size: var(--fs-lg);
  font-weight: 700;
  margin: 0 0 4px;
  line-height: 1.25;
  min-height: 2.5em; /* выравнивание длинных и коротких имён */
}
.cv2-cat-from {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  margin: 0;
}
.cv2-cat-from b {
  color: var(--text);
  font-weight: 700;
}
.cv2-cat-meta {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin-top: auto;
  padding-top: var(--s-3);
  font-size: var(--fs-xs);
  color: var(--text-mute);
}
.cv2-cat-count {
  background: var(--bg-soft);
  padding: 3px 9px;
  border-radius: 99px;
  font-weight: 600;
  color: var(--text);
}
.cv2-cat-stock {
  color: var(--success);
  font-weight: 600;
}

/* === PRODUCTS === */
.prod-grid {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: repeat(2, 1fr);
  align-items: stretch;
}
@media (min-width: 768px)  { .prod-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .prod-grid { grid-template-columns: repeat(4, 1fr); } }
.prod {
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: all var(--t); display: flex; flex-direction: column;
  height: 100%;
}
.prod:hover { border-color: var(--text); box-shadow: var(--shadow-md); }
.prod-media { aspect-ratio: 1; background: var(--bg-soft); padding: var(--s-4); display: grid; place-items: center; position: relative; }
.prod-media img { max-width: 100%; max-height: 100%; object-fit: contain; }
.prod-badges { position: absolute; top: var(--s-3); left: var(--s-3); display: flex; flex-direction: column; gap: 4px; }
.badge { font-size: 10px; font-weight: 700; padding: 3px 7px; border-radius: 4px; letter-spacing: 0.04em; text-transform: uppercase; }
.badge-hit { background: var(--accent); color: #fff; }
.badge-new { background: var(--success); color: #fff; }
.badge-analog { background: #EFF6FF; color: var(--link); border: 1px solid #DBEAFE; }

/* === Analog badge (issue #4) === */
.cv2-analog-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 3px 7px;
  border-radius: 4px;
  border: 1px solid #DBEAFE;
  background: #EFF6FF;
  color: var(--link);
  font-family: var(--font-mono);
  text-transform: none;
  transition: all var(--t);
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cv2-analog-badge:hover {
  background: var(--link);
  color: #fff;
  border-color: var(--link);
}
.cv2-analog-near {
  background: var(--bg-soft);
  border-color: var(--border);
  color: var(--text-mute);
}
.cv2-analog-near:hover {
  background: var(--text);
  color: #fff;
}
.cv2-analog-lg {
  font-size: var(--fs-sm);
  padding: 6px 12px;
  border-radius: var(--radius);
  font-weight: 700;
}
.cv2-product-analog {
  margin-bottom: var(--s-3);
}
.prod-body { padding: var(--s-4); display: flex; flex-direction: column; flex: 1; }
.prod-sku { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-dim); margin-bottom: 4px; }
.prod-title { font-weight: 600; font-size: var(--fs-sm); line-height: 1.35; margin-bottom: var(--s-2); }
.prod-attrs { display: flex; gap: 6px; flex-wrap: wrap; margin: var(--s-2) 0; }
.attr-chip { font-size: 11px; padding: 2px 7px; background: var(--bg-soft); border: 1px solid var(--border); border-radius: 4px; color: var(--text-mute); }
.prod-foot {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  margin-top: auto;
  padding-top: var(--s-3);
  gap: var(--s-2);
}
.prod-price {
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.02em;
  white-space: nowrap;
  line-height: 1.1;
  text-align: left;
  color: var(--text);
}
.prod-price .woocommerce-Price-amount { white-space: nowrap; }
.prod-price bdi { white-space: nowrap; }
.prod-stock { font-size: var(--fs-xs); color: var(--success); font-weight: 600; }
.prod-stock-low { color: var(--warning); }
.prod-stock-out { color: var(--danger); }
.prod-cta {
  background: var(--text); color: #fff;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
  font-weight: 600;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  width: 100%;
}
.prod-cta:hover { background: var(--link); color: #fff; }

/* === FEATURES === */
.feature-row { display: grid; gap: var(--s-6); grid-template-columns: 1fr; }
@media (min-width: 768px) { .feature-row { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .feature-row { grid-template-columns: repeat(4, 1fr); } }
.feature { padding: var(--s-6); background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); }
.feature-num {
  width: 36px; height: 36px; background: var(--bg-dark); color: #fff;
  border-radius: 50%; display: grid; place-items: center;
  font-weight: 700; margin-bottom: var(--s-4);
}
.feature h3 { margin-bottom: var(--s-2); }
.feature p { color: var(--text-mute); font-size: var(--fs-sm); }

/* === TOOLS (dark) === */
.tools-section { background: var(--bg-dark); color: #fff; }
.tools-section h2 { color: #fff; }
.tools-section .section-head p { color: #CBD5E1; }
.tools-section .see-all { color: #60A5FA; }
.tools-grid { display: grid; gap: var(--s-4); grid-template-columns: 1fr; }
@media (min-width: 640px) { .tools-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .tools-grid { grid-template-columns: repeat(3, 1fr); } }
.tool {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1);
  padding: var(--s-6); border-radius: var(--radius-lg);
  transition: all var(--t); color: #fff;
  position: relative; overflow: hidden;
}
.tool:hover {
  background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.25);
  transform: translateY(-2px); color: #fff;
}
.tool-icon { font-size: 28px; margin-bottom: var(--s-3); }
.tool h3 { color: #fff; margin-bottom: var(--s-2); }
.tool-desc { color: #CBD5E1; font-size: var(--fs-sm); }
.tool-arrow { position: absolute; top: var(--s-6); right: var(--s-6); color: rgba(255,255,255,0.4); transition: all var(--t); }
.tool:hover .tool-arrow { color: #fff; transform: translate(2px, -2px); }

/* === CTA BLOCK === */
.cta-block {
  background: linear-gradient(135deg, var(--accent), #C2410C);
  color: #fff; padding: var(--s-12); border-radius: var(--radius-lg);
  display: grid; gap: var(--s-5); grid-template-columns: 1fr; align-items: center;
}
@media (min-width: 768px) { .cta-block { grid-template-columns: 1.2fr auto; } }
.cta-block h2 { color: #fff; }
.cta-block p { color: rgba(255,255,255,0.9); margin-top: var(--s-3); }
.cta-block .btn { background: #fff; color: var(--accent); }
.cta-block .btn:hover { background: var(--bg-soft); color: var(--accent-hover); transform: translateY(-1px); }

/* === FAQ V3 accordion === */
.faq-grid {
  display: grid;
  gap: 0;
  max-width: 880px;
  margin: 0 auto;
}
.faq {
  background: #fff;
  border-bottom: 1px solid var(--border);
  padding: 0;
  transition: background var(--t);
}
.faq:first-child { border-top: 1px solid var(--border); }
.faq:hover { background: rgba(249,115,22,0.02); }
.faq[open] { background: rgba(249,115,22,0.03); }
.faq summary {
  list-style: none;
  cursor: pointer;
  padding: var(--s-4) var(--s-5);
  font-weight: 600;
  font-size: var(--fs-base);
  color: var(--text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-4);
  line-height: 1.4;
  user-select: none;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-size: 24px;
  font-weight: 300;
  color: var(--accent);
  transition: transform 0.2s ease;
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.faq[open] summary::after { transform: rotate(45deg); }
.faq-body {
  padding: 0 var(--s-5) var(--s-5);
  color: var(--text-mute);
  font-size: var(--fs-sm);
  line-height: 1.65;
  max-width: 780px;
}
.faq-body a { color: var(--link); font-weight: 500; }
.faq-body a:hover { color: var(--link-hover); }

/* === FOOTER V3 compact === */
.cv2-footer {
  background: var(--bg-dark);
  color: #94A3B8;
  padding: var(--s-10) 0 var(--s-6);
}
.cv2-footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-8);
  margin-bottom: var(--s-8);
}
@media (min-width: 768px) {
  .cv2-footer-top {
    grid-template-columns: 2fr 3fr;
    gap: var(--s-10);
  }
}
.cv2-footer-brand { max-width: 460px; }
.cv2-footer-logo {
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}
.cv2-footer-tagline {
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: #94A3B8;
  margin: 0 0 var(--s-4);
}
.cv2-footer-contacts {
  display: flex;
  gap: var(--s-4);
  flex-wrap: wrap;
  align-items: center;
}
.cv2-footer-phone {
  color: #fff;
  font-weight: 700;
  font-size: var(--fs-base);
}
.cv2-footer-phone:hover { color: var(--accent); }
.cv2-footer-email { color: #94A3B8; font-size: var(--fs-sm); }
.cv2-footer-email:hover { color: #fff; }

/* Three short columns */
.cv2-footer-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
}
@media (max-width: 640px) {
  .cv2-footer-cols { grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }
}
.cv2-footer-col h4 {
  color: #fff;
  font-size: var(--fs-xs);
  margin: 0 0 var(--s-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.cv2-footer-col a {
  display: block;
  color: #94A3B8;
  font-size: var(--fs-sm);
  padding: 3px 0;
  line-height: 1.5;
}
.cv2-footer-col a:hover { color: #fff; }

/* Bottom strip */
.cv2-footer-bottom {
  padding-top: var(--s-5);
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  justify-content: space-between;
  gap: var(--s-4);
  font-size: var(--fs-xs);
  color: #64748b;
  flex-wrap: wrap;
}
.cv2-footer-legal a { color: #94A3B8; }
.cv2-footer-legal a:hover { color: #fff; }
.cv2-footer-dot { margin: 0 6px; color: #475569; }

/* === BREADCRUMBS === */
.bc { padding: var(--s-3) 0; font-size: var(--fs-xs); color: var(--text-mute); }
.bc a { color: var(--text-mute); }
.bc a:hover { color: var(--link); }

/* === Унифицированные breadcrumbs (issue #3) === */
.cv2-breadcrumbs {
  padding: var(--s-3) 0;
  font-size: var(--fs-sm);
  color: var(--text-mute);
}
.cv2-breadcrumbs ol {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}
.cv2-breadcrumbs li {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
}
.cv2-breadcrumbs a {
  color: var(--text-mute);
  text-decoration: none;
  transition: color var(--t);
  white-space: nowrap;
}
.cv2-breadcrumbs a:hover { color: var(--link); }
.cv2-breadcrumbs li:last-child span {
  color: var(--text);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 360px;
}
.cv2-bc-sep {
  color: var(--text-dim);
  flex-shrink: 0;
}
@media (max-width: 640px) {
  .cv2-breadcrumbs { font-size: var(--fs-xs); }
  .cv2-breadcrumbs li:last-child span { max-width: 180px; }
}

/* === MOBILE DRAWER (issue #19) === */
.cv2-drawer-overlay {
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.5);
  z-index: 70;
  opacity: 0;
  visibility: hidden;
  transition: opacity 200ms ease, visibility 200ms ease;
}
.cv2-drawer-overlay.is-open {
  opacity: 1;
  visibility: visible;
}
.cv2-drawer {
  position: fixed;
  top: 0; left: 0;
  width: min(85vw, 360px);
  height: 100vh; max-height: 100dvh;
  background: #fff;
  z-index: 71;
  transform: translateX(-100%);
  transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
  display: flex; flex-direction: column;
  box-shadow: 4px 0 24px rgba(0,0,0,0.15);
  overflow-y: auto;
}
.cv2-drawer.is-open { transform: translateX(0); }
.cv2-drawer-head {
  padding: var(--s-4);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; background: #fff; z-index: 1;
}
.cv2-drawer-close {
  width: 40px; height: 40px;
  border-radius: var(--radius); border: 0;
  background: var(--bg-soft);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.cv2-drawer-close:hover { background: var(--border); }
.cv2-drawer-nav {
  flex: 1; padding: var(--s-4);
}
.cv2-drawer-section-title {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute);
  font-weight: 700;
  margin: var(--s-4) 0 var(--s-2);
}
.cv2-drawer-section-title:first-child { margin-top: 0; }
.cv2-drawer-cats,
.cv2-drawer-links {
  list-style: none; padding: 0; margin: 0;
}
.cv2-drawer-cats li,
.cv2-drawer-links li {
  border-bottom: 1px solid var(--border);
}
.cv2-drawer-cats li:last-child,
.cv2-drawer-links li:last-child { border-bottom: 0; }
.cv2-drawer-cats a,
.cv2-drawer-links a {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-3) 0;
  font-size: var(--fs-base);
  color: var(--text);
  font-weight: 500;
}
.cv2-drawer-cats a:hover,
.cv2-drawer-links a:hover { color: var(--link); }
.cv2-drawer-cats .count {
  font-family: var(--font-mono); font-size: 10px;
  color: var(--text-dim);
  background: var(--bg-soft);
  padding: 2px 7px;
  border-radius: 99px;
  font-weight: 600;
}
.cv2-drawer-foot {
  padding: var(--s-4);
  border-top: 1px solid var(--border);
  background: var(--bg-soft);
  position: sticky; bottom: 0;
}
.cv2-drawer-phone {
  display: block;
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--text);
  text-align: center;
  margin-bottom: 4px;
}
.cv2-drawer-hint {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  text-align: center;
}

/* === MOBILE STICKY ATC (issue #1) === */
.cv2-sticky-atc {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 60;
  background: #fff;
  border-top: 1px solid var(--border);
  box-shadow: 0 -4px 16px rgba(0,0,0,0.08);
  padding: var(--s-2) var(--s-3) calc(var(--s-2) + env(safe-area-inset-bottom));
  display: none; /* по умолчанию скрыт, JS показывает */
  transform: translateY(100%);
  transition: transform var(--t);
  pointer-events: none;
}
.cv2-sticky-atc.is-visible {
  display: block;
  transform: translateY(0);
  pointer-events: auto;
}
.cv2-sticky-atc-inner {
  display: flex; align-items: center;
  gap: var(--s-3);
  max-width: var(--max-w);
  margin: 0 auto;
}
.cv2-sticky-atc-thumb {
  width: 48px; height: 48px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  object-fit: cover;
  flex-shrink: 0;
}
.cv2-sticky-atc-body {
  flex: 1; min-width: 0;
}
.cv2-sticky-atc-title {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  line-height: 1.2;
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  margin-bottom: 2px;
}
.cv2-sticky-atc-price {
  font-size: var(--fs-base);
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}
.cv2-sticky-atc-price .woocommerce-Price-amount {
  font-size: inherit;
  font-weight: inherit;
}
.cv2-sticky-atc-price del { display: none; }
.cv2-sticky-atc-price .cv2-price-na { font-size: var(--fs-xs); }
.cv2-sticky-atc-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--accent);
  color: #fff;
  font-weight: 700;
  font-size: var(--fs-sm);
  padding: 12px 18px;
  border-radius: var(--radius);
  white-space: nowrap;
  min-height: 44px;
  box-shadow: 0 2px 8px rgba(249,115,22,0.35);
}
.cv2-sticky-atc-btn:hover { background: var(--accent-hover); color: #fff; }
.cv2-sticky-atc-btn-secondary {
  background: var(--text);
  box-shadow: none;
}
.cv2-sticky-atc-btn-secondary:hover { background: var(--link); }

/* На desktop sticky-bar тоже показывается — но центрированный, с max-width,
   и с отступами, чтобы не сливаться с краями экрана. Логика показа (по
   IntersectionObserver) уже срабатывает на любой ширине. */
@media (min-width: 768px) {
  .cv2-sticky-atc {
    padding: var(--s-3) var(--s-5) calc(var(--s-3) + env(safe-area-inset-bottom));
  }
  .cv2-sticky-atc-inner { max-width: var(--max-w); }
  .cv2-sticky-atc-thumb { width: 56px; height: 56px; }
  .cv2-sticky-atc-title { font-size: var(--fs-sm); -webkit-line-clamp: 2; }
  .cv2-sticky-atc-price { font-size: var(--fs-lg); }
  .cv2-sticky-atc-btn { padding: 14px 26px; min-height: 48px; font-size: var(--fs-base); }
}

/* === ACCESSIBILITY === */
:focus-visible { outline: 2px solid var(--link); outline-offset: 2px; border-radius: 4px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* === URGENT BAR (Сценарий 5 — срочная замена) === */
.urgent-bar {
  background: linear-gradient(90deg, #B91C1C, #DC2626 50%, #B91C1C);
  color: #fff;
  font-size: var(--fs-sm);
  font-weight: 500;
  padding: 9px 0;
  position: relative;
  overflow: hidden;
}
.urgent-bar::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
  animation: urgent-shine 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes urgent-shine {
  0%, 100% { transform: translateX(-100%); }
  50%      { transform: translateX(100%); }
}
@media (prefers-reduced-motion: reduce) {
  .urgent-bar::before { animation: none; }
}
.urgent-inner {
  display: flex; align-items: center; gap: var(--s-3);
  justify-content: center; flex-wrap: wrap;
}
.urgent-icon { font-size: 16px; }
.urgent-text { color: #fff; }
.urgent-cta {
  color: #fff; font-weight: 700;
  text-decoration: underline; text-underline-offset: 3px;
  white-space: nowrap;
}
.urgent-cta:hover { color: #FECACA; }
@media (max-width: 768px) {
  .urgent-bar {
    font-size: var(--fs-xs);
    padding: 6px 0;
    /* Однострочный режим — совпадает с topbar по толщине */
  }
  .urgent-inner {
    gap: var(--s-2);
    flex-wrap: nowrap;
    white-space: nowrap;
    overflow: hidden;
  }
  /* На узком экране оставляем только иконку + CTA-телефон */
  .urgent-text { display: none; }
}

/* === INDUSTRIES (Сценарий 4 — для отрасли) === */
.industries-grid {
  display: grid; gap: var(--s-4);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px) { .industries-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 980px) { .industries-grid { grid-template-columns: repeat(6, 1fr); } }
.industry-card {
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: var(--s-5);
  transition: all var(--t);
  color: var(--text);
  display: flex; flex-direction: column; gap: var(--s-3);
  position: relative;
  text-align: left;
}
.industry-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  color: var(--text);
}
.industry-icon {
  font-size: 30px;
  width: 48px; height: 48px;
  background: var(--bg-soft);
  border-radius: var(--radius);
  display: grid; place-items: center;
}
.industry-card:hover .industry-icon {
  background: rgba(249,115,22,0.1);
}
.industry-body { flex: 1; }
.industry-title { font-weight: 600; font-size: var(--fs-base); margin-bottom: 4px; line-height: 1.3; }
.industry-desc { font-size: var(--fs-xs); color: var(--text-mute); line-height: 1.45; }
.industry-tag {
  font-size: 11px; font-weight: 600;
  color: var(--text-dim);
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

/* === BRAND LANDING (page-brand.php) === */
.brand-hero {
  background: linear-gradient(135deg, var(--bg-dark) 0%, var(--brand-color, #1E3A8A) 70%, var(--bg-dark) 100%);
  color: #fff; padding: var(--s-16) 0; position: relative; overflow: hidden;
}
.brand-hero .bc { color: rgba(255,255,255,0.7); padding-bottom: var(--s-3); }
.brand-hero .bc a { color: rgba(255,255,255,0.85); }
.brand-hero .bc a:hover { color: #fff; }
.brand-hero-inner {
  position: relative; display: grid; grid-template-columns: 1fr;
  gap: var(--s-10); align-items: center;
}
@media (min-width: 980px) { .brand-hero-inner { grid-template-columns: 1.1fr 1fr; } }
.brand-hero h1 { color: #fff; max-width: 16ch; }
.brand-hero .lead { color: #CBD5E1; font-size: clamp(16px,2vw,19px); max-width: 56ch; margin-top: var(--s-5); }

.brand-matcher-table, .brand-compare {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #fff;
}
.brand-matcher-table table, .brand-compare table {
  width: 100%; border-collapse: collapse;
  font-size: var(--fs-sm);
}
.brand-matcher-table th, .brand-compare th {
  background: var(--bg-soft);
  text-align: left;
  padding: var(--s-3) var(--s-4);
  font-weight: 600;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute);
  border-bottom: 1px solid var(--border);
}
.brand-matcher-table td, .brand-compare td {
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--border);
}
.brand-matcher-table tr:last-child td, .brand-compare tr:last-child td { border-bottom: 0; }
.brand-matcher-table .mono, .brand-compare .mono {
  font-family: var(--font-mono); font-size: 13px;
}
.brand-matcher-table .brand-analog { color: var(--link); font-weight: 600; }
.brand-matcher-table .brand-discount {
  color: var(--success); font-weight: 700;
  font-family: var(--font-mono);
}
@media (max-width: 768px) {
  .brand-matcher-table table, .brand-compare table { font-size: var(--fs-xs); }
  .brand-matcher-table th, .brand-matcher-table td,
  .brand-compare th, .brand-compare td { padding: var(--s-2) var(--s-3); }
}

/* ========================================================================
   WOOCOMMERCE
   ======================================================================== */

/* === CATALOG DROPDOWN === */
.cv2-catalog-dd { position: relative; }
.cv2-catalog-dd .catalog-trigger { transition: all var(--t); }
.cv2-catalog-dd .catalog-trigger.is-active { background: var(--link); }
.cv2-catalog-dd .catalog-trigger > svg,
.cv2-catalog-dd .catalog-trigger > * { pointer-events: none; }
.cv2-catalog-panel {
  display: none;
  position: absolute; top: calc(100% + 8px); left: 0;
  z-index: 51;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  width: min(1200px, calc(100vw - 32px));
  padding: var(--s-5) var(--s-6);
  opacity: 0; transform: translateY(-8px);
  transition: opacity var(--t), transform var(--t);
  pointer-events: none;
}
.cv2-catalog-panel.is-open {
  display: block;
  opacity: 1; transform: translateY(0);
  pointer-events: auto;
}
.cv2-catalog-grid {
  display: grid;
  gap: var(--s-5) var(--s-5);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px)  { .cv2-catalog-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .cv2-catalog-grid { grid-template-columns: repeat(3, 1fr); } }

.cv2-catalog-col {
  display: flex; flex-direction: column;
  min-width: 0;
  overflow: hidden;
}
.cv2-catalog-col-head {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: var(--s-2);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--s-3);
  color: var(--text);
  font-weight: 700;
  font-size: var(--fs-sm);
  line-height: 1.25;
  min-height: 56px;
  word-break: break-word;
}
.cv2-catalog-col-head:hover { color: var(--link); }
.cv2-catalog-col-head:hover .cv2-catalog-thumb { border-color: var(--link); }
.cv2-catalog-thumb {
  width: 40px; height: 40px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: grid; place-items: center;
  transition: border-color var(--t);
  flex-shrink: 0;
}
.cv2-catalog-thumb img {
  width: 100%; height: 100%; object-fit: cover;
}
.cv2-catalog-col-name {
  min-width: 0;
  white-space: normal;
  word-break: break-word;
  hyphens: auto;
  line-height: 1.25;
}
.cv2-catalog-col-head .count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-dim);
  background: var(--bg-soft);
  padding: 2px 7px;
  border-radius: 99px;
  font-weight: 600;
  white-space: nowrap;
}
.cv2-catalog-col ul {
  list-style: none; padding: 0; margin: 0;
  min-width: 0;
}
.cv2-catalog-col li {
  padding: 2px 0;
  min-width: 0;
  overflow: hidden;
}
.cv2-catalog-col li a {
  font-size: 13px;
  color: var(--text-mute);
  line-height: 1.35;
  display: block;
  padding: 3px 0;
  word-break: break-word;
  hyphens: auto;
}
.cv2-catalog-col li a:hover { color: var(--link); }
.cv2-catalog-foot {
  margin-top: var(--s-5);
  padding-top: var(--s-3);
  border-top: 1px solid var(--border);
  text-align: right;
}
.cv2-catalog-all {
  font-weight: 600; font-size: var(--fs-sm);
  color: var(--link);
}

/* === SIDEBAR FILTERS (расширенная навигация для каталога) === */
.cv2-sidebar-block {
  background: var(--bg-soft);
  padding: var(--s-4);
  border-radius: var(--radius);
  margin-bottom: var(--s-3);
}
.cv2-sidebar-block h4 {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute);
  font-weight: 700;
  margin-bottom: var(--s-3);
}

/* Иерархия категорий */
.cv2-cat-tree { list-style: none; padding: 0; margin: 0; }
.cv2-cat-tree > li.cv2-cat-root {
  padding: 0;
  margin-top: var(--s-4);
}
.cv2-cat-tree > li.cv2-cat-root:first-child { margin-top: 0; }
.cv2-cat-tree > li.cv2-cat-root > a {
  display: flex; align-items: center; justify-content: space-between;
  font-size: var(--fs-base);
  color: var(--text);
  font-weight: 700;
  padding: var(--s-2) 0;
  border-bottom: 1px solid var(--border);
}
.cv2-cat-tree > li.cv2-cat-root > a:hover { color: var(--link); }
.cv2-cat-tree .count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-dim);
  background: rgba(0,0,0,0.04);
  padding: 2px 8px;
  border-radius: 99px;
  font-weight: 500;
  min-width: 28px;
  text-align: center;
}
.cv2-cat-tree > li.cv2-cat-root.is-active > a {
  color: var(--link);
}
/* Дети — с отступом + вертикальной линией */
.cv2-cat-children {
  list-style: none;
  padding: 0;
  margin: var(--s-2) 0 0 var(--s-3);
  border-left: 2px solid var(--border);
}
.cv2-cat-children li {
  padding: 0;
  position: relative;
}
.cv2-cat-children a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px var(--s-3);
  font-size: var(--fs-sm);
  color: var(--text-mute);
  font-weight: 400;
  line-height: 1.35;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  transition: background var(--t), color var(--t);
}
.cv2-cat-children a:hover {
  color: var(--link);
  background: rgba(0,0,0,0.025);
}
.cv2-cat-children .is-active a {
  color: var(--link);
  font-weight: 600;
  background: rgba(0,0,0,0.04);
}
.cv2-cat-children .is-active::before {
  content: '';
  position: absolute;
  left: -2px; top: 0; bottom: 0;
  width: 2px;
  background: var(--link);
}

/* Активные фильтры (issue #11) */
.cv2-active-filters-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s-2);
}
.cv2-active-filters-head h4 { margin: 0; }
.cv2-reset-all {
  font-size: 11px;
  color: var(--link);
  font-weight: 600;
  text-decoration: underline;
}
.cv2-reset-all:hover { color: var(--accent); }
.cv2-active-filters-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.cv2-active-filters-list li {
  background: var(--text); color: #fff;
  font-size: 11px;
  padding: 4px 6px 4px 10px;
  border-radius: 99px;
  display: inline-flex; align-items: center; gap: 6px;
  max-width: 100%;
}
.cv2-active-filters-list li > span {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 180px;
}
.cv2-filter-remove {
  color: #fff;
  font-size: 16px;
  line-height: 1;
  width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.15);
  border-radius: 50%;
  flex-shrink: 0;
  transition: background var(--t);
}
.cv2-filter-remove:hover { background: var(--accent); color: #fff; }

/* Фильтр по наличию (issue #8) */
.cv2-stock-filter-toggle {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 6px 10px;
  background: #fff;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  color: var(--text);
  transition: all var(--t);
  width: 100%;
  cursor: pointer;
}
.cv2-stock-filter-toggle:hover {
  border-color: var(--success);
  color: var(--text);
}
.cv2-stock-box {
  width: 18px; height: 18px;
  border: 1.5px solid var(--border-strong);
  border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; color: #fff;
  flex-shrink: 0;
  background: #fff;
  transition: all var(--t);
}
.cv2-stock-filter-toggle.is-active {
  border-color: var(--success);
  background: rgba(5,150,105,0.08);
  font-weight: 600;
}
.cv2-stock-filter-toggle.is-active .cv2-stock-box {
  background: var(--success);
  border-color: var(--success);
}

/* Фильтр по цене */
.cv2-price-filter .price_slider_wrapper { padding-top: var(--s-2); }
.cv2-price-filter .price_slider {
  height: 4px; background: var(--border-strong);
  border-radius: 2px;
  position: relative;
  margin: var(--s-5) 0 var(--s-4);
}
.cv2-price-filter .ui-slider-range {
  position: absolute; top: 0; height: 100%;
  background: var(--accent); border-radius: 2px;
}
.cv2-price-filter .ui-slider-handle {
  position: absolute; top: -7px;
  width: 18px; height: 18px;
  background: #fff; border: 2px solid var(--accent);
  border-radius: 50%; cursor: pointer;
  margin-left: -9px;
}
.cv2-price-filter .price_slider_amount {
  display: flex; justify-content: space-between; align-items: center;
  font-size: var(--fs-sm);
}
.cv2-price-filter .price_slider_amount .price_label {
  font-family: var(--font-mono); color: var(--text-mute);
}
.cv2-price-filter .price_slider_amount .button {
  background: var(--text); color: #fff;
  padding: 6px 14px; font-size: var(--fs-xs);
  border-radius: var(--radius-sm);
}

/* === Collapsible sidebar blocks (details/summary) === */
.cv2-sidebar-block details.cv2-attr-filter,
.cv2-sidebar-block.cv2-price-filter[open],
details.cv2-attr-filter[open] {
  /* override базовый padding из .cv2-sidebar-block */
}
details.cv2-attr-filter,
details.cv2-price-filter {
  padding: 0 !important;
  overflow: hidden;
}
details.cv2-attr-filter > summary,
details.cv2-price-filter > summary {
  list-style: none;
  cursor: pointer;
  padding: var(--s-3) var(--s-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-2);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute);
  font-weight: 700;
  user-select: none;
  background: var(--bg-soft);
  border-radius: var(--radius);
  transition: background var(--t);
}
details.cv2-attr-filter > summary:hover,
details.cv2-price-filter > summary:hover {
  background: rgba(15,23,42,0.05);
  color: var(--text);
}
details.cv2-attr-filter > summary::-webkit-details-marker,
details.cv2-price-filter > summary::-webkit-details-marker { display: none; }
details.cv2-attr-filter > summary::marker,
details.cv2-price-filter > summary::marker { content: ''; }
.cv2-collapse-arrow {
  transition: transform var(--t);
  color: var(--text-mute);
  flex-shrink: 0;
}
details[open] > summary .cv2-collapse-arrow {
  transform: rotate(180deg);
}
details[open] > summary {
  border-radius: var(--radius) var(--radius) 0 0;
}
.cv2-attr-content {
  padding: var(--s-3) var(--s-4) var(--s-4);
  background: var(--bg-soft);
  border-radius: 0 0 var(--radius) var(--radius);
}

/* Атрибутные фильтры (Layered Nav) внутри collapsed блока */
.cv2-attr-filter .cv2-attr-content ul { list-style: none; padding: 0; margin: 0; }
.cv2-attr-filter .cv2-attr-content li {
  padding: 4px 0;
  display: flex; justify-content: space-between; align-items: center;
}
.cv2-attr-filter .cv2-attr-content li a {
  font-size: var(--fs-sm); color: var(--text);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-2);
  flex: 1; min-width: 0;
}
.cv2-attr-filter .cv2-attr-content li a:hover { color: var(--link); }
.cv2-attr-filter .cv2-attr-content li.chosen a { color: var(--link); font-weight: 600; }
.cv2-attr-filter .cv2-attr-content li.chosen a::before {
  content: "✓"; color: var(--success);
  font-weight: 700;
  margin-right: 4px;
}
.cv2-attr-filter .cv2-attr-content .count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-dim);
  background: rgba(0,0,0,0.04);
  padding: 1px 6px;
  border-radius: 99px;
}

/* === ARCHIVE / SHOP LAYOUT === */
.cv2-shop { background: #fff; }
.cv2-archive-header {
  padding: var(--s-4) 0 var(--s-6);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--s-6);
}
.cv2-archive-title { font-size: clamp(24px, 3.5vw, 36px); margin-bottom: var(--s-2); }
.cv2-archive-header .term-description {
  color: var(--text-mute); font-size: var(--fs-sm); max-width: 76ch;
}

/* === Term description (SEO-блок внизу category) === */
.cornet-category-seo,
.term-description {
  margin-top: var(--s-12);
  padding-top: var(--s-8);
  border-top: 1px solid var(--border);
  max-width: 900px;
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--text);
}
.cornet-category-seo p,
.term-description p {
  margin: 0 0 var(--s-3);
}
.cornet-category-seo p:first-child,
.term-description p:first-child {
  font-size: var(--fs-base);
  font-weight: 400;
  line-height: 1.6;
  color: var(--text);
  letter-spacing: 0;
  margin-bottom: var(--s-4);
  padding-bottom: 0;
  border-bottom: 0;
}
.cornet-category-seo p:first-child br,
.term-description p:first-child br { display: none; }
.cornet-category-seo p:first-child::first-line,
.term-description p:first-child::first-line {
  /* h2-стиль для подзаголовка вида "Пневмоцилиндры: подбор..." */
}
.cornet-category-seo p strong:first-child,
.term-description p strong:first-child {
  display: inline-block;
  color: var(--text);
  font-weight: 700;
  margin-right: 4px;
}
.cornet-category-seo p:has(> strong:first-child),
.term-description p:has(> strong:first-child) {
  background: var(--bg-soft);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
  margin-bottom: var(--s-2);
}
.cornet-category-seo a,
.term-description a {
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cornet-category-seo a:hover,
.term-description a:hover { color: var(--link-hover); }
.cornet-category-seo strong,
.term-description strong { color: var(--text); font-weight: 700; }

.cv2-shop-layout {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
}
@media (min-width: 980px)  { .cv2-shop-layout { grid-template-columns: 260px 1fr; } }
@media (min-width: 1100px) { .cv2-shop-layout { grid-template-columns: 280px 1fr; } }
@media (min-width: 1300px) { .cv2-shop-layout { grid-template-columns: 300px 1fr; } }
@media (min-width: 1500px) { .cv2-shop-layout { grid-template-columns: 320px 1fr; } }

/* Sidebar collapse: на mobile свёрнут, на desktop ≥980px всегда открыт */
.cv2-mobile-filters-toggle {
  width: 100%;
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-4);
  background: var(--text); color: #fff;
  border: 0;
  border-radius: var(--radius);
  font-weight: 600; font-size: var(--fs-sm);
  cursor: pointer;
  user-select: none;
}
.cv2-mobile-filters-toggle::after {
  content: "+"; margin-left: auto; font-size: 20px; line-height: 1;
}
.cv2-mobile-filters-toggle[aria-expanded="true"]::after { content: "−"; }
.cv2-mobile-filters-toggle[aria-expanded="true"] { border-radius: var(--radius) var(--radius) 0 0; }
.cv2-mobile-filters > .cv2-sidebar-content {
  display: none;
  padding-top: var(--s-3);
}
.cv2-mobile-filters[data-cv2-open="1"] > .cv2-sidebar-content {
  display: block;
}
@media (min-width: 980px) {
  .cv2-mobile-filters-toggle { display: none !important; }
  .cv2-mobile-filters > .cv2-sidebar-content {
    display: block !important;
    padding-top: 0;
  }
}
.cv2-shop-sidebar {
  font-size: var(--fs-sm);
}
.cv2-shop-sidebar .widget,
.cv2-sidebar-hint {
  background: var(--bg-soft);
  padding: var(--s-4);
  border-radius: var(--radius);
  margin-bottom: var(--s-4);
}
.cv2-shop-sidebar h4,
.cv2-shop-sidebar .widget-title {
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute);
  margin-bottom: var(--s-3);
  font-weight: 700;
}
.cv2-shop-sidebar ul { list-style: none; padding: 0; margin: 0; }
.cv2-shop-sidebar li { padding: 4px 0; }
.cv2-shop-sidebar a { color: var(--text); }
.cv2-shop-sidebar a:hover { color: var(--link); }
.cv2-shop-sidebar .count {
  color: var(--text-dim);
  font-family: var(--font-mono);
  font-size: 11px;
}

.cv2-loop-toolbar {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--bg-soft);
  border-radius: var(--radius);
  margin-bottom: var(--s-5);
}
.cv2-loop-toolbar-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.cv2-loop-toolbar .woocommerce-result-count {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  margin: 0;
}
.cv2-loop-toolbar .woocommerce-ordering select {
  padding: 6px 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  background: #fff;
  font-size: var(--fs-sm);
  cursor: pointer;
}

/* === Toolbar filter chips (issue: filters in toolbar) === */
.cv2-toolbar-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.cv2-toolbar-chip {
  position: relative;
}
.cv2-toolbar-chip > summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: #fff;
  border: 1px solid var(--border-strong);
  border-radius: 99px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  transition: all var(--t);
  user-select: none;
}
.cv2-toolbar-chip > summary::-webkit-details-marker { display: none; }
.cv2-toolbar-chip > summary::marker { content: ''; }
.cv2-toolbar-chip > summary:hover {
  border-color: var(--text);
  color: var(--text);
}
.cv2-toolbar-chip[data-active="1"] > summary,
.cv2-toolbar-chip[open] > summary {
  border-color: var(--link);
  background: rgba(37,99,235,0.05);
  color: var(--link);
}
.cv2-toolbar-chip[data-active="1"] > summary {
  font-weight: 600;
}
.cv2-chip-count {
  background: var(--link);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 99px;
  min-width: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cv2-chip-arrow {
  transition: transform var(--t);
  color: var(--text-mute);
}
.cv2-toolbar-chip[open] .cv2-chip-arrow {
  transform: rotate(180deg);
}
.cv2-chip-panel {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 30;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  min-width: 220px;
  max-width: 320px;
  max-height: 360px;
  overflow-y: auto;
  padding: 6px;
}
.cv2-chip-panel ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cv2-chip-panel li {
  padding: 0;
}
.cv2-chip-panel li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  font-size: 13px;
  color: var(--text);
  border-radius: var(--radius-sm);
  transition: background var(--t);
  gap: var(--s-2);
}
.cv2-chip-panel li a:hover {
  background: var(--bg-soft);
}
.cv2-chip-panel li.chosen a {
  background: rgba(5,150,105,0.08);
  color: var(--success);
  font-weight: 600;
}
.cv2-chip-panel li.chosen a::before {
  content: '✓';
  font-weight: 700;
}
.cv2-chip-panel .count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-dim);
  background: var(--bg-soft);
  padding: 1px 7px;
  border-radius: 99px;
}
@media (max-width: 640px) {
  .cv2-chip-panel {
    min-width: calc(100vw - 32px);
    left: -8px;
  }
}
.cv2-chip-empty {
  padding: var(--s-3);
  color: var(--text-mute);
  font-size: 13px;
  text-align: center;
  font-style: italic;
}

/* === Related articles (Полезные материалы) === */
.cv2-related-articles {
  margin: var(--s-12) 0 var(--s-8);
  padding: var(--s-8) var(--s-6);
  background: linear-gradient(135deg, var(--bg-soft) 0%, #fff 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.cv2-related-head {
  margin-bottom: var(--s-6);
}
.cv2-related-head h2 {
  font-size: clamp(20px, 2.5vw, 26px);
  margin-bottom: var(--s-2);
}
.cv2-related-head p {
  color: var(--text-mute);
  font-size: var(--fs-sm);
}
.cv2-related-grid {
  display: grid;
  gap: var(--s-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .cv2-related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px)  { .cv2-related-grid { grid-template-columns: repeat(3, 1fr); } }
.cv2-related-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: all var(--t);
  color: var(--text);
  text-decoration: none;
}
.cv2-related-card:hover {
  border-color: var(--link);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  color: var(--text);
}
.cv2-related-thumb {
  display: block;
  aspect-ratio: 16/9;
  background: var(--bg-soft);
  overflow: hidden;
}
.cv2-related-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.cv2-related-placeholder {
  width: 100%; height: 100%;
  display: grid; place-items: center;
  font-size: 36px;
  color: var(--text-dim);
}
.cv2-related-body {
  display: flex;
  flex-direction: column;
  padding: var(--s-4);
  flex: 1;
}
.cv2-related-cat {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--link);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--s-2);
}
.cv2-related-title {
  font-weight: 700;
  font-size: var(--fs-base);
  line-height: 1.35;
  color: var(--text);
  margin-bottom: var(--s-2);
}
.cv2-related-excerpt {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  line-height: 1.5;
  flex: 1;
}

/* Применяем prod-grid и для дефолтного WC-loop */
.cv2-shop-grid,
.woocommerce ul.products {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: repeat(2, 1fr);
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (min-width: 640px)  { .cv2-shop-grid, .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .cv2-shop-grid, .woocommerce ul.products { grid-template-columns: repeat(4, 1fr); } }
.woocommerce ul.products li.product { float: none; width: auto; margin: 0; padding: 0; }
.woocommerce ul.products li.product::before, .woocommerce ul.products li.product::after { display: none; }

/* === PAGINATION === */
.cv2-pagination { margin-top: var(--s-8); display: flex; justify-content: center; }
.cv2-pagination ul.page-numbers {
  display: inline-flex; gap: 4px;
  list-style: none; padding: 0; margin: 0;
}
.cv2-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text);
  background: #fff;
  font-weight: 600;
  font-size: var(--fs-sm);
}
.cv2-pagination .page-numbers:hover { border-color: var(--link); color: var(--link); }
.cv2-pagination .page-numbers.current {
  background: var(--text); color: #fff; border-color: var(--text);
}
.cv2-pagination .page-numbers.dots { border: 0; background: transparent; min-width: 24px; padding: 0; }

/* AJAX load more (issue #10) */
.cv2-pagination--js-hidden { display: none !important; }
.cv2-load-more {
  display: block;
  margin: var(--s-8) auto var(--s-4);
  padding: 14px 36px;
  background: #fff;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font: inherit;
  font-weight: 600;
  font-size: var(--fs-base);
  color: var(--text);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.cv2-load-more:hover { border-color: var(--link); color: var(--link); }
.cv2-load-more[aria-busy="true"] { opacity: 0.65; cursor: wait; }
.cv2-load-more.is-loading::before {
  content: '';
  display: inline-block;
  width: 14px; height: 14px;
  margin-right: 10px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: cv2-spin 0.7s linear infinite;
  vertical-align: -2px;
}
@keyframes cv2-spin { to { transform: rotate(360deg); } }
.cv2-newly-loaded { animation: cv2-fade-in 0.35s ease-out; }
@keyframes cv2-fade-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* === SINGLE PRODUCT === */
.cv2-single-product { padding-top: var(--s-4); }
.cv2-product-top {
  display: grid;
  gap: var(--s-10);
  grid-template-columns: 1fr;
  margin-bottom: var(--s-12);
  align-items: start;
}
/* Желаемая пропорция как в V1: ~50/50, галерея не тянется в высоту summary
   (align-items: start на родителе). Картинка центрируется в своей колонке
   и не растягивается — натуральный размер (обычно 600×600) с max-width:100%.
   minmax(0, 1fr) — иначе картинка 600px не даст колонке сжаться на уже viewport. */
@media (min-width: 768px) {
  .cv2-product-top { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: var(--s-10); }
}
.cv2-product-gallery { align-self: start; }
.cv2-product-gallery .woocommerce-product-gallery {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  cursor: zoom-in;
  text-align: center;
}
/* WC FlexSlider навязывает inline width/height на изображение и фикс-ширину
   на slider-контейнеры. Снимаем, чтобы картинка ужималась с колонкой. */
.cv2-product-gallery .woocommerce-product-gallery__image img,
.cv2-product-gallery img.wp-post-image {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  margin: 0 auto;
}
.cv2-product-gallery .woocommerce-product-gallery__image,
.cv2-product-gallery .woocommerce-product-gallery__wrapper,
.cv2-product-gallery .flex-viewport,
.cv2-product-gallery .flex-slides,
.cv2-product-gallery .flex-slides > li,
.cv2-product-gallery .woocommerce-product-gallery__wrapper > div {
  max-width: 100% !important;
}
/* Padding вокруг главной картинки — как в V1, чтобы изображение занимало
   ~80% ширины колонки. Thumbs (.flex-control-thumbs) остаются без отступа. */
.cv2-product-gallery .woocommerce-product-gallery__image {
  padding: 0 4%;
}

/* === Product gallery lightbox (issue #2) === */
.cv2-lightbox {
  position: fixed; inset: 0;
  z-index: 100;
  background: rgba(10, 22, 40, 0.95);
  display: none;
  align-items: center; justify-content: center;
  padding: var(--s-5);
}
.cv2-lightbox.is-open { display: flex; }
.cv2-lb-stage {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.cv2-lb-img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  touch-action: pinch-zoom;
  user-select: none;
}
.cv2-lb-close,
.cv2-lb-prev,
.cv2-lb-next {
  position: absolute;
  background: rgba(255,255,255,0.1);
  color: #fff;
  border: 0;
  width: 48px; height: 48px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t);
  z-index: 1;
}
.cv2-lb-close:hover,
.cv2-lb-prev:hover,
.cv2-lb-next:hover {
  background: rgba(255,255,255,0.25);
}
.cv2-lb-close { top: 20px; right: 20px; }
.cv2-lb-prev  { left: 20px; top: 50%; transform: translateY(-50%); }
.cv2-lb-next  { right: 20px; top: 50%; transform: translateY(-50%); }
.cv2-lb-counter {
  position: absolute;
  bottom: 20px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,0.1);
  color: #fff;
  padding: 6px 14px;
  border-radius: 99px;
  font-family: var(--font-mono);
  font-size: 13px;
}
@media (max-width: 640px) {
  .cv2-lb-close { width: 40px; height: 40px; font-size: 22px; top: 12px; right: 12px; }
  .cv2-lb-prev,
  .cv2-lb-next { width: 40px; height: 40px; font-size: 22px; }
  .cv2-lb-prev { left: 8px; }
  .cv2-lb-next { right: 8px; }
}
.cv2-product-gallery .woocommerce-product-gallery__image {
  background: var(--bg-soft); border-radius: var(--radius);
}
.cv2-product-gallery .flex-control-thumbs {
  display: flex; gap: var(--s-2); padding: var(--s-3) 0; margin: 0;
  list-style: none; flex-wrap: wrap;
}
.cv2-product-gallery .flex-control-thumbs li {
  width: 72px !important; height: 72px;
  margin: 0;
}
.cv2-product-gallery .flex-control-thumbs img {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: var(--radius-sm); border: 1px solid var(--border);
  cursor: pointer;
}
.cv2-product-gallery .flex-control-thumbs img.flex-active {
  border-color: var(--link); box-shadow: 0 0 0 2px rgba(37,99,235,0.15);
}

.cv2-product-summary { display: flex; flex-direction: column; gap: var(--s-3); }
.cv2-product-sku {
  font-family: var(--font-mono); font-size: var(--fs-sm);
  color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.04em;
}
.product_title { font-size: clamp(24px, 3vw, 32px); margin-bottom: var(--s-2); }

.woocommerce-Price-amount, .price {
  font-size: 28px; font-weight: 700; color: var(--text); letter-spacing: -0.02em;
  white-space: nowrap;
}
.woocommerce-Price-amount bdi { white-space: nowrap; }
.price del { color: var(--text-dim); font-size: 18px; font-weight: 400; margin-right: var(--s-2); }
.price ins { background: transparent; text-decoration: none; color: var(--accent); }

.stock {
  display: inline-block;
  font-size: var(--fs-xs); font-weight: 600;
  padding: 4px 10px; border-radius: 99px;
}
.stock.in-stock      { background: rgba(5,150,105,0.1); color: var(--success); }
.stock.out-of-stock  { background: rgba(220,38,38,0.1); color: var(--danger); }
.stock.available-on-backorder { background: rgba(217,119,6,0.1); color: var(--warning); }

.woocommerce-product-details__short-description {
  color: var(--text-mute);
  font-size: var(--fs-sm); line-height: 1.6;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: var(--s-4) 0;
}

/* Add to cart — единый gap для qty / В корзину / один клик.
   Variable product: кнопки внутри .woocommerce-variation-add-to-cart.
   Simple product: кнопки прямые дети form.cart. Обрабатываем оба. */
form.cart,
.woocommerce-variation-add-to-cart {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: var(--s-4);
}
form.cart > *,
.woocommerce-variation-add-to-cart > * { margin: 0 !important; }
/* Эти блоки должны занимать полную строку (не inline с кнопками) */
form.cart > .cornet-b2b-buttons,
form.cart > .cv2-product-meta-block,
form.cart > .cv2-trust-block,
form.cart > .cv2-current-price,
form.cart > .cv2-single-variations,
form.cart > .single_variation_wrap,
.woocommerce-variation-add-to-cart > .cornet-b2b-buttons,
.woocommerce-variation-add-to-cart > .cv2-product-meta-block,
.woocommerce-variation-add-to-cart > .cv2-trust-block,
.woocommerce-variation-add-to-cart > .cv2-current-price,
.woocommerce-variation-add-to-cart > .cv2-single-variations { flex-basis: 100%; }
.quantity { display: inline-flex; align-items: center; }
.quantity .qty {
  width: 80px; height: 44px; padding: 0 12px;
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  font-size: var(--fs-base); font-weight: 600; text-align: center;
}
.single_add_to_cart_button, .button.alt {
  background: var(--accent) !important; color: #fff !important;
  padding: 10px 24px !important; min-height: 38px;
  border-radius: var(--radius) !important;
  font-weight: 600 !important; font-size: var(--fs-sm);
  border: 0;
  box-shadow: 0 4px 10px rgba(249,115,22,0.3);
  transition: all var(--t);
}
.single_add_to_cart_button:hover, .button.alt:hover {
  background: var(--accent-hover) !important;
  transform: translateY(-1px);
}
.button {
  background: var(--text); color: #fff;
  padding: 8px 17px; border-radius: var(--radius);
  font-weight: 600; font-size: var(--fs-xs);
  border: 0;
  transition: all var(--t);
}
.button:hover { background: var(--link); color: #fff; }

.cv2-product-trust {
  list-style: none; padding: var(--s-4); margin: var(--s-4) 0 0;
  background: var(--bg-soft); border-radius: var(--radius);
  font-size: var(--fs-sm); display: flex; flex-direction: column; gap: 6px;
  color: var(--text);
}

/* === Specs above fold (ключевые характеристики) === */
.cv2-specs-summary {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--s-4);
  margin: var(--s-3) 0;
}
.cv2-specs-title {
  margin: 0 0 var(--s-3);
  font-size: var(--fs-base);
  font-weight: 700;
  color: var(--text);
  display: flex; align-items: center; gap: 6px;
}
.cv2-specs-title::before {
  content: "⚙";
  font-size: 16px;
  line-height: 1;
}
.cv2-specs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
.cv2-specs-table tr + tr td { border-top: 1px solid var(--border); }
.cv2-specs-table td {
  padding: 8px 0;
  vertical-align: top;
  line-height: 1.4;
}
.cv2-sp-label {
  color: var(--text-mute);
  width: 45%;
  padding-right: var(--s-3);
}
.cv2-sp-value {
  color: var(--text);
  font-weight: 600;
  text-align: right;
}
.cv2-sp-sku {
  font-family: var(--font-mono);
  color: var(--link);
  font-weight: 700;
  letter-spacing: 0.02em;
}
.cv2-specs-more {
  display: inline-block;
  margin-top: var(--s-3);
  color: var(--link);
  font-size: var(--fs-sm);
  font-weight: 500;
  text-decoration: none;
}
.cv2-specs-more:hover { color: var(--link-hover); text-decoration: underline; }
@media (max-width: 480px) {
  .cv2-specs-summary { padding: var(--s-3); }
  .cv2-sp-label { width: 50%; padding-right: var(--s-2); }
}

/* Variations */
table.variations { width: 100%; margin: var(--s-4) 0; }
table.variations th, table.variations td { padding: 6px 0; text-align: left; vertical-align: middle; }
table.variations th { width: 130px; color: var(--text-mute); font-size: var(--fs-sm); font-weight: 500; }
table.variations select {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  font-size: var(--fs-sm);
  background: #fff;
}
.reset_variations {
  display: inline-block; margin-left: var(--s-2);
  font-size: var(--fs-xs); color: var(--text-mute);
}

.product_meta {
  font-size: var(--fs-xs); color: var(--text-mute);
  padding-top: var(--s-3); border-top: 1px solid var(--border);
}
.product_meta > span { display: block; margin: 4px 0; }
.product_meta a { color: var(--link); }

/* === Product tabs (Описание / Детали) === */
.cv2-product-tabs { margin-top: var(--s-10); }
.woocommerce-tabs ul.tabs {
  display: flex; gap: var(--s-2);
  list-style: none; padding: 0; margin: 0;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
}
.woocommerce-tabs ul.tabs li {
  margin: 0; padding: 0;
  background: transparent !important; border: 0 !important;
}
.woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 14px 24px;
  font-weight: 600; font-size: var(--fs-base);
  color: var(--text-mute);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: all var(--t);
  margin-bottom: -1px;
}
.woocommerce-tabs ul.tabs li a:hover { color: var(--text); }
.woocommerce-tabs ul.tabs li.active a {
  color: var(--text);
  border-bottom-color: var(--accent);
}

/* === Tab content typography === */
.woocommerce-Tabs-panel {
  padding: var(--s-4) 0;
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--text);
}
.woocommerce-Tabs-panel > h2:first-child,
.woocommerce-Tabs-panel > h3:first-child {
  margin-top: 0;
}
.woocommerce-Tabs-panel h2 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: var(--s-5) 0 var(--s-2);
  padding-bottom: 6px;
  border-bottom: 2px solid var(--accent);
}
.woocommerce-Tabs-panel h3 {
  font-size: 15px;
  font-weight: 700;
  margin: var(--s-4) 0 6px;
  color: var(--text);
}
.woocommerce-Tabs-panel h4 {
  font-size: var(--fs-sm);
  font-weight: 700;
  margin: var(--s-3) 0 4px;
  color: var(--text);
}
.woocommerce-Tabs-panel p {
  margin: 0 0 var(--s-2);
}
.woocommerce-Tabs-panel strong { color: var(--text); font-weight: 700; }
.woocommerce-Tabs-panel a {
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.woocommerce-Tabs-panel a:hover { color: var(--link-hover); }

/* Списки в описании */
.woocommerce-Tabs-panel ul,
.woocommerce-Tabs-panel ol {
  margin: 0 0 var(--s-2);
  padding-left: 0;
  list-style: none;
}
.woocommerce-Tabs-panel ul li {
  position: relative;
  padding-left: var(--s-4);
  margin-bottom: 2px;
  line-height: 1.45;
}
.woocommerce-Tabs-panel ul li::before {
  content: '';
  position: absolute;
  left: 2px; top: 8px;
  width: 4px; height: 4px;
  background: var(--accent);
  border-radius: 50%;
}
.woocommerce-Tabs-panel ol {
  counter-reset: cv2-ol;
  list-style: none;
}
.woocommerce-Tabs-panel ol li {
  counter-increment: cv2-ol;
  position: relative;
  padding-left: 26px;
  margin-bottom: 4px;
  line-height: 1.45;
}
.woocommerce-Tabs-panel ol li::before {
  content: counter(cv2-ol);
  position: absolute;
  left: 0; top: 1px;
  width: 18px; height: 18px;
  background: var(--text);
  color: #fff;
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

/* Таблицы в описании — compact style */
.woocommerce-Tabs-panel table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-2) 0 var(--s-3);
  font-size: var(--fs-sm);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.woocommerce-Tabs-panel table thead { background: var(--bg-soft); }
.woocommerce-Tabs-panel table th {
  text-align: left;
  padding: 6px 12px;
  font-weight: 700;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute);
  border-bottom: 1px solid var(--border);
  line-height: 1.3;
}
.woocommerce-Tabs-panel table td {
  padding: 6px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
  line-height: 1.3;
}
.woocommerce-Tabs-panel table tr:last-child td { border-bottom: 0; }
.woocommerce-Tabs-panel table tr:hover td { background: var(--bg-soft); }

/* Attributes таблица (additional info tab) — плотнее + valign center */
.woocommerce-Tabs-panel table.shop_attributes {
  width: 100%; border-collapse: collapse;
  font-size: var(--fs-sm);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.woocommerce-Tabs-panel table.shop_attributes tr {
  border-bottom: 1px solid var(--border);
}
.woocommerce-Tabs-panel table.shop_attributes tr:last-child {
  border-bottom: 0;
}
.woocommerce-Tabs-panel table.shop_attributes th {
  text-align: left;
  padding: 9px 14px;
  background: var(--bg-soft);
  width: 40%;
  font-weight: 500;
  color: var(--text-mute);
  border: 0;
  text-transform: none;
  letter-spacing: normal;
  font-size: var(--fs-sm);
  line-height: 1.4;
  vertical-align: middle;
}
.woocommerce-Tabs-panel table.shop_attributes td {
  padding: 9px 14px;
  border: 0;
  color: var(--text);
  font-weight: 500;
  line-height: 1.4;
  vertical-align: middle;
}
.woocommerce-Tabs-panel table.shop_attributes td p {
  margin: 0;
  line-height: inherit;
}
.woocommerce-Tabs-panel table.shop_attributes a {
  color: var(--link);
}

/* Documents tab (issue #5) */
.cv2-doc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--s-2);
}
.cv2-doc-item a {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  transition: all var(--t);
}
.cv2-doc-item a:hover {
  border-color: var(--link);
  background: var(--bg-soft);
}
.cv2-doc-type {
  background: var(--accent);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 4px;
  letter-spacing: 0.04em;
}
.cv2-doc-title {
  flex: 1;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text);
}
.cv2-doc-item svg {
  color: var(--text-mute);
  flex-shrink: 0;
}

/* Related / Upsells (issue #14) */
.related, .upsells {
  margin-top: var(--s-12);
  padding-top: var(--s-8);
  border-top: 1px solid var(--border);
}
.related h2, .upsells h2 {
  margin: 0 0 var(--s-6);
  font-size: var(--fs-xl);
  font-weight: 700;
}
/* Контейнер с сеткой 4 колонки на desktop, 2 — tablet, 1 — mobile */
.related .prod-grid, .upsells .prod-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}
@media (max-width: 1023px) {
  .related .prod-grid, .upsells .prod-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 767px) {
  .related .prod-grid, .upsells .prod-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .related .prod-grid, .upsells .prod-grid { grid-template-columns: 1fr; }
}

/* === CART === */
body.woocommerce-cart .site-main,
body.woocommerce-checkout .site-main,
body.woocommerce-account .site-main {
  background: #fff;
}
/* ВАЖНО: только main-container, не задеваем .topbar .container / .header .container etc. */
body.woocommerce-cart .site-main > .container,
body.woocommerce-checkout .site-main > .container,
body.woocommerce-account .site-main > .container {
  padding-top: var(--s-6) !important;
  padding-bottom: var(--s-16) !important;
  max-width: var(--max-w) !important;
}
body.woocommerce-cart h1,
body.woocommerce-checkout h1,
body.woocommerce-account h1 {
  margin-bottom: var(--s-6);
}

/* Sticky cart-summary справа на desktop (issue #13).
   Cross-sells вынесен через WC hook в woocommerce_after_cart (см. inc/woocommerce.php),
   поэтому он рендерится ПОСЛЕ .cart-collaterals и не попадает в 360px колонку. */
@media (min-width: 980px) {
  body.woocommerce-cart .woocommerce {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: var(--s-8);
    align-items: start;
  }
  body.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper {
    grid-column: 1 / -1;
  }
  body.woocommerce-cart .woocommerce > .woocommerce-cart-form {
    grid-column: 1;
    min-width: 0;
  }
  body.woocommerce-cart .woocommerce > .cart-collaterals {
    grid-column: 2;
    position: sticky;
    top: var(--s-6);
    width: 100%;
    max-width: 360px;
    min-width: 0;
  }
  body.woocommerce-cart .woocommerce > .cross-sells {
    grid-column: 1 / -1;
    margin-top: var(--s-8);
    width: 100%;
    min-width: 0;
  }
  body.woocommerce-cart .cart_totals {
    margin: 0 !important;
    width: 100%;
  }
}

/* Cross-sells: сетка карточек на полную ширину (issue #13 fix) */
body.woocommerce-cart .cross-sells {
  margin-top: var(--s-8);
}
body.woocommerce-cart .cross-sells h2 {
  margin-bottom: var(--s-5);
}
body.woocommerce-cart .cross-sells ul.products {
  display: grid;
  gap: var(--s-4);
  grid-template-columns: repeat(2, 1fr);
  list-style: none;
  padding: 0;
}
@media (min-width: 640px) {
  body.woocommerce-cart .cross-sells ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1100px) {
  body.woocommerce-cart .cross-sells ul.products { grid-template-columns: repeat(4, 1fr); }
}
/* === CART TABLE — карточки вместо стандартной таблицы === */
.woocommerce-cart-form table.cart {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin-bottom: var(--s-6);
}
/* Скрываем thead на десктопе — карточки самодостаточны */
.woocommerce-cart-form table.cart thead { display: none; }
.woocommerce-cart-form table.cart tr.cart_item {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-4) var(--s-10) var(--s-4) var(--s-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--s-3);
  background: #fff;
  transition: border-color var(--t), box-shadow var(--t);
  position: relative; /* для × кнопки в верхнем правом углу */
}
.woocommerce-cart-form table.cart tr.cart_item:hover {
  border-color: var(--border-strong);
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.woocommerce-cart-form table.cart td {
  padding: 0;
  border: 0;
  background: transparent;
}
/* × delete button: правый верхний угол, всегда видим */
.woocommerce-cart-form .product-remove {
  position: absolute;
  top: 10px; right: 10px;
  grid-column: auto;
  grid-row: auto;
}
.woocommerce-cart-form .product-remove .remove {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--bg-soft);
  color: var(--text-mute);
  font-size: 20px; font-weight: 400;
  line-height: 1;
  text-decoration: none !important;
  transition: all var(--t);
  border: 1px solid transparent;
}
.woocommerce-cart-form .product-remove .remove:hover {
  background: var(--danger);
  color: #fff !important;
  border-color: var(--danger);
  transform: scale(1.05);
}
.woocommerce-cart-form .product-thumbnail {
  grid-column: 1;
  grid-row: 1;
}
.woocommerce-cart-form .product-thumbnail img {
  width: 80px; height: 80px;
  object-fit: cover;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--bg-soft);
}
.woocommerce-cart-form .product-name {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
}
.woocommerce-cart-form .product-name a {
  font-weight: 600;
  color: var(--text);
  font-size: var(--fs-base);
  line-height: 1.3;
  display: block;
  margin-bottom: 4px;
}
.woocommerce-cart-form .product-name a:hover { color: var(--link); }

/* Variations (Диаметр/Цвет) — компактный двухколоночный grid вместо
   уродливого dl/dt/dd default с переносами строк и отступом 40px. */
.woocommerce-cart-form .product-name .variation {
  margin: 6px 0 0;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: var(--s-2);
  row-gap: 2px;
  font-size: var(--fs-sm);
  line-height: 1.4;
}
.woocommerce-cart-form .product-name .variation dt {
  margin: 0;
  padding: 0;
  font-weight: 400;
  color: var(--text-mute);
}
.woocommerce-cart-form .product-name .variation dt::after { content: ''; }
.woocommerce-cart-form .product-name .variation dd {
  margin: 0;
  padding: 0;
  color: var(--text);
  font-weight: 600;
}
.woocommerce-cart-form .product-name .variation dd p { margin: 0; }

.woocommerce-cart-form .product-price {
  display: block;
  font-size: var(--fs-sm);
  color: var(--text);
  font-weight: 600;
  white-space: nowrap;
}
.woocommerce-cart-form .product-price::before {
  content: 'за шт. · ';
  color: var(--text-dim);
  font-size: var(--fs-xs);
  font-weight: 400;
}
.woocommerce-cart-form .product-quantity {
  grid-column: 3;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  min-width: 120px;
}
.woocommerce-cart-form .product-quantity .qty {
  width: 64px;
  height: 36px;
  padding: 0;
  text-align: center;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: var(--fs-sm);
}
.woocommerce-cart-form .product-quantity::after {
  content: '';
}
.woocommerce-cart-form .product-subtotal {
  display: none; /* total показываем сразу в totals блоке справа */
}
@media (min-width: 768px) {
  .woocommerce-cart-form .product-subtotal {
    display: block;
    grid-column: 3;
    grid-row: 1;
    font-weight: 700;
    font-size: var(--fs-lg);
    text-align: right;
    white-space: nowrap;
  }
  .woocommerce-cart-form table.cart tr.cart_item {
    grid-template-columns: 80px minmax(0, 1fr) 130px 100px 120px;
  }
  .woocommerce-cart-form .product-name { grid-column: 2; }
  .woocommerce-cart-form .product-price { grid-column: 3; text-align: right; }
  .woocommerce-cart-form .product-quantity { grid-column: 4; }
  .woocommerce-cart-form .product-subtotal { grid-column: 5; }
}

/* Coupon + actions row */
/* td.actions — flex-контейнер. ВАЖНО: класс "actions" находится на <td>,
   НЕ на <tr>. Раньше селектор tr.actions промахивался → wrap. */
.woocommerce-cart-form td.actions {
  display: flex !important;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-4) 0 0 !important;
  border-top: 1px solid var(--border) !important;
  border-bottom: 0 !important;
  margin-top: var(--s-3);
  background: transparent !important;
}
.woocommerce-cart-form td.actions .coupon {
  display: flex;
  gap: var(--s-2);
  align-items: center;
  flex: 0 0 auto;
}
.woocommerce-cart-form td.actions button[name="update_cart"] {
  margin-left: auto;
}
.woocommerce-cart-form .coupon {
  display: flex;
  gap: var(--s-2);
  align-items: center;
}
.woocommerce-cart-form .coupon label { display: none; }
.woocommerce-cart-form .coupon #coupon_code {
  flex: 1;
  max-width: 240px;
  height: 40px;
  padding: 0 var(--s-3);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
}
.woocommerce-cart-form .coupon button[name="apply_coupon"] {
  height: 40px;
  padding: 0 var(--s-4);
  background: var(--text);
  color: #fff;
  border: 0;
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}
.woocommerce-cart-form .coupon button[name="apply_coupon"]:hover { background: var(--link); }
.woocommerce-cart-form button[name="update_cart"] {
  height: 40px;
  padding: 0 var(--s-4);
  background: transparent;
  color: var(--text-mute);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  font-weight: 500;
  cursor: pointer;
}
.woocommerce-cart-form button[name="update_cart"]:hover {
  border-color: var(--text);
  color: var(--text);
}
.woocommerce-cart-form button[name="update_cart"]:disabled {
  opacity: 0.5; cursor: default;
}

/* === CART TOTALS (правая колонка) === */
.cart_totals {
  background: var(--bg-soft);
  padding: var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}
.cart_totals h2 {
  font-size: var(--fs-lg);
  margin: 0 0 var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--border);
}
.cart_totals table.shop_table {
  background: transparent !important;
  border: 0 !important;
  width: 100%;
  border-collapse: collapse;
}
.cart_totals table.shop_table th,
.cart_totals table.shop_table td {
  padding: var(--s-2) 0 !important;
  border: 0 !important;
  background: transparent !important;
  font-size: var(--fs-sm);
  vertical-align: top;
}
.cart_totals table.shop_table th {
  color: var(--text-mute);
  font-weight: 500;
  width: 40%;
  text-align: left;
}
.cart_totals table.shop_table td {
  text-align: right;
}
.cart_totals .order-total {
  border-top: 1px solid var(--border) !important;
}
.cart_totals .order-total th,
.cart_totals .order-total td {
  padding-top: var(--s-4) !important;
  font-size: var(--fs-base) !important;
  font-weight: 700 !important;
  color: var(--text) !important;
}
.cart_totals .order-total .amount {
  font-size: var(--fs-2xl);
  font-weight: 800;
  letter-spacing: -0.01em;
  display: block;
}

/* Shipping (доставка) внутри totals — компактный radio-list */
.cart_totals .shipping ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.cart_totals .shipping li {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 6px 0;
  font-size: var(--fs-sm);
  text-align: left;
}
.cart_totals .shipping li input[type="radio"] {
  margin: 4px 0 0 0;
  flex-shrink: 0;
  accent-color: var(--accent);
}
.cart_totals .shipping li label {
  flex: 1;
  cursor: pointer;
  color: var(--text);
}
.cart_totals .shipping-calculator-button { display: none; }
.cart_totals .woocommerce-shipping-destination {
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px dashed var(--border);
  font-size: var(--fs-xs);
  color: var(--text-mute);
  text-align: left;
  line-height: 1.5;
}
.cart_totals .woocommerce-shipping-destination strong { color: var(--text); }

.wc-proceed-to-checkout {
  margin-top: var(--s-5);
}
.wc-proceed-to-checkout .checkout-button,
.cart_totals .awoof-form .awoof-submit-btn,
.cart_totals input[type="submit"].button[name*="order"],
.cart_totals .awoof-form button[type="submit"] {
  display: block; width: 100%; text-align: center;
  padding: 16px 24px;
  background: var(--accent) !important;
  color: #fff !important;
  border: 0;
  border-radius: var(--radius) !important;
  font-weight: 700; font-size: var(--fs-base);
  transition: all var(--t);
  box-shadow: 0 4px 14px rgba(249,115,22,0.35);
  cursor: pointer;
  min-height: 52px;
}
.wc-proceed-to-checkout .checkout-button:hover,
.cart_totals .awoof-form .awoof-submit-btn:hover,
.cart_totals .awoof-form button[type="submit"]:hover {
  background: var(--accent-hover) !important; color: #fff !important;
  transform: translateY(-1px);
}
/* Поле телефона между кнопками — выровнять стиль */
.cart_totals .awoof-form input[type="tel"],
.cart_totals .awoof-form input[type="text"] {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-base);
  margin: var(--s-2) 0;
  background: #fff;
}
.cart_totals .awoof-form { margin-top: var(--s-3); }

/* Mobile: компактные карточки (issue #16)
   Сетка: [img|title][img|qty subtotal] — img растягивается на 2 строки. */
@media (max-width: 767px) {
  .woocommerce-cart-form table.cart tr.cart_item {
    grid-template-columns: 72px 1fr auto;
    gap: var(--s-2) var(--s-3);
    position: relative;
    padding: var(--s-3) var(--s-8) var(--s-3) var(--s-3);
  }
  .woocommerce-cart-form .product-thumbnail {
    grid-column: 1;
    grid-row: 1 / 3;
    align-self: start;
  }
  .woocommerce-cart-form .product-thumbnail img {
    width: 72px; height: 72px;
  }
  .woocommerce-cart-form .product-name {
    grid-column: 2 / 4;
    grid-row: 1;
  }
  .woocommerce-cart-form .product-name a {
    font-size: var(--fs-sm);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  /* "Цена за единицу:" скрыта — есть subtotal */
  .woocommerce-cart-form .product-price { display: none; }
  /* Qty input по левому краю row 2 */
  .woocommerce-cart-form .product-quantity {
    grid-column: 2;
    grid-row: 2;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    min-width: 0;
  }
  .woocommerce-cart-form .product-quantity .qty {
    width: 56px; height: 32px;
  }
  /* Subtotal по правому краю row 2 */
  .woocommerce-cart-form .product-subtotal {
    display: block !important;
    grid-column: 3;
    grid-row: 2;
    text-align: right;
    font-size: var(--fs-base);
    font-weight: 700;
    white-space: nowrap;
    align-self: center;
  }
  .woocommerce-cart-form .product-remove {
    top: var(--s-2);
    right: var(--s-2);
  }
  .woocommerce-cart-form tr.actions { grid-template-columns: 1fr; }
  .woocommerce-cart-form .coupon {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s-2);
  }
  /* Coupon input full-width (главный фокус для ввода).
     Кнопки compact и одинаковые между собой, под input'ом. */
  .woocommerce-cart-form td.actions {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--s-2);
  }
  .woocommerce-cart-form .coupon {
    width: 100%;
    display: flex !important;
    flex-direction: column !important;
    gap: var(--s-2);
    align-items: flex-start !important;
  }
  .woocommerce-cart-form .coupon #coupon_code {
    max-width: none;
    width: 100%;
    height: 48px;
    font-size: var(--fs-base);
  }
  .woocommerce-cart-form td.actions .coupon button[name="apply_coupon"],
  .woocommerce-cart-form td.actions button[name="update_cart"] {
    width: auto !important;
    min-width: 180px;
    height: 44px;
    padding: 0 var(--s-5);
    margin-left: 0 !important;
    font-size: var(--fs-sm);
    white-space: nowrap;
  }
}

/* Privacy notice (WC default) — на mobile collapsible через <details>
   Большой текст «Ваши персональные данные...» занимал полэкрана. */
.woocommerce-privacy-policy-text {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  line-height: 1.4;
  background: var(--bg-soft);
  border-radius: var(--radius);
  padding: var(--s-3);
  margin: var(--s-3) 0;
}
@media (max-width: 767px) {
  /* Очень компактно — 1 строка + toggle. Полный текст в expanded. */
  .woocommerce-privacy-policy-text {
    max-height: 32px;
    overflow: hidden;
    position: relative;
    padding: var(--s-2) 44px var(--s-2) var(--s-3);
    font-size: 11px;
    line-height: 1.3;
  }
  .woocommerce-privacy-policy-text.cv2-expanded {
    max-height: 600px;
    padding: var(--s-3) 44px var(--s-3) var(--s-3);
    transition: max-height 0.3s ease;
  }
  .cv2-privacy-toggle {
    position: absolute;
    top: 50%;
    right: var(--s-2);
    transform: translateY(-50%);
    background: transparent;
    border: 0;
    padding: 2px 6px;
    font-size: 16px;
    color: var(--link);
    cursor: pointer;
    z-index: 1;
    line-height: 1;
  }
}

/* Order info table (thank-you) — на mobile stack columns */
@media (max-width: 600px) {
  body.woocommerce-order-received .woocommerce-order-details .shop_table {
    display: block;
  }
  body.woocommerce-order-received .woocommerce-order-details .shop_table thead { display: none; }
  body.woocommerce-order-received .woocommerce-order-details .shop_table tbody,
  body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot,
  body.woocommerce-order-received .woocommerce-order-details .shop_table tr {
    display: block;
  }
  body.woocommerce-order-received .woocommerce-order-details .shop_table tbody tr {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4px var(--s-3);
    padding: var(--s-3) 0;
    border-bottom: 1px solid var(--border);
  }
  body.woocommerce-order-received .woocommerce-order-details .shop_table tbody td {
    padding: 0 !important;
    border: 0 !important;
    font-size: var(--fs-sm);
  }
  body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--s-3);
    padding: var(--s-2) 0;
  }
  body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot th,
  body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot td {
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
  }
}

/* Cart drawer (issue #20) */
.cv2-cart-drawer {
  position: fixed;
  top: 0; right: 0;
  width: 400px;
  max-width: 100vw;
  height: 100dvh;
  background: #fff;
  box-shadow: -8px 0 32px rgba(0,0,0,0.12);
  z-index: 1100;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
}
.cv2-cart-drawer.is-open { transform: none; }
.cv2-cart-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 1099;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s;
}
.cv2-cart-drawer-overlay.is-open { opacity: 1; pointer-events: auto; }
.cv2-cart-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
}
.cv2-cart-drawer-title {
  margin: 0;
  font-size: var(--fs-lg);
  font-weight: 700;
}
.cv2-cart-drawer-count { color: var(--text-mute); font-weight: 500; }
.cv2-cart-drawer-close {
  width: 36px; height: 36px;
  background: var(--bg-soft);
  border: 0;
  border-radius: 50%;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  color: var(--text-mute);
}
.cv2-cart-drawer-close:hover { background: var(--border); color: var(--text); }
.cv2-cart-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--s-4) var(--s-5);
}
.cv2-cart-drawer-empty {
  text-align: center;
  padding: var(--s-12) var(--s-4);
  color: var(--text-mute);
}
.cv2-mini-cart-items {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.cv2-mini-cart-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--border);
}
.cv2-mini-cart-item:last-child { border-bottom: 0; }
.cv2-mini-cart-thumb {
  width: 56px; height: 56px;
  object-fit: cover;
  border-radius: var(--radius);
  border: 1px solid var(--border);
}
.cv2-mini-cart-meta { min-width: 0; }
.cv2-mini-cart-name {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: var(--fs-sm);
  line-height: 1.35;
  font-weight: 500;
  color: var(--text);
  margin-bottom: var(--s-1);
}
.cv2-mini-cart-name:hover { color: var(--link); }
.cv2-mini-cart-qp {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--fs-xs);
}
.cv2-mini-cart-qty { color: var(--text-mute); }
.cv2-mini-cart-price { font-weight: 700; color: var(--text); font-size: var(--fs-sm); }
.cv2-cart-drawer-foot {
  padding: var(--s-4) var(--s-5);
  border-top: 1px solid var(--border);
  background: var(--bg-soft);
}
.cv2-cart-drawer-total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--s-3);
  font-size: var(--fs-base);
}
.cv2-cart-drawer-total strong {
  font-size: var(--fs-xl);
  font-weight: 700;
}
.cv2-cart-drawer-checkout {
  display: flex !important;
  width: 100%;
  justify-content: center;
  margin-bottom: var(--s-2);
}
.cv2-cart-drawer-link {
  display: block;
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--text-mute);
  text-decoration: none;
  padding: var(--s-2);
}
.cv2-cart-drawer-link:hover { color: var(--link); }
.prod-cta.is-loading {
  opacity: 0.7;
  pointer-events: none;
  position: relative;
}
.prod-cta.is-loading::after {
  content: '';
  position: absolute;
  top: 50%; right: 8px;
  margin-top: -7px;
  width: 14px; height: 14px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: cv2-spin 0.7s linear infinite;
}

/* Checkout progress bar (issue #18) */
.cv2-checkout-progress {
  margin: 0 0 var(--s-8);
}
.cv2-checkout-progress ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.cv2-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-4) var(--s-2);
  position: relative;
  color: var(--text-mute);
  font-size: var(--fs-sm);
  font-weight: 500;
}
.cv2-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--bg-soft);
  border: 2px solid var(--border);
  font-weight: 700;
  font-size: var(--fs-sm);
  color: var(--text-mute);
  transition: all var(--t);
}
.cv2-step-label { white-space: nowrap; }
/* Соединительная линия между шагами */
.cv2-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: calc(var(--s-4) + 16px);
  left: 50%;
  width: 100%;
  height: 2px;
  background: var(--border);
  z-index: 0;
}
.cv2-step-num { position: relative; z-index: 1; }
/* Done — зелёная галочка */
.cv2-step--done .cv2-step-num {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  font-size: 0;
}
.cv2-step--done .cv2-step-num::before {
  content: '✓';
  font-size: var(--fs-sm);
  font-weight: 700;
}
.cv2-step--done:not(:last-child)::after { background: var(--accent); }
.cv2-step--done .cv2-step-label { color: var(--text); }
/* Current — выделенный */
.cv2-step--current .cv2-step-num {
  background: var(--text);
  border-color: var(--text);
  color: #fff;
}
.cv2-step--current .cv2-step-label {
  color: var(--text);
  font-weight: 700;
}
/* Mobile */
@media (max-width: 640px) {
  .cv2-step { font-size: var(--fs-xs); padding: var(--s-2); }
  .cv2-step-num { width: 28px; height: 28px; font-size: var(--fs-xs); }
}

/* Legal-type switcher (Физ/Юр) — единый accent для обоих выбранных
   состояний (плагин даёт оранжевый для individual + синий для legal). */
.radio-switch-option.individual.active,
.radio-switch-option.legal.active {
  background: var(--accent) !important;
  color: #fff !important;
}

/* ════════════════════════════════════════════
   BOTTOM-TAB NAVIGATION (mobile)
   ════════════════════════════════════════════ */
.cv2-bottom-nav { display: none; }
@media (max-width: 767px) {
  .cv2-bottom-nav {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 90;
    background: #fff;
    border-top: 1px solid var(--border);
    box-shadow: 0 -2px 12px rgba(0,0,0,0.04);
    padding: 6px 0 max(6px, env(safe-area-inset-bottom));
  }
  /* Сдвигаем body чтобы bottom-nav не закрывал контент */
  body { padding-bottom: 64px; }
  .cv2-bn-item {
    background: none;
    border: 0;
    padding: 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    font-size: 10px;
    color: var(--text-mute);
    text-decoration: none;
    cursor: pointer;
  }
  .cv2-bn-item:hover, .cv2-bn-item:active { color: var(--text); }
  .cv2-bn-item svg { color: currentColor; }
  .cv2-bn-cart-wrap { position: relative; }
  .cv2-bn-badge {
    position: absolute;
    top: -4px; right: -8px;
    min-width: 18px; height: 18px;
    padding: 0 4px;
    background: var(--accent);
    color: #fff;
    border-radius: 99px;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
  }
  .cv2-bn-badge[hidden] { display: none; }
  /* На /checkout/ bottom-nav закрывает кнопку «Подтвердить заказ» — прячем.
     На thank-you (.woocommerce-order-received) оставляем — там кнопка уже не нужна. */
  body.woocommerce-checkout:not(.woocommerce-order-received) .cv2-bottom-nav { display: none; }
  body.woocommerce-checkout:not(.woocommerce-order-received) { padding-bottom: 0; }
  /* На single-product мобильный sticky-atc приоритетнее nav-а: bottom-nav прячем,
     чтобы CTA «В корзину» из sticky-bar не перекрывался. */
  body.single-product .cv2-bottom-nav { display: none; }
  body.single-product { padding-bottom: 0; }
}

/* ════════════════════════════════════════════
   QUICK VIEW MODAL
   ════════════════════════════════════════════ */
.cv2-quickview-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--s-4);
}
.cv2-quickview-overlay.is-open { display: flex; }
.cv2-quickview {
  background: #fff;
  border-radius: var(--radius-lg);
  max-width: 960px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  padding: var(--s-6);
  box-shadow: 0 20px 60px rgba(0,0,0,0.2);
}
.cv2-quickview-close {
  position: absolute;
  top: var(--s-3); right: var(--s-3);
  width: 36px; height: 36px;
  background: var(--bg-soft);
  border: 0;
  border-radius: 50%;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  color: var(--text-mute);
}
.cv2-quickview-close:hover { background: var(--border); color: var(--text); }
.cv2-quickview-loading {
  text-align: center;
  padding: var(--s-10);
  color: var(--text-mute);
}
.cv2-quickview-content { padding: var(--s-2) 0; }
/* Reset Elementor styles inside modal — show only essential */
.cv2-quickview-content .elementor-element,
.cv2-quickview-content .elementor-widget { display: contents !important; }
.cv2-quickview-content h1 { font-size: var(--fs-2xl); margin: 0 0 var(--s-2); }
.cv2-quickview-content .price, .cv2-quickview-content .woocommerce-Price-amount {
  font-size: var(--fs-xl); font-weight: 700;
}
.cv2-quickview-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: var(--s-2);
  padding: 6px 10px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
  color: var(--text-mute);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
}
.cv2-quickview-btn:hover { color: var(--link); border-color: var(--link); }

/* ════════════════════════════════════════════
   THANK-YOU / ORDER RECEIVED PAGE
   ════════════════════════════════════════════ */
body.woocommerce-order-received p.woocommerce-thankyou-order-received,
body.woocommerce-order-received p:has(+ .woocommerce-order-overview) {
  font-size: var(--fs-lg);
  color: var(--text);
  margin: var(--s-4) 0 var(--s-6);
}

/* «Номер заказа / Дата / Итого / Способ оплаты» — карточная сетка */
body.woocommerce-order-received .woocommerce-order-overview {
  list-style: none;
  padding: 0;
  margin: var(--s-4) 0 var(--s-8);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s-3);
  border: 0;
  background: transparent;
}
body.woocommerce-order-received .woocommerce-order-overview li {
  background: var(--bg-soft);
  padding: var(--s-4);
  border-radius: var(--radius-lg);
  font-size: var(--fs-xs);
  color: var(--text-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  border: 1px solid var(--border);
}
body.woocommerce-order-received .woocommerce-order-overview li strong {
  font-size: var(--fs-lg);
  color: var(--text);
  font-weight: 800;
  text-transform: none;
  letter-spacing: normal;
}

/* h2 заголовки секций */
body.woocommerce-order-received .woocommerce-order-details h2,
body.woocommerce-order-received .woocommerce-customer-details h2,
body.woocommerce-order-received .woocommerce-column__title {
  font-size: var(--fs-xl);
  font-weight: 700;
  margin: var(--s-8) 0 var(--s-4);
  padding-bottom: var(--s-2);
  border-bottom: 1px solid var(--border);
}

/* Таблица «Информация о заказе» */
body.woocommerce-order-received .woocommerce-order-details .shop_table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 var(--s-6);
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
body.woocommerce-order-received .woocommerce-order-details .shop_table thead th {
  background: var(--bg-soft);
  font-weight: 700;
  font-size: var(--fs-xs);
  color: var(--text-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: var(--s-3) var(--s-4);
  text-align: left;
  border-bottom: 1px solid var(--border);
}
body.woocommerce-order-received .woocommerce-order-details .shop_table thead th:last-child {
  text-align: right;
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tbody td {
  padding: var(--s-3) var(--s-4);
  vertical-align: top;
  border-bottom: 1px solid var(--border);
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tbody td.product-name a {
  color: var(--text);
  font-weight: 500;
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tbody td.product-name a:hover {
  color: var(--link);
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tbody td.product-total,
body.woocommerce-order-received .woocommerce-order-details .shop_table tbody td.woocommerce-table__product-total {
  text-align: right;
  font-weight: 600;
  white-space: nowrap;
}
body.woocommerce-order-received .woocommerce-order-details .product-quantity {
  display: inline-block;
  padding: 2px 8px;
  margin-left: var(--s-2);
  background: var(--bg-soft);
  border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--text-mute);
  white-space: nowrap;
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot th {
  text-align: left;
  padding: var(--s-3) var(--s-4);
  font-weight: 600;
  background: var(--bg-soft);
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot td {
  text-align: right;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-soft);
  white-space: nowrap;
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr:last-child th,
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr:last-child td {
  font-size: var(--fs-lg);
  font-weight: 800;
}
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr:last-child td .amount {
  font-size: var(--fs-2xl);
  font-weight: 800;
}

/* Customer details (платёжный + доставка) — две колонки */
body.woocommerce-order-received .woocommerce-customer-details {
  margin-top: var(--s-8);
}
body.woocommerce-order-received .woocommerce-customer-details > section.woocommerce-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-6);
}
@media (max-width: 767px) {
  body.woocommerce-order-received .woocommerce-customer-details > section.woocommerce-columns {
    grid-template-columns: 1fr;
  }
}
body.woocommerce-order-received .woocommerce-customer-details address {
  font-style: normal;
  background: var(--bg-soft);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  line-height: 1.7;
  font-size: var(--fs-sm);
}

/* Docs by order — card */
body.woocommerce-order-received .vadim_corneta_1c_docs,
body.woocommerce-order-received [class*="order-documents"] {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--s-5);
  margin: var(--s-6) 0;
}

/* Уменьшаем шрифты на странице «спасибо за заказ» — base 12px (по запросу).
   Heading-страницы (h1) не трогаем. */
body.woocommerce-order-received { font-size: 12px; }
body.woocommerce-order-received p.woocommerce-thankyou-order-received,
body.woocommerce-order-received p:has(+ .woocommerce-order-overview) { font-size: 14px; }
body.woocommerce-order-received .woocommerce-order-overview li { font-size: 9px; }
body.woocommerce-order-received .woocommerce-order-overview li strong { font-size: 14px; }
body.woocommerce-order-received .woocommerce-order-details h2,
body.woocommerce-order-received .woocommerce-customer-details h2,
body.woocommerce-order-received .woocommerce-column__title { font-size: 18px; }
body.woocommerce-order-received .woocommerce-order-details .shop_table thead th { font-size: 9px; }
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr:last-child th,
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr:last-child td { font-size: 14px; }
body.woocommerce-order-received .woocommerce-order-details .shop_table tfoot tr:last-child td .amount { font-size: 24px; }
body.woocommerce-order-received .woocommerce-order-details .product-quantity { font-size: 9px; }
body.woocommerce-order-received .woocommerce-customer-details address { font-size: 11px; }

/* ════════════════════════════════════════════
   LEGAL PAGES (privacy / terms / consents)
   ════════════════════════════════════════════ */
.cv2-legal-page {
  padding: var(--s-8) 0 var(--s-16);
  background: var(--bg);
}
.cv2-legal-breadcrumbs {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  margin-bottom: var(--s-4);
}
.cv2-legal-breadcrumbs a { color: var(--text-mute); }
.cv2-legal-breadcrumbs a:hover { color: var(--link); }
.cv2-legal-breadcrumbs span { margin: 0 var(--s-1); color: var(--text-dim); }
.cv2-legal-breadcrumbs strong { color: var(--text); font-weight: 500; }

.cv2-legal-head {
  margin-bottom: var(--s-8);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--border);
}
.cv2-legal-title {
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0 0 var(--s-3);
}
.cv2-legal-meta {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  color: var(--text-mute);
  background: var(--bg-soft);
  padding: var(--s-2) var(--s-3);
  border-radius: var(--radius);
  margin: 0;
}

.cv2-legal-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s-10);
  align-items: start;
}
@media (max-width: 1023px) {
  .cv2-legal-layout {
    grid-template-columns: 1fr;
    gap: var(--s-6);
  }
}

.cv2-legal-toc {
  position: sticky;
  top: var(--s-6);
  max-height: calc(100vh - var(--s-12));
  overflow-y: auto;
}
.cv2-legal-toc details {
  background: var(--bg-soft);
  border-radius: var(--radius-lg);
  padding: var(--s-3) var(--s-4);
}
.cv2-legal-toc summary {
  font-weight: 700;
  font-size: var(--fs-base);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-1) 0;
}
.cv2-legal-toc summary::-webkit-details-marker { display: none; }
.cv2-legal-toc summary::after {
  content: '▾';
  font-size: 12px;
  color: var(--text-mute);
  transition: transform var(--t);
}
.cv2-legal-toc details[open] summary::after { transform: rotate(180deg); }
.cv2-legal-toc ol {
  list-style: none;
  padding: 0;
  margin: var(--s-3) 0 0;
  counter-reset: toc;
}
.cv2-legal-toc li {
  counter-increment: toc;
  padding: 4px 0;
  position: relative;
  padding-left: 28px;
  font-size: var(--fs-sm);
  line-height: 1.4;
}
.cv2-legal-toc li::before {
  content: counter(toc) '.';
  position: absolute;
  left: 0;
  top: 4px;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--text-dim);
  font-weight: 600;
}
.cv2-legal-toc a {
  color: var(--text-mute);
  text-decoration: none;
}
.cv2-legal-toc a:hover { color: var(--link); }

/* Body typography */
.cv2-legal-body {
  max-width: 760px;
  font-size: 17px;
  line-height: 1.7;
  color: var(--text);
}
.cv2-legal-body h2 {
  font-size: clamp(22px, 2.8vw, 30px);
  font-weight: 700;
  line-height: 1.2;
  margin: var(--s-10) 0 var(--s-4);
  padding-left: var(--s-4);
  border-left: 4px solid var(--accent);
  scroll-margin-top: 100px;
}
.cv2-legal-body h2:first-child { margin-top: 0; }
.cv2-legal-body h3 {
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 700;
  margin: var(--s-6) 0 var(--s-3);
}
.cv2-legal-body h4 {
  font-size: 17px;
  font-weight: 700;
  margin: var(--s-4) 0 var(--s-2);
}
.cv2-legal-body p {
  margin: 0 0 var(--s-3);
}
.cv2-legal-body ul, .cv2-legal-body ol {
  margin: 0 0 var(--s-4);
  padding-left: var(--s-6);
}
.cv2-legal-body li { margin-bottom: var(--s-1); }
.cv2-legal-body strong { font-weight: 700; color: var(--text); }
.cv2-legal-body a {
  color: var(--link);
  border-bottom: 1px solid var(--link-hover);
}
.cv2-legal-body a:hover {
  color: var(--link-hover);
}
.cv2-legal-body table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-4) 0;
  font-size: var(--fs-sm);
}
.cv2-legal-body th, .cv2-legal-body td {
  padding: var(--s-2) var(--s-3);
  border: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}
.cv2-legal-body th {
  background: var(--bg-soft);
  font-weight: 700;
}
.cv2-legal-body blockquote {
  border-left: 3px solid var(--border-strong);
  padding-left: var(--s-4);
  margin: var(--s-4) 0;
  color: var(--text-mute);
  font-style: italic;
}
.cv2-legal-body code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--bg-soft);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}
.cv2-legal-body hr {
  border: 0;
  border-top: 1px solid var(--border);
  margin: var(--s-6) 0;
}

/* Footer of legal page */
.cv2-legal-foot {
  margin-top: var(--s-12);
  padding-top: var(--s-8);
  border-top: 1px solid var(--border);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-8);
  align-items: start;
}
@media (max-width: 767px) {
  .cv2-legal-foot { grid-template-columns: 1fr; gap: var(--s-6); }
}
.cv2-legal-related h3 {
  font-size: var(--fs-base);
  font-weight: 700;
  margin: 0 0 var(--s-3);
}
.cv2-legal-related ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.cv2-legal-related a {
  color: var(--link);
  font-size: var(--fs-sm);
}
.cv2-legal-cta {
  text-align: right;
  font-size: var(--fs-sm);
  color: var(--text-mute);
}
@media (max-width: 767px) {
  .cv2-legal-cta { text-align: left; }
}
.cv2-legal-cta p { margin: 0 0 var(--s-2); }
.cv2-legal-phone, .cv2-legal-mail {
  font-weight: 700;
  color: var(--text);
}
.cv2-legal-sep { margin: 0 var(--s-2); color: var(--text-dim); }


/* ════════════════════════════════════════════
   GENERIC PAGE (page.php) — /about/, /delivery/ и т.п.
   Динамическая ширина: чем шире viewport, тем шире контент.
   Min 880 для читаемости текста, max 1200 на широких экранах.
   ════════════════════════════════════════════ */
.cv2-page-wrap {
  padding-top: var(--s-10);
  padding-bottom: var(--s-16);
  max-width: clamp(880px, 92vw, 1200px);
}
@media (max-width: 880px) {
  .cv2-page-wrap { max-width: 100%; }
}
.cv2-page-title { margin-bottom: var(--s-6); }
.cv2-page-content {
  font-size: var(--fs-lg);
  line-height: 1.7;
}
.cv2-page-lead {
  font-size: var(--fs-lg);
  line-height: 1.5;
  color: var(--text-mute);
  max-width: 720px;
  margin: 0 0 var(--s-8);
}

/* Breadcrumb (унифицированный для всех V2-страниц) */
.cv2-bc {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  margin: 0 0 var(--s-5);
}
.cv2-bc a { color: var(--text-mute); }
.cv2-bc a:hover { color: var(--link); }
.cv2-bc-sep { margin: 0 var(--s-1); color: var(--text-dim); }
.cv2-bc strong { color: var(--text); font-weight: 500; }

/* ════════════════════════════════════════════
   TOOLS LANDING — /tools/
   ════════════════════════════════════════════ */
.cv2-tools-grid {
  display: grid;
  gap: var(--s-4);
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
@media (max-width: 480px) {
  .cv2-tools-grid { grid-template-columns: 1fr; }
}
.cv2-tool-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-5);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: var(--text);
  transition: all var(--t);
  overflow: hidden;
}
.cv2-tool-card:hover {
  border-color: var(--accent);
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  transform: translateY(-2px);
  color: var(--text);
}
.cv2-tool-card-arrow {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  font-size: 18px;
  color: var(--text-dim);
  transition: all var(--t);
}
.cv2-tool-card:hover .cv2-tool-card-arrow {
  color: var(--accent);
  transform: translateX(4px);
}
.cv2-tool-card-icon {
  font-size: 32px;
  line-height: 1;
  margin-bottom: var(--s-1);
}
.cv2-tool-card-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  margin: 0;
  line-height: 1.3;
  padding-right: var(--s-6); /* место под стрелку */
}
.cv2-tool-card-desc {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}
.cv2-tool-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--s-2);
}
.cv2-tool-tag {
  font-size: var(--fs-xs);
  padding: 3px 8px;
  background: var(--bg-soft);
  color: var(--text-mute);
  border-radius: 4px;
  font-weight: 500;
}
/* Первый тег обычно содержит статус-маркер (🔥 НОВИНКА, ⭐ ХИТ, ✅ Готов) */
.cv2-tool-tag:first-child {
  background: rgba(249,115,22,0.1);
  color: var(--accent);
  font-weight: 600;
}
/* «ХИТ» — выделенная карточка (Analog Finder) */
.cv2-tool-card--hit { border-color: rgba(249,115,22,0.3); background: linear-gradient(135deg, rgba(249,115,22,0.04), #fff); }

/* ════════════════════════════════════════════
   ANALOG FINDER — /analog/ (V2 wrapper для dark SPA)
   ════════════════════════════════════════════ */
.cv2-analog-page { padding-bottom: var(--s-12); }
.cv2-analog-page .cv2-page-lead { margin-bottom: var(--s-5); }

/* Hero — split layout: текст слева, search card справа (по прототипу proto/analog-v2) */
.cv2-analog-hero {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  color: #fff;
  padding: 56px 0 16px;
  position: relative;
  overflow: hidden;
}
.cv2-analog-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 78% 30%, rgba(249,115,22,0.14), transparent 60%);
  pointer-events: none;
}
.cv2-analog-hero > .container {
  position: relative; z-index: 1;
  max-width: 1600px;
  /* padding 24px чтобы совпало с widget chrome (.v2-header__inner / .v2-brand-bar / .v2-breadcrumbs / .v2-layout — все 24px) */
  padding-left: 24px !important;
  padding-right: 24px !important;
}

.cv2-analog-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 780px;
  gap: 32px;
  align-items: start;
}
.cv2-hero-searchcard { width: 100%; box-sizing: border-box; }
.cv2-analog-hero-right { padding-right: 16px; }
@media (max-width: 980px) { .cv2-analog-hero-right { padding-right: 0; } }
.cv2-analog-hero-left { max-width: 100%; }
.cv2-analog-hero-right { display: flex; flex-direction: column; gap: 14px; }
@media (max-width: 980px) {
  .cv2-analog-hero-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* Breadcrumb (внутри left column сверху) */
.cv2-bc--dark { color: rgba(255,255,255,0.55); margin-bottom: 18px; line-height: 1; font-size: 13px; }
.cv2-bc--dark a { color: rgba(255,255,255,0.55); text-decoration: none; }
.cv2-bc--dark a:hover { color: rgba(255,255,255,0.85); }
.cv2-bc--dark strong { color: rgba(255,255,255,0.9); font-weight: 500; }
.cv2-bc--dark .cv2-bc-sep { color: rgba(255,255,255,0.3); margin: 0 6px; }

/* Eyebrow */
.cv2-analog-hero-eyebrow {
  display: inline-block;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  color: #cbd5e1;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 99px;
  margin-bottom: 22px;
}
/* H1 */
.cv2-analog-hero-title {
  font-size: clamp(28px, 3.6vw, 42px);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0 0 20px;
}
.cv2-analog-hero-title .cv2-hero-accent { color: var(--accent); white-space: nowrap; }
.cv2-hero-accent { color: var(--accent); }
/* Lead */
.cv2-analog-hero-lead {
  font-size: 16.5px;
  line-height: 1.55;
  color: #cbd5e1;
  margin: 0 0 8px;
  max-width: 520px;
}

/* Popular tags row — под search card в правой колонке */
.cv2-analog-hero-popular {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}
.cv2-analog-hero-popular-label {
  font-size: 11px;
  color: #94a3b8;
  margin-right: 6px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
}
.cv2-analog-hero-popular a {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: #e2e8f0;
  padding: 6px 12px;
  border-radius: 99px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
  transition: all .15s;
}
.cv2-analog-hero-popular a:hover {
  background: rgba(249,115,22,0.15);
  border-color: rgba(249,115,22,0.6);
  color: #fff;
}
.cv2-analog-hero-popular__more-btn {
  color: #94a3b8;
  background: transparent;
  border: 1px dashed rgba(255,255,255,0.18);
  padding: 6px 12px;
  border-radius: 99px;
  font-family: Inter, sans-serif;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
}
.cv2-analog-hero-popular__more-btn:hover {
  color: #fff;
  border-style: solid;
  border-color: rgba(255,255,255,0.3);
}

/* ── SEARCH CARD ── */
.cv2-hero-searchcard {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  padding: 24px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 24px 60px rgba(0,0,0,0.35);
}
.cv2-hero-searchcard__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.cv2-hero-searchcard__head b {
  color: var(--accent);
  font-size: 22px;
  font-weight: 800;
  font-family: var(--font-mono);
  letter-spacing: -0.02em;
}
.cv2-hero-searchcard__head span {
  font-size: 11px;
  color: #94a3b8;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}

/* Mount для перенесённого widget .v2-search-wrap. Внутри карточки рендерим
   в row-flex: input + кнопка «Поиск» в одну строку (3:1), «Списком» переносится ниже. */
.cv2-hero-searchcard__mount { position: relative; }
.cv2-hero-searchcard__mount .v2-search-wrap {
  display: flex !important;
  flex-wrap: wrap;
  gap: 10px;
  background: transparent;
  padding: 0;
  position: relative;
  width: auto !important;
  height: auto !important;
  clip: auto !important;
  clip-path: none !important;
  overflow: visible !important;
  box-shadow: none;
}
.cv2-hero-searchcard__mount .v2-search-input-wrap {
  position: relative;
  flex: 4 1 0;
  min-width: 0;
}
.cv2-hero-searchcard__mount .v2-search-input {
  width: 100%;
  padding: 18px 18px 18px 50px;
  border: 2px solid transparent;
  background: #fff;
  color: #0f172a;
  border-radius: 12px;
  font-family: var(--font-mono);
  font-size: 15.5px;
  font-weight: 600;
  outline: 0;
  transition: border-color .15s, box-shadow .15s;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
  min-width: 0;
}
.cv2-hero-searchcard__mount .v2-search-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(249,115,22,0.18), 0 8px 24px rgba(0,0,0,0.18);
}
.cv2-hero-searchcard__mount .v2-search-input::placeholder { color: #94a3b8; font-weight: 500; }
/* 🔍 иконка перед input через ::before на .v2-search-input-wrap */
.cv2-hero-searchcard__mount .v2-search-input-wrap::before {
  content: "🔍";
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
  font-size: 17px;
  pointer-events: none;
  z-index: 1;
}
.cv2-hero-searchcard__mount .v2-search-btn {
  flex: 1 1 0;
  min-width: 0;
  padding: 16px 12px;
  background: var(--accent);
  color: #fff;
  border: 0;
  border-radius: 12px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  transition: background .15s, box-shadow .15s;
  box-shadow: 0 8px 24px rgba(249,115,22,0.28);
  letter-spacing: 0.01em;
}
.cv2-hero-searchcard__mount .v2-search-btn:hover {
  background: var(--accent-hover);
  box-shadow: 0 12px 28px rgba(249,115,22,0.4);
}
/* bulk-кнопка переносится на свою строку под input+button, плоский text-link */
.cv2-hero-searchcard__mount .v2-search-btn--bulk {
  flex: 1 1 100%;
  background: transparent;
  color: #cbd5e1;
  box-shadow: none;
  padding: 8px 0 2px;
  font-weight: 500;
  font-size: 13px;
  border-radius: 4px;
  text-align: center;
}
.cv2-hero-searchcard__mount .v2-search-btn--bulk::before { content: "📄 "; margin-right: 4px; }
.cv2-hero-searchcard__mount .v2-search-btn--bulk:hover {
  background: transparent;
  color: #fff;
}

/* Suggest-выпадашка под input */
.cv2-hero-searchcard__mount .v2-suggest {
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  border-radius: 10px;
  z-index: 30;
}

/* Lang switcher (внизу справа за карточкой) */
.cv2-hero-searchcard__lang {
  align-self: flex-end;
  font-size: 12px;
  color: #64748b;
}
.cv2-hero-searchcard__lang .v2-lang-btn {
  display: inline-block !important;
  background: transparent;
  border: 0;
  color: #94a3b8;
  padding: 3px 10px;
  border-radius: 99px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  letter-spacing: 0;
  text-transform: none;
}
.cv2-hero-searchcard__lang .v2-lang-btn:hover {
  background: rgba(255,255,255,0.06);
  color: #fff;
}

/* Widget container — синяя секция на ВСЮ ширину viewport (как hero главной).
   Без max-width, без rounded corners, без отступов сбоку. */
.cv2-analog-widget {
  width: 100%;
  margin: 0 0 var(--s-8);
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  /* Переопределяем внутренние CSS-переменные виджета чтобы карточки/панели
     тоже смотрелись в slate-палитре главной, а не в navy-black. */
  --v2-bg: #0f172a;
  --v2-panel: #1e293b;
  --v2-panel-2: #243042;
  --v2-border: #334155;
  /* Жёлтые акценты warning/near (АНАЛОГ-бэйдж, каталожная серия) → оранжевый бренд-акцент */
  --v2-warning: #f97316;
  --v2-near: #f97316;
}
/* Прямые hex #eab308 / #f59e0b в правилах виджета — переопределяем точечно */
.cv2-analog-widget [style*="#eab308"],
.cv2-analog-widget [style*="#f59e0b"] { color: #f97316 !important; }
.cv2-analog-widget .v2-header.v2-header--embedded {
  /* Internal widget header — содержит критичные DOM-узлы (search/sidebar toggle) для JS.
     Не sticky, чтобы не дублировать V2 sticky-header сверху. */
  position: relative !important;
  top: auto !important;
}
/* Logo image в widget header — спрятан (наш WP header уже имеет логотип) */
.cv2-analog-widget .v2-logo__img { display: none; }
.cv2-analog-widget .v2-logo { pointer-events: none; }
.cv2-analog-widget .v2-shop-link { display: none; } /* «Магазин ↗» — V2 header уже даёт это */
.cv2-analog-widget .v2-contact-link { display: none; } /* «Контакт» — V2 header даёт */

/* Поиск виджета перенесён в hero-card; внутренний header виджета упрощён. */
.cv2-analog-widget .v2-header__inner { padding: 8px 24px; min-height: 0; }
.cv2-analog-widget .v2-logo__sub { display: none; }
.cv2-analog-widget .v2-sidebar-toggle { display: none; }

/* Widget chrome остаётся 1600px (native), hero расширен до 1600px чтобы совпадало.
   На ultra-wide прозрачные фоны чтобы не было разных оттенков по бокам. */
.cv2-analog-widget .v2-brand-bar,
.cv2-analog-widget .v2-breadcrumbs {
  background: transparent !important;
  border-bottom-color: rgba(255,255,255,0.06) !important;
}
.cv2-analog-widget .v2-header { background: transparent !important; }

/* Контраст для критичных текстов внутри виджета (серия SKU + заголовки Configurator/Аналоги) */
.cv2-analog-widget .v2-series-title,
.cv2-analog-widget .v2-section-head h2,
.cv2-analog-widget .v2-analogs-head h2,
.cv2-analog-widget .v2-analogs h2 {
  color: #f1f5f9 !important;
  font-weight: 700;
}
.cv2-analog-widget .v2-analogs .v2-muted,
.cv2-analog-widget .v2-analogs-head .v2-muted { color: #cbd5e1 !important; }

/* Landing-stats: «4 000 серий · 166 795 артикулов · 14 брендов» — крупно и читаемо */
.cv2-analog-widget .v2-landing-stats {
  font-size: 15px;
  padding: 18px 24px;
  gap: 32px;
  color: #cbd5e1 !important;
}
.cv2-analog-widget .v2-landing-stats span {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.cv2-analog-widget .v2-landing-stats strong {
  color: var(--accent) !important;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.cv2-analog-widget .v2-series-title { color: #fff !important; font-weight: 800; }
.cv2-analog-widget .v2-series-head__meta,
.cv2-analog-widget .v2-section-title { color: #cbd5e1 !important; }

/* Brand-чип в suggest-выпадашке — оранжевый акцент */
.cv2-analog-widget .v2-suggest-brand {
  color: var(--accent) !important;
  background: rgba(249,115,22,0.10) !important;
  border-color: rgba(249,115,22,0.35) !important;
  font-weight: 600;
}

/* SEO content под widget'ом — светлая тема, V2 типографика */
.cv2-analog-seo {
  font-size: var(--fs-base);
  line-height: 1.7;
  color: var(--text);
  max-width: clamp(880px, 92vw, 1100px);
  padding-top: var(--s-8);
}
.cv2-analog-seo h2 {
  font-size: clamp(20px, 2.5vw, 28px);
  margin: var(--s-8) 0 var(--s-3);
  color: var(--text);
}
.cv2-analog-seo h3 {
  font-size: var(--fs-lg);
  margin: var(--s-5) 0 var(--s-2);
  color: var(--text);
}
.cv2-analog-seo p { margin: 0 0 var(--s-3); color: var(--text-mute); }
.cv2-analog-seo strong { color: var(--text); }
.cv2-analog-seo a { color: var(--link); }
.cv2-analog-seo a:hover { color: var(--link-hover); }


/* ════════════════════════════════════════════
   CONTACTS PAGE
   ════════════════════════════════════════════ */
.cv2-contacts-page { background: var(--bg); padding-bottom: var(--s-16); }
.cv2-contacts-hero {
  background: linear-gradient(135deg, var(--text) 0%, #1a2332 100%);
  color: #fff;
  padding: var(--s-10) 0 var(--s-12);
  margin-bottom: var(--s-10);
}
.cv2-contacts-hero .cv2-legal-breadcrumbs,
.cv2-contacts-hero .cv2-legal-breadcrumbs a,
.cv2-contacts-hero .cv2-legal-breadcrumbs strong {
  color: rgba(255,255,255,0.7);
}
.cv2-contacts-hero .cv2-legal-breadcrumbs strong { color: #fff; }
.cv2-contacts-hero h1 {
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 var(--s-3);
  color: #fff;
}
.cv2-contacts-hero .lead {
  max-width: 720px;
  font-size: var(--fs-lg);
  line-height: 1.5;
  color: rgba(255,255,255,0.85);
  margin: 0;
}

.cv2-contacts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
}
@media (max-width: 767px) {
  .cv2-contacts-grid { grid-template-columns: 1fr; }
}

.cv2-contact-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  transition: border-color var(--t), box-shadow var(--t);
}
.cv2-contact-card:hover {
  border-color: var(--border-strong);
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}
.cv2-contact-icon {
  font-size: 36px;
  line-height: 1;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-soft);
  border-radius: var(--radius-lg);
}
.cv2-contact-title {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--text-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cv2-contact-value {
  font-size: var(--fs-lg);
  display: flex;
  flex-direction: column;
}
.cv2-contact-value a {
  color: var(--text);
  font-weight: 600;
}
.cv2-contact-value a:hover { color: var(--link); }
.cv2-contact-value strong { font-weight: 700; font-size: var(--fs-xl); }
.cv2-contact-note {
  font-size: var(--fs-xs);
  color: var(--text-mute);
  font-weight: 400;
}
.cv2-contact-hours {
  margin-top: auto;
  padding-top: var(--s-3);
  border-top: 1px solid var(--border);
  font-size: var(--fs-sm);
  color: var(--text-mute);
  line-height: 1.5;
}

.cv2-contacts-juridical {
  margin-top: var(--s-12);
  padding-top: var(--s-10);
  border-top: 1px solid var(--border);
}
.cv2-contacts-juridical h2 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  margin: 0 0 var(--s-6);
}
.cv2-juridical-table {
  background: var(--bg-soft);
  border-radius: var(--radius-lg);
  padding: var(--s-6);
  max-width: 760px;
}
.cv2-juridical-table dl {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: var(--s-3) var(--s-4);
  margin: 0;
}
@media (max-width: 599px) {
  .cv2-juridical-table dl { grid-template-columns: 1fr; gap: var(--s-1); }
  .cv2-juridical-table dt { margin-top: var(--s-3); }
  .cv2-juridical-table dt:first-child { margin-top: 0; }
}
.cv2-juridical-table dt {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--text-mute);
}
.cv2-juridical-table dd {
  margin: 0;
  font-size: var(--fs-base);
  color: var(--text);
}
.cv2-juridical-table dd code {
  font-family: var(--font-mono);
  background: #fff;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
}
.cv2-contacts-note {
  margin-top: var(--s-6);
  font-size: var(--fs-sm);
  color: var(--text-mute);
  line-height: 1.6;
  max-width: 760px;
}

.cv2-contacts-extra {
  margin-top: var(--s-10);
  padding-top: var(--s-8);
  border-top: 1px solid var(--border);
}

.cv2-cart-empty { padding: var(--s-12) 0; text-align: center; }
.cv2-empty-state { padding: var(--s-12) 0; text-align: center; max-width: 480px; margin: 0 auto; }
.cv2-empty-state h2 { margin-bottom: var(--s-2); }
.cv2-empty-state p { color: var(--text-mute); }

/* === CHECKOUT — layout === */
body.woocommerce-checkout .woocommerce {
  display: flex;
  flex-direction: column;
}
/* Login + coupon notices сверху — компактнее */
body.woocommerce-checkout .woocommerce-form-coupon-toggle,
body.woocommerce-checkout .woocommerce-form-login-toggle,
body.woocommerce-checkout .woocommerce-info {
  background: rgba(37,99,235,0.06) !important;
  color: var(--text-mute) !important;
  border: 1px dashed var(--border-strong) !important;
  border-radius: var(--radius);
  padding: var(--s-2) var(--s-4) !important;
  margin: 0 0 var(--s-3) !important;
  font-size: var(--fs-sm);
}
body.woocommerce-checkout .woocommerce-form-coupon-toggle::before,
body.woocommerce-checkout .woocommerce-form-login-toggle::before { display: none !important; }
body.woocommerce-checkout .woocommerce-form-coupon-toggle a,
body.woocommerce-checkout .woocommerce-form-login-toggle a,
body.woocommerce-checkout .woocommerce-info a {
  color: var(--link); font-weight: 600;
}
body.woocommerce-checkout .woocommerce-form-login,
body.woocommerce-checkout .woocommerce-form-coupon {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--s-4) !important;
  margin-bottom: var(--s-4) !important;
}

body.woocommerce-checkout form.checkout {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 980px) {
  body.woocommerce-checkout form.checkout {
    grid-template-columns: 1.4fr 1fr;
    grid-template-rows: auto auto 1fr;
    align-items: start;
    column-gap: var(--s-6);
    row-gap: 0; /* heading и card вплотную, без grid-gap */
  }
  body.woocommerce-checkout form.checkout > #customer_details {
    grid-column: 1;
    grid-row: 1 / 4;
  }
  body.woocommerce-checkout form.checkout > #order_review_heading {
    grid-column: 2;
    grid-row: 1;
    margin: 0 0 var(--s-3); /* плотнее к card (12px вместо 16+24) */
  }
  body.woocommerce-checkout form.checkout > #order_review {
    grid-column: 2;
    grid-row: 2;
    margin: 4.5px 0 0 !important; /* card на 0.5px ниже switcher top */
  }
}
@media (min-width: 980px) {
  body.woocommerce-checkout #order_review_heading,
  body.woocommerce-checkout #order_review {
    position: sticky;
    top: var(--s-6);
  }
  body.woocommerce-checkout #order_review_heading { top: var(--s-6); }
  body.woocommerce-checkout #order_review { top: calc(var(--s-6) + 56px); }
}

#customer_details {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: 1fr;
}
/* Billing → Shipping → Additional fields всегда сложены вертикально в одну колонку.
   Раньше .col-1/.col-2 ставили additional справа от billing, что разрывало flow. */
#customer_details .col-1,
#customer_details .col-2,
.woocommerce-billing-fields,
.woocommerce-shipping-fields,
.woocommerce-additional-fields {
  grid-column: 1;
  width: 100%;
}

/* «Ваш заказ» — h-заголовок выровнен с «Оплата и доставка» (no card-frame). */
#order_review_heading {
  font-size: var(--fs-xl);
  font-weight: 700;
  margin: 0 0 var(--s-4);
  padding: 0;
  background: none;
  border: 0;
  border-radius: 0;
}

/* «Оплата и доставка» — тот же стиль что «Ваш заказ». */
body.woocommerce-checkout .woocommerce-billing-fields > h3,
body.woocommerce-checkout .woocommerce-additional-fields > h3 {
  font-size: var(--fs-xl);
  font-weight: 700;
  margin: 0 0 var(--s-4);
}

/* Switcher слегка вниз, чтобы визуально не «висел» сразу под h3 */
body.woocommerce-checkout #billing_legal_type_field {
  margin-top: var(--s-3);
}
/* Card-обрамление #order_review подтянуть наверх — уменьшаем top padding,
   чтобы row ТОВАР начинался ближе к уровню switcher слева */
body.woocommerce-checkout #order_review {
  padding-top: var(--s-3);
  padding-bottom: var(--s-3);
}
body.woocommerce-checkout #order_review .shop_table thead th {
  padding-top: 0 !important;
  padding-bottom: var(--s-2) !important;
}
#order_review {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--s-5);
  margin: 0 !important;
}

/* === Order summary table === */
#order_review .shop_table {
  background: transparent !important;
  border: 0 !important;
  margin: 0 0 var(--s-4);
  width: 100%;
}
#order_review .shop_table th,
#order_review .shop_table td {
  padding: var(--s-2) 0 !important;
  border: 0 !important;
  background: transparent !important;
  font-size: var(--fs-sm);
  vertical-align: top;
  line-height: 1.4;
}
#order_review .shop_table tr { border-bottom: 1px solid var(--border); }
#order_review .shop_table tr:last-child { border-bottom: 0; }

/* Заголовки шапки таблицы */
#order_review .shop_table thead th {
  font-weight: 700;
  font-size: var(--fs-xs) !important;
  color: var(--text-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: left !important;
  padding-bottom: var(--s-3) !important;
}
#order_review .shop_table thead th.product-total { text-align: right !important; }

/* Строки товаров */
#order_review .shop_table .cart_item .product-name {
  text-align: left !important;
  color: var(--text);
  padding-right: var(--s-3) !important;
}
#order_review .shop_table .cart_item .product-name strong.product-quantity {
  display: inline-block;
  font-weight: 700;
  margin-left: var(--s-1);
  color: var(--text);
  white-space: nowrap;
}
#order_review .shop_table .cart_item .product-total {
  text-align: right !important;
  white-space: nowrap;
  font-weight: 600;
  color: var(--text);
}

/* Подытог / Купон / Доставка — label слева жирный, value справа */
#order_review .shop_table tfoot th {
  font-weight: 600;
  text-align: left !important;
  color: var(--text);
  padding-right: var(--s-3) !important;
  width: 50%;
}
#order_review .shop_table tfoot td {
  text-align: right !important;
  white-space: nowrap;
}
#order_review .shop_table tfoot td.cart-discount {
  color: var(--accent);
  font-weight: 600;
}

/* Итого — самая важная строка */
#order_review .shop_table .order-total th {
  font-size: var(--fs-base) !important;
  font-weight: 700;
  padding-top: var(--s-3) !important;
}
#order_review .shop_table .order-total td {
  padding-top: var(--s-3) !important;
}
#order_review .order-total .amount {
  font-size: var(--fs-2xl);
  font-weight: 800;
  letter-spacing: -0.01em;
}

/* Доставка с текстом — value может занять несколько строк */
#order_review .shop_table .shipping td {
  white-space: normal;
  font-size: var(--fs-xs);
  color: var(--text-mute);
  line-height: 1.4;
}

.woocommerce-checkout .form-row { margin-bottom: var(--s-3); }
.woocommerce-checkout .form-row label {
  display: block; font-weight: 500; font-size: var(--fs-sm);
  color: var(--text-mute); margin-bottom: 4px;
}
.woocommerce-checkout .form-row .input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row .select2-selection {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-sm); background: #fff;
  height: 44px;
}
.woocommerce-checkout textarea.input-text { height: 100px; }
.woocommerce-checkout .form-row .input-text:focus,
.woocommerce-checkout .form-row select:focus {
  outline: none; border-color: var(--link);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}
.payment_methods {
  list-style: none; padding: 0;
  margin: 0 0 var(--s-4);
  border: 1px solid var(--border); border-radius: var(--radius);
  background: #fff;
}
.payment_methods li {
  padding: var(--s-4);
  border-bottom: 1px solid var(--border);
}
.payment_methods li:last-child { border-bottom: 0; }
.payment_methods label { font-weight: 600; }
.payment_box { margin-top: var(--s-3); color: var(--text-mute); font-size: var(--fs-xs); }
#place_order {
  background: var(--accent) !important; color: #fff !important;
  padding: 14px 32px !important; min-height: 52px;
  border-radius: var(--radius) !important; font-weight: 700 !important;
  font-size: var(--fs-base) !important;
  width: 100%; border: 0;
  box-shadow: 0 4px 14px rgba(249,115,22,0.35);
}
#place_order:hover { background: var(--accent-hover) !important; transform: translateY(-1px); }

/* Sticky place-order на мобайле (issue #17) */
@media (max-width: 768px) {
  body.woocommerce-checkout .form-row.place-order,
  body.woocommerce-checkout #payment .place-order {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: #fff;
    border-top: 1px solid var(--border);
    padding: var(--s-3) var(--s-4) calc(var(--s-3) + env(safe-area-inset-bottom));
    z-index: 60;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.08);
    margin: 0;
  }
  body.woocommerce-checkout {
    padding-bottom: 100px;
  }
  /* Showcase order-total above the sticky button (через :before) */
  body.woocommerce-checkout .form-row.place-order::before,
  body.woocommerce-checkout #payment .place-order::before {
    content: attr(data-total);
    display: block;
    text-align: center;
    font-size: var(--fs-sm);
    color: var(--text-mute);
    margin-bottom: var(--s-2);
  }
}

/* === MY ACCOUNT (login + register + dashboard) === */
.cv2-account-auth { padding: var(--s-4) 0 var(--s-12); }
.cv2-account-cols {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: 1fr;
}
@media (min-width: 980px) {
  /* Login card уже, register card шире — как в V1 (там слева узкий, справа широкий).
     Брэйкпоинт 980 — ниже стек одной колонкой чтобы текст не ломался по словам. */
  .cv2-account-cols { grid-template-columns: minmax(0, 340px) minmax(0, 1fr); }
}
.cv2-account-cols .u-column1,
.cv2-account-cols .u-column2 {
  background: var(--bg-soft);
  padding: var(--s-5) var(--s-6);
  border-radius: var(--radius-lg);
  /* WC default .col-1/.col-2 имеют width: 48% (legacy float layout) — ломает grid.
     Сбрасываем чтобы grid-template-columns работал. */
  width: auto !important;
  float: none !important;
  max-width: none !important;
}
.cv2-account-cols h2 {
  font-size: var(--fs-lg);
  font-weight: 700;
  margin: 0 0 var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--border);
}
.woocommerce-form .form-row {
  margin-bottom: var(--s-3);
}
.woocommerce-form .form-row label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text);
  margin-bottom: 6px;
}
.woocommerce-form .form-row .input-text {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: var(--fs-base);
  background: #fff;
  height: 42px;
}
.woocommerce-form .form-row .input-text:focus {
  outline: none;
  border-color: var(--link);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}

/* WC-форма по умолчанию выводит ВТОРОЙ h1 «Мой аккаунт» внутри страницы.
   В V1 эта секция — единый блок с heading наверху. Гарантируем что h1 виден
   и расположен над .cv2-account-auth контейнером. */
body.woocommerce-account .woocommerce > h1.entry-title,
body.woocommerce-account h1.entry-title {
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 800;
  margin: 0 0 var(--s-6);
  letter-spacing: -0.02em;
}
.woocommerce-form-login__rememberme,
.woocommerce-form-register__rememberme {
  display: flex; align-items: center; gap: 6px;
  font-size: var(--fs-sm); color: var(--text);
  margin-bottom: var(--s-4) !important;
}
.woocommerce-form-login__rememberme input,
.woocommerce-form-register__rememberme input { margin: 0; }

.woocommerce-form-login__submit,
.woocommerce-form-register__submit,
.woocommerce-Button {
  background: var(--accent) !important;
  color: #fff !important;
  padding: 12px 28px !important;
  border-radius: var(--radius) !important;
  font-weight: 600 !important;
  font-size: var(--fs-base) !important;
  border: 0 !important;
  cursor: pointer;
  min-height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all var(--t);
}
.woocommerce-form-login__submit:hover,
.woocommerce-form-register__submit:hover,
.woocommerce-Button:hover {
  background: var(--accent-hover) !important;
  transform: translateY(-1px);
}
.woocommerce-LostPassword {
  margin-top: var(--s-3);
  font-size: var(--fs-sm);
}
.required { color: var(--danger); }


/* My Account dashboard — grid sidebar + content ТОЛЬКО когда залогинены
   (когда есть .woocommerce-MyAccount-navigation). Logged-out форма
   рендерится без sidebar и не должна попасть в 240px-track. */
body.woocommerce-account.logged-in .woocommerce {
  display: grid;
  grid-template-columns: minmax(0, 240px) minmax(0, 1fr);
  gap: var(--s-8);
  align-items: start;
}
@media (max-width: 767px) {
  body.woocommerce-account.logged-in .woocommerce { grid-template-columns: 1fr; }
}
.woocommerce-account .woocommerce-MyAccount-navigation {
  background: var(--bg-soft);
  padding: var(--s-5) var(--s-4);
  border-radius: var(--radius-lg);
  margin-bottom: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation::before {
  content: 'МОЙ АККАУНТ';
  display: block;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--text-mute);
  padding: 0 var(--s-3);
  margin-bottom: var(--s-3);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--border);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none; padding: 0; margin: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation li {
  margin: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation a {
  display: block;
  padding: 10px var(--s-3);
  font-weight: 500;
  font-size: var(--fs-sm);
  color: var(--text);
  border-radius: var(--radius);
  transition: background var(--t);
}
.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
  background: rgba(255,255,255,0.7);
  color: var(--text);
}
.woocommerce-account .woocommerce-MyAccount-navigation .is-active a {
  background: #fff;
  color: var(--text);
  font-weight: 700;
}

/* Welcome + intro */
.cv2-account-welcome {
  font-size: var(--fs-base);
  color: var(--text);
  margin: 0 0 var(--s-3);
}
.cv2-account-welcome strong { font-weight: 700; }
.cv2-account-welcome a { color: var(--link); }
.cv2-account-intro {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  line-height: 1.5;
  margin: 0 0 var(--s-6);
}
.cv2-account-intro a { color: var(--link); }

/* Cards grid (Заказы, Адрес, Анкета, etc.) */
.cv2-account-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--s-3);
}
.cv2-account-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--s-3);
  padding: var(--s-6) var(--s-4);
  min-height: 140px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: var(--text);
  transition: all var(--t);
}
.cv2-account-card:hover {
  border-color: var(--border-strong);
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  transform: translateY(-1px);
  color: var(--text);
}
.cv2-account-card-icon {
  color: var(--text-mute);
  line-height: 0;
}
.cv2-account-card:hover .cv2-account-card-icon { color: var(--accent); }
.cv2-account-card-label {
  font-size: var(--fs-base);
  font-weight: 600;
  text-align: center;
}
@media (max-width: 480px) {
  .cv2-account-cards { grid-template-columns: repeat(2, 1fr); }
  .cv2-account-card { min-height: 110px; padding: var(--s-4) var(--s-2); }
  .cv2-account-card-icon svg { width: 32px; height: 32px; }
  .cv2-account-card-label { font-size: var(--fs-sm); }
}
@media (min-width: 768px) {
  body.woocommerce-account.logged-in .woocommerce { display: grid; grid-template-columns: 240px 1fr; gap: var(--s-6); }
  .woocommerce-account .woocommerce-MyAccount-navigation { margin-bottom: 0; }
}

/* === MESSAGES (notices) === */
.woocommerce-notices-wrapper:empty { display: none; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  padding: var(--s-4); border-radius: var(--radius);
  margin-bottom: var(--s-4);
  font-size: var(--fs-sm);
  display: flex; align-items: center; gap: var(--s-3);
}
.woocommerce-message { background: rgba(5,150,105,0.1); border: 1px solid var(--success); color: var(--success); }
.woocommerce-info    { background: rgba(37,99,235,0.08); border: 1px solid var(--link);    color: var(--link); }
.woocommerce-error   { background: rgba(220,38,38,0.08); border: 1px solid var(--danger);  color: var(--danger); }
.woocommerce-message .button, .woocommerce-info .button, .woocommerce-error .button {
  margin-left: auto; padding: 6px 12px; font-size: var(--fs-xs);
}

/* === WIKI (база знаний) === */
.cv2-wiki { background: #fff; }
.cv2-wiki-hero {
  background: linear-gradient(135deg, #0A1628 0%, #1E3A8A 60%, #0A1628 100%);
  color: #fff;
  padding: var(--s-10) 0 var(--s-12);
}
.cv2-wiki-hero .bc { color: rgba(255,255,255,0.7); padding-bottom: var(--s-3); }
.cv2-wiki-hero .bc a { color: rgba(255,255,255,0.85); }
.cv2-wiki-hero h1 {
  color: #fff;
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: var(--s-3);
}
.cv2-wiki-lead { color: #CBD5E1; font-size: clamp(16px,1.5vw,18px); max-width: 60ch; }
.cv2-wiki-stats {
  display: flex; gap: var(--s-6); margin-top: var(--s-6);
  flex-wrap: wrap;
  padding-top: var(--s-4);
  border-top: 1px solid rgba(255,255,255,0.15);
  font-size: var(--fs-sm); color: #CBD5E1;
}
.cv2-wiki-stats strong { color: #fff; }

.cv2-wiki-recent {
  display: grid; gap: var(--s-5);
  grid-template-columns: repeat(1, 1fr);
}
@media (min-width: 640px) { .cv2-wiki-recent { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .cv2-wiki-recent { grid-template-columns: repeat(3, 1fr); } }
.cv2-wiki-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--t);
  display: flex; flex-direction: column;
}
.cv2-wiki-card:hover { border-color: var(--link); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.cv2-wiki-card-media {
  display: block; aspect-ratio: 16/10;
  background: var(--bg-soft); overflow: hidden;
}
.cv2-wiki-card-media img { width: 100%; height: 100%; object-fit: cover; }
.cv2-wiki-card-placeholder {
  width: 100%; height: 100%;
  display: grid; place-items: center;
  font-size: 48px; color: var(--text-dim);
}
.cv2-wiki-card-body { padding: var(--s-4); flex: 1; display: flex; flex-direction: column; }
.cv2-wiki-card-cat {
  font-size: var(--fs-xs); font-weight: 600;
  color: var(--link);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: var(--s-2);
}
.cv2-wiki-card-title {
  font-size: var(--fs-base); font-weight: 700;
  line-height: 1.35;
  margin-bottom: var(--s-3);
}
.cv2-wiki-card-title a { color: var(--text); }
.cv2-wiki-card-title a:hover { color: var(--link); }
.cv2-wiki-card-meta {
  margin-top: auto; padding-top: var(--s-3);
  font-size: var(--fs-xs); color: var(--text-mute);
  border-top: 1px solid var(--border);
}

.cv2-wiki-categories {
  display: grid; gap: var(--s-5);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .cv2-wiki-categories { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .cv2-wiki-categories { grid-template-columns: repeat(3, 1fr); } }
.cv2-wiki-cat {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--s-5);
}
.cv2-wiki-cat-title {
  font-size: var(--fs-lg);
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--border);
}
.cv2-wiki-cat-title a {
  color: var(--text); display: flex; align-items: center; justify-content: space-between;
}
.cv2-wiki-cat-title a:hover { color: var(--link); }
.cv2-wiki-cat-title .count {
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--bg-soft);
  color: var(--text-mute);
  padding: 2px 8px;
  border-radius: 99px;
  font-weight: 500;
}
.cv2-wiki-cat-list { list-style: none; padding: 0; margin: 0; }
.cv2-wiki-cat-list li {
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  display: flex; justify-content: space-between; gap: var(--s-3);
  align-items: baseline;
}
.cv2-wiki-cat-list li:last-child { border-bottom: 0; }
.cv2-wiki-cat-list li a {
  font-size: var(--fs-sm); color: var(--text);
  flex: 1; line-height: 1.4;
}
.cv2-wiki-cat-list li a:hover { color: var(--link); }
.cv2-wiki-cat-list li time {
  font-size: var(--fs-xs); color: var(--text-dim);
  font-family: var(--font-mono);
  white-space: nowrap;
}
.cv2-wiki-cat-all {
  display: inline-block;
  margin-top: var(--s-4);
  font-size: var(--fs-sm); font-weight: 600;
  color: var(--link);
}

/* Цена «Цена по запросу» вместо 0,00 ₽ */
.cv2-price-na {
  font-size: var(--fs-sm);
  color: var(--text-mute);
  font-weight: 500;
  font-style: italic;
}

/* Стилизация SEO-блоков на главной (от MU-plugin corneta-home-h2.php) */
.corneta-seo-blocks {
  background: var(--bg-soft);
  padding: var(--s-12) var(--s-5) !important;
  margin: 0 !important;
  max-width: none !important;
  border-top: 1px solid var(--border);
}
.corneta-seo-blocks > * {
  max-width: var(--max-w);
  margin-left: auto !important;
  margin-right: auto !important;
}
.corneta-seo-blocks h2 {
  font-size: clamp(20px, 2.5vw, 28px) !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  letter-spacing: -0.01em;
  margin: var(--s-8) auto var(--s-3) !important;
}
.corneta-seo-blocks p {
  color: var(--text-mute) !important;
  font-size: var(--fs-base) !important;
  line-height: 1.6;
  margin-bottom: var(--s-3) !important;
}
.corneta-seo-blocks ul {
  font-size: var(--fs-sm) !important;
  line-height: 1.7 !important;
}
.corneta-seo-blocks a {
  color: var(--link);
  font-weight: 500;
}

/* Гарантия видимости цен в карточках (на случай конфликта с другими стилями) */
.prod-price,
.prod .price,
.woocommerce ul.products .price {
  color: var(--text) !important;
  font-size: var(--fs-xl) !important;
  font-weight: 700 !important;
  display: block !important;
  visibility: visible !important;
  margin-top: 4px;
}
.woocommerce-Price-amount { font-size: inherit; font-weight: inherit; color: inherit; }

/* === One-click order popup (issue #7, art-woocommerce-order-one-click) === */
.awooc-popup-wrapper {
  background: rgba(10,22,40,0.85) !important;
}
.awooc-popup-inner,
.awooc-custom-order-wrap {
  background: #fff !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: var(--s-6) !important;
  max-width: 500px !important;
  width: calc(100vw - 32px);
  font-family: var(--font-sans) !important;
}
.awooc-popup-inner h2,
.awooc-popup-inner h3,
.awooc-popup-inner .awooc-popup-title {
  font-size: var(--fs-xl) !important;
  font-weight: 700 !important;
  margin: 0 0 var(--s-2) !important;
  color: var(--text) !important;
  letter-spacing: -0.01em;
}
.awooc-popup-inner label {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text-mute);
  margin-bottom: 4px;
  display: block;
}
.awooc-popup-inner input[type="text"],
.awooc-popup-inner input[type="tel"],
.awooc-popup-inner input[type="email"],
.awooc-popup-inner textarea {
  width: 100% !important;
  padding: 10px 14px !important;
  border: 1px solid var(--border-strong) !important;
  border-radius: var(--radius) !important;
  font-size: var(--fs-base) !important;
  background: #fff !important;
  margin-bottom: var(--s-3) !important;
}
.awooc-popup-inner input:focus,
.awooc-popup-inner textarea:focus {
  outline: none !important;
  border-color: var(--link) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,0.12) !important;
}
.awooc-popup-inner .awooc-submit,
.awooc-popup-inner button[type="submit"],
.awooc-popup-inner input[type="submit"] {
  background: var(--accent) !important;
  color: #fff !important;
  padding: 14px 28px !important;
  min-height: 52px !important;
  border-radius: var(--radius) !important;
  font-weight: 700 !important;
  font-size: var(--fs-base) !important;
  border: 0 !important;
  width: 100%;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(249,115,22,0.35);
  transition: all var(--t);
}
.awooc-popup-inner .awooc-submit:hover,
.awooc-popup-inner button[type="submit"]:hover {
  background: var(--accent-hover) !important;
  transform: translateY(-1px);
}
.awooc-close {
  position: absolute;
  top: 12px; right: 12px;
  width: 32px; height: 32px;
  background: var(--bg-soft) !important;
  border: 0;
  border-radius: 50% !important;
  font-size: 20px;
  color: var(--text-mute) !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center; justify-content: center;
  z-index: 1;
}
.awooc-close:hover {
  background: var(--text) !important;
  color: #fff !important;
}
.awooc-col-wrap.awooc-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
.awooc-col { padding: 0 !important; }

/* === DEV BADGE (показываем что включена v2-тема) === */
.cv2-dev-badge {
  position: fixed; bottom: 16px; left: 16px; z-index: 100;
  background: var(--bg-dark); color: #fff;
  font-family: var(--font-mono); font-size: 11px;
  padding: 6px 10px; border-radius: 6px;
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(255,255,255,0.15);
  opacity: 0.85;
}
.cv2-dev-badge:hover { opacity: 1; }
.cv2-dev-badge a { color: var(--accent); margin-left: 6px; }


/* Product card attribute chips (v2.1 — 2026-05-17) */
.prod-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
  margin: 8px 0;
}
.prod-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 4px;
  font-size: 0.78em;
  color: #475569;
  white-space: nowrap;
}
.prod-chip-label {
  color: #94a3b8;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 0.85em;
  margin-right: 4px;
}
.prod-chip-value {
  color: #0f172a;
  font-weight: 500;
}

/* Variation Swatches in catalog (v2.2 — 2026-05-19) */
.cv2-swatches { margin: 10px 0; }
.cv2-swatch-row { margin-bottom: 8px; }
.cv2-swatch-row:last-child { margin-bottom: 0; }
.cv2-swatch-label {
  display: block;
  font-size: 10px;
  color: #64748b;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 5px;
}
.cv2-swatch-options {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.cv2-swatch {
  background: #fff;
  border: 1.5px solid #e2e8f0;
  border-radius: 6px;
  padding: 6px 9px;
  cursor: pointer;
  font-size: 12px;
  font-family: inherit;
  text-align: center;
  transition: all .15s;
  line-height: 1.2;
  min-width: 50px;
}
.cv2-swatch:hover {
  border-color: #6366f1;
}
.cv2-swatch.is-active {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}
.cv2-swatch-val {
  display: block;
  font-weight: 600;
  color: inherit;
}
.cv2-swatch-price {
  display: block;
  font-size: 11px;
  margin-top: 2px;
  opacity: .75;
  color: inherit;
}
/* Mobile (≤ 768px): variant A — compact (hide price on chips) */
@media (max-width: 768px) {
  .cv2-swatch { min-width: 38px; padding: 5px 8px; }
  .cv2-swatch-price { display: none; }
  .cv2-swatch-val { font-size: 12px; }
  .cv2-swatch-label { font-size: 9px; }
}

/* Variation Swatches — Single product page (v2.2 — 2026-05-19) */
.cv2-single-variations { margin: 16px 0 20px; }
.cv2-single-row {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 12px 0;
  border-top: 1px solid #e2e8f0;
}
.cv2-single-row:first-child { border-top: none; padding-top: 0; }
.cv2-single-label {
  min-width: 120px;
  font-size: 13px;
  color: #475569;
  font-weight: 500;
  padding-top: 6px;
}
.cv2-single-swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  flex: 1;
}
.cv2-single-swatch {
  background: #fff;
  border: 1.5px solid #cbd5e1;
  border-radius: 8px;
  padding: 8px 14px;
  cursor: pointer;
  font-family: inherit;
  text-align: center;
  transition: all .15s;
  line-height: 1.25;
  min-width: 70px;
}
.cv2-single-swatch:hover {
  border-color: #6366f1;
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(99,102,241,0.12);
}
.cv2-single-swatch.is-active {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}
.cv2-single-swatch-val {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: inherit;
}
.cv2-single-swatch-price {
  display: block;
  font-size: 12px;
  margin-top: 3px;
  opacity: .75;
  color: inherit;
}
.cv2-single-swatch-price .woocommerce-Price-amount { color: inherit; }
.reset_variations {
  display: inline-block;
  margin-left: auto;
  font-size: 12px;
  color: #94a3b8;
  text-decoration: none;
  border-bottom: 1px dashed #cbd5e1;
  padding: 4px 0;
}
.reset_variations:hover { color: #64748b; }
/* Hide native WC table rendering */
.variations_form table.variations { display: none; }

/* Mobile (≤ 768px) — chips остаются с ценой (по требованию пользователя) */
@media (max-width: 768px) {
  .cv2-single-row {
    flex-direction: column;
    gap: 8px;
  }
  .cv2-single-label { min-width: auto; padding-top: 0; }
  .cv2-single-swatch { min-width: 60px; padding: 6px 10px; }
  .cv2-single-swatch-val { font-size: 13px; }
  .cv2-single-swatch-price { font-size: 11px; }
}

/* Current variation price display (single product) */
.cv2-current-price {
  font-size: 28px;
  font-weight: 700;
  color: #0f172a;
  margin: 16px 0 8px;
  line-height: 1;
}
.cv2-current-price .woocommerce-Price-amount {
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
}
@media (max-width: 768px) {
  .cv2-current-price { font-size: 24px; margin: 12px 0 6px; }
}

/* === Single product price layout fix (v2.2.1 — 2026-05-19) === */
/* Hide WC's default .price for Variable products — we render our own via .cv2-current-price */
.cv2-product-summary > .price,
.cv2-product-summary p.price {
  display: none;
}
/* Show only our cv2-current-price block above swatches */
.cv2-current-price {
  font-size: 28px;
  font-weight: 700;
  color: #0f172a;
  margin: 16px 0 12px;
  line-height: 1;
  min-height: 32px;  /* стабильная высота — цена не "прыгает" */
}
/* Hide WC's woocommerce-variation-price (duplicate of our cv2-current-price) */
.woocommerce-variation-price { display: none; }
@media (max-width: 768px) {
  .cv2-current-price { font-size: 24px; min-height: 28px; }
}

/* Product meta block (SKU + Categories) above trust banner (v2.2.2 — 2026-05-19) */
.cv2-product-meta-block {
  margin: 18px 0 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cv2-product-meta-sku {
  font-size: 18px;  /* 2 шрифта больше чем default 14px */
  color: #0f172a;
  font-weight: 500;
}
.cv2-product-meta-sku .sku {
  font-family: 'JetBrains Mono', 'Menlo', monospace;
  font-weight: 600;
  color: #4338ca;
  font-size: 16px;
  letter-spacing: 0.3px;
}
.cv2-product-meta-cats {
  font-size: 13px;
  color: #475569;
  line-height: 1.5;
}
.cv2-meta-label {
  color: #64748b;
  font-weight: 500;
  margin-right: 6px;
}
.cv2-product-meta-cats a {
  color: #4338ca;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s;
}
.cv2-product-meta-cats a:hover { border-bottom-color: #4338ca; }
@media (max-width: 768px) {
  .cv2-product-meta-sku { font-size: 16px; }
  .cv2-product-meta-sku .sku { font-size: 15px; }
}

/* === Trust block — under chips, above price + ATC button === */
.cv2-trust-block {
  margin: 16px 0;
  padding: 14px 16px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-left: 4px solid #10b981;
  border-radius: 6px;
}
.cv2-trust-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}
.cv2-trust-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  line-height: 1.4;
  color: #334155;
}
.cv2-trust-list li.cv2-trust-fast { color: #065f46; }
.cv2-trust-list li.cv2-trust-backorder { color: #92400e; }
.cv2-trust-icon {
  flex-shrink: 0;
  font-size: 18px;
  width: 22px;
  text-align: center;
}
.cv2-trust-text strong { font-weight: 600; }
.cv2-trust-text a { color: #1e40af; text-decoration: underline; }

@media (max-width: 768px) {
  .cv2-trust-block { padding: 12px 14px; margin: 14px 0; }
  .cv2-trust-list li { font-size: 13px; }
}

/* Mailto/tel buttons in landing CTAs — kill any global underline */
.entry-content a[href^="mailto:"],
.entry-content a[href^="tel:"],
.page-content a[href^="mailto:"],
.page-content a[href^="tel:"] {
  text-decoration: none !important;
}

/* ========================================================================
   === SINGLE ARTICLE / PROSE (single.php + page.php) ===
   Шире контейнер (~1140px), типографика, таблицы, формулы, чек-листы.
   ======================================================================== */

.cv2-article-wrap {
  max-width: 1140px;
  padding-top: var(--s-10);
  padding-bottom: var(--s-16);
}
.cv2-article-head { margin-bottom: var(--s-8); }
.cv2-article-title {
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.18;
  margin: 0 0 var(--s-3);
  color: var(--text);
}
.cv2-article-meta {
  color: var(--text-mute);
  font-size: var(--fs-sm);
  margin: 0;
}
.cv2-article-hero {
  margin: 0 auto var(--s-8);
  max-width: 720px;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-soft);
}
.cv2-article-hero img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 320px;
  object-fit: cover;
}
@media (max-width: 768px) {
  .cv2-article-hero img { max-height: 220px; }
}

/* === PROSE typography === */
.cv2-prose {
  font-size: 16px;
  line-height: 1.65;
  color: var(--text);
}
.cv2-prose > * + * { margin-top: var(--s-4); }
.cv2-prose p { margin: 0 0 var(--s-4); }
.cv2-prose p:last-child { margin-bottom: 0; }
.cv2-prose strong { font-weight: 700; color: var(--text); }
.cv2-prose em { font-style: italic; }
.cv2-prose a {
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: rgba(37, 99, 235, 0.35);
  transition: color var(--t), text-decoration-color var(--t);
}
.cv2-prose a:hover {
  color: var(--link-hover);
  text-decoration-color: var(--link-hover);
}

/* Headings inside articles */
.cv2-prose h2 {
  font-size: clamp(19px, 2.1vw, 24px);
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1.25;
  margin: var(--s-10) 0 var(--s-3);
  padding-bottom: var(--s-2);
  border-bottom: 2px solid var(--border);
  color: var(--text);
  scroll-margin-top: 80px;
}
.cv2-prose h2:first-child { margin-top: 0; }
.cv2-prose h3 {
  font-size: clamp(16.5px, 1.5vw, 18.5px);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.35;
  margin: var(--s-6) 0 var(--s-2);
  color: var(--text);
  scroll-margin-top: 80px;
}
.cv2-prose h4 {
  font-size: 16px;
  font-weight: 700;
  margin: var(--s-5) 0 var(--s-2);
  color: var(--text);
}

/* Lists */
.cv2-prose ul,
.cv2-prose ol {
  margin: 0 0 var(--s-5);
  padding-left: 1.4em;
}
.cv2-prose ul li,
.cv2-prose ol li {
  margin-bottom: var(--s-2);
  line-height: 1.65;
}
.cv2-prose ul > li::marker { color: var(--link); }
.cv2-prose ol > li::marker { color: var(--text-mute); font-weight: 600; }
.cv2-prose li > p { margin: 0; }
.cv2-prose li > ul,
.cv2-prose li > ol { margin-top: var(--s-2); margin-bottom: var(--s-2); }

/* Tables — горизонтальный скролл на мобиле */
.cv2-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-5) 0;
  font-size: 13.5px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.cv2-prose thead { background: linear-gradient(135deg, #1e293b 0%, #334155 100%); }
.cv2-prose thead th {
  color: #fff;
  font-weight: 600;
  padding: 9px 12px;
  text-align: left;
  font-size: 12.5px;
  letter-spacing: 0.01em;
  border: 0;
}
.cv2-prose tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background var(--t);
}
.cv2-prose tbody tr:last-child { border-bottom: 0; }
.cv2-prose tbody tr:nth-child(even) { background: #f8fafc; }
.cv2-prose tbody tr:hover { background: #eff6ff; }
.cv2-prose tbody td {
  padding: 8px 12px;
  vertical-align: middle;
  border: 0;
  color: var(--text);
}
.cv2-prose tbody td strong { color: var(--text); }
.cv2-prose tbody td a { font-weight: 600; }

/* Wrap tables for horizontal scroll on small screens */
@media (max-width: 700px) {
  .cv2-prose table { font-size: 12.5px; display: block; overflow-x: auto; white-space: nowrap; }
  .cv2-prose thead th,
  .cv2-prose tbody td { padding: 7px 9px; }
}

/* Pre / formulas — dark code block */
.cv2-prose pre {
  background: #0f172a !important;
  color: #5eead4 !important;
  padding: 18px 20px !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-mono) !important;
  font-size: 14.5px !important;
  line-height: 1.65 !important;
  overflow-x: auto;
  margin: var(--s-5) 0;
  border-left: 3px solid #5eead4;
  box-shadow: var(--shadow);
}
.cv2-prose code {
  background: #f1f5f9;
  color: #be185d;
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.92em;
  border: 1px solid var(--border);
}
.cv2-prose pre code {
  background: transparent;
  color: inherit;
  padding: 0;
  border: 0;
}

/* TOC (corneta-toc) — нормализуем поверх inline-styles */
.cv2-prose .corneta-toc {
  background: linear-gradient(135deg, #f8fafc 0%, #eff6ff 100%) !important;
  border: 1px solid var(--border) !important;
  border-left: 4px solid var(--link) !important;
  border-radius: var(--radius) !important;
  padding: 20px 26px !important;
  margin: var(--s-6) 0 var(--s-8) !important;
  line-height: 1.65 !important;
  box-shadow: var(--shadow-sm);
}
.cv2-prose .corneta-toc > p:first-child {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--text-mute) !important;
  margin: 0 0 10px !important;
}
.cv2-prose .corneta-toc ol {
  margin: 0 !important;
  padding-left: 22px !important;
  columns: 2;
  column-gap: 26px;
}
.cv2-prose .corneta-toc li {
  margin-bottom: 6px;
  break-inside: avoid;
}
.cv2-prose .corneta-toc a {
  text-decoration: none;
  color: var(--text);
}
.cv2-prose .corneta-toc a:hover { color: var(--link); text-decoration: underline; }
@media (max-width: 640px) {
  .cv2-prose .corneta-toc ol { columns: 1; }
}

/* Hr separator */
.cv2-prose hr {
  border: 0;
  height: 1px;
  background: var(--border);
  margin: var(--s-10) 0;
}

/* Blockquote */
.cv2-prose blockquote {
  margin: var(--s-6) 0;
  padding: var(--s-4) var(--s-6);
  border-left: 4px solid var(--link);
  background: #eff6ff;
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 17px;
  line-height: 1.6;
}
.cv2-prose blockquote p:last-child { margin-bottom: 0; }

/* Figure inside content */
.cv2-prose figure {
  margin: var(--s-6) 0;
}
.cv2-prose figure img {
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.cv2-prose figure figcaption {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--text-mute);
  margin-top: var(--s-2);
  font-style: italic;
}

/* Картинки внутри текста — ограничиваем чтобы не были огромными */
.cv2-prose img {
  max-width: 100%;
  max-height: 380px;
  width: auto;
  height: auto;
  border-radius: var(--radius);
  margin: var(--s-4) auto;
  display: block;
  box-shadow: var(--shadow-sm);
}
.cv2-prose figure img {
  max-height: 420px;
}
@media (max-width: 768px) {
  .cv2-prose img { max-height: 260px; }
}

/* Маркеры ❌ ✅ ⚠ перед h3 — отступы */
.cv2-prose h3:has(+ p) { margin-bottom: var(--s-2); }

/* PDF lead-magnet CTA (поверх inline-style) — уточнения */
.cv2-prose div[style*="linear-gradient(135deg,#1a3a8e"] {
  margin: var(--s-8) 0 !important;
  box-shadow: var(--shadow-md);
}

/* Application examples — карточки с примерами выбора */
.cv2-prose-example {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  border-left: 4px solid #f59e0b;
  border-radius: var(--radius);
  padding: var(--s-5) var(--s-6);
  margin: var(--s-6) 0;
}

/* Mobile tweaks */
@media (max-width: 768px) {
  .cv2-article-wrap { padding-top: var(--s-6); padding-bottom: var(--s-10); }
  .cv2-prose { font-size: 17px; line-height: 1.65; }
  .cv2-prose h2 { margin-top: var(--s-8); }
  .cv2-prose h3 { margin-top: var(--s-6); }
}
