/* =====================================================
   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))}
}

/* ── Προβεβλημένες — slim premium "paid" ribbon (low height, horizontal scroll) ── */
.feat-slider{padding:10px 0 8px}
.feat-head{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.feat-head svg.feat-star{width:14px;height:14px;color:var(--gold);flex-shrink:0}
.feat-head b{font-size:13px;color:var(--text);font-weight:700;letter-spacing:.01em}
.feat-head .feat-sub{font-size:12px;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:28px;height:28px;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:13px;height:13px}
/* the single row: horizontal scroll + snap, hidden scrollbar */
.feat-row{display:flex;gap:9px;overflow-x:auto;scroll-snap-type:x proximity;scroll-behavior:smooth;padding-bottom:2px;scrollbar-width:none}
.feat-row::-webkit-scrollbar{display:none}
/* compact horizontal card (thumb + name/price); gold left-accent + ⭐ = paid */
.feat-card{flex:0 0 auto;width:230px;display:flex;align-items:center;gap:10px;scroll-snap-align:start;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:var(--r);padding:6px;transition:box-shadow .15s,transform .15s}
.feat-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.feat-card-img{position:relative;flex-shrink:0;width:64px;height:48px;border-radius:calc(var(--r) - 1px);overflow:hidden;background:var(--surface-2)}
.feat-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.feat-card-img .feat-ph{position:absolute;inset:0;display:grid;place-items:center;background:linear-gradient(140deg,hsl(var(--ph-h,210),33%,45%),hsl(var(--ph-h,210),40%,29%));color:#fff}
.feat-card-img .feat-ph svg{width:20px;height:20px;opacity:.9}
.feat-star-badge{position:absolute;top:2px;left:2px;width:15px;height:15px;display:grid;place-items:center;color:var(--gold);filter:drop-shadow(0 1px 1px rgba(0,0,0,.55))}
.feat-star-badge svg{width:12px;height:12px}
.feat-card-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.feat-card-nm{font-size:12.5px;font-weight:600;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.feat-card-pr{font-size:13px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
@media(max-width:640px){.feat-card{width:208px}}

/* ── 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)}

/* ── Model combobox: hide native <select> (kept as form field + cascade target) ── */
.sb-native-select{display:none}
.sb-make-btn:disabled,.sb-make-wrap.is-disabled .sb-make-btn{opacity:.5;cursor:not-allowed}
.sb-make-btn:disabled:hover,.sb-make-wrap.is-disabled .sb-make-btn:hover{border-color:var(--line-2)}

/* ── Multi-select checkbox facets (reuse the .sb-make-* dropdown look) ── */
.facet-opt{cursor:pointer}
.facet-opt input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.facet-opt .ck{width:17px;height:17px;flex-shrink:0;border:1.5px solid var(--line-2);border-radius:var(--r);display:grid;place-items:center;transition:background .12s,border-color .12s}
.facet-opt .ck::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) scale(0);margin-top:-2px;transition:transform .1s}
.facet-opt input:checked + .ck{background:var(--blue);border-color:var(--blue)}
.facet-opt input:checked + .ck::after{transform:rotate(45deg) scale(1)}
.facet-opt input:checked ~ .n{color:var(--blue-txt);font-weight:600}
.facet-clear{display:block;width:100%;text-align:center;padding:9px;border-top:1px solid var(--line);color:var(--blue-txt);font-weight:600;font-size:13px;cursor:pointer}
.facet-clear:hover{background:var(--hover)}

/* ── Εξοπλισμός (features) — category-grouped checklist ── */
.sb-badge[hidden]{display:none}
.feat-cat{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);margin:9px 0 3px}
.feat-cat:first-child{margin-top:2px}
.feat-chk{display:flex;align-items:center;gap:9px;padding:5px 4px;border-radius:var(--r);cursor:pointer;font-size:13px;color:var(--text);transition:background .12s}
.feat-chk:hover{background:var(--hover)}
.feat-chk input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.feat-chk .ck{width:17px;height:17px;flex-shrink:0;border:1.5px solid var(--line-2);border-radius:var(--r);display:grid;place-items:center;transition:background .12s,border-color .12s}
.feat-chk .ck::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) scale(0);margin-top:-2px;transition:transform .1s}
.feat-chk input:checked + .ck{background:var(--blue);border-color:var(--blue)}
.feat-chk input:checked + .ck::after{transform:rotate(45deg) scale(1)}
.feat-chk input:checked ~ .n{color:var(--blue-txt);font-weight:600}

/* 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:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.sb-title{font-size:18px;font-weight:700;margin:2px 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:2px}
.sb-h{font-size:14px;font-weight:700;letter-spacing:.01em}
.sb-clear{font-size:12.5px;color:var(--blue-txt);font-weight:600;cursor:pointer;background:none;border:none}
.sb-clear:hover{text-decoration:underline}

/* collapsible filter groups (accordion): summary head + body */
.sb-group{border-top:1px solid var(--line)}
.sb-group:first-of-type{border-top:none}
.sb-group-head{display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;list-style:none;user-select:none;padding:12px 0}
.sb-group-head::-webkit-details-marker{display:none}
.sb-group-head:hover .sb-group-lbl,.sb-group[open] .sb-group-lbl{color:var(--text-2)}
.sb-group-lbl{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin:0;display:inline-flex;align-items:center;gap:6px;transition:color .12s}
.sb-group-arr{width:15px;height:15px;color:var(--text-3);transition:transform .15s;flex-shrink:0}
.sb-group[open] .sb-group-head .sb-group-arr{transform:rotate(180deg)}
.sb-group-body{padding-bottom:13px}
.sb-group-body > .frow:first-child,.sb-group-body > .frange:first-child,.sb-group-body > .ffacet:first-child{margin-top:0}

/* toggle-chip facet (gearbox/fuel/condition/drive/doors/seats/region) */
.ffacet{margin:12px 0}
.ffacet-lbl{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:7px}
.ffacet-lbl svg,.ffacet-lbl img{width:14px;height:14px;flex-shrink:0;color:var(--text-3)}
.ffacet:has(input:checked) .ffacet-lbl{color:var(--blue-txt)}
.ffacet:has(input:checked) .ffacet-lbl svg{color:var(--blue)}
.chip-set{display:flex;flex-wrap:wrap;gap:6px}
.fchip{position:relative;display:inline-flex;align-items:center;padding:5px 11px;border:1px solid var(--line-2);border-radius:var(--r);font-size:12.5px;font-weight:500;color:var(--text-2);background:var(--surface);cursor:pointer;white-space:nowrap;transition:border-color .12s,background .12s,color .12s}
.fchip:hover{border-color:var(--text-3);color:var(--text)}
.fchip input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.fchip:has(input:checked){background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600}
.fchip:focus-within{outline:none;box-shadow:0 0 0 2px var(--blue-dim)}
/* color swatch grid */
.swatch-set{display:flex;flex-wrap:wrap;gap:7px}
.swatch{position:relative;cursor:pointer;line-height:0}
.swatch input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.sw-dot{display:grid;place-items:center;width:26px;height:26px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);overflow:hidden;transition:box-shadow .12s,border-color .12s}
.sw-dot svg,.sw-dot img{width:100%;height:100%;object-fit:cover;display:block}
.swatch:hover .sw-dot{border-color:var(--text-3)}
.swatch:has(input:checked) .sw-dot{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue)}

/* μία γραμμή ανά φίλτρο: [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}
/* διακριτική κλίμακα ορίων (min … max) ώστε ο χρήστης να ξέρει το εύρος */
.frange-scale{display:flex;justify-content:space-between;margin-top:5px;font-size:10px;color:var(--text-3);font-variant-numeric:tabular-nums;letter-spacing:.01em}

/* κατηγορίες (αμάξωμα) — compact 2-col multi-select chip grid */
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.cat{position:relative;display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--line-2);border-radius:var(--r);font-size:13px;font-weight:500;color:var(--text);background:var(--surface);cursor:pointer;min-width:0;transition:border-color .12s,background .12s,color .12s}
.cat:hover{border-color:var(--text-3)}
.cat input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.cat .ic{width:18px;height:18px;display:grid;place-items:center;flex-shrink:0;color:var(--text-2)}
.cat .ic svg,.cat .ic img{width:18px;height:18px}
.cat .cat-nm{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cat .cnt{margin-left:auto;font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums;flex-shrink:0}
.cat:has(input:checked){border-color:var(--blue);background:var(--blue-dim);color:var(--blue-txt);font-weight:600}
.cat:has(input:checked) .ic,.cat:has(input:checked) .cnt{color:var(--blue)}
.cat:focus-within{outline:none;border-color:var(--blue)}

/* upsell επαγγελματιών */
.sb-pro{position:relative;margin-top:18px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r);padding:14px 13px 13px;overflow:hidden}
.sb-pro::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--gold),#e0a92e)}
.sb-pro-ic{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:var(--r);background:var(--blue-dim);color:var(--gold);margin-bottom:7px}
.sb-pro-ic svg{width:15px;height:15px}
.sb-pro b{font-size:14px;display:block;margin-bottom:3px;letter-spacing:-.01em}
.sb-pro p{font-size:12.5px;color:var(--text-2);margin-bottom:9px;line-height:1.4}
.sb-pro a{color:var(--blue-txt);font-weight:600;font-size:13.5px;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(47,99,224,.25);display:grid;place-items:center;font-size:10px;line-height:1;color:inherit}
.fchip a:hover,.fchip button:hover{background:rgba(47,99,224,.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}}
