/* ============================================================
   НИЛИНА АВТО — стили страницы каталога
   (подключается ПОСЛЕ styles.css)
   ============================================================ */

/* ---------- авто-хедер (панель выбранного авто) ---------- */
.autobar{ background:var(--bg-soft); border-bottom:1px solid var(--line); }
.autobar .container{ display:flex; align-items:center; gap:18px; padding-top:16px; padding-bottom:16px; flex-wrap:wrap; }
.autobar-car{ width:42px; height:32px; color:var(--red); flex-shrink:0; }
.autobar-main{ flex:1; min-width:240px; }
.autobar-chain{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-family:var(--font-head); font-size:15px; }
.autobar-chain a{ font-weight:700; color:var(--ink); border-bottom:1px dashed transparent; }
.autobar-chain a:hover{ color:var(--red); border-bottom-color:var(--red); }
.autobar-chain .sep{ color:var(--faint); }
.autobar-chain .hint{ color:var(--faint); font-weight:600; }
.autobar-body{ margin-top:5px; }
.autobar-body .refine{ font-size:13px; color:var(--red); font-weight:600; font-family:var(--font-head); display:inline-flex; align-items:center; gap:5px; cursor:pointer; }
.autobar-body .refine:hover{ text-decoration:underline; }
.btn-change{
  background:#fff; border:1px solid var(--line); color:var(--ink); padding:11px 18px; border-radius:var(--radius);
  font-family:var(--font-head); font-weight:600; font-size:14px; display:inline-flex; align-items:center; gap:8px;
  transition:border-color .15s, color .15s; flex-shrink:0; white-space:nowrap;
}
.btn-change:hover{ border-color:var(--red); color:var(--red); }

/* ---------- хлебные крошки ---------- */
.breadcrumbs{ padding:16px 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); }

/* ---------- заголовок + сортировка ---------- */
.cat-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; padding:14px 0 26px; flex-wrap:wrap; }
.cat-head h1{ font-size:30px; font-weight:800; letter-spacing:-.01em; max-width:760px; line-height:1.18; }
.cat-head .found{ font-size:14px; color:var(--muted); margin-top:8px; }
.cat-head .found b{ color:var(--ink); font-family:var(--font-head); }
.sort{ display:flex; align-items:center; gap:10px; flex-shrink:0; }
.sort label{ font-size:13px; color:var(--muted); }
.sort .select{ min-width:190px; }
.sort .select select{
  width:100%; appearance:none; -webkit-appearance:none; border:1px solid var(--line); background:#fff;
  color:var(--ink); padding:11px 38px 11px 14px; border-radius:var(--radius); font-size:14px; cursor:pointer;
}
.sort .select select:focus{ outline:0; border-color:var(--red); }
.sort .select::after{ border-color:var(--faint); }

/* ---------- тело: сайдбар + сетка ---------- */
.cat-body{ display:grid; grid-template-columns:268px 1fr; gap:28px; padding-bottom:64px; align-items:start; }

/* сайдбар */
.sidebar{ position:sticky; top:72px; }
.side-search{ position:relative; margin-bottom:14px; }
.side-search input{
  width:100%; border:1px solid var(--line); border-radius:var(--radius); padding:11px 14px 11px 38px; font-size:14px;
  background:#fff; outline:0;
}
.side-search input:focus{ border-color:var(--red); }
.side-search .s-ico{ position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--faint); }
.side-title{ font-family:var(--font-head); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin:6px 4px 10px; }
.cat-list{ display:flex; flex-direction:column; gap:1px; max-height:none; }
.cat-list button{
  display:flex; align-items:center; justify-content:space-between; gap:10px; width:100%; text-align:left;
  background:none; border:0; padding:10px 12px; border-radius:7px; font-size:14px; color:var(--ink); cursor:pointer;
  transition:background .12s, color .12s; font-family:var(--font-body);
}
.cat-list button:hover{ background:var(--bg-soft); }
.cat-list button.active{ background:var(--red-soft); color:var(--red); font-weight:700; }
.cat-list button .c-name{ flex:1 1 auto; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cat-list button .c-cnt{ font-size:12px; color:var(--faint); flex-shrink:0; }
.cat-list button.active .c-cnt{ color:var(--red); }
.cat-empty{ font-size:13px; color:var(--faint); padding:10px 12px; }

/* сетка товаров */
.prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.prod{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .18s, transform .18s, border-color .18s; }
.prod:hover{ box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:#D7DDE3; }
.prod-img{ display:block; position:relative; aspect-ratio:4/3; background:#fff; overflow:hidden; }
.prod-img .ph{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; background:#fff; }
.prod-img .wm{ position:absolute; inset:0; background-repeat:repeat; background-size:170px 110px; opacity:.45; pointer-events:none; }
.prod-img.no-photo{ display:grid; place-items:center; background:var(--bg-soft); }
.prod-no-photo{ display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--faint); }
.prod-no-photo .npx{ font-family:var(--font-head); font-weight:800; font-size:14px; letter-spacing:.04em; color:var(--dark); }
.prod-no-photo .npx b{ color:var(--red); }
.prod-no-photo small{ font-size:11px; }
.badge{
  position:absolute; left:10px; top:10px; z-index:2; padding:5px 10px; border-radius:5px;
  font-family:var(--font-head); font-weight:700; font-size:11px; letter-spacing:.04em; color:#fff; text-transform:uppercase;
}
.badge.contract{ background:var(--green); }
.badge.new{ background:#2A6FDB; }
.badge.used{ background:#7A8794; }
.prod-body{ padding:16px 18px 18px; display:flex; flex-direction:column; gap:8px; flex:1; }
.prod-price{ font-family:var(--font-head); font-weight:800; font-size:22px; color:var(--ink); }
.prod-name{ display:block; font-size:15px; font-weight:600; line-height:1.32; color:var(--ink); text-decoration:none; }
.prod:hover .prod-name{ color:var(--red); }
.prod-fit{ font-size:12.5px; color:var(--muted); }
.prod-donor{ font-size:11.5px; color:var(--faint); line-height:1.45; padding-top:2px; }
.prod-donor .dl{ color:var(--muted); }
.prod-foot{ margin-top:auto; padding-top:12px; display:flex; align-items:center; justify-content:space-between; gap:10px; border-top:1px solid var(--line-2); }
.prod-stock{ font-size:12.5px; color:var(--muted); }
.prod-stock b{ color:var(--ink); font-family:var(--font-head); }
.prod-add{
  width:38px; height:38px; border-radius:8px; border:1px solid var(--line); background:#fff; color:var(--red);
  display:grid; place-items:center; cursor:pointer; transition:all .15s; flex-shrink:0;
}
.prod-add:hover{ background:var(--red); border-color:var(--red); color:#fff; }

/* пусто */
.prod-none{ grid-column:1/-1; text-align:center; padding:60px 20px; color:var(--muted); }
.prod-none h3{ font-size:18px; margin-bottom:6px; }

/* ---------- адаптив каталога ---------- */
@media (max-width:1199px){
  .cat-body{ grid-template-columns:240px 1fr; gap:22px; }
  .prod-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px){
  .cat-body{ grid-template-columns:1fr; }
  .sidebar{ position:static; }
  .cat-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px 14px; }
}
@media (max-width:767px){
  .cat-head h1{ font-size:23px; }
  .prod-grid{ grid-template-columns:1fr; }
  .cat-list{ grid-template-columns:1fr; }
  .autobar .container{ gap:12px; }
  .btn-change{ width:100%; justify-content:center; }
}
