/* ─── Vetrina punti vendita ─────────────────────────────────────── */
.vetr-hero {
    background: linear-gradient(180deg, #FFFFFF 0%, #FFF3F3 100%);
    padding: 8rem 0 2.5rem;
    border-bottom: 1px solid var(--border-light);
}
.vetr-hero-inner { max-width: 46rem; margin: 0 auto; text-align: center; }
.vetr-hero-title { font-size: clamp(1.9rem, 4.5vw, 2.75rem); font-weight: 800; letter-spacing: -.02em; line-height: 1.1; }
.vetr-hero-sub { color: var(--text-secondary); font-size: 1.075rem; margin: .9rem 0 1.8rem; }

.vetr-search {
    position: relative; display: flex; align-items: center;
    background: #fff; border: 1px solid var(--border-light); border-radius: 999px;
    box-shadow: 0 10px 30px -12px rgba(184,0,0,.18); padding: 0 1rem; height: 60px;
    transition: box-shadow .25s, border-color .25s;
}
.vetr-search:focus-within { border-color: var(--brand-red); box-shadow: 0 14px 36px -12px rgba(184,0,0,.28); }
.vetr-search-ico { color: var(--text-secondary); flex-shrink: 0; }
.vetr-search-input { flex: 1; border: none; outline: none; font-size: 1.05rem; padding: 0 .75rem; background: transparent; color: var(--text-primary); }
.vetr-search-clear { border: none; background: var(--bg-secondary); color: var(--text-secondary); width: 26px; height: 26px; border-radius: 50%; cursor: pointer; font-size: .8rem; }

/* categorie */
.vetr-catbar { position: sticky; top: 64px; z-index: 20; background: rgba(255,255,255,.9); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border-light); }
.vetr-cats { display: flex; gap: .6rem; overflow-x: auto; padding: .9rem 0; scrollbar-width: none; }
.vetr-cats::-webkit-scrollbar { display: none; }
.vetr-cat {
    flex-shrink: 0; display: inline-flex; align-items: center; gap: .45rem;
    border: 1px solid var(--border-light); background: #fff; color: var(--text-primary);
    border-radius: 999px; padding: .5rem 1rem; font-size: .9rem; font-weight: 600; cursor: pointer;
    transition: all .2s;
}
.vetr-cat:hover { border-color: var(--brand-red); color: var(--brand-red); }
.vetr-cat.on { background: var(--brand-red); border-color: var(--brand-red); color: #fff; }
.vetr-cat-n { font-size: .72rem; font-weight: 700; opacity: .65; }
.vetr-cat.on .vetr-cat-n { opacity: .9; }

/* filtri */
.vetr-filterbar { background: #fff; border-bottom: 1px solid var(--border-light); }
.vetr-filters { display: flex; align-items: center; flex-wrap: wrap; gap: .6rem; padding: 1rem 0; }
.vetr-filters-lbl { font-size: .85rem; color: var(--text-secondary); font-weight: 600; }
.vetr-chip {
    border: 1px solid var(--border-light); background: #fff; color: var(--text-primary);
    border-radius: 999px; padding: .4rem .9rem; font-size: .85rem; font-weight: 600; cursor: pointer; transition: all .2s;
}
.vetr-chip:hover { border-color: var(--brand-red); }
.vetr-chip.on { background: var(--brand-red-light); border-color: var(--brand-red); color: var(--brand-red); }
.vetr-sort { margin-left: auto; display: flex; align-items: center; gap: .5rem; }
.vetr-sort label { font-size: .85rem; color: var(--text-secondary); font-weight: 600; }
.vetr-sort select { border: 1px solid var(--border-light); border-radius: 10px; padding: .45rem .7rem; font-size: .85rem; font-weight: 600; background: #fff; cursor: pointer; color: var(--text-primary); }

/* risultati */
.vetr-results { padding: 1.75rem 0 4rem; }
.vetr-count { color: var(--text-secondary); font-size: .9rem; margin-bottom: 1.25rem; }
.vetr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 1.5rem; }

.vetr-card {
    display: block; background: #fff; border: 1px solid var(--border-light); border-radius: 1.1rem;
    overflow: hidden; text-decoration: none; color: inherit; transition: transform .25s, box-shadow .25s, border-color .25s;
}
.vetr-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px -18px rgba(0,0,0,.25); border-color: transparent; }
.vetr-card-cover { position: relative; aspect-ratio: 16/10; background: var(--bg-secondary); overflow: hidden; }
.vetr-card-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.vetr-card:hover .vetr-card-cover img { transform: scale(1.05); }
.vetr-card-cover-ph { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--brand-red-light), var(--bg-secondary)); opacity: .8; }
.vetr-card-cover-logo { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: #fff; padding: 1.5rem; }
.vetr-card-cover-logo img { max-width: 72%; max-height: 72%; object-fit: contain; }
.vetr-card-cat {
    position: absolute; top: .7rem; left: .7rem; background: rgba(29,29,31,.78); color: #fff;
    font-size: .68rem; font-weight: 700; letter-spacing: .02em; padding: .25rem .6rem; border-radius: 999px; backdrop-filter: blur(4px);
}
.vetr-card-body { padding: .95rem; }
.vetr-card-name { font-weight: 700; font-size: 1.02rem; line-height: 1.25; margin-bottom: .3rem; }
.vetr-card:hover .vetr-card-name { color: var(--brand-red); }
.vetr-card-addr { display: flex; align-items: center; gap: .35rem; color: var(--text-secondary); font-size: .82rem; margin-bottom: .7rem; }
.vetr-card-addr svg { flex-shrink: 0; color: var(--brand-red); }
.vetr-card-feats { display: flex; flex-wrap: wrap; gap: .35rem; }
.vetr-feat { font-size: .68rem; font-weight: 600; color: var(--text-secondary); background: var(--bg-secondary); padding: .22rem .55rem; border-radius: 999px; }

/* skeleton + empty */
.vetr-skel { aspect-ratio: 16/13; border-radius: 1.1rem; background: linear-gradient(100deg, #f0f0f2 30%, #f7f7f8 50%, #f0f0f2 70%); background-size: 200% 100%; animation: vetr-sh 1.3s infinite; }
@keyframes vetr-sh { to { background-position-x: -200%; } }
.vetr-empty { text-align: center; padding: 4rem 1rem; }
.vetr-empty-ico { font-size: 2.5rem; margin-bottom: 1rem; }
.vetr-empty h3 { font-size: 1.2rem; font-weight: 700; margin-bottom: .5rem; }
.vetr-empty p { color: var(--text-secondary); margin-bottom: 1.5rem; }

@media (max-width: 640px) {
    .vetr-catbar { top: 56px; }
    .vetr-sort { margin-left: 0; width: 100%; }
    .vetr-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1rem; }
}
