/* =========================================================================
   Prezzly — livello "public" (marketing + listing) costruito sui token del
   design system telaio (telaio-theme.css). Prefisso pz- per evitare collisioni
   con le classi gr-*/t-* del Core. Caricato dopo telaio-theme.css + prezzly-brand.css.
   ========================================================================= */

/* ---------- Base pagina pubblica ---------- */
.pz-body { background: var(--t-bg-page); color: var(--t-text-primary); }
.pz-container { width: 100%; max-width: 1180px; margin-inline: auto; padding-inline: clamp(1rem, 3vw, 1.75rem); }
.pz-visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

/* ---------- Header pubblico ---------- */
.pz-site-header { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.92); backdrop-filter: saturate(160%) blur(8px); border-bottom: 1px solid var(--t-border-subtle); }
.pz-site-header__inner { display: flex; align-items: center; gap: 1rem; min-height: 64px; }
.pz-logo { display: inline-flex; align-items: center; gap: .55rem; text-decoration: none; color: var(--t-text-primary); font-weight: 800; font-size: 1.2rem; letter-spacing: -.02em; flex-shrink: 0; }
.pz-logo__mark { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; background: linear-gradient(135deg, var(--t-color-indigo-500), var(--t-color-indigo-700)); color: #fff; font-weight: 800; box-shadow: var(--t-shadow-sm); }
.pz-logo__text { color: var(--t-text-primary); }
.pz-site-search { flex: 1 1 auto; display: flex; max-width: 560px; margin-inline: auto; }
.pz-site-search__input { flex: 1; min-width: 0; height: 42px; padding: 0 .9rem; border: 1px solid var(--t-border-default); border-right: 0; border-radius: var(--t-radius-md) 0 0 var(--t-radius-md); background: var(--t-bg-surface); color: var(--t-text-primary); font-size: .95rem; }
.pz-site-search__input:focus { outline: 2px solid var(--t-color-indigo-400); outline-offset: -1px; }
.pz-site-search__btn { height: 42px; padding: 0 1.1rem; border: 0; border-radius: 0 var(--t-radius-md) var(--t-radius-md) 0; background: var(--t-color-indigo-600); color: #fff; font-weight: 600; cursor: pointer; }
.pz-site-search__btn:hover { background: var(--t-color-indigo-700); }
.pz-site-header__actions { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }

.pz-navlink { text-decoration: none; color: var(--t-text-secondary); font-weight: 600; font-size: .9rem; padding: .5rem .7rem; border-radius: var(--t-radius-md); }
.pz-navlink:hover { color: var(--t-text-primary); background: var(--t-bg-subtle); }

/* ---------- Selettore città (header) ---------- */
.pz-city { position: relative; flex-shrink: 0; }
.pz-city__btn { list-style: none; cursor: pointer; display: inline-flex; align-items: center; gap: .4rem; height: 42px; padding: 0 .8rem; border: 1px solid var(--t-border-default); border-radius: var(--t-radius-md); background: var(--t-bg-surface); color: var(--t-text-primary); font-weight: 600; font-size: .9rem; white-space: nowrap; }
.pz-city__btn::-webkit-details-marker { display: none; }
.pz-city__btn svg:first-child { color: var(--t-color-indigo-600); }
.pz-city__btn:hover { border-color: var(--t-color-indigo-300); }
.pz-city__label { max-width: 130px; overflow: hidden; text-overflow: ellipsis; }
.pz-city__chev { transition: transform .15s ease; color: var(--t-text-muted); }
.pz-city[open] .pz-city__chev { transform: rotate(180deg); }
.pz-city__menu { position: absolute; top: calc(100% + 6px); left: 0; z-index: 50; min-width: 230px; max-height: 340px; overflow-y: auto; background: var(--t-bg-surface); border: 1px solid var(--t-border-subtle); border-radius: var(--t-radius-md); box-shadow: var(--t-shadow-lg); padding: .35rem; }
.pz-city__item { display: flex; align-items: center; justify-content: space-between; gap: .5rem; padding: .5rem .6rem; border-radius: var(--t-radius-sm); text-decoration: none; color: var(--t-text-primary); font-size: .9rem; }
.pz-city__item:hover { background: var(--t-color-indigo-50); }
.pz-city__item.is-active { background: var(--t-color-indigo-50); color: var(--t-color-indigo-700); font-weight: 700; }
.pz-city__sep { height: 1px; background: var(--t-border-subtle); margin: .35rem 0; }
.pz-city__soon { font-size: .68rem; color: var(--t-text-muted); background: var(--t-bg-subtle); padding: .1rem .45rem; border-radius: var(--t-radius-full); }
@media (max-width: 760px) { .pz-city__label { max-width: 70px; } }

/* Categorie nav (seconda riga header) */
.pz-catbar { border-top: 1px solid var(--t-border-subtle); background: var(--t-bg-surface); }
.pz-catbar__list { display: flex; gap: .25rem; overflow-x: auto; list-style: none; margin: 0; padding: .4rem 0; scrollbar-width: none; -ms-overflow-style: none; }
.pz-catbar__list::-webkit-scrollbar { display: none; }
.pz-catbar__link { white-space: nowrap; text-decoration: none; color: var(--t-text-secondary); font-size: .85rem; font-weight: 600; padding: .35rem .7rem; border-radius: var(--t-radius-full); }
.pz-catbar__link:hover { color: var(--t-color-indigo-700); background: var(--t-color-indigo-50); }

/* ---------- Buttons (public) ---------- */
.pz-btn { display: inline-flex; align-items: center; justify-content: center; gap: .45rem; height: 44px; padding: 0 1.2rem; border-radius: var(--t-radius-md); border: 1px solid transparent; font-weight: 600; font-size: .95rem; text-decoration: none; cursor: pointer; transition: transform .06s ease, background .15s ease, box-shadow .15s ease; }
.pz-btn:active { transform: translateY(1px); }
.pz-btn--primary { background: var(--t-color-indigo-600); color: #fff; box-shadow: var(--t-shadow-sm); }
.pz-btn--primary:hover { background: var(--t-color-indigo-700); }
.pz-btn--secondary { background: var(--t-color-navy-700); color: var(--t-color-cream); }
.pz-btn--secondary:hover { background: var(--t-color-navy-800); }
.pz-btn--ghost { background: transparent; color: var(--t-text-primary); border-color: var(--t-border-default); }
.pz-btn--ghost:hover { background: var(--t-bg-subtle); }
.pz-btn--lg { height: 52px; padding: 0 1.6rem; font-size: 1.05rem; }
.pz-btn--block { width: 100%; }

/* ---------- Hero ---------- */
.pz-hero { position: relative; overflow: hidden; padding: clamp(2.5rem, 7vw, 5rem) 0 clamp(2rem, 5vw, 3.5rem); background:
    radial-gradient(900px 380px at 78% -8%, var(--t-color-indigo-50), transparent 60%),
    radial-gradient(700px 320px at 8% 0%, #FFF6E8, transparent 55%),
    var(--t-bg-page); }
.pz-hero__inner { max-width: 820px; }
.pz-hero__eyebrow { display: inline-flex; align-items: center; gap: .4rem; font-size: .8rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--t-color-indigo-700); background: var(--t-color-indigo-50); border: 1px solid var(--t-color-indigo-100); padding: .3rem .7rem; border-radius: var(--t-radius-full); margin-bottom: 1rem; }
.pz-hero__title { font-family: var(--t-font-display); font-size: clamp(2.2rem, 5.5vw, 3.6rem); line-height: 1.05; letter-spacing: -.02em; margin: 0 0 .9rem; color: var(--t-text-primary); }
.pz-hero__highlight { color: var(--t-color-indigo-600); }
.pz-hero__lead { font-size: clamp(1.05rem, 2vw, 1.25rem); color: var(--t-text-secondary); max-width: 620px; margin: 0 0 1.6rem; }
.pz-hero__search { display: flex; max-width: 620px; box-shadow: var(--t-shadow-lg); border-radius: var(--t-radius-lg); overflow: hidden; background: var(--t-bg-surface); }
.pz-hero__search-input { flex: 1; min-width: 0; height: 58px; padding: 0 1.1rem; border: 1px solid var(--t-border-default); border-right: 0; border-radius: var(--t-radius-lg) 0 0 var(--t-radius-lg); font-size: 1.05rem; background: var(--t-bg-surface); color: var(--t-text-primary); }
.pz-hero__search-input:focus { outline: 2px solid var(--t-color-indigo-400); outline-offset: -1px; }
.pz-hero__search-btn { height: 58px; padding: 0 1.6rem; border: 0; background: var(--t-color-indigo-600); color: #fff; font-weight: 700; font-size: 1.05rem; cursor: pointer; }
.pz-hero__search-btn:hover { background: var(--t-color-indigo-700); }
.pz-hero__hints { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; margin-top: 1.1rem; color: var(--t-text-muted); font-size: .9rem; }
.pz-chip { text-decoration: none; font-size: .85rem; font-weight: 600; color: var(--t-text-secondary); background: var(--t-bg-surface); border: 1px solid var(--t-border-default); border-radius: var(--t-radius-full); padding: .35rem .8rem; }
.pz-subcats { display: flex; flex-wrap: wrap; gap: .5rem; margin: .75rem 0 0; }
.pz-chip:hover { color: var(--t-color-indigo-700); border-color: var(--t-color-indigo-300); background: var(--t-color-indigo-50); }

/* ---------- Sezioni ---------- */
.pz-section { padding: clamp(2rem, 5vw, 3.5rem) 0; }
.pz-section--muted { background: var(--t-bg-subtle); }
.pz-section__head { margin-bottom: 1.5rem; }
.pz-section__title { font-family: var(--t-font-display); font-size: clamp(1.5rem, 3vw, 2rem); letter-spacing: -.01em; margin: 0; color: var(--t-text-primary); }
.pz-section__subtitle { color: var(--t-text-secondary); margin: .35rem 0 0; }

/* ---------- Grid ---------- */
.pz-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.pz-grid--2 { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; }
.pz-grid--3 { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.pz-grid--4 { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
/* Griglia categorie a colonne FISSE: righe sempre complete (12 = 4×3) */
.pz-cat-grid { display: grid; gap: 1rem; grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1000px) { .pz-cat-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px)  { .pz-cat-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Category card ---------- */
.pz-cat-card { display: flex; align-items: center; gap: .8rem; min-height: 96px; text-decoration: none; padding: 1rem 1.1rem; border-radius: var(--t-radius-lg); background: var(--t-bg-surface); border: 1px solid var(--t-border-subtle); box-shadow: var(--t-shadow-xs); transition: transform .1s ease, box-shadow .15s ease, border-color .15s ease; }
.pz-cat-card:hover { transform: translateY(-2px); box-shadow: var(--t-shadow-md); border-color: var(--t-color-indigo-200); }
.pz-cat-card__icon { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 12px; background: var(--t-color-indigo-50); font-size: 1.4rem; flex-shrink: 0; }
.pz-cat-card__label { display: block; font-weight: 700; color: var(--t-text-primary); }
.pz-cat-card__meta { display: block; font-size: .8rem; color: var(--t-text-muted); }

/* ---------- Feature blocks ---------- */
.pz-feature { padding: 1.75rem; border-radius: var(--t-radius-xl); background: var(--t-bg-surface); border: 1px solid var(--t-border-subtle); box-shadow: var(--t-shadow-sm); }
.pz-feature--alt { background: linear-gradient(180deg, var(--t-color-navy-700), var(--t-color-navy-800)); color: var(--t-color-cream); border-color: transparent; }
.pz-feature--alt .pz-feature__text { color: rgba(250,250,247,0.82); }
.pz-feature__icon { font-size: 1.8rem; }
.pz-feature__title { font-family: var(--t-font-display); font-size: 1.4rem; margin: .6rem 0 .5rem; }
.pz-feature__text { color: var(--t-text-secondary); line-height: 1.6; }
.pz-feature__actions { margin-top: 1.1rem; display: flex; gap: .6rem; flex-wrap: wrap; }

/* ---------- CTA band ---------- */
.pz-cta { text-align: center; padding: clamp(2rem, 5vw, 3.2rem); border-radius: var(--t-radius-xl); background: linear-gradient(135deg, var(--t-color-indigo-600), var(--t-color-indigo-800)); color: #fff; box-shadow: var(--t-shadow-lg); }
.pz-cta__title { font-family: var(--t-font-display); font-size: clamp(1.5rem, 3vw, 2.1rem); margin: 0 0 .6rem; }
.pz-cta__text { color: rgba(255,255,255,0.88); max-width: 620px; margin: 0 auto 1.4rem; }
.pz-cta .pz-btn--primary { background: #fff; color: var(--t-color-indigo-700); }
.pz-cta .pz-btn--primary:hover { background: var(--t-color-indigo-50); }

/* ---------- Product card (listing/confronto) ---------- */
.pz-product-card { display: flex; flex-direction: column; text-decoration: none; background: var(--t-bg-surface); border: 1px solid var(--t-border-subtle); border-radius: var(--t-radius-lg); overflow: hidden; box-shadow: var(--t-shadow-xs); transition: transform .1s ease, box-shadow .15s ease; }
.pz-product-card:hover { transform: translateY(-2px); box-shadow: var(--t-shadow-md); }
.pz-product-card__media { aspect-ratio: 4/3; background: var(--t-bg-subtle); display: grid; place-items: center; overflow: hidden; }
.pz-product-card__media img { width: 100%; height: 100%; object-fit: contain; padding: .5rem; }
.pz-product-card__body { padding: .9rem 1rem 1rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.pz-product-card__title { font-weight: 600; color: var(--t-text-primary); font-size: .95rem; line-height: 1.3; }
.pz-product-card__brand { font-size: .78rem; color: var(--t-text-muted); text-transform: uppercase; letter-spacing: .03em; }
.pz-product-card__price { margin-top: auto; font-weight: 800; font-size: 1.2rem; color: var(--t-text-primary); }
.pz-product-card__price-from { font-size: .75rem; color: var(--t-text-muted); font-weight: 600; }
.pz-product-card__meta { font-size: .8rem; color: var(--t-text-secondary); }

/* ---------- Merchant card ---------- */
.pz-merchant-card { display: flex; flex-direction: column; gap: .5rem; text-decoration: none; background: var(--t-bg-surface); border: 1px solid var(--t-border-subtle); border-radius: var(--t-radius-lg); padding: 1.1rem; box-shadow: var(--t-shadow-xs); transition: transform .1s ease, box-shadow .15s ease; }
.pz-merchant-card:hover { transform: translateY(-2px); box-shadow: var(--t-shadow-md); }
.pz-merchant-card__name { font-weight: 700; color: var(--t-text-primary); }
.pz-merchant-card__meta { font-size: .85rem; color: var(--t-text-muted); }

/* ---------- Price comparison table ---------- */
.pz-offers { display: flex; flex-direction: column; gap: .6rem; }
.pz-offer { display: flex; align-items: center; gap: 1rem; padding: .9rem 1rem; border: 1px solid var(--t-border-subtle); border-radius: var(--t-radius-md); background: var(--t-bg-surface); }
.pz-offer--best { border-color: var(--t-color-indigo-400); box-shadow: 0 0 0 1px var(--t-color-indigo-300); }
.pz-offer__merchant { font-weight: 600; color: var(--t-text-primary); }
.pz-offer__price { margin-left: auto; font-weight: 800; font-size: 1.15rem; color: var(--t-text-primary); }
.pz-offer__cta { flex-shrink: 0; }

/* ---------- Map ---------- */
.pz-map { height: 380px; width: 100%; border-radius: var(--t-radius-lg); overflow: hidden; border: 1px solid var(--t-border-subtle); }

/* ---------- Footer ---------- */
.pz-site-footer { margin-top: 3rem; background: var(--t-color-navy-800); color: var(--t-color-cream); }
.pz-site-footer__inner { display: flex; flex-wrap: wrap; gap: 2rem; justify-content: space-between; padding: 2.5rem 0 1.5rem; }
.pz-site-footer__brand { max-width: 320px; }
.pz-site-footer__tagline { color: rgba(250,250,247,0.7); margin-top: .5rem; font-size: .9rem; }
.pz-site-footer__col h4 { font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; color: var(--t-color-gold-300); margin: 0 0 .7rem; }
/* Link footer a opacità piena: contrasto ≥4.5:1 su navy-800; la gerarchia resta affidata a font-size/weight */
.pz-site-footer__col a { display: block; color: var(--t-color-cream, #f5f3ef); text-decoration: none; padding: .25rem 0; font-size: .9rem; }
.pz-site-footer__col a:hover { color: #fff; }
.pz-site-footer__bar { border-top: 1px solid rgba(255,255,255,0.1); padding: 1rem 0; font-size: .82rem; color: rgba(250,250,247,0.6); }

/* ---------- Breadcrumb ---------- */
.pz-breadcrumb { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; font-size: .85rem; color: var(--t-text-muted); padding: 1rem 0; }
.pz-breadcrumb a { color: var(--t-text-secondary); text-decoration: none; }
.pz-breadcrumb a:hover { color: var(--t-color-indigo-700); }

/* ===================== VISUAL MARKETPLACE ===================== */

/* Hero a due colonne con visual flottante */
.pz-hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 2.5rem; align-items: center; }
.pz-hero__visual { position: relative; min-height: 340px; }
.pz-hero__deal { position: absolute; background: var(--t-bg-surface); border: 1px solid var(--t-border-subtle); border-radius: var(--t-radius-lg); box-shadow: var(--t-shadow-xl); overflow: hidden; }
.pz-hero__deal img { width: 100%; height: 150px; object-fit: cover; display: block; }
.pz-hero__deal-body { padding: .7rem .9rem 1rem; }
.pz-hero__deal--front { top: 24px; right: 6px; width: 250px; transform: rotate(3deg); z-index: 2; }
.pz-hero__deal--back  { top: 150px; left: 0;  width: 220px; transform: rotate(-4deg); z-index: 1; }

/* Product card ricca */
.pz-product-card__media { position: relative; aspect-ratio: 4/3; background: var(--t-bg-subtle); overflow: hidden; display: block; }
.pz-product-card__media img { width: 100%; height: 100%; object-fit: cover; padding: 0; transition: transform .35s ease; }
.pz-product-card:hover .pz-product-card__media img { transform: scale(1.05); }
.pz-deal-badge { position: absolute; top: .6rem; left: .6rem; background: var(--t-color-gold-500); color: #fff; font-weight: 800; font-size: .8rem; padding: .25rem .55rem; border-radius: var(--t-radius-sm); box-shadow: var(--t-shadow-sm); }
.pz-product-card__brand { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--t-text-muted); font-weight: 700; }
.pz-product-card__title { font-weight: 600; color: var(--t-text-primary); font-size: .95rem; line-height: 1.3; }
.pz-price-row { display: flex; align-items: baseline; gap: .5rem; margin-top: auto; }
.pz-price { font-weight: 800; font-size: 1.3rem; color: var(--t-text-primary); }
.pz-price-strike { font-size: .85rem; color: var(--t-text-muted); text-decoration: line-through; }
.pz-product-card__from { font-size: .72rem; color: var(--t-text-muted); }
.pz-product-card__count { font-size: .78rem; color: var(--t-color-indigo-700); font-weight: 600; }

/* Rating */
.pz-rating { display: inline-flex; align-items: center; gap: .3rem; font-size: .82rem; color: var(--t-text-secondary); font-weight: 600; }
.pz-rating__stars { color: var(--t-color-gold-500); letter-spacing: .5px; }
.pz-rating__count { color: var(--t-text-muted); font-weight: 400; }

/* Merchant card con copertina (solo le card che HANNO una cover diventano padding:0) */
.pz-merchant-card:has(.pz-merchant-card__cover) { padding: 0; overflow: hidden; }
.pz-merchant-card__cover { aspect-ratio: 16/9; overflow: hidden; background: var(--t-bg-subtle); position: relative; }
.pz-merchant-card__cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.pz-merchant-card:hover .pz-merchant-card__cover img { transform: scale(1.05); }
.pz-merchant-card__cat { position: absolute; bottom: .6rem; left: .6rem; background: rgba(17,17,30,.62); color: #fff; font-size: .72rem; font-weight: 600; padding: .22rem .6rem; border-radius: var(--t-radius-full); backdrop-filter: blur(4px); }
.pz-merchant-card__body { padding: .9rem 1rem 1.1rem; display: flex; flex-direction: column; gap: .4rem; }
.pz-merchant-card__name { font-weight: 700; color: var(--t-text-primary); font-size: 1.05rem; }
.pz-merchant-card__desc { font-size: .85rem; color: var(--t-text-secondary); line-height: 1.45; }

/* Section head con azione + eyebrow */
.pz-section__head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.pz-section__eyebrow { font-size: .8rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--t-color-gold-600); margin: 0 0 .25rem; }
.pz-section__link { color: var(--t-color-indigo-700); font-weight: 700; text-decoration: none; font-size: .9rem; white-space: nowrap; }
.pz-section__link:hover { text-decoration: underline; }

/* Category card icon (SVG) */
.pz-cat-card__icon svg { width: 22px; height: 22px; stroke: var(--t-color-indigo-600); fill: none; }

/* Trust band */
.pz-stats { display: flex; flex-wrap: wrap; gap: 3rem; justify-content: center; padding: 1.75rem 1rem; }
.pz-stat { text-align: center; }
.pz-stat__num { font-family: var(--t-font-display); font-size: 2.1rem; font-weight: 700; color: var(--t-color-indigo-700); line-height: 1; }
.pz-stat__label { font-size: .85rem; color: var(--t-text-muted); margin-top: .25rem; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
    .pz-hero__grid { grid-template-columns: 1fr; }
    .pz-hero__visual { display: none; }
}
@media (max-width: 760px) {
    .pz-site-search { display: none; }
    .pz-grid--2 { grid-template-columns: 1fr; }
    .pz-stats { gap: 1.5rem; }
}

/* ---------- Rifiniture: titolo+follow, newsletter, cookie banner ---------- */

/* Riga titolo con azione affiancata (es. bottone Segui) */
.pz-titlebar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.pz-titlebar > .pz-section__title { flex: 1 1 auto; min-width: 0; margin: 0; }

/* Bottone "Segui" merchant/prodotto */
.pz-follow {
    display: inline-flex; align-items: center; gap: .45rem; flex: 0 0 auto;
    height: 40px; padding: 0 1rem;
    border: 1.5px solid var(--t-color-indigo-600, #4f46e5);
    border-radius: var(--t-radius-full, 999px);
    background: var(--t-bg-surface, #fff); color: var(--t-color-indigo-700, #4338ca);
    font-weight: 600; font-size: .92rem; cursor: pointer;
    transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.pz-follow:hover { background: var(--t-color-indigo-50, #eef2ff); }
.pz-follow__icon { font-size: 1.05rem; line-height: 1; }
.pz-follow__count { font-variant-numeric: tabular-nums; font-weight: 700; }
.pz-follow__count:empty { display: none; }
.pz-follow.is-following {
    background: var(--t-color-indigo-600, #4f46e5);
    border-color: var(--t-color-indigo-600, #4f46e5); color: #fff;
}
.pz-follow.is-following:hover {
    background: var(--t-color-indigo-700, #4338ca); border-color: var(--t-color-indigo-700, #4338ca);
}
.pz-follow:disabled { opacity: .6; cursor: default; }

/* Newsletter (colonna footer scuro) */
.pz-newsletter__text { color: var(--t-color-cream, #f5f3ef); opacity: .8; font-size: .9rem; margin: 0 0 .6rem; }
.pz-newsletter__row { display: flex; gap: .4rem; }
.pz-newsletter__input {
    flex: 1 1 auto; min-width: 0; height: 40px; padding: 0 .75rem;
    border: 1px solid rgba(255, 255, 255, .25); border-radius: var(--t-radius-md, 8px);
    background: rgba(255, 255, 255, .95); color: #1f2430; font-size: .9rem;
}
.pz-newsletter__input:focus { outline: 2px solid var(--t-color-indigo-400, #818cf8); outline-offset: 1px; }
.pz-newsletter .pz-btn { flex: 0 0 auto; height: 40px; }
.pz-newsletter__consent {
    display: flex; align-items: flex-start; gap: .45rem; margin-top: .55rem;
    font-size: .78rem; color: var(--t-color-cream, #f5f3ef); opacity: .8; line-height: 1.4;
}
.pz-newsletter__consent input { margin-top: .15rem; }
.pz-newsletter__consent a { color: inherit; text-decoration: underline; }

/* Banner cookie GDPR */
.pz-cookie {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 1200;
    background: var(--t-bg-surface, #fff);
    border-top: 1px solid var(--t-border-default, #e3e6ee);
    box-shadow: 0 -8px 24px rgba(16, 24, 40, .12);
}
.pz-cookie__inner {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    padding: .9rem 1rem; flex-wrap: wrap;
}
.pz-cookie__text { margin: 0; font-size: .88rem; color: var(--t-text-secondary, #4a5163); flex: 1 1 320px; }
.pz-cookie__text a { color: var(--t-color-indigo-600, #4f46e5); }
.pz-cookie__actions { display: flex; gap: .5rem; flex: 0 0 auto; }
.pz-cookie__actions .pz-btn { height: 40px; }

@media (max-width: 560px) {
    .pz-cookie__inner { flex-direction: column; align-items: stretch; }
    .pz-cookie__actions { justify-content: flex-end; }
}

/* ---------- Micro-interazioni: hover card + focus tastiera ---------- */
html { scroll-behavior: smooth; }

/* Sollevamento morbido delle card nelle griglie (prodotti/attività/categorie) */
.pz-product-card,
.pz-merchant-card,
.pz-cat-card {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.pz-product-card:hover,
.pz-merchant-card:hover,
.pz-cat-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 26px rgba(26, 26, 46, .10);
    border-color: var(--t-color-indigo-300, #a5b4fc);
}
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .pz-product-card, .pz-merchant-card, .pz-cat-card { transition: none; }
    .pz-product-card:hover, .pz-merchant-card:hover, .pz-cat-card:hover { transform: none; }
}

/* Focus da tastiera coerente col brand (accessibilità WCAG) */
a:focus-visible,
button:focus-visible,
.pz-btn:focus-visible,
.pz-follow:focus-visible,
summary:focus-visible,
input:focus-visible,
[tabindex]:focus-visible {
    outline: 2px solid var(--t-color-indigo-500, #6366f1);
    outline-offset: 2px;
    border-radius: 6px;
}

/* Bottone "Attiva notifiche" (footer scuro) */
.pz-push {
    margin-top: .9rem;
    display: inline-flex; align-items: center; gap: .4rem;
    background: transparent; border: 1px solid rgba(255, 255, 255, .25);
    color: var(--t-color-cream, #f5f3ef); border-radius: var(--t-radius-full, 999px);
    padding: .45rem .9rem; font-size: .82rem; font-weight: 600; cursor: pointer;
    transition: background .15s ease, border-color .15s ease;
}
.pz-push:hover { background: rgba(255, 255, 255, .08); border-color: rgba(255, 255, 255, .4); }
.pz-push:disabled { opacity: .7; cursor: default; }

/* =========================================================================
   Accessibilità & classi mancanti (chip attiva, prosa, alert pubblici,
   breadcrumb espliciti, QR coupon, focus visibile dedicato)
   ========================================================================= */

/* Chip attiva (filtro/modalità selezionata): indaco pieno + testo bianco
   (#4f46e5 su #fff = contrasto ~7.6:1, oltre il minimo WCAG 4.5:1) */
.pz-chip--active,
.pz-chip--active:hover {
    background: var(--t-color-indigo-600, #4f46e5);
    border-color: var(--t-color-indigo-600, #4f46e5);
    color: #fff;
}

/* Blocchi di testo lungo leggibili (descrizione coupon, contenuti editoriali) */
.pz-prose { max-width: 65ch; line-height: 1.6; color: var(--t-text-primary); }
.pz-prose p { margin: 0 0 .85em; }
.pz-prose p:last-child { margin-bottom: 0; }

/* Alert inline pubblici (pagina ricerca: servizio non disponibile, hint geo).
   L'ordine info → warning conta: il JS può promuovere l'hint a warning. */
.pz-alert {
    display: flex; flex-wrap: wrap; align-items: center; gap: .6rem;
    padding: .8rem 1rem; margin-bottom: 1.25rem;
    border-radius: var(--t-radius-md, 8px);
    border-left: 3px solid var(--t-color-gray-400, #9ca3af);
    background: var(--t-bg-subtle, #f4f4f6); color: var(--t-text-primary, #1f2430);
    font-size: .92rem; line-height: 1.5;
}
.pz-alert a { color: var(--t-color-indigo-700, #4338ca); font-weight: 600; }
.pz-alert--info    { border-left-color: var(--t-color-indigo-600, #4f46e5); background: var(--t-color-indigo-50, #eef2ff); color: var(--t-color-indigo-900, #312e81); }
.pz-alert--warning { border-left-color: #d97706; background: #fffbeb; color: #78350f; }

/* Breadcrumb: elementi espliciti usati nei template (oltre al selettore discendente) */
.pz-breadcrumb__link { color: var(--t-text-secondary); text-decoration: none; }
.pz-breadcrumb__link:hover { color: var(--t-color-indigo-700); }
.pz-breadcrumb__sep { color: var(--t-text-muted); }
.pz-breadcrumb__current { color: var(--t-text-primary); font-weight: 600; }

/* QR code del coupon (sidebar scheda coupon) */
.pz-coupon__qr {
    display: block; margin-inline: auto;
    width: 180px; height: 180px;
    border: 1px solid var(--t-border-subtle, #e7e7ec);
    border-radius: var(--t-radius-md, 8px);
    background: #fff; padding: .4rem;
}

/* Stato di salvataggio del bottone Segui (aria-busy impostato da follow.js) */
.pz-follow[aria-busy="true"] { cursor: progress; }

/* Focus da tastiera dedicato: chip, follow e card-link (raggio coerente con la card) */
.pz-chip:focus-visible,
.pz-follow:focus-visible {
    outline: 2px solid var(--t-color-indigo-600, #4f46e5);
    outline-offset: 2px;
    border-radius: var(--t-radius-full, 999px);
}
a.pz-product-card:focus-visible,
a.pz-merchant-card:focus-visible,
a.pz-cat-card:focus-visible,
a.pz-hero__deal:focus-visible {
    outline: 2px solid var(--t-color-indigo-600, #4f46e5);
    outline-offset: 3px;
    border-radius: var(--t-radius-lg, 12px);
}

/* ------------------------------------------------------------------
   Fallback immagini rotte (img-fallback.js sostituisce src col
   placeholder): resa neutra, niente ritagli aggressivi.
   ------------------------------------------------------------------ */
img.pz-img--fallback {
    object-fit: contain;
    background: #f3f4f6;
}

/* ==================================================================
   SCHEDA MERCHANT "STORE PAGE" (/attivita/m/{slug})
   Cover hero + logo, badge stato apertura, tabella orari, ricerca
   interna prodotti, paginazione e card condivisione.
   ================================================================== */

/* Hero "store page" (struttura ispirata a eShopping Salerno):
   cover con gradiente, avatar sovrapposto, identita' + CTA, tab anchor. */
.pz-store-hero {
    margin-bottom: 1.5rem;
    border: 1px solid var(--t-border-subtle, #e2e8f0);
    border-radius: var(--t-radius-lg, 12px);
    overflow: hidden;
    background: var(--t-bg-surface, #fff);
}

.pz-store-hero__cover {
    position: relative;
    height: 240px;
    background: #f3f4f6;
}
.pz-store-hero__cover--placeholder {
    height: 140px;
    background: linear-gradient(120deg, var(--t-color-indigo-700, #4338ca), var(--t-color-indigo-500, #6366f1));
}
.pz-store-hero__cover-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* Gradiente di lettura sul bordo basso della cover */
.pz-store-hero__gradient {
    position: absolute;
    inset: auto 0 0 0;
    height: 45%;
    background: linear-gradient(to top, rgba(15, 23, 42, .55), transparent);
    pointer-events: none;
}
/* Chip categoria sulla cover, in basso a destra */
.pz-store-hero__cats {
    position: absolute;
    right: 1rem;
    bottom: .85rem;
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    justify-content: flex-end;
}
.pz-store-hero__cat {
    font-size: .75rem;
    font-weight: 600;
    color: #fff;
    background: rgba(15, 23, 42, .55);
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: var(--t-radius-full, 999px);
    padding: .2rem .65rem;
    backdrop-filter: blur(2px);
}

/* Barra identita': avatar sovrapposto alla cover + nome/meta + CTA */
.pz-store-hero__bar {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 0 1.25rem 1rem;
}
.pz-store-hero__avatar {
    flex: 0 0 auto;
    width: 96px;
    height: 96px;
    margin-top: -48px; /* sovrapposto alla cover */
    border-radius: 50%;
    border: 3px solid #fff;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--t-color-indigo-700, #4338ca);
    background: var(--t-color-indigo-100, #e0e7ff);
    box-shadow: 0 2px 8px rgba(0, 0, 0, .25);
}
.pz-store-hero__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.pz-store-hero__identity {
    flex: 1 1 auto;
    min-width: 0;
    padding-top: .65rem;
}
.pz-store-hero__title {
    margin: 0;
    font-size: 1.5rem;
    line-height: 1.2;
}
.pz-store-hero__meta {
    margin: .25rem 0 0;
    font-size: .9rem;
    color: var(--t-text-muted, #64748b);
}
.pz-store-hero__status {
    margin: .45rem 0 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .6rem;
    font-size: .85rem;
    color: var(--t-text-secondary, #475569);
}
.pz-store-hero__today { white-space: nowrap; }
.pz-store-hero__followers { white-space: nowrap; }
.pz-store-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .6rem;
    padding-top: .85rem;
}

/* CTA WhatsApp: verde scuro WhatsApp, contrasto AA con testo bianco */
.pz-btn--whatsapp {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    background: #128c7e;
    color: #fff;
    border: 1px solid #128c7e;
}
.pz-btn--whatsapp:hover,
.pz-btn--whatsapp:focus-visible {
    background: #0e6f64;
    border-color: #0e6f64;
    color: #fff;
}

/* Tab anchor delle sezioni della scheda */
.pz-store-tabs {
    display: flex;
    gap: .25rem;
    border-top: 1px solid var(--t-border-subtle, #e2e8f0);
    padding: 0 .75rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.pz-store-tab {
    padding: .8rem 1rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--t-text-secondary, #475569);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
}
.pz-store-tab:hover,
.pz-store-tab:focus-visible {
    color: var(--t-color-indigo-700, #4338ca);
    border-bottom-color: var(--t-color-indigo-300, #a5b4fc);
}
/* Tab attiva: la vista corrente della scheda */
.pz-store-tab.is-active {
    color: var(--t-color-indigo-700, #4338ca);
    border-bottom-color: var(--t-color-indigo-700, #4338ca);
}

@media (max-width: 700px) {
    .pz-store-hero__cover { height: 160px; }
    .pz-store-hero__bar { flex-wrap: wrap; }
    .pz-store-hero__avatar { width: 76px; height: 76px; margin-top: -38px; }
    .pz-store-hero__ctas { width: 100%; padding-top: .25rem; }
}

/* Badge stato apertura: verde aperto / rosso chiuso (contrasto AA) */
.pz-open-badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .2rem .65rem;
    border-radius: var(--t-radius-full, 999px);
    font-size: .8rem;
    font-weight: 600;
    white-space: nowrap;
}
.pz-open-badge::before {
    content: '';
    width: .5rem;
    height: .5rem;
    border-radius: 50%;
    background: currentColor;
}
.pz-open-badge--open { background: #dcfce7; color: #166534; }
.pz-open-badge--closed { background: #fee2e2; color: #991b1b; }

/* Vendor badge in scheda prodotto: chi vende al miglior prezzo */
.pz-vendor-badge {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-top: 1rem;
    padding: .75rem 1rem;
    border: 1px solid var(--t-border-default);
    border-radius: var(--t-radius-lg);
    text-decoration: none;
    color: inherit;
    background: var(--t-bg-surface);
}
.pz-vendor-badge:hover { border-color: var(--t-color-indigo-300); background: var(--t-color-indigo-50); }
.pz-vendor-badge__avatar {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    background: var(--t-color-indigo-100, #e0e7ff);
    color: var(--t-color-indigo-700, #4338ca);
}
.pz-vendor-badge__avatar img { width: 100%; height: 100%; object-fit: cover; }
.pz-vendor-badge__info { display: flex; flex-direction: column; min-width: 0; }
.pz-vendor-badge__label { font-size: .75rem; color: var(--t-text-muted); }
.pz-vendor-badge__name { font-weight: 700; }
.pz-vendor-badge__cta { margin-left: auto; font-size: .85rem; font-weight: 600; color: var(--t-color-indigo-700, #4338ca); white-space: nowrap; }

/* Trust badge sotto il box prezzo: garanzie del marketplace */
.pz-trust-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .75rem;
    margin-top: 1rem;
}
.pz-trust-item { display: flex; flex-direction: column; gap: .15rem; }
.pz-trust-item__title { font-size: .85rem; font-weight: 700; }
.pz-trust-item__desc { font-size: .78rem; color: var(--t-text-muted); }
@media (max-width: 700px) {
    .pz-trust-row { grid-template-columns: 1fr; }
}

/* Teaser "offerte e coupon" nella vista Prodotti della scheda merchant */
.pz-offers-teaser {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .8rem 1rem;
    border: 1px dashed var(--t-color-indigo-300, #a5b4fc);
    border-radius: var(--t-radius-lg, 12px);
    background: var(--t-color-indigo-50, #eef2ff);
    color: var(--t-color-indigo-700, #4338ca);
    text-decoration: none;
    font-size: .95rem;
}
.pz-offers-teaser:hover { border-style: solid; }

/* Card coupon cliccabile nella tab "Offerte e coupon" */
.pz-coupon-card {
    display: block;
    text-decoration: none;
    color: inherit;
}
.pz-coupon-card:hover { border-color: var(--t-color-indigo-300, #a5b4fc); }
.pz-coupon-card__value {
    margin: .35rem 0;
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--t-color-indigo-700, #4338ca);
}
.pz-coupon-card__cta { font-weight: 600; color: var(--t-color-indigo-700, #4338ca); }

/* Galleria foto della scheda merchant: griglia di thumb quadrate */
.pz-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .75rem;
}
.pz-gallery__item {
    position: relative;
    aspect-ratio: 1 / 1;
    padding: 0;
    border: 1px solid var(--t-border-subtle, #e2e8f0);
    border-radius: var(--t-radius-lg, 12px);
    overflow: hidden;
    cursor: zoom-in;
    background: #f3f4f6;
}
.pz-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .2s ease;
}
.pz-gallery__item:hover img,
.pz-gallery__item:focus-visible img { transform: scale(1.04); }
.pz-gallery__item:focus-visible {
    outline: 3px solid var(--t-color-indigo-300, #a5b4fc);
    outline-offset: 2px;
}
@media (max-width: 700px) {
    .pz-gallery { grid-template-columns: repeat(2, 1fr); }
}

/* Lightbox (dialog nativo) della galleria */
.pz-gallery-lightbox {
    border: 0;
    padding: 0;
    background: transparent;
    max-width: min(92vw, 1100px);
    max-height: 92vh;
}
.pz-gallery-lightbox::backdrop { background: rgba(15, 23, 42, .85); }
.pz-gallery-lightbox img {
    display: block;
    max-width: min(92vw, 1100px);
    max-height: 88vh;
    border-radius: var(--t-radius-lg, 12px);
}
.pz-gallery-lightbox__close {
    position: absolute;
    top: .5rem;
    right: .5rem;
    width: 2.4rem;
    height: 2.4rem;
    border: 0;
    border-radius: 50%;
    background: rgba(15, 23, 42, .7);
    color: #fff;
    font-size: 1.1rem;
    cursor: pointer;
}
.pz-gallery-lightbox__close:hover { background: rgba(15, 23, 42, .9); }

/* Gestione galleria nel cruscotto: thumb + checkbox elimina */
.pz-gallery-manage {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(9rem, 1fr));
    gap: .75rem;
    margin-bottom: 1rem;
}
.pz-gallery-manage__item {
    display: block;
    border: 1px solid var(--t-border-subtle, #e2e8f0);
    border-radius: var(--t-radius-lg, 12px);
    overflow: hidden;
    cursor: pointer;
}
.pz-gallery-manage__item img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
}
.pz-gallery-manage__delete {
    display: flex;
    align-items: center;
    gap: .4rem;
    padding: .4rem .6rem;
    font-size: .8rem;
    font-weight: 600;
    color: #991b1b;
}
.pz-gallery-manage__item:has(input:checked) {
    border-color: #dc2626;
    box-shadow: 0 0 0 2px rgba(220, 38, 38, .25);
}

/* Tabella orari settimanali nella sidebar (riga di oggi evidenziata) */
.pz-hours-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
}
.pz-hours-table th,
.pz-hours-table td {
    padding: .4rem .25rem;
    text-align: left;
    border-bottom: 1px solid #f3f4f6;
    vertical-align: top;
}
.pz-hours-table th { font-weight: 500; white-space: nowrap; }
.pz-hours-table td { text-align: right; color: #374151; }
.pz-hours-table tr:last-child th,
.pz-hours-table tr:last-child td { border-bottom: 0; }
.pz-hours-table tr.is-today th,
.pz-hours-table tr.is-today td {
    font-weight: 700;
    color: var(--t-color-indigo-700, #4338ca);
    background: #eef2ff;
}

/* Lista contatti sidebar con icone SVG inline */
.pz-contact-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
.pz-contact-list svg {
    width: 1rem;
    height: 1rem;
    vertical-align: -.15em;
    margin-right: .3rem;
}

/* Form di ricerca interna alla scheda (GET q sulla stessa route) */
.pz-store-search {
    display: flex;
    gap: .5rem;
    margin-bottom: 1rem;
}
.pz-store-search input[type="search"] {
    flex: 1;
    min-width: 0;
    padding: .5rem .75rem;
    border: 1px solid #d1d5db;
    border-radius: var(--t-radius-md, 8px);
    font: inherit;
}
.pz-store-search input[type="search"]:focus-visible {
    outline: 2px solid var(--t-color-indigo-600, #4f46e5);
    outline-offset: 1px;
}

/* Paginazione prodotti: prev/next + indicatore pagina */
.pz-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 1.25rem;
}
.pz-pagination__link {
    display: inline-flex;
    align-items: center;
    padding: .45rem .9rem;
    border: 1px solid #d1d5db;
    border-radius: var(--t-radius-full, 999px);
    text-decoration: none;
    font-size: .9rem;
    color: var(--t-color-indigo-700, #4338ca);
    background: #fff;
}
.pz-pagination__link:hover { background: #eef2ff; }
.pz-pagination__link:focus-visible {
    outline: 2px solid var(--t-color-indigo-600, #4f46e5);
    outline-offset: 2px;
}
.pz-pagination__info { font-size: .9rem; color: #4b5563; }

/* Caratteristiche (attributi) nelle schede pubbliche merchant/prodotto. */
.pz-attr-list {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.pz-attr-row {
    display: grid;
    grid-template-columns: minmax(8rem, 11rem) 1fr;
    gap: .35rem .9rem;
    align-items: baseline;
}
@media (max-width: 540px) {
    .pz-attr-row { grid-template-columns: 1fr; gap: .15rem; }
}
.pz-attr-row__label {
    font-weight: 600;
    font-size: .82rem;
    color: var(--t-text-secondary, #6b7280);
    text-transform: uppercase;
    letter-spacing: .03em;
    margin: 0;
}
.pz-attr-row__values {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}
.pz-attr-chip {
    display: inline-flex;
    align-items: center;
    padding: .2rem .6rem;
    background: #eef2ff;
    color: #3730a3;
    border-radius: 999px;
    font-size: .82rem;
    line-height: 1.35;
}

/* Card condividi: bottoni copia link + WhatsApp e feedback "Copiato!" */
.pz-share {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}
.pz-share__btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .45rem .9rem;
    border: 1px solid #d1d5db;
    border-radius: var(--t-radius-full, 999px);
    background: #fff;
    color: #1f2937;
    font: inherit;
    font-size: .9rem;
    text-decoration: none;
    cursor: pointer;
}
.pz-share__btn:hover { background: #f9fafb; }
.pz-share__btn:focus-visible {
    outline: 2px solid var(--t-color-indigo-600, #4f46e5);
    outline-offset: 2px;
}
.pz-share__btn svg { width: 1rem; height: 1rem; }
.pz-share__feedback {
    font-size: .85rem;
    font-weight: 600;
    color: #166534;
    min-height: 1.2em;
}
