/* ============================================================================
   CardioPower — Components & Layout
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--t-base);
  line-height: var(--lh-normal);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, picture, svg { display: block; max-width: 100%; }
svg { stroke-linecap: round; stroke-linejoin: round; }   /* мягкие, аккуратные иконки */
.section[id] { scroll-margin-top: 90px; }                /* заголовки не прячутся под шапку */
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 3px solid var(--pulse); outline-offset: 2px; border-radius: var(--r-xs); }

/* ---- Typography helpers ---- */
.display { font-family: var(--font-display); font-weight: 600; line-height: var(--lh-tight); letter-spacing: var(--ls-display); text-transform: uppercase; }
.h1 { font-family: var(--font-display); font-weight: 600; font-size: var(--t-h1); line-height: var(--lh-snug); letter-spacing: -0.01em; }
.h2 { font-family: var(--font-display); font-weight: 600; font-size: var(--t-h2); line-height: var(--lh-snug); text-transform: uppercase; letter-spacing: .01em; }
.h2 .h2-soft { font-weight: 400; }
.h3 { font-family: var(--font-display); font-weight: 500; font-size: var(--t-h3); }
.eyebrow { font-size: var(--t-xs); font-weight: 600; letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--pulse-600); }
.lead { font-size: var(--t-lg); color: var(--text-soft); }
.muted { color: var(--text-muted); }

/* ---- Layout ---- */
.container { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(2.25rem, 4.5vw, 3.75rem); }
.section--tight { padding-block: clamp(1.5rem, 3vw, 2.5rem); }
.grid { display: grid; gap: var(--s-5); }
.stack > * + * { margin-top: var(--s-4); }
.center { text-align: center; }
.flow-sm > * + * { margin-top: var(--s-2); }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: .85rem 1.5rem; border-radius: var(--r-pill); border: 1.5px solid transparent;
  font-weight: 600; font-size: var(--t-sm); letter-spacing: .02em; white-space: nowrap;
  transition: transform var(--dur-1) var(--ease), background var(--dur-1), box-shadow var(--dur-2), color var(--dur-1), border-color var(--dur-1);
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--pulse); color: #fff; box-shadow: var(--sh-pulse); }
.btn--primary:hover { background: var(--pulse-600); box-shadow: 0 10px 30px rgba(255,68,56,.36); }
.btn--dark { background: var(--ink-900); color: var(--on-ink); }
.btn--dark:hover { background: var(--ink-700); }
.btn--ghost { background: transparent; border-color: var(--border-strong); color: var(--text); }
.btn--ghost:hover { border-color: var(--ink-900); background: var(--white); }
.btn--on-dark { background: #fff; color: var(--ink-900); }
.btn--on-dark:hover { background: var(--n-100); }
.btn--ghost-light { background: transparent; border-color: rgba(255,255,255,.35); color:#fff; }
.btn--ghost-light:hover { border-color:#fff; background: rgba(255,255,255,.08); }
.btn--lg { padding: 1.05rem 2rem; font-size: var(--t-base); }
.btn--block { width: 100%; }

.link-arrow { display:inline-flex; align-items:center; gap:.4rem; font-weight:600; color:var(--text); }
.link-arrow svg { transition: transform var(--dur-1) var(--ease); }
.link-arrow:hover svg { transform: translateX(4px); }
.link-arrow:hover { color: var(--pulse-600); }

/* ---- Badges / chips ---- */
.badge { display:inline-flex; align-items:center; gap:.25rem; font-size:.62rem; font-weight:600; letter-spacing:.03em; text-transform:uppercase; padding:.15rem .5rem; border-radius:var(--r-pill); line-height:1.3; }
.badge--new { background: var(--success); color:#fff; }
.badge--hit { background: #ED7D2B; color:#fff; }
.badge--sale { background: var(--pulse); color:#fff; }
.badge--stock { background: var(--success-tint); color: var(--success); }

/* =========================== HEADER =========================== */
.topbar { background: var(--ink-900); color: var(--on-ink-soft); font-size: var(--t-xs); }
.topbar .container { display:flex; justify-content:space-between; align-items:center; min-height:38px; gap:1rem; }
.topbar a:hover { color:#fff; }
.topbar__list { display:flex; align-items:center; gap:1.25rem; flex-wrap:wrap; }
.topbar__call { color: var(--pulse-400) !important; font-weight:600; transition: color .15s; }
.topbar__call:hover { color:#fff !important; text-decoration:underline; text-underline-offset:3px; }
.topbar__hl { background: var(--pulse); color:#fff !important; padding:.2rem .8rem; border-radius:var(--r-pill); font-weight:600; line-height:1.35; }
.topbar__hl:hover { background: var(--pulse-600); color:#fff !important; }
.topbar__write { display:inline-flex; align-items:center; gap:.35rem; border:1px solid var(--pulse); color:var(--pulse-400) !important; padding:.13rem .7rem; border-radius:var(--r-pill); font-weight:600; line-height:1.35; transition:background .15s, color .15s, border-color .15s; }
.topbar__write:hover { background:var(--pulse); border-color:var(--pulse); color:#fff !important; }
.btn--write { padding:.55rem 1.1rem; font-size: var(--t-sm); }
@media (max-width:980px){ .btn--write { display:none; } }

/* ---- Селектор города ---- */
.city { position:relative; }
.city__btn { display:inline-flex; align-items:center; gap:.35rem; background:transparent; border:0; color:inherit; font:inherit; cursor:pointer; padding:0; }
.city__btn svg { opacity:.85; }
.city__btn:hover { color:#fff; }
.city__chev { transition:transform .2s; }
.city.open .city__chev { transform:rotate(180deg); }
.city__menu { position:absolute; top:calc(100% + 9px); left:0; z-index:60; min-width:230px; background:var(--white); color:var(--text); border:1px solid var(--border); border-radius:var(--r-md); box-shadow:var(--sh-3); padding:.4rem; display:none; }
.city.open .city__menu { display:block; }
.city__opt { display:flex; align-items:center; gap:.5rem; width:100%; text-align:left; background:transparent; border:0; padding:.5rem .6rem; border-radius:var(--r-sm); font-size:var(--t-sm); color:var(--text); cursor:pointer; }
.city__opt:hover { background:var(--surface-2); }
.city__auto { color:var(--pulse-600); font-weight:600; }
.city__sep { height:1px; background:var(--border); margin:.3rem 0; }
.city__search { display:flex; align-items:center; gap:.45rem; padding:.45rem .6rem; margin-bottom:.3rem; border:1px solid var(--border-strong); border-radius:var(--r-sm); color:var(--text-muted); }
.city__search input { border:0; outline:0; width:100%; font:inherit; font-size:var(--t-sm); color:var(--text); background:transparent; }
.city__list { max-height:248px; overflow-y:auto; }
.city__list::-webkit-scrollbar { width:8px; } .city__list::-webkit-scrollbar-thumb { background:var(--n-300); border-radius:8px; }
.city__empty { padding:.7rem; font-size:var(--t-sm); color:var(--text-muted); text-align:center; }

.header { position: sticky; top: 0; z-index: 50; background: rgba(247,246,244,.86); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
/* Тёмная шапка */
.header--dark { background: rgba(15,17,21,.92); border-bottom: 1px solid rgba(255,255,255,.22); }
.header--dark .nav a { color: var(--on-ink-soft); }
.header--dark .nav a:hover { color:#fff; }
.header--dark .icon-btn { color: var(--on-ink); }
.header--dark .icon-btn:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.14); }
.header--dark .btn--write { border-color: rgba(255,255,255,.28); color:#fff; }
.header--dark .btn--write:hover { background: rgba(255,255,255,.08); border-color:#fff; }
.header__row { display:flex; align-items:center; gap: var(--s-5); min-height: 72px; }
.brand { font-family: var(--font-display); font-weight:700; font-size:1.5rem; letter-spacing:.02em; text-transform:uppercase; display:flex; align-items:center; gap:.5rem; flex:none; }
.brand b { color: var(--pulse); }
.brand img { height: 38px; width: auto; display: block; flex:none; max-width:none; }
.footer .brand img { height: 34px; margin-bottom: var(--s-3); }
.nav { display:flex; gap: clamp(.7rem, 1.5vw, 1.4rem); margin-left: var(--s-3); }
.nav a { font-weight:500; font-size: clamp(.78rem, 1vw, .88rem); padding: .5rem 0; position:relative; color: var(--text); white-space:nowrap; }
.nav a::after { content:""; position:absolute; left:0; right:100%; bottom:0; height:2px; background:var(--pulse); transition: right var(--dur-2) var(--ease); }
.nav a:hover::after { right:0; }
.header__actions { margin-left:auto; display:flex; align-items:center; gap: var(--s-4); }
.icon-btn { display:grid; place-items:center; width:42px; height:42px; border-radius:var(--r-pill); border:1px solid transparent; background:transparent; position:relative; color:var(--text); }
.icon-btn:hover { background: var(--white); border-color: var(--border); }
.icon-btn .count { position:absolute; top:2px; right:2px; min-width:18px; height:18px; padding:0 4px; background:var(--pulse); color:#fff; font-size:11px; font-weight:700; border-radius:var(--r-pill); display:grid; place-items:center; }
.burger { display:none; }

/* =========================== HERO =========================== */
.hero { position: relative; background: var(--ink-900); color: var(--on-ink); overflow:hidden; }
.hero__media { position:absolute; inset:0; }
.hero__media img { width:100%; height:100%; object-fit:cover; opacity:.55; }
.hero__media::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(15,17,21,.95) 0%, rgba(15,17,21,.7) 38%, rgba(15,17,21,.15) 100%); }
.hero__inner { position:relative; padding-block: clamp(1.5rem, 4vw, 3rem); max-width: 660px; }
.hero h1 { font-family:var(--font-display); font-weight:700; font-size:clamp(2.4rem, 5vw, 4.25rem); line-height:var(--lh-tight); text-transform:uppercase; letter-spacing:var(--ls-display); }
.hero h1 em { color: var(--pulse); font-style: normal; }
.hero p { margin-top: var(--s-4); font-size: var(--t-lg); color: var(--on-ink-soft); max-width: 48ch; }
.hero__cta { margin-top: var(--s-6); display:flex; gap: var(--s-3); flex-wrap:wrap; }
.hero__meta { margin-top: var(--s-5); display:flex; gap: var(--s-6); flex-wrap:wrap; }

/* ---- Hero slider ---- */
.hero-slider { position:relative; overflow:hidden; background:var(--ink-900); width:100%; }
.hero-track { display:flex; transition:transform .6s cubic-bezier(.16,1,.3,1); }
.hero-slide { flex:0 0 100%; min-width:100%; min-height: clamp(460px, 70vh, 660px); display:flex; flex-direction:column; justify-content:center; }
.hero-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:6; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.32); color:#fff; display:grid; place-items:center; backdrop-filter:blur(6px); transition:background var(--dur-1); }
.hero-arrow:hover { background:rgba(255,255,255,.28); }
.hero-arrow--prev { left:clamp(.5rem,2vw,1.5rem); }
.hero-arrow--next { right:clamp(.5rem,2vw,1.5rem); }
.hero-dots { position:absolute; bottom:16px; left:0; right:0; z-index:6; display:flex; gap:.5rem; justify-content:center; }
.hero-dots button { width:28px; height:5px; border-radius:99px; background:rgba(255,255,255,.4); border:0; padding:0; cursor:pointer; transition:background var(--dur-1), width var(--dur-1); }
.hero-dots button.is-active { background:var(--pulse); width:42px; }
@media (max-width:560px){ .hero-arrow { width:38px; height:38px; } .hero-dots { bottom:10px; } }
@media (prefers-reduced-motion: reduce){ .hero-track { transition:none; } }
.hero__meta .num { font-family:var(--font-display); font-size:2rem; font-weight:600; }
.hero__meta .lbl { font-size:var(--t-xs); color:var(--on-ink-soft); text-transform:uppercase; letter-spacing:.08em; }

/* Финансовая плашка */
.finance-strip { background: var(--pulse); color:#fff; width: min(var(--maxw), calc(100% - 2 * var(--gutter))); margin: var(--s-4) auto 0; border-radius: var(--r-xl); overflow:hidden; }
/* Скруглённые «парящие» панели-секции на холсте */
.section--panel { padding-block: var(--s-5); }
.section--panel > .container { background: var(--surface-2); border-radius: var(--r-xl); max-width: none; width: min(var(--maxw), calc(100% - 2 * var(--gutter))); margin-inline: auto; padding: clamp(2.25rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem); }
.finance-strip .container { display:flex; align-items:center; justify-content:center; gap:1.5rem; min-height:54px; flex-wrap:wrap; text-align:center; }
.finance-strip strong { font-family:var(--font-display); font-size:1.15rem; letter-spacing:.03em; }

/* =========================== CATEGORIES =========================== */
.section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom: var(--s-6); flex-wrap:wrap; }
.cat-grid { display:grid; grid-template-columns: repeat(12, 1fr); gap: var(--s-4); }
.cat { position:relative; border-radius:var(--r-lg); overflow:hidden; background:var(--ink-800); color:#fff; min-height:280px; display:flex; align-items:flex-end; isolation:isolate; }
.cat img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition: transform var(--dur-3) var(--ease-out); }
.cat::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, rgba(15,17,21,.05) 35%, rgba(15,17,21,.85) 100%); }
.cat:hover img { transform: scale(1.05); }
.cat__body { padding: var(--s-5); width:100%; display:flex; justify-content:space-between; align-items:flex-end; }
.cat__name { font-family:var(--font-display); font-weight:600; font-size:clamp(1.05rem, 1.5vw, 1.35rem); text-transform:uppercase; letter-spacing:-0.01em; }
.cat__count { font-size:var(--t-xs); color:rgba(255,255,255,.7); }
.cat__go { width:40px; height:40px; border-radius:var(--r-pill); background:rgba(255,255,255,.16); display:grid; place-items:center; transition: background var(--dur-1); }
.cat:hover .cat__go { background: var(--pulse); }
.cat--xl { grid-column: span 6; min-height: 380px; }
.cat--md { grid-column: span 3; }
.cat--sm { grid-column: span 4; }

/* =========================== PRODUCT CARDS =========================== */
.products { display:grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
/* Подборки товаров — слайдер со стрелками */
.prod-slider { position:relative; }
.prod-slider .products { display:flex; grid-template-columns:none; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none; padding-bottom:.25rem; }
.prod-slider .products::-webkit-scrollbar { display:none; }
.prod-slider .pcard { flex:0 0 calc((100% - var(--s-5) * 3) / 4); scroll-snap-align:start; }
.prod-arrow { position:absolute; top:42%; transform:translateY(-50%); width:46px; height:46px; border-radius:var(--r-pill); background:var(--surface); border:1px solid var(--border-strong); color:var(--ink-900); display:grid; place-items:center; cursor:pointer; z-index:4; box-shadow:var(--sh-2); transition:color .15s, border-color .15s, opacity .15s; }
.prod-arrow:hover { color:var(--pulse); border-color:var(--pulse); }
.prod-arrow--prev { left:-16px; }
.prod-arrow--next { right:-16px; }
.prod-arrow[disabled] { opacity:.3; cursor:default; pointer-events:none; }
@media (max-width:980px){ .prod-slider .pcard { flex:0 0 calc((100% - var(--s-5)) / 2); } }
@media (max-width:760px){ .prod-slider .pcard { flex:0 0 86%; } .prod-arrow { display:none; } }
/* Цена в плитке категории */
.cat__price { font-size:var(--t-xs); font-weight:400; color:rgba(255,255,255,.82); margin-top:.15rem; }
.pcard { background: var(--surface); border:1px solid var(--border); border-radius: var(--r-lg); overflow:hidden; display:flex; flex-direction:column; transition: box-shadow var(--dur-2) var(--ease), transform var(--dur-2) var(--ease), border-color var(--dur-2); }
.pcard:hover { box-shadow: var(--sh-3); transform: translateY(-4px); border-color: var(--border-strong); }
.pcard__media { position:relative; aspect-ratio: 4/3; background: var(--n-100); overflow:hidden; }
.pcard__media-link { position:absolute; inset:0; z-index:2; }
.pcard__slider { position:absolute; inset:0; display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none; scroll-behavior:smooth; }
.pcard__slider::-webkit-scrollbar { display:none; }
.pcard__slider img { flex:0 0 100%; width:100%; height:100%; object-fit:cover; scroll-snap-align:center; }
.pcard__dots { position:absolute; left:0; right:0; bottom:10px; display:flex; gap:6px; justify-content:center; z-index:3; }
.pcard__dots span { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.55); cursor:pointer; transition:width .2s, background .2s; box-shadow:0 0 3px rgba(0,0,0,.3); }
.pcard__dots span.is-active { background:#fff; width:18px; border-radius:4px; }
/* стрелки прокрутки фото */
.pcard__nav { position:absolute; top:45%; transform:translateY(-50%); width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.92); border:1px solid var(--border); display:grid; place-items:center; color:var(--ink-900); z-index:3; opacity:0; transition:opacity .2s, background .2s, color .2s; box-shadow:0 2px 8px rgba(0,0,0,.12); }
.pcard__nav--prev { left:10px; } .pcard__nav--next { right:10px; }
.pcard:hover .pcard__nav { opacity:1; }
.pcard__nav:hover { background:#fff; color:var(--pulse); }
@media (hover:none){ .pcard__nav { opacity:.9; } }
/* плашки-новинки */
.badge--leader { background: var(--ink-900); color:#fff; }
.badge--rec { background: var(--pulse-tint); color: var(--pulse-700); }
.badge--choice { background: var(--info); color:#fff; }
/* 5 кратких характеристик */
.pcard__specs5 { display:flex; flex-wrap:wrap; gap:.28rem .3rem; align-content:flex-start; height:4.7rem; overflow:hidden; }
.pcard__specs5 li { font-size:.72rem; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-sm); padding:.15rem .42rem; color:var(--text-soft); line-height:1.25; }
.pcard__badges { display:flex; flex-wrap:wrap; gap:.35rem; min-height:1.55rem; align-content:flex-start; }
.pcard__flags { position:absolute; top: var(--s-3); left: var(--s-3); display:flex; gap:.4rem; z-index:4; flex-wrap:wrap; max-width:80%; }
.pcard__fav { position:absolute; top: var(--s-3); right: var(--s-3); width:27px; height:27px; border-radius:var(--r-pill); background:#fff; border:1px solid var(--border); display:grid; place-items:center; color:var(--n-500); z-index:4; }
.pcard__fav:hover { color: var(--pulse); border-color: var(--pulse); }
/* кнопка «в сравнение» — под «избранным» */
.pcard__cmp { position:absolute; top: var(--s-3); right: calc(var(--s-3) + 32px); width:27px; height:27px; border-radius:var(--r-pill); background:#fff; border:1px solid var(--border); display:grid; place-items:center; color:var(--n-500); z-index:4; transition:color var(--dur-1), background var(--dur-1), border-color var(--dur-1); }
.pcard__cmp:hover { color: var(--info); border-color: var(--info); }
.pcard__cmp.is-active { background: var(--info); border-color: var(--info); color:#fff; }
/* иконки мельче + аккуратный фокус без «двойного кружка» */
.pcard__fav svg, .pcard__cmp svg { width:15px; height:15px; }
.pcard__fav:focus-visible, .pcard__cmp:focus-visible { outline:2px solid currentColor; outline-offset:-2px; }

/* тост «добавлено к сравнению» */
.cmp-toast { position:fixed; left:50%; bottom:24px; transform:translateX(-50%) translateY(18px); z-index:80; display:flex; align-items:center; gap:.9rem; max-width:calc(100vw - 32px); background:var(--ink-900); color:#fff; border-radius:var(--r-lg); box-shadow:0 16px 44px rgba(0,0,0,.34); padding:.7rem .8rem .7rem 1rem; opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; }
.cmp-toast.show { opacity:1; transform:translateX(-50%); pointer-events:auto; }
.cmp-toast__ic { width:36px; height:36px; border-radius:50%; background:rgba(45,107,216,.22); color:#7fb0ff; display:grid; place-items:center; flex:none; }
.cmp-toast__txt b { font-family:var(--font-display); font-weight:600; font-size:var(--t-sm); display:block; line-height:1.2; }
.cmp-toast__sub { font-size:var(--t-xs); color:rgba(255,255,255,.6); }
.cmp-toast__open { background:var(--info); color:#fff; border-radius:var(--r-pill); padding:.5rem 1rem; font-size:var(--t-sm); font-weight:600; white-space:nowrap; }
.cmp-toast__open:hover { background:#2356b3; }
.cmp-toast__x { background:none; border:0; color:rgba(255,255,255,.55); font-size:1rem; cursor:pointer; padding:.2rem .3rem; line-height:1; }
.cmp-toast__x:hover { color:#fff; }
@media (max-width:560px){ .cmp-toast { left:16px; right:16px; transform:translateY(18px); } .cmp-toast.show { transform:none; } }
.pcard__body { padding: var(--s-3) var(--s-4) var(--s-4); display:flex; flex-direction:column; gap:.45rem; flex:1; }
.pcard__cat { font-size:var(--t-xs); color:var(--text-muted); text-transform:uppercase; letter-spacing:.08em; }
.pcard__name { font-weight:600; font-size:var(--t-base); line-height:1.25; min-height:2.5em; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.pcard__name:hover { color: var(--pulse-600); }
.pcard__specs { display:flex; gap:var(--s-4); font-size:var(--t-sm); color:var(--text-soft); flex-wrap:wrap; }
.pcard__specs span { display:inline-flex; align-items:center; gap:.3rem; }
.rating { display:flex; align-items:center; gap:.3rem; font-size:var(--t-xs); color:var(--text-soft); white-space:nowrap; }
.stars { color: var(--warning); letter-spacing:0; font-size:.92em; }
.pcard__foot { margin-top:auto; display:flex; align-items:flex-end; justify-content:space-between; gap:var(--s-4); padding-top: var(--s-3); border-top:1px solid var(--border); }
.price { display:flex; flex-direction:column; min-width:0; }
.price .now { font-family:var(--font-display); font-weight:600; font-size:clamp(1.02rem, 1.5vw, 1.2rem); white-space:nowrap; }
.price .old { font-size:var(--t-sm); color:var(--text-muted); text-decoration:line-through; white-space:nowrap; min-height:1.15em; line-height:1.15; }
.price .mo { font-size:var(--t-xs); color:var(--success); font-weight:600; white-space:nowrap; }
.pcard__foot { gap:var(--s-4); }
.btn-cart { width:44px; height:44px; flex:none; align-self:flex-end; margin-bottom:2px; border-radius:var(--r-md); background:var(--ink-900); color:#fff; display:grid; place-items:center; transition: background var(--dur-1); }
.btn-cart:hover { background: var(--pulse); }

/* =========================== ПОИСК (оверлей) =========================== */
.search-ov { position:fixed; inset:0; z-index:300; display:none; }
.search-ov.is-open { display:block; }
.search-ov__backdrop { position:absolute; inset:0; background:rgba(15,17,21,.45); }
.search-ov__panel { position:relative; background:var(--surface); box-shadow:var(--sh-3); max-height:90vh; display:flex; flex-direction:column; animation:searchDown .22s var(--ease-out); }
@keyframes searchDown { from { transform:translateY(-22px); opacity:0; } to { transform:none; opacity:1; } }
.search-ov__bar { display:flex; align-items:center; gap:.9rem; padding:1.05rem 0; border-bottom:1px solid var(--border); }
.search-ov__bar .ic { color:var(--text-muted); flex:none; display:inline-flex; }
.search-ov__bar input { flex:1; min-width:0; border:0; outline:0; background:transparent; font-family:var(--font-display); font-weight:600; font-size:clamp(1.05rem,2.4vw,1.4rem); color:var(--ink-900); }
.search-ov__bar input::placeholder { color:var(--text-muted); font-weight:500; }
.search-ov__close { width:40px; height:40px; border-radius:var(--r-pill); border:1px solid var(--border); background:var(--surface); cursor:pointer; display:grid; place-items:center; color:var(--text-soft); flex:none; transition:color var(--dur-1), border-color var(--dur-1); }
.search-ov__close:hover { color:var(--pulse); border-color:var(--pulse); }
.search-ov__body { overflow-y:auto; padding:var(--s-5) 0 var(--s-6); }
.search-sec { margin-bottom:var(--s-5); }
.search-sec:last-child { margin-bottom:0; }
.search-sec h5 { font-size:var(--t-xs); letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); margin:0 0 .8rem; }
.search-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.search-chip { padding:.45rem .9rem; border:1px solid var(--border-strong); border-radius:var(--r-pill); background:var(--surface); font:inherit; font-size:var(--t-sm); color:var(--text); cursor:pointer; transition:all var(--dur-1); }
.search-chip:hover { border-color:var(--ink-900); background:var(--ink-900); color:#fff; }
.search-cats { display:flex; flex-wrap:wrap; gap:.5rem; }
.search-cat { padding:.5rem .9rem; border-radius:var(--r-md); background:var(--surface-2); border:1px solid var(--border); font-size:var(--t-sm); color:var(--text); }
.search-cat:hover { color:var(--pulse); border-color:var(--pulse); }
.search-res { display:flex; flex-direction:column; gap:.15rem; }
.search-res__i { display:flex; gap:.9rem; align-items:center; padding:.55rem .55rem; border-radius:var(--r-md); }
.search-res__i:hover { background:var(--surface-2); }
.search-res__i img { width:56px; height:44px; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--border); flex:none; background:#fff; }
.search-res__t { min-width:0; }
.search-res__cat { font-size:var(--t-xs); color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; }
.search-res__nm { font-weight:600; color:var(--ink-900); }
.search-res__nm b { color:var(--pulse); }
.search-res__price { margin-left:auto; font-family:var(--font-display); font-weight:700; white-space:nowrap; padding-left:.6rem; }
.search-all { display:inline-flex; gap:.4rem; align-items:center; color:var(--pulse); font-weight:600; font-size:var(--t-sm); margin-top:.7rem; }
.search-all:hover { gap:.6rem; }
.search-empty { color:var(--text-muted); margin-bottom:var(--s-4); }
.search-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:var(--s-6); }
.search-art { display:flex; flex-direction:column; gap:.15rem; }
.search-art__i { display:flex; gap:.7rem; align-items:center; padding:.5rem .55rem; border-radius:var(--r-md); }
.search-art__i:hover { background:var(--surface-2); }
.search-art__ic { width:34px; height:34px; border-radius:var(--r-sm); background:var(--surface-2); color:var(--text-soft); display:grid; place-items:center; flex:none; }
.search-art__tag { font-size:var(--t-xs); text-transform:uppercase; letter-spacing:.06em; color:var(--pulse); font-weight:700; }
.search-art__t { font-weight:500; color:var(--ink-900); line-height:1.3; }
.search-art__t b { color:var(--pulse); }
@media (max-width:760px){ .search-grid2 { grid-template-columns:1fr; gap:var(--s-5); } }

/* =========================== ИЗБРАННОЕ (drawer) =========================== */
.fav-ov { position:fixed; inset:0; z-index:300; display:none; }
.fav-ov.is-open { display:block; }
.fav-ov__backdrop { position:absolute; inset:0; background:rgba(15,17,21,.45); }
.fav-ov__panel { position:absolute; top:0; right:0; bottom:0; width:420px; max-width:92vw; background:var(--surface); display:flex; flex-direction:column; box-shadow:var(--sh-3); animation:favIn .25s var(--ease-out); }
@keyframes favIn { from { transform:translateX(100%); } to { transform:none; } }
.fav-ov__head { display:flex; align-items:center; justify-content:space-between; padding:var(--s-4) var(--s-5); border-bottom:1px solid var(--border); }
.fav-ov__head b { font-family:var(--font-display); font-size:1.2rem; }
.fav-ov__head b span { color:var(--text-muted); font-weight:500; font-size:var(--t-sm); }
.fav-ov__close { width:38px; height:38px; border-radius:var(--r-pill); border:1px solid var(--border); background:var(--surface); cursor:pointer; display:grid; place-items:center; color:var(--text-soft); }
.fav-ov__close:hover { color:var(--pulse); border-color:var(--pulse); }
.fav-ov__body { flex:1; overflow-y:auto; padding:var(--s-3) var(--s-4); }
.fav-item { display:flex; gap:.8rem; align-items:center; padding:.7rem .4rem; border-bottom:1px solid var(--border); }
.fav-item:last-child { border-bottom:0; }
.fav-item img { width:64px; height:50px; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--border); flex:none; background:#fff; }
.fav-item__t { min-width:0; flex:1; }
.fav-item__cat { font-size:var(--t-xs); color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; }
.fav-item__nm { font-weight:600; color:var(--ink-900); display:block; }
.fav-item__nm:hover { color:var(--pulse-600); }
.fav-item__p { font-family:var(--font-display); font-weight:700; margin-top:.15rem; }
.fav-item__act { display:flex; flex-direction:column; gap:.4rem; flex:none; }
.fav-item__cart, .fav-item__rm { width:34px; height:34px; border-radius:var(--r-md); border:1px solid var(--border-strong); background:var(--surface); cursor:pointer; display:grid; place-items:center; color:var(--text-soft); }
.fav-item__cart:hover { background:var(--ink-900); color:#fff; border-color:var(--ink-900); }
.fav-item__rm:hover { color:var(--pulse); border-color:var(--pulse); }
.fav-ov__foot { padding:var(--s-4) var(--s-5); border-top:1px solid var(--border); }
.fav-empty { text-align:center; padding:var(--s-8) var(--s-4); display:flex; flex-direction:column; align-items:center; gap:var(--s-3); }
.fav-empty p { color:var(--text-muted); }
@media (max-width:560px){ .fav-ov__panel { width:100%; } }

/* =========================== PRODUCT TABS =========================== */
.prod-tabs { display:flex; gap:.4rem; background:var(--white); border:1px solid var(--border); border-radius:var(--r-pill); padding:.3rem; flex-wrap:wrap; }
.ptab { padding:.55rem 1.1rem; border-radius:var(--r-pill); border:0; background:transparent; font-weight:600; font-size:var(--t-sm); color:var(--text-soft); transition: background var(--dur-1), color var(--dur-1); }
.ptab:hover { color:var(--text); }
.ptab.is-active { background:var(--ink-900); color:#fff; }

/* =========================== NEWS =========================== */
.news { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-5); }
/* Новости — слайдер со стрелками */
.news-slider { position:relative; }
.news-slider .news { display:flex; grid-template-columns:none; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none; padding-bottom:.25rem; }
.news-slider .news::-webkit-scrollbar { display:none; }
.news-slider .ncard { flex:0 0 calc((100% - var(--s-5) * 2) / 3); scroll-snap-align:start; }
.news-arrow { position:absolute; top:38%; transform:translateY(-50%); width:46px; height:46px; border-radius:var(--r-pill); background:var(--surface); border:1px solid var(--border-strong); color:var(--ink-900); display:grid; place-items:center; cursor:pointer; z-index:4; box-shadow:var(--sh-2); transition:color .15s, border-color .15s, opacity .15s; }
.news-arrow:hover { color:var(--pulse); border-color:var(--pulse); }
.news-arrow--prev { left:-16px; }
.news-arrow--next { right:-16px; }
.news-arrow[disabled] { opacity:.3; cursor:default; pointer-events:none; }
@media (max-width:980px){ .news-slider .ncard { flex:0 0 calc((100% - var(--s-5)) / 2); } }
@media (max-width:760px){ .news-slider .ncard { flex:0 0 86%; } .news-arrow { display:none; } }
.ncard { display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; transition: box-shadow var(--dur-2) var(--ease), transform var(--dur-2) var(--ease); }
.ncard:hover { box-shadow:var(--sh-3); transform:translateY(-4px); }
.ncard__media { aspect-ratio:16/10; overflow:hidden; }
.ncard__media img { width:100%; height:100%; object-fit:cover; }
.ncard__body { padding:var(--s-4) var(--s-5) var(--s-5); display:flex; flex-direction:column; gap:.5rem; }
.ncard__meta { display:flex; align-items:center; gap:.7rem; font-size:var(--t-xs); color:var(--text-muted); }
.ncard__tag { background:var(--pulse-tint); color:var(--pulse-700); font-weight:600; text-transform:uppercase; letter-spacing:.04em; padding:.2rem .55rem; border-radius:var(--r-sm); }
.ncard__title { font-size:var(--t-lg); font-weight:600; line-height:1.3; }
.ncard:hover .ncard__title { color:var(--pulse-600); }
.ncard__body p { font-size:var(--t-sm); color:var(--text-soft); }

@media (max-width:860px){ .news { grid-template-columns:1fr; } }

/* =========================== USP / TRUST =========================== */
.usp { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--s-5); }
.usp__item { display:flex; gap:var(--s-3); align-items:flex-start; }
.usp__ic { flex:none; width:56px; height:56px; border-radius:50%; background:var(--pulse); color:#fff; display:grid; place-items:center; box-shadow:0 6px 16px rgba(211,55,49,.28); }
.usp__item h4 { font-size:var(--t-base); font-weight:600; }
.usp__item p { font-size:var(--t-sm); color:var(--text-soft); }

/* Editorial split */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,4vw,4rem); align-items:center; }
.split__media img { border-radius: var(--r-lg); width:100%; aspect-ratio: 3/4; object-fit:cover; }
.split--dark { background:var(--ink-900); color:var(--on-ink); border-radius:var(--r-xl); padding: clamp(2rem,5vw,4rem); }
.split--dark .lead { color: var(--on-ink-soft); }
.split__media--cta img { aspect-ratio: 5/4; box-shadow: var(--sh-2); }
@media (max-width:760px){ .split__media--cta { order:-1; } .split__media--cta img { aspect-ratio:16/10; } }

/* Logos / reviews */
.reviews { display:grid; grid-template-columns: repeat(3,1fr); gap:var(--s-5); }
.review { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:var(--s-5); }
/* Reviews carousel (homepage) */
.reviews-slider { position:relative; }
.reviews-slider .reviews { display:flex; grid-template-columns:none; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none; padding-bottom:.25rem; }
.reviews-slider .reviews::-webkit-scrollbar { display:none; }
.reviews-slider .review { flex:0 0 calc((100% - var(--s-5) * 2) / 3); scroll-snap-align:start; }
.reviews-arrow { position:absolute; top:50%; transform:translateY(-50%); width:46px; height:46px; border-radius:var(--r-pill); background:var(--surface); border:1px solid var(--border-strong); color:var(--ink-900); display:grid; place-items:center; cursor:pointer; z-index:4; box-shadow:var(--sh-2); transition:color .15s, border-color .15s, opacity .15s; }
.reviews-arrow:hover { color:var(--pulse); border-color:var(--pulse); }
.reviews-arrow--prev { left:-16px; }
.reviews-arrow--next { right:-16px; }
.reviews-arrow[disabled] { opacity:.32; cursor:default; pointer-events:none; }
@media (max-width:760px){ .reviews-slider .review { flex:0 0 86%; } .reviews-arrow { display:none; } }
.review p { font-size:var(--t-base); }
.review__who { margin-top:var(--s-4); display:flex; align-items:center; gap:.6rem; font-size:var(--t-sm); }
.review__who .av { width:38px; height:38px; border-radius:var(--r-pill); background:var(--ink-700); color:#fff; display:grid; place-items:center; font-weight:600; }

/* =========================== FOOTER =========================== */
.footer { background: var(--ink-900); color: var(--on-ink-soft); padding-block: var(--s-8) var(--s-6); margin-top: var(--s-7); }
.footer__top { display:grid; grid-template-columns: 1.6fr repeat(3,1fr); gap: var(--s-6); padding-bottom: var(--s-7); border-bottom:1px solid var(--ink-700); }
.footer h5 { color:#fff; font-size:var(--t-sm); text-transform:uppercase; letter-spacing:.1em; margin-bottom:var(--s-4); }
.footer a { display:block; padding:.3rem 0; font-size:var(--t-sm); }
.footer a:hover { color:#fff; }
.footer__brand .brand { color:#fff; margin-bottom:var(--s-3); }
.footer__bottom { display:flex; justify-content:space-between; gap:1rem; padding-top:var(--s-5); font-size:var(--t-xs); flex-wrap:wrap; }
.footer__bottom a { text-decoration:underline; text-underline-offset:2px; }
.footer__bottom span { white-space:nowrap; }
.footer__dealer { display:block; color:var(--on-ink-soft); opacity:.65; margin-top:.25rem; }
.footer__legal { display:flex; flex-direction:column; align-items:flex-end; }
.footer__legal a { padding-block:.3rem; font-size:var(--t-sm); }
.footer__bottom a:hover { color:#fff; }
.footer__social { margin-top:1rem; display:flex; gap:.6rem; }
.footer__social a { width:40px; height:40px; border-radius:var(--r-pill); border:1px solid var(--ink-700); display:grid; place-items:center; color:#cfcdc8; transition: background var(--dur-1), border-color var(--dur-1), color var(--dur-1); }
.footer__social a:hover { background:var(--pulse); border-color:var(--pulse); color:#fff; }

/* ---- Cookie banner ---- */
.cookie { position:fixed; left:50%; bottom:18px; transform:translateX(-50%); z-index:300; width:min(680px, calc(100% - 2rem));
  display:flex; align-items:center; gap:1rem; padding:.9rem 1.1rem; background:var(--ink-900); color:var(--on-ink);
  border-radius:var(--r-lg); box-shadow:var(--sh-3); font-size:var(--t-sm); }
.cookie p { flex:1; color:var(--on-ink-soft); }
.cookie a { color:#fff; text-decoration:underline; }
.cookie.hide { display:none; }

/* Попап определения города + модалка выбора */
.geo { position:fixed; left:18px; bottom:18px; z-index:280; background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-3); padding:1rem 1.1rem; width:min(330px, calc(100% - 2rem)); }
.geo[hidden] { display:none; }
.geo p { font-size:var(--t-sm); margin-bottom:.8rem; display:flex; gap:.4rem; align-items:center; }
.geo p svg { color:var(--pulse); flex:none; }
.geo__btns { display:flex; gap:1rem; align-items:center; }
.geo__pick { background:none; border:0; color:var(--pulse); font-weight:600; cursor:pointer; font:inherit; padding:0; }
.geo__pick:hover { color:var(--pulse-600); }
.geomodal { position:fixed; inset:0; z-index:320; background:rgba(15,17,21,.5); display:grid; place-items:center; padding:1rem; }
.geomodal[hidden] { display:none; }
.geomodal__box { background:#fff; border-radius:var(--r-lg); width:min(420px,100%); max-height:82vh; display:flex; flex-direction:column; padding:1.4rem; position:relative; }
.geomodal__close { position:absolute; top:1rem; right:1rem; background:none; border:0; font-size:1.3rem; line-height:1; cursor:pointer; color:var(--text-muted); }
.geomodal__close:hover { color:var(--ink-900); }
.geomodal h3 { font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:1.15rem; margin-bottom:1rem; }
.geomodal__search { display:flex; align-items:center; gap:.5rem; padding:.55rem .7rem; border:1px solid var(--border-strong); border-radius:var(--r-sm); color:var(--text-muted); margin-bottom:.6rem; }
.geomodal__search input { border:0; outline:0; width:100%; font:inherit; font-size:var(--t-sm); color:var(--text); background:transparent; }
.geomodal__list { overflow-y:auto; display:flex; flex-direction:column; }
.geomodal__opt { text-align:left; background:none; border:0; padding:.55rem .6rem; border-radius:var(--r-sm); font-size:var(--t-sm); cursor:pointer; color:var(--text); }
.geomodal__opt:hover { background:var(--surface-2); }
.geomodal__empty { padding:.8rem; font-size:var(--t-sm); color:var(--text-muted); text-align:center; }
@media (max-width:540px){ .cookie { flex-direction:column; align-items:stretch; text-align:center; } }

/* =========================== CATALOG PAGE =========================== */
.crumbs { font-size:var(--t-sm); color:var(--text-muted); padding-block: var(--s-5) 0; }
.crumbs a:hover { color:var(--pulse-600); }

/* ---- Заглушка раздела (контент зальём позже) ---- */
.stub { max-width:760px; margin:var(--s-5) auto var(--s-6); text-align:center; border:1px solid var(--border); border-radius:var(--r-xl); background:var(--surface); padding:var(--s-8) var(--s-6); }
.stub__tag { display:inline-block; font-size:var(--t-xs); font-weight:600; letter-spacing:var(--ls-caps); text-transform:uppercase; color:var(--pulse-600); background:var(--pulse-tint); padding:.3rem .75rem; border-radius:var(--r-pill); margin-bottom:var(--s-4); }
.stub__ic { width:72px; height:72px; border-radius:50%; background:var(--surface-2); color:var(--n-600); display:grid; place-items:center; margin:0 auto var(--s-4); }
.stub h2 { font-family:var(--font-display); font-weight:600; font-size:var(--t-h3); text-transform:uppercase; letter-spacing:.01em; margin-bottom:var(--s-3); }
.stub p { color:var(--text-soft); max-width:50ch; margin:0 auto var(--s-5); line-height:1.6; }
.stub__actions { display:flex; gap:.7rem; justify-content:center; flex-wrap:wrap; }
.stub-skel { max-width:760px; margin:0 auto var(--s-9); display:grid; gap:var(--s-3); }
.stub-skel i { height:13px; border-radius:var(--r-pill); background:var(--surface-2); display:block; }
.stub-skel i:nth-child(1){ width:100%; } .stub-skel i:nth-child(2){ width:94%; } .stub-skel i:nth-child(3){ width:80%; } .stub-skel i:nth-child(4){ width:88%; }

/* ---- Футер: подписка / соцсети / оплата ---- */
.footer__news { border-bottom:1px solid rgba(255,255,255,.1); padding-block: var(--s-6); margin-bottom: var(--s-2); }
.footer__news-in { display:grid; grid-template-columns:1.1fr 1fr; gap:var(--s-7); align-items:center; }
.footer__news h3 { font-family:var(--font-display); font-weight:600; font-size:clamp(1.25rem,2.1vw,1.65rem); text-transform:uppercase; letter-spacing:.01em; color:#fff; }
.footer__news p { color:var(--on-ink-soft); font-size:var(--t-sm); margin-top:.4rem; }
.subscribe { display:flex; gap:.6rem; }
.subscribe input { flex:1; min-width:0; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.22); border-radius:var(--r-pill); padding:.85rem 1.2rem; color:#fff; font:inherit; }
.subscribe input::placeholder { color:rgba(255,255,255,.45); }
.subscribe input:focus { outline:none; border-color:var(--pulse); box-shadow:0 0 0 3px rgba(211,55,49,.25); }
.subscribe .btn { white-space:nowrap; border-radius:var(--r-pill); gap:.5rem; }
@media (max-width:760px){ .footer__news-in { grid-template-columns:1fr; gap:var(--s-4); } }

.soc-round { display:flex; gap:.6rem; }
.soc-round a { width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); color:#fff; display:grid; place-items:center; transition:transform var(--dur-1), background var(--dur-1), border-color var(--dur-1); }
.soc-round a:hover { background:var(--pulse); border-color:var(--pulse); color:#fff; transform:translateY(-2px); }

.pay-row { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.pay-badge { height:30px; min-width:50px; padding:0 .6rem; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.18); border-radius:6px; display:inline-flex; align-items:center; justify-content:center; }
.pay-badge .visa { font-family:Arial,sans-serif; font-style:italic; font-weight:800; font-size:14px; color:rgba(255,255,255,.92); letter-spacing:.5px; }
.pay-badge .mir { font-family:Arial,sans-serif; font-style:italic; font-weight:800; font-size:14px; color:rgba(255,255,255,.92); }
.pay-badge .mc { position:relative; width:36px; height:22px; }
.pay-badge .mc i { position:absolute; top:0; width:22px; height:22px; border-radius:50%; }
.pay-badge .mc i:first-child { left:0; background:rgba(255,255,255,.9); }
.pay-badge .mc i:last-child { right:0; background:rgba(255,255,255,.45); }

/* ---- Чат-таб + лаунчер (онлайн-чат Jivo + мессенджеры) ---- */
.chat-tab { position:fixed; right:0; top:46%; transform:translateY(-50%); z-index:60; background:var(--pulse); color:#fff; writing-mode:vertical-rl; padding:1.1rem .55rem; border-radius:14px 0 0 14px; font-weight:600; font-size:.85rem; box-shadow:-6px 6px 22px rgba(0,0,0,.3); cursor:pointer; display:flex; align-items:center; gap:.55rem; transition:background var(--dur-1); border:0; font-family:inherit; }
.chat-tab:hover { background:var(--pulse-600); }
.chat-tab .dot { width:9px; height:9px; border-radius:50%; background:#46d369; box-shadow:0 0 0 3px rgba(70,211,105,.3); }
.chat-pop { position:fixed; right:18px; bottom:18px; z-index:61; width:300px; max-width:calc(100vw - 36px); background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:0 18px 50px rgba(15,17,21,.28); overflow:hidden; transform:translateY(12px) scale(.98); opacity:0; pointer-events:none; transition:opacity .18s, transform .18s; }
.chat-pop.open { opacity:1; transform:none; pointer-events:auto; }
.chat-pop__head { position:relative; background:var(--ink-900); color:#fff; padding:var(--s-4) var(--s-5); }
.chat-pop__head b { font-family:var(--font-display); font-weight:600; font-size:1.05rem; }
.chat-pop__head > span { display:block; font-size:var(--t-xs); color:rgba(255,255,255,.65); margin-top:.15rem; }
.chat-pop__close { position:absolute; top:10px; right:12px; background:none; border:0; color:rgba(255,255,255,.7); font-size:1.05rem; cursor:pointer; line-height:1; }
.chat-pop__body { padding:var(--s-3); display:flex; flex-direction:column; gap:.3rem; }
.chat-opt { display:flex; align-items:center; gap:.7rem; padding:.65rem .7rem; border-radius:var(--r-md); color:var(--text); transition:background var(--dur-1); }
.chat-opt:hover { background:var(--surface-2); }
.chat-opt__ic { width:38px; height:38px; border-radius:50%; display:grid; place-items:center; color:#fff; flex:none; }
.chat-opt b { font-size:var(--t-sm); display:block; line-height:1.2; }
.chat-opt > span:last-child > span { font-size:var(--t-xs); color:var(--text-muted); }
@media (max-width:560px){ .chat-tab { font-size:.78rem; padding:.9rem .5rem; } }
.catalog { display:grid; grid-template-columns: 264px 1fr; gap: var(--s-6); align-items:start; }
/* Быстрый подбор — табы-подборки над каталогом (редактируемый блок) */
.cat-presets { display:flex; align-items:center; gap:var(--s-4); margin-bottom:var(--s-5); background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:var(--s-3) var(--s-4); }
.cat-presets__label { font-size:var(--t-sm); font-weight:600; color:var(--text-soft); white-space:nowrap; flex:none; }
.cat-presets__row { display:flex; gap:.4rem; overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none; padding-bottom:2px; }
.cat-presets__row::-webkit-scrollbar { display:none; }
.cat-presets__row .ptab { white-space:nowrap; border:1px solid var(--border); background:var(--white); }
.cat-presets__row .ptab.is-active { background:var(--ink-900); color:#fff; border-color:var(--ink-900); }
@media (max-width:560px){ .cat-presets { flex-direction:column; align-items:stretch; gap:var(--s-2); } }
.filters { position:sticky; top:96px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:var(--s-5); }
.filters h4 { font-size:var(--t-sm); text-transform:uppercase; letter-spacing:.08em; margin-bottom:var(--s-3); }
.fgroup { padding-block: var(--s-4); border-top:1px solid var(--border); }
.fgroup:first-of-type { border-top:0; padding-top:0; }
.check { display:flex; align-items:center; gap:.6rem; padding:.35rem 0; font-size:var(--t-sm); color:var(--text-soft); }
.check input { width:18px; height:18px; accent-color: var(--pulse); }
.check .c { margin-left:auto; color:var(--text-muted); font-size:var(--t-xs); }
.range { display:flex; gap:.5rem; }
.range input { width:100%; padding:.5rem .6rem; border:1px solid var(--border-strong); border-radius:var(--r-sm); font-size:var(--t-sm); }
.catalog__toolbar { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:var(--s-5); flex-wrap:wrap; }
.chips { display:flex; gap:.5rem; flex-wrap:wrap; }
.chip { display:inline-flex; align-items:center; gap:.4rem; background:var(--white); border:1px solid var(--border-strong); border-radius:var(--r-pill); padding:.4rem .8rem; font-size:var(--t-sm); }
.chip button { border:0; background:transparent; color:var(--text-muted); }
.select { appearance:none; -webkit-appearance:none; -moz-appearance:none; padding:.55rem 2.1rem .55rem .95rem; border:1px solid var(--border-strong); border-radius:var(--r-pill); background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230F1115' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>") no-repeat right .75rem center; font:inherit; font-size:var(--t-sm); font-weight:600; color:var(--ink-900); cursor:pointer; transition:border-color .15s, box-shadow .15s; }
.select:hover { border-color:var(--ink-700); }
.select:focus { outline:0; border-color:var(--pulse); box-shadow:0 0 0 3px var(--pulse-tint); }

/* Ползунок диапазона цены */
.price-slider { position:relative; height:30px; margin-top:.7rem; }
.price-slider__track { position:absolute; top:50%; left:9px; right:9px; height:4px; transform:translateY(-50%); background:var(--border-strong); border-radius:3px; }
.price-slider__fill { position:absolute; height:100%; background:var(--pulse); border-radius:3px; }
.price-slider input[type=range] { position:absolute; top:0; left:0; width:100%; height:30px; margin:0; padding:0; background:none; pointer-events:none; -webkit-appearance:none; appearance:none; }
.price-slider input[type=range]::-webkit-slider-thumb { pointer-events:auto; -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:#fff; border:2px solid var(--pulse); cursor:pointer; box-shadow:var(--sh-2); }
.price-slider input[type=range]::-moz-range-thumb { pointer-events:auto; width:16px; height:16px; border-radius:50%; background:#fff; border:2px solid var(--pulse); cursor:pointer; }
.price-slider input[type=range]::-webkit-slider-runnable-track { background:none; border:0; }
.price-slider input[type=range]::-moz-range-track { background:none; }

/* Кастомный селект сортировки */
.sortsel { position:relative; }
.sortsel__btn { display:inline-flex; align-items:center; gap:.5rem; padding:.55rem .95rem; border:1px solid var(--border-strong); border-radius:var(--r-pill); background:#fff; font:inherit; font-size:var(--t-sm); font-weight:600; color:var(--ink-900); cursor:pointer; transition:border-color .15s, box-shadow .15s; white-space:nowrap; }
.sortsel__btn:hover { border-color:var(--ink-700); }
.sortsel.open .sortsel__btn { border-color:var(--pulse); box-shadow:0 0 0 3px var(--pulse-tint); }
.sortsel__btn svg { color:var(--text-muted); transition:transform .2s; }
.sortsel.open .sortsel__btn svg { transform:rotate(180deg); }
.sortsel__menu { position:absolute; top:calc(100% + 6px); right:0; min-width:210px; background:#fff; border:1px solid var(--border); border-radius:var(--r-md); box-shadow:var(--sh-3); padding:.35rem; z-index:60; display:none; }
.sortsel.open .sortsel__menu { display:block; }
.sortsel__opt { display:block; width:100%; text-align:left; background:none; border:0; padding:.55rem .7rem; border-radius:var(--r-sm); font-size:var(--t-sm); color:var(--text); cursor:pointer; }
.sortsel__opt:hover { background:var(--surface-2); }
.sortsel__opt.is-active { color:var(--pulse); font-weight:600; }
.catalog .products { grid-template-columns: repeat(3,1fr); }

/* =========================== PRODUCT PAGE =========================== */
.pdp { display:grid; grid-template-columns: 1.1fr 1fr; gap: clamp(1.5rem,4vw,3.5rem); align-items:start; }
.gallery { position:sticky; top:96px; }
.gallery__main { background:linear-gradient(160deg,#fff,var(--n-100)); border:1px solid var(--border); border-radius:var(--r-lg); aspect-ratio:1; display:grid; place-items:center; padding:var(--s-7); }
.gallery__main img { object-fit:contain; mix-blend-mode:multiply; }
.gallery__thumbs { display:flex; gap:var(--s-3); margin-top:var(--s-3); }
.thumb { width:78px; height:78px; border:1px solid var(--border); border-radius:var(--r-md); background:#fff; padding:.4rem; cursor:pointer; }
.thumb.is-active { border-color: var(--ink-900); }
.pdp__head h1 { font-family:var(--font-display); font-weight:700; font-size:var(--t-h1); text-transform:uppercase; line-height:1.05; }
.pdp__sku { font-size:var(--t-sm); color:var(--text-muted); }
.pdp__price { display:flex; align-items:baseline; gap:.8rem; margin:var(--s-4) 0; flex-wrap:wrap; }
.pdp__price .now { font-family:var(--font-display); font-size:2.5rem; font-weight:600; }
.pdp__price .old { font-size:var(--t-lg); color:var(--text-muted); text-decoration:line-through; }
.finance-box { background:var(--success-tint); border:1px solid #BCE3CC; border-radius:var(--r-md); padding:var(--s-4); display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-block:var(--s-4); }
.finance-box .mo { font-family:var(--font-display); font-size:1.5rem; color:var(--success); font-weight:600; }
.opt-row { margin-block:var(--s-4); }
.opt-row .lbl { font-size:var(--t-sm); font-weight:600; margin-bottom:.5rem; }
.swatches { display:flex; gap:.5rem; }
.swatch { padding:.55rem 1rem; border:1.5px solid var(--border-strong); border-radius:var(--r-sm); font-size:var(--t-sm); background:#fff; }
.swatch.is-active { border-color:var(--ink-900); background:var(--ink-900); color:#fff; }
.buy-row { display:flex; gap:var(--s-3); margin-block:var(--s-5); }
.buy-row .btn { flex:1; }
.assurances { display:grid; gap:.6rem; margin-top:var(--s-4); }
.assurances li { display:flex; gap:.6rem; align-items:flex-start; font-size:var(--t-sm); color:var(--text-soft); }
.assurances svg { color:var(--success); flex:none; margin-top:2px; }

/* Sticky tabs + rich content */
.pdp-tabs { position:sticky; top:72px; z-index:20; background:rgba(247,246,244,.92); backdrop-filter:blur(10px); border-block:1px solid var(--border); margin-top:var(--s-8); }
.pdp-tabs .container { display:flex; gap:var(--s-6); overflow-x:auto; }
.pdp-tabs a { padding:1rem 0; font-size:var(--t-sm); font-weight:600; color:var(--text-soft); border-bottom:2px solid transparent; white-space:nowrap; }
.pdp-tabs a.is-active, .pdp-tabs a:hover { color:var(--text); border-color:var(--pulse); }

.rich { max-width: 920px; }
.rich h2 { margin-bottom:var(--s-4); }
.rich__feature { display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3rem); align-items:center; margin-block:var(--s-7); }
.rich__feature:nth-child(even) .rich__feature-media { order:-1; }
.rich__feature img { border-radius:var(--r-lg); width:100%; aspect-ratio:4/3; object-fit:cover; }
.specs-table { width:100%; border-collapse:collapse; }
.specs-table tr { border-bottom:1px solid var(--border); }
.specs-table th { text-align:left; padding:.85rem 0; font-weight:600; width:45%; color:var(--text-soft); font-size:var(--t-sm); }
.specs-table td { padding:.85rem 0; }
.compare { width:100%; border-collapse:collapse; font-size:var(--t-sm); }
.compare th, .compare td { padding:.8rem 1rem; text-align:center; border:1px solid var(--border); }
.compare th { background:var(--surface-2); }
.compare td:first-child, .compare th:first-child { text-align:left; }
.compare .is-this { background:var(--pulse-tint); }

/* =========================== UTIL / RESPONSIVE =========================== */
.hide-mobile { } .show-mobile { display:none; }

@media (max-width: 1024px) {
  .products { grid-template-columns: repeat(3,1fr); }
  .catalog { grid-template-columns: 1fr; }
  .filters { position:static; }
  .pdp { grid-template-columns: 1fr; }
  .gallery { position:static; }
  .footer__top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .nav, .topbar { display:none; }
  .burger { display:grid; }
  .hero__media::after { background: linear-gradient(180deg, rgba(15,17,21,.55), rgba(15,17,21,.92)); }
  .products, .catalog .products { grid-template-columns: repeat(2,1fr); }
  .usp { grid-template-columns: 1fr 1fr; }
  .split, .rich__feature { grid-template-columns: 1fr; }
  .reviews { grid-template-columns:1fr; }
  .cat--xl, .cat--md, .cat--sm { grid-column: span 6; min-height:240px; }
}
@media (max-width: 540px) {
  .products, .catalog .products { grid-template-columns: 1fr 1fr; gap: var(--s-3); }
  .usp { grid-template-columns:1fr; }
  .cat--xl, .cat--md, .cat--sm { grid-column: span 12; }
  .hero__meta { gap: var(--s-5); }
  .buy-row { flex-direction:column; }
}
