/* ───────────────────────────────────────────────────────────────
 * K-Promo — PATCH 1.5
 * ───────────────────────────────────────────────────────────────
 * Цель: восстановить визуал к референсу из Claude Design.
 *
 * Корневая причина расхождений: WoodMart-родитель грузит свой CSS
 * с более высокой специфичностью (через body.theme-default, через
 * .website-wrapper .btn, через a { ... } без префиксов) и перебивает
 * наши .kp-* правила, у которых специфичность всего 0,0,1,0.
 *
 * Решение: префиксуем критичные правила селектором body.kp-body —
 * это даёт 0,0,1,1 (плюс класс на body), что покрывает большинство
 * WoodMart-овских селекторов. На самых упорных местах добавляем !important.
 *
 * Подключается ПОСЛЕ patch-1.4.css → перебивает и main, и patch-1.4.
 * ─────────────────────────────────────────────────────────────── */


/* ═══════════════════════════════════════════════════════════════
 * FIX A — Sticky-меню: UPPERCASE + чёткие стили ссылок
 * ═══════════════════════════════════════════════════════════════ */

/* WoodMart перебивает text-transform на ссылках через .website-wrapper a.
 * Поднимаем специфичность + !important */
body.kp-body .kp-snav-link,
body.kp-body .kp-snav-allcats,
body.kp-body .kp-snav-allcats span {
  text-transform: uppercase !important;
  letter-spacing:normal!important;
  font-weight: 800 !important;
  font-size: 14px !important;
  color: var(--ink) !important;
  text-decoration: none !important;
}

body.kp-body .kp-snav-allcats,
body.kp-body .kp-snav-allcats span {
  color: #fff !important;
}

/* Разделительная вертикальная линия между "Все категории" и первой ссылкой */
body.kp-body .kp-snav-left .kp-snav-link:first-of-type {
  position: relative;
  padding-left: 28px;
}
body.kp-body .kp-snav-left .kp-snav-link:first-of-type::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 24px;
  background: rgba(0, 0, 0, 0.15);
}

/* CTA "Заказать звонок" в шапке — жёлтая кнопка, UPPERCASE по дизайну */
body.kp-body .kp-cta-call {
  background: var(--yellow) !important;
  color: var(--ink) !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  letter-spacing:normal!important;
  height: 56px !important;
  padding: 0 28px !important;
  border-radius: var(--radius-sm) !important;
  text-transform: none !important; /* в дизайне НЕ uppercase, остаётся как есть */
}

/* Кнопка корзины в sticky — UPPERCASE убираем, она остаётся "0 ₽" */
body.kp-body .kp-snav-cart,
body.kp-body .kp-snav-cart-sum {
  text-transform: none !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX B — Hero: заголовок жирный, без межбуквенного воздуха
 * ═══════════════════════════════════════════════════════════════ */

body.kp-body .kp-hero-title {
  font-weight: 900 !important;
  font-size: 64px !important;            /* было 72, в дизайне ~64 на ширине 1240 */
  line-height: 0.98 !important;
  letter-spacing:normal!important;
  text-transform: uppercase !important;
  margin: 0 0 32px !important;
  color: var(--ink) !important;
}

body.kp-body .kp-hero-kicker {
  text-transform: uppercase !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  letter-spacing:normal!important;
  color: var(--ink-2) !important;
}

body.kp-body .kp-hero-sub {
  font-size: 17px !important;
  line-height: 1.55 !important;
  color: var(--ink-2) !important;
  font-weight: 400 !important;
  max-width: 520px !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX C — Кнопки: восстанавливаем заливку и обводку
 * ═══════════════════════════════════════════════════════════════ */

/* Базовая кнопка — все ключевые свойства с !important. 
 * WoodMart перебивает background, color, padding, border-radius. */
body.kp-body .kp-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  height: 56px !important;
  padding: 0 28px !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  letter-spacing:normal!important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  border: 0 !important;
  cursor: pointer !important;
  text-decoration: none !important;
  transition: all .15s !important;
}

/* Primary — тёмная заливка, белый текст */
body.kp-body .kp-btn-primary,
body.kp-body button.kp-btn-primary,
body.kp-body a.kp-btn-primary {
  background: var(--ink) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: none !important;
}
body.kp-body .kp-btn-primary:hover {
  background: #1a1a1a !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-card) !important;
  color: #fff !important;
}
body.kp-body .kp-btn-primary span {
  color: #fff !important;
}

/* Ghost — прозрачная с обводкой */
body.kp-body .kp-btn-ghost,
body.kp-body button.kp-btn-ghost,
body.kp-body a.kp-btn-ghost {
  background: transparent !important;
  color: var(--ink) !important;
  box-shadow: inset 0 0 0 2px var(--ink) !important;
  border: 0 !important;
}
body.kp-body .kp-btn-ghost:hover {
  background: var(--yellow) !important;
  box-shadow: inset 0 0 0 2px var(--ink) !important;
  color: var(--ink) !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX D — Hero trust-items (✓ БЕЗНАЛ С НДС и т.д.)
 * ═══════════════════════════════════════════════════════════════ */

body.kp-body .kp-hero-trust {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 28px !important;
  margin-top: 32px !important;
  margin-bottom: 0 !important;
}
body.kp-body .kp-hero-trust-item {
  display: inline-flex !important;
  gap: 8px !important;
  align-items: center !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  color: var(--ink-2) !important;
  letter-spacing:normal!important;
  text-transform: uppercase !important;
}
body.kp-body .kp-hero-trust-item svg {
  color: var(--ink) !important;
  stroke: var(--ink) !important;
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX E — Точки-индикаторы слайдера hero (в дизайне они есть!)
 * ═══════════════════════════════════════════════════════════════ */

/* Баг: в hero.php класс button — "dot", но в main.css селектор — ".kp-dot".
 * Селектор не находит элементы → точки не видны.
 * Решение: подхватываем оба варианта класса для совместимости. */

body.kp-body .kp-hero-dots {
  position: absolute !important;
  bottom: -20px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  gap: 8px !important;
  z-index: 5;
}

body.kp-body .kp-hero-dots .dot,
body.kp-body .kp-hero-dots .kp-dot,
body.kp-body .kp-hero-dots button {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--ink) !important;
  opacity: 0.18 !important;
  border: 0 !important;
  padding: 0 !important;
  cursor: pointer !important;
  transition: all .2s !important;
  display: block !important;
}

body.kp-body .kp-hero-dots .dot.is-active,
body.kp-body .kp-hero-dots .kp-dot.is-active,
body.kp-body .kp-hero-dots button.is-active {
  opacity: 1 !important;
  width: 24px !important;
  border-radius: 4px !important;
}

body.kp-body .kp-hero-dots .dot:hover,
body.kp-body .kp-hero-dots .kp-dot:hover {
  opacity: 0.5;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX F — Поиск в шапке: жёлтая кнопка-лупа должна быть заметной
 * ═══════════════════════════════════════════════════════════════ */

body.kp-body .kp-search {
  background: var(--fog) !important;
  border-radius: var(--radius-sm) !important;
  height: 56px !important;
  max-width: 520px !important;
  border: 1px solid transparent;
  padding: 4px !important;
  gap: 4px;
}
body.kp-body .kp-search-input {
  padding: 0 20px !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  background: transparent !important;
  color: var(--ink) !important;
}
body.kp-body .kp-search-btn {
  width: 48px !important;
  height: 48px !important;
  background: var(--yellow) !important;
  border-radius: var(--radius-sm) !important;
  border: 0 !important;
  display: grid !important;
  place-items: center;
  flex-shrink: 0;
}
body.kp-body .kp-search-btn:hover {
  background: var(--yellow-hover) !important;
}
body.kp-body .kp-search-btn svg {
  color: var(--ink) !important;
  stroke: var(--ink) !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX G — Общая защита от WoodMart: ссылки и кнопки
 * ═══════════════════════════════════════════════════════════════ */

/* WoodMart часто добавляет underline/color на все a-теги внутри
 * .website-wrapper. Снимаем для наших блоков. */
body.kp-body .kp-topbar a,
body.kp-body .kp-header a,
body.kp-body .kp-snav a,
body.kp-body .kp-page a,
body.kp-body .kp-footer a {
  text-decoration: none;
}

/* WoodMart-овская тень на кнопках */
body.kp-body .kp-snav-cart,
body.kp-body .kp-snav-icon,
body.kp-body .kp-cta-call,
body.kp-body .kp-btn,
body.kp-body .kp-search-btn {
  box-shadow: none;
}

/* Bring back специфичные box-shadow только где они нужны */
body.kp-body .kp-btn-ghost {
  box-shadow: inset 0 0 0 2px var(--ink) !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX H — Контейнер hero: расстояние, выравнивание
 * ═══════════════════════════════════════════════════════════════ */

body.kp-body .kp-hero {
  padding: 64px 0 80px !important;
}
body.kp-body .kp-hero-grid {
  display: grid !important;
  grid-template-columns: 1.1fr 1fr !important;
  gap: 64px !important;
  align-items: center !important;
  min-height: 520px;
}
body.kp-body .kp-hero-ctas {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  margin-bottom: 0 !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX I — Чтобы не было лишнего верхнего отступа у main.kp-home
 * ═══════════════════════════════════════════════════════════════ */
body.kp-body main.kp-home,
body.kp-body main.kp-page {
  padding-top: 0 !important;
  margin-top: 0 !important;
}


/* ═══════════════════════════════════════════════════════════════
 * FIX J — Lighter z-index fix для админ-бара WP
 * ═══════════════════════════════════════════════════════════════ */
body.admin-bar .kp-snav-wrap {
  top: 32px;
}
@media (max-width: 782px) {
  body.admin-bar .kp-snav-wrap {
    top: 46px;
  }
}
