/* ============================================================
   КЛИМАТ ПРО — ecom-блоки: мега-меню, отзывы, exit-intent,
   срочность, доставка, рассрочка, комплект, FAQ, 1 клик
   Использует токены из styles.css. Плотность «просторно».
   ============================================================ */

/* ===================== МЕГА-МЕНЮ ===================== */
.mega-wrap { position: relative; }
.hdr-catalog.is-open { background: var(--accent); color: var(--on-accent); }
.mega-panel {
  position: absolute; top: calc(100% + 14px); left: 0; z-index: 80;
  display: grid; grid-template-columns: 268px 1fr 232px;
  width: min(960px, calc(100vw - 48px));
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); box-shadow: var(--sh-lg); overflow: hidden;
  animation: megaIn .16s ease both;
}
@keyframes megaIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
.mega-panel::before { content: ""; position: absolute; top: -14px; left: 0; right: 0; height: 14px; }

.mega-rail { background: var(--surface-2); padding: 12px; display: flex; flex-direction: column; gap: 2px; }
.mega-cat {
  display: flex; align-items: center; gap: 12px; width: 100%;
  padding: 12px 14px; border: 0; background: none; border-radius: var(--r-sm);
  cursor: pointer; text-align: left; color: var(--ink-2); font: inherit; font-weight: 600; font-size: 14.5px;
  transition: background .14s, color .14s;
}
.mega-cat svg { color: var(--accent); flex-shrink: 0; }
.mega-cat-name { flex: 1; min-width: 0; }
.mega-cat-count { font-size: 12px; color: var(--muted-2); font-weight: 600; }
.mega-cat-arr { color: var(--muted-2); opacity: 0; transform: translateX(-4px); transition: .14s; }
.mega-cat:hover, .mega-cat.active { background: var(--surface); color: var(--accent); box-shadow: var(--sh-sm); }
.mega-cat.active .mega-cat-arr { opacity: 1; transform: none; }
.mega-rail-div { height: 1px; background: var(--line); margin: 10px 6px; }
.mega-cat-quick { font-weight: 600; color: var(--muted); font-size: 13.5px; }
.mega-cat-quick svg { color: var(--warm); }
.mega-cat-quick:hover { color: var(--warm); }

.mega-mid { padding: 22px 26px; }
.mega-mid-h {
  display: inline-flex; align-items: center; gap: 8px; border: 0; background: none;
  font: inherit; font-weight: 800; font-size: 18px; color: var(--ink); cursor: pointer; padding: 0; margin-bottom: 16px;
}
.mega-mid-h svg { color: var(--accent); }
.mega-mid-h:hover { color: var(--accent); }
.mega-sublist { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 18px; margin-bottom: 22px; }
.mega-sub {
  text-align: left; border: 0; background: none; font: inherit; font-size: 14px; color: var(--muted);
  padding: 7px 0; cursor: pointer; border-radius: 6px; transition: color .12s; position: relative;
}
.mega-sub:hover { color: var(--accent); padding-left: 6px; }
.mega-brands-h { font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 12px; }
.mega-brand-row { display: flex; flex-wrap: wrap; gap: 8px; }
.mega-brand {
  display: inline-flex; align-items: center; gap: 8px; padding: 7px 13px 7px 7px;
  background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-pill);
  font: inherit; font-size: 13px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: .14s;
}
.mega-brand:hover { border-color: var(--accent); color: var(--accent); }
.mega-brand-logo { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 12px; }

.mega-promo {
  position: relative; overflow: hidden; border: 0; cursor: pointer; text-align: left;
  display: flex; flex-direction: column; gap: 6px; padding: 26px 22px;
  background: linear-gradient(155deg, var(--accent-strong), var(--accent)); color: #fff;
}
.mega-promo-eyebrow { font-size: 12px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; opacity: .8; }
.mega-promo-title { font-size: 26px; font-weight: 800; line-height: 1.05; }
.mega-promo-text { font-size: 13.5px; opacity: .9; margin-bottom: 8px; }
.mega-promo-cta { margin-top: auto; display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: 14px; }
.mega-promo-glow { position: absolute; right: -50px; top: -50px; width: 180px; height: 180px; border-radius: 50%; background: rgba(255,255,255,.12); }
.mega-promo:hover .mega-promo-cta { gap: 11px; }

@media (max-width: 900px) { .mega-wrap { display: none; } }

/* ===================== ОТЗЫВЫ ===================== */
.rev-block { display: grid; grid-template-columns: 280px 1fr; gap: 30px; align-items: start; }
@media (max-width: 820px) { .rev-block { grid-template-columns: 1fr; } }

.rev-summary { padding: 24px; position: sticky; top: 96px; text-align: center; }
.rev-avg { font-size: 52px; font-weight: 800; line-height: 1; color: var(--ink); }
.rev-bars { display: flex; flex-direction: column; gap: 7px; margin: 18px 0; }
.rev-bar-row { display: grid; grid-template-columns: 34px 1fr 24px; align-items: center; gap: 8px; }
.rev-bar { height: 7px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden; }
.rev-bar i { display: block; height: 100%; background: var(--warm); border-radius: var(--r-pill); }
.rev-recommend { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; font-weight: 600; color: var(--ink-2); margin-bottom: 16px; }

.rev-main { min-width: 0; }
.rev-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; flex-wrap: wrap; }
.rev-filters { display: flex; flex-wrap: wrap; gap: 8px; }
.select-sm { padding: 9px 30px 9px 14px; font-size: 13.5px; border-radius: var(--r-sm); }

.rev-list { display: flex; flex-direction: column; gap: 16px; }
.rev-card-rich { padding: 22px; }
.rev-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 2px; }
.rev-verified { display: inline-flex; align-items: center; gap: 4px; color: var(--eco); font-weight: 600; }
.rev-verified svg { stroke-width: 2.6; }
.rev-text { margin: 14px 0 0; line-height: 1.6; color: var(--ink-2); }
.rev-more {
  display: inline-flex; align-items: center; gap: 5px; margin-top: 8px; padding: 0;
  border: 0; background: none; color: var(--accent); font: inherit; font-weight: 600; font-size: 14px; cursor: pointer;
}
.rev-more:hover { text-decoration: underline; }

.rev-procon { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 16px; }
@media (max-width: 560px) { .rev-procon { grid-template-columns: 1fr; } }
.rev-pc { padding: 12px 14px; border-radius: var(--r-sm); font-size: 13.5px; line-height: 1.5; color: var(--ink-2); }
.rev-pc-h { display: flex; align-items: center; gap: 6px; font-weight: 700; font-size: 12.5px; margin-bottom: 5px; }
.rev-pc-pro { background: var(--eco-soft); }
.rev-pc-pro .rev-pc-h { color: var(--eco); }
.rev-pc-con { background: var(--surface-2); }
.rev-pc-con .rev-pc-h { color: var(--muted); }

.rev-photos { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.rev-photo { width: 72px; height: 72px; border-radius: var(--r-sm); background: var(--surface-3); display: grid; place-items: center; color: var(--brand-300); border: 1px solid var(--line); }

.rev-reply { margin-top: 16px; padding: 14px 16px; background: var(--accent-tint); border-radius: var(--r-md); border-left: 3px solid var(--accent); }
.rev-reply-h { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 13px; color: var(--accent-strong); margin-bottom: 5px; }
.rev-reply-logo { width: 22px; height: 22px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; }
.rev-reply p { margin: 0; line-height: 1.5; }

.rev-actions { margin-top: 16px; }
.rev-helpful {
  display: inline-flex; align-items: center; gap: 7px; padding: 8px 16px;
  border: 1px solid var(--line); background: var(--surface); border-radius: var(--r-pill);
  font: inherit; font-size: 13px; font-weight: 600; color: var(--muted); cursor: pointer; transition: .14s;
}
.rev-helpful:hover { border-color: var(--accent); color: var(--accent); }
.rev-helpful.on { background: var(--accent-tint); border-color: var(--accent); color: var(--accent-strong); }

/* leave-review form */
.rev-form { padding: 24px; margin-bottom: 20px; display: flex; flex-direction: column; gap: 14px; animation: megaIn .18s ease both; }
.rev-form-rate { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.rev-star-pick:hover svg { opacity: 1 !important; transform: scale(1.12); }
.rev-form-rateval { font-weight: 700; color: var(--warm); }
.rev-form-pc { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 560px) { .rev-form-pc { grid-template-columns: 1fr; } }
.rev-form-photo {
  align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px;
  border: 1.5px dashed var(--line); border-radius: var(--r-sm); background: var(--surface-2);
  font: inherit; font-size: 13.5px; font-weight: 600; color: var(--muted); cursor: pointer; transition: .14s;
}
.rev-form-photo:hover { border-color: var(--accent); color: var(--accent); }

/* ===================== EXIT-INTENT ===================== */
.exit-overlay {
  position: fixed; inset: 0; z-index: 200; background: rgba(10,26,36,.55); backdrop-filter: blur(4px);
  display: grid; place-items: center; padding: 24px; animation: fadeIn .2s ease both;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.exit-modal { position: relative; width: min(760px, 100%); padding: 0; overflow: hidden; animation: popIn .24s cubic-bezier(.2,.9,.3,1.1) both; }
@keyframes popIn { from { opacity: 0; transform: scale(.94) translateY(10px); } to { opacity: 1; transform: none; } }
.exit-close { position: absolute; top: 14px; right: 14px; z-index: 3; }
.exit-grid { display: grid; grid-template-columns: 1fr 280px; }
@media (max-width: 680px) { .exit-grid { grid-template-columns: 1fr; } .exit-right { display: none; } }
.exit-left { padding: 36px; }
.exit-chip { background: var(--warm-soft); color: var(--warm); border-color: transparent; }
.exit-code { display: flex; align-items: stretch; gap: 12px; margin: 20px 0 14px; }
.exit-code-box { flex: 1; padding: 12px 16px; border: 1.5px dashed var(--accent); border-radius: var(--r-md); background: var(--accent-tint); }
.promo-code { font-size: 22px; font-weight: 800; letter-spacing: .06em; color: var(--accent-strong); }
.exit-save { display: flex; gap: 10px; }
.exit-save .input { flex: 1; }
.exit-saved { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: var(--eco-soft); border-radius: var(--r-md); font-size: 14px; color: var(--ink-2); }
.exit-perk { display: inline-flex; align-items: center; gap: 6px; }
.exit-perk svg { color: var(--accent); }

.exit-right { background: var(--surface-2); padding: 28px 24px; display: flex; flex-direction: column; }
.exit-mini-h { font-weight: 700; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 14px; }
.exit-mini { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--line); }
.exit-mini-thumb { width: 40px; height: 40px; border-radius: var(--r-sm); background: var(--surface-3); display: grid; place-items: center; color: var(--brand-300); flex-shrink: 0; }
.exit-mini-name { flex: 1; min-width: 0; line-height: 1.3; }
.exit-mini-total { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; }
.exit-mini-disc { padding-top: 6px; color: var(--warm); }
.exit-mini-disc strong { color: var(--warm); }

/* ===================== 1 КЛИК ===================== */
.oneclick { position: relative; width: min(440px, 100%); padding: 32px; animation: popIn .24s cubic-bezier(.2,.9,.3,1.1) both; }
.oneclick-prod { display: flex; align-items: center; gap: 12px; padding: 14px; background: var(--surface-2); border-radius: var(--r-md); }
.oneclick-done { text-align: center; padding: 8px 0; }
.oneclick-check { width: 64px; height: 64px; border-radius: 50%; background: var(--eco-soft); color: var(--eco); display: grid; place-items: center; margin: 0 auto 16px; }
.oneclick-check svg { stroke-width: 2.4; }

/* ===================== СРОЧНОСТЬ / СКЛАД ===================== */
.stock-pill {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: var(--r-pill);
  font-size: 13.5px; font-weight: 700; background: var(--eco-soft); color: var(--eco);
}
.stock-pill.low { background: var(--warm-soft); color: var(--warm); }
.stock-dot { width: 8px; height: 8px; border-radius: 50%; background: currentColor; box-shadow: 0 0 0 0 currentColor; animation: stockPulse 1.8s infinite; }
@keyframes stockPulse { 0% { box-shadow: 0 0 0 0 rgba(232,115,44,.5); } 70% { box-shadow: 0 0 0 7px rgba(232,115,44,0); } 100% { box-shadow: 0 0 0 0 rgba(232,115,44,0); } }

/* ===================== ДОСТАВКА ===================== */
.deliv { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: var(--accent-tint); border-radius: var(--r-md); margin: 4px 0; }
.deliv-ic { width: 40px; height: 40px; border-radius: var(--r-sm); background: var(--surface); display: grid; place-items: center; color: var(--accent); flex-shrink: 0; }
.deliv-compact { padding: 10px 12px; }

/* ===================== РАССРОЧКА ===================== */
.instal { padding: 16px 18px; margin: 4px 0; display: flex; flex-direction: column; gap: 12px; }
.instal-head { display: flex; gap: 11px; align-items: flex-start; }
.instal-ic { flex-shrink: 0; width: 36px; height: 36px; border-radius: var(--r-sm); background: var(--accent-tint); color: var(--accent); display: grid; place-items: center; }
.instal-head strong { display: block; font-size: 15px; color: var(--ink); }
.instal-head .muted { display: block; margin-top: 2px; line-height: 1.4; }
.instal-form { display: flex; flex-direction: column; gap: 8px; }
.instal-form .qlead-input { padding: 12px 14px; font-size: 15px; }
.instal-btn.is-off { opacity: .55; }
.instal-done { display: flex; align-items: center; gap: 8px; padding: 11px 13px; border-radius: var(--r-sm); background: var(--eco-soft); color: var(--eco); font-size: 13.5px; font-weight: 600; }

/* ===================== ОПЛАТА ===================== */
.paymethods { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.paymethod { display: inline-flex; align-items: center; gap: 6px; padding: 7px 12px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-pill); font-size: 12.5px; font-weight: 600; color: var(--muted); }
.paymethod svg { color: var(--accent); }

/* ===================== КОМПЛЕКТ ===================== */
.bundle { display: grid; grid-template-columns: 1fr 280px; gap: 24px; padding: 26px; align-items: center; }
@media (max-width: 760px) { .bundle { grid-template-columns: 1fr; } }
.bundle-parts { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.bundle-part { flex: 1; min-width: 120px; display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 18px 12px; background: var(--surface-2); border-radius: var(--r-md); text-align: center; }
.bundle-part-ic { width: 56px; height: 56px; border-radius: var(--r-md); background: var(--surface); display: grid; place-items: center; color: var(--accent); }
.bundle-part-name { line-height: 1.3; }
.bundle-plus { color: var(--muted-2); flex-shrink: 0; }
.bundle-buy { padding: 22px; background: var(--accent-tint); border-radius: var(--r-md); text-align: center; }
.bundle-save { display: inline-block; margin-top: 6px; padding: 5px 12px; background: var(--eco); color: #fff; border-radius: var(--r-pill); font-size: 13px; font-weight: 700; }

/* ===================== FAQ ===================== */
.faq-list { display: flex; flex-direction: column; gap: 12px; max-width: 860px; }
.faq-item { padding: 0; overflow: hidden; transition: box-shadow .15s; }
.faq-item.open { box-shadow: var(--sh-md); }
.faq-q {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; width: 100%;
  padding: 20px 24px; border: 0; background: none; cursor: pointer; text-align: left;
  font: inherit; font-weight: 700; font-size: 16px; color: var(--ink);
}
.faq-ic { width: 32px; height: 32px; border-radius: 50%; background: var(--surface-2); display: grid; place-items: center; color: var(--accent); flex-shrink: 0; transition: .15s; }
.faq-item.open .faq-ic { background: var(--accent); color: #fff; }
.faq-a { padding: 0 24px 22px; animation: faqIn .2s ease both; }
.faq-a p { margin: 0; line-height: 1.65; max-width: 680px; }
@keyframes faqIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }

.btn-icon-sm { width: 34px; height: 34px; }

/* ===================== СТАТУС СКЛАДА НА КАРТОЧКЕ ===================== */
.pcard-stock { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; color: var(--warm); margin-top: 2px; }
.pcard-stock.in { color: var(--eco); }
.pcard-stock.in svg { stroke-width: 2.6; }
.pcard-stock.order { color: var(--muted-2); }
.pcard-stock-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--warm); animation: stockPulse 1.8s infinite; }

/* ===================== ТРАСТ-СТРИП КАТАЛОГА ===================== */
.cat-trust { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 860px) { .cat-trust { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .cat-trust { grid-template-columns: 1fr; } }
.cat-trust-item { display: flex; align-items: center; gap: 14px; padding: 20px 22px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); }
.cat-trust-ic { width: 48px; height: 48px; border-radius: var(--r-md); background: var(--accent-tint); color: var(--accent); display: grid; place-items: center; flex-shrink: 0; }

/* ===================== АВТОРИЗАЦИЯ ===================== */
.auth-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; max-width: 940px; margin: 8px auto 0; }
@media (max-width: 760px) { .auth-wrap { grid-template-columns: 1fr; } .auth-perks { order: -1; } }
.auth-card { padding: 28px; }
.auth-tabs { display: flex; gap: 4px; padding: 4px; background: var(--surface-2); border-radius: var(--r-pill); margin-bottom: 22px; }
.auth-tab { flex: 1; padding: 11px; border: 0; background: none; border-radius: var(--r-pill); font: inherit; font-weight: 600; font-size: 14.5px; color: var(--muted); cursor: pointer; transition: .15s; }
.auth-tab.active { background: var(--surface); color: var(--accent); box-shadow: var(--sh-sm); }
.auth-agree { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.auth-agree input, .acc-notif input { position: absolute; opacity: 0; width: 0; height: 0; }
.auth-or { display: flex; align-items: center; gap: 12px; margin: 22px 0 16px; color: var(--muted-2); font-size: 13px; }
.auth-or::before, .auth-or::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.auth-socials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.auth-social { padding: 11px; border: 1px solid var(--line); background: var(--surface); border-radius: var(--r-sm); font: inherit; font-size: 13.5px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: .14s; }
.auth-social:hover { border-color: var(--accent); color: var(--accent); }
.auth-perks { padding: 8px 0 0; }
.auth-perk-list { list-style: none; padding: 0; margin: 22px 0 0; display: flex; flex-direction: column; gap: 18px; }
.auth-perk { display: flex; align-items: flex-start; gap: 14px; }
.auth-perk-ic { width: 46px; height: 46px; border-radius: var(--r-md); background: var(--accent-tint); color: var(--accent); display: grid; place-items: center; flex-shrink: 0; }

/* ===================== ШАПКА КАБИНЕТА ===================== */
.acc-level-pill { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--r-pill); background: linear-gradient(135deg, var(--accent-strong), var(--accent)); color: #fff; font-size: 13px; font-weight: 700; }
.acc-level-pill svg { color: #FFD66B; }
@media (max-width: 600px) { .acc-level-pill { display: none; } }

/* ===================== ЛОЯЛЬНОСТЬ ===================== */
.loyalty-card { position: relative; overflow: hidden; padding: 24px 26px; border-radius: var(--r-lg); background: linear-gradient(135deg, var(--brand-800), var(--accent)); color: #fff; }
.loyalty-glow { position: absolute; right: -40px; top: -60px; width: 200px; height: 200px; border-radius: 50%; background: rgba(255,255,255,.12); }
.loyalty-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; position: relative; }
.loyalty-eyebrow { font-size: 12.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; opacity: .8; }
.loyalty-points { font-size: 34px; font-weight: 800; line-height: 1.1; margin-top: 4px; }
.loyalty-points span { font-size: 16px; font-weight: 500; opacity: .8; }
.loyalty-badge { display: inline-flex; align-items: center; gap: 6px; padding: 7px 13px; border-radius: var(--r-pill); background: rgba(255,255,255,.18); font-size: 13px; font-weight: 700; white-space: nowrap; }
.loyalty-prog { margin-top: 20px; position: relative; }
.loyalty-bar { height: 8px; background: rgba(255,255,255,.22); border-radius: var(--r-pill); overflow: hidden; }
.loyalty-bar i { display: block; height: 100%; background: #fff; border-radius: var(--r-pill); transition: width .5s; }
.loyalty-prog-lbl { display: block; margin-top: 10px; font-size: 13px; opacity: .92; }

.loyalty-levels { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 560px) { .loyalty-levels { grid-template-columns: 1fr; } }
.loyalty-level { position: relative; padding: 18px; border: 1.5px solid var(--line); border-radius: var(--r-md); background: var(--surface); }
.loyalty-level.reached { border-color: var(--accent-soft); background: var(--accent-tint); }
.loyalty-level.current { border-color: var(--accent); box-shadow: var(--sh-md); }
.loyalty-level-name { font-weight: 800; font-size: 17px; color: var(--ink); display: block; }
.loyalty-level-rate { color: var(--accent); font-weight: 700; font-size: 14px; display: block; margin: 4px 0; }
.loyalty-level-tag { position: absolute; top: 14px; right: 14px; padding: 4px 10px; background: var(--accent); color: #fff; border-radius: var(--r-pill); font-size: 11px; font-weight: 700; }

.bonus-hist { padding: 6px 18px; }
.bonus-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--line-2); }
.bonus-row:last-child { border-bottom: 0; }
.bonus-plus { color: var(--eco); }
.bonus-minus { color: var(--muted); }

/* ===================== ОБЗОР ===================== */
.acc-soon { max-width: 640px; margin: 20px auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 30px 20px; }
.acc-soon h1 { margin: 4px 0 0; line-height: 1.15; font-size: clamp(26px, 4vw, 34px); }
.acc-soon-sub { margin: 0; }
.acc-soon-ic { width: 84px; height: 84px; border-radius: 50%; background: var(--accent-tint); color: var(--accent); display: grid; place-items: center; }
.acc-soon-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--warm-soft); color: var(--warm); }
.acc-soon-sub { max-width: 480px; line-height: 1.6; }
.acc-soon-feats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; width: 100%; max-width: 460px; margin: 8px 0; }
.acc-soon-feat { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--surface); font-weight: 600; font-size: 14px; color: var(--ink-2); text-align: left; }
.acc-soon-feat > svg { color: var(--accent); flex-shrink: 0; }
.acc-soon-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-top: 8px; }
@media (max-width: 480px) { .acc-soon-feats { grid-template-columns: 1fr; } .acc-soon-actions { flex-direction: column; width: 100%; } .acc-soon-actions .btn { width: 100%; } }

.acc-overview-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 760px) { .acc-overview-grid { grid-template-columns: 1fr; } }
.acc-widget { padding: 20px; display: flex; flex-direction: column; gap: 6px; align-items: flex-start; }
.acc-widget-h { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 2px; }
.acc-widget-h svg { color: var(--accent); }
.acc-widget .btn { margin-top: 8px; }
.acc-widget-warn { border: 1.5px solid var(--warm-soft); background: linear-gradient(180deg, var(--warm-soft), var(--surface)); }
.acc-widget-warn .acc-widget-h svg { color: var(--warm); }
.acc-section-h { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }

/* ===================== МОИ КОНДИЦИОНЕРЫ ===================== */
.acc-hint { display: flex; align-items: center; gap: 14px; padding: 16px 18px; }
.device { padding: 20px; }
.device-urgent { border: 1.5px solid var(--warm-soft); }
.device-main { display: flex; gap: 16px; align-items: center; }
.device-thumb { width: 76px; height: 76px; border-radius: var(--r-md); overflow: hidden; background: var(--surface-2); flex-shrink: 0; }
.device-info { min-width: 0; }
.device-name { font-size: 17px; font-weight: 700; color: var(--ink); }
.device-room { display: inline-flex; align-items: center; gap: 4px; font-size: 12.5px; font-weight: 600; color: var(--muted); background: var(--surface-2); padding: 3px 10px; border-radius: var(--r-pill); }
.device-meta { display: flex; flex-wrap: wrap; gap: 6px 16px; margin-top: 8px; }
.device-warranty { display: inline-flex; align-items: center; gap: 5px; color: var(--eco); font-weight: 600; }
.device-reminder { display: flex; align-items: center; gap: 12px; margin-top: 16px; padding: 14px 16px; background: var(--accent-tint); border-radius: var(--r-md); }
.device-reminder.urgent { background: var(--warm-soft); }
.device-rem-ic { width: 40px; height: 40px; border-radius: 50%; background: var(--surface); display: grid; place-items: center; color: var(--accent); flex-shrink: 0; }
.device-reminder.urgent .device-rem-ic { color: var(--warm); }
.device-actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.device-act { display: inline-flex; align-items: center; gap: 6px; padding: 9px 14px; border: 1px solid var(--line); background: var(--surface); border-radius: var(--r-pill); font: inherit; font-size: 13px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: .14s; }
.device-act:hover { border-color: var(--accent); color: var(--accent); }
.device-act svg { color: var(--accent); }

/* ===================== ДОКУМЕНТЫ ===================== */
.docs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 600px) { .docs-grid { grid-template-columns: 1fr; } }
.doc-card { display: flex; align-items: center; gap: 14px; padding: 18px; }
.doc-ic { width: 46px; height: 46px; border-radius: var(--r-md); display: grid; place-items: center; flex-shrink: 0; }
.doc-ic-eco { background: var(--eco-soft); color: var(--eco); }
.doc-ic-accent { background: var(--accent-tint); color: var(--accent); }
.acc-notif { display: flex; align-items: center; gap: 10px; cursor: pointer; }

/* ===================== СОЦ. ДОКАЗАТЕЛЬСТВО ===================== */
.social-proof { display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 4px 0 18px; }
.sp-item { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); }
.sp-item strong { color: var(--ink); }
.sp-item svg { color: var(--muted-2); }
.sp-live { color: var(--eco); }
.sp-live strong { color: var(--eco); }
.sp-eye { display: inline-grid; place-items: center; color: var(--eco); position: relative; }
.sp-eye::after { content: ""; position: absolute; right: -3px; top: -1px; width: 6px; height: 6px; border-radius: 50%; background: var(--eco); animation: stockPulse 1.6s infinite; }

/* ===================== ТИКЕР ПОКУПОК ===================== */
.purchase-pop {
  position: fixed; left: 20px; bottom: 24px; z-index: 150; display: flex; align-items: center; gap: 12px;
  max-width: 320px; padding: 12px 14px; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); box-shadow: var(--sh-lg); cursor: pointer; text-align: left;
  animation: purchaseIn .4s cubic-bezier(.2,.9,.3,1.1) both;
}
@keyframes purchaseIn { from { opacity: 0; transform: translateX(-30px); } to { opacity: 1; transform: none; } }
.purchase-thumb { width: 44px; height: 44px; border-radius: var(--r-sm); overflow: hidden; background: var(--surface-2); flex-shrink: 0; }
.purchase-txt { display: flex; flex-direction: column; min-width: 0; }
.purchase-live { width: 9px; height: 9px; border-radius: 50%; background: var(--eco); flex-shrink: 0; animation: stockPulse 1.8s infinite; }
@media (max-width: 560px) { .purchase-pop { left: 12px; right: 12px; bottom: 88px; max-width: none; } }

/* ===================== PRICE-MATCH ===================== */
.pricematch { display: flex; align-items: center; gap: 14px; margin-top: 16px; padding: 16px 18px; border: 1.5px dashed var(--accent-soft); border-radius: var(--r-md); background: var(--accent-tint); }
.pricematch-ic { width: 42px; height: 42px; border-radius: var(--r-sm); background: var(--surface); color: var(--accent); display: grid; place-items: center; flex-shrink: 0; }
.pricematch-form { display: flex; gap: 8px; margin-top: 10px; }
.pricematch-form .input { flex: 1; }

/* ===================== КВИЗ ===================== */
.quiz { width: min(640px, 100%); }
.quiz-prog { height: 5px; background: var(--surface-3); margin: 12px 24px 0; border-radius: var(--r-pill); overflow: hidden; }
.quiz-prog i { display: block; height: 100%; background: var(--accent); border-radius: var(--r-pill); transition: width .3s; }
.quiz-step { padding: 6px 0; }
.quiz-count { display: block; margin-bottom: 8px; }
.quiz-q { font-size: 22px; font-weight: 800; color: var(--ink); margin: 0 0 20px; line-height: 1.2; }
.quiz-opts { display: flex; flex-direction: column; gap: 10px; }
.quiz-opt {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 18px;
  border: 1.5px solid var(--line); background: var(--surface); border-radius: var(--r-md);
  font: inherit; font-size: 15px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: .14s; text-align: left;
}
.quiz-opt:hover { border-color: var(--accent); background: var(--accent-tint); }
.quiz-opt.on { border-color: var(--accent); background: var(--accent-tint); color: var(--accent-strong); }
.quiz-opt-dot { width: 24px; height: 24px; border-radius: 50%; border: 1.5px solid var(--line); display: grid; place-items: center; color: transparent; flex-shrink: 0; transition: .14s; }
.quiz-opt.on .quiz-opt-dot { background: var(--accent); border-color: var(--accent); color: #fff; }
.quiz-grid { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 600px) { .quiz-grid { grid-template-columns: 1fr; } }

/* ===================== ПРОГРЕСС ДОСТАВКИ ===================== */
.freeship { margin: 4px 0 16px; padding: 12px 14px; background: var(--accent-tint); border-radius: var(--r-md); }
.freeship.done { background: var(--eco-soft); }
.freeship-top { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.freeship-ic { color: var(--accent); display: grid; place-items: center; }
.freeship.done .freeship-ic { color: var(--eco); }
.freeship-bar { height: 7px; background: var(--surface); border-radius: var(--r-pill); overflow: hidden; }
.freeship-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--brand-500)); border-radius: var(--r-pill); transition: width .5s; }
.freeship.done .freeship-bar i { background: var(--eco); }

/* ===================== ДОПРОДАЖИ В КОРЗИНЕ ===================== */
.upsell { padding: 20px; }
.upsell-h { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.upsell-list { display: flex; flex-direction: column; gap: 12px; }
.upsell-item { display: flex; align-items: center; gap: 12px; }
.upsell-thumb { width: 48px; height: 48px; border-radius: var(--r-sm); background: var(--surface-2); display: grid; place-items: center; color: var(--accent); flex-shrink: 0; }
.upsell-buy { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }

/* ===================== БРОШЕННАЯ КОРЗИНА ===================== */
.abandon {
  position: fixed; right: 20px; bottom: 24px; z-index: 150; width: 300px; padding: 16px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-lg);
  animation: purchaseIn .4s cubic-bezier(.2,.9,.3,1.1) both;
}
.abandon-close { position: absolute; top: 10px; right: 10px; width: 26px; height: 26px; border-radius: 50%; border: 0; background: var(--surface-2); color: var(--muted); display: grid; place-items: center; cursor: pointer; }
.abandon-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.abandon-thumb { width: 48px; height: 48px; border-radius: var(--r-sm); overflow: hidden; background: var(--surface-2); display: grid; place-items: center; flex-shrink: 0; }
@media (max-width: 560px) { .abandon { right: 12px; left: 12px; width: auto; bottom: 88px; } }

/* ===================== ПОЧЕМУ МЫ ===================== */
.whyus-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 760px) { .whyus-grid { grid-template-columns: 1fr 1fr; } }
.whyus-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 6px; padding: 28px 20px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); }
.whyus-ic { width: 52px; height: 52px; border-radius: 50%; background: var(--accent-tint); color: var(--accent); display: grid; place-items: center; margin-bottom: 4px; }
.whyus-num { font-size: 30px; font-weight: 800; color: var(--ink); line-height: 1; }

/* ===================== ГАРАНТИЯ ВОЗВРАТА ===================== */
.guarantee { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; padding: 24px 28px; }
@media (max-width: 700px) { .guarantee { grid-template-columns: 1fr; gap: 16px; } }
.guarantee-item { display: flex; align-items: flex-start; gap: 14px; }
.guarantee-ic { width: 46px; height: 46px; border-radius: var(--r-md); background: var(--eco-soft); color: var(--eco); display: grid; place-items: center; flex-shrink: 0; }

/* ===================== КВИЗ-CTA НА ГЛАВНОЙ ===================== */
.quiz-cta {
  display: flex; align-items: center; gap: 20px; width: 100%; padding: 24px 28px; cursor: pointer; text-align: left;
  border: 0; border-radius: var(--r-lg); background: linear-gradient(120deg, var(--accent-tint), var(--surface));
  border: 1.5px solid var(--accent-soft); transition: box-shadow .15s, transform .15s;
}
.quiz-cta:hover { box-shadow: var(--sh-md); }
.quiz-cta-ic { width: 56px; height: 56px; border-radius: var(--r-md); background: var(--accent); color: #fff; display: grid; place-items: center; flex-shrink: 0; }
.quiz-cta-copy { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.quiz-cta-go { flex-shrink: 0; pointer-events: none; }
@media (max-width: 700px) { .quiz-cta { flex-wrap: wrap; } .quiz-cta-go { width: 100%; justify-content: center; } }

/* ===================== HERO-CALC: подходящие модели ===================== */
.herocalc-matches { display: flex; flex-direction: column; gap: 6px; margin: 14px 0; }
.hcm { display: flex; align-items: center; gap: 10px; padding: 8px; border: 1px solid var(--line); background: var(--surface); border-radius: var(--r-sm); cursor: pointer; transition: .14s; text-align: left; }
.hcm:hover { border-color: var(--accent); background: var(--accent-tint); }
.hcm-thumb { width: 40px; height: 40px; border-radius: 8px; overflow: hidden; background: var(--surface-2); flex-shrink: 0; }
.hcm-info { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.hcm-name { font-weight: 600; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ===================== ЧАТ: МЕССЕНДЖЕРЫ ===================== */
.chat-messengers { display: flex; gap: 8px; margin-top: 8px; }
.chat-msgr { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 9px; border: 0; border-radius: var(--r-sm); font: inherit; font-size: 13px; font-weight: 600; color: #fff; cursor: pointer; }
.chat-msgr-max { background: #6E5BE8; }
.chat-msgr-tg { background: #2AABEE; }

/* ===================== ВИДЕО-ОТЗЫВ ===================== */
.rev-video { position: relative; }
.rev-play { position: absolute; inset: 0; display: grid; place-items: center; background: rgba(14,26,36,.35); color: #fff; border-radius: var(--r-sm); }

/* ===================== БАНКИ-ПАРТНЁРЫ ===================== */
.pbanks { margin-top: 12px; }
.pbanks-compact { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.pbanks-h { display: block; margin-bottom: 10px; }
.pbanks-row { display: flex; flex-wrap: wrap; gap: 8px; }
.pbank { display: inline-flex; align-items: center; gap: 8px; padding: 7px 12px 7px 7px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-pill); }
.pbank-logo { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-weight: 800; font-size: 13px; flex-shrink: 0; }
.pbank-txt { display: flex; flex-direction: column; line-height: 1.1; }
.pbank-txt strong { font-size: 13px; color: var(--ink); }
.pbank-txt .muted { font-size: 11px; }

/* ===================== РАСПИСАНИЕ ДОСТАВКИ ===================== */
.sched { margin-top: 4px; }
.sched-h { display: block; margin-bottom: 8px; font-weight: 600; }
.sched-days { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.sched-day { flex: 0 0 auto; width: 64px; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 10px 4px; border: 1.5px solid var(--line); background: var(--surface); border-radius: var(--r-md); cursor: pointer; transition: .14s; }
.sched-day:hover { border-color: var(--accent); }
.sched-day.on { border-color: var(--accent); background: var(--accent-tint); }
.sched-day-w { color: var(--muted); text-transform: lowercase; }
.sched-day.weekend .sched-day-w { color: var(--warm); }
.sched-day-n { font-size: 20px; font-weight: 800; color: var(--ink); }
.sched-day-m { color: var(--muted-2); }
.sched-slots { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
@media (max-width: 560px) { .sched-slots { grid-template-columns: 1fr 1fr; } }
.sched-slot { position: relative; padding: 11px 8px; border: 1.5px solid var(--line); background: var(--surface); border-radius: var(--r-sm); font: inherit; font-size: 13.5px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: .14s; }
.sched-slot:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }
.sched-slot.on { border-color: var(--accent); background: var(--accent-tint); color: var(--accent-strong); }
.sched-slot:disabled { opacity: .5; cursor: not-allowed; }
.sched-slot-busy { position: absolute; top: -7px; right: 6px; font-size: 10px; background: var(--surface-3); color: var(--muted); padding: 1px 6px; border-radius: var(--r-pill); }

/* ===================== АВТОПОДСКАЗКИ АДРЕСА ===================== */
.addr-field { position: relative; }
.addr-sug { position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 30; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-lg); overflow: hidden; padding: 4px; }
.addr-sug-item { display: flex; align-items: center; gap: 10px; width: 100%; padding: 10px 12px; border: 0; background: none; border-radius: var(--r-sm); cursor: pointer; text-align: left; font: inherit; font-size: 14px; color: var(--ink-2); }
.addr-sug-item svg { color: var(--accent); flex-shrink: 0; }
.addr-sug-item:hover { background: var(--accent-tint); color: var(--accent); }

/* ===================== ПУНКТЫ САМОВЫВОЗА ===================== */
.pickup { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 700px) { .pickup { grid-template-columns: 1fr; } }
.pickup-map { position: relative; aspect-ratio: 1 / 1; border-radius: var(--r-md); overflow: hidden; background: linear-gradient(135deg, var(--surface-2), var(--surface-3)); border: 1px solid var(--line); }
.pickup-map-grid { position: absolute; inset: 0; background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px); background-size: 36px 36px; opacity: .5; }
.pickup-pin { position: absolute; transform: translate(-50%, -100%); border: 0; background: none; color: var(--accent); cursor: pointer; filter: drop-shadow(0 2px 3px rgba(0,0,0,.2)); transition: .14s; }
.pickup-pin.on { color: var(--warm); z-index: 2; }
.pickup-map-lbl { position: absolute; left: 12px; bottom: 10px; background: var(--surface); padding: 4px 10px; border-radius: var(--r-pill); }
.pickup-list { display: flex; flex-direction: column; gap: 8px; }
.pickup-item { display: flex; gap: 12px; padding: 14px; border: 1.5px solid var(--line); background: var(--surface); border-radius: var(--r-md); cursor: pointer; transition: .14s; align-items: flex-start; }
.pickup-item:hover { border-color: var(--accent); }
.pickup-item.on { border-color: var(--accent); background: var(--accent-tint); }
.pickup-radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--line); flex-shrink: 0; margin-top: 2px; transition: .14s; }
.pickup-item.on .pickup-radio { border-color: var(--accent); border-width: 6px; }
.pickup-meta { display: flex; align-items: center; gap: 10px; margin-top: 4px; flex-wrap: wrap; }
.pickup-today { display: inline-flex; align-items: center; gap: 4px; color: var(--eco); font-size: 12px; font-weight: 600; }

/* ===================== ПОДПИСКА НА ПОСТУПЛЕНИЕ/ЦЕНУ ===================== */
.stocksub { display: flex; align-items: center; gap: 14px; margin-top: 12px; padding: 16px 18px; border-radius: var(--r-md); background: var(--surface-2); border: 1px solid var(--line); }
.stocksub.out { background: var(--warm-soft); border-color: transparent; }
.stocksub-ic { width: 42px; height: 42px; border-radius: var(--r-sm); background: var(--surface); color: var(--accent); display: grid; place-items: center; flex-shrink: 0; }
.stocksub.out .stocksub-ic { color: var(--warm); }
.stocksub-form { display: flex; gap: 8px; margin-top: 10px; }
.stocksub-form .input { flex: 1; }

/* ===================== ГЛОССАРИЙ-ТУЛТИП ===================== */
.gloss { position: relative; display: inline-block; }
.gloss-term { border: 0; background: none; padding: 0; font: inherit; color: inherit; cursor: help; border-bottom: 1px dashed var(--muted-2); display: inline-flex; align-items: center; gap: 3px; }
.gloss-q { display: inline-grid; place-items: center; width: 14px; height: 14px; border-radius: 50%; background: var(--accent-soft); color: var(--accent-strong); font-size: 10px; font-weight: 700; }
.gloss-pop { position: absolute; left: 0; top: calc(100% + 8px); z-index: 40; width: 250px; padding: 12px 14px; background: var(--ink); color: #fff; border-radius: var(--r-md); box-shadow: var(--sh-lg); font-size: 12.5px; line-height: 1.5; font-weight: 400; }
.gloss-pop strong { display: block; margin-bottom: 4px; color: #fff; }
.gloss-pop::before { content: ""; position: absolute; left: 18px; top: -5px; width: 10px; height: 10px; background: var(--ink); transform: rotate(45deg); }

/* ===================== ПЕРЕКЛЮЧАТЕЛЬ МОЩНОСТИ/ПЛОЩАДИ ===================== */
.capsw { display: flex; flex-direction: column; gap: 14px; margin: 4px 0 20px; padding: 18px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--surface-2); }
.capsw-row { display: flex; flex-direction: column; gap: 8px; }
.capsw-lbl { font-size: 13px; font-weight: 600; color: var(--muted); }
.capsw-opts { display: flex; flex-wrap: wrap; gap: 8px; }
.capsw-opt { min-width: 56px; padding: 10px 14px; border: 1.5px solid var(--line); background: var(--surface); border-radius: var(--r-sm); font: inherit; font-size: 15px; font-weight: 700; color: var(--ink-2); cursor: pointer; transition: .14s; }
.capsw-opt:hover { border-color: var(--accent); color: var(--accent); }
.capsw-opt.on { border-color: var(--accent); background: var(--accent); color: #fff; }

/* ===================== БЕЙДЖИ У ФОТО ===================== */
.photobadges { position: absolute; top: 14px; left: 14px; z-index: 4; display: flex; flex-direction: column; gap: 8px; }
.photobadge { position: relative; width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; cursor: default; box-shadow: var(--sh-sm); }
.photobadge-eco { background: var(--eco-soft); color: var(--eco); }
.photobadge-accent { background: var(--accent-tint); color: var(--accent); }
.photobadge-violet { background: #ECE8FB; color: #6E5BE8; }
.photobadge-tip { position: absolute; left: calc(100% + 8px); top: 50%; transform: translateY(-50%); white-space: nowrap; background: var(--ink); color: #fff; font-size: 12px; font-weight: 600; padding: 6px 10px; border-radius: var(--r-sm); opacity: 0; pointer-events: none; transition: opacity .15s; }
.photobadge:hover .photobadge-tip { opacity: 1; }

/* ===================== ПОДАРОК ПРИ ПОКУПКЕ ===================== */
.giftblock { position: relative; overflow: hidden; margin-top: 14px; padding: 16px 18px; border-radius: var(--r-md); background: linear-gradient(120deg, var(--eco-soft), var(--surface)); border: 1px solid var(--eco-soft); }
.giftblock-deco { position: absolute; right: -16px; top: -16px; width: 70px; height: 70px; border-radius: 50%; background: rgba(31,138,91,.12); display: grid; place-items: center; color: var(--eco); }
.giftblock-eyebrow { display: block; font-weight: 700; color: var(--eco); margin-bottom: 2px; }
.giftblock-prod { display: flex; align-items: center; gap: 12px; margin-top: 12px; padding: 12px; background: var(--surface); border-radius: var(--r-sm); }
.giftblock-thumb { width: 44px; height: 44px; border-radius: var(--r-sm); background: var(--surface-2); display: grid; place-items: center; color: var(--accent); flex-shrink: 0; }
.giftblock-price { display: flex; align-items: center; gap: 8px; margin-top: 2px; }
.giftblock-free { color: var(--eco); font-weight: 700; font-size: 13px; }
.giftblock-check { width: 28px; height: 28px; border-radius: 50%; background: var(--eco); color: #fff; display: grid; place-items: center; flex-shrink: 0; }

/* ===================== КОНСУЛЬТАЦИЯ ===================== */
.consult-btn { display: flex; align-items: center; gap: 14px; width: 100%; margin-top: 14px; padding: 16px 18px; border: 0; border-radius: var(--r-md); cursor: pointer; background: linear-gradient(120deg, var(--accent-tint), var(--surface)); border: 1.5px solid var(--accent-soft); font: inherit; font-weight: 700; font-size: 15px; color: var(--ink); transition: box-shadow .15s; }
.consult-btn:hover { box-shadow: var(--sh-md); }
.consult-ic { width: 42px; height: 42px; border-radius: var(--r-sm); background: var(--accent); color: #fff; display: grid; place-items: center; flex-shrink: 0; }
.consult-btn > svg { color: var(--accent); flex-shrink: 0; }

/* ===================== ВСЕ ХАРАКТЕРИСТИКИ ===================== */
.allspecs-btn { display: inline-flex; align-items: center; gap: 7px; margin-top: 16px; padding: 11px 20px; border: 1.5px solid var(--line); background: var(--surface); border-radius: var(--r-pill); font: inherit; font-weight: 600; font-size: 14px; color: var(--accent); cursor: pointer; transition: .14s; }
.allspecs-btn:hover { border-color: var(--accent); background: var(--accent-tint); }

/* ===================== ОЦЕНКА МОНТАЖА В КОРЗИНЕ ===================== */
.installest { padding: 18px; }
.installest.on { border-color: var(--accent); }
.installest-head { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; }
.installest-head input { display: none; }
.installest-head input:checked + .fcheck-box { background: var(--accent); border-color: var(--accent); color: #fff; }
.installest-lines { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 9px; }
.installest-line { display: flex; align-items: center; gap: 10px; }
.installest-note { display: flex; align-items: flex-start; gap: 7px; margin-top: 4px; line-height: 1.5; }
.installest-note svg { flex-shrink: 0; margin-top: 2px; color: var(--accent); }
.installest-none { display: flex; align-items: center; gap: 12px; }
