/* ============================================================================
   PRIDO — Columna de compra del PDP (buy-box) · rediseño
   ----------------------------------------------------------------------------
   Capa de presentación SCOPEADA a `.prido-bb` (= la columna derecha
   `.prido-product-details`). Re-skin del diseño "Columna Producto PRIDO"
   mapeado sobre el markup vivo de producción:
     [prido_product_info] (.prido-pi-…), el form nativo de WooCommerce,
     [prido_product_actions] (.prido-actions / .prido-logistics / .prido-share),
     el cotizador (.prido-cotizar-…), la barra de modales (.prido-product-info-bar)
     y los acordeones inline (.prido-bb-acc).
   - NO reescribe el form de WooCommerce: los <select> de variación quedan
     ocultos pero funcionales; los chips los controlan vía JS (prido-buybox.js).
   - Tema por DOS señales: :root[data-theme="dark"] y body.woodmart-dark.
   - Carga después de css-maestro → gana empates; usa !important donde compite.
   ============================================================================ */

.prido-bb, .prido-bb *, .prido-bb *::before, .prido-bb *::after { box-sizing: border-box; }

/* ---------- TOKENS (light) ---------- */
.prido-bb {
  --bb-fh: 'Outfit', system-ui, sans-serif;
  --bb-fb: var(--prido-font-body, 'Noto Sans', system-ui, sans-serif);
  --bb-mono: 'JetBrains Mono', ui-monospace, monospace;
  --bb-teal: var(--prido-secondary, var(--prido-teal, #2dc6c1));
  --bb-teal-600: #20a9a4;
  --bb-ri: 12px; --bb-rc: 14px; --bb-rp: 999px;
  --bb-ease: cubic-bezier(.2, 0, .2, 1);

  --bb-ink:#0f1a26; --bb-ink-soft:#1a2a3a; --bb-muted:#5e6f80; --bb-faint:#8a9aae;
  --bb-line:#e4e9ef; --bb-line-soft:#eef1f5; --bb-line-strong:#cfd6df;
  --bb-page:#ffffff; --bb-surface:#ffffff; --bb-surface-2:#f6f8fb; --bb-surface-3:#eef2f6;
  --bb-info-bg:#e8f9f8; --bb-info-fg:#147068;       /* AA-safe sobre claro */
  --bb-success:#157a4d; --bb-success-bg:#e8f5ee;     /* AA-safe sobre success-bg/blanco */
  --bb-danger:#c0392f;
  --bb-quote:#b0561a; --bb-quote-600:#a4511a;        /* naranjo AA-safe (#fff ≥4.5:1) */
  --bb-shadow-sm:0 1px 2px rgba(15,26,38,.05);
  --bb-shadow-md:0 10px 30px -12px rgba(15,26,38,.16), 0 2px 6px rgba(15,26,38,.05);
}

/* ---------- TOKENS (dark) — dos señales ---------- */
:root[data-theme="dark"] .prido-bb,
body.woodmart-dark .prido-bb {
  --bb-ink:#ecf2f7; --bb-ink-soft:#d8e2ec; --bb-muted:#8d9eb2; --bb-faint:#6b7c91;
  --bb-line:rgba(255,255,255,.10); --bb-line-soft:rgba(255,255,255,.06); --bb-line-strong:rgba(255,255,255,.22);
  --bb-page:#101822; --bb-surface:#18222e; --bb-surface-2:#1d2835; --bb-surface-3:#243042;
  --bb-info-bg:rgba(45,198,193,.14); --bb-info-fg:#3fd6d0;
  --bb-success:#46c98b; --bb-success-bg:rgba(70,201,139,.14);
  --bb-danger:#ff6b66;
  --bb-quote:#e08a4f; --bb-quote-600:#eb9a63;
  --bb-shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --bb-shadow-md:0 14px 34px -14px rgba(0,0,0,.6), 0 2px 8px rgba(0,0,0,.4);
}

/* ============================================================================
   SHELL / RITMO VERTICAL
   ============================================================================ */
.prido-bb {
  font-family: var(--bb-fb);
  color: var(--bb-ink);
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
/* Aplanamos ambos wrappers (display:contents) para INTERCALAR sus hijos con
   `order` y lograr el orden del mockup: …form -> cotizar -> retiro -> badges.
   #prido-pi-container queda display:contents pero su DOM intacto -> el JS de
   precio/cuota (pridoInfoContainer.querySelector) sigue funcionando. */
.prido-bb .prido-pi-wrapper,
.prido-bb .prido-actions-wrapper { display: contents !important; }
.prido-bb .prido-pi-title { order: 1; }
.prido-bb .prido-pi-subtitle { order: 2; }
.prido-bb .prido-pi-meta-row { order: 3; }
.prido-bb .prido-pi-divider { order: 3; }
.prido-bb .prido-pi-pricing-block { order: 4; }
.prido-bb .prido-woo-native-form { order: 5; }
.prido-bb .prido-cotizar-wrap { order: 6; }       /* Cotizar: debajo del selector de cantidad */
.prido-bb .prido-logistics-glass { order: 7; }    /* Retiro pegado debajo del cotizar */
.prido-bb .prido-pi-financing-glass { order: 8; } /* Badges (3 cuotas / garantía / cert) debajo */
.prido-bb .prido-pi-warranty-glass { order: 9; }
.prido-bb .prido-pi-cert-glass { order: 10; }
.prido-bb .prido-share-section { order: 11; }
.prido-bb .prido-product-info-bar { order: 12; }
.prido-bb .prido-bb-acc { order: 13; }

/* ============================================================================
   HEADER
   ============================================================================ */
.prido-bb .prido-pi-title {
  font-family: var(--bb-fh) !important;
  font-size: 27px !important;
  font-weight: 700 !important;
  letter-spacing: -.025em !important;
  color: var(--bb-ink) !important;
  line-height: 1.12 !important;
  margin: 0 !important;
}
.prido-bb .prido-pi-subtitle {
  font-size: 13px !important;
  color: var(--bb-muted) !important;
  margin: -8px 0 0 !important;
  line-height: 1.5 !important;
}
.prido-bb .prido-pi-meta-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
}
.prido-bb .prido-pi-reviews-link {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 5px 11px !important;
  border-radius: var(--bb-rp) !important;
  background: var(--bb-surface-2) !important;
  border: 1px solid var(--bb-line) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--bb-ink-soft) !important;
  text-decoration: none !important;
  transition: border-color .16s var(--bb-ease), background .16s var(--bb-ease);
}
.prido-bb .prido-pi-reviews-link:hover { border-color: var(--bb-line-strong) !important; }
.prido-bb .prido-pi-star { display: inline-flex; align-items: center; gap: 4px; color: var(--bb-teal) !important; }
.prido-bb .prido-pi-star svg { width: 13px; height: 13px; }
.prido-bb .prido-pi-reviews-text { color: inherit !important; }
.prido-bb .prido-pi-sku {
  font-size: 12px !important;
  color: var(--bb-muted) !important;
  font-variant-numeric: tabular-nums;
}
.prido-bb .prido-pi-sku .sku {
  font-family: var(--bb-mono) !important;
  font-weight: 500;
  color: var(--bb-ink-soft) !important;
}
/* Pill de stock en la meta (lo añade el shortcode info) */
.prido-bb .prido-bb-stock {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--bb-rp);
  background: var(--bb-success-bg);
  color: var(--bb-success);
  font-size: 11.5px;
  font-weight: 700;
  line-height: 1.2;
}
.prido-bb .prido-bb-stock .d {
  width: 6px; height: 6px; border-radius: 999px; background: currentColor;
  box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 25%, transparent);
}
.prido-bb .prido-bb-stock.is-out { background: color-mix(in srgb, var(--bb-danger) 12%, transparent); color: var(--bb-danger); }
.prido-bb .prido-pi-divider { display: none !important; }

/* ============================================================================
   PRECIO
   ============================================================================ */
.prido-bb .prido-pi-pricing-block {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 4px !important;
  margin: 0 !important;
}
.prido-bb .prido-pi-prices { display: flex !important; flex-direction: column; gap: 2px; }
.prido-bb .prido-pi-price-reg-wrap { margin: 0 !important; }
.prido-bb #prido-pi-reg-val,
.prido-bb .prido-pi-price-reg-wrap del {
  font-size: 16px !important;
  color: var(--bb-faint) !important;
  text-decoration: line-through;
  font-weight: 500 !important;
}
.prido-bb .prido-pi-price-main-wrap {
  display: flex !important;
  align-items: center !important;   /* precio + badge de ahorro en la misma línea */
  gap: 12px !important;
  flex-wrap: wrap;
  margin: 0 !important;
}
.prido-bb #prido-pi-main-val {
  font-family: var(--bb-fh) !important;
  font-size: 40px !important;
  font-weight: 700 !important;
  letter-spacing: -.03em !important;
  color: var(--bb-ink) !important;
  line-height: 1 !important;
  font-variant-numeric: tabular-nums;
}
.prido-bb .prido-price-tax-note {
  display: block !important;
  margin: 2px 0 0 !important;
  font-size: 12.5px !important;
  color: var(--bb-muted) !important;
  font-weight: 400 !important;
}
.prido-bb .prido-pi-badge-ahorro {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  margin: 0 !important;
  padding: 4px 11px !important;
  border-radius: var(--bb-rp) !important;
  background: color-mix(in srgb, var(--bb-quote) 14%, transparent) !important;
  color: var(--bb-quote) !important;
  border: 0 !important;
  font-family: var(--bb-fh) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}
:root[data-theme="dark"] .prido-bb .prido-pi-badge-ahorro,
body.woodmart-dark .prido-bb .prido-pi-badge-ahorro { color: var(--bb-quote-600) !important; }
.prido-bb .prido-pi-badge-ahorro svg { width: 13px; height: 13px; }
/* Ocultar el badge cuando el descuento es 0% (sin oferta). Se hace por CLASE con
 * especificidad de ID porque el base `display:inline-flex !important` (y reglas de
 * css-maestro sobre .prido-onsale) pisan cualquier inline display:none del PHP.
 * PHP añade .prido-ahorro-empty en carga; prido-buybox.js la togglea por variación. */
.prido-bb #prido-pi-badge-ahorro.prido-ahorro-empty { display: none !important; }
/* Mensaje de stock nativo de WC bajo el precio ("Hay existencias"/"Agotado"):
 * redundante — el buy-box ya muestra la píldora .prido-bb-stock junto al SKU. */
.prido-bb p.stock,
.prido-bb .prido-woo-native-form > p.stock,
.prido-bb .woocommerce-variation-availability { display: none !important; }

/* ============================================================================
   FORM WC: VARIACIONES (chips sobre selects), CANTIDAD, AÑADIR
   ============================================================================ */
.prido-bb .prido-woo-native-form { margin: 0 !important; }
.prido-bb .prido-woo-native-form form.cart { margin: 0 !important; }
/* Form variable: apila variaciones + área de compra */
.prido-bb .prido-woo-native-form form.variations_form { display: flex; flex-direction: column; gap: 16px; }

/* --- Variaciones: tabla → bloques apilados --- */
.prido-bb table.variations { display: block !important; margin: 0 !important; border: 0 !important; }
.prido-bb table.variations tbody { display: block !important; }
.prido-bb table.variations tr {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;   /* anula el align-items:center que filtra el tr{display:grid} de css-maestro */
  gap: 9px !important;
  margin: 0 0 16px !important;
  border: 0 !important;
}
.prido-bb table.variations tr:last-child { margin-bottom: 0 !important; }
.prido-bb table.variations th.label { display: none !important; }   /* el chip-field trae su propia etiqueta */
.prido-bb table.variations td.value {
  display: block !important;
  width: 100% !important;
  position: relative;
  padding: 0 !important;
  border: 0 !important;
}
/* el <select> nativo queda funcional pero oculto (lo controlan los chips) */
.prido-bb table.variations td.value select {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important; clip: rect(0,0,0,0) !important;
  white-space: nowrap !important; border: 0 !important;
}

/* campo (label + chips) generado por el filtro PHP.
   Especificidad bajo td.value para ganar al `td.value>div{...!important}` de css-maestro. */
.prido-bb table.variations td.value .bb-field-head {
  display: flex !important; align-items: baseline !important; justify-content: space-between;
  gap: 8px; margin: 0 !important; padding: 0 !important;
}
.prido-bb .bb-field-label { font-size: 13px; font-weight: 700; color: var(--bb-ink-soft); }
.prido-bb .bb-field-label .bb-fv { color: var(--bb-muted); font-weight: 500; }
/* "Limpiar" por atributo (en cada .bb-field-head, alineado a la derecha por el
   space-between de la cabecera). Oculto salvo cuando el grupo tiene selección
   (.bb-head-dirty, togglada por prido-buybox.js). Reemplaza al reset global de WC. */
.prido-bb table.variations td.value .bb-clear-attr {
  flex: 0 0 auto; margin-left: auto; display: none;
  align-items: center; gap: 5px;
  font-family: var(--bb-fb); font-size: 12px; font-weight: 600;
  letter-spacing: 0; text-transform: none;   /* mockup: "Limpiar", no MAYÚSCULAS */
  color: var(--bb-muted); background: transparent; border: 0;
  padding: 5px 11px; border-radius: var(--bb-rp); line-height: 1.2;  /* píldora */
  cursor: pointer; transition: background .16s var(--bb-ease), color .16s var(--bb-ease);
}
.prido-bb table.variations td.value .bb-field-head.bb-head-dirty .bb-clear-attr { display: inline-flex; }
.prido-bb table.variations td.value .bb-clear-attr svg { width: 12px; height: 12px; flex-shrink: 0; }
.prido-bb table.variations td.value .bb-clear-attr:hover { background: var(--bb-surface-2); color: var(--bb-ink); }
.prido-bb table.variations td.value .bb-clear-attr:focus-visible { outline: 2px solid var(--bb-teal); outline-offset: 2px; }
.prido-bb table.variations td.value .bb-chips {
  display: flex !important; gap: 8px !important; flex-wrap: wrap !important;
  margin: 9px 0 0 !important; padding: 0 !important;
}
.prido-bb .bb-chip {
  display: inline-flex; align-items: center; gap: 8px;
  min-height: 44px; padding: 8px 15px;
  background: var(--bb-surface); border: 1.5px solid var(--bb-line);
  border-radius: var(--bb-ri); font-family: var(--bb-fb);
  font-size: 13.5px; font-weight: 600; color: var(--bb-ink);
  cursor: pointer; transition: all .16s var(--bb-ease);
}
.prido-bb .bb-chip:hover { border-color: var(--bb-line-strong); background: var(--bb-surface-2); }
.prido-bb .bb-chip.is-active {
  border-color: var(--bb-teal); background: var(--bb-info-bg); color: var(--bb-ink);
  box-shadow: 0 0 0 1px var(--bb-teal);
}
.prido-bb .bb-chip:focus-visible { outline: 2px solid var(--bb-teal); outline-offset: 2px; }
.prido-bb .bb-chip[aria-disabled="true"] { opacity: .4; cursor: not-allowed; text-decoration: line-through; }
.prido-bb .bb-swatch {
  width: 17px; height: 17px; border-radius: 50%;
  border: 1px solid var(--bb-line-strong); flex-shrink: 0;
  background-size: cover; background-position: center;
}
/* Ícono paleta "colores de madera" (mu-plugin prido-cubierta-palette.php): lo
   cuelga FUERA de .bb-chips → con td.value en block caía en su propia línea.
   Solo en el td que LO contiene, hacemos grid [chips | paleta] para que quede en
   la MISMA FILA que los chips (y como 3ª columna abajo si los chips hacen wrap).
   :has() acota el cambio a ese td; los demás grupos siguen en block. CSS-only. */
.prido-bb table.variations td.value:has(> .prido-cubierta-palette) {
  display: grid !important;
  grid-template-columns: 1fr auto;
  grid-template-areas: "head head" "chips palette";
  column-gap: 10px;
  align-items: end;
}
.prido-bb table.variations td.value:has(> .prido-cubierta-palette) .bb-field-head { grid-area: head; }
.prido-bb table.variations td.value:has(> .prido-cubierta-palette) .bb-chips { grid-area: chips; margin-top: 9px !important; }
.prido-bb table.variations td.value > .prido-cubierta-palette { grid-area: palette; align-self: end; margin: 0; }
/* Reestiliza la paleta para parear con los chips (44px, radio de chip) en vez del
   círculo de 38px del mu-plugin; !important para ganar a su <style> de wp_footer. */
.prido-bb .prido-cubierta-palette {
  width: 44px !important; height: 44px !important;
  border: 1.5px solid var(--bb-line) !important;
  border-radius: var(--bb-ri) !important;
  background: var(--bb-surface) !important;
}
.prido-bb .prido-cubierta-palette:hover {
  border-color: var(--bb-teal) !important;
  box-shadow: 0 0 0 1px var(--bb-teal) !important;
  transform: none !important;
}
/* "Limpiar" global nativo de WC (.reset_variations): OCULTO — lo reemplazan los
   botones "Limpiar" por atributo (.bb-clear-attr). display:none!important gana al
   `visibility:visible` inline de WC. NO se borra del DOM (WC lo usa internamente). */
.prido-bb table.variations td.value .reset_variations { display: none !important; }

/* --- single_variation (precio/disponibilidad WC) — el precio ya vive en el header --- */
.prido-bb .single_variation_wrap { margin: 0 !important; }
.prido-bb .single_variation .woocommerce-variation-price { display: none !important; }
.prido-bb .single_variation .woocommerce-variation-availability {
  margin: 0 0 12px !important; font-size: 13px !important; color: var(--bb-muted) !important;
}
.prido-bb .single_variation .woocommerce-variation-availability .stock.in-stock { color: var(--bb-success) !important; }
.prido-bb .single_variation .woocommerce-variation-availability .stock.out-of-stock { color: var(--bb-danger) !important; }

/* --- fila de compra: cantidad + añadir --- */
.prido-bb .woocommerce-variation-add-to-cart,
.prido-bb form.cart:not(.variations_form) {
  display: flex !important;
  align-items: stretch;
  gap: 10px !important;
  flex-wrap: wrap;
}
.prido-bb form.cart .quantity {
  display: inline-flex !important;
  align-items: center !important;
  height: 56px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: var(--bb-surface) !important;
  border: 1.5px solid var(--bb-line) !important;
  border-radius: var(--bb-ri) !important;
  overflow: hidden !important;
  flex: 0 0 auto;
}
/* Botones +/− del stepper: los inyecta js-maestro (.qty-btn), aquí solo se estilizan */
.prido-bb form.cart .quantity .qty-btn {
  width: 42px !important; min-width: 42px !important; height: 100% !important;
  padding: 0 !important; margin: 0 !important;
  background: transparent !important; border: 0 !important; box-shadow: none !important;
  color: var(--bb-ink-soft) !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  cursor: pointer; transition: background .16s var(--bb-ease);
  font-family: var(--bb-fh) !important; font-size: 18px !important; font-weight: 600 !important;
  line-height: 1 !important; border-radius: 0 !important;
}
.prido-bb form.cart .quantity .qty-btn:hover { background: var(--bb-surface-2) !important; color: var(--bb-ink) !important; }
.prido-bb form.cart .quantity input.qty {
  width: 44px !important; height: 100% !important; min-height: 0 !important;
  border: 0 !important; background: transparent !important; box-shadow: none !important;
  text-align: center !important;
  font-family: var(--bb-fh) !important; font-size: 16px !important; font-weight: 700 !important;
  color: var(--bb-ink) !important; outline: none;
  font-variant-numeric: tabular-nums;
  -moz-appearance: textfield; appearance: textfield;
}
.prido-bb form.cart .quantity input.qty::-webkit-outer-spin-button,
.prido-bb form.cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.prido-bb .single_add_to_cart_button {
  display: inline-flex !important;
  align-items: center; justify-content: center; gap: 10px;
  flex: 1 1 auto;
  min-width: 200px;
  height: 56px !important;
  padding: 0 22px !important;
  background: var(--bb-teal) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--bb-ri) !important;
  cursor: pointer;
  font-family: var(--bb-fh) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -.005em !important;
  text-transform: none !important;
  box-shadow: 0 8px 20px -6px color-mix(in srgb, var(--bb-teal) 55%, transparent) !important;
  transition: all .16s var(--bb-ease) !important;
}
.prido-bb .single_add_to_cart_button:hover { background: var(--bb-teal-600) !important; transform: translateY(-1px); }
.prido-bb .single_add_to_cart_button:disabled,
.prido-bb .single_add_to_cart_button.disabled,
.prido-bb .single_add_to_cart_button.wc-variation-selection-needed { opacity: .45 !important; cursor: not-allowed; box-shadow: none !important; transform: none !important; }
.prido-bb .single_add_to_cart_button svg { width: 19px; height: 19px; flex-shrink: 0; }
.prido-bb .single_add_to_cart_button > span { display: inline-flex; align-items: center; gap: 10px; }
.prido-bb .single_add_to_cart_button .prido-btn-text { font: inherit; color: inherit; }
/* DARK: css-maestro tiene un override (0,4,0)!important; lo superamos en especificidad */
:root[data-theme="dark"] .prido-bb .prido-woo-native-form .single_add_to_cart_button,
body.woodmart-dark .prido-bb .prido-woo-native-form .single_add_to_cart_button {
  background: var(--bb-teal) !important;
  color: #fff !important;
}
:root[data-theme="dark"] .prido-bb .prido-woo-native-form .single_add_to_cart_button:hover,
body.woodmart-dark .prido-bb .prido-woo-native-form .single_add_to_cart_button:hover {
  background: var(--bb-teal-600) !important;
}

/* ============================================================================
   COTIZAR
   ============================================================================ */
.prido-bb .prido-cotizar-wrap { position: relative; margin: 0 !important; }
.prido-bb .prido-cotizar-btn {
  display: inline-flex !important;
  align-items: center; justify-content: center; gap: 10px;
  width: 100%;
  height: 54px;
  padding: 0 22px;
  background: #c8631f !important;   /* naranjo del mockup (.bb-quote --quote) */
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--bb-ri) !important;
  cursor: pointer;
  font-family: var(--bb-fh) !important;
  font-size: 15px !important; font-weight: 700 !important;
  letter-spacing: .01em; text-transform: uppercase;
  box-shadow: 0 8px 20px -8px color-mix(in srgb, #c8631f 60%, transparent) !important;
  transition: all .16s var(--bb-ease);
}
.prido-bb .prido-cotizar-btn:hover { background: #ad5316 !important; transform: translateY(-1px); }
:root[data-theme="dark"] .prido-bb .prido-cotizar-btn,
body.woodmart-dark .prido-bb .prido-cotizar-btn { background: var(--bb-quote) !important; }
:root[data-theme="dark"] .prido-bb .prido-cotizar-btn:hover,
body.woodmart-dark .prido-bb .prido-cotizar-btn:hover { background: var(--bb-quote-600) !important; }
:root[data-theme="dark"] .prido-bb .prido-cotizar-btn,
body.woodmart-dark .prido-bb .prido-cotizar-btn { color: #1a1205 !important; }
.prido-bb .prido-cotizar-btn svg { width: 18px; height: 18px; }
.prido-bb .prido-cotizar-btn--disabled { opacity: .9 !important; cursor: default; }
.prido-bb .prido-cotizar-btn--disabled:hover { transform: none; background: var(--bb-quote) !important; }

/* ============================================================================
   RETIRO EN TIENDA
   ============================================================================ */
.prido-bb .prido-logistics-glass { margin: -6px 0 0 !important; background: transparent !important; border: 0 !important; padding: 0 !important; box-shadow: none !important; }
.prido-bb .prido-logistic-badge {
  display: flex !important;
  align-items: center; gap: 9px; justify-content: center;
  width: 100%;
  font-size: 16px !important; line-height: 1.3 !important; color: var(--bb-ink) !important;
  background: transparent !important; border: 0 !important; padding: 0 !important;
}
.prido-bb .prido-logistic-badge svg { width: 20px; height: 20px; color: var(--bb-teal) !important; flex-shrink: 0; }
:root[data-theme="dark"] .prido-bb .prido-logistic-badge svg,
body.woodmart-dark .prido-bb .prido-logistic-badge svg { color: var(--bb-teal) !important; }
.prido-bb .prido-logistic-badge strong { color: var(--bb-ink) !important; font-weight: 700 !important; }
.prido-bb .prido-logistic-badge small { color: var(--bb-muted) !important; font-size: inherit; font-weight: 400 !important; }

/* ============================================================================
   ASSURANCES (cuotas / garantía / certificación)
   ============================================================================ */
.prido-bb .prido-pi-financing-glass,
.prido-bb .prido-pi-warranty-glass {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 0 !important;
  padding: 14px 16px !important;
  background: var(--bb-surface-2) !important;
  border: 1px solid var(--bb-line) !important;
  border-radius: var(--bb-ri) !important;
  box-shadow: none !important;
}
.prido-bb .prido-pi-fin-icon,
.prido-bb .prido-pi-war-icon {
  width: 42px; height: 42px; flex-shrink: 0;
  border-radius: 11px;
  background: var(--bb-info-bg) !important;
  color: var(--bb-info-fg) !important;
  display: inline-flex !important; align-items: center; justify-content: center;
}
.prido-bb .prido-pi-fin-icon svg,
.prido-bb .prido-pi-war-icon svg { width: 22px; height: 22px; }
/* Estructura de 2 líneas: título (negrita, tinta) + subtítulo (tenue, normal) */
.prido-bb .prido-pi-fin-text,
.prido-bb .prido-pi-war-text {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: var(--bb-ink) !important;
  line-height: 1.3 !important;
}
.prido-bb .prido-pi-line-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--bb-ink) !important;
  line-height: 1.3 !important;
}
.prido-bb .prido-pi-line-sub {
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--bb-muted) !important;
  line-height: 1.3 !important;
}
/* Financiamiento: énfasis teal AA-safe (info-fg: #147068 light / #3fd6d0 dark) */
.prido-bb .prido-pi-fin-text .prido-pi-line-title strong { color: var(--bb-info-fg) !important; font-weight: 700 !important; }
/* Garantía/certificación: el título va en tinta oscura (no teal), como el mockup */
.prido-bb .prido-pi-war-text .prido-pi-line-title strong { color: var(--bb-ink) !important; font-weight: 700 !important; }
/* DARK: el fondo/borde del rediseño los pisa css-maestro (0,3,0)!important → subir especificidad */
:root[data-theme="dark"] .prido-bb .prido-pi-financing-glass,
:root[data-theme="dark"] .prido-bb .prido-pi-warranty-glass,
body.woodmart-dark .prido-bb .prido-pi-financing-glass,
body.woodmart-dark .prido-bb .prido-pi-warranty-glass {
  background: var(--bb-surface-2) !important;
  border-color: var(--bb-line) !important;
}

/* ============================================================================
   COMPARTIR
   ============================================================================ */
.prido-bb .prido-share-section {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 !important;
}
.prido-bb .prido-share-title {
  font-size: 11px !important; font-weight: 700 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important;
  color: var(--bb-muted) !important;
}
.prido-bb .prido-share-links { display: flex !important; gap: 6px !important; margin-left: auto !important; }
.prido-bb .prido-share-links a,
.prido-bb .prido-copy-link-btn {
  width: 34px; height: 34px;
  border-radius: 999px !important;
  background: var(--bb-surface-2) !important;
  border: 1px solid var(--bb-line) !important;
  color: var(--bb-ink-soft) !important;
  cursor: pointer;
  display: inline-flex !important; align-items: center; justify-content: center;
  transition: all .16s var(--bb-ease);
}
.prido-bb .prido-share-links a:hover,
.prido-bb .prido-copy-link-btn:hover { background: var(--bb-teal) !important; color: #fff !important; border-color: var(--bb-teal) !important; }
.prido-bb .prido-share-links a svg,
.prido-bb .prido-copy-link-btn svg { width: 15px; height: 15px; }

/* ============================================================================
   GRID DE MODALES (.prido-product-info-bar → tarjetas)
   ============================================================================ */
.prido-bb .prido-product-info-bar {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 18px 0 0 !important;
  border: 0 !important;
  border-top: 1px solid var(--bb-line-soft) !important;
}
.prido-bb .prido-info-bar-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px !important;
  padding: 13px !important;
  text-align: left !important;
  text-decoration: none !important;
  background: var(--bb-surface) !important;
  border: 1px solid var(--bb-line) !important;
  border-radius: var(--bb-ri) !important;
  font-family: var(--bb-fb) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--bb-ink-soft) !important;
  line-height: 1.25 !important;
  transition: all .16s var(--bb-ease) !important;
}
.prido-bb .prido-info-bar-item:hover { border-color: var(--bb-teal) !important; background: var(--bb-info-bg) !important; color: var(--bb-ink) !important; transform: translateY(-1px); }
.prido-bb .prido-info-bar-icon {
  width: 28px; height: 28px; flex-shrink: 0;
  border-radius: 8px;
  background: var(--bb-surface-2) !important;
  color: var(--bb-info-fg) !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  transition: background .16s;
}
.prido-bb .prido-info-bar-item:hover .prido-info-bar-icon { background: #fff !important; }
:root[data-theme="dark"] .prido-bb .prido-info-bar-item:hover .prido-info-bar-icon,
body.woodmart-dark .prido-bb .prido-info-bar-item:hover .prido-info-bar-icon { background: var(--bb-surface-3) !important; }
.prido-bb .prido-info-bar-icon svg { width: 15px !important; height: 15px !important; }
.prido-bb .prido-info-bar-label { font: inherit !important; color: inherit !important; }
/* DARK: css-maestro tiene `:root[data-theme=dark] .prido-info-bar-item` (0,3,0); subimos a (0,4,0) */
:root[data-theme="dark"] .prido-bb .prido-info-bar-item,
body.woodmart-dark .prido-bb .prido-info-bar-item {
  background: var(--bb-surface) !important;
  border-color: var(--bb-line) !important;
  color: var(--bb-ink-soft) !important;
}
:root[data-theme="dark"] .prido-bb .prido-info-bar-item:hover,
body.woodmart-dark .prido-bb .prido-info-bar-item:hover {
  background: var(--bb-info-bg) !important;
  border-color: var(--bb-teal) !important;
  color: var(--bb-ink) !important;
}
:root[data-theme="dark"] .prido-bb .prido-info-bar-icon,
body.woodmart-dark .prido-bb .prido-info-bar-icon {
  background: var(--bb-surface-2) !important;
  color: var(--bb-info-fg) !important;
}

/* ============================================================================
   ACORDEONES INLINE (.prido-bb-acc / <details>)
   ============================================================================ */
.prido-bb .prido-bb-acc { display: flex; flex-direction: column; margin: 4px 0 0; }
.prido-bb .bb-acc-item { border-top: 1px solid var(--bb-line); }
.prido-bb .bb-acc-item:last-child { border-bottom: 1px solid var(--bb-line); }
.prido-bb .bb-acc-bar {
  width: 100%; list-style: none;
  background: transparent; border: 0; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 4px; text-align: left;
  font-family: var(--bb-fh); font-size: 14.5px; font-weight: 700; color: var(--bb-ink);
}
.prido-bb .bb-acc-bar::-webkit-details-marker { display: none; }
.prido-bb .bb-acc-bar:focus-visible { outline: 2px solid var(--bb-teal); outline-offset: -2px; }
.prido-bb .bb-acc-bar .chev { color: var(--bb-muted); display: inline-flex; transition: transform .22s var(--bb-ease); flex-shrink: 0; }
.prido-bb .bb-acc-bar .chev svg { width: 17px; height: 17px; }
.prido-bb .bb-acc-item[open] .bb-acc-bar .chev { transform: rotate(180deg); }
.prido-bb .bb-acc-body { padding: 0 4px 18px; font-size: 13.5px; line-height: 1.6; color: var(--bb-muted); }
.prido-bb .bb-acc-body p { margin: 0 0 12px; color: var(--bb-muted); }
.prido-bb .bb-acc-body p:last-child { margin-bottom: 0; }
.prido-bb .bb-acc-body strong, .prido-bb .bb-acc-body b { color: var(--bb-ink-soft); font-weight: 600; }
.prido-bb .bb-acc-body a { color: var(--bb-info-fg); }
.prido-bb .bb-acc-body img { max-width: 100%; height: auto; border-radius: 10px; }
.prido-bb .prido-bb-medida { margin: 0 0 12px; padding: 0; }
.prido-bb .prido-bb-medida:last-child { margin-bottom: 0; }
.prido-bb .prido-bb-medida img { display: block; width: 100%; }
/* ---- DETALLES DEL PRODUCTO (descripción larga estructurada) → look mockup ---- */
/* Oculta el título de producto redundante y la etiqueta "DESCRIPCIÓN:" del contenido */
.prido-bb .bb-acc-body > h3,
.prido-bb .bb-acc-body .product-description > h3:first-child { display: none !important; }
.prido-bb .bb-acc-body .descripcion,
.prido-bb .bb-acc-body .descripcion + br { display: none !important; }
.prido-bb .bb-acc-body .product-description { font-size: 13.5px; line-height: 1.6; color: var(--bb-muted); }
.prido-bb .bb-acc-body .product-description > p { margin: 0 0 12px; }
.prido-bb .bb-acc-body .cuerpo { color: var(--bb-muted); }
.prido-bb .bb-acc-body .product-description strong:not(.section-title):not(.descripcion),
.prido-bb .bb-acc-body .product-description b { color: var(--bb-ink-soft); font-weight: 600; }
/* Encabezados de sección (Componentes:, Medidas:, Peso:…) */
.prido-bb .bb-acc-body .section-title {
  display: block; margin: 16px 0 6px;
  font-family: var(--bb-fh); font-size: 12.5px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase; color: var(--bb-ink-soft);
}
.prido-bb .bb-acc-body .product-description > p:first-child .section-title,
.prido-bb .bb-acc-body .product-description > p:first-of-type:has(.section-title) { margin-top: 0; }
.prido-bb .bb-acc-body p:has(> .section-title) { margin: 0; }
/* Listas de viñetas con marcador teal */
.prido-bb .bb-acc-body .product-list { list-style: none; margin: 0 0 4px; padding: 0; }
.prido-bb .bb-acc-body .product-list li {
  position: relative; padding: 2px 0 2px 18px;
  font-size: 13.5px; line-height: 1.55; color: var(--bb-muted);
}
.prido-bb .bb-acc-body .product-list li::before {
  content: ""; position: absolute; left: 2px; top: 10px;
  width: 5px; height: 5px; border-radius: 999px; background: var(--bb-teal);
}
/* Nota legal de-enfatizada */
.prido-bb .bb-acc-body .product-note {
  margin: 16px 0 0; padding-top: 12px; border-top: 1px solid var(--bb-line-soft);
  font-size: 12px; line-height: 1.5; color: var(--bb-faint); font-style: normal;
}

/* ---- INFORMACIÓN ADICIONAL (tabla de atributos WC) → grilla limpia mockup ---- */
.prido-bb .bb-acc-body table.shop_attributes { width: 100% !important; border: 0 !important; border-collapse: collapse !important; margin: 0 !important; }
.prido-bb .bb-acc-body table.shop_attributes tr,
.prido-bb .bb-acc-body table.shop_attributes tr:nth-child(even) td,
.prido-bb .bb-acc-body table.shop_attributes tr:nth-child(even) th,
.prido-bb .bb-acc-body table.shop_attributes tr:nth-child(odd) td,
.prido-bb .bb-acc-body table.shop_attributes tr:nth-child(odd) th { background: transparent !important; }
.prido-bb .bb-acc-body table.shop_attributes th,
.prido-bb .bb-acc-body table.shop_attributes td {
  text-align: left !important; padding: 5px 0 !important; border: 0 !important;
  font-size: 13.5px !important; line-height: 1.5 !important; vertical-align: top !important; font-style: normal !important;
}
.prido-bb .bb-acc-body table.shop_attributes th { color: var(--bb-muted) !important; font-weight: 500 !important; width: 40% !important; padding-right: 18px !important; white-space: nowrap; }
.prido-bb .bb-acc-body table.shop_attributes td { color: var(--bb-ink-soft) !important; font-weight: 600 !important; }
.prido-bb .bb-acc-body table.shop_attributes td p { margin: 0 !important; padding: 0 !important; font-style: normal !important; }

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
/* el grid de modales a 2 columnas en mobile/columna estrecha */
@media (max-width: 600px) {
  .prido-bb .prido-product-info-bar { grid-template-columns: 1fr 1fr !important; }
  .prido-bb .prido-pi-title { font-size: 24px !important; }
  .prido-bb #prido-pi-main-val { font-size: 34px !important; }
  .prido-bb .single_add_to_cart_button { min-width: 0; }
}
@media (max-width: 380px) {
  .prido-bb .woocommerce-variation-add-to-cart,
  .prido-bb form.cart:not(.variations_form) { gap: 8px !important; }
  .prido-bb .single_add_to_cart_button { flex-basis: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  .prido-bb .single_add_to_cart_button,
  .prido-bb .prido-cotizar-btn,
  .prido-bb .prido-info-bar-item,
  .prido-bb .bb-chip { transition: none !important; }
  .prido-bb .single_add_to_cart_button:hover,
  .prido-bb .prido-cotizar-btn:hover,
  .prido-bb .prido-info-bar-item:hover { transform: none !important; }
}

/* ============================================================================
   LAYOUT DESKTOP — ancho total y reparto de columnas (feedback 2026-06-16)
   Override de css-maestro (.prido-product-page 1320px / .prido-product-layout
   55%/45%). Se vive aquí (asset dedicado del PDP) para no re-hashear el monolito.
   1) ancho total +10%: 1320 → 1452px.
   2) +10 puntos a la galería, −10 a la columna derecha: 55/45 → 65/35.
   Solo ≥1025px (a ≤1024px el layout colapsa a 1 columna en el monolito).
   ============================================================================ */
@media (min-width: 1025px) {
  .prido-product-page { max-width: 1452px !important; }
  /* fr (no %) para que el gap se descuente antes del reparto y no haya overflow;
     minmax(0,…) evita blowout si un hijo trae min-content ancho. Ratio 65/35. */
  .prido-product-layout { grid-template-columns: minmax(0, 65fr) minmax(0, 35fr) !important; }
}
