/* catalog.css — общий каталог: выезжающий фильтр, чипсы, пагинация */
.catwrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 32px}
.cathead{margin-bottom:24px}
.cathead__title{font-family:var(--font-display);font-weight:400;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--color-dark);line-height:1.12}
.cathead__sub{color:var(--color-muted);font-size:1.05rem;margin-top:10px;max-width:680px}
.catbar{display:flex;align-items:center;gap:18px;padding:16px 0;border-top:1px solid var(--color-line);border-bottom:1px solid var(--color-line);flex-wrap:wrap}
.catbar__filterbtn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14.5px;color:var(--color-dark);padding:11px 16px;border-radius:var(--radius-sm);background:var(--color-bg-soft);transition:var(--trans)}
.catbar__filterbtn i{color:var(--color-accent)}
.catbar__filterbtn:hover{background:var(--color-accent);color:#fff}
.catbar__filterbtn:hover i{color:#fff}
.catbar__count{font-size:15px;color:var(--color-muted)}
.catbar__right{margin-left:auto}
.catbar__sort{font-size:14.5px;color:var(--color-muted);display:inline-flex;align-items:center;gap:10px}
.catbar__sort select{padding:10px 14px;border:1.5px solid var(--color-line);border-radius:var(--radius-sm);font-family:inherit;font-size:14.5px;color:var(--color-text);background:#fff;cursor:pointer}
.chips{display:flex;flex-wrap:wrap;gap:10px;padding:18px 0 0}
.chips:empty{padding:0}
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--color-bg-soft);border:1px solid var(--color-line);border-radius:30px;padding:7px 12px 7px 14px;font-size:13.5px;font-weight:600;color:var(--color-text)}
.chip button{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--color-line);color:var(--color-muted);font-size:.65rem;transition:var(--trans)}
.chip button:hover{background:var(--color-accent);color:#fff}
.cards-grid--catalog{padding-top:28px}
.catalog__empty{padding:60px 24px;text-align:center;color:var(--color-muted);font-size:16px;margin-top:28px}
.linkbtn{color:var(--color-accent);font-weight:700;text-decoration:underline}
.pager{display:flex;justify-content:center;align-items:center;gap:8px;margin:48px 0 12px;flex-wrap:wrap}
.pager__btn{min-width:44px;height:44px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1.5px solid var(--color-line);border-radius:var(--radius-sm);font-weight:700;font-size:15px;color:var(--color-text);background:#fff;transition:var(--trans)}
.pager__btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}
.pager__btn--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}
.pager__btn:disabled{opacity:.4;cursor:not-allowed}
.pager__dots{color:var(--color-muted);padding:0 4px}
.filterpanel{position:fixed;top:0;left:0;width:320px;max-width:88%;height:100dvh;z-index:115;background:#fff;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg);border-right:1px solid var(--color-line)}
.filterpanel.open{transform:translateX(0)}
.filterpanel__top{display:flex;align-items:center;justify-content:space-between;padding:22px;border-bottom:1px solid var(--color-line)}
.filterpanel__title{display:flex;align-items:center;gap:10px;font-size:1.2rem;color:var(--color-dark);font-weight:700}
.filterpanel__title i{color:var(--color-accent)}
.filterpanel__close{width:38px;height:38px;border-radius:50%;color:var(--color-muted);font-size:1.2rem;transition:var(--trans)}
.filterpanel__close:hover{background:var(--color-bg-soft);color:var(--color-accent)}
.filterpanel__foot{padding:18px 22px 24px;border-top:1px solid var(--color-line);display:flex;flex-direction:column;gap:10px}
.filterpanel__overlay{position:fixed;inset:0;background:rgba(31,29,26,.5);backdrop-filter:blur(2px);z-index:110;opacity:0;visibility:hidden;transition:var(--trans)}
.filterpanel__overlay.show{opacity:1;visibility:visible}
.fpanel{flex:1;overflow-y:auto;padding:18px 22px}
.fgroup{margin-bottom:24px;padding-bottom:22px;border-bottom:1px solid var(--color-line)}
.fgroup:last-child{border-bottom:none}
.fgroup__label{display:block;font-size:12.5px;font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:13px}
.check{display:flex;align-items:center;gap:11px;padding:7px 0;font-size:15px;color:var(--color-text);cursor:pointer}
.check input{width:19px;height:19px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}
.frange{display:flex;align-items:center;gap:10px}
.frange__input{width:100%;padding:11px 12px;border:1.5px solid var(--color-line);border-radius:var(--radius-sm);font-family:inherit;font-size:14.5px;background:#fff;transition:var(--trans)}
.frange__input:focus{outline:none;border-color:var(--color-accent)}
.frange__dash{color:var(--color-muted)}
@media (max-width:1280px){ .cards-grid--catalog{grid-template-columns:repeat(3,1fr)} }
@media (max-width:1024px){ .catwrap{padding:0 24px} .cards-grid--catalog{grid-template-columns:repeat(2,1fr)} }
@media (max-width:680px){ .catwrap{padding:0 18px} .cards-grid--catalog{grid-template-columns:1fr} .catbar{gap:12px} .catbar__right{margin-left:0;width:100%} .catbar__sort{width:100%;justify-content:space-between} .catbar__sort select{flex:1;margin-left:10px} }
