/* ─────────────────────────────────────────────────────────────────────────
 * Stili pagina prodotto singolo — Barra
 *
 * Loaded solo su is_product(). Override del layout WooCommerce via CSS grid.
 * Token da src/css/theme.css; proprietà in ordine alfabetico per regola.
 * ───────────────────────────────────────────────────────────────────────── */

/* ── Larghezza — .woocommerce è full-width; ogni sezione gestisce il boxed ─ */

.woocommerce {
  width: 100%;
}

/* Breadcrumb e notice wrapper: boxed come l'hero.
   Specificità (0,2,0) per battere .woocommerce .woocommerce-breadcrumb { padding: 0 } di woocommerce.css. */
.woocommerce .woocommerce-notices-wrapper,
.woocommerce .woocommerce-breadcrumb {
  margin-inline: auto;
  max-width: var(--container-boxed);
  padding-inline: var(--spacing-md);
}

.woocommerce .woocommerce-breadcrumb {
  padding-top: var(--spacing-lg);
  margin-bottom: 0;
  ;
}

/* ── Fix clearfix WooCommerce ──────────────────────────────────────────── */

/* WC aggiunge ::after con clear:both su .product; in un grid container
   diventa un grid item fantasma che collassa la struttura. */
.woocommerce div.product::after {
  content: none;
}

/* WC imposta margin-bottom su tutti i figli di .summary tramite il block gap
   di Gutenberg — azzeriamo per usare il gap del nostro flex container. */
.woocommerce div.product div.summary>* {
  margin-bottom: 0;
}

/* ── Layout hero: flex 2 colonne ───────────────────────────────────────── */

/* Il prodotto è il wrapper WC: solo spaziatura verticale, nessun layout. */
.woocommerce div.product {
  padding-top: var(--spacing-lg);
}

/* Hero: boxed + flex 2 colonne — larghezze esplicite in %
   così Swiper può calcolare clientWidth correttamente. */
.barra-product-hero {
  align-items: flex-start;
  display: flex;
  gap: var(--spacing-lg);
  margin-inline: auto;
  max-width: var(--container-boxed);
  padding-bottom: var(--spacing-xl);
  padding-inline: var(--spacing-md);
}

.barra-product-gallery {
  flex: 0 0 calc(50% - var(--spacing-lg) / 2);
  max-width: calc(50% - var(--spacing-lg) / 2);
  min-width: 0;
}

.barra-product-hero .summary.entry-summary {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
  padding-top: 0;
  width: 0;
  /* forza il shrink; flex:1 gestisce la crescita */
}

/* ── Gallery Swiper ────────────────────────────────────────────────────── */

.barra-product-gallery {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Wrapper slider principale */
.barra-gallery-main {
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  width: 100%;
}

.barra-gallery-main .swiper-slide {
  overflow: hidden;
}

.barra-gallery-main .barra-gallery-img {
  aspect-ratio: 1;
  display: block;
  height: auto;
  object-fit: cover;
  object-position: bottom;
  width: 100%;
}

/* Frecce di navigazione */
.barra-gallery-prev,
.barra-gallery-next {
  align-items: center;
  background: rgba(255, 255, 255, 0.88);
  border-radius: var(--radius-full);
  color: var(--color-text);
  cursor: pointer;
  display: flex;
  height: 2.5rem;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.5rem;
  z-index: 10;
}

.barra-gallery-prev {
  left: 0.75rem;
}

.barra-gallery-next {
  right: 0.75rem;
}

.barra-gallery-prev svg,
.barra-gallery-next svg {
  height: 1.125rem;
  width: 1.125rem;
}

/* Thumbnails */
.barra-gallery-thumbs {
  width: 100%;
}

.barra-gallery-thumbs .swiper-slide {
  border-radius: var(--radius-lg);
  cursor: pointer;
  opacity: 0.55;
  overflow: hidden;
  transition: opacity 0.2s;
}

.barra-gallery-thumbs .swiper-slide-thumb-active {
  border: 2px solid #3D2817;
  opacity: 1;
}

.barra-gallery-thumbs .barra-gallery-thumb-img {
  aspect-ratio: 1;
  display: block;
  height: auto;
  object-fit: cover;
  width: 100%;
}

/* ── Summary: tipografia ───────────────────────────────────────────────── */

.barra-product-category {
  color: var(--color-category-title);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  margin: 0;
  text-transform: uppercase;
}

.woocommerce div.product .product_title.entry-title {
  color: var(--color-text);
  font-family: var(--font-family-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 400;
  line-height: 1.15;
  margin: 0;
}

.barra-product-subtitle {
  color: var(--color-text);
  font-family: var(--font-family-display);
  font-style: italic;
  margin: 0;
  opacity: 0.75;
}

/* ── Prezzo + nota IVA inline ──────────────────────────────────────────── */

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  align-items: baseline;
  color: #985931;
  display: flex;
  flex-wrap: wrap;
  font-family: var(--font-family-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 400;
  gap: 0.625rem;
  margin: 0;
}

.woocommerce div.product .woocommerce-Price-amount.amount {
  display: inline-flex;
  gap: 0.25rem;
}

.barra-price-note {
  color: var(--color-text);
  font-family: var(--font-family-sans);
  font-size: 0.75rem;
  font-weight: 400;
  opacity: 0.6;
}

/* ── Breve descrizione ─────────────────────────────────────────────────── */

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--color-text);
  font-size: 0.9375rem;
  line-height: 1.65;
  margin: 0;
}

.woocommerce div.product .woocommerce-product-details__short-description p {
  margin: 0;
}

/* ── Attributo formato ─────────────────────────────────────────────────── */

.barra-product-format {
  border-top: 1px solid color-mix(in srgb, var(--color-text) 15%, transparent);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding-top: 1rem;
}

.barra-product-format__label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.barra-product-format__value {
  font-size: 0.9375rem;
}

/* ── Form: stepper + bottone ───────────────────────────────────────────── */

.woocommerce div.product form.cart {
  align-items: center;
  display: flex;
  gap: 0.75rem;
  margin: 0;
}

/* Annulla il clearfix WC: serviva con i float, inutile in flex. */
.woocommerce div.product form.cart::before,
.woocommerce div.product form.cart::after {
  content: none;
}

/* Wrapper quantità — pill con bordo.
   Usiamo div.quantity per battere la specificità di WC:
   .woocommerce :where(...) div.product form.cart div.quantity { display: inline-block } */
.woocommerce div.product form.cart div.quantity {
  align-items: center;
  border: 1.5px solid #EEE3D8;
  border-radius: var(--radius-full);
  display: flex;
  flex-shrink: 0;
  padding: 0.25rem;
  vertical-align: unset;
}

/* Pulsanti stepper − / + */
.barra-qty-btn {
  align-items: center;
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  color: var(--color-text);
  cursor: pointer;
  display: flex;
  font-size: 1.125rem;
  height: 2rem;
  justify-content: center;
  line-height: 1;
  padding: 0;
  transition: background-color 0.15s;
  width: 2rem;
}

.barra-qty-btn:hover {
  background-color: color-mix(in srgb, var(--color-text) 8%, transparent);
}

/* Input quantità — specificità (0,5,4) per battere:
   .woocommerce :where(...) div.product form.cart div.quantity .input-text { padding: .9rem 1.1rem } */
.woocommerce div.product form.cart div.quantity input.qty {
  -moz-appearance: textfield;
  appearance: textfield;
  background: transparent;
  border: none;
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 600;
  outline: none;
  padding: 0;
  text-align: center;
  width: 3rem;
}

.woocommerce div.product form.cart input.qty::-webkit-inner-spin-button,
.woocommerce div.product form.cart input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none;
  appearance: none;
}

/* Bottone aggiungi al carrello.
   Usiamo button.single_add_to_cart_button per battere la specificità di WC:
   .woocommerce div.product form.cart button.single_add_to_cart_button { display: inline-block } */
.woocommerce div.product form.cart button.single_add_to_cart_button {
  align-items: center;
  background: #985931;
  border: none;
  border-radius: var(--radius-full);
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  flex: 1;
  float: none;
  font-family: var(--font-family-sans);
  font-size: 1rem;
  font-weight: 500;
  gap: 0.5rem;
  justify-content: center;
  padding: 0.875rem 2rem;
  text-decoration: none;
  transition: background-color 0.2s;
  vertical-align: unset;
  word-break: normal;
}

.woocommerce div.product form.cart button.single_add_to_cart_button:hover {
  background: var(--color-text);
}

/* ── Feature icons ─────────────────────────────────────────────────────── */

.barra-product-features {
  border-top: 1px solid color-mix(in srgb, var(--color-text) 15%, transparent);
  display: flex;
  gap: var(--spacing-md);
  justify-content: space-between;
  margin-top: 0.5rem;
  padding-top: 1.25rem;
}

.barra-product-feature {
  align-items: center;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 0.5rem;
  text-align: center;
}

.barra-product-feature svg {
  color: var(--color-category-title);
  flex-shrink: 0;
}

.barra-product-feature span {
  color: var(--color-text);
  font-size: 0.75rem;
  line-height: 1.3;
}

/* ── Sezione inferiore: Ingredienti (sx) + 3 tab (dx) ─────────────────── */

/* Background fullwidth; contenuto boxed tramite padding-inline calcolato:
   (100% - container-boxed) / 2 + padding-interno
   = margini laterali che allineano il contenuto al boxed delle altre sezioni. */
.barra-product-bottom {
  background-color: var(--color-surface-muted);
  display: grid;
  gap: var(--spacing-lg);
  grid-template-columns: 1fr 1fr;
  padding-block: var(--spacing-lg);
  padding-inline: max(var(--spacing-md), calc((100% - var(--container-boxed)) / 2 + var(--spacing-md)));
}

/* Colonna sinistra: Ingredienti */
.barra-bottom-heading {
  color: var(--color-category-title);
  font-family: var(--font-family-display);
  font-size: 1.75rem;
  font-weight: 400;
  margin: 0 0 1rem;
}

.barra-ingredienti-testo {
  font-size: 0.9375rem;
  line-height: 1.65;
  margin: 0 0 0.5rem;
}

.barra-ingredienti-nota {
  font-size: 0.8125rem;
  margin: 0;
  opacity: 0.65;
}

/* Colonna destra: tab nav */
.barra-tabs-nav {
  border-bottom: 1px solid color-mix(in srgb, var(--color-text) 15%, transparent);
  display: flex;
  gap: var(--spacing-md);
  margin-bottom: 1.5rem;
}

.barra-tab-btn {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--color-text);
  cursor: pointer;
  font-family: var(--font-family-sans);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  opacity: 0.45;
  padding: 0.75rem 0;
  position: relative;
  text-transform: uppercase;
  top: 1px;
  transition: opacity 0.15s;
}

.barra-tab-btn.is-active {
  border-bottom-color: var(--color-text);
  opacity: 1;
}

.barra-tab-btn:hover:not(.is-active) {
  opacity: 0.7;
}

/* Pannelli */
.barra-tab-panel {
  display: none;
}

.barra-tab-panel.is-active {
  display: block;
}

/* Scheda tecnica */
.barra-scheda-table {
  border-collapse: collapse;
  width: 100%;
}

.barra-scheda-table td {
  border-bottom: 1px solid color-mix(in srgb, var(--color-text) 10%, transparent);
  font-size: 0.9375rem;
  padding: 1rem 0;
  vertical-align: middle;
}

.barra-scheda-table td:first-child {
  color: var(--color-category-title);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  width: 35%;
}

/* Formati */
.barra-formati-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.barra-formati-list__item {
  align-items: baseline;
  border: 1.5px solid color-mix(in srgb, var(--color-text) 20%, transparent);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.75rem 1.25rem;
}

.barra-formati-list__item strong {
  font-size: 0.9375rem;
  font-weight: 600;
}

.barra-formati-list__item span {
  font-size: 0.8125rem;
  opacity: 0.65;
}

/* Valori nutrizionali */
.barra-nutrition-table {
  border-collapse: collapse;
  border: 1px solid color-mix(in srgb, var(--color-text) 15%, transparent);
  font-size: 0.875rem;
  max-width: 480px;
  width: 100%;
}

.barra-nutrition-table thead th {
  background-color: color-mix(in srgb, var(--color-text) 5%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--color-text) 15%, transparent);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.625rem 0.875rem;
  text-align: left;
  text-transform: uppercase;
}

.barra-nutrition-table thead th:last-child {
  text-align: right;
}

.barra-nutrition-table tbody td {
  border-bottom: 1px solid color-mix(in srgb, var(--color-text) 8%, transparent);
  padding: 0.5rem 0.875rem;
}

.barra-nutrition-table tbody td:last-child {
  text-align: right;
}

.barra-nutrition-table tbody tr:last-child td {
  border-bottom: none;
}

/* ── Mobile (≤ 767px) ──────────────────────────────────────────────────── */

@media (max-width: 767px) {

  /* Hero: impila verticalmente, padding ridotto */
  .barra-product-hero {
    flex-direction: column;
    gap: var(--spacing-md);
    padding-inline: var(--spacing-sm);
  }

  .barra-product-gallery {
    flex: 0 0 100%;
    max-width: 100%;
    overflow: hidden;
    /* clip peek slide successiva */
  }

  .barra-product-hero .summary.entry-summary {
    width: 100%;
  }

  /* Gallery mobile: peek tramite slidesPerView: 1.18 in JS */
  .barra-gallery-main {
    border-radius: var(--radius-md);
  }

  /* Thumbs nascoste su mobile, si naviga con swipe / frecce */
  .barra-gallery-thumbs {
    display: none;
  }

  .woocommerce div.product form.cart {
    flex-wrap: wrap;
  }

  .woocommerce div.product form.cart button.single_add_to_cart_button {
    flex: 1 0 100%;
  }

  .barra-product-features {
    flex-wrap: wrap;
  }

  .barra-product-feature {
    flex: 0 0 calc(33% - var(--spacing-md));
  }

  .barra-product-bottom {
    grid-template-columns: 1fr;
    padding: var(--spacing-md);
  }

  .barra-tabs-nav {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
}