/* results.css — view modes, controls, feed, cards, map */

/* view modes: home <-> results */
.results{display:none;flex:1;flex-direction:column}
body.mode-results .home{display:none}
body.mode-results .results{display:flex}
body.mode-results .head-search{display:flex}
body.mode-results .head-loc{display:flex}
body.mode-results .head .brand{display:flex}

/* controls bar */
.controls{position:sticky;top:var(--head-h);z-index:40;background:var(--paper);border-bottom:1px solid var(--line)}
.controls-row{display:flex;align-items:center;gap:14px;padding:12px 0}
.count{font-family:var(--display);font-weight:700;font-size:15px;color:var(--pine-ink);white-space:nowrap}
.count b{color:var(--coral-ink)}
.controls-spacer{flex:1}
.seg{display:inline-flex;background:var(--surface-2);border-radius:999px;padding:3px}
.seg button{border:none;background:none;color:var(--muted);font-weight:600;font-size:13.5px;padding:8px 15px;border-radius:999px;display:flex;align-items:center;gap:7px}
.seg button svg{width:15px;height:15px}
.seg button.on{background:var(--surface);color:var(--pine-ink);box-shadow:var(--shadow-sm)}
.filtri{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1.5px solid var(--line-2);border-radius:999px;padding:8px 14px;font-weight:600;font-size:13.5px;color:var(--pine-ink)}
.filtri:hover{border-color:var(--pine-2)}
.filtri svg{width:15px;height:15px}
.filtri .badge{min-width:18px;height:18px;background:var(--coral);color:#fff;border-radius:99px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}
.chips{display:flex;gap:8px;overflow-x:auto;padding:0 0 12px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{border:1.5px solid var(--line);background:var(--surface);color:var(--muted);font-weight:600;font-size:13px;padding:7px 13px;border-radius:999px;white-space:nowrap;display:flex;align-items:center;gap:6px;transition:all .14s}
.chip:hover{border-color:var(--pine-2);color:var(--pine-ink)}
.chip.on{background:var(--pine);border-color:var(--pine);color:#fff}
.chip svg{width:14px;height:14px}

/* feed + cards */
.feed{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:18px;padding:20px 0 60px}
.card{position:relative;background:var(--surface);border-radius:var(--r-lg);border:1.5px solid transparent;box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:transform .12s,box-shadow .14s,border-color .14s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--line-2)}
.card-link{position:absolute;inset:0;z-index:1}
.card-img{position:relative;aspect-ratio:5/4;display:flex;align-items:center;justify-content:center}
.card-img>svg{width:46px;height:46px;color:rgba(255,255,255,.92)}
.card-dist{position:absolute;left:9px;top:9px;display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.94);color:var(--pine-ink);font-size:12px;font-weight:700;padding:5px 9px;border-radius:99px;box-shadow:var(--shadow-sm)}
.card-dist svg{width:12px;height:12px;color:var(--coral)}
.card-fav{position:absolute;right:9px;top:9px;z-index:2;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.94);border:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.card-fav svg{width:17px;height:17px;color:var(--muted)}
.card-fav.on svg{color:var(--coral);fill:var(--coral)}
.card-b{padding:11px 13px 14px}
.card-price{font-family:var(--display);font-weight:700;font-size:18px;color:var(--pine-ink)}
.card-price.free{color:var(--coral-ink)}
.card-title{font-size:14px;color:var(--ink);margin-top:2px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:38px}
.card-area{display:flex;align-items:center;gap:6px;margin-top:7px;color:var(--faint);font-size:12.5px}
.card-area svg{width:13px;height:13px}

/* map */
.mapwrap{display:none}
body.view-map .feed{display:none}
body.view-map .mapwrap{display:grid;grid-template-columns:minmax(360px,40%) 1fr;height:calc(100vh - var(--head-h) - 110px);min-height:480px}
.map-list{overflow-y:auto;padding:16px 18px 24px;border-right:1px solid var(--line)}
.map-list .card{flex-direction:row;margin-bottom:11px}
.map-list .card-img{width:120px;flex:none;aspect-ratio:auto}
.map-list .card-b{flex:1}.map-list .card-title{min-height:0}
.pane-map{position:relative;background:var(--land);border-radius:var(--r-lg);overflow:hidden;margin:16px 0}
.map-stage{position:absolute;inset:0}.map-svg{position:absolute;inset:0;width:100%;height:100%}
.map-overlay{position:absolute;inset:0}
.radius-ring{position:absolute;border-radius:50%;border:2px dashed var(--coral);background:rgba(240,85,45,.07);transform:translate(-50%,-50%);transition:width .25s,height .25s;pointer-events:none}
.me{position:absolute;transform:translate(-50%,-50%);z-index:5;left:50%;top:52%}
.me-dot{width:16px;height:16px;border-radius:50%;background:var(--pine);border:3px solid #fff;box-shadow:var(--shadow-md)}
.me-pulse{position:absolute;inset:-7px;border-radius:50%;background:rgba(27,67,50,.25);animation:pulse 2.6s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.7}80%,100%{transform:scale(2.4);opacity:0}}
.pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;z-index:8;transition:transform .12s}
.pin-shape{width:28px;height:28px;border-radius:50% 50% 50% 0;background:var(--surface);border:2px solid var(--pine-2);transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.pin-shape span{transform:rotate(45deg);font-family:var(--display);font-weight:700;font-size:11px;color:var(--pine-ink)}
.pin.active .pin-shape,.pin:hover .pin-shape{background:var(--coral);border-color:var(--coral)}
.pin.active .pin-shape span,.pin:hover .pin-shape span{color:#fff}
.pin.active{transform:translate(-50%,-100%) scale(1.18);z-index:12}
.map-cards{display:none}

/* feed empty state */
.feed-empty{grid-column:1/-1;padding:50px 24px;text-align:center;color:var(--muted)}
/* saved (favourite) toggled on */
.card-fav.on svg{color:var(--coral);fill:var(--coral)}
/* hide the heart inside the mobile map strip cards (compact) */
.map-cards .card .card-fav{display:none}

/* Profili pack (business profiles above the listings feed) */
.profpack{padding:18px 0 4px}
body.view-map .profpack{display:none}
.profpack-head{font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);margin:0 0 12px}
.profpack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px}
.pcard{display:flex;flex-direction:column;gap:5px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:13px 14px}
.pcard-name{font-weight:700;font-size:15px;color:var(--pine-ink);text-decoration:none;line-height:1.25}
.pcard-name:hover{color:var(--pine-2)}
.pcard-meta{font-size:12.5px;color:var(--muted)}
.pcard-meta .dot{margin:0 6px;color:var(--line-2)}
.pcard-acts{display:flex;flex-wrap:wrap;gap:14px;margin-top:3px}
.pcard-acts a{font-size:12.5px;font-weight:600;color:var(--pine-2);text-decoration:none}
.pcard-acts a:hover{text-decoration:underline}

/* Single listing detail */
.lst{max-width:760px;margin:0 auto;padding:22px 20px 60px}
.lst-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 26px 30px}
.lst-crumbs{font-size:13px;color:var(--faint);margin-bottom:14px}
.lst-crumbs a{color:var(--pine);text-decoration:none}
.lst-crumbs a:hover{text-decoration:underline}
.lst-sep{margin:0 6px}
.lst-title{font-size:26px;line-height:1.2;margin:0 0 10px;color:var(--ink)}
.lst-price{font-size:22px;font-weight:700;color:var(--coral);margin-bottom:22px}
.lst-specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:0 0 22px}
.lst-spec{display:flex;justify-content:space-between;gap:12px;background:var(--surface);padding:11px 15px}
.lst-spec dt{color:var(--faint);font-size:13.5px;margin:0}
.lst-spec dd{margin:0;font-size:13.5px;font-weight:600;color:var(--ink);text-align:right}
.lst-desc{font-size:15.5px;line-height:1.65;color:var(--ink);white-space:normal;margin-bottom:22px}
.lst-loc{display:flex;align-items:center;gap:7px;font-size:14px;color:var(--muted,#5d6b66)}
.lst-loc-ic{color:var(--coral);font-weight:700}
@media(max-width:560px){.lst-specs{grid-template-columns:1fr}.lst-title{font-size:22px}}
