/* ============================================================
   ЛЮМО Components
   ============================================================ */

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);
  font-family:var(--ff-heading);font-weight:var(--fw-semibold);font-size:var(--fs-base);
  padding:.75rem 1.75rem;border-radius:var(--r-btn);
  position:relative;overflow:hidden;
  transition:all var(--t-base) var(--ease-out);
  white-space:nowrap;user-select:none;
  letter-spacing:0;isolation:isolate;
}
.btn:hover{letter-spacing:.02em}
.btn:active{transform:scale(.97)}

/* Shine sweep overlay on hover */
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .7s var(--ease-out);
  pointer-events:none;
}
.btn:hover::before{transform:translateX(120%)}

.btn--primary{
  background:var(--accent-gradient);color:#fff;
  background-size:200% 100%;background-position:0% 50%;
  box-shadow:0 4px 16px rgba(109,20,24,.25),inset 0 1px 0 rgba(255,255,255,.15);
}
.btn--primary:hover{
  background-position:100% 50%;
  transform:translateY(-2px);
  box-shadow:0 10px 32px rgba(109,20,24,.45),0 0 0 3px var(--accent-soft),inset 0 1px 0 rgba(255,255,255,.2);
}
.btn--primary:active{transform:translateY(0);box-shadow:0 2px 8px rgba(109,20,24,.2)}

.btn--neu{
  box-shadow:var(--shadow-neu);
}
.btn--neu:hover{
  box-shadow:var(--shadow-neu-sm);transform:translate(2px,2px);
}
.btn--neu:active{box-shadow:none;transform:translate(4px,4px)}

.btn--secondary{
  background:var(--bg-card);color:var(--ink);
  border:1.5px solid var(--line-strong);
}
.btn--secondary::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,var(--accent-soft),transparent 60%);
  opacity:0;transition:opacity var(--t-base) var(--ease-out);
}
.btn--secondary:hover{
  border-color:var(--accent);color:var(--accent);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(109,20,24,.12);
}
.btn--secondary:hover::after{opacity:1}

.btn--ghost{
  background:transparent;color:var(--accent);
  padding:.65rem 1.25rem;
}
.btn--ghost:hover{background:var(--accent-soft)}

.btn--outline{
  background:transparent;color:var(--accent);
  border:1.5px solid var(--accent);
}
.btn--outline:hover{background:var(--accent);color:#fff}

.btn--sm{padding:.5rem 1rem;font-size:var(--fs-sm)}
.btn--lg{padding:1rem 2.25rem;font-size:var(--fs-lg)}
.btn--full{width:100%}
.btn--icon{padding:.65rem;border-radius:var(--r-squircle)}

.btn .icon{transition:transform var(--t-fast) var(--ease-out)}
.btn:hover .icon{transform:translateX(2px)}

/* Ripple */
.ripple{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.35);
  transform:scale(0);animation:ripple-anim .6s linear;
  pointer-events:none;
}
@keyframes ripple-anim{to{transform:scale(4);opacity:0}}

/* === PRODUCT CARD — Premium Concept === */
.product-card{
  position:relative;
  background:var(--bg-card);
  border-radius:22px;
  border:1px solid var(--line);
  transition:transform var(--t-slow) var(--ease-out),
             box-shadow var(--t-slow) var(--ease-out),
             border-color var(--t-slow) var(--ease-out);
  display:flex;flex-direction:column;
  overflow:hidden;isolation:isolate;
}
.product-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,transparent 0%,var(--accent-soft) 100%);
  opacity:0;transition:opacity var(--t-slow) var(--ease-out);
  pointer-events:none;z-index:0;
}
.product-card:hover{
  border-color:transparent;
  box-shadow:0 28px 64px rgba(20,20,20,.08),0 0 40px rgba(109,20,24,.08);
  transform:translateY(-8px);
  z-index:2;
}
.product-card:hover::before{opacity:.5}
.product-card:hover .product-card__img img{transform:scale(1.07) translateY(-4px)}

/* Badges — refined pill style in top-left */
.product-card__badges{
  position:absolute;top:12px;left:12px;
  display:flex;gap:6px;z-index:3;flex-wrap:wrap;
}
.product-card__badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--ff-heading);font-size:10px;font-weight:var(--fw-extrabold);
  padding:.25rem .55rem;color:#fff;
  text-transform:uppercase;letter-spacing:.06em;
  border-radius:var(--r-pill);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  line-height:1;
}
.product-card__badge--sale{background:linear-gradient(135deg,#d23a3a,#a91818)}
.product-card__badge--new{background:var(--accent-gradient);box-shadow:0 2px 8px rgba(109,20,24,.3)}
.product-card__badge--hit{background:linear-gradient(135deg,#ffb93d,#e88b00);color:#2a1800}

/* Quick actions — float on right, appear on hover */
.product-card__quick{
  position:absolute;top:12px;right:12px;
  display:flex;flex-direction:column;gap:6px;z-index:3;
  opacity:0;transform:translateX(6px);
  transition:opacity var(--t-base) var(--ease-out),transform var(--t-base) var(--ease-out);
}
.product-card:hover .product-card__quick{opacity:1;transform:translateX(0)}
.product-card__quick-btn{
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);
  border-radius:50%;
  transition:all var(--t-fast) var(--ease-out);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
}
.product-card__quick-btn .icon{width:16px;height:16px}
.product-card__quick-btn:hover{
  border-color:var(--accent);color:var(--accent);
  transform:scale(1.08);
  box-shadow:0 6px 16px rgba(109,20,24,.2);
}
.product-card__quick-btn.is-active{
  background:var(--accent-gradient);color:#fff;border-color:transparent;
  box-shadow:0 6px 16px rgba(109,20,24,.35);
}

/* Image area — larger, gradient backdrop, premium feel */
.product-card__img{
  position:relative;overflow:hidden;
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  padding:var(--space-5);
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.8), transparent 60%),
    linear-gradient(160deg,var(--bg-subtle) 0%,#fff 100%);
  z-index:1;
}
.product-card__img::after{
  content:"";position:absolute;left:15%;right:15%;bottom:12%;height:14px;
  background:radial-gradient(ellipse at center,rgba(20,20,20,.2),transparent 70%);
  filter:blur(8px);opacity:.5;
  transition:opacity var(--t-slow) var(--ease-out);
}
.product-card:hover .product-card__img::after{opacity:.8;transform:scaleX(.8)}
.product-card__img img{
  width:86%;height:86%;object-fit:contain;
  transition:transform var(--t-slow) var(--ease-out);
  position:relative;z-index:1;
}

/* Body — cleaner spacing */
.product-card__body{
  padding:var(--space-4) var(--space-4) var(--space-2);
  flex:1;display:flex;flex-direction:column;gap:var(--space-2);
  position:relative;z-index:1;
}
.product-card__title{
  font-family:var(--ff-heading);font-size:var(--fs-base);font-weight:var(--fw-bold);
  line-height:1.3;letter-spacing:-.01em;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:2.6em;color:var(--ink);
  transition:color var(--t-fast) var(--ease-out);
}
.product-card:hover .product-card__title{color:var(--accent)}

/* Specs — subtle pills */
.product-card__specs{
  display:flex;gap:6px;flex-wrap:wrap;
}
.product-card__spec{
  font-family:var(--ff-heading);font-size:11px;color:var(--muted);
  background:var(--bg-subtle);
  padding:.2rem .55rem;border-radius:var(--r-pill);
  font-weight:var(--fw-semibold);letter-spacing:.02em;
  border:1px solid transparent;
  transition:all var(--t-fast) var(--ease-out);
}
.product-card:hover .product-card__spec{border-color:var(--line)}
.product-card__color-dot{
  width:12px;height:12px;border-radius:50%;
  border:1.5px solid var(--line-strong);
  display:inline-block;vertical-align:middle;
  margin-right:var(--space-1);
}

/* Color chips — available colorways with tooltips */
.product-card__colors-label{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--ff-mono);
  font-size:10px;font-weight:var(--fw-bold);
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);
  margin:4px 0 2px;
  padding:0;
}
.product-card__colors-label-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 0 rgba(160,32,40,.45);
  animation:colors-label-ping 2.4s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes colors-label-ping{
  0%,100%{box-shadow:0 0 0 0 rgba(160,32,40,.45);transform:scale(1)}
  50%{box-shadow:0 0 0 5px rgba(160,32,40,0);transform:scale(1.2)}
}
.product-card__colors{
  display:flex;gap:8px;align-items:center;
  margin:2px 0 4px;
  flex-wrap:wrap;
}
.product-card__color{
  --c1:#bbb;--c2:#eee;
  position:relative;
  width:18px;height:18px;border-radius:50%;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.55) 0%,rgba(255,255,255,0) 35%),
    linear-gradient(135deg,var(--c1) 0%,var(--c2) 100%);
  border:1.5px solid rgba(255,255,255,.9);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.08),
    inset 0 -3px 5px rgba(0,0,0,.12),
    0 2px 4px rgba(0,0,0,.06);
  cursor:pointer;
  outline:none;
  flex-shrink:0;
  transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-fast) var(--ease-out);
}
.product-card__color:hover,
.product-card__color:focus-visible{
  transform:scale(1.2);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.1),
    inset 0 -3px 5px rgba(0,0,0,.14),
    0 4px 10px rgba(0,0,0,.12);
}
.product-card__color.is-active{
  box-shadow:
    0 0 0 2px #fff,
    0 0 0 3.5px var(--accent),
    inset 0 -3px 5px rgba(0,0,0,.12);
}
.product-card__color.is-active::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.55) 0%,rgba(255,255,255,0) 35%),
    linear-gradient(135deg,var(--c1) 0%,var(--c2) 100%);
}

/* Prices — stacked, cleaner hierarchy */
.product-card__prices{
  display:flex;flex-direction:column;gap:4px;
  margin-top:auto;padding-top:var(--space-2);
}
/* Old/MSRP price — "Старая цена: N ₽" — label non-struck, only the number crossed */
.price-old{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;color:var(--muted);
  font-family:var(--ff-body);font-weight:var(--fw-semibold);
  line-height:1.15;
  text-decoration:none;
}
.price-old__label{
  font-size:10px;font-weight:var(--fw-bold);
  color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
  background:var(--bg-subtle);border:1px solid var(--line);
  padding:2px 6px;border-radius:4px;
  text-decoration:none;
  flex-shrink:0;
}
.price-old__value{
  font-family:var(--ff-price);
  font-feature-settings:'tnum','lnum';font-weight:var(--fw-semibold);
  text-decoration:line-through;
  text-decoration-color:rgba(160,32,40,.65);
  text-decoration-thickness:1.5px;
  color:var(--muted);
}
.price-current{
  font-size:var(--fs-2xl);font-weight:var(--fw-extrabold);
  font-family:var(--ff-price);color:var(--ink);
  letter-spacing:-.03em;line-height:1.05;
  font-feature-settings:'tnum','lnum';
}
/* Price with warranty — BEST price tier (3rd, cheapest with LUMO warranty) */
.price-warranty{
  position:relative;
  display:flex;align-items:center;gap:8px;flex-wrap:nowrap;
  font-size:1.05rem;font-weight:var(--fw-extrabold);
  font-family:var(--ff-price);color:#fff;
  font-feature-settings:'tnum','lnum';
  background:linear-gradient(135deg,#6d1418 0%,#a02028 55%,#c83a40 100%);
  padding:.55rem .75rem;
  border-radius:var(--r-btn);
  border:none;
  margin-top:14px;
  cursor:help;
  mask:none;-webkit-mask:none;
  letter-spacing:-.02em;line-height:1.1;
  transition:all var(--t-base) var(--ease-out);
  box-shadow:0 6px 18px rgba(109,20,24,.28),inset 0 1px 0 rgba(255,255,255,.15);
  overflow:visible;
  min-width:0;
  min-height:42px;
}
.price-warranty > span:not(.price-warranty__label){
  flex:0 0 auto;
  min-width:0;
  white-space:nowrap;
  position:relative;z-index:1;
}
.price-warranty::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.18),transparent 50%);
  pointer-events:none;
  border-radius:inherit;
}
.price-warranty::after{
  content:"Лучшая цена";
  position:absolute;top:-9px;left:12px;
  z-index:3;
  font-family:var(--ff-body);font-size:9px;font-weight:var(--fw-extrabold);
  letter-spacing:.14em;text-transform:uppercase;
  color:#2a1010;
  background:linear-gradient(135deg,#ffd166,#f8a93a);
  padding:3px 8px;border-radius:var(--r-pill);
  box-shadow:0 4px 12px rgba(248,169,58,.45),0 0 0 2px #fff;
  line-height:1;
  animation:best-pop 3s ease-in-out infinite;
  white-space:nowrap;
}
@keyframes best-pop{
  0%,100%{transform:translateY(0) rotate(-3deg)}
  50%{transform:translateY(-2px) rotate(3deg)}
}
.price-warranty:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(109,20,24,.4),inset 0 1px 0 rgba(255,255,255,.2);
}
.price-warranty .icon{width:16px;height:16px;color:#fff;flex-shrink:0;position:relative;z-index:1}
.price-warranty__label{
  font-size:8.5px;font-family:var(--ff-body);font-weight:var(--fw-extrabold);
  color:var(--accent);margin-left:auto;
  text-transform:uppercase;letter-spacing:.06em;
  background:#fff;padding:.24rem .7rem;border-radius:10px;
  position:relative;z-index:1;
  box-shadow:0 2px 6px rgba(0,0,0,.15);
  flex:0 1 auto;
  min-width:min-content;
  max-width:20ch;
  line-height:1.2;
  text-align:center;
  white-space:normal;
  word-break:keep-all;
  overflow-wrap:normal;
  display:-webkit-box;
  -webkit-line-clamp:2;line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Actions — asymmetric diagonal pill (matches --r-btn shape) */
.product-card__actions{
  padding:var(--space-2) var(--space-4) var(--space-4);
  display:flex;gap:8px;align-items:stretch;
}
.product-card__actions .btn{
  font-size:13px;padding:.7rem .9rem;
  border-radius:var(--r-btn);
}
.product-card__actions .btn--primary{flex:1}
.product-card__actions .btn--secondary{flex:0 0 auto;padding:.7rem 1rem;border-radius:var(--r-btn-inverse)}

/* === CATEGORY CARD === */
.category-card{
  position:relative;
  background:var(--bg-card);
  border-radius:var(--r-card);
  border:1px solid var(--line);
  padding:var(--space-6) var(--space-5);
  text-align:center;
  transition:all var(--t-slow) var(--ease-out);
  cursor:pointer;
  overflow:hidden;
  min-height:220px;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
}
.category-card:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
  background:linear-gradient(180deg,var(--bg-card) 0%,var(--accent-soft) 100%);
  z-index:2;
}
.category-card::after{
  content:"";position:absolute;bottom:-20px;left:20%;right:20%;height:40px;
  background:var(--accent);filter:blur(30px);opacity:0;
  transition:opacity var(--t-slow) var(--ease-out);
  pointer-events:none;
}
.category-card:hover::after{opacity:.15}

.category-card__icon{
  width:80px;height:80px;
  margin:0 auto var(--space-4);
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-subtle);
  border-radius:var(--r-squircle);
  transition:background var(--t-base) var(--ease-out);
}
.category-card:hover .category-card__icon{background:var(--accent-soft)}
.category-card__icon .icon{width:40px;height:40px}

.category-card__img{
  width:120px;height:120px;
  object-fit:contain;
  margin:0 auto var(--space-3);
  transition:transform var(--t-slow) var(--ease-out);
  filter:drop-shadow(0 10px 24px rgba(20,20,20,.12));
}
.category-card:hover .category-card__img{transform:scale(1.08) translateY(-6px)}
.category-card__name{
  font-family:var(--ff-heading);font-size:var(--fs-lg);font-weight:var(--fw-bold);
  margin-bottom:var(--space-1);letter-spacing:-.01em;
}
.category-card__price{
  font-size:var(--fs-sm);color:var(--muted);
  font-family:var(--ff-heading);font-weight:var(--fw-medium);
  font-feature-settings:'tnum';
}

/* === HEADER === */
/* ─── Topbar: статус слева, маркетинг-лента в центре, контакты справа ─── */
.topbar{
  position:relative;
  font-size:var(--fs-xs);
  height:var(--topbar-h);
  display:flex;align-items:center;
  color:var(--ink-secondary);
  background:
    radial-gradient(60% 100% at 50% 0%, rgba(160,32,40,.05), transparent 70%),
    linear-gradient(90deg, #f3eeec 0%, #faf6f4 50%, #f3eeec 100%);
  border-bottom:1px solid var(--line);
  letter-spacing:.005em;
  isolation:isolate;
}
.topbar::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(109,20,24,.18) 30%, rgba(109,20,24,.18) 70%, transparent 100%);
  pointer-events:none;
}
.topbar__inner{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--space-6);
  width:100%;
}
.topbar__cluster{display:flex;align-items:center;gap:var(--space-3);min-width:0}
.topbar__cluster--left{justify-self:start}
.topbar__cluster--center{justify-self:center;min-width:0}
.topbar__cluster--right{justify-self:end;gap:var(--space-4)}
.topbar a{transition:color var(--t-fast) var(--ease-out)}
.topbar a:hover{color:var(--accent)}
.topbar .icon{width:13px;height:13px;stroke-width:2}

/* Status — pulse-точка + город + часы */
.topbar__status{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px 6px 8px;
  background:rgba(255,255,255,.7);
  border:1px solid var(--line);
  border-radius:var(--r-pill);
  font-weight:var(--fw-semibold);
  font-size:11.5px;letter-spacing:.01em;
  white-space:nowrap;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transition:background var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out);
}
.topbar__status:hover{background:#fff;border-color:var(--line-strong)}
.topbar__pulse{
  position:relative;width:8px;height:8px;border-radius:50%;
  background:#1A7D45;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(26,125,69,.5);
  animation:topbar-pulse 2.2s infinite cubic-bezier(.66,0,0,1);
}
.topbar__status.is-closed .topbar__pulse{
  background:var(--muted-light);
  animation:none;
}
@keyframes topbar-pulse{
  0%{box-shadow:0 0 0 0 rgba(26,125,69,.55)}
  70%{box-shadow:0 0 0 8px rgba(26,125,69,0)}
  100%{box-shadow:0 0 0 0 rgba(26,125,69,0)}
}
.topbar__status-icon{color:var(--accent)}
.topbar__status-city{font-weight:var(--fw-bold);color:var(--ink)}
.topbar__status-sep{color:var(--line-strong);font-weight:400;margin:0 -2px}
.topbar__status-hours{color:var(--muted)}

/* Маркетинг-лента — пилюли преимуществ */
.topbar__benefits{
  display:flex;align-items:center;gap:2px;
  list-style:none;
}
.topbar__benefit{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;
  font-size:11.5px;font-weight:var(--fw-semibold);
  color:var(--ink-secondary);
  letter-spacing:.005em;
  white-space:nowrap;
  position:relative;
  transition:color var(--t-fast) var(--ease-out);
}
.topbar__benefit::after{
  content:"";
  position:absolute;right:-1px;top:50%;transform:translateY(-50%);
  width:3px;height:3px;border-radius:50%;
  background:var(--line-strong);
}
.topbar__benefit:last-child::after{display:none}
.topbar__benefit .icon{color:var(--accent);width:13px;height:13px}
.topbar__benefit:hover{color:var(--ink)}

/* Контакты справа */
.topbar__phone{
  display:inline-flex;align-items:center;gap:7px;
  font-weight:var(--fw-bold);font-size:12px;color:var(--ink);
  letter-spacing:.01em;
  font-feature-settings:'tnum';
}
.topbar__phone .icon{color:var(--accent);width:13px;height:13px}
.topbar__phone:hover{color:var(--accent)}
.topbar__socials{
  display:inline-flex;align-items:center;gap:2px;
  padding:3px;
  background:rgba(255,255,255,.5);
  border:1px solid var(--line);
  border-radius:var(--r-pill);
}
.topbar__social{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;
  border-radius:50%;
  color:var(--ink-secondary);
  transition:background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-spring);
}
.topbar__social:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}
.topbar__social--avito{
  width:auto;padding:0 9px;height:24px;
  font-family:var(--ff-heading);font-size:9.5px;font-weight:var(--fw-extrabold);
  letter-spacing:.12em;
}
.topbar__social--avito:hover{background:#00aaff;color:#fff}

/* ─── Header (main row) ─── */
.header{
  position:sticky;top:0;z-index:var(--z-sticky);
  background:var(--bg-card);
  border-bottom:1px solid var(--line);
  transition:background var(--t-base) var(--ease-out),box-shadow var(--t-base) var(--ease-out);
}
.header.is-scrolled{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  box-shadow:0 2px 24px rgba(20,20,20,.06),0 1px 0 rgba(109,20,24,.08);
}

.header__inner{
  display:flex;align-items:center;gap:var(--space-6);
  height:var(--header-h);
}
.header__logo{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:var(--space-3);
}
.header__logo picture{display:inline-flex;align-items:center}
.header__logo img{height:60px;width:auto;transition:transform var(--t-base) var(--ease-out)}
.header__logo:hover img{transform:scale(1.04)}
.header__logo-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:3px 11px;
  font-family:var(--ff-heading);
  font-size:9.5px;font-weight:var(--fw-bold);
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-secondary);
  border-left:1px solid var(--line-strong);
  padding-left:var(--space-3);
  white-space:nowrap;
}
.header__logo-tag-dot{
  display:inline-block;width:3px;height:3px;border-radius:50%;
  background:var(--accent);opacity:.7;
}
@media(max-width:1199px){.header__logo-tag{display:none}}
@media(max-width:767px){.header__logo img{height:40px}}

.header__search{
  flex:1;max-width:580px;position:relative;
}
.header__search-input{
  width:100%;
  padding:.85rem 3.6rem .85rem 2.95rem;
  border:1.5px solid var(--line);
  border-radius:var(--r-search);
  background:var(--bg-subtle);
  font-size:var(--fs-base);
  font-family:var(--ff-body);
  transition:all var(--t-base) var(--ease-out);
}
.header__search-input::placeholder{color:var(--muted);opacity:.85}
.header__search-input:hover{background:#fff;border-color:var(--line-strong)}
.header__search-input:focus{
  outline:none;border-color:var(--accent);
  background:#fff;box-shadow:0 0 0 4px var(--accent-soft),0 12px 32px rgba(160,32,40,.10);
}
.header__search-icon{
  position:absolute;left:1.05rem;top:50%;transform:translateY(-50%);
  color:var(--muted);pointer-events:none;
  width:18px;height:18px;
  transition:color var(--t-fast) var(--ease-out);
}
.header__search:focus-within .header__search-icon{color:var(--accent)}

/* Hotkey hint — ⌘ K */
.header__search-kbd{
  position:absolute;right:.65rem;top:50%;transform:translateY(-50%);
  display:inline-flex;align-items:center;gap:2px;
  padding:3px 8px;
  font-family:var(--ff-mono);font-size:10px;font-weight:var(--fw-bold);
  letter-spacing:.04em;
  color:var(--muted);background:#fff;
  border:1px solid var(--line-strong);
  border-radius:6px;
  box-shadow:inset 0 -1px 0 rgba(20,20,20,.06);
  pointer-events:none;
  transition:opacity var(--t-fast) var(--ease-out);
}
.header__search.is-open .header__search-kbd,
.header__search.has-value .header__search-kbd{opacity:0}
@media(max-width:1199px){.header__search-kbd{display:none}}

/* Clear button — visible only when input has value */
.header__search-clear{
  position:absolute;right:.55rem;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border:none;background:var(--bg-subtle);
  color:var(--muted);border-radius:50%;
  display:none;align-items:center;justify-content:center;cursor:pointer;
  transition:background var(--t-fast) var(--ease-out),
             color var(--t-fast) var(--ease-out),
             transform var(--t-fast) var(--ease-spring);
  padding:0;
}
.header__search-clear .icon{width:12px;height:12px}
.header__search-clear:hover{background:var(--accent);color:#fff;transform:translateY(-50%) rotate(90deg)}
.header__search.has-value .header__search-clear{display:inline-flex}

/* Dropdown container */
.header__search-dropdown{
  position:absolute;top:calc(100% + 10px);left:-8px;right:-8px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:
    0 30px 70px rgba(18,18,24,.18),
    0 12px 28px rgba(18,18,24,.08),
    0 0 0 1px rgba(0,0,0,.02);
  display:none;z-index:calc(var(--z-dropdown) + 50);
  overflow:hidden;
}
.header__search.is-open .header__search-dropdown{
  display:flex;flex-direction:column;
  animation:search-dropdown-in .22s var(--ease-spring);
}
@keyframes search-dropdown-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* Category chip bar — sticky top */
.search-panel__chipsbar{
  display:flex;align-items:center;gap:6px;
  padding:12px 14px;
  background:linear-gradient(180deg,#fff 0%,#fbfbfb 100%);
  border-bottom:1px solid var(--line);
  overflow-x:auto;
  scrollbar-width:none;-ms-overflow-style:none;
  flex-shrink:0;
}
.search-panel__chipsbar::-webkit-scrollbar{display:none}

.search-chip{
  display:inline-flex;align-items:center;
  padding:.42rem .85rem;
  border:1px solid var(--line);background:#fff;
  border-radius:var(--r-pill);
  font-family:var(--ff-body);font-size:12.5px;font-weight:var(--fw-semibold);
  color:var(--ink);cursor:pointer;
  transition:all var(--t-fast) var(--ease-out);
  white-space:nowrap;flex-shrink:0;
  letter-spacing:.01em;
}
.search-chip:hover{border-color:var(--accent);color:var(--accent)}
.search-chip.is-active{
  background:linear-gradient(135deg,#c83a40 0%,var(--accent) 100%);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 12px rgba(160,32,40,.28);
}

/* Body (scrollable) */
.search-panel__body{
  flex:1;min-height:0;
  padding:14px 16px 6px;
  overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent;
  max-height:min(54vh,480px);
}
.search-panel__body::-webkit-scrollbar{width:6px}
.search-panel__body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}

.search-panel__empty{display:flex;flex-direction:column;gap:16px}
.search-panel__block{display:flex;flex-direction:column;gap:8px}

.search-panel__blockhead{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.search-panel__blocktitle{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-mono);font-size:10.5px;font-weight:var(--fw-bold);
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--muted);
}
.search-panel__blocktitle .icon{width:13px;height:13px;color:var(--accent)}

.search-panel__count{
  font-family:var(--ff-price);font-size:11px;font-weight:var(--fw-extrabold);
  color:var(--accent);background:var(--accent-soft);
  padding:2px 9px;border-radius:var(--r-pill);
  letter-spacing:0;
}
.search-panel__clear{
  border:none;background:transparent;
  font:inherit;font-size:10.5px;letter-spacing:.1em;
  color:var(--muted);cursor:pointer;text-transform:uppercase;
  transition:color var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out);
  padding:3px 8px;border-radius:6px;font-weight:var(--fw-semibold);
}
.search-panel__clear:hover{color:var(--accent);background:var(--accent-soft)}

/* Tag chips (popular + recent) */
.search-panel__tags{display:flex;flex-wrap:wrap;gap:6px}
.search-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:.38rem .78rem;
  background:var(--bg-subtle);color:var(--ink);
  border:1px solid transparent;border-radius:var(--r-pill);
  font-size:12.5px;font-weight:var(--fw-semibold);
  transition:all var(--t-fast) var(--ease-out);
}
.search-tag::before{
  content:"";width:5px;height:5px;border-radius:50%;
  background:var(--accent);opacity:.5;
  transition:opacity var(--t-fast) var(--ease-out);
}
.search-tag:hover{
  border-color:var(--accent);color:var(--accent);
  background:#fff;transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(160,32,40,.12);
}
.search-tag:hover::before{opacity:1}

/* Live results list */
.search-panel__results{display:flex;flex-direction:column;gap:10px}
.search-panel__list{display:flex;flex-direction:column;gap:2px}
.search-result{
  display:flex;align-items:center;gap:12px;
  padding:10px;border-radius:12px;
  transition:background var(--t-fast) var(--ease-out);
  cursor:pointer;
}
.search-result:hover,.search-result.is-focused{background:var(--bg-subtle)}
.search-result__thumb{
  width:42px;height:42px;border-radius:10px;
  background:var(--bg-subtle);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.search-result__thumb .icon{width:20px;height:20px;color:var(--muted)}
.search-result__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.search-result__title{
  font-size:13.5px;font-weight:var(--fw-semibold);color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.search-result__meta{font-size:11px;color:var(--muted)}
.search-result__price{
  font-family:var(--ff-price);font-weight:var(--fw-extrabold);font-size:13.5px;
  color:var(--accent);white-space:nowrap;
}

/* ─── Advanced (collapsible) ─── */
.search-panel__advanced{
  border-top:1px solid var(--line);
  background:#fafafa;
}
.search-panel__advanced-trigger{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;
  font-family:var(--ff-mono);font-size:11px;font-weight:var(--fw-bold);
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--ink-secondary);
  user-select:none;
  transition:color var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out);
}
.search-panel__advanced-trigger::-webkit-details-marker{display:none}
.search-panel__advanced-trigger:hover{color:var(--accent);background:#fff}
.search-panel__advanced-trigger > span{flex:1}
.search-panel__advanced-icon{width:14px;height:14px;color:var(--accent)}
.search-panel__advanced-chev{
  width:14px;height:14px;color:var(--muted);
  transition:transform var(--t-base) var(--ease-out);
}
.search-panel__advanced[open] .search-panel__advanced-chev{transform:rotate(180deg)}
.search-panel__advanced[open] .search-panel__advanced-trigger{color:var(--accent);background:#fff}

.search-panel__advanced-body{
  display:grid;grid-template-columns:1fr 1.4fr;gap:14px;
  padding:4px 16px 14px;
  animation:advanced-in .22s var(--ease-out);
}
@keyframes advanced-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:640px){.search-panel__advanced-body{grid-template-columns:1fr}}

.search-panel__minilabel{
  display:block;
  font-family:var(--ff-mono);font-size:9.5px;font-weight:var(--fw-bold);
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--muted);margin-bottom:6px;
}
.search-panel__pricefields{
  display:flex;align-items:center;gap:8px;
  padding:5px;
  background:#fff;
  border-radius:var(--r-squircle);
  border:1px solid var(--line);
}
.search-panel__price-input{
  flex:1;min-width:0;
  border:none;background:transparent;
  padding:.4rem .6rem;
  font-family:var(--ff-price);font-weight:var(--fw-semibold);font-size:13px;
  color:var(--ink);
  border-radius:8px;
  transition:background var(--t-fast) var(--ease-out),box-shadow var(--t-fast) var(--ease-out);
  -moz-appearance:textfield;
}
.search-panel__price-input::-webkit-outer-spin-button,
.search-panel__price-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.search-panel__price-input:focus{outline:none;background:var(--accent-soft);box-shadow:inset 0 0 0 1.5px var(--accent)}
.search-panel__dash{width:8px;height:1.5px;background:var(--line-strong);border-radius:2px;flex-shrink:0}

.search-panel__toggle-row{display:flex;flex-wrap:wrap;gap:6px}
.search-toggle{
  display:inline-flex;align-items:center;gap:7px;
  padding:.42rem .75rem;
  border:1px solid var(--line);background:#fff;
  border-radius:var(--r-pill);
  font-size:12px;font-weight:var(--fw-semibold);color:var(--ink);
  cursor:pointer;transition:all var(--t-fast) var(--ease-out);
}
.search-toggle input{
  appearance:none;-webkit-appearance:none;
  width:14px;height:14px;
  border:1.5px solid var(--line-strong);border-radius:4px;
  position:relative;cursor:pointer;flex-shrink:0;
  transition:all var(--t-fast) var(--ease-out);
}
.search-toggle input:checked{background:var(--accent);border-color:var(--accent)}
.search-toggle input:checked::after{
  content:"";position:absolute;left:3px;top:0;
  width:6px;height:10px;
  border:solid #fff;border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.search-toggle:has(input:checked){border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}

/* Footer hint row */
.search-panel__footer{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);
  padding:10px 16px;
  border-top:1px solid var(--line);
  background:#fff;
  flex-shrink:0;
}
.search-panel__hint{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;color:var(--muted);letter-spacing:.02em;
}
.search-panel__hint-sep{
  width:3px;height:3px;border-radius:50%;
  background:var(--line-strong);
}
.search-panel__hint kbd{
  font-family:var(--ff-mono);font-size:10px;font-weight:var(--fw-bold);
  background:var(--bg-subtle);color:var(--ink);
  padding:2px 6px;border-radius:4px;
  border:1px solid var(--line);
  line-height:1;
}
.search-panel__all{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:var(--fw-bold);color:var(--accent);
  letter-spacing:.02em;
  transition:transform var(--t-fast) var(--ease-out),gap var(--t-fast) var(--ease-out);
  white-space:nowrap;
}
.search-panel__all .icon{width:12px;height:12px}
.search-panel__all:hover{gap:9px}

.header__actions{display:flex;align-items:stretch;gap:2px}
.header__action{
  position:relative;
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;
  min-width:62px;padding:8px 10px;
  border-radius:var(--r-md);
  color:var(--ink-secondary);
  background:transparent;
  transition:color var(--t-fast) var(--ease-out),
             background var(--t-fast) var(--ease-out),
             transform var(--t-fast) var(--ease-spring);
}
.header__action-iconwrap{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;
}
.header__action .icon{
  width:22px;height:22px;
  transition:transform var(--t-base) var(--ease-spring),color var(--t-fast) var(--ease-out);
  position:relative;z-index:1;
}
.header__action-label{
  font-family:var(--ff-heading);
  font-size:10.5px;font-weight:var(--fw-semibold);
  letter-spacing:.02em;
  color:var(--muted);
  transition:color var(--t-fast) var(--ease-out);
}
.header__action:hover{
  color:var(--accent);
  background:var(--accent-soft);
}
.header__action:hover .icon{transform:translateY(-2px) scale(1.08);color:var(--accent)}
.header__action:hover .header__action-label{color:var(--accent)}
.header__action:active{transform:scale(.96)}

/* Cart — выделяем как primary CTA */
.header__action--cart{
  background:var(--accent-soft);
  color:var(--accent);
}
.header__action--cart .header__action-label{color:var(--accent)}
.header__action--cart:hover{
  background:var(--accent-gradient);
  color:#fff;
  box-shadow:0 8px 20px rgba(109,20,24,.28);
  transform:translateY(-1px);
}
.header__action--cart:hover .icon,
.header__action--cart:hover .header__action-label{color:#fff}

.header__action--menu{display:none;min-width:46px}
.header__action--menu .header__action-iconwrap{width:auto;height:auto}
@media(max-width:1023px){.header__action--menu{display:inline-flex}}
@media(max-width:1199px){
  .header__action{min-width:46px;padding:8px}
  .header__action-label{display:none}
}

.header__action-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--accent-gradient);color:#fff;
  font-family:var(--ff-heading);font-size:10px;font-weight:var(--fw-extrabold);
  border-radius:var(--r-pill);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 2px var(--bg-card),0 4px 10px rgba(109,20,24,.35);
  line-height:1;letter-spacing:0;
  font-feature-settings:'tnum';
  transform-origin:center;
  animation:badge-pop .4s var(--ease-spring) both;
}
@keyframes badge-pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}

/* ─── Quick-nav strip: категории + инфо-ссылки ─── */
.header__quicknav{
  position:relative;
  height:var(--quicknav-h);
  background:linear-gradient(180deg,#fdfbfa 0%,#f8f5f3 100%);
  border-top:1px solid var(--line);
}
.header__quicknav::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(109,20,24,.10) 50%, transparent 100%);
  pointer-events:none;
}
.header__quicknav-inner{
  display:flex;align-items:center;gap:var(--space-4);
  height:100%;
}
.header__quicknav-divider{
  width:1px;align-self:stretch;
  margin-block:10px;
  background:linear-gradient(180deg,transparent 0%, var(--line-strong) 50%, transparent 100%);
  flex-shrink:0;
}

/* Main nav — пилюли категорий */
.main-nav{
  display:flex;align-items:center;gap:2px;
  flex:1;min-width:0;
  overflow-x:auto;
  scrollbar-width:none;-ms-overflow-style:none;
}
.main-nav::-webkit-scrollbar{display:none}
.main-nav__item{position:relative;flex-shrink:0}
.main-nav__link{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--ff-heading);font-size:13px;font-weight:var(--fw-semibold);
  padding:8px 14px;
  color:var(--ink);
  border:1px solid transparent;
  border-radius:var(--r-pill);
  position:relative;
  letter-spacing:.005em;
  transition:color var(--t-fast) var(--ease-out),
             background var(--t-fast) var(--ease-out),
             border-color var(--t-fast) var(--ease-out);
}
.main-nav__link-icon{
  width:15px;height:15px;
  color:var(--muted);
  transition:color var(--t-fast) var(--ease-out),transform var(--t-base) var(--ease-out);
}
.main-nav__link:hover{color:var(--accent);background:#fff;border-color:var(--line)}
.main-nav__link:hover .main-nav__link-icon{color:var(--accent);transform:rotate(-4deg) scale(1.1)}
.main-nav__link.is-active{color:var(--accent)}
.main-nav__chev{
  width:12px;height:12px;margin-left:2px;
  opacity:.6;
  transition:transform var(--t-fast) var(--ease-out),opacity var(--t-fast) var(--ease-out);
}
.main-nav__item:hover .main-nav__chev{transform:rotate(180deg);opacity:1}

/* Каталог — primary accent link */
.main-nav__link--catalog{
  background:var(--accent-gradient);
  color:#fff;
  padding:8px 16px;
  border-color:transparent;
  box-shadow:0 4px 12px rgba(109,20,24,.22),inset 0 1px 0 rgba(255,255,255,.18);
}
.main-nav__link--catalog .main-nav__link-icon{color:#fff}
.main-nav__link--catalog:hover{
  color:#fff;background:linear-gradient(135deg,#7c1a1f,#b62832);
  border-color:transparent;
  box-shadow:0 8px 20px rgba(109,20,24,.32),inset 0 1px 0 rgba(255,255,255,.22);
}
.main-nav__link--catalog:hover .main-nav__link-icon{color:#fff;transform:rotate(0) scale(1.08)}

/* Info-nav — сервисные ссылки из футера */
.info-nav{
  display:flex;align-items:center;gap:0;
  flex-shrink:0;
}
.info-nav__link{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--ff-heading);font-size:12.5px;font-weight:var(--fw-medium);
  color:var(--ink-secondary);
  padding:7px 12px;
  border-radius:var(--r-pill);
  white-space:nowrap;
  letter-spacing:.005em;
  transition:color var(--t-fast) var(--ease-out),
             background var(--t-fast) var(--ease-out),
             transform var(--t-fast) var(--ease-spring);
}
.info-nav__link .icon{
  width:14px;height:14px;
  color:var(--muted);
  transition:color var(--t-fast) var(--ease-out),transform var(--t-base) var(--ease-out);
}
.info-nav__link:hover{
  color:var(--accent);background:var(--accent-soft);
}
.info-nav__link:hover .icon{color:var(--accent);transform:rotate(-6deg) scale(1.12)}
.info-nav__link--accent{
  color:var(--accent);
  font-weight:var(--fw-semibold);
}
.info-nav__link--accent .icon{color:var(--accent)}
.info-nav__link--accent::before{
  content:"";
  display:inline-block;width:5px;height:5px;border-radius:50%;
  background:var(--accent);
  margin-right:-2px;
  box-shadow:0 0 0 0 rgba(109,20,24,.4);
  animation:topbar-pulse 2.2s infinite cubic-bezier(.66,0,0,1);
}

/* Submenu (hover dropdown per category) */
.submenu{
  position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%,-4px);
  min-width:840px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid var(--line);
  border-top:2px solid var(--accent);
  border-radius:var(--r-lg);
  box-shadow:0 24px 64px rgba(20,20,20,.12),0 8px 24px rgba(109,20,24,.08);
  padding:var(--space-5);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity var(--t-base) var(--ease-out),transform var(--t-base) var(--ease-out),visibility var(--t-base);
  z-index:var(--z-dropdown);
}
.submenu::before{
  content:"";position:absolute;top:-10px;left:0;right:0;height:12px;
}
.main-nav__item:hover .submenu,
.main-nav__item:focus-within .submenu{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translate(-50%,0);
}
/* Edge alignment for last nav items (avoid right overflow) */
.main-nav__item:nth-last-child(-n+2) .submenu{
  left:auto;right:0;transform:translate(0,-4px);
}
.main-nav__item:nth-last-child(-n+2):hover .submenu,
.main-nav__item:nth-last-child(-n+2):focus-within .submenu{
  transform:translate(0,0);
}
.submenu__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-4);
}
.submenu__col-title{
  font-family:var(--ff-heading);font-size:var(--fs-xs);
  font-weight:var(--fw-semibold);text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted);
  margin-bottom:var(--space-2);
  padding-bottom:var(--space-2);
  border-bottom:1px solid var(--line);
}
.submenu__link{
  display:flex;align-items:center;gap:var(--space-2);
  padding:var(--space-2) var(--space-3);
  border-radius:var(--r-sm);
  font-size:var(--fs-sm);font-weight:var(--fw-medium);
  color:var(--ink-secondary);
  transition:all var(--t-fast) var(--ease-out);
  margin-bottom:2px;
}
.submenu__link:hover{
  background:var(--accent-soft);color:var(--accent);
  transform:translateX(4px);
}
.submenu__link .submenu__new{
  font-size:9px;font-weight:var(--fw-extrabold);
  background:var(--accent-gradient);color:#fff;
  padding:.15rem .4rem;border-radius:var(--r-badge);
  text-transform:uppercase;letter-spacing:.05em;
  margin-left:auto;
}
.submenu__footer{
  margin-top:var(--space-4);padding-top:var(--space-4);
  border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--space-4);
}
.submenu__promo{
  display:flex;align-items:center;gap:var(--space-2);
  font-size:var(--fs-sm);color:var(--muted);
}
.submenu__promo .icon{width:18px;height:18px;color:var(--accent)}
.submenu__all{
  color:var(--accent);font-weight:var(--fw-semibold);font-size:var(--fs-sm);
  display:inline-flex;align-items:center;gap:var(--space-1);
}
.submenu__all:hover{gap:var(--space-2)}

/* Mega menu */
.mega-menu{
  position:absolute;top:100%;left:0;right:0;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-top:1px solid var(--line);
  border-bottom:3px solid transparent;
  border-image:var(--accent-gradient) 1;
  border-image-slice:0 0 3 0;
  box-shadow:var(--shadow-lg);
  padding:var(--space-8) 0;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(-8px);
  transition:opacity var(--t-base) var(--ease-out),transform var(--t-base) var(--ease-out),visibility var(--t-base);
  z-index:var(--z-dropdown);
}
.mega-menu.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}

.mega-menu__grid{
  display:grid;grid-template-columns:repeat(6,1fr) 280px;gap:var(--space-6);
}
.mega-menu__category{
  display:flex;flex-direction:column;align-items:center;gap:var(--space-2);
  padding:var(--space-4);border-radius:var(--r-md);
  transition:background var(--t-fast) var(--ease-out);
  text-align:center;
}
.mega-menu__category:hover{background:var(--accent-soft)}
.mega-menu__category .icon{width:36px;height:36px}

/* === FOOTER — Premium gradient (matches guarantee-banner) === */
.footer{
  position:relative;overflow:hidden;
  color:rgba(255,255,255,.7);
  background:
    radial-gradient(900px 400px at 10% 0%, rgba(160,32,40,.45), transparent 60%),
    radial-gradient(700px 400px at 90% 100%, rgba(109,20,24,.4), transparent 60%),
    linear-gradient(135deg, #0f0405 0%, #1a0808 30%, #2d0e10 70%, #0d0202 100%);
}
.footer::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:28px 28px;
  opacity:.4;pointer-events:none;
  mask-image:radial-gradient(ellipse 80% 70% at center,#000 20%,transparent 90%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at center,#000 20%,transparent 90%);
}
.footer a{color:rgba(255,255,255,.7);transition:color var(--t-fast) var(--ease-out)}
.footer a:hover{color:#fff}
.footer__wave{
  position:absolute;top:-1px;left:0;right:0;height:60px;
  background:var(--bg);
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0,0 C480,60 960,60 1440,0 L1440,0 L0,0 Z'/%3E%3C/svg%3E");
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0,0 C480,60 960,60 1440,0 L1440,0 L0,0 Z'/%3E%3C/svg%3E");
  mask-size:100% 100%;-webkit-mask-size:100% 100%;
  z-index:1;
}
.footer__inner{
  position:relative;z-index:1;
  padding:calc(var(--space-16) + 40px) 0 var(--space-12);
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-8);
}

/* Logo tile on white background — positioned directly under "О магазине" title */
.footer__brand{display:flex;flex-direction:column;gap:var(--space-3)}
.footer__brand-text{font-size:var(--fs-sm);line-height:1.55;color:rgba(255,255,255,.7);margin:0}
.footer__logo-tile{
  display:inline-flex;align-items:center;justify-content:center;
  align-self:flex-start;
  background:#fff;
  padding:var(--space-3) var(--space-5);
  border-radius:var(--r-card);
  box-shadow:0 8px 24px rgba(0,0,0,.3),inset 0 0 0 1px rgba(255,255,255,.1);
  transition:all var(--t-base) var(--ease-out);
  margin-top:var(--space-2);
  position:relative;overflow:hidden;
}
.footer__logo-tile::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 0%,rgba(160,32,40,.06) 50%,transparent 100%);
  opacity:0;transition:opacity var(--t-base) var(--ease-out);
}
.footer__logo-tile:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(0,0,0,.35)}
.footer__logo-tile:hover::before{opacity:1}
.footer__logo-tile img{height:44px;width:auto;display:block;position:relative;z-index:1}

.footer__col-title{
  font-family:var(--ff-heading);font-size:var(--fs-base);font-weight:var(--fw-semibold);
  color:#fff;margin-bottom:var(--space-4);
  display:flex;align-items:center;gap:var(--space-2);
}
.footer__col-title::before{
  content:"";width:4px;height:16px;
  background:var(--accent-gradient);border-radius:2px;
}
.footer__links{display:flex;flex-direction:column;gap:2px}
.footer__links a{font-size:var(--fs-sm)}
.footer__links .footer__contact-row{margin-bottom:2px}
.footer__links .footer__contact-row:last-child{margin-bottom:0}

/* Animated link: icon in white circle + slide-out underline */
.footer__link-anim{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 0;
  position:relative;
  transition:transform var(--t-fast) var(--ease-out);
}
.footer__link-icon{
  width:18px;height:18px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;color:var(--accent);
  border-radius:50%;
  box-shadow:0 2px 6px rgba(0,0,0,.2);
  transition:all var(--t-base) var(--ease-spring);
}
.footer__link-icon .icon{width:10px;height:10px}
.footer__link-anim:hover{transform:translateX(4px)}
.footer__link-anim:hover .footer__link-icon{
  background:var(--accent-gradient);color:#fff;
  box-shadow:0 4px 12px rgba(160,32,40,.45);
}
.footer__link-anim .footer__link-text{
  position:relative;
  background-image:linear-gradient(#fff,#fff);
  background-size:0 1px;background-repeat:no-repeat;
  background-position:0 100%;
  transition:background-size var(--t-base) var(--ease-out);
}
.footer__link-anim:hover .footer__link-text{background-size:100% 1px}

/* Contact lines: icon pill matching footer__social style */
.footer__contact-row{
  display:flex;align-items:center;gap:10px;
  padding:6px 0;
  font-size:var(--fs-sm);
  transition:transform var(--t-fast) var(--ease-out);
}
.footer__contact-row:hover{transform:translateX(3px)}
.footer__contact-icon{
  width:36px;height:36px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:50%;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:#fff;
  transition:all var(--t-base) var(--ease-out);
}
.footer__contact-icon .icon{width:16px;height:16px}
.footer__contact-row:hover .footer__contact-icon{
  background:#fff;color:var(--accent);border-color:transparent;
  box-shadow:0 6px 18px rgba(255,255,255,.15);
}
.footer__contact-value{color:#fff;font-weight:var(--fw-semibold);letter-spacing:.01em}
.footer__contact-label{font-size:11px;color:rgba(255,255,255,.5);display:block;margin-bottom:1px;text-transform:uppercase;letter-spacing:.08em}

.footer__socials{display:flex;gap:var(--space-3);margin-top:var(--space-4)}
.footer__social{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:50%;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:all var(--t-fast) var(--ease-out);
}
.footer__social:hover{
  background:var(--accent-gradient);color:#fff;
  border-color:transparent;
  box-shadow:0 0 24px rgba(160,32,40,.5);
  transform:translateY(-2px) scale(1.06);
}

/* === MAP SECTION === */
.map-section{position:relative;padding:var(--space-16) 0}
.map-section__grid{
  display:grid;grid-template-columns:360px 1fr;gap:var(--space-6);
  align-items:stretch;
}
@media (max-width:900px){.map-section__grid{grid-template-columns:1fr}}
.map-section__info{
  background:linear-gradient(135deg,#fff 0%,#fbf7f4 100%);
  border-radius:var(--r-card);
  padding:var(--space-6);
  box-shadow:0 20px 50px rgba(0,0,0,.06);
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:var(--space-4);
  position:relative;overflow:hidden;
}
.map-section__info::before{
  content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(160,32,40,.08),transparent 70%);
  pointer-events:none;
}
.map-section__eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:var(--fw-bold);letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);
}
.map-section__eyebrow::before{content:"";width:20px;height:2px;background:var(--accent-gradient);border-radius:2px}
.map-section__title{
  font-family:var(--ff-heading);font-size:var(--fs-2xl);font-weight:var(--fw-extrabold);
  color:var(--ink);letter-spacing:-.02em;line-height:1.15;
}
.map-section__row{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
}
.map-section__row:last-of-type{border-bottom:none}
.map-section__row-icon{
  width:40px;height:40px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--accent);
  border-radius:50%;
  transition:all var(--t-base) var(--ease-spring);
}
.map-section__row:hover .map-section__row-icon{
  background:var(--accent-gradient);color:#fff;transform:scale(1.08) rotate(-6deg);
}
.map-section__row-icon .icon{width:18px;height:18px}
.map-section__row-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:var(--fw-semibold);margin-bottom:2px}
.map-section__row-value{font-family:var(--ff-heading);font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--ink);line-height:1.35}
.map-section__row-value a{color:var(--ink)}
.map-section__row-value a:hover{color:var(--accent)}
.map-section__map{
  position:relative;
  border-radius:var(--r-card);
  overflow:hidden;
  min-height:420px;
  box-shadow:0 20px 50px rgba(0,0,0,.1);
  border:1px solid var(--line);
  background:#f5f0eb;
}
.map-section__map iframe{width:100%;height:100%;min-height:420px;border:none;display:block}
.map-section__map::after{
  content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);
  border-radius:var(--r-card);
  pointer-events:none;
}

.footer__bottom{
  position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.1);
  padding:var(--space-8) 0;
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;
  font-size:var(--fs-xs);
}

/* === MOBILE BOTTOM NAV === */
.mobile-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;
  height:var(--mobile-nav-h);
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-top:1px solid var(--line);
  z-index:var(--z-sticky);
  padding-bottom:env(safe-area-inset-bottom);
}
.mobile-nav__inner{
  display:flex;align-items:center;justify-content:space-around;
  height:100%;
}
.mobile-nav__item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  font-size:10px;font-weight:var(--fw-medium);
  color:var(--muted);position:relative;
  transition:color var(--t-fast) var(--ease-out);
}
.mobile-nav__item.is-active{color:var(--accent)}
.mobile-nav__item.is-active::before{
  content:"";position:absolute;top:-1px;
  width:4px;height:4px;border-radius:50%;
  background:var(--accent);
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}

.mobile-nav__item .icon{width:22px;height:22px}

/* === BREADCRUMBS === */
.breadcrumbs{
  display:flex;align-items:center;gap:var(--space-2);
  font-size:var(--fs-sm);color:var(--muted);
  padding:var(--space-4) 0;
  flex-wrap:wrap;
}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs__sep{
  width:16px;height:16px;opacity:.4;
}

/* === TOOLTIPS === */
.tooltip{
  position:relative;cursor:pointer;
}
.tooltip__content{
  position:absolute;z-index:var(--z-dropdown);
  background:var(--ink);color:#fff;
  font-size:var(--fs-sm);font-weight:var(--fw-medium);
  padding:var(--space-4) var(--space-5);
  border-radius:16px;
  white-space:nowrap;
  box-shadow:var(--shadow-lg);
  pointer-events:none;
  opacity:0;transform:scale(.92) translateY(4px);
  transition:all var(--t-fast) var(--ease-spring);
}
.tooltip:hover .tooltip__content{opacity:1;transform:scale(1) translateY(0)}

.tooltip__content--top{bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) scale(.92) translateY(4px)}
.tooltip:hover .tooltip__content--top{transform:translateX(-50%) scale(1) translateY(0)}
.tooltip__content--top::after{
  content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--ink);
}
.tooltip__content--bottom{top:calc(100% + 8px);left:50%;transform:translateX(-50%) scale(.92) translateY(-4px)}
.tooltip:hover .tooltip__content--bottom{transform:translateX(-50%) scale(1) translateY(0)}
.tooltip__content--bottom::after{
  content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-bottom-color:var(--ink);
}

/* Tooltip wide variant */
.tooltip__content--wide{white-space:normal;width:240px;text-align:left;line-height:1.5}

/* === TOAST NOTIFICATIONS === */
.toast-container{
  position:fixed;top:var(--space-6);right:var(--space-6);
  display:flex;flex-direction:column;gap:var(--space-3);
  z-index:var(--z-toast);pointer-events:none;
}
.toast{
  display:flex;align-items:center;gap:var(--space-3);
  padding:var(--space-4) var(--space-6);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);
  font-size:var(--fs-sm);font-weight:var(--fw-medium);
  pointer-events:auto;
  animation:toast-in .4s var(--ease-spring);
}
.toast--success{border-left:3px solid transparent;border-image:linear-gradient(180deg,var(--success),#34d399) 1}
.toast--error{border-left:3px solid transparent;border-image:linear-gradient(180deg,var(--danger),#f87171) 1}
.toast--info{border-left:3px solid transparent;border-image:linear-gradient(180deg,var(--accent),#e85d64) 1}
.toast.is-leaving{animation:toast-out .3s var(--ease-out) forwards}

@keyframes toast-in{from{opacity:0;transform:translateX(100%) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes toast-out{to{opacity:0;transform:translateX(100%) scale(.9)}}

/* === BACK TO TOP === */
.back-to-top{
  position:fixed;bottom:var(--space-6);right:var(--space-6);
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-card);border:1.5px solid var(--line);
  border-radius:50%;
  box-shadow:var(--shadow-md);
  opacity:0;visibility:hidden;
  transform:translateY(16px);
  transition:all var(--t-base) var(--ease-out);
  z-index:var(--z-sticky);
  color:var(--accent);
}
.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{
  border-color:var(--accent);
  background:var(--accent-gradient);color:#fff;
  box-shadow:0 12px 28px rgba(109,20,24,.35),0 0 0 4px rgba(109,20,24,.12);
  transform:translateY(-3px);
}
.back-to-top .icon{position:relative;z-index:2;width:20px;height:20px;transition:transform var(--t-base) var(--ease-spring)}
.back-to-top:hover .icon{transform:translateY(-3px)}

.back-to-top__progress{
  position:absolute;inset:0;width:100%;height:100%;
  transform:rotate(-90deg);
  pointer-events:none;
}
.back-to-top__progress circle{
  fill:none;stroke:var(--accent);stroke-width:2.5;
  stroke-dasharray:138;stroke-dashoffset:138;
  transform-origin:center;
  transition:stroke-dashoffset var(--t-fast) linear;
  opacity:.9;
}
.back-to-top:hover .back-to-top__progress circle{stroke:#fff;opacity:1}

/* === FLOATING FEEDBACK FAB === */
.fab-contact{
  position:fixed;bottom:calc(var(--space-6) + 70px);right:var(--space-6);
  z-index:var(--z-sticky);
  display:flex;flex-direction:column-reverse;align-items:center;gap:var(--space-3);
}
.fab-contact__trigger{
  width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:var(--accent-gradient);color:#fff;
  box-shadow:0 10px 30px rgba(109,20,24,.35),0 0 0 6px rgba(109,20,24,.08);
  transition:all var(--t-base) var(--ease-spring);
  position:relative;
  animation:fab-pulse 2.6s ease-in-out infinite;
}
@keyframes fab-pulse{
  0%,100%{box-shadow:0 10px 30px rgba(109,20,24,.35),0 0 0 0 rgba(160,32,40,.35)}
  70%{box-shadow:0 10px 30px rgba(109,20,24,.35),0 0 0 18px rgba(160,32,40,0)}
}
.fab-contact__trigger:hover{transform:scale(1.08) rotate(-8deg)}
.fab-contact__trigger .icon{width:24px;height:24px;transition:transform var(--t-base) var(--ease-spring)}
.fab-contact.is-open .fab-contact__trigger{animation:none;transform:rotate(45deg);background:#2a1010}
.fab-contact.is-open .fab-contact__trigger .icon{transform:rotate(0deg)}
.fab-contact__trigger .fab-contact__close-icon{display:none}
.fab-contact.is-open .fab-contact__trigger .fab-contact__main-icon{display:none}
.fab-contact.is-open .fab-contact__trigger .fab-contact__close-icon{display:block}

.fab-contact__items{
  display:flex;flex-direction:column;gap:var(--space-2);
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(12px) scale(.9);
  transform-origin:bottom center;
  transition:all var(--t-base) var(--ease-spring);
}
.fab-contact.is-open .fab-contact__items{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateY(0) scale(1);
}
.fab-contact__item{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:#fff;color:var(--ink);
  border-radius:50%;
  box-shadow:0 8px 20px rgba(0,0,0,.14);
  transition:all var(--t-fast) var(--ease-spring);
  position:relative;
  animation:fab-item-in .3s var(--ease-spring) both;
}
.fab-contact.is-open .fab-contact__item:nth-child(1){animation-delay:.05s}
.fab-contact.is-open .fab-contact__item:nth-child(2){animation-delay:.1s}
.fab-contact.is-open .fab-contact__item:nth-child(3){animation-delay:.15s}
.fab-contact.is-open .fab-contact__item:nth-child(4){animation-delay:.2s}
@keyframes fab-item-in{from{opacity:0;transform:translateY(10px) scale(.6)}to{opacity:1;transform:translateY(0) scale(1)}}
.fab-contact__item:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.18)}
.fab-contact__item .icon{width:22px;height:22px}
.fab-contact__item--tg{color:#0088cc}
.fab-contact__item--wa{color:#25d366}
.fab-contact__item--phone{color:var(--accent)}
.fab-contact__item--max{color:#ff3a2e}

/* Tooltip attached to fab item — pops out to the left */
.fab-contact__item[data-title]::before{
  content:attr(data-title);
  position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%);
  background:var(--ink);color:#fff;
  font-size:12px;font-weight:var(--fw-semibold);
  padding:.35rem .7rem;border-radius:var(--r-pill);
  white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity var(--t-fast) var(--ease-out);
  box-shadow:0 6px 14px rgba(0,0,0,.25);
}
.fab-contact__item:hover::before{opacity:1}

/* === GLOBAL TOOLTIP (JS-portaled, gradient — matches guarantee-banner) === */
.lumo-tooltip{
  position:fixed;
  top:0;left:0;
  padding:.5rem .85rem;
  background:
    radial-gradient(180px 80px at 20% 0%,rgba(200,58,64,.55),transparent 70%),
    linear-gradient(135deg,#2a0708 0%,#4d0f13 35%,#791821 70%,#a02028 100%);
  color:#fff;
  font-family:var(--ff-body);font-size:12px;font-weight:var(--fw-semibold);
  letter-spacing:.02em;
  border-radius:10px;
  white-space:nowrap;
  pointer-events:none;
  opacity:0;
  transform:translate(-50%,0) scale(.94);
  transform-origin:center bottom;
  transition:opacity var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-out);
  box-shadow:
    0 14px 30px rgba(109,20,24,.38),
    0 4px 10px rgba(0,0,0,.18),
    inset 0 1px 0 rgba(255,255,255,.14),
    0 0 0 1px rgba(255,255,255,.06);
  z-index:99999;
  max-width:min(320px,90vw);
  text-align:center;
  will-change:transform,opacity;
}
.lumo-tooltip::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at 70% 100%,rgba(255,255,255,.08),transparent 55%);
  pointer-events:none;
}
.lumo-tooltip::after{
  content:"";position:absolute;left:var(--arrow-x,50%);transform:translateX(-50%);
  border:6px solid transparent;
  filter:drop-shadow(0 1px 0 rgba(0,0,0,.1));
}
.lumo-tooltip[data-pos="top"]::after{
  top:100%;border-top-color:#791821;
}
.lumo-tooltip[data-pos="bottom"]::after{
  bottom:100%;border-bottom-color:#2a0708;
}
.lumo-tooltip.is-visible{
  opacity:1;transform:translate(-50%,0) scale(1);
}

/* === CHIP / FILTER TAG === */
.chip{
  display:inline-flex;align-items:center;gap:var(--space-1);
  padding:.35rem .85rem;
  font-family:var(--ff-heading);font-size:var(--fs-sm);font-weight:var(--fw-medium);
  border:1.5px solid var(--line-strong);
  border-radius:var(--r-badge);
  background:var(--bg-card);
  transition:all var(--t-fast) var(--ease-out);
  cursor:pointer;white-space:nowrap;
}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.is-active{
  background:var(--accent);color:#fff;border-color:var(--accent);
}

/* === TABS === */
.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--line)}
.tab{
  padding:var(--space-3) var(--space-5);
  font-family:var(--ff-heading);font-size:var(--fs-base);font-weight:var(--fw-medium);
  color:var(--muted);
  border-radius:var(--r-pill) var(--r-pill) 0 0;
  transition:all var(--t-fast) var(--ease-out);
  position:relative;
}
.tab:hover{color:var(--ink);background:var(--bg-subtle)}
.tab.is-active{
  color:var(--accent);font-weight:var(--fw-semibold);
  background:var(--bg-card);
  border:1px solid var(--line);border-bottom-color:var(--bg-card);
  margin-bottom:-1px;
}
.tab-content{display:none;padding:var(--space-6) 0}
.tab-content.is-active{display:block;animation:fade-up .3s var(--ease-out)}

/* === MODAL === */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(20,20,20,.3);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:var(--z-modal);
  opacity:0;visibility:hidden;
  transition:all var(--t-base) var(--ease-out);
}
.modal-overlay.is-open{opacity:1;visibility:visible}

.modal{
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.95);
  background:var(--bg-card);
  border-radius:var(--r-section);
  box-shadow:var(--shadow-lg);
  padding:var(--space-8);
  z-index:calc(var(--z-modal) + 1);
  max-width:90vw;max-height:90vh;
  overflow-y:auto;
  opacity:0;visibility:hidden;
  transition:all var(--t-base) var(--ease-spring);
}
.modal.is-open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}

.modal__close{
  position:absolute;top:var(--space-4);right:var(--space-4);
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  transition:background var(--t-fast) var(--ease-out);
}
.modal__close:hover{background:var(--bg-subtle)}

/* === SKELETON LOADING === */
.skeleton{
  background:linear-gradient(90deg,var(--bg-subtle) 25%,var(--bg) 37%,var(--bg-subtle) 63%);
  background-size:400% 100%;
  animation:skeleton-pulse 1.4s ease infinite;
  border-radius:var(--r-sm);
}
.skeleton--circle{border-radius:50%}
.skeleton--text{height:1em;margin-bottom:.5em}
.skeleton--title{height:1.5em;width:60%}
.skeleton--img{aspect-ratio:1}
@keyframes skeleton-pulse{0%{background-position:100% 50%}100%{background-position:0 50%}}

/* === HERO SLIDER === */
.hero{
  position:relative;overflow:hidden;
  border-radius:var(--r-hero);
  margin:0 var(--container-px);
}
.hero__slides{
  display:flex;
  transition:transform var(--t-slower) var(--ease-out);
}
.hero__slide{
  min-width:100%;position:relative;
  aspect-ratio:2/1;
  display:flex;align-items:center;
  overflow:hidden;
}
.hero__slide::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.2) 40%,transparent 70%);
  pointer-events:none;
}
.hero__slide-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 8s linear;
}
.hero__slide.is-active .hero__slide-bg{transform:scale(1.05)}

.hero__slide-inner{
  position:relative;z-index:2;
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding-inline:var(--container-px);
  max-width:var(--container-max);margin-inline:auto;
}
.hero__slide-content{
  position:relative;z-index:2;
  max-width:560px;padding:var(--space-8) 0;
}
.hero__slide-content h1,.hero__slide-content .hero__title{
  font-size:clamp(1.75rem,3.5vw,3rem);
  line-height:1.1;
}
.hero__slide-product{
  max-height:80%;width:auto;max-width:40%;
  object-fit:contain;
  filter:drop-shadow(0 24px 48px rgba(0,0,0,.4));
  animation:hero-float 6s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes hero-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero__dots{
  position:absolute;bottom:var(--space-6);left:50%;transform:translateX(-50%);
  display:flex;gap:var(--space-2);z-index:3;
}
.hero__dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.4);
  transition:all var(--t-base) var(--ease-out);
  cursor:pointer;
}
.hero__dot.is-active{width:32px;border-radius:var(--r-pill);background:#fff}

.hero__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.2);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-radius:50%;z-index:3;
  transition:all var(--t-fast) var(--ease-out);
  color:#fff;
}
.hero__nav:hover{background:rgba(255,255,255,.4)}
.hero__nav--prev{left:var(--space-4)}
.hero__nav--next{right:var(--space-4)}

/* === PRELOADER — phone-fill progress === */
.preloader{
  position:fixed;inset:0;
  background:
    radial-gradient(800px 400px at 50% 30%,var(--accent-soft) 0%,transparent 65%),
    linear-gradient(180deg,var(--bg) 0%,#fbf7f4 100%);
  display:flex;align-items:center;justify-content:center;
  z-index:var(--z-preloader);
  transition:opacity .5s var(--ease-out),visibility .5s var(--ease-out);
  padding:var(--space-6);
}
.preloader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}

.preloader__inner{
  display:flex;flex-direction:column;align-items:center;gap:var(--space-6);
  max-width:460px;width:100%;
}

.preloader__brand{
  display:flex;gap:2px;
  font-family:var(--ff-heading);font-size:clamp(2rem,6vw,3rem);
  font-weight:var(--fw-extrabold);
  letter-spacing:-.04em;
  text-transform:lowercase;
  position:relative;
}
.preloader__letter{
  opacity:0;transform:translateY(16px);
  animation:preloader-letter .5s var(--ease-spring) forwards;
}
.preloader__letter:nth-child(1){animation-delay:.05s}
.preloader__letter:nth-child(2){animation-delay:.15s}
.preloader__letter:nth-child(3){animation-delay:.25s}
.preloader__letter:nth-child(4){animation-delay:.35s}
.preloader__letter--accent{
  color:var(--accent);
  animation:preloader-letter .5s var(--ease-spring) forwards,preloader-pulse 1.6s .6s ease-in-out infinite;
}
@keyframes preloader-letter{to{opacity:1;transform:translateY(0)}}
@keyframes preloader-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.06)}}

/* Row of phone silhouettes that fill sequentially */
.preloader__phones{
  display:flex;gap:16px;align-items:flex-end;
  margin-top:var(--space-2);
}
.preloader__phone{
  --phone-w:42px;--phone-h:74px;
  position:relative;
  width:var(--phone-w);height:var(--phone-h);
  background:#fff;
  border-radius:9px;
  box-shadow:inset 0 0 0 2px var(--line-strong),0 6px 16px rgba(0,0,0,.06);
  overflow:hidden;
  display:flex;flex-direction:column;align-items:center;
  transition:box-shadow .4s var(--ease-out),transform .4s var(--ease-spring);
  opacity:.55;
  filter:grayscale(1);
}
/* Phone notch */
.preloader__phone::before{
  content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);
  width:16px;height:3px;
  background:var(--line-strong);border-radius:2px;
  z-index:2;
  transition:background .4s var(--ease-out);
}
/* Home indicator bar */
.preloader__phone::after{
  content:"";position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  width:18px;height:2px;
  background:var(--line-strong);border-radius:2px;
  z-index:2;opacity:.6;
  transition:background .4s var(--ease-out);
}
.preloader__phone-fill{
  position:absolute;left:0;right:0;bottom:0;
  height:0;
  background:
    linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 28%),
    linear-gradient(180deg,#c83a40 0%,#a02028 55%,#6d1418 100%);
  transition:height .85s cubic-bezier(.22,1,.36,1);
  z-index:1;
}
.preloader__phone-label{
  position:absolute;left:50%;transform:translateX(-50%);
  bottom:calc(var(--phone-h) * -1 - 8px);
  font-family:var(--ff-mono,ui-monospace,monospace);
  font-size:9px;font-weight:var(--fw-bold);
  color:var(--muted);
  letter-spacing:.14em;text-transform:uppercase;
  white-space:nowrap;
  opacity:.65;
  transition:color .4s var(--ease-out),opacity .4s var(--ease-out);
}
.preloader__phone.is-filled{
  opacity:1;filter:grayscale(0);
  box-shadow:inset 0 0 0 2px var(--accent),0 10px 26px rgba(109,20,24,.22);
  transform:translateY(-4px);
}
.preloader__phone.is-filled::before{background:var(--accent)}
.preloader__phone.is-filled::after{background:rgba(255,255,255,.85)}
.preloader__phone.is-filled .preloader__phone-fill{height:calc(100% - 8px)}
.preloader__phone.is-filled .preloader__phone-label{color:var(--accent);opacity:1}

/* Progress bar */
.preloader__progress{
  width:100%;height:4px;
  background:rgba(109,20,24,.08);
  border-radius:var(--r-pill);
  overflow:hidden;
  margin-top:var(--space-6);
  position:relative;
}
.preloader__progress-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,#c83a40 0%,var(--accent) 50%,#6d1418 100%);
  border-radius:var(--r-pill);
  transition:width .35s var(--ease-out);
  box-shadow:0 0 12px rgba(160,32,40,.45);
  position:relative;
}
.preloader__progress-bar::after{
  content:"";position:absolute;top:0;right:-2px;bottom:0;width:12px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6));
  animation:preloader-shine 1.2s linear infinite;
}
@keyframes preloader-shine{0%{opacity:0}50%{opacity:1}100%{opacity:0}}

/* Status line */
.preloader__meta{
  display:flex;align-items:center;gap:10px;
  font-family:var(--ff-mono,ui-monospace,monospace);
  font-size:12px;font-weight:var(--fw-bold);
  color:var(--ink);
  letter-spacing:.06em;
  text-transform:uppercase;
  min-height:18px;
}
.preloader__percent{
  color:var(--accent);font-size:16px;
  font-family:var(--ff-price,ui-monospace,monospace);
  font-variant-numeric:tabular-nums;
  font-feature-settings:'tnum','lnum';
  min-width:2.2ch;text-align:right;
}
.preloader__percent-sign{color:var(--accent);font-size:14px;opacity:.75;margin-left:-6px}
.preloader__divider{
  width:14px;height:1px;background:var(--line-strong);
  flex-shrink:0;
}
.preloader__msg{
  color:var(--muted);font-weight:var(--fw-semibold);
  letter-spacing:.04em;
  text-transform:none;
  font-size:13px;
  font-family:var(--ff-body);
}

@media (max-width:520px){
  .preloader__phone{--phone-w:34px;--phone-h:60px}
  .preloader__phones{gap:10px}
  .preloader__phone-label{font-size:8px;bottom:-20px}
}

/* === QUANTITY COUNTER === */
.qty{
  display:inline-flex;align-items:center;gap:0;
  border:1.5px solid var(--line-strong);
  border-radius:var(--r-squircle);overflow:hidden;
}
.qty__btn{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-fast) var(--ease-out);
}
.qty__btn:hover{background:var(--bg-subtle);color:var(--accent)}
.qty__btn .icon{width:16px;height:16px}
.qty__value{
  width:48px;text-align:center;
  font-family:var(--ff-heading);font-weight:var(--fw-semibold);
  font-size:var(--fs-base);font-feature-settings:'tnum';
  border-left:1px solid var(--line);border-right:1px solid var(--line);
}

/* === RANGE SLIDER === */
.range-slider{position:relative;height:36px;display:flex;align-items:center}
.range-slider__track{
  width:100%;height:4px;
  background:var(--line-strong);border-radius:var(--r-pill);
  position:relative;
}
.range-slider__fill{
  position:absolute;height:100%;
  background:var(--accent-gradient);border-radius:var(--r-pill);
}
.range-slider input[type=range]{
  position:absolute;width:100%;height:4px;
  -webkit-appearance:none;appearance:none;
  background:transparent;pointer-events:none;
}
.range-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:20px;height:20px;
  background:var(--bg-card);border:2px solid var(--accent);
  border-radius:var(--r-squircle);
  box-shadow:var(--shadow-sm);
  pointer-events:auto;cursor:pointer;
}

/* === CHECKBOX === */
.checkbox{
  display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;
  font-size:var(--fs-sm);
}
.checkbox__box{
  width:20px;height:20px;
  border:2px solid var(--line-strong);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-fast) var(--ease-out);
  flex-shrink:0;
}
.checkbox input{position:absolute;opacity:0;pointer-events:none}
.checkbox input:checked ~ .checkbox__box{
  background:var(--accent);border-color:var(--accent);
}
.checkbox input:checked ~ .checkbox__box .icon{opacity:1;transform:scale(1)}
.checkbox__box .icon{
  width:14px;height:14px;color:#fff;
  opacity:0;transform:scale(.5);
  transition:all var(--t-fast) var(--ease-spring);
}

/* === INPUT / FORM === */
.input{
  width:100%;
  padding:.7rem 1rem;
  border:1.5px solid var(--line-strong);
  border-radius:var(--r-md);
  background:var(--bg-card);
  font-size:var(--fs-base);
  transition:all var(--t-base) var(--ease-out);
}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.input::placeholder{color:var(--muted-light)}

.input-group{
  display:flex;gap:0;
}
.input-group .input{border-radius:var(--r-badge);border-right:none}
.input-group .btn{border-radius:var(--r-badge-inverse)}

/* === USP CARD === */
.usp-card{
  padding:var(--space-6);
  background:var(--bg-card);
  border:1.5px solid var(--line);
  border-radius:var(--r-card);
  text-align:center;
  transition:all var(--t-slow) var(--ease-out);
  position:relative;
  overflow:hidden;
}
.usp-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--accent-gradient);
  opacity:0;transition:opacity var(--t-base) var(--ease-out);
}
.usp-card:hover::before{opacity:1}
.usp-card::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),transparent);
  opacity:0;transition:opacity var(--t-base) var(--ease-out);
}
.usp-card:hover::after{opacity:1}
.usp-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-glow);
  border-color:var(--accent-soft);
}
.usp-card__icon{
  width:72px;height:72px;
  margin:0 auto var(--space-4);
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);
  border-radius:var(--r-squircle);
}
.usp-card__icon .icon{width:36px;height:36px;color:var(--accent)}
.usp-card__title{
  font-family:var(--ff-heading);font-size:var(--fs-md);font-weight:var(--fw-semibold);
  margin-bottom:var(--space-2);
}
.usp-card__text{font-size:var(--fs-sm);color:var(--muted);line-height:1.6}

/* === PAGINATION === */
.pagination{display:flex;align-items:center;gap:var(--space-2);justify-content:center}
.pagination__btn{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line-strong);
  border-radius:var(--r-squircle);
  font-family:var(--ff-heading);font-size:var(--fs-sm);font-weight:var(--fw-semibold);
  font-feature-settings:'tnum';
  transition:all var(--t-fast) var(--ease-out);
}
.pagination__btn:hover{border-color:var(--accent);color:var(--accent)}
.pagination__btn.is-active{
  background:var(--accent);color:#fff;border-color:var(--accent);
  box-shadow:var(--shadow-neu-sm);
}

/* === DRAWER (mobile filters) === */
.drawer-overlay{
  position:fixed;inset:0;
  background:rgba(20,20,20,.3);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  z-index:var(--z-overlay);
  opacity:0;visibility:hidden;
  transition:all var(--t-base) var(--ease-out);
}
.drawer-overlay.is-open{opacity:1;visibility:visible}

.drawer{
  position:fixed;bottom:0;left:0;right:0;
  max-height:85vh;
  background:var(--bg-card);
  border-radius:var(--r-drawer);
  box-shadow:var(--shadow-lg);
  z-index:calc(var(--z-overlay) + 1);
  transform:translateY(100%);
  transition:transform var(--t-base) var(--ease-out);
  overflow-y:auto;
  padding:var(--space-6);
}
.drawer.is-open{transform:translateY(0)}
.drawer__handle{
  width:36px;height:4px;
  background:var(--line-strong);border-radius:var(--r-pill);
  margin:0 auto var(--space-4);
}

/* === COLOR SWATCH === */
.color-swatches{display:flex;gap:var(--space-2);flex-wrap:wrap}
.color-swatch{
  width:32px;height:32px;
  border-radius:var(--r-squircle);
  border:2px solid transparent;
  outline:2px solid transparent;
  outline-offset:2px;
  cursor:pointer;
  transition:all var(--t-fast) var(--ease-out);
}
.color-swatch:hover{transform:scale(1.15)}
.color-swatch.is-active{
  outline-color:var(--accent);
  box-shadow:2px 2px 0 var(--accent);
}

/* === MEMORY SELECTOR === */
.memory-chips{display:flex;gap:var(--space-2);flex-wrap:wrap}
.memory-chip{
  padding:.4rem 1rem;
  font-family:var(--ff-heading);font-size:var(--fs-sm);font-weight:var(--fw-semibold);
  font-feature-settings:'tnum';
  border:1.5px solid var(--line-strong);
  border-radius:var(--r-btn);
  background:var(--bg-card);
  cursor:pointer;
  transition:all var(--t-fast) var(--ease-out);
}
.memory-chip:hover{border-color:var(--accent);color:var(--accent)}
.memory-chip.is-active{
  background:var(--accent);color:#fff;border-color:var(--accent);
  box-shadow:var(--shadow-neu-sm);
}

/* === AVAILABILITY INDICATOR === */
.availability{display:flex;align-items:center;gap:var(--space-2);font-size:var(--fs-sm)}
.availability__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--success);
  animation:pulse-dot 2s infinite;
}
.availability--order .availability__dot{background:var(--warning);animation:none}

/* === LIGHTBOX === */
.lightbox{
  position:fixed;inset:0;
  background:rgba(20,20,20,.2);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  z-index:var(--z-modal);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:all var(--t-base) var(--ease-out);
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{
  max-width:90vw;max-height:85vh;
  object-fit:contain;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
}
.lightbox__close{
  position:absolute;top:var(--space-6);right:var(--space-6);
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.2);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-radius:50%;color:#fff;
  transition:background var(--t-fast) var(--ease-out);
}
.lightbox__close:hover{background:rgba(255,255,255,.4)}

/* === RESPONSIVE === */
@media(max-width:1399px){
  /* На средне-крупных экранах сокращаем "О нас" чтобы не переносилось */
  .info-nav__link span{font-size:12px}
}
@media(max-width:1279px){
  /* Скрываем маркетинговую ленту в центре topbar — оставляем статус и контакты */
  .topbar__cluster--center{display:none}
  .topbar__inner{grid-template-columns:auto auto}
  .topbar__cluster--right{justify-self:end}
}
@media(max-width:1199px){
  /* Quick-nav: разрешаем горизонтальный скролл info-nav при тесноте */
  .info-nav{overflow-x:auto;scrollbar-width:none}
  .info-nav::-webkit-scrollbar{display:none}
}
@media(max-width:1023px){
  /* Topbar полностью скрываем — только основной хедер + quick-nav */
  .topbar{display:none}
  .header__search{max-width:360px}
  /* Quick-nav остаётся, но с горизонтальным скроллом и без divider */
  .header__quicknav-divider{display:none}
  .info-nav{display:none}
  .mega-menu__grid{grid-template-columns:repeat(3,1fr)}
  .footer__inner{grid-template-columns:repeat(2,1fr)}
  .hero__slide{aspect-ratio:16/9}
}
@media(max-width:767px){
  .mobile-nav{display:flex}
  .header__search{display:none}
  /* На мобильном quick-nav скрываем целиком — категории доступны через mobile-nav */
  .header__quicknav{display:none}
  /* Keep favorites + compare + cart visible; hide only the menu button (there is a bottom "Ещё") */
  .header__actions .header__action--menu,
  .header__actions .header__action[data-action="menu"]{display:none}
  .hero{margin:0;border-radius:0 0 24px 24px}
  .hero__slide{aspect-ratio:4/3}
  .hero__slide-content{padding:var(--space-6)}
  .mega-menu__grid{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr}
  .back-to-top{bottom:calc(var(--mobile-nav-h) + var(--space-4));right:var(--space-4)}
  .fab-contact{bottom:calc(var(--mobile-nav-h) + var(--space-4) + 64px);right:var(--space-4)}
  .fab-contact__trigger{width:50px;height:50px}
  .fab-contact__item{width:44px;height:44px}
  .toast-container{top:auto;bottom:calc(var(--mobile-nav-h) + var(--space-4));right:var(--space-4);left:var(--space-4)}
  .product-card__actions{opacity:1;transform:none}
  .product-card__quick{opacity:1;transform:none}
}
/* Disable hover tooltips on touch devices — JS also bails out */
@media (hover:none){
  .lumo-tooltip{display:none !important}
}

/* ==================== MOBILE AUDIT — fine-tuned responsive fixes ==================== */
@media(max-width:767px){
  /* Global safety: no horizontal jitter, smooth scrolling */
  html,body{max-width:100vw;overflow-x:hidden}
  .container{padding-inline:var(--space-4)}

  /* Smaller section titles + proper wrapping */
  .section-head{flex-direction:column;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-5)}
  .section-head__title{font-size:clamp(1.4rem,6vw,1.9rem);line-height:1.15}
  .section-head__sub{font-size:var(--fs-sm);width:100%;max-width:none;line-height:1.5}
  .section-head__eyebrow{font-size:10px}
  .section-head__count{align-self:flex-end}
  .section-head__link{font-size:13px}

  /* Product cards — tighter padding + smaller prices */
  .product-card__body{padding:var(--space-3)}
  .product-card__title{font-size:var(--fs-sm);min-height:2.4em}
  .price-current{font-size:1.35rem}
  .price-warranty{font-size:.95rem;padding:.5rem .65rem;min-height:40px;gap:6px}
  .price-warranty__label{font-size:8px;padding:.22rem .6rem;max-width:18ch;min-width:min-content}
  .price-warranty::after{font-size:8px;padding:2px 6px}
  .product-card__colors-label{font-size:9px;margin-top:2px}
  .product-card__color{width:16px;height:16px}

  /* Color chip active ring thinner to fit */
  .product-card__color.is-active{box-shadow:0 0 0 2px #fff,0 0 0 3px var(--accent),inset 0 -3px 5px rgba(0,0,0,.12)}

  /* Product card action buttons — full width, stacked */
  .product-card__actions{flex-direction:column;gap:6px;padding:var(--space-3)}
  .product-card__actions .btn{width:100%;font-size:12px}

  /* Header */
  .header__inner{gap:var(--space-2)}
  .header__actions{gap:var(--space-1)}
  .header__action{min-width:42px;padding:6px 6px}
  .header__action-iconwrap{width:28px;height:28px}
  .header__action .icon{width:20px;height:20px}

  /* Mega menu mobile */
  .mega-menu{padding:var(--space-4) !important}

  /* Brands row items compact */
  .brands-row__items{gap:var(--space-4);flex-wrap:wrap;justify-content:center}
  .brands-row__item{height:28px}
  .brands-row__item svg{max-width:90px}

  /* Deals marquee — smaller cards on mobile */
  .deal-card{padding:.6rem .8rem;gap:10px}
  .deal-card__icon{width:34px;height:34px}
  .deal-card__icon .icon{width:18px;height:18px}
  .deal-card__title{font-size:13px}
  .deal-card__tag{font-size:9px}

  /* USP section — disable clip-path on mobile (cuts edges too aggressively) */
  .section-usp{clip-path:none;-webkit-clip-path:none;margin:0 !important;padding:var(--space-section) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .section-usp::before{top:0}
  .section-usp::after{bottom:0}

  /* USP items — tighter */
  .usp-item{padding:var(--space-4);gap:var(--space-3)}
  .usp-item__icon{width:44px;height:44px}
  .usp-item__icon .icon{width:22px;height:22px}
  .usp-item__title{font-size:var(--fs-base)}
  .usp-item__text{font-size:13px}
  .usp-item__features li{font-size:12px}
  /* USP trust card — smaller padding */
  .usp-trust{padding:var(--space-6) var(--space-5)}
  .usp-trust__title{font-size:clamp(1.35rem,6vw,1.75rem)}

  /* Guarantee banner — smaller padding */
  .guarantee-banner{padding:var(--space-12) var(--space-4)}
  .guarantee-banner__stats{grid-template-columns:1fr;gap:var(--space-3)}

  /* Map section */
  .map-section{padding:var(--space-12) 0}
  .map-section__grid{gap:var(--space-4)}
  .map-section__map iframe{min-height:320px}
  .map-section__info{padding:var(--space-5)}
  .map-section__title{font-size:clamp(1.3rem,5vw,1.65rem)}
  .map-section__row-value{font-size:var(--fs-sm)}

  /* Footer refinements */
  .footer__inner{padding-block:var(--space-10) calc(var(--space-8) + var(--mobile-nav-h));padding-inline:var(--space-4);gap:var(--space-6)}
  .footer__col-title{font-size:var(--fs-base)}
  .footer__link-anim{padding:4px 0;gap:8px}
  .footer__link-anim .footer__link-text{font-size:13px}
  .footer__socials{gap:var(--space-2);margin-top:var(--space-3)}
  .footer__social{width:40px;height:40px}
  .footer__logo-tile img{height:36px}
  .footer__contact-row{gap:8px}
  .footer__contact-icon{width:32px;height:32px}
  .footer__contact-icon .icon{width:14px;height:14px}
  .footer__contact-value{font-size:13px;line-height:1.3}

  /* FAB sizing + positioning already set globally — ensure labels don't wrap offscreen */
  .fab-contact__item[data-title]::before{font-size:11px;padding:.3rem .6rem}

  /* Hero nav arrows — hide on small screens, keep dots */
  .hero__nav{width:38px;height:38px}
  .hero__nav .icon{width:16px;height:16px}

  /* === CAROUSEL — native swipe on mobile === */
  .carousel{overflow-x:auto !important;overflow-y:visible;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;touch-action:pan-x;padding-bottom:8px}
  .carousel::-webkit-scrollbar{display:none}
  /* Disable JS-driven transform so native scroll works */
  .carousel__track{transform:none !important;transition:none !important;width:max-content;gap:var(--space-3) !important}
  .carousel__slide{flex:0 0 calc(100vw - 64px) !important;max-width:320px;scroll-snap-align:start}
  .carousel__nav{display:none !important}

  /* Hero actions wrap */
  .hero__slide-actions{width:100%}
  .hero__slide-actions .btn{flex:1 1 auto}

  /* === PRODUCTS GRID on mobile — stacks properly === */
  .grid--products{grid-template-columns:repeat(2,1fr) !important;gap:var(--space-3) !important}

  /* === HEADER actions: all icons visible & tight on mobile === */
  .header__actions{gap:4px}
  .header__action{min-width:40px;padding:6px}
  .header__action-iconwrap{width:26px;height:26px}
  .header__action .icon{width:18px;height:18px}
  .header__action-badge{min-width:14px;height:14px;font-size:9px;top:-2px;right:-2px}

  /* Search dropdown — better mobile layout */
  .search-panel__chipsbar{padding:10px 12px;gap:5px}
  .search-chip{font-size:11.5px;padding:.35rem .7rem}
  .search-tag{font-size:11.5px;padding:.3rem .65rem}
  .search-panel__body{padding:12px 14px 4px;max-height:48vh}
  .search-panel__advanced-trigger{padding:10px 14px;font-size:10.5px}
  .search-panel__advanced-body{padding:4px 14px 12px}
  .search-panel__footer{padding:9px 14px;flex-wrap:wrap}
  .search-panel__hint{font-size:10.5px}
  .search-panel__all{font-size:11.5px}
  .header__search-dropdown{border-radius:16px}

  /* Section paddings tighter */
  .section{padding:var(--space-12) 0}

  /* Quick action buttons visible always on mobile */
  .product-card__quick{opacity:1;transform:none;gap:6px}
  .product-card__quick-btn{width:32px;height:32px}
  .product-card__quick-btn .icon{width:14px;height:14px}

  /* Ensure any fixed overlap reserves space for mobile nav */
  main,.footer{padding-bottom:0}

  /* Topbar fully hidden on mobile already but keep safety */
  .topbar{display:none !important}

  /* Header inner fits tight */
  .header__inner{justify-content:space-between;padding-inline:0}
  .header__logo img{height:38px}

  /* Mobile nav bar baseline */
  .mobile-nav{padding:0;box-shadow:0 -10px 30px rgba(0,0,0,.08),0 -1px 0 var(--line)}
  .mobile-nav__item{font-size:10px;letter-spacing:.04em;gap:3px}
  .mobile-nav__item .icon{width:20px;height:20px}

  /* Guarantee banner — slimmer on mobile, stat card tighter */
  .guarantee-banner{border-radius:var(--r-lg)}
  .guarantee-banner__stat{padding:var(--space-5) var(--space-3)}
  .guarantee-banner__stat-num{font-size:clamp(1.9rem,9vw,2.4rem)}
  .guarantee-banner__cta{flex-direction:column;gap:10px;margin-top:var(--space-6)}
  .guarantee-banner__cta .btn{width:100%}

  /* Category tile sizes optimised */
  .category-tile{padding:var(--space-4)}
  .category-tile__title{font-size:var(--fs-lg)}
  .category-tile__meta{font-size:11px}

  /* Deals marquee — keep continuous flow, cap card width */
  .deals-marquee{padding-block:var(--space-2)}
  .deal-card{min-width:220px}
  .deal-card__title{white-space:normal;line-height:1.2}

  /* USP trust card stats */
  .usp-trust__stats{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}
  .usp-trust__stat{padding:var(--space-3)}
  .usp-trust__stat-value{font-size:clamp(1.3rem,6vw,1.65rem)}
  .usp-trust__stat-label{font-size:10px}

  /* USP items — ensure no overflow of feature chips */
  .usp-item__features{gap:4px 8px}
  .usp-item__link{font-size:12px}
  .usp-item__chip{font-size:9.5px;padding:.2rem .55rem}

  /* Brands row — reduce vertical padding, compact text */
  .brands-row{padding:var(--space-5) var(--space-4);gap:var(--space-5);border-radius:var(--r-lg)}
  .brands-row__label{width:100%;text-align:center;margin-bottom:var(--space-2)}

  /* Map info compact, buttons full width */
  .map-section__row{gap:10px}
  .map-section__row-icon{width:32px;height:32px}
  .map-section__row-icon .icon{width:14px;height:14px}
  .map-section__actions{flex-direction:column;gap:8px}
  .map-section__actions .btn{width:100%}

  /* Back-to-top inner size */
  .back-to-top__inner{width:36px;height:36px}
  .back-to-top svg{width:46px;height:46px}

  /* Preloader text compact */
  .preloader__brand{font-size:clamp(2rem,10vw,2.6rem)}
  .preloader__msg{font-size:12px}
  .preloader__percent{font-size:26px}

  /* Mega-menu pane takes full viewport width when open */
  .mega-menu{border-radius:0 0 var(--r-lg) var(--r-lg);max-width:100vw}

  /* ============ HERO mobile tweaks (см. также pages.css) ============ */
  /* На мобильном скрываем 4-й feature чтобы не растягивать слайд */
  .hero__slide-features .hero__slide-feature:nth-child(n+4){display:none}
  /* Скрываем ghost-CTA — primary достаточно на узком экране */
  .hero__slide-cta--ghost{display:none}

  /* ============ FOOTER brand row (title + logo in one line) ============ */
  .footer__brand{display:grid;grid-template-columns:1fr auto;grid-template-areas:"title logo" "text text" "socials socials";gap:var(--space-3) var(--space-3);align-items:center}
  .footer__brand .footer__col-title{grid-area:title;margin-bottom:0}
  .footer__brand .footer__logo-tile{grid-area:logo;margin:0;padding:4px 10px;min-height:auto}
  .footer__brand .footer__logo-tile img{height:30px}
  .footer__brand .footer__brand-text{grid-area:text;margin:0;font-size:13px;line-height:1.5}
  .footer__brand .footer__socials{grid-area:socials;margin-top:var(--space-2)}

  /* Footer columns spacing + dividers */
  .footer__inner > *{padding-bottom:var(--space-5);border-bottom:1px solid var(--line)}
  .footer__inner > *:last-child{border-bottom:none;padding-bottom:0}
  .footer__inner > * + *{padding-top:var(--space-2)}
  .footer__col-title{margin-bottom:var(--space-3) !important}

  /* Manager social — ensure visible with label on mobile */
  .footer__socials{flex-wrap:wrap;gap:var(--space-2)}
  .footer__social{position:relative}

  /* ============ MOBILE BOTTOM NAV — stretched & even ============ */
  .mobile-nav{width:100%}
  .mobile-nav__inner{
    display:grid !important;
    grid-template-columns:repeat(5,1fr);
    width:100% !important;
    max-width:100%;
    padding:0;
    gap:0;
  }
  .mobile-nav__item{
    width:100%;height:100%;
    display:flex !important;
    flex-direction:column;align-items:center;justify-content:center;
    padding:6px 2px;gap:3px;
    min-width:0;
    text-align:center;
  }
  .mobile-nav__item .icon{width:22px;height:22px;flex-shrink:0}
  .mobile-nav__item span{font-size:10.5px;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}
}

/* Extra-small screens — iPhone SE and similar */
@media(max-width:479px){
  .container{padding-inline:14px}
  .section{padding:var(--space-10) 0}
  .section-head__title{font-size:clamp(1.25rem,6vw,1.6rem)}
  .section-head__eyebrow{letter-spacing:.12em}
  .product-card__img{aspect-ratio:4/3}

  /* Collapse product-card prices vertical spacing */
  .product-card__prices{gap:3px;padding-top:var(--space-1)}

  /* Make warranty label compact on tiny cards */
  .price-warranty{padding:.45rem .6rem}
  .price-warranty .icon{width:14px;height:14px}
  .price-warranty__label{font-size:7.5px;letter-spacing:.04em;max-width:16ch;min-width:min-content}

  /* Deals marquee — even more compact */
  .deal-card{min-width:200px;padding:.5rem .65rem;gap:8px}
  .deal-card__icon{width:30px;height:30px}
  .deal-card__title{font-size:12px}
  .deal-card__tag{font-size:8px}

  /* USP stats grid 1-col */
  .usp-trust__stats{grid-template-columns:1fr;gap:var(--space-3)}
  .usp-trust{padding:var(--space-5) var(--space-4)}
  .usp-trust__title{font-size:clamp(1.2rem,6vw,1.5rem)}
  .usp-trust__eyebrow{font-size:10px}

  /* USP items — single column, tighter header layout */
  .usp-item{padding:var(--space-4)}
  .usp-item__head{gap:var(--space-2)}
  .usp-item__title{font-size:var(--fs-base)}
  .usp-item__text{font-size:12.5px}

  /* Guarantee banner title compression + padding */
  .guarantee-banner{padding:var(--space-10) var(--space-4)}
  .guarantee-banner h2{font-size:clamp(1.4rem,7vw,2rem) !important}
  .guarantee-banner__stat{padding:var(--space-4) var(--space-3)}
  .guarantee-banner__stat-label{font-size:11px;margin-top:var(--space-1)}

  /* Brand row items smaller */
  .brands-row__item svg{max-width:72px}
  .brands-row__item--text{font-size:var(--fs-sm) !important}
  .brands-row{gap:var(--space-4)}

  /* Map section tighter */
  .map-section__info{padding:var(--space-4)}
  .map-section__map iframe{min-height:260px}

  /* Footer — even more compact on small mobile */
  .footer__inner{padding-top:var(--space-8);gap:var(--space-5)}
  .footer__col-title{font-size:var(--fs-sm);margin-bottom:var(--space-2)}
  .footer__social{width:38px;height:38px}
  .footer__logo-tile img{height:32px}
  .footer__bottom{font-size:11px;flex-direction:column;gap:10px;text-align:center}

  /* Back-to-top and FAB slightly smaller */
  .back-to-top{width:44px;height:44px}
  .back-to-top__inner{width:32px;height:32px}
  .back-to-top svg{width:42px;height:42px}
  .fab-contact__trigger{width:48px;height:48px}
  .fab-contact__item{width:42px;height:42px}

  /* Hero slide tweaks */
  .home-hero .hero__slide{min-height:480px}
  .home-hero .hero__slide-features{flex-wrap:wrap;gap:4px}
  .home-hero .hero__slide-feature{padding:.25rem .5rem .25rem .25rem;font-size:10px}
  .home-hero .hero__slide-content h2{font-size:clamp(1.3rem,7vw,1.7rem)}
  .home-hero .hero__slide-content p{font-size:13px}
  .home-hero .hero__slide-product{max-width:42%}
  .hero__slide-actions{flex-direction:column;width:100%}
  .hero__slide-actions .btn{width:100%}

  /* Product card action buttons compact font */
  .product-card__title{font-size:13px;min-height:2.2em}
  .price-current{font-size:1.25rem}
  .product-card__actions .btn{font-size:11.5px;padding:.55rem .8rem}

  /* Mobile-nav very compact */
  .mobile-nav__item{font-size:9.5px}
  .mobile-nav__item .icon{width:18px;height:18px}
}

/* === ANIMATION CLASSES (scroll-triggered) === */
@keyframes fade-up{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
@keyframes scale-in{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
@keyframes slide-left{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}
@keyframes slide-right{from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:translateX(0)}}

.anim-fade-up{opacity:0;transform:translateY(24px);transition:all var(--t-slower) var(--ease-out)}
.anim-fade-in{opacity:0;transition:opacity var(--t-slower) var(--ease-out)}
.anim-scale-in{opacity:0;transform:scale(.9);transition:all var(--t-slower) var(--ease-spring)}
.anim-slide-left{opacity:0;transform:translateX(32px);transition:all var(--t-slower) var(--ease-out)}
.anim-slide-right{opacity:0;transform:translateX(-32px);transition:all var(--t-slower) var(--ease-out)}

.is-visible{opacity:1!important;transform:none!important}
