/* ===============================================================
   🎯 PRODOTTI-SINGOLO.CSS — Layout del singolo prodotto vetrina
   Allineato a variables.css / base.css / components.css
   =============================================================== */

/* ===== Variabili locali (override facoltativi) ===== */
:root {
  --prod-single-max: 1340px;
  --prod-gap: 2rem;
  --prod-accent: var(--color-accent, #db4a2f);

  --btn-radius-pill: 999px;
  --btn-font: 1rem;

  --border-soft: 1px solid #ddd;
  --muted: #444;
  --muted-2: #666;

  --price-size: 1.4rem;
  --price-weight: 600;

  --h1-size-single: clamp(1.6rem, 1.2rem + 1.5vw, 2.1rem);
}

/* ===== Wrapper pagina ===== */
.prodotto-vetrineshop{
  /* niente max-width: lo fa .contenitore */
  margin: 0;
  padding: 2rem 0; /* solo verticale, i lati li gestisce .contenitore */

  /* ok mantenerli */
  font-family: var(--font-base, system-ui, sans-serif);
  color: var(--color-text, #111);
  box-sizing: border-box;
}

/* ===== Layout colonne ===== */
.grid-layout {
  display: flex;
  flex-wrap: wrap;
  gap: var(--prod-gap);
  align-items: flex-start;
}

/* ===== Colonna immagini ===== */
.colonna-immagini-unificate {
  flex: 1 1 65%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.25rem;
}

.colonna-immagini-unificate .box-img {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: #f5f5f5;
}

.colonna-immagini-unificate img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
  display: block;
}

/* =======================================================
   🖼️ Fix immagini orizzontali (no spazio fantasma)
   ======================================================= */

.colonna-immagini-unificate .box-img.is-landscape{
  aspect-ratio: 16 / 10;
}

.colonna-immagini-unificate .box-img.is-landscape img{
  object-fit: contain;
  background: #fff;
}

/* ===== Colonna info ===== */
.colonna-info {
  flex: 1 1 32%;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 280px;
}

/* Titolo */
.colonna-info h1 {
  font-family: var(--font-heading);
  font-size: var(--h1-size-single);
  line-height: var(--h2-lh, 1.2);
  margin: 0 0 0.5rem 0;
  color: var(--heading-color, #111);
  font-weight: var(--heading-weight-semibold, 600);
}

/* Categoria / breadcrumb mini */
.colonna-info .categoria a {
  font-size: 0.9rem;
  color: var(--prod-accent);
  text-decoration: none;
}
.colonna-info .categoria a:hover { text-decoration: underline; }

/* Marchio + Prezzo */
.marchio-prezzo {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.colonna-info .marchio img {
  width: 110px;
  height: 110px;
  object-fit: contain;
  display: block;
}

.marchio-prezzo .prezzo {
  font-size: var(--price-size);
  font-weight: var(--price-weight);
  margin: 0;
  color: var(--color-text, #111);
}

/* Pulsanti azione */
.gruppo-pulsanti {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

.btn-acquista,
.btn-wishlist {
  padding: 0.9rem 1.5rem;
  font-size: var(--btn-font);
  border-radius: var(--btn-radius-pill);
  cursor: pointer;
  width: 100%;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-weight: 600;
  box-sizing: border-box;
  transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}

/* Variante chiara (ghost) */
.btn-acquista {
  background: #fff;
  color: #111;
  border: 1px solid #111;
}
.btn-acquista:hover {
  background: #111;
  color: #fff;
}

/* Variante piena (primary) */
.btn-wishlist {
  background: #000;
  color: #fff;
  border: 1px solid #000;
}
.btn-wishlist:hover {
  background: #111;
  border-color: #111;
}

/* Accordion dettagli */
.accordion details {
  border-top: var(--border-soft);
  padding: 1rem 0;
}

.accordion summary {
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  outline: none;
  list-style: none; /* evita marker in alcuni browser */
}
.accordion summary::-webkit-details-marker { display: none; }

.accordion .contenuto {
  padding: 0.5rem 0 0 0;
  font-size: 0.95rem;
  color: var(--muted);
}

/* Micro meta/descrizioni */
.colonna-info .meta,
.colonna-info .note,
.colonna-info .disclaimer {
  font-size: 0.9rem;
  color: var(--muted-2);
}

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  .colonna-immagini-unificate {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 820px) {
  .grid-layout {
    flex-direction: column;
  }
  .colonna-info {
    order: 2;
  }
  .colonna-immagini-unificate {
    order: 1;
  }
}

@media (max-width: 480px) {
  .colonna-immagini-unificate {
    grid-template-columns: 1fr;
  }
  .marchio-prezzo {
    gap: 1rem;
  }
}
/* ================================
   🔒 Stabilizzazione galleria negozio (anti-CLS)
   ================================ */

.galleria-negozio{
  aspect-ratio: 4 / 3;
  width: 100%;
  overflow: hidden;
}

/* ✅ Riserva altezza al wrapper Swiper senza forzare le immagini */
.galleria-negozio .swiper{
  width: 100%;
  height: 100%;
}

/* ❌ rimuoviamo height:100% sulla slide: il layout contain gestisce la dimensione */
.galleria-negozio .swiper-slide{
  /* lasciamo vuoto apposta (governato da header-negozio.css) */
}

/* ❌ non forziamo cover/height:100% sull’immagine: header-negozio.css usa contain */
.galleria-negozio .shop-gallery-img{
  /* lasciamo vuoto apposta (governato da header-negozio.css) */
}










/* ===============================================================
   SINGOLO PRODOTTO — MOBILE REFINEMENT FINALE
   Solo mobile, desktop invariato
   =============================================================== */

@media (max-width: 820px){

  .prodotto-vetrineshop{
    padding: 1rem 0 1.5rem;
  }

  .grid-layout{
    gap: 1rem;
  }

  .colonna-immagini-unificate{
    width: 100%;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .colonna-immagini-unificate .box-img{
    border-radius: 16px;
    overflow: hidden;
    background: #f7f7f7;
  }

  .colonna-immagini-unificate img{
    border-radius: 16px;
  }

  .colonna-info{
    min-width: 0;
    gap: .85rem;
  }

  .colonna-info h1{
    margin: 0;
    font-size: clamp(1.7rem, 6.8vw, 2.15rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    text-wrap: balance;
  }

  .marchio-prezzo{
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: nowrap;
  }

  .colonna-info .marchio img{
    width: 84px;
    height: 84px;
  }

  .marchio-prezzo .prezzo{
    font-size: 1.2rem;
    line-height: 1;
    text-align: right;
    letter-spacing: -0.01em;
  }

  .accordion details{
    padding: .9rem 0;
  }

  .accordion summary{
    font-size: .98rem;
    line-height: 1.3;
    letter-spacing: 0.01em;
  }

  .accordion .contenuto{
    padding-top: .55rem;
    font-size: .95rem;
    line-height: 1.55;
  }

  .gruppo-pulsanti{
    gap: .7rem;
    margin-top: .4rem;
  }

  .btn-acquista,
  .btn-wishlist{
    min-height: 48px;
    padding: 0 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .96rem;
    line-height: 1.1;
    letter-spacing: 0.01em;
    white-space: nowrap;
  }

  .prodotti-correlati{
    margin-top: 1.5rem;
  }

  .prodotti-correlati .titolo-sezione{
    font-size: clamp(1.28rem, 5vw, 1.5rem);
    line-height: 1.12;
    letter-spacing: -0.015em;
    text-wrap: balance;
  }
}

@media (max-width: 560px){

  .prodotto-vetrineshop{
    padding-top: .75rem;
  }

  .colonna-immagini-unificate{
    gap: 8px;
  }

  .colonna-immagini-unificate .box-img{
    border-radius: 14px;
  }

  .colonna-immagini-unificate img{
    border-radius: 14px;
  }

  .colonna-info h1{
    font-size: clamp(1.55rem, 7.2vw, 1.95rem);
  }

  .marchio-prezzo{
    gap: 10px;
  }

  .colonna-info .marchio img{
    width: 72px;
    height: 72px;
  }

  .marchio-prezzo .prezzo{
    font-size: 1.08rem;
  }

  .btn-acquista,
  .btn-wishlist{
    min-height: 46px;
    font-size: .92rem;
  }

  .accordion summary{
    font-size: .95rem;
  }

  .accordion .contenuto{
    font-size: .92rem;
  }
}
 
/* ===============================================================
   GALLERIA PRODOTTO — SCROLL ORIZZONTALE MOBILE
   =============================================================== */

@media (max-width: 820px){

  .colonna-immagini-unificate{

    display:flex;
    flex-wrap:nowrap;

    overflow-x:auto;
    overflow-y:hidden;

    gap:12px;
    padding-bottom:4px;

    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;

  }

  .colonna-immagini-unificate::-webkit-scrollbar{
    display:none;
  }

  .colonna-immagini-unificate .box-img{

    flex:0 0 88%;
    aspect-ratio:3/4;

    scroll-snap-align:start;

    border-radius:16px;
    overflow:hidden;
  }

  .colonna-immagini-unificate img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:16px;
  }

}


/* ===============================================================
   🧪 MOBILE EXPERIMENT — GALLERIA PRODOTTO SCROLL ORIZZONTALE
   (rimuovi tutto questo blocco per tornare al layout precedente)
   =============================================================== */

@media (max-width: 820px){

  .colonna-immagini-unificate{
    display:flex !important;
    flex-wrap:nowrap !important;

    overflow-x:auto;
    overflow-y:hidden;

    gap:12px;
    padding-bottom:6px;

    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }

  /* nasconde scrollbar */
  .colonna-immagini-unificate::-webkit-scrollbar{
    display:none;
  }

  /* slide */
  .colonna-immagini-unificate .box-img{
    flex:0 0 88%;
    aspect-ratio:3/4;

    scroll-snap-align:start;

    border-radius:16px;
    overflow:hidden;
    box-sizing:border-box;
  }

  /* immagine */
  .colonna-immagini-unificate img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:16px;
    display:block;
  }
}

/* ===============================================================
   🧪 MOBILE FIX — evita il ballo laterale della pagina
   con galleria orizzontale
   =============================================================== */

@media (max-width: 820px){

  .prodotto-singolo,
  .prodotto-vetrineshop,
  .grid-layout,
  .colonna-info{
    min-width:0;
  }

  .pagina-con-header-globale.prodotto-singolo,
  .pagina-con-header-globale.prodotto-singolo .site-main,
  .pagina-con-header-globale.prodotto-singolo .contenitore{
    overflow-x:clip;
  }

  .colonna-immagini-unificate{
    width:100%;
    max-width:100%;
    box-sizing:border-box;
    overscroll-behavior-x:contain;
  }
}