/* ============================================================
   ТеплоЛайф — ТЕМА «ТЕПЛОВАЯ КАРТА» (thermo)
   Подключается ВМЕСТО styles-refined.css; импортирует refined
   (а тот — оригинал) и накладывает только дизайн-слой:
   типографика Unbounded/Onest + термальная палитра.
   Структура, каталог с фото, корзина, конфигуратор — НЕ меняются.
   Шрифты Onest/Unbounded — самохостинг (fonts-thermo.css), как Inter в styles.css.
   ============================================================ */
@import url('styles-refined.css');
@import url('fonts-thermo.css');

/* ---------- токены темы ---------- */
:root{
  /* светлый «пол» — чуть светлее Tado Greige для контраста с термо-акцентами */
  --bg:#f7f2ea;
  --bg-alt:#efe8dc;
  --line:#e4d8c6;
  --card:#ffffff;
  --card-border:#e4d8c6;
  --ink:#15110e;
  --ink-soft:#574a43;

  /* бренд-нагрев (менее яркий оранж, вар.1) */
  --brand:#fd612a;
  --brand-dark:#d75224;
  --brand-soft:#fff0e6;

  /* «холод» для контрастных поверхностей */
  --cold:#0b1f3a;
  --cold-2:#142e52;

  /* термальная шкала — главный акцент темы */
  --t-cold:#1f4fd6;
  --t-cool:#16a3c9;
  --t-mid:#16a34a;
  --t-warm:#ffd166;
  --t-hot:#ff8a00;
  --t-fire:#e11d2a;
  --thermo:linear-gradient(90deg,var(--t-cold),var(--t-cool),var(--t-mid),var(--t-warm),var(--t-hot),var(--t-fire));
  --thermo-warm:linear-gradient(90deg,var(--t-warm),var(--t-hot),var(--t-fire));   /* для тёмных поверхностей */
  --thermo-deep:linear-gradient(90deg,#c25e00,#e11d2a);                            /* читаемый на светлом */

  --shadow:0 10px 30px rgba(25,14,6,.07);
  --shadow-lg:0 26px 64px rgba(25,14,6,.15);
}

/* ---------- типографика ---------- */
body{font-family:'Onest','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.6}
h1,h2,h3,.h2{font-family:'Unbounded','Onest','Inter',sans-serif;font-weight:700}
/* H1: Unbounded 700 был слишком «громоздким» и обрезался → легче и компактнее */
.hero h1{font-weight:600;font-size:clamp(26px,3.2vw,40px);line-height:1.1;letter-spacing:-.025em;overflow-wrap:break-word}
.feat h3,.features__grid--3 .feat h3{font-weight:600;font-size:16px}

/* шапка под новую базу */
.hdr{background:rgba(247,242,234,.88);box-shadow:0 6px 20px rgba(25,14,6,.06)}
/* кнопка-звонок в шапке — только на телефоне (≤640px), где скрыты .phone и CTA */
.hdr-call{display:none}
@media(max-width:640px){
  .hdr__cta{display:none}
  .hdr-call{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--brand);color:#fff;flex:none;margin-left:auto}
  .hdr-call svg{width:22px;height:22px}
}

/* логотип: ОСТАВЛЯЕМ ОРИГИНАЛ из styles.css по выбору пользователя —
   «Тепло» #c34812 + «Лайф» #f4a300 (Inter 900) + пульсирующий ореол «прогрева» + 3D-монета.
   Тема НЕ переопределяет логотип: вариант Unbounded/чернила/термоградиент отклонён. */

/* ---------- hero ---------- */
.hero{
  background:
    radial-gradient(820px 360px at 80% 12%,rgba(255,138,0,.10),transparent 62%),
    linear-gradient(180deg,var(--bg) 0%,#fdfaf3 100%);
}
.badge{background:#fff;color:var(--ink-soft);border:1px solid var(--line)}
.hero__bullets span{
  font-family:'Unbounded',sans-serif;font-weight:700;font-size:19px;
  background:var(--thermo-deep);-webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
}
/* термо-кант сверху hero-карточек */
.hero__card{position:relative;overflow:hidden;border-color:var(--line)}
/* Один градиент жар(слева)→холод(справа), который «прокатывается» по полоске,
   так что тепло проявляется СЛЕВА НАПРАВО через чистый спектр.
   Один слой, без наложений → никаких серых стыков. Полоса шире (8px). */
.hero__card::before,
.calc__result::before{
  content:"";position:absolute;left:0;right:0;top:0;height:8px;z-index:1;
  background:linear-gradient(90deg,
    var(--t-fire) 0%, var(--t-fire) 33%,
    var(--t-hot) 42%, var(--t-warm) 50%, var(--t-mid) 58%, var(--t-cool) 64%,
    var(--t-cold) 67%, var(--t-cold) 100%);
  background-size:300% 100%;
  background-repeat:no-repeat;
  background-position:100% 0;          /* старт — холодная (синяя) сторона */
  animation:heatScan 6.5s ease-in-out infinite;
}
/* лёгкий каскад — вторая карточка прогревается чуть позже */
.hero__cards .hero__card:nth-child(2)::before{animation-delay:1s}
/* холод → прогрев слева направо → держим жар → плавное остывание → цикл */
@keyframes heatScan{
  0%,8% {background-position:100% 0}    /* холод (синий) */
  46%   {background-position:0% 0}      /* прогрев слева направо (прокат) */
  74%   {background-position:0% 0;animation-timing-function:steps(1)}  /* держим жар → затем мгновенный сброс */
  75%   {background-position:100% 0}    /* охлаждение: синий появляется РАЗОМ, без проката */
  100%  {background-position:100% 0}    /* держим холод → цикл */
}
@media (prefers-reduced-motion:reduce){
  .hero__card::before,.calc__result::before{animation:none;background:var(--thermo);background-size:100% 100%}
}
/* цена в hero-карточке — всегда в одну строку (не разрывать «3 788 ₽») */
.price-now{font-family:'Unbounded',sans-serif;font-weight:700;font-size:20px;white-space:nowrap}
/* «−15%» в hero чуть компактнее глобального, чтобы строка цены не переносилась */
.hero__card .price-off{font-size:12px;padding:5px 8px}
/* блобы → мягкое «свечение тепла» */
.hero__blob{filter:none}
.hero__blob--1{background:radial-gradient(circle,rgba(255,138,0,.26),transparent 65%)}
.hero__blob--2{background:radial-gradient(circle,rgba(225,29,42,.15),transparent 65%)}

/* ---------- hero: гармонизация левой колонки (центровка/размеры) ---------- */
/* единый вертикальный ритм вместо вразнобой 42/18/28/32/22 */
.badge{margin-bottom:30px;padding:9px 16px;font-size:13.5px}
.badge .chtk-logo-inline,.badge .chtk-logo-inline img{height:20px}
.hero h1{margin:0 0 20px}
.hero__sub{font-size:17px;line-height:1.55;margin:0 0 28px;max-width:500px}
.hero__btns{gap:12px;margin-bottom:28px}
/* подписи второго плана к единому кеглю 13.5px, акценты-цифры — 20px */
.hero__bullets{gap:30px}
.hero__bullets li{font-size:13.5px}
.hero__bullets span{font-size:20px}
.hero__trust{margin-top:26px}
.hero__trust-rating{font-size:13.5px}
.hero__trust-rating .stars{font-size:16px}

/* ---------- eyebrow: термо-черта (вместо одноцветной) ---------- */
.eyebrow{color:var(--ink-soft);font-family:'Unbounded',sans-serif;font-weight:600;font-size:14px;letter-spacing:.14em}
/* eyebrow: вместо абстрактной радужной полоски — значок по теме раздела (CSS-mask, сплошной бренд-цвет) */
.eyebrow::before{
  width:26px;height:26px;border-radius:0;background:var(--brand-dark);
  -webkit-mask:var(--eb-ico) center/contain no-repeat;
          mask:var(--eb-ico) center/contain no-repeat;
}
.calc .eyebrow{--eb-ico:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='5' y='2' width='14' height='20' rx='2'/><path d='M8 6h8'/><path d='M8.5 11h.01M12 11h.01M15.5 11h.01M8.5 15h.01M12 15h.01M15.5 15h.01'/></svg>")}
.catalog .eyebrow{--eb-ico:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='7' height='7' rx='1.2'/><rect x='14' y='3' width='7' height='7' rx='1.2'/><rect x='3' y='14' width='7' height='7' rx='1.2'/><rect x='14' y='14' width='7' height='7' rx='1.2'/></svg>")}
.services .eyebrow{--eb-ico:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z'/></svg>")}
.delivery .eyebrow{--eb-ico:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 6h11v9H3z'/><path d='M14 9h4l3 3v3h-7z'/><circle cx='7.5' cy='17.5' r='1.6'/><circle cx='17.5' cy='17.5' r='1.6'/></svg>")}
.reviews .eyebrow{--eb-ico:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20 5a1 1 0 0 0-1-1H5a1 1 0 0 0-1 1v9a1 1 0 0 0 1 1h3v4l4-4h7a1 1 0 0 0 1-1z'/></svg>")}
.contacts .eyebrow{--eb-ico:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 22s7-5.8 7-12a7 7 0 0 0-14 0c0 6.2 7 12 7 12z'/><circle cx='12' cy='10' r='2.5'/></svg>")}

/* ---------- преимущества: «горячие» плитки иконок ---------- */
.features__grid--3 .feat__ico,
.feat__ico{
  background:linear-gradient(135deg,var(--t-hot),var(--t-fire));
  color:#fff;box-shadow:0 8px 18px rgba(225,29,42,.22);
}

/* ---------- калькулятор ---------- */
.calc__gauge{background:#ece2d2}
.calc__gauge span{background:var(--brand)} /* индикатор площади — сплошной, не радуга */
/* ползунок площади (range): оранжевая заливка слева + круглый бегунок */
.calc__range{-webkit-appearance:none;appearance:none;width:100%;height:10px;border-radius:999px;background:#ece2d2;outline:none;cursor:pointer;margin-top:8px}
.calc__range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;margin-top:-7px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 2px 8px rgba(253,97,42,.45);cursor:pointer}
.calc__range::-moz-range-thumb{width:24px;height:24px;border:3px solid #fff;border-radius:50%;background:var(--brand);box-shadow:0 2px 8px rgba(253,97,42,.45);cursor:pointer}
.calc__range:focus-visible{box-shadow:0 0 0 3px rgba(253,97,42,.35)}
.calc__opt.is-active{
  background:var(--brand);border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-soft),0 6px 16px rgba(253,97,42,.25);
}
.calc__result{position:relative;overflow:hidden}
/* полоса результата калькулятора — та же анимированная термополоса, что на hero (см. .hero__card::before) */

/* ---------- каталог ---------- */
.tab.is-active{background:var(--brand);border-color:var(--brand);box-shadow:0 6px 16px rgba(253,97,42,.25)}
/* вкладки каталога: равной ширины, длинные подписи переносятся ВНУТРИ кнопки (без обрезки) */
.tabs{flex-wrap:wrap;justify-content:center;align-items:stretch}
.tab{flex:1 1 200px;min-width:0;white-space:normal;text-align:center;line-height:1.25;
  background:#fff;border:1.5px solid #dccbb2;color:var(--ink);font-weight:700;box-shadow:0 3px 12px rgba(25,14,6,.09)}
.tab:hover{border-color:var(--brand);color:var(--brand-dark);box-shadow:0 7px 18px rgba(253,97,42,.2);transform:translateY(-1px)}
/* карточки каталога — равная высота, цена/кнопка прижаты к низу */
#catalog-root .cards{align-items:stretch}
#catalog-root .card__foot{margin-top:auto}
/* Без декоративной радужной полоски сверху — она лезла на бейдж «ХИТ» и рамку.
   overflow не ставим: «ХИТ» выступает на top:-10px, фото клипится своим .card__img. */
#catalog-root .card{position:relative}
/* карточка-хит: оранжевая рамка жирнее + бейдж «Хит» крупнее */
#catalog-root .card--hit{border-width:2.5px}
#catalog-root .card__badge{font-size:15px;padding:6px 14px;top:-13px}
/* цена в карточке — всегда одной строкой (не разрывать «2 726 ₽») */
#catalog-root .card__pr-now{font-family:'Unbounded',sans-serif;font-weight:700;white-space:nowrap}

/* ---------- услуги / доставка-оплата ---------- */
.serv__price{font-family:'Unbounded',sans-serif;font-weight:700;font-size:16px}
.dp__item-h svg{color:var(--brand)}

/* ---------- отзывы ---------- */
/* звёзды — золото (в тон «Лайф» в логотипе), по запросу — везде одинаково */
.rev__stars{color:var(--gold)}
.hero__trust-rating .stars{color:var(--gold)}
.eyebrow .star-gold{color:var(--gold)}

/* ---------- кнопки ---------- */
.btn{font-weight:700;touch-action:manipulation}
.btn--primary{background:var(--brand);box-shadow:0 10px 24px rgba(253,97,42,.30)}
.btn--primary:hover{background:var(--brand-dark);box-shadow:0 14px 28px rgba(253,97,42,.4)}
/* вторичные кнопки были блёклые (серый контур) → чёткий оранжевый контур, жирнее */
.btn--ghost{background:#fff;color:var(--brand-dark);border:1.6px solid var(--brand);font-weight:700}
.btn--ghost:hover{background:var(--brand-soft);border-color:var(--brand-dark);color:var(--brand-dark)}
.hero__btns .btn--primary:nth-child(2){border:1.6px solid var(--brand);color:var(--brand-dark)}
.hero__btns .btn--primary:nth-child(2):hover{background:var(--brand-soft);border-color:var(--brand-dark)}

/* ---------- nav: оранжевые «пилюли» (десктоп) ---------- */
@media (min-width:1025px){
  .nav a{
    background:var(--brand);color:#fff;border-color:var(--brand);
    box-shadow:0 2px 0 rgba(140,40,0,.18),0 6px 14px rgba(253,97,42,.22);
  }
  .nav a:hover{
    background:var(--brand-dark);color:#fff;border-color:var(--brand-dark);
    transform:translateY(-2px);
    box-shadow:0 4px 0 rgba(140,40,0,.22),0 10px 20px rgba(253,97,42,.30);
  }
}

/* ---------- бейдж скидки «−15%»: крупнее везде ---------- */
.price-off,.calc__r-off{font-size:14px;padding:6px 10px}
#catalog-root .card__pr-now .card__pr-off{font-size:12px;padding:5px 8px;margin-left:6px}

/* ---------- доступность/полировка поверх refined ---------- */
html{scroll-padding-top:112px}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
.field input:focus,.field textarea:focus,.field select:focus,
.calc__field input[type=number]:focus{
  outline:0;border-color:var(--brand);box-shadow:0 0 0 3px rgba(253,97,42,.35);
}
.burger{width:44px;height:44px;background:#fff}
.ftr__links a{display:inline-block;padding:8px 0}

/* ---------- мобильная адаптация темы ---------- */
@media (max-width:1024px){
  /* hero складывается в колонку (карточки уходят наверх) — снимаем десктопный
     «подъём» бейджа, иначе он залезает на карточки сверху */
  .badge{margin-top:0}
  /* пункт бургер-меню при тапе — в тон темы */
  .nav.is-open a:active{color:var(--brand)}
}
@media (max-width:640px){
  /* hero-карточки в одну колонку: 2-в-ряд на телефоне сплющивались */
  .hero__cards{grid-template-columns:1fr}
  /* кнопки hero — на всю ширину, удобнее тапать */
  .hero__btns .btn{flex:1 1 100%;justify-content:center}
}

/* запас на случай незагрузки background-clip (древние браузеры) */
@supports not ((-webkit-background-clip:text) or (background-clip:text)){
  .logo__txt span,.hero__bullets span{background:none;color:var(--brand-dark);-webkit-text-fill-color:var(--brand-dark)}
}


/* ====================================================================
   ЗАФИКСИРОВАНО с теста: зелёные акценты (#2e8b57) + полировка вёрстки.
   Новый оранж --brand:#fd612a уже задан в :root выше.
   ==================================================================== */
.btn,.badge{outline:3px solid #2e8b57;outline-offset:0;box-shadow:none;border-color:transparent}
@media(min-width:1025px){.nav a{outline:3px solid #2e8b57;outline-offset:0;border-color:transparent;box-shadow:none}}
.btn--ghost{border-color:transparent;color:#1f6e43}
.hero__btns .btn--primary:nth-child(2){border-color:transparent;box-shadow:none}
.btn--ghost:hover{background:#eaf5ee;border-color:#1f6e43;color:#1f6e43}
.eyebrow{font-size:17px;white-space:nowrap}
.eyebrow::before{background:#2e8b57;width:30px;height:30px}
.hero__art{align-self:start;margin-top:0}
.hero__grid>.badge{grid-column:1/-1;width:100%;justify-content:center;margin-top:0;margin-bottom:20px}
.phone{display:none}
@media(min-width:1025px){.nav{gap:10px}.nav a{flex:1 1 0;justify-content:center}}
.tab,.calc__opt{outline:3px solid #2e8b57;outline-offset:0;border-color:transparent;box-shadow:none}
.feat,.hero__card,#catalog-root .card,.serv,.rev,.calc__result,.dp__item,.calc__box{outline:3px solid #2e8b57;outline-offset:0;border-color:transparent;box-shadow:none}
.serv__grid{align-items:stretch}
.serv__price{margin-top:auto}
.cart-link{color:var(--brand);outline:3px solid #2e8b57;outline-offset:0;border-color:transparent;box-shadow:none}
.badge{font-size:21px;padding:14px 24px;margin-top:-112px}
.badge .chtk-logo-inline,.badge .chtk-logo-inline img{height:28px}
/* фикс: логотип ЧТК — не сжимать flex'ом и не давать схлопнуться по ширине
   (на мобиле бейдж inline-flex без wrap → логотип сплющивался в полоску ~6px) */
.badge{flex-wrap:wrap;row-gap:2px;justify-content:center}
.badge .chtk-logo-inline{flex:0 0 auto}
.badge .chtk-logo-inline img{width:auto;max-width:none}
*:focus-visible{outline-color:#2e8b57}

/* ---------- модалка «Купить оптом» ---------- */
.ws-modal[hidden]{display:none}
.ws-modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:20px}
.ws-modal__overlay{position:absolute;inset:0;background:rgba(11,31,58,.55);backdrop-filter:blur(2px)}
.ws-modal__box{
  position:relative;z-index:1;width:380px;max-width:100%;background:#fff;border-radius:20px;
  box-shadow:0 30px 80px rgba(11,31,58,.4);padding:28px 26px 26px;animation:wsIn .2s ease;
}
@keyframes wsIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.ws-modal__close{
  position:absolute;top:12px;right:14px;width:34px;height:34px;border-radius:50%;
  font-size:24px;line-height:1;color:var(--muted);display:grid;place-items:center;
}
.ws-modal__close:hover{color:var(--ink);background:var(--bg-alt)}
.ws-modal__badge{
  display:inline-block;font-size:12px;font-weight:700;letter-spacing:.02em;
  color:var(--brand-dark);background:var(--brand-soft);padding:5px 12px;border-radius:999px;margin-bottom:14px;
}
.ws-modal__h{font-family:'Unbounded',sans-serif;font-weight:700;font-size:22px;margin:0 0 10px}
.ws-modal__p{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin:0 0 18px}
.ws-modal__act{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  padding:14px;border-radius:13px;font-weight:700;font-size:15px;margin-top:11px;
  transition:transform .12s,box-shadow .15s,background .15s;
}
.ws-modal__act svg{flex:none}
.ws-modal__act--call{background:var(--brand);color:#fff;box-shadow:0 10px 22px rgba(253,97,42,.32)}
.ws-modal__act--call:hover{background:var(--brand-dark);transform:translateY(-1px)}
.ws-modal__act--mail{background:var(--cold);color:#fff;box-shadow:0 10px 22px rgba(11,31,58,.3)}
.ws-modal__act--mail:hover{background:var(--cold-2);transform:translateY(-1px)}
@media(max-width:640px){
  .ws-modal__box{padding:24px 20px 20px}
  .ws-modal__h{font-size:20px}
  .ws-modal__act{font-size:14px}
}

/* ====================================================================
   МОБИЛЬНАЯ РЕВИЗИЯ (аудит 16.06.2026): паритет с десктопом —
   убираем горизонтальный overflow, возвращаем корзину и «Купить оптом»
   на телефон, поднимаем hero-текст/CTA над сгибом, тач-таргеты ≥44px.
   ==================================================================== */

/* Footer: ссылки переносятся, а не уезжают за правый край.
   Это главный источник горизонтального overflow на всех мобильных
   ширинах (ряд из 5 ссылок = 458px не влезал в вьюпорт и обрезал
   «Политику конфиденциальности», смещал плавающую кнопку и бургер). */
@media(max-width:768px){
  .ftr__links{flex-wrap:wrap;row-gap:10px;column-gap:18px}
  /* декоративный hero-блоб больше не выпирает за край (+12px к ширине) */
  .hero{overflow-x:clip}
}

/* Шапка на телефоне (≤640px): показываем иконку корзины (#cartLink),
   прячем текстовый телефон (есть кнопка-звонок) и кнопку «Купить оптом»
   — она переезжает в бургер-меню. Раньше весь .hdr__cta был display:none,
   из-за чего корзина и опт были недоступны с телефона. */
@media(max-width:640px){
  /* logo + корзина + звонок + бургер должны влезть в 390px:
     убираем большой gap шапки и дублирующую плавающую кнопку звонка
     (звонок уже есть иконкой в sticky-шапке). */
  .hdr__row{gap:8px}
  .hdr__cta{display:flex;align-items:center;gap:8px;margin-left:auto}
  .hdr__cta .phone{display:none}
  .hdr__cta .btn{display:none}
  .hdr-call{margin-left:0;flex:none}
  .floating{display:none}
  .nav .nav__opt{color:var(--brand-dark);font-weight:700}
  /* cookie-баннер не шире вьюпорта независимо от раскладки */
  .cookie{left:12px;right:12px;width:auto;max-width:none}
}

/* Hero на мобильном/планшете: бейдж → ценностное предложение + CTA →
   и только потом карточки товара. Раньше order:-1 у .hero__art
   выталкивал картинки на первый экран, а заголовок и кнопки
   «Подобрать комплект»/«Каталог» уходили на ~1080px ниже сгиба. */
@media(max-width:1024px){
  .hero__art{order:1}
  .hero__grid>.badge{order:-1}
}

/* Тач-таргеты ≥44px (эталон iOS/WCAG) на тач-ширинах */
@media(max-width:1024px){
  .btn--sm{min-height:44px}
  .tab{min-height:44px}
  .hero__trust-rating{min-height:44px;display:inline-flex;align-items:center}
  .contacts__row a[href^="tel:"],.contacts__row a[href^="mailto:"]{
    display:inline-flex;align-items:center;min-height:44px}
  .cart-row__qty button{width:44px;height:44px}
  .cart-row__qty input{height:44px}
  .cart-row__del{min-width:44px;min-height:44px;padding:10px}
  .ws-modal__close{width:44px;height:44px}
}

/* Мелкий служебный текст: не опускаем кегль ниже 13px на телефоне */
@media(max-width:640px){
  .price-off,.calc__r-off{font-size:13px}
}
