/* ============================================================
   Карточка товара (детальная)
   подключается ПОСЛЕ styles.css
   ============================================================ */
.product-wrap{ padding-bottom:64px; }
.breadcrumbs{ padding:18px 0 0; }
.breadcrumbs ol{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; align-items:center; gap:7px; font-size:13px; color:var(--muted); }
.breadcrumbs a{ color:var(--muted); }
.breadcrumbs a:hover{ color:var(--red); }
.breadcrumbs .sep{ color:var(--faint); }
.breadcrumbs .cur{ color:var(--faint); }

.product-h1{ font-size:27px; font-weight:800; letter-spacing:-.01em; line-height:1.22; margin:14px 0 22px; max-width:1000px; }

/* ---------- основная раскладка ---------- */
.product-grid{ display:grid; grid-template-columns:1fr 420px; gap:36px; align-items:start; }

/* ===== ГАЛЕРЕЯ ===== */
.gallery{ position:sticky; top:74px; }
.gal-main{
  position:relative; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  background:#fff; aspect-ratio:4/3; cursor:zoom-in;
}
.gal-main .ph{ position:absolute; inset:0; width:100%; height:100%; transition:transform .25s ease; transform-origin:center; }
.gal-main.zooming .ph{ transform:scale(2.2); transition:transform .05s linear; cursor:zoom-out; }
.gal-main .wm{ position:absolute; inset:0; background-repeat:repeat; background-size:200px 130px; opacity:.4; pointer-events:none; }
.gal-main .prod-no-photo .npx b{ color:var(--red); }
.gal-main .badge{
  position:absolute; left:14px; top:14px; z-index:3; padding:6px 12px; border-radius:6px;
  font-family:var(--font-head); font-weight:700; font-size:12px; letter-spacing:.04em; color:#fff; text-transform:uppercase;
}
.gal-main .badge.contract{ background:var(--green); }
.gal-main .badge.new{ background:#2A6FDB; }
.gal-main .badge.used{ background:#7A8794; }
.gal-zoomhint{ position:absolute; right:14px; bottom:14px; z-index:3; background:rgba(21,32,43,.78); color:#fff; font-size:11.5px; padding:5px 10px; border-radius:6px; display:flex; align-items:center; gap:6px; font-family:var(--font-head); pointer-events:none; }
.gal-thumbs{ display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.gal-thumb{
  width:84px; height:64px; border-radius:8px; overflow:hidden; border:2px solid var(--line); cursor:pointer; padding:0; background:#fff;
  position:relative; transition:border-color .15s;
}
.gal-thumb img{ width:100%; height:100%; object-fit:cover; }
.gal-thumb:hover{ border-color:#C7CFD6; }
.gal-thumb.active{ border-color:var(--red); }

/* ===== ПРАВАЯ КОЛОНКА ===== */
.buy-col{ display:flex; flex-direction:column; gap:16px; }
.buy-card{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px; background:#fff; box-shadow:var(--shadow-sm); }
.buy-price{ font-family:var(--font-head); font-weight:800; font-size:34px; color:var(--ink); letter-spacing:-.01em; }
.buy-sub{ font-size:13px; color:var(--faint); margin-top:2px; }
.btn-buy{
  margin-top:18px; width:100%; background:var(--red); color:var(--brand-cta-fg); border:0; border-radius:var(--radius);
  min-height:52px; padding:14px 18px; font-family:var(--font-head); font-weight:700; font-size:16px; display:flex; align-items:center; justify-content:center; gap:10px;
  transition:background .15s, border-color .15s, color .15s, transform .08s, box-shadow .15s;
}
.btn-buy:hover{ background:var(--red-dark); }
.btn-buy:active{ transform:translateY(1px); }
.btn-buy:focus-visible{ outline:0; box-shadow:0 0 0 3px color-mix(in srgb, var(--red) 22%, transparent); }
.btn-buy.in-cart{ background:#fff; color:var(--green); border:1.5px solid var(--green); border-radius:var(--radius); }
.btn-buy.in-cart:hover,
.btn-buy.in-cart:focus-visible,
.btn-buy.in-cart.is-remove-intent{ background:#F2FBF5; border-color:#20964C; color:#20964C; box-shadow:0 0 0 3px color-mix(in srgb, var(--green) 16%, transparent); }
.btn-buy.price-request,
.btn-buy.price-request:hover,
.btn-buy.price-request:focus-visible{
  background:#fff; color:var(--ink); border:1.5px solid var(--line); box-shadow:none; cursor:default;
}

.buy-status{ display:flex; align-items:center; gap:10px; margin-top:18px; flex-wrap:wrap; }
.buy-badge{ padding:6px 12px; border-radius:6px; font-family:var(--font-head); font-weight:700; font-size:12px; letter-spacing:.04em; color:#fff; text-transform:uppercase; }
.buy-badge.contract{ background:var(--green); }
.buy-badge.new{ background:#2A6FDB; }
.buy-badge.used{ background:#7A8794; }
.buy-stock{ display:flex; align-items:center; gap:8px; font-size:14.5px; color:var(--ink); }
.buy-stock .bs-ico{ color:var(--green); flex-shrink:0; }
.buy-stock b{ font-family:var(--font-head); }

/* складская плашка */
.wh{ margin-top:20px; padding-top:20px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:14px; }
.wh-row{ display:flex; gap:12px; align-items:flex-start; }
.wh-ico{ width:20px; color:var(--red); flex-shrink:0; margin-top:2px; }
.wh-row .lbl{ font-size:11.5px; color:var(--faint); text-transform:uppercase; letter-spacing:.05em; font-weight:600; font-family:var(--font-head); margin-bottom:3px; }
.wh-row .val{ font-size:14px; color:var(--ink); line-height:1.45; }
.wh-row .val a{ font-weight:600; }
.wh-row .val a:hover{ color:var(--red); }
.wh-map{ color:var(--red); font-weight:600; font-size:13px; margin-left:8px; white-space:nowrap; }
.wh-phone{ font-family:var(--font-head); font-weight:700; font-size:17px; }
.wh-wa{ display:inline-flex; align-items:center; gap:6px; color:var(--green); font-weight:600; font-size:13.5px; margin-top:4px; }
.wh-wa:hover{ text-decoration:underline; }

/* баннер донора */
.donor-banner{
  background:var(--dark); color:#fff; border-radius:var(--radius-lg); padding:20px 22px;
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.donor-banner .db-car{ width:40px; height:30px; color:var(--red); flex-shrink:0; }
.donor-banner .db-text{ flex:1; min-width:180px; font-size:14.5px; color:#C6CFD8; }
.donor-banner .db-text b{ color:#fff; font-family:var(--font-head); }
.donor-banner .db-more{
  background:var(--red); color:var(--brand-cta-fg); border-radius:var(--radius); padding:11px 18px; font-family:var(--font-head); font-weight:700; font-size:13.5px;
  display:inline-flex; align-items:center; gap:7px; white-space:nowrap; transition:background .15s;
}
.donor-banner .db-more:hover{ background:var(--red-dark); }

/* ===== ВКЛАДКИ ===== */
.tabs{ margin-top:44px; }
.tab-head{ display:flex; gap:4px; border-bottom:1px solid var(--line); }
.tab-btn{
  background:none; border:0; padding:14px 22px; font-family:var(--font-head); font-weight:700; font-size:16px; color:var(--muted);
  position:relative; cursor:pointer; transition:color .15s;
}
.tab-btn:hover{ color:var(--ink); }
.tab-btn.active{ color:var(--ink); }
.tab-btn.active::after{ content:""; position:absolute; left:0; right:0; bottom:-1px; height:3px; background:var(--red); border-radius:3px 3px 0 0; }
.tab-pane{ padding:26px 0; max-width:760px; }
.tab-pane[hidden]{ display:none; }

/* таблица характеристик */
.spec{ width:100%; border-collapse:collapse; }
.spec tr{ border-bottom:1px solid var(--line-2); }
.spec th, .spec td{ text-align:left; padding:13px 4px; font-size:14.5px; vertical-align:top; }
.spec th{ font-weight:500; color:var(--muted); width:42%; }
.spec td{ font-weight:600; color:var(--ink); font-family:var(--font-head); }
.spec td.cross{ font-family:var(--font-body); font-weight:400; color:var(--ink); }

/* применимость */
.fit-list{ display:flex; flex-direction:column; gap:1px; }
.fit-item{ display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:14px; padding:13px 6px; border-bottom:1px solid var(--line-2); font-size:14px; }
.fit-item .fi-car{ font-weight:600; font-family:var(--font-head); color:var(--ink); }
.fit-item .fi-gen{ color:var(--muted); }
.fit-item .fi-eng{ color:var(--muted); }
.fit-head{ font-family:var(--font-head); font-weight:700; font-size:12px; text-transform:uppercase; letter-spacing:.04em; color:var(--faint); border-bottom:1px solid var(--line); }

/* адаптив */
@media (max-width:980px){
  .product-grid{ grid-template-columns:1fr; gap:26px; }
  .gallery{ position:static; }
  .gal-main{ max-width:560px; }
}
@media (max-width:767px){
  .product-h1{ font-size:21px; }
  .buy-price{ font-size:28px; }
  .fit-item{ grid-template-columns:1fr; gap:3px; }
  .fit-item .fi-gen, .fit-item .fi-eng{ font-size:12.5px; }
  /* таблица характеристик — вертикальный вид (значение под названием) */
  .spec th, .spec td{ display:block; width:auto; padding:6px 4px; }
  .spec th{ padding-top:12px; color:var(--faint); }
  /* убираем min-width баннера донора, чтобы не было переполнения */
  .donor-banner .db-text{ min-width:0; }
}
