/* =====================================================
   Marketplace feed (homepage / search / browse)
   sidebar φίλτρων (μία γραμμή ανά φίλτρο) + dense grid (5/σειρά)
   + infinite scroll + skeletons. Border radius: var(--r) παντού.
   ===================================================== */
body{padding-top:56px}
/* footer clears the fixed filter sidebar on feed pages */
.mk-footer{margin-left:320px}
@media (max-width:900px){.mk-footer{margin-left:0}}

/* ── Bottom-nav coexistence (mobile): the center "Πούλησε" tab replaces the
   create FAB, and the filters FAB rises above the bar. ── */
@media (max-width:768px){
  body.has-bnav .fab{display:none}
  body.has-bnav .filters-fab{bottom:calc(70px + env(safe-area-inset-bottom,0px))}
}

/* ── "Συνέχισε εκεί που έμεινες" — compact chip strip ── */
.rv-chips-wrap{padding:10px 0 6px}
.rv-chips-head{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.rv-chips-head svg{width:13px;height:13px;color:var(--text-3);flex-shrink:0}
.rv-chips-head b{font-size:12.5px;font-weight:600;color:var(--text-3);letter-spacing:.01em}
.rv-chips{display:flex;gap:7px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.rv-chips::-webkit-scrollbar{display:none}
.rv-chip{flex:none;display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 11px 0 5px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);text-decoration:none;color:var(--text);font-size:12.5px;white-space:nowrap;transition:border-color .12s,background .12s}
.rv-chip:hover{border-color:var(--blue);background:var(--blue-dim)}
.rv-chip-img{width:26px;height:26px;border-radius:calc(var(--r) - 1px);object-fit:cover;flex-shrink:0;background:var(--surface-2);display:block}
.rv-chip-nm{font-weight:600;max-width:115px;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.rv-chip-sep{color:var(--text-3);font-size:11px;flex-shrink:0}
.rv-chip-pr{color:var(--blue-txt);font-weight:700;font-variant-numeric:tabular-nums;font-size:12px;flex-shrink:0}

/* ── Προβεβλημένες — ALWAYS one row, scrolls (slider) when items overflow ── */
.feat-slider{padding:12px 0 8px}
.feat-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.feat-head svg.feat-star{width:15px;height:15px;color:var(--gold);flex-shrink:0}
.feat-head b{font-size:15px;color:var(--text);font-weight:700}
.feat-head .feat-sub{font-size:12.5px;color:var(--text-3)}
.feat-nav{margin-left:auto;display:flex;align-items:center;gap:6px}
/* [hidden] alone loses to .feat-nav{display:flex} → force it (AGENTS Phase 54.1) */
.feat-nav[hidden]{display:none}
.feat-nav-btn{width:30px;height:30px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line-2);display:grid;place-items:center;cursor:pointer;color:var(--text-2);transition:background .12s,color .12s;flex-shrink:0}
.feat-nav-btn:hover{background:var(--hover);color:var(--text)}
.feat-nav-btn:disabled{opacity:.3;cursor:default}
.feat-nav-btn svg{width:14px;height:14px}
/* the single row: horizontal scroll + snap, hidden scrollbar */
.feat-row{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x proximity;scroll-behavior:smooth;padding-bottom:4px;scrollbar-width:none}
.feat-row::-webkit-scrollbar{display:none}
/* Smart sizing: when few, cards GROW to fill the row (no dead space on wide
   screens, capped so they never get absurd); when many, they hold 140px and
   the row overflows → horizontal scroll/slider. grow:1 shrink:0 basis:140. */
.feat-card{flex:1 0 140px;max-width:250px;scroll-snap-align:start;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .15s,transform .15s}
.feat-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
/* photo: absolute-fill so the image always covers, zero blank space */
.feat-card-img{display:block;position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surface-2)}
.feat-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* one-line info: brand model · price */
.feat-card-info{display:flex;align-items:center;gap:4px;padding:5px 7px 6px;min-width:0}
.feat-card-nm{font-size:11px;font-weight:600;color:var(--text-2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.feat-card-dot{font-size:10px;color:var(--text-3);flex-shrink:0}
.feat-card-pr{font-size:11.5px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;flex-shrink:0;white-space:nowrap}
@media(max-width:640px){.feat-card{flex-basis:152px;max-width:200px}}

/* ── Brand combobox with logos (replaces native <select> for #feedMake) ── */
.sb-make-wrap{flex:1;min-width:0;position:relative}
.sb-make-btn{display:flex;align-items:center;gap:7px;width:100%;height:38px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);padding:0 26px 0 8px;font-size:14px;color:var(--text);cursor:pointer;text-align:left;overflow:hidden;position:relative;white-space:nowrap}
.sb-make-btn:hover{border-color:var(--text-3)}
.sb-make-btn:focus,.frow--on .sb-make-btn{outline:none;border-color:var(--blue)}
.sb-lbl{display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden}
.sb-lbl .n{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-sel-arr{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-3);pointer-events:none;flex-shrink:0}
/* dropdown panel — εκτείνεται από την αριστερή άκρη της γραμμής (κάτω από το
   label) ώς το control, δηλ. όλο το πλάτος του sidebar content → ΔΕΝ ξεχειλίζει
   ούτε κόβεται από το .sidebar{overflow-y:auto}. Το -98px = label(88) + gap(10). */
.sb-make-pop{position:absolute;left:-98px;top:calc(100% + 4px);width:calc(100% + 98px);background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-pop);z-index:200;overflow:hidden}
.sb-make-search{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--line)}
.sb-make-search svg{width:14px;height:14px;color:var(--text-3);flex-shrink:0}
.sb-make-q{flex:1;min-width:0;border:none;background:transparent;color:var(--text);font-size:13.5px;outline:none}
.sb-make-q::placeholder{color:var(--text-3)}
.sb-make-list{max-height:min(280px,55vh);overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;padding:4px 0}
.sb-make-opt{display:flex;align-items:center;gap:9px;width:100%;padding:7px 12px;background:none;border:none;font-size:13.5px;color:var(--text);cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden}
.sb-make-opt:hover{background:var(--hover)}
.sb-make-opt.on{color:var(--blue-txt);font-weight:600;background:var(--blue-dim)}
.sb-make-opt .n{min-width:0;overflow:hidden;text-overflow:ellipsis}
.sb-make-opt .cnt{margin-left:auto;font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums;flex-shrink:0;padding-left:4px}
/* brand logo image inside the combobox (the global .blogo is scoped to .lcard,
   so it has NO size here → must constrain it explicitly or it renders huge) */
.sb-make-wrap .blogo{width:22px;height:22px;flex-shrink:0;border-radius:var(--r);object-fit:contain;background:#fff;padding:2px}
/* brand logo placeholder (first letter or ✕ for clear) */
.blogo-ph{width:22px;height:22px;flex-shrink:0;border-radius:var(--r);background:var(--hover-2);color:var(--text-2);display:grid;place-items:center;font-size:10px;font-weight:800;line-height:1}
.blogo-clear{font-size:11px;background:var(--hover);color:var(--text-3)}

/* active filter count badge on the "Φίλτρα" heading */
.sb-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--r);background:var(--blue);color:#fff;font-size:11px;font-weight:700;margin-left:6px;line-height:1}

/* model select: visually disabled until a brand is chosen */
#feedModel:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}

/* ---------- Sidebar (φίλτρα) ---------- */
.sidebar{position:fixed;left:0;top:56px;bottom:0;width:320px;background:var(--surface);border-right:1px solid var(--line);overflow-y:auto;overscroll-behavior:contain;padding:14px 16px 28px;z-index:50;scrollbar-width:thin;scrollbar-color:transparent transparent}
.sidebar:hover,.sidebar:focus-within{scrollbar-color:var(--line-2) transparent}
.sidebar::-webkit-scrollbar{width:7px}
.sidebar::-webkit-scrollbar-thumb{background:transparent;border-radius:var(--r)}
.sidebar:hover::-webkit-scrollbar-thumb,.sidebar:focus-within::-webkit-scrollbar-thumb{background:var(--line-2)}
.sb-kicker{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3)}
.sb-title{font-size:22px;font-weight:700;margin:1px 0 12px;letter-spacing:-.01em}
.sb-hr{border:none;border-top:1px solid var(--line-2);margin:12px -4px}
.sb-head-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.sb-h{font-size:16px;font-weight:700}
.sb-clear{font-size:13px;color:var(--blue-txt);font-weight:600;cursor:pointer;background:none;border:none}
.sb-clear:hover{text-decoration:underline}

/* μία γραμμή ανά φίλτρο: [label] [control] */
.frow{position:relative;display:flex;align-items:center;gap:10px;min-height:38px;margin:9px 0}
/* όταν το brand-combobox είναι ανοιχτό, η γραμμή του ανεβαίνει πάνω από τις
   υπόλοιπες (+ τα native selects τους) ώστε το dropdown να μην "σπάει" το design */
.frow:has(.sb-make-btn[aria-expanded="true"]){z-index:120}
/* ενεργό φίλτρο: μπλε accent στο label + αριστερή γραμμή */
.frow--on .frow-lbl{color:var(--blue-txt)}
.frow--on .frow-lbl svg{color:var(--blue)}
.frow--on .frow-ctl .sb-select{border-color:var(--blue);color:var(--text)}
.frow-lbl{flex:0 0 88px;font-size:13px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:6px;line-height:1.15}
.frow-lbl svg{width:14px;height:14px;flex-shrink:0;color:var(--text-3)}
.frow-ctl{flex:1;min-width:0;display:flex;align-items:center;gap:6px}
.frow-ctl .sb-select,.frow-ctl .sb-num{width:100%;min-width:0;height:38px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);padding:0 9px;font-size:14px;color:var(--text)}
.frow-ctl .sb-select{cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238a8d91' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:14px}
.frow-ctl .sb-select:hover{border-color:var(--text-3)}
.frow-ctl .sb-select:focus,.frow-ctl .sb-num:focus{outline:none;border-color:var(--blue)}
.frow-ctl .sb-num{background:transparent}
.frow-ctl .sb-num::placeholder{color:var(--text-3)}
.frow-ctl .sep{color:var(--text-3);font-size:12px;flex-shrink:0}
.sb-select option{background:var(--surface);color:var(--text)}

/* dual-handle range slider */
.frange{margin:12px 0}
.frange-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:2px}
.frange-lbl{font-size:13px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:6px}
.frange-lbl svg{width:14px;height:14px;flex-shrink:0;color:var(--text-3)}
.frange-val{font-size:12.5px;font-weight:600;color:var(--blue-txt);font-variant-numeric:tabular-nums;white-space:nowrap}
.rs{position:relative;height:24px}
.rs-track{position:absolute;left:2px;right:2px;top:10px;height:4px;border-radius:var(--r);background:var(--line-2)}
.rs-fill{position:absolute;height:100%;border-radius:var(--r);background:var(--blue)}
.rs input[type=range]{position:absolute;left:0;top:0;width:100%;height:24px;margin:0;background:none;pointer-events:none;-webkit-appearance:none;appearance:none}
.rs input.rs-lo{z-index:2}
.rs input.rs-hi{z-index:3}
.rs input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;width:16px;height:16px;border-radius:var(--r);background:var(--surface);border:2px solid var(--blue);box-shadow:var(--shadow);cursor:grab}
.rs input[type=range]:active::-webkit-slider-thumb{cursor:grabbing}
.rs input[type=range]::-moz-range-thumb{pointer-events:auto;width:14px;height:14px;border-radius:var(--r);background:var(--surface);border:2px solid var(--blue);box-shadow:var(--shadow);cursor:grab}
.rs input[type=range]::-webkit-slider-runnable-track{background:none;border:none}
.rs input[type=range]::-moz-range-track{background:none;border:none}

/* κατηγορίες (αμάξωμα) */
.sb-sub{font-size:13px;font-weight:700;color:var(--text-2);margin:6px 0 2px}
.cat{display:flex;align-items:center;gap:11px;width:100%;padding:8px 6px;margin:0 -6px;border-radius:var(--r);font-size:14.5px;font-weight:500;text-align:left;transition:background .12s;color:var(--text);background:none;border:none;cursor:pointer}
.cat:hover{background:var(--hover)}
.cat .ic{width:34px;height:34px;border-radius:var(--r);background:var(--hover);display:grid;place-items:center;flex-shrink:0;color:var(--text);transition:background .12s}
.cat .ic svg,.cat .ic img{width:18px;height:18px}
.cat.on .ic{background:var(--blue);color:#fff}
.cat.on{font-weight:600}
.cat .cnt{margin-left:auto;font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums}

/* upsell επαγγελματιών */
.sb-pro{margin-top:16px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r);padding:13px}
.sb-pro b{font-size:14.5px;display:block;margin-bottom:3px}
.sb-pro p{font-size:12.5px;color:var(--text-2);margin-bottom:8px}
.sb-pro a{color:var(--blue-txt);font-weight:600;font-size:14px;cursor:pointer}
.sb-pro a:hover{text-decoration:underline}

/* ---------- Main feed ---------- */
.main{margin-left:320px;padding:0 24px 56px}

/* sticky results header: τίτλος + πλήθος | save + ταξινόμηση */
.feed-bar{position:sticky;top:56px;z-index:40;background:var(--bg);display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:16px 0 10px}
.feed-headings{display:flex;align-items:baseline;gap:10px;min-width:0;flex:1}
.feed-head{font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-count{font-size:13px;color:var(--text-2);white-space:nowrap;flex-shrink:0}
.feed-spin{display:none;color:var(--blue-txt)}
.htmx-request .feed-spin{display:inline}
.feed-tools{display:flex;align-items:center;gap:8px;flex-shrink:0}
.feed-save{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 13px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);color:var(--text-2);font-size:13.5px;font-weight:600;cursor:pointer;white-space:nowrap}
.feed-save:hover{background:var(--hover);color:var(--text)}
.feed-save.on{background:var(--blue-dim);border-color:transparent;color:var(--blue-txt)}
.feed-save svg{width:15px;height:15px}
.feed-sort{position:relative;display:flex;align-items:center}
.feed-sort svg{position:absolute;left:10px;width:14px;height:14px;color:var(--text-2);pointer-events:none}
.feed-sort select{height:36px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);color:var(--text);font-size:13.5px;font-weight:600;padding:0 9px 0 30px;cursor:pointer}
.feed-sort select:focus{outline:none;border-color:var(--blue)}

/* ενεργά φίλτρα */
.active-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.fchip{display:inline-flex;align-items:center;gap:7px;background:var(--blue-dim);color:var(--blue-txt);font-size:12.5px;font-weight:600;padding:6px 8px 6px 12px;border-radius:var(--r)}
.fchip a,.fchip button{width:16px;height:16px;border-radius:var(--r);background:rgba(45,136,255,.25);display:grid;place-items:center;font-size:10px;line-height:1;color:inherit}
.fchip a:hover,.fchip button:hover{background:rgba(45,136,255,.45)}
.fchip-clear{font-size:12.5px;font-weight:700;color:var(--text-2);padding:6px 10px;border-radius:var(--r)}
.fchip-clear:hover{background:var(--hover);color:var(--text)}

.empty{padding:70px 20px;text-align:center;color:var(--text-2)}
.empty b{display:block;color:var(--text);font-size:17px;margin-bottom:6px}
.empty .clearbtn{display:inline-flex;align-items:center;height:38px;padding:0 18px;margin-top:14px;border-radius:var(--r);background:var(--blue);color:#fff;font-weight:600;font-size:14px}
.empty .clearbtn:hover{background:var(--blue-hover)}

/* feed grid: σταθερές 5 στήλες με αέρα, responsive */
.feed-results .grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:26px 20px}
.feed-results.htmx-swapping{opacity:.45;transition:opacity .12s ease-in}

/* infinite scroll trigger + skeletons */
.feed-more{margin-top:26px;min-height:1px}
.feed-more .feed-skel{display:none}
.feed-more.htmx-request .feed-skel{display:grid}

/* ── Χάρτης (Leaflet feed map) ──────────────────────────── */
.feed-map-toggle{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 13px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);color:var(--text-2);font-size:13.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s,border-color .12s}
.feed-map-toggle:hover{background:var(--hover);color:var(--text)}
.feed-map-toggle.on{background:var(--blue-dim);border-color:transparent;color:var(--blue-txt)}
.feed-map-toggle svg{width:15px;height:15px}
/* Map view: το #feedMap είναι sibling του #feedResults (επιβιώνει στα HTMX
   swaps). Η κλάση .map-mode μπαίνει στο .main (ΔΕΝ γίνεται swap) → κρύβει τις
   κάρτες + δείχνει τον χάρτη. Specificity 1,2,0 νικά το .grid{display:grid}. */
.feed-map{display:none;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;height:min(640px,calc(100vh - 150px));min-height:420px;background:var(--surface-2);margin-bottom:24px}
.main.map-mode #feedGrid,
.main.map-mode #feedMore{display:none}
.main.map-mode .feed-map{display:block}
.map-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-2);font-size:14px}
.map-err{padding:24px;text-align:center;color:var(--text-2);font-size:14px}
/* Leaflet βάση/popups/dark tiles: ΚΟΙΝΑ στο marketplace.css (tokens) */

/* ── Listing pins (price-pill divIcons) ───────────────────────── */
.mk-pin-wrap{background:transparent !important;border:0 !important}
.mk-pin{display:inline-flex;align-items:center;background:var(--surface);color:var(--text);border:1px solid var(--line-2);border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;box-shadow:var(--shadow);white-space:nowrap;cursor:pointer;transform:translate(-50%,-100%);position:relative;transition:transform .12s,box-shadow .12s,background .12s,color .12s}
.mk-pin:hover{transform:translate(-50%,-100%) scale(1.06);box-shadow:var(--shadow-pop);background:var(--blue);color:#fff;border-color:var(--blue)}
.mk-pin::after{content:"";position:absolute;left:50%;bottom:-5px;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--surface);filter:drop-shadow(0 1px 0 var(--line-2))}
.mk-pin:hover::after{border-top-color:var(--blue);filter:none}

/* ── Clusters (count circles, branded) ────────────────────────── */
.mk-cluster{background:transparent !important;border:0 !important}
.mk-cluster-i{display:flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:50%;background:#1f2433;color:#fff;font-weight:800;font-size:13px;border:3px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.35);font-variant-numeric:tabular-nums}
[data-theme="dark"] .mk-cluster-i{background:#0d1220;border-color:var(--line-2)}
@media (prefers-color-scheme: dark){
  :root:not([data-theme]) .mk-cluster-i{background:#0d1220;border-color:var(--line-2)}
}

/* ── Dealer business pins (separate layer, always visible) ────── */
.mk-dealer-wrap{background:transparent !important;border:0 !important}
.mk-dealer{position:relative;transform:translate(-50%,-100%)}
.mk-dealer-i{width:36px;height:36px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.35);display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px;overflow:hidden;cursor:pointer;transition:transform .12s,box-shadow .12s}
.mk-dealer-i img{width:100%;height:100%;object-fit:cover;display:block;background:#fff}
.mk-dealer:hover .mk-dealer-i{transform:scale(1.08);box-shadow:0 6px 18px rgba(0,0,0,.45)}
.mk-dealer::after{content:"";position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--blue)}

/* dealer popup extras (.mp-tag/.mp-sub): ΚΟΙΝΑ στο marketplace.css */

/* scroll-to-top */
.to-top{position:fixed;right:22px;bottom:84px;width:44px;height:44px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line-2);color:var(--text);display:grid;place-items:center;box-shadow:var(--shadow-pop);z-index:60;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .15s,transform .15s,visibility .15s}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top svg{width:20px;height:20px}

/* FABs */
.fab{position:fixed;right:22px;bottom:22px;width:52px;height:52px;border-radius:var(--r);background:var(--blue);border:none;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-pop);z-index:60;transition:background .12s,transform .12s}
.fab:hover{background:var(--blue-hover);transform:scale(1.05)}
.fab svg{width:22px;height:22px}
.filters-fab{display:none;position:fixed;left:22px;bottom:22px;height:44px;padding:0 18px;border-radius:var(--r);background:var(--surface);color:var(--text);border:1px solid var(--line-2);font-weight:700;font-size:14px;z-index:60;box-shadow:var(--shadow-pop);align-items:center;gap:8px;cursor:pointer}
.filters-fab svg{color:var(--blue)}

@media(max-width:1280px){.feed-results .grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:1040px){.feed-results .grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:980px){
  .sidebar{transform:translateX(-100%);transition:transform .22s ease;width:min(330px,86vw);box-shadow:8px 0 30px rgba(0,0,0,.5)}
  .sidebar.open{transform:none}
  .main{margin-left:0;padding:0 14px 90px}
  .feed-bar{top:56px}
  .filters-fab{display:flex}
}
@media(max-width:640px){.feed-results .grid{grid-template-columns:repeat(2,1fr);gap:16px 10px}}
