/* =====================================================
   ADV BANNER ORIZZONTALE — base (3:4, con badge attivo)
   ===================================================== */
.adv-banner-orizz{
  --adv-radius: 4px;
  --adv-gap: 24px;
  --adv-pad: 12px 12px;

  --adv-imgcol-w: 540px;
  --adv-thumb-ratio: 3 / 4;

  --adv-title-size: clamp(1.55rem, 1.4vw + 1rem, 2.2rem);
  --adv-title-weight: 400;
  --adv-subtitle-size: clamp(1rem, .65vw + .9rem, 1.15rem);
  --adv-subtitle-color: #c0c0c0;

  --adv-cta-h: 60px;
  --adv-cta-bw: 2px;
  --adv-cta-maxw: 600px;

  background:#fff;
  border:1px solid rgba(0,0,0,.08);  /* soft (niente bordo nero) */
  border-radius:var(--adv-radius);
  padding:var(--adv-pad);
  margin:16px 0 22px;
}

.adv-banner-orizz .advb-inner{
  display:flex;
  gap:var(--adv-gap);
  align-items:center;
  justify-content:space-between;
}

/* ===== Colonna immagini (3 thumbs verticali 3:4) ===== */
.adv-banner-orizz .advb-imgcol{
  display:flex;
  gap:14px;
  flex:0 0 var(--adv-imgcol-w);
  max-width:var(--adv-imgcol-w);
}
.adv-banner-orizz .advb-thumb{
  flex:1 1 0;
  min-width:0;
  border:1px solid #e6e6e6;
  border-radius:8px;
  overflow:hidden;
  background:#f7f7f7;
  aspect-ratio: var(--adv-thumb-ratio);
  display:flex;
}
.adv-banner-orizz .advb-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* ===== Colonna testo ===== */
.adv-banner-orizz .advb-content{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}

/* Badge */
.adv-banner-orizz .advb-badge{
  display:inline-block;
  background:#ffe16a;
  color:#111;
  font-weight:600;
  font-size:.8rem;
  padding:4px 12px;
  border-radius:999px;
  margin-bottom:14px;
}

/* Titolo */
.adv-banner-orizz .advb-title{
  margin:0 0 10px;
  font-weight:var(--adv-title-weight);
  font-size:var(--adv-title-size);
  line-height:1.18;
  letter-spacing:.1px;
}

/* Sottotitolo (brand • prezzo) */
.adv-banner-orizz .advb-subtitle{
  margin:0 0 18px;
  color:var(--adv-subtitle-color);
  font-size:var(--adv-subtitle-size);
}
.adv-banner-orizz .advb-subtitle .brand{ font-weight:600; color:#595959; }
.adv-banner-orizz .advb-subtitle .sep { margin:0 8px; color:#bdbdbd; }
.adv-banner-orizz .advb-subtitle .price{ font-weight:700; color:#2f2f2f; }

/* CTA */
.adv-banner-orizz .advb-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:var(--adv-cta-h);
  padding:0 30px;
  border:var(--adv-cta-bw) solid #111;
  border-radius:999px;
  font-weight:700;
  text-decoration:none;
  color:#111;
  background:#fff;
  transition:.15s ease;
  max-width:var(--adv-cta-maxw);
  width:100%;
}
.adv-banner-orizz .advb-cta:hover{ background:#111; color:#fff; }

/* ===== Responsive base ===== */
@media (max-width: 1100px){
  .pagina-vetrina .adv-banner-orizz{ --adv-imgcol-w: 460px; }
}
@media (max-width: 900px){
  .adv-banner-orizz .advb-inner{ flex-direction:column; }
  .adv-banner-orizz{ --adv-imgcol-w: 100%; }
  .adv-banner-orizz .advb-cta{ max-width:560px; }
}
@media (max-width: 560px){
  .adv-banner-orizz .advb-cta{ max-width:100%; }
}

/* =====================================================
   VARIANTE COMPATTA (comune) – attivata con .adv--compact
   ===================================================== */
.adv-banner-orizz.adv--compact{
  --adv-imgcol-w: 420px;                         /* 540 → 420 */
  --adv-gap: 16px;                               /* 24 → 16 */
  --adv-title-size: clamp(1.2rem, 0.9vw + 0.9rem, 1.6rem);
  --adv-cta-h: 50px;                             /* 60 → 50 */
  --adv-cta-bw: 1px;                             /* bordo più fino */
  --adv-cta-maxw: 420px;
}
.adv-banner-orizz.adv--compact .advb-badge{ margin-bottom: 8px; }
.adv-banner-orizz.adv--compact .advb-title{ margin:0 0 8px; line-height:1.18; }
.adv-banner-orizz.adv--compact .advb-subtitle{
  margin:0 0 14px;
  font-size:.98rem;
  display:inline-flex; align-items:baseline; gap:10px; white-space:nowrap;
}
.adv-banner-orizz.adv--compact .advb-subtitle .sep{ margin:0; } /* usa gap */
.adv-banner-orizz.adv--compact .advb-cta{
  min-height:var(--adv-cta-h); padding:0 20px; border-width:var(--adv-cta-bw);
}
@media (max-width: 900px){
  .adv-banner-orizz.adv--compact{ --adv-imgcol-w: 100%; }
  .adv-banner-orizz.adv--compact .advb-cta{ min-height:48px; padding:0 18px; }
}
@media (max-width: 560px){
  .adv-banner-orizz.adv--compact .advb-cta{ min-height:46px; padding:0 16px; }
}

/* =====================================================
   RIFINITURE SOLO MAGAZINE (wrapper .mag-article-wrapper)
   ===================================================== */
.mag-article-wrapper .adv-banner-orizz{
  /* ritmo verticale armonico e niente padding-top hack */
  margin-top: 48px;
  margin-bottom: 48px;
  padding-top: 12px;
  display: flow-root; /* evita margin-collapsing */
}
.mag-article-wrapper .mag-lead + .adv-banner-orizz{ margin-top: 48px; }
@media (max-width: 900px){
  .mag-article-wrapper .adv-banner-orizz{ margin-top:32px; margin-bottom:36px; }
  .mag-article-wrapper .mag-lead + .adv-banner-orizz{ margin-top:32px; }
}

/* brand più vicino al titolo + look magazine */
.mag-article-wrapper .adv-banner-orizz .advb-subtitle{ margin-top:-6px; margin-bottom:16px; }
.mag-article-wrapper .adv-banner-orizz .advb-subtitle .brand{
  text-transform: uppercase; font-weight:300; color:#000; letter-spacing:.5px;
}
/* CTA più snella nel magazine */
.mag-article-wrapper .adv-banner-orizz .advb-cta{
  min-height:46px; padding:0 18px; font-size:.9rem; font-weight:500; white-space:nowrap;
}

/* =====================================================
   SOLO mag_top (banner sotto cover) — layout deterministico
   ===================================================== */
/* Aggiungi la classe .is-magtop nel template quando pos=mag_top */
.adv-banner-orizz.is-magtop .advb-inner{
  display:grid;
  grid-template-columns: var(--adv-imgcol-w, 420px) minmax(0, 1fr);
  align-items:center;
  gap:16px;
}
.adv-banner-orizz.is-magtop .advb-imgcol{
  width: var(--adv-imgcol-w, 420px);
  max-width: var(--adv-imgcol-w, 420px);
  flex: 0 0 var(--adv-imgcol-w, 420px);
}
.adv-banner-orizz.is-magtop .advb-content{
  min-width:0;
  display:flex; flex-direction:column; align-items:center;
  text-align:center;
}
/* Titolo max 2 righe per non “spaccare” la gabbia */
.adv-banner-orizz.is-magtop .advb-title{
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden; max-width:36ch; margin:0 0 8px;
}
/* brand • prezzo: riga unica, dot piccolo e centrato */
.adv-banner-orizz.is-magtop .advb-subtitle{
  display:inline-flex; align-items:baseline; gap:10px; white-space:nowrap;
  line-height:1.1; margin:0 0 14px; font-size:1rem; color:#3a3a3a;
}
.adv-banner-orizz.is-magtop .advb-subtitle .sep{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:#bdbdbd; margin:0; font-size:0; line-height:0;
}
.adv-banner-orizz.is-magtop .advb-subtitle .brand{
  text-transform:uppercase; font-weight:300; letter-spacing:.5px; color:#000;
}
.adv-banner-orizz.is-magtop .advb-subtitle .price{ font-weight:700; color:#111827; }
/* CTA coerente e centrata */
.adv-banner-orizz.is-magtop .advb-cta{
  min-height:50px; padding:0 20px; border-width:1px; align-self:center;
}
/* Cornice soft (niente “riquadri” marcati) */
.adv-banner-orizz.is-magtop{ border:1px solid rgba(0,0,0,.08); box-shadow:none; }

/* Bordi dei thumb sempre soft (mai neri) */
.adv-banner-orizz .advb-thumb{
  border-color: #fff;     /* ribadisco il colore giusto */
}
/* BASE (Vetrine) */
.adv-banner-orizz{
  /* …tutto il resto invariato… */
  border: 1px solid #e7e7e7;   /* ripristino Vetrine */
}
/* =====================================================
   MOBILE FIX — Banner orizzontale ADV (Vetrina & pubblico)
   Obiettivo:
   - su mobile mostra una sola immagine forte
   - evita 3 thumb compresse
   - contenuto più pulito e leggibile
===================================================== */
@media (max-width: 768px){
  .adv-banner-orizz{
    --adv-gap: 14px;
    --adv-pad: 10px;
    --adv-title-size: clamp(1.55rem, 1.2rem + 2.2vw, 2.15rem);
	--adv-subtitle-size: 0.96rem;
    --adv-cta-h: 48px;
    margin: 14px 0 18px;
  }

  .adv-banner-orizz .advb-inner{
    flex-direction: column;
    gap: 14px;
    align-items: stretch;
  }

  .adv-banner-orizz .advb-imgcol{
    width: 100%;
    max-width: 100%;
    flex: 0 0 auto;
    display: block;              /* non più 3 thumb in fila */
  }

  .adv-banner-orizz .advb-thumb{
    width: 100%;
    max-width: 100%;
    border-radius: 12px;
    aspect-ratio: 4 / 5;         /* più adatta al mobile */
  }

  /* mostra solo la prima immagine */
  .adv-banner-orizz .advb-thumb:nth-child(n+2){
    display: none;
  }

  .adv-banner-orizz .advb-content{
    width: 100%;
    align-items: center;
    text-align: center;
    padding: 2px 4px 0;
  }

  .adv-banner-orizz .advb-badge{
    margin-bottom: 10px;
    font-size: 0.76rem;
    padding: 4px 10px;
  }

  .adv-banner-orizz .advb-title{
    margin: 0 0 8px;
    line-height: 1.16;
    letter-spacing: -0.015em;
    max-width: 18ch;
  }

  .adv-banner-orizz .advb-subtitle{
    margin: 0 0 12px;
    line-height: 1.15;
  }

  .adv-banner-orizz .advb-cta{
    width: 100%;
    max-width: 100%;
    min-height: 48px;
    padding: 0 16px;
    font-size: 0.95rem;
    border-width: 1px;
  }
}