/* =====================================================
   Car For Sale Cyprus — Marketplace design system
   (νέο public frontend, FB Marketplace στυλ)

   ΜΗΝ το επεξεργάζεσαι χειροκίνητα ανά σελίδα: εδώ ζει ΜΟΝΟ το κοινό
   σύστημα (design tokens + reset + topbar + κάρτες + skeleton + map + toast).
   Στυλ ανά σελίδα → public/assets/css/mk-*.css.

   Border radius: ΕΝΑ token --r:4px παντού (συνέπεια). Ακόμα και τα πρώην
   κυκλικά (avatar / εικονίδια header / overlay κουμπιά) είναι rounded squares.

   Θέμα: ακολουθεί τη ΣΥΣΚΕΥΗ (prefers-color-scheme) — αν δεν υπάρχει
   ρητή επιλογή. Το [data-theme="dark|light"] (cookie) υπερισχύει.
   Σκούρα παλέτα: #21232f navy-indigo.
   ===================================================== */

/* ---------- Design tokens — LIGHT (default + ρητό light) ---------- */
:root,
:root[data-theme="light"]{
  --bg:         #F0F2F5;
  --surface:    #FFFFFF;
  --surface-2:  #F0F2F5;
  --hover:      #E4E6EB;
  --hover-2:    #D8DADF;
  --input:      #F0F2F5;
  --line:       #E4E6E9;
  --line-2:     #CED0D4;
  --text:       #050505;
  --text-2:     #65676B;
  --text-3:     #8A8D91;
  --blue:       #2D88FF;
  --blue-hover: #1877F2;
  --blue-txt:   #1B6FE0;
  --blue-dim:   rgba(45,136,255,.12);
  --red:        #E41E3F;
  --green:      #31A24C;
  --gold:       #F5C33B;
  --scroll:     #BCC0C4;
  --r:          4px;       /* ← ΕΝΙΑΙΟ border radius παντού */
  --shadow:       0 1px 2px rgba(0,0,0,.12);
  --shadow-card:  0 1px 4px rgba(0,0,0,.08);
  --shadow-hover: 0 6px 18px rgba(0,0,0,.14);
  --shadow-pop:   0 8px 26px rgba(0,0,0,.22);
  --map-tile-filter: none;  /* Leaflet tiles: αλλάζει σε dark (βλ. tokens dark) */
  --map-canvas: #ddd;
}

/* ---------- DARK μέσω προτίμησης συσκευής (μόνο χωρίς ρητή επιλογή) ---------- */
@media (prefers-color-scheme: dark){
  :root:not([data-theme]){
    --bg:         #21232f;
    --surface:    #272a38;
    --surface-2:  #2d3044;
    --hover:      #33374a;
    --hover-2:    #3d4260;
    --input:      #2a2d3d;
    --line:       #2e3145;
    --line-2:     #383d58;
    --text:       #e2e5f0;
    --text-2:     #9ca3c0;
    --text-3:     #6c7294;
    --blue:       #4d96ff;
    --blue-hover: #3c87f0;
    --blue-txt:   #7aadff;
    --blue-dim:   rgba(77,150,255,.22);
    --red:        #f04055;
    --green:      #3ec75a;
    --gold:       #f5c33b;
    --scroll:     #3a3f58;
    --shadow:       0 1px 3px rgba(0,0,0,.55);
    --shadow-card:  0 2px 8px rgba(0,0,0,.40);
    --shadow-hover: 0 6px 22px rgba(0,0,0,.60);
    --shadow-pop:   0 8px 30px rgba(0,0,0,.70);
    --map-tile-filter: brightness(.7) invert(1) contrast(2) hue-rotate(200deg) saturate(.7) brightness(.7);
    --map-canvas: #1e2333;
  }
}

/* ---------- DARK ρητό (cookie theme=dark / toggle) ---------- */
:root[data-theme="dark"]{
  --bg:         #21232f;
  --surface:    #272a38;
  --surface-2:  #2d3044;
  --hover:      #33374a;
  --hover-2:    #3d4260;
  --input:      #2a2d3d;
  --line:       #2e3145;
  --line-2:     #383d58;
  --text:       #e2e5f0;
  --text-2:     #9ca3c0;
  --text-3:     #6c7294;
  --blue:       #4d96ff;
  --blue-hover: #3c87f0;
  --blue-txt:   #7aadff;
  --blue-dim:   rgba(77,150,255,.22);
  --red:        #f04055;
  --green:      #3ec75a;
  --gold:       #f5c33b;
  --scroll:     #3a3f58;
  --shadow:       0 1px 3px rgba(0,0,0,.55);
  --shadow-card:  0 2px 8px rgba(0,0,0,.40);
  --shadow-hover: 0 6px 22px rgba(0,0,0,.60);
  --shadow-pop:   0 8px 30px rgba(0,0,0,.70);
  --map-tile-filter: brightness(.7) invert(1) contrast(2) hue-rotate(200deg) saturate(.7) brightness(.7);
  --map-canvas: #1e2333;
}

/* ---------- Reset & βάση ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.34;-webkit-font-smoothing:antialiased;transition:background .15s,color .15s}
button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
img{max-width:100%}
input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:var(--scroll);border-radius:var(--r)}
::-webkit-scrollbar-track{background:transparent}
:focus-visible{outline:2px solid var(--blue);outline-offset:1px;border-radius:var(--r)}
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;z-index:300}
.skip-link:focus{left:8px;top:8px;background:var(--blue);color:#fff;padding:8px 14px;border-radius:var(--r);font-weight:600}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ---------- Top bar ---------- */
.topbar{position:fixed;top:0;left:0;right:0;height:56px;background:var(--surface);box-shadow:var(--shadow);z-index:100;display:flex;align-items:center;padding:0 16px;gap:10px}
.topbar--flow{position:static;flex-shrink:0}
/* 3-column centred layout when the inline search is present */
.topbar--search{display:grid;grid-template-columns:1fr minmax(0,560px) 1fr;align-items:center;gap:12px}
.topbar--search .tb-left{flex:0 0 auto}
.topbar--search .tb-right{margin-left:0;justify-self:end}
.tb-center{display:flex;align-items:center;min-width:0}
.tb-center .tb-search{flex:1;min-width:0;max-width:none}
.tb-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.tb-brand{display:flex;align-items:center;gap:9px;flex-shrink:0}
.tb-logo{width:40px;height:40px;border-radius:var(--r);flex-shrink:0;display:block}
.tb-name{font-size:18px;font-weight:700;letter-spacing:-.01em;white-space:nowrap}
.tb-circle{position:relative;width:40px;height:40px;border-radius:var(--r);background:var(--hover);display:grid;place-items:center;color:var(--text);flex-shrink:0;transition:background .12s}
.tb-circle:hover{background:var(--hover-2)}
.tb-circle svg{width:18px;height:18px}
.tb-badge{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;border-radius:var(--r);background:var(--red);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;padding:0 5px}
.tb-badge.fav{background:var(--blue)}            /* count αγαπημένων = ενημερωτικό (μπλε), όχι alert */
.tb-right{margin-left:auto;display:flex;align-items:center;gap:7px}
/* διακριτικός κάθετος διαχωριστής μεταξύ ομάδων εικονιδίων */
.tb-div{width:1px;height:22px;background:var(--line-2);flex-shrink:0;margin:0 3px}
.tb-avatar{position:relative;width:40px;height:40px;border-radius:var(--r);background:linear-gradient(135deg,#2D88FF,#7B5CFF);display:grid;place-items:center;font-weight:700;font-size:16px;color:#fff;flex-shrink:0;text-transform:uppercase}
.tb-btn{height:38px;padding:0 16px;border-radius:var(--r);font-weight:600;font-size:14.5px;display:inline-flex;align-items:center;gap:7px;transition:background .12s,filter .12s;white-space:nowrap;flex:none}
.tb-btn.blue{background:var(--blue);color:#fff}
.tb-btn.blue:hover{background:var(--blue-hover)}
.tb-btn.ghost{background:var(--hover)}
.tb-btn.ghost:hover{background:var(--hover-2)}

/* topbar inline search (feed σελίδες) */
.tb-search{flex:1;min-width:0;max-width:560px;position:relative;display:flex;align-items:center}
.tb-search svg{position:absolute;left:12px;width:16px;height:16px;color:var(--text-2);pointer-events:none}
.tb-search input{width:100%;height:40px;border:none;border-radius:var(--r);background:var(--input);padding:0 12px 0 36px;color:var(--text);font-size:15px}
.tb-search input::placeholder{color:var(--text-2)}
.tb-search input:focus{outline:none;box-shadow:0 0 0 2px var(--blue) inset}
/* autocomplete dropdown */
.tb-suggest{position:absolute;left:0;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-pop);z-index:120;overflow:hidden;padding:4px 0;max-height:min(420px,70vh);overflow-y:auto}
.tsg-item{display:flex;align-items:center;gap:10px;padding:9px 12px;color:var(--text);cursor:pointer}
.tsg-item:hover,.tsg-item.on{background:var(--hover)}
.tsg-logo{width:24px;height:24px;flex-shrink:0;border-radius:var(--r);object-fit:contain;background:#fff;padding:2px}
.tsg-ic{width:24px;height:24px;flex-shrink:0;display:grid;place-items:center;color:var(--text-3)}
.tsg-ic svg{width:18px;height:18px}
.tsg-lbl{flex:1;min-width:0;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tsg-type{font-size:11px;color:var(--text-3);font-weight:600;flex-shrink:0}
.tsg-cnt{font-size:11px;color:var(--text-2);font-variant-numeric:tabular-nums;background:var(--hover);border-radius:var(--r);padding:1px 7px;flex-shrink:0}

/* topbar "Πούλησε" CTA */
.tb-create{height:40px;padding:0 16px;border-radius:var(--r);background:var(--blue);color:#fff;font-weight:600;font-size:14.5px;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:background .12s}
.tb-create:hover{background:var(--blue-hover)}
.tb-create svg{width:17px;height:17px}

/* ≤480px: register (the primary CTA) keeps its label; login moves to the
   bottom-nav "Λογαριασμός" tab so the topbar never clips its buttons. */
@media(max-width:480px){.tb-name{display:none}.tb-btn.ghost{display:none}.tb-btn{padding:0 13px}}
@media(max-width:720px){.tb-create .lbl{display:none}.tb-create{width:40px;padding:0;justify-content:center}}
@media(max-width:600px){
  .topbar{gap:7px;padding:0 10px}
  .tb-create{display:none}              /* στο mobile το καλύπτει το FAB */
  .tb-circle,.tb-avatar{width:36px;height:36px}
  .tb-search input{height:36px}
}
/* On narrow screens collapse back to flex so logo/actions don't get clipped */
@media(max-width:768px){
  .topbar--search{display:flex;grid-template-columns:unset}
  .topbar--search .tb-left{flex:0 0 auto}
  .topbar--search .tb-center{flex:1;min-width:0}
  .topbar--search .tb-right{margin-left:0}
}

/* ---------- Topbar dropdowns (μηνύματα / ειδοποιήσεις / μενού χρήστη) ---------- */
.tb-pop-wrap{position:relative;display:flex}
.tb-pop{position:absolute;top:calc(100% + 10px);right:0;width:368px;max-width:94vw;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-pop);z-index:210;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .14s ease,transform .14s ease,visibility .14s;overflow:hidden}
.tb-pop.open{opacity:1;visibility:visible;transform:none}
.tb-pop-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 10px;border-bottom:1px solid var(--line)}
.tb-pop-head b{font-size:16px;font-weight:700}
.tb-pop-head a{font-size:13px;color:var(--blue-txt);font-weight:600}
.tb-pop-head a:hover{text-decoration:underline}
.tb-pop-body{max-height:min(440px,68vh);overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:transparent transparent}
.tb-pop-body:hover{scrollbar-color:var(--line-2) transparent}
.tb-pop-body::-webkit-scrollbar{width:7px}
.tb-pop-body::-webkit-scrollbar-thumb{background:transparent;border-radius:var(--r)}
.tb-pop-body:hover::-webkit-scrollbar-thumb{background:var(--line-2)}
.tb-item{display:flex;gap:11px;align-items:flex-start;padding:11px 14px;border-bottom:1px solid var(--line);color:var(--text)}
.tb-item:last-child{border-bottom:none}
.tb-item:hover{background:var(--hover)}
.tb-item.unread{background:var(--blue-dim)}
.tb-item .tb-ic,.tb-item .tb-av{width:38px;height:38px;border-radius:var(--r);flex-shrink:0;display:grid;place-items:center;font-weight:700;font-size:15px}
.tb-item .tb-ic{background:var(--hover);color:var(--text-2)}
.tb-item .tb-ic svg{width:18px;height:18px}
.tb-item .tb-av{background:linear-gradient(135deg,#2D88FF,#7B5CFF);color:#fff;text-transform:uppercase}
.tb-item .c{min-width:0;flex:1}
.tb-item .c b{display:block;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-item .c p{font-size:13px;color:var(--text-2);margin:1px 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tb-item .c .t{display:block;font-size:11.5px;color:var(--text-3);margin-top:3px}
.tb-item .tb-dot{width:9px;height:9px;border-radius:var(--r);background:var(--blue);flex-shrink:0;margin-top:6px}
.tb-empty{padding:34px 16px;text-align:center;color:var(--text-2);font-size:14px}
.tb-skel{padding:11px 14px;display:flex;gap:11px;align-items:center}
.tb-skel .a{width:38px;height:38px;flex-shrink:0}
.tb-skel .c{flex:1}
.tb-skel .l{height:11px;margin-bottom:7px}
/* μενού χρήστη */
.tb-menu{width:248px}
.tb-menu-head{display:flex;gap:10px;align-items:center;padding:13px 14px;border-bottom:1px solid var(--line)}
.tb-menu-head .tb-av{width:40px;height:40px}
.tb-menu-head .mh{min-width:0}
.tb-menu-head .mh b{display:block;font-size:14.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-menu-head .mh span{display:block;font-size:12.5px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-menu a,.tb-menu button{display:flex;align-items:center;gap:11px;width:100%;padding:10px 14px;font-size:14.5px;font-weight:500;color:var(--text);text-align:left;background:none;border:none;cursor:pointer}
.tb-menu a:hover,.tb-menu button:hover{background:var(--hover)}
.tb-menu svg{width:18px;height:18px;color:var(--text-2);flex-shrink:0}
.tb-menu .sep{border-top:1px solid var(--line);margin:5px 0}
.tb-menu form{margin:0}
@media(max-width:480px){.tb-pop{width:calc(100vw - 16px);position:fixed;top:54px;right:8px}}

/* ---------- Κάρτες αγγελιών (grid) ----------
   Default = ευέλικτο auto-fill (favorites / profile). Το feed (/, /search,
   /browse) το κάνει override σε σταθερές 5 στήλες στο mk-home.css. */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:24px 18px}
.lcard{display:block;position:relative;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);overflow:hidden;color:inherit;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.lcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:var(--line-2)}
.lcard-link{display:block;cursor:pointer;color:inherit}
.lcard .imgw{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surface-2)}
.lcard img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.lcard:hover img{transform:scale(1.04)}
.lcard .badge{position:absolute;left:8px;top:8px;background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:var(--r)}
.lcard .badge.new{background:var(--green)}
.lcard .pcount{position:absolute;left:8px;bottom:8px;display:inline-flex;align-items:center;gap:4px;background:rgba(0,0,0,.62);color:#fff;font-size:11.5px;font-weight:600;padding:3px 7px;border-radius:var(--r)}
.lcard .pcount svg{width:12px;height:12px}
.lcard .sold{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.75);color:#fff;font-size:12px;font-weight:600;padding:3px 9px;border-radius:var(--r)}
.lcard .txt{padding:10px 12px 12px}
.lcard .price{font-size:17px;font-weight:700;display:flex;flex-wrap:wrap;align-items:baseline;gap:3px 7px;font-variant-numeric:tabular-nums}
.lcard .price .amt{white-space:nowrap}
.lcard .price .neg{font-size:12px;font-weight:600;color:var(--green);white-space:nowrap}
.lcard .title{font-size:15px;color:var(--text);margin-top:2px;display:flex;align-items:center;gap:6px}
.lcard .title .tt{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lcard .blogo{width:18px;height:18px;flex-shrink:0;border-radius:var(--r);object-fit:contain;background:#fff;padding:1px}
.lcard .fairp{display:inline-flex;align-items:center;gap:5px;margin-top:3px;font-size:11.5px;font-weight:600;line-height:1}
.lcard .fairp .dot{width:7px;height:7px;border-radius:var(--r);flex-shrink:0}
.lcard .fairp.good{color:var(--green)}.lcard .fairp.good .dot{background:var(--green)}
.lcard .fairp.fair{color:var(--text-2)}.lcard .fairp.fair .dot{background:var(--text-3)}
.lcard .fairp.high{color:var(--gold)}.lcard .fairp.high .dot{background:var(--gold)}
.lcard .fairp.none{color:var(--text-3);font-weight:500}
.lcard .fairp.none .dot{background:var(--line-2);border:1px dashed var(--text-3);box-sizing:border-box}
/* Price-change pill (recent drop = green ↓, hike = amber ↑). Self-gating in PHP. */
.lcard .price .pchg{font-size:11.5px;font-weight:700;line-height:1;padding:3px 6px;border-radius:var(--r);font-variant-numeric:tabular-nums;margin-left:2px}
.lcard .price .pchg.down{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green)}
.lcard .price .pchg.up  {background:color-mix(in srgb,var(--gold) 16%,transparent);color:var(--gold)}
.lcard .specs{font-size:12.5px;color:var(--text-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lcard .loc{font-size:13px;color:var(--text-2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lcard .sp{font-size:13px;color:var(--text-2);margin-top:1px}

/* ---------- Overlay actions πάνω στην κάρτα (αγαπημένο + σύγκριση) ----------
   Εμφανίζονται ΜΟΝΟ στο hover (+ translucent / blur). Τα ενεργά (.on) και
   το keyboard focus μένουν ορατά. Σε touch (no hover) πάντα ορατά. */
.lcard .ov{position:absolute;top:8px;right:8px;display:flex;gap:6px;z-index:3}
.cmp-btn,.fav-btn{width:32px;height:32px;border-radius:var(--r);display:grid;place-items:center;background:color-mix(in srgb,var(--surface) 82%,transparent);color:var(--text-2);box-shadow:var(--shadow);border:1px solid color-mix(in srgb,var(--line-2) 70%,transparent);opacity:0;transition:opacity .15s ease,transform .12s,background .12s,color .12s}
.lcard:hover .cmp-btn,.lcard:hover .fav-btn,.cmp-btn.on,.fav-btn.on,.cmp-btn:focus-visible,.fav-btn:focus-visible{opacity:1}
.cmp-btn:hover,.fav-btn:hover{transform:scale(1.08);color:var(--text);background:var(--surface)}
.cmp-btn svg,.fav-btn svg{width:16px;height:16px}
.cmp-btn.on{background:var(--blue);border-color:var(--blue);color:#fff}
.fav-btn.on{color:var(--red);border-color:var(--red)}
.fav-btn.on svg{fill:var(--red)}
/* touch devices: always visible + bigger tap target (≥40px) */
@media (hover:none){.cmp-btn,.fav-btn{opacity:1;width:40px;height:40px}}

/* ---------- Skeleton loading (shimmer, theme-aware) ---------- */
@keyframes mk-shimmer{100%{transform:translateX(100%)}}
.skel{position:relative;overflow:hidden;background:var(--hover);border-radius:var(--r)}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,var(--hover-2),transparent);animation:mk-shimmer 1.2s infinite}
/* Skeleton card mirrors .lcard exactly so swaps don't reflow the grid.
   A short fade-in makes the loading state clearly perceivable even on
   very fast networks (paired with a min-show timer in marketplace.js). */
@keyframes mk-skel-in{from{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}
.skel-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;animation:mk-skel-in .18s ease-out both}
.skel-card .ph{aspect-ratio:4/3;border-radius:0;background:var(--surface-2)}
.skel-card .body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:7px}
.skel-card .l{height:12px;border-radius:var(--r)}
.skel-card .l.price{height:18px;width:42%}
.skel-card .l.fairp{height:11px;width:38%}
.skel-card .title-row{display:flex;align-items:center;gap:7px;margin-top:1px}
.skel-card .title-row .logo{width:18px;height:18px;flex-shrink:0;border-radius:var(--r)}
.skel-card .title-row .l{flex:1}
.skel-card .l.w40{width:40%}
.skel-card .l.w50{width:50%}
.skel-card .l.w60{width:60%}
.skel-card .l.w70{width:70%}
.skel-card .l.w80{width:80%}

/* ---------- Tray σύγκρισης (σταθερό κάτω) ---------- */
.cmp-tray-wrap{position:fixed;left:0;right:0;bottom:0;z-index:120;display:flex;justify-content:center;padding:0 12px 12px;pointer-events:none}
.cmp-tray{pointer-events:auto;width:min(960px,100%);background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-pop);padding:9px 11px;display:flex;align-items:center;gap:12px}
.cmp-tray-lead{display:flex;align-items:center;gap:8px;flex-shrink:0}
.cmp-badge{background:var(--green);color:#fff;font-size:12px;font-weight:700;border-radius:var(--r);padding:2px 9px}
.cmp-hint{font-size:12.5px;font-weight:600;color:var(--text-2)}
.cmp-tray-items{display:flex;align-items:center;gap:8px;overflow-x:auto;flex:1;min-width:0;scrollbar-width:none}
.cmp-tray-items::-webkit-scrollbar{display:none}
.cmp-mini{display:flex;align-items:center;gap:4px;background:var(--surface-2);border-radius:var(--r);padding-right:4px;flex-shrink:0;max-width:200px}
.cmp-mini>a{display:flex;align-items:center;gap:8px;min-width:0}
.cmp-mini .th{width:46px;height:40px;border-radius:var(--r) 0 0 var(--r);overflow:hidden;background:var(--hover);display:grid;place-items:center;color:var(--text-3);flex-shrink:0}
.cmp-mini .th img{width:100%;height:100%;object-fit:cover}
.cmp-mini .th svg{width:18px;height:18px}
.cmp-mini .info{min-width:0;padding:2px 0}
.cmp-mini .info b{display:block;font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.cmp-mini .info span{display:block;font-size:11.5px;color:var(--text-2);white-space:nowrap}
.cmp-mini .rm{width:24px;height:24px;border-radius:var(--r);display:grid;place-items:center;color:var(--text-3);flex-shrink:0}
.cmp-mini .rm:hover{background:var(--hover-2);color:var(--red)}
.cmp-mini .rm svg{width:13px;height:13px}
.cmp-slot{display:flex;align-items:center;gap:5px;height:44px;padding:0 13px;border-radius:var(--r);border:1px dashed var(--line-2);color:var(--text-2);font-size:12.5px;font-weight:600;flex-shrink:0;white-space:nowrap}
.cmp-slot:hover{border-color:var(--blue);color:var(--blue-txt)}
.cmp-slot svg{width:14px;height:14px}
.cmp-cta{flex-shrink:0;height:38px;padding:0 16px;border-radius:var(--r);background:var(--blue);color:#fff;font-weight:600;font-size:14px;display:inline-flex;align-items:center;white-space:nowrap}
.cmp-cta:hover{background:var(--blue-hover)}
@media(max-width:560px){
  .cmp-hint{display:none}
  .cmp-slot{display:none}
  .cmp-tray{gap:8px}
}

/* ---------- Χάρτης τοποθεσίας ---------- */
.aa-map{border-radius:var(--r);overflow:hidden;position:relative}
.aa-map svg{display:block;width:100%;height:110px}
.aa-map .info-i{position:absolute;top:8px;right:8px;width:18px;height:18px;border-radius:var(--r);background:rgba(255,255,255,.85);color:#1B3A5C;font-size:12px;font-weight:700;display:grid;place-items:center}

/* ---------- Flash (server-rendered) ---------- */
.mk-flash-wrap{position:fixed;top:64px;left:50%;transform:translateX(-50%);z-index:150;display:flex;flex-direction:column;gap:8px;width:min(440px,92vw)}
.mk-flash{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r);font-size:14px;box-shadow:var(--shadow-pop);background:var(--surface-2);border:1px solid var(--line-2);color:var(--text)}
.mk-flash.ok{border-color:rgba(49,162,76,.5)}
.mk-flash.err{border-color:rgba(228,30,63,.5)}
.mk-flash .x{margin-left:auto;width:22px;height:22px;border-radius:var(--r);display:grid;place-items:center;color:var(--text-2)}
.mk-flash .x:hover{background:var(--hover)}

/* ---------- Site banner / impersonation ---------- */
.mk-strip{padding:9px 16px;text-align:center;font-size:13.5px;font-weight:600;position:relative}
.mk-strip.info{background:var(--blue);color:#fff}
.mk-strip.warn{background:var(--gold);color:#3a2c00}
.mk-strip.danger{background:var(--red);color:#fff}
.mk-strip a.cta{margin-left:8px;text-decoration:underline}
.mk-strip .x{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:var(--r);display:grid;place-items:center;background:rgba(0,0,0,.15)}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(90px);background:var(--surface-2);border:1px solid var(--line-2);color:var(--text);padding:11px 18px;border-radius:var(--r);font-size:14px;box-shadow:var(--shadow-pop);z-index:200;transition:transform .28s cubic-bezier(.2,.6,.2,1);max-width:92vw}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- Mobile bottom navigation (app-like 5-tab bar) ----------
   Mobile-only (≤768px); desktop never sees it. The body gets .has-bnav
   so content + other fixed bottom elements clear its height. */
.bnav{display:none}
@media (max-width:768px){
  .bnav{position:fixed;left:0;right:0;bottom:0;z-index:110;display:flex;align-items:stretch;background:var(--surface);border-top:1px solid var(--line);box-shadow:0 -2px 12px rgba(0,0,0,.08);padding-bottom:env(safe-area-inset-bottom,0px)}
  .bnav-it,.bnav-sell{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 2px 6px;font-size:10.5px;font-weight:600;color:var(--text-2);text-decoration:none;-webkit-tap-highlight-color:transparent}
  .bnav-it svg{width:21px;height:21px}
  .bnav-it.on{color:var(--blue-txt)}
  .bnav-it.on svg{color:var(--blue)}
  .bnav-it:active,.bnav-sell:active{transform:scale(.95)}
  .bnav-sell{color:var(--text-2)}
  .bnav-sell .bnav-plus{width:34px;height:34px;margin-top:-14px;border-radius:var(--r);background:var(--blue);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-pop)}
  .bnav-sell .bnav-plus svg{width:18px;height:18px}
  .bnav-sell.on{color:var(--blue-txt)}
  /* content + footer clear the bar */
  body.has-bnav{padding-bottom:calc(58px + env(safe-area-inset-bottom,0px))}
  /* compare tray floats above the bar */
  body.has-bnav .cmp-tray-wrap{bottom:calc(58px + env(safe-area-inset-bottom,0px))}
}

/* ---------- Public footer (legal + brand SEO links) ----------
   Hidden on full-screen surfaces via $hideFooter (layout-level).
   Feed pages (mk-home.css) offset it with margin-left to clear
   the fixed sidebar. */
.mk-footer{border-top:1px solid var(--line);background:var(--surface);margin-top:auto}
.mk-foot-in{max-width:1100px;margin:0 auto;padding:20px 20px 24px}
.mkf-brands{display:flex;flex-wrap:wrap;gap:6px 16px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.mkf-brands a{font-size:12.5px;color:var(--text-2);text-decoration:none}
.mkf-brands a:hover{color:var(--blue-txt);text-decoration:underline}
.mkf-brands .mkf-sell{margin-left:auto;color:var(--blue-txt);font-weight:600}
.mkf-legal{display:flex;flex-wrap:wrap;gap:6px 16px;margin-bottom:10px}
.mkf-legal a{font-size:12.5px;color:var(--text-2);text-decoration:none}
.mkf-legal a:hover{color:var(--blue-txt);text-decoration:underline}
.mkf-copy{font-size:12px;color:var(--text-3);margin:0}
@media (max-width:640px){
  .mkf-brands .mkf-sell{margin-left:0}
}

/* ---------- Leaflet maps (ΚΟΙΝΑ: feed χάρτης + προφίλ + ρυθμίσεις) ----------
   Τα tiles σκουραίνουν μέσω token (--map-tile-filter) ώστε το dark να
   δουλεύει ΚΑΙ με cookie (data-theme) ΚΑΙ με προτίμηση συσκευής. */
/* `html` prefix: κερδίζει το vendor/leaflet.css που φορτώνεται lazy ΜΕΤΑ από εμάς */
html .leaflet-tile{filter:var(--map-tile-filter)}
html .leaflet-container{background:var(--map-canvas)}
.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--surface)!important;color:var(--text)!important;box-shadow:var(--shadow-pop)!important}
.leaflet-popup-content-wrapper{border-radius:var(--r)!important}
.map-popup{font-size:13px;line-height:1.5;padding:2px 0}
.map-popup b{display:block;font-weight:700;margin-bottom:2px;color:var(--text)}
.map-popup .mp-price{font-size:13.5px;font-weight:700;color:var(--blue-txt);font-variant-numeric:tabular-nums}
.map-popup a{color:var(--blue-txt);font-weight:600;font-size:12px;display:block;margin-top:5px}
.map-popup a:hover{text-decoration:underline}
.map-popup .mp-tag{display:inline-block;background:var(--blue-dim);color:var(--blue-txt);font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:var(--r);margin-bottom:4px;letter-spacing:.02em}
.map-popup .mp-sub{display:block;font-size:12px;color:var(--text-2);margin-top:2px}
