/* /CSS/immobili_lista.css */
:root{
    --bg:#f5f5f5; --fg:#333; --muted:#666;
    --accent:#34546A; --card:#ffffff; --border:#e5e7eb;
    --danger:#e53935; --shadow:rgba(0,0,0,.12);
    color-scheme: light;
}
@media (prefers-color-scheme: dark){
  :root{ color-scheme: light; }
  html, body{ background-color:#f5f5f5; color:#333; }
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--fg);font-family:'Poppins', system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,sans-serif}
img{display:block;max-width:100%;height:auto}

.page{padding:0}
.header, main{padding-top:10px;padding-right:24px;padding-bottom:24px;padding-left:24px}
.header h1{margin:0 0 4px;font-size:28px}
.header .sub{color:var(--muted);margin-bottom:0px}

@media (min-width: 1024px){
    .header, main{
        max-width: 1200px;
        margin-left: auto;
        margin-right: auto;
        padding-left: 32px;
        padding-right: 32px;
    }
}

.grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:20px;
}

.card{
    display:flex; flex-direction:column;
    background:var(--card); border:1px solid var(--border);
    border-radius:14px; overflow:hidden;
    box-shadow:0 8px 18px var(--shadow);
    text-decoration:none; color:inherit;
    transition:transform .12s ease,border-color .12s ease, box-shadow .12s ease;
}
.card:hover,.card:focus{transform:translateY(-2px);border-color:#cbd5e1;outline:none;box-shadow:0 10px 22px rgba(0,0,0,.16)}

.thumb{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;background:#f0f3f7}

/* Striscia rossa diagonale (stile originale, poco invasiva) */
.badge-nd{
    position:absolute; top:12px; left:-42px; transform:rotate(-20deg);
    background:var(--danger); color:#fff; font-weight:700; font-size:12px;
    padding:6px 82px 6px 120px; letter-spacing:.4px; text-indent:-12px; box-shadow:0 6px 12px rgba(229,57,53,.35);
    z-index:3; pointer-events:none;
}

.carousel{position:relative;height:100%}
.track{display:flex;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;scroll-snap-stop:always;scroll-behavior:smooth;-ms-overflow-style:none;scrollbar-width:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}
.track::-webkit-scrollbar{display:none}
.track img{flex:0 0 100%;width:100%;height:100%;object-fit:cover;scroll-snap-align:center;user-select:none}

/* Frecce */
.thumb .nav{
    position:absolute;
    top:0;
    bottom:0;
    transform:none;
    border:none;
    width:90px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    padding:0 14px;
    color:#fff;
    cursor:pointer;
    z-index:4;
    font-size:30px;
    line-height:1;
    background:linear-gradient(to right, rgba(5,8,20,.32) 0%, rgba(5,8,20,0) 78%);
    opacity:0;
    transition:opacity .18s ease;
}
.thumb .nav.next{
    right:0;
    left:auto;
    justify-content:flex-end;
    background:linear-gradient(to left, rgba(5,8,20,.32) 0%, rgba(5,8,20,0) 78%);
}
.thumb .nav.prev{left:0;}
.thumb:hover .nav,
.thumb:focus-within .nav{
    opacity:1;
}
/* Mobile: hitbox ridotta per permettere swipe */
@media (max-width: 768px){
    .thumb .nav{
        width:50px;
        padding:0 8px;
        font-size:24px;
        opacity:0;
    }
    .thumb:active .nav{
        opacity:0.85;
    }
}
@media (hover:none){
    .thumb .nav{opacity:0;}
}

/* Topline e stats come in home */
.meta{padding:10px 12px 12px}
.topline{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px}
.price{font-size:18px;font-weight:800;color:#1f2937;margin:0}
.tipo{color:#64748b;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stats{display:flex;align-items:center;gap:12px;justify-content:flex-start;flex-wrap:wrap;row-gap:6px}
.stat{display:inline-flex;align-items:center;gap:6px;flex:0 1 auto;min-width:0;white-space:nowrap}
.stat .icon{width:16px;height:16px;display:inline-block}
.stat .t{font-size:.95rem}

/* Dots */
.dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);max-width:min(90%, 140px);display:flex;gap:6px;padding:4px 6px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}
.dots::-webkit-scrollbar{display:none}
.dots .dot{flex:0 0 7px;width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer}
.dots .dot.active{background:#fff}

/* Meta */
.meta{padding:10px 12px 12px}
.price{font-size:18px;font-weight:800;margin-bottom:6px;color:#1f2937}
.line.small{font-size:12px;color:var(--muted);display:flex;gap:6px;align-items:center}
.dot{opacity:.6}
.addr{margin-top:6px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#475569}
.labels{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.tag{display:inline-block;font-size:11px;padding:3px 8px;border-radius:999px;border:1px solid var(--border);color:#35506a;background:#f9fafb}
.lbl-vendita{border-color:#93c5fd;color:#1d4ed8;background:#eff6ff}
.lbl-affitto{border-color:#86efac;color:#047857;background:#ecfdf5}
.lbl-vacanza{border-color:#fcd34d;color:#b45309;background:#fef3c7}
.tag.danger{border-color:#fecaca;color:#b91c1c;background:#fee2e2}

/* Pagination */
.pagination{display:flex;gap:8px;justify-content:center;align-items:center;margin:22px 0 8px}
.pagination:empty{display:none}
.page-link{display:inline-block;min-width:32px;text-align:center; display:inline-flex; align-items:center; justify-content:center;padding:6px 10px;border-radius:10px;border:1px solid var(--border);text-decoration:none;color:#d6d8de;background:rgba(255,255,255,.02)}
.page-link:hover{border-color:#2b3242}
.page-link.current{background:#2b3242;color:#fff;pointer-events:none}
.ellipsis{color:var(--muted)}

/* Responsive tweaks per ridurre tagli su schermi piccoli */
@media (max-width: 640px){
  .stats{gap:10px;row-gap:4px}
  .stat .icon{width:15px;height:15px}
  .stat .t{font-size:.9rem}
}
@media (max-width: 420px){
  .stats{gap:8px}
  .stat .icon{width:14px;height:14px}
  .stat .t{font-size:.85rem}
}

