/* AV24 — catalog/category layout. Loaded on product archive + product_cat. Extracted 1:1. */
/* ============================================================
   CATALOG / CATEGORY PAGE
   ============================================================ */
.cat-page{padding-top:clamp(14px,1.8vw,22px)}
.crumb{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--muted-2);margin-bottom:14px;flex-wrap:wrap}
.crumb a{color:var(--muted-2);text-decoration:none}
.crumb a:hover{color:var(--blue)}
.crumb svg{width:6px;height:10px;opacity:.7}
.cat-h1{font-size:clamp(21px,2.5vw,29px);font-weight:800;color:var(--ink);margin-bottom:22px;letter-spacing:-.01em;line-height:1.15}

/* ---- top category tiles ---- */
.ccat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:30px}
.ccat-tile{position:relative;border-radius:var(--r);overflow:hidden;line-height:0;box-shadow:var(--shadow-card);
  aspect-ratio:1/.97;transition:transform .18s,box-shadow .18s}
.ccat-tile:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(20,23,33,.13)}
.ccat-tile img{width:100%;height:100%;object-fit:cover;display:block}

/* ---- body grid ---- */
.cat-body{display:grid;grid-template-columns:262px minmax(0,1fr);gap:28px;align-items:start;padding-bottom:50px}

/* ---- sidebar ---- */
.cat-side{position:sticky;top:86px;display:flex;flex-direction:column;gap:16px}
.side-block{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:8px}
.side-cats{display:flex;flex-direction:column;gap:1px}
.side-cat{display:block;padding:9px 12px;border-radius:9px;font-size:13px;color:var(--ink-soft);
  text-decoration:none;line-height:1.35;transition:background .12s,color .12s}
.side-cat:hover{background:#fff;color:var(--blue)}
.side-cat.active{background:#eef1f6;color:var(--ink);font-weight:600}
.side-ftitle{font-size:15px;font-weight:700;color:var(--ink);padding:8px 8px 4px}
.filter-group{border-top:1px solid var(--line);padding:14px 8px 4px;margin-top:8px}
.filter-group:first-of-type{border-top:none;margin-top:0}
.fg-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:11px;user-select:none}
.fg-head svg{width:14px;height:14px;color:var(--muted-2);transition:transform .2s;flex-shrink:0}
.filter-group.collapsed .fg-head svg{transform:rotate(-90deg)}
.filter-group.collapsed .fg-body{display:none}
.fg-search{width:100%;height:34px;border:1px solid var(--line);border-radius:8px;padding:0 11px;font-size:12.5px;
  font-family:inherit;color:var(--ink);margin-bottom:10px;background:#fff}
.fg-search::placeholder{color:var(--muted-2)}
.fg-search:focus{outline:none;border-color:var(--blue)}
.fg-opts{display:flex;flex-direction:column;gap:1px;max-height:210px;overflow-y:auto}
.fg-opts::-webkit-scrollbar{width:6px}
.fg-opts::-webkit-scrollbar-thumb{background:#d6dae1;border-radius:3px}
.fg-opt{display:flex;align-items:center;gap:9px;padding:6px 4px;font-size:12.5px;color:var(--ink-soft);cursor:pointer;border-radius:6px;line-height:1.3}
.fg-opt:hover{background:#fff}
.fg-opt input{width:16px;height:16px;accent-color:var(--blue);cursor:pointer;flex-shrink:0;margin:0}
.filter-apply{display:block;width:100%;text-align:center;background:var(--blue);color:#fff;font-weight:700;font-size:13.5px;
  border:none;padding:12px;border-radius:10px;cursor:pointer;margin-top:14px;transition:background .15s;font-family:inherit}
.filter-apply:hover{background:var(--blue-hover)}
.filter-reset{display:block;text-align:center;font-size:13px;color:var(--muted);text-decoration:none;margin-top:10px;padding:4px;cursor:pointer}
.filter-reset:hover{color:var(--blue)}

/* ---- main: toolbar ---- */
.filter-toggle{display:none;align-items:center;justify-content:center;gap:8px;width:100%;background:#fff;
  border:1px solid var(--line);border-radius:10px;padding:12px;font-size:14px;font-weight:600;color:var(--ink);
  cursor:pointer;margin-bottom:16px;font-family:inherit}
.filter-toggle svg{width:18px;height:18px;color:var(--blue)}
.cat-toolbar{display:flex;align-items:center;gap:11px;margin-bottom:18px;flex-wrap:wrap}
.tb-sort{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:9px;padding:9px 13px;
  font-size:13px;color:var(--ink);background:#fff;cursor:pointer;font-weight:500}
.tb-sort svg{width:13px;height:13px;color:var(--muted-2)}
.tb-chip{display:inline-flex;align-items:center;gap:8px;background:var(--blue-soft);color:var(--blue);
  font-size:12.5px;font-weight:500;padding:8px 12px;border-radius:8px}
.tb-chip button{background:none;border:none;color:var(--blue);cursor:pointer;display:grid;place-items:center;padding:0;opacity:.8}
.tb-chip button:hover{opacity:1}
.tb-chip svg{width:12px;height:12px}
.tb-clear{font-size:13px;color:var(--muted);text-decoration:none;cursor:pointer}
.tb-clear:hover{color:var(--blue)}
.tb-views{margin-left:auto;display:flex;gap:5px}
.tb-view{width:36px;height:36px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;
  background:#fff;cursor:pointer;color:var(--muted-2);transition:.12s}
.tb-view:hover{color:var(--ink)}
.tb-view.on{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}
.tb-view svg{width:16px;height:16px}

/* ---- product grid (reuse .prod) ---- */
.cat-prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
/* view-toggle modes (wired) */
.cat-prod-grid.v-list{grid-template-columns:1fr;gap:14px}
.cat-prod-grid.v-list .prod{display:flex;flex-direction:row;gap:20px;text-align:left}
.cat-prod-grid.v-list .prod .p-img{flex:0 0 240px;width:240px;height:auto;min-height:190px}
.cat-prod-grid.v-list .prod .p-body{flex:1;display:flex;flex-direction:column;justify-content:center}
.cat-prod-grid.v-list .prod .btns{margin-top:14px}
@media (min-width:1024px){.cat-prod-grid.v-2{grid-template-columns:repeat(2,1fr)}.cat-prod-grid.v-3{grid-template-columns:repeat(3,1fr)}.cat-prod-grid.v-4{grid-template-columns:repeat(4,1fr)}}
@media (max-width:560px){.cat-prod-grid.v-list .prod{flex-direction:column}.cat-prod-grid.v-list .prod .p-img{width:100%;flex:none;height:200px}}
.cat-prod-grid .prod .p-img{height:200px}
.cat-prod-grid .prod .p-img img{width:100%;height:100%;object-fit:cover;padding:0}
.prod .p-badges{margin-bottom:8px}
a.p-img{display:block;text-decoration:none}
.prod a.p-name{text-decoration:none;color:var(--ink-soft);transition:color .12s;display:block}
.prod a.p-name:hover{color:var(--blue)}
.stock.out{color:var(--muted-2)}
.stock.out i{background:var(--muted-2)}
.btn-cart.oos{background:linear-gradient(90deg,#f3aecd,#f8cda0);cursor:default}

/* ---- catalog responsive ---- */
@media (max-width:1180px){
  .ccat-grid{grid-template-columns:repeat(4,1fr)}
  .cat-prod-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:960px){
  .cat-body{grid-template-columns:1fr;gap:0}
  .cat-side{position:static;display:none;margin-bottom:18px}
  .cat-side.open{display:flex}
  .filter-toggle{display:flex}
  .ccat-grid{grid-template-columns:repeat(3,1fr);gap:12px}
}
@media (max-width:680px){
  .ccat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cat-prod-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .cat-prod-grid .prod .p-img{height:160px}
}
@media (max-width:380px){
  .cat-prod-grid{grid-template-columns:1fr}
}


/* catalog-specific mobile override (was nested in shared MOBILE_POLISH) */
@media (max-width:600px){ .crumb{margin-bottom:14px;font-size:12.5px} }
/* fallback for category tiles without an uploaded image */
.ccat-tile .ccat-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:14px;font-weight:700;font-size:14px;color:#1a2a3a;background:linear-gradient(135deg,#eef2f6,#dde6ee)}
.ccat-tile{position:relative}
.cat-desc{color:var(--muted);font-size:14.5px;line-height:1.6;margin:-6px 0 22px;max-width:880px}
