/**
 * ComprasGuate Theme — Single product page styles.
 * Loaded only on single-product pages.
 */

/* =========================
   PRODUCT LAYOUT (gallery + info)
   ========================= */
.cg-product-page {
  margin-top: 16px;
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 22px;
}
.cg-product-detail {
  display: grid;
  grid-template-columns: minmax(0, 480px) minmax(0, 1fr);
  gap: 32px;
}
@media (max-width: 1024px) {
  .cg-product-detail { grid-template-columns: 1fr; }
}

/* Left column wrapper holds gallery + vendor card as a vertical stack. */
.cg-product-left {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* =========================
   PRODUCT GALLERY
   ========================= */
.cg-product-gallery .woocommerce-product-gallery {
  margin: 0 !important;
  width: 100% !important;
}
.cg-product-gallery .woocommerce-product-gallery__image {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--c-border);
  background: #fff;
}
/* Cap the main gallery image. WC outputs the placeholder SVG at its native
   600x600 (and real product images can be even larger), which made the
   gallery balloon to ~800px tall on staging products without proper crops. */
.cg-product-gallery .woocommerce-product-gallery__image > a,
.cg-product-gallery .woocommerce-product-gallery__image > img {
  display: block;
}
.cg-product-gallery .woocommerce-product-gallery__image img,
.cg-product-gallery .woocommerce-product-gallery__image .wp-post-image {
  width: 100% !important;
  height: 480px !important;
  max-height: 480px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #fff;
}
@media (max-width: 1024px) {
  .cg-product-gallery .woocommerce-product-gallery__image img,
  .cg-product-gallery .woocommerce-product-gallery__image .wp-post-image {
    height: 360px !important;
    max-height: 360px !important;
  }
}

/* Hide WCFM's "Ask a Question" button injection in the product summary —
   we surface inquiries differently in our design. The selector covers the
   common WCFM markup variations we've seen on staging. */
.cg-product-info .wcfm_inquiry_form_submit,
.cg-product-info .wcfm_enquiry_form_submit,
.cg-product-info a.wcfmmp_enquiry_btn,
.cg-product-info .wcfm-enquiry-button,
.cg-product-info .wcfmmp-enquiry,
.cg-product-info button[name="wcfm_inquiry_form_submit"] {
  display: none !important;
}

/* Hide WC's default product_meta block — we render our own
   .cg-product-meta-list with brand-aware styling. The default block prints
   "Category:" / "Tags:" labels in English regardless of locale and competes
   with our metadata block visually. */
.cg-product-info .product_meta {
  display: none !important;
}
.cg-product-gallery .flex-control-thumbs {
  margin-top: 10px !important;
  display: flex !important;
  gap: 8px;
  flex-wrap: wrap;
}
.cg-product-gallery .flex-control-thumbs li {
  width: 64px !important;
  height: 64px !important;
  list-style: none;
  margin: 0;
}
.cg-product-gallery .flex-control-thumbs img {
  width: 64px;
  height: 64px;
  border-radius: var(--radius);
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color 0.15s;
  object-fit: cover;
}
.cg-product-gallery .flex-control-thumbs img.flex-active,
.cg-product-gallery .flex-control-thumbs img:hover {
  border-color: var(--c-blue);
}

/* =========================
   PRODUCT INFO (right column)
   ========================= */
.cg-product-info-tag {
  display: inline-block;
  background: #FEF3C7;
  color: var(--c-promo-text);
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  margin-bottom: 8px;
}
.cg-product-info-title {
  font-size: 26px;
  font-weight: 800;
  color: var(--c-text);
  margin: 0 0 10px;
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.cg-product-info-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--c-text-muted);
  margin-bottom: 18px;
}
.cg-product-info-meta .stars { color: #FBBF24; font-size: 14px; }
.cg-product-info-meta a { color: var(--c-blue); }

/* Price block */
.cg-product-price-block {
  background: #F9FAFB;
  border-radius: var(--radius);
  padding: 14px 16px;
  margin-bottom: 16px;
}
.cg-product-price-block .price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 10px;
}
.cg-product-price-block .price .woocommerce-Price-amount,
.cg-product-price-block .price ins,
.cg-product-price-block .price > .amount {
  font-size: 32px;
  font-weight: 800;
  color: var(--c-text);
  text-decoration: none;
}
.cg-product-price-block .price ins .woocommerce-Price-amount {
  color: var(--c-sale);
}
.cg-product-price-block .price del,
.cg-product-price-block .price del .woocommerce-Price-amount {
  font-size: 14px;
  font-weight: 500;
  color: var(--c-text-muted);
  text-decoration: line-through;
}
.cg-product-installments {
  font-size: 12.5px;
  color: var(--c-text-muted);
  margin-top: 6px;
}

/* Shipping block */
.cg-shipping-block {
  background: var(--c-trust-bg);
  border: 1px solid #A7F3D0;
  border-radius: var(--radius);
  padding: 12px 14px;
  margin-bottom: 18px;
}
.cg-shipping-block-title {
  font-size: 13px;
  font-weight: 700;
  color: #065F46;
}
.cg-shipping-block-desc {
  font-size: 12.5px;
  color: #047857;
  margin: 2px 0 0;
}

/* Add to cart form */
.cg-product-info form.cart {
  margin: 0 0 18px !important;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.cg-product-info form.cart .quantity {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--c-border);
  border-radius: 4px;
  overflow: hidden;
}
.cg-product-info form.cart .quantity input.qty {
  width: 56px;
  padding: 10px 6px;
  border: 0;
  font-size: 14px;
  font-family: inherit;
  text-align: center;
  background: #fff;
}
.cg-product-info form.cart .single_add_to_cart_button {
  flex: 1;
  min-width: 200px;
  padding: 12px 24px;
  background: var(--c-promo);
  color: var(--c-promo-text);
  border: 0;
  border-radius: 4px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cg-product-info form.cart .single_add_to_cart_button:hover {
  filter: brightness(0.96);
}

/* Variations table (color/size swatches) */
.cg-product-info .variations {
  margin-bottom: 14px !important;
}
.cg-product-info .variations th,
.cg-product-info .variations td {
  padding: 8px 6px !important;
  vertical-align: middle !important;
  border: 0 !important;
}
.cg-product-info .variations label {
  font-size: 13px;
  font-weight: 700;
  color: var(--c-text);
}
.cg-product-info .variations select {
  padding: 8px 10px;
  border: 1px solid var(--c-border);
  border-radius: 4px;
  font-size: 13.5px;
  font-family: inherit;
  background: #fff;
  min-width: 200px;
}

/* Share row */
.cg-share-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--c-text-muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 14px 0;
  border-top: 1px solid var(--c-border);
  margin-top: 14px;
}
.cg-share-icons {
  display: flex;
  gap: 12px;
  align-items: center;
}
.cg-share-icon {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform 0.15s;
}
.cg-share-icon:hover { transform: translateY(-2px); }
.cg-share-icon svg { width: 100%; height: 100%; }

/* Product metadata list (SKU, Categoría, Etiquetas) */
.cg-product-meta-list {
  font-size: 12.5px;
  color: var(--c-text-muted);
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--c-border);
}
.cg-product-meta-row {
  display: flex;
  gap: 8px;
  padding: 4px 0;
}
.cg-product-meta-row .meta-label {
  min-width: 90px;
  color: var(--c-text-muted);
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.cg-product-meta-row .meta-value { color: var(--c-text); }
.cg-product-meta-row .meta-value a { color: var(--c-blue); }

/* =========================
   VENDOR CARD (below gallery)
   ========================= */
.cg-vendor-card {
  margin-top: 14px;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 16px;
  background: var(--c-card);
}
.cg-vendor-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.cg-vendor-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-blue);
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  flex-shrink: 0;
}
.cg-vendor-name {
  font-size: 15px;
  font-weight: 800;
  margin: 0 0 2px;
  color: var(--c-text);
}
.cg-vendor-tagline {
  font-size: 12px;
  color: var(--c-text-muted);
}
.cg-vendor-badges {
  display: flex;
  gap: 6px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.cg-vendor-badge {
  background: #ECFDF5;
  color: #065F46;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: 700;
}
.cg-vendor-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}
.cg-vendor-actions a {
  flex: 1;
  text-align: center;
  padding: 8px 12px;
  border-radius: 4px;
  font-size: 12.5px;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid var(--c-border);
  color: var(--c-blue);
  background: #fff;
  transition: background 0.12s;
}
.cg-vendor-actions a:hover { background: var(--c-blue); color: #fff; border-color: var(--c-blue); }
.cg-vendor-actions a.primary { background: var(--c-blue); color: #fff; border-color: var(--c-blue); }
.cg-vendor-actions a.primary:hover { background: var(--c-blue-dark); border-color: var(--c-blue-dark); }

/* =========================
   PRODUCT TABS (Description / Specs / Shipping / Reviews)
   ========================= */
.cg-product-tabs {
  margin-top: 22px;
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.woocommerce-tabs ul.tabs {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  border-bottom: 1px solid var(--c-border) !important;
  background: #FAFBFC;
  flex-wrap: wrap;
}
.woocommerce-tabs ul.tabs::before,
.woocommerce-tabs ul.tabs::after { display: none !important; }
.woocommerce-tabs ul.tabs li {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 14px 22px !important;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--c-text-muted) !important;
  text-decoration: none;
  text-transform: none !important;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
}
.woocommerce-tabs ul.tabs li a:hover {
  color: var(--c-blue) !important;
}
.woocommerce-tabs ul.tabs li.active a {
  color: var(--c-blue) !important;
  border-bottom-color: var(--c-blue);
  background: #fff;
}
.woocommerce-tabs .panel,
.woocommerce-tabs .wc-tab {
  padding: 22px 26px !important;
  font-size: 14px;
  line-height: 1.65;
  color: var(--c-text);
}
.woocommerce-tabs h2 {
  font-size: 18px;
  font-weight: 800;
  color: var(--c-text);
  margin: 0 0 12px;
}

/* WC reviews list */
.woocommerce-Reviews .commentlist {
  list-style: none;
  margin: 0;
  padding: 0;
}
.woocommerce-Reviews .commentlist li {
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin-bottom: 10px;
}

/* =========================
   RELATED PRODUCTS
   We override WC's default single-product/related.php template with our
   own structure (woocommerce/single-product/related.php), so we no longer
   need to fight WC's .related.products wrapper or its flex/grid styles.
   Our markup:
       <section class="cg-related-section">
           <h2 class="cg-related-heading">Productos relacionados</h2>
           <ul class="cg-related-grid products">
               <li class="product">...</li>
           </ul>
       </section>
   ========================= */
.cg-related-products {
  margin-top: 22px;
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 22px;
}
/* Force every wrapper between .cg-related-products and .cg-related-grid
   to be a plain block. We removed the <section> tag because some upstream
   CSS (probably the WP block editor's section rules) was making it a grid
   container and pushing the heading into row 1 col 1. We also dropped the
   "products" class from the <ul> so WC's .woocommerce ul.products rules
   can't match. */
.cg-related-section {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cg-related-heading {
  font-size: 17px !important;
  font-weight: 800 !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  color: var(--c-text) !important;
  display: block !important;
  width: 100% !important;
}
.cg-related-grid-wrap {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cg-related-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 12px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: both !important;
  width: 100% !important;
}
@media (max-width: 1024px) { .cg-related-grid { grid-template-columns: repeat(3, 1fr) !important; } }
@media (max-width: 700px)  { .cg-related-grid { grid-template-columns: repeat(2, 1fr) !important; } }

/* Direct children of the grid (each is an <a class="cg-product-card"> from
   our content-product.php template). Override any list defaults. */
.cg-related-grid > * {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
  width: auto !important;
  max-width: 100% !important;
}

/* Cap image height inside related-grid cards. home.css uses aspect-ratio:1
   which would make each image ~440px tall in a 4-col layout. */
.cg-related-grid .cg-product-image {
  aspect-ratio: auto !important;
  height: 220px !important;
}
.cg-related-grid .cg-product-card {
  padding: 10px !important;
}

/* Backwards-compat selectors (kept so old WC default markup still styles
   correctly if our template override doesn't load for some reason). */
.cg-related-products .related.products {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cg-related-products .related.products > h2 {
  font-size: 17px !important;
  font-weight: 800 !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  color: var(--c-text) !important;
  display: block !important;
  width: 100% !important;
  grid-column: 1 / -1 !important;
}
.cg-related-products ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 12px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: both !important;
}
@media (max-width: 1024px) { .cg-related-products ul.products { grid-template-columns: repeat(3, 1fr) !important; } }
@media (max-width: 700px)  { .cg-related-products ul.products { grid-template-columns: repeat(2, 1fr) !important; } }

/* Reduce card image size inside the related-products grid. Without this,
   home.css's aspect-ratio:1 on .cg-product-image makes each image ~440px
   tall in a 4-col layout, pushing each card to ~520px. Cap the image at
   220px so the related grid stays compact. */
.cg-related-products ul.products li.product .cg-product-image {
  aspect-ratio: auto !important;
  height: 220px !important;
}
.cg-related-products ul.products li.product .cg-product-card {
  padding: 10px !important;
}
.cg-related-products ul.products li.product {
  margin: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  float: none !important;
  clear: none !important;
  list-style: none !important;
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex !important;
  flex-direction: column !important;
  position: relative;
}
.cg-related-products ul.products li.product > a {
  display: block;
  text-decoration: none;
  color: var(--c-text);
  padding: 0;
}
.cg-related-products ul.products li.product > a:hover { text-decoration: none; }

/* Constrain related-product images. WC outputs the placeholder SVG at its
   native size (often 600+ px square) which is what blew out the layout. */
.cg-related-products ul.products li.product img,
.cg-related-products ul.products li.product .attachment-woocommerce_thumbnail,
.cg-related-products ul.products li.product .wp-post-image {
  width: 100% !important;
  height: 200px !important;
  max-height: 200px !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  background: #fff;
  margin: 0 !important;
}
.cg-related-products ul.products li.product .woocommerce-loop-product__title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--c-text) !important;
  padding: 10px 12px 4px !important;
  margin: 0 !important;
  line-height: 1.35 !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 40px;
}
.cg-related-products ul.products li.product .price {
  padding: 0 12px 10px !important;
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  color: var(--c-text) !important;
}
.cg-related-products ul.products li.product .price del {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--c-text-muted) !important;
}
.cg-related-products ul.products li.product .button,
.cg-related-products ul.products li.product .added_to_cart {
  margin: 0 12px 12px !important;
  padding: 8px 12px !important;
  background: var(--c-promo) !important;
  color: var(--c-promo-text) !important;
  border: 0 !important;
  border-radius: 4px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  text-align: center;
  display: block;
}

/* WC default badges to match our product card style */
.cg-product-detail span.onsale,
.cg-related-products span.onsale {
  background: var(--c-sale) !important;
  color: #fff !important;
  border-radius: 3px !important;
  padding: 3px 8px !important;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em !important;
  min-height: auto !important;
  line-height: 1.2 !important;
}

/* =============================================================================
   v1.2.6 — PRODUCT PAGE v2: 3-column layout matching the demo
   ============================================================================= */

.cg-product-page-v2 {
  max-width: 1320px;
  margin: 20px auto;
  padding: 0 16px;
}

.cg-product-3col {
  display: grid;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr) minmax(0, 320px);
  gap: 24px;
  align-items: start;
}

.cg-product-col {
  min-width: 0;
}

/* ---------- LEFT: gallery wrap + vendor card + más de esta tienda ---------- */

.cg-gallery-wrap {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  border: 1px solid #E5E7EB;
}

.cg-gallery-sale-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  background: #DC2626;
  color: #fff;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.cg-gallery-wrap .woocommerce-product-gallery {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

.cg-vendor-card-full {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 18px;
  margin-top: 16px;
}

.cg-vendor-card-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.cg-vendor-card-avatar {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, #1e73be, #0F4C81);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 800;
  flex-shrink: 0;
}

.cg-vendor-card-meta {
  flex: 1;
  min-width: 0;
}

.cg-vendor-card-name {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: #1D2327;
}

.cg-vendor-card-tagline {
  font-size: 12px;
  color: #6B7280;
  margin-top: 2px;
  line-height: 1.4;
}

.cg-vendor-card-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.cg-vendor-card-badge {
  background: #DCFCE7;
  color: #166534;
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 999px;
}

.cg-vendor-card-badge--top {
  background: #FEF3C7;
  color: #92400E;
}

.cg-vendor-card-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 14px;
  padding: 12px;
  background: #F9FAFB;
  border-radius: 10px;
}

.cg-vendor-card-stat {
  text-align: center;
}

.cg-vendor-card-stat-num {
  font-size: 14px;
  font-weight: 800;
  color: #1e73be;
  line-height: 1.1;
}

.cg-vendor-card-stat-label {
  font-size: 10px;
  color: #6B7280;
  margin-top: 3px;
  line-height: 1.3;
}

.cg-vendor-card-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cg-vendor-card-btn {
  display: block;
  text-align: center;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid #E5E7EB;
  color: #1F2937;
  background: #fff;
  transition: all 0.15s;
}

.cg-vendor-card-btn:hover {
  background: #F9FAFB;
  text-decoration: none;
}

.cg-vendor-card-btn--primary {
  background: linear-gradient(135deg, #1e73be, #155490);
  color: #fff;
  border-color: #1e73be;
}

.cg-vendor-card-btn--primary:hover {
  background: linear-gradient(135deg, #155490, #0F4C81);
  color: #fff;
}

/* Más productos de este vendedor — 4-up grid */
.cg-more-from-vendor {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 16px;
  margin-top: 16px;
}

.cg-more-from-vendor-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
}

.cg-more-from-vendor-head h3 {
  font-size: 14px;
  font-weight: 700;
  color: #1D2327;
  margin: 0;
}

.cg-more-from-vendor-head a {
  font-size: 11.5px;
  color: #1e73be;
  font-weight: 600;
  text-decoration: none;
}

.cg-more-from-vendor-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.cg-mfv-item {
  text-decoration: none;
  color: inherit;
}

.cg-mfv-img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 8px;
  background: #F3F4F6;
  display: block;
}

.cg-mfv-name {
  font-size: 11.5px;
  margin: 6px 0 2px;
  color: #1F2937;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cg-mfv-price {
  font-size: 12.5px;
  font-weight: 800;
  color: #1e73be;
  margin: 0;
}

/* ---------- CENTER: info column ---------- */

.cg-product-col-info {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 24px;
}

.cg-product-tag {
  display: inline-block;
  background: #DCFCE7;
  color: #166534;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 8px;
}

.cg-product-title {
  font-size: 24px;
  font-weight: 700;
  color: #1D2327;
  line-height: 1.25;
  margin: 0 0 8px;
}

.cg-product-rating-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #4B5563;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.cg-product-rating-row .cg-stars {
  color: #F59E0B;
  letter-spacing: 1px;
}

.cg-product-rating-row a {
  color: #1e73be;
  text-decoration: none;
  font-weight: 500;
}

/* Price block */
.cg-price-block {
  margin-bottom: 14px;
}

.cg-price-old {
  font-size: 14px;
  color: #9CA3AF;
  text-decoration: line-through;
  margin-bottom: 2px;
}

.cg-price-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}

.cg-price-current {
  font-size: 30px;
  font-weight: 800;
  color: #1D2327;
  line-height: 1;
}

.cg-price-current .woocommerce-Price-amount {
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
}

.cg-price-discount {
  background: #FEE2E2;
  color: #991B1B;
  font-size: 11px;
  font-weight: 800;
  padding: 3px 9px;
  border-radius: 999px;
  letter-spacing: 0.04em;
}

.cg-price-cuotas {
  font-size: 12.5px;
  color: #6B7280;
  margin-top: 6px;
}

/* Urgency countdown */
.cg-urgency-countdown {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #FEF2F2;
  border: 1px solid #FCA5A5;
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 14px;
  flex-wrap: wrap;
  font-size: 13px;
}

.cg-urg-icon {
  font-size: 18px;
}

.cg-urg-text {
  color: #7F1D1D;
  font-weight: 500;
}

.cg-urg-text strong {
  color: #991B1B;
  font-weight: 800;
}

.cg-urg-clock {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  margin-left: auto;
  font-family: 'SF Mono', Menlo, Consolas, monospace;
}

.cg-urg-num {
  background: #991B1B;
  color: #fff;
  padding: 4px 6px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 800;
  min-width: 24px;
  text-align: center;
}

.cg-urg-tag {
  font-size: 11px;
  color: #991B1B;
  font-weight: 700;
  margin-left: 2px;
}

.cg-urg-sep {
  color: #991B1B;
  font-weight: 800;
  margin: 0 2px;
}

/* Social proof strip */
.cg-social-proof {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: #FFFBEB;
  border-left: 3px solid #F59E0B;
  border-radius: 0 8px 8px 0;
  padding: 10px 14px;
  margin-bottom: 12px;
}

.cg-sp-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: #92400E;
}

.cg-sp-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #16A34A;
  border-radius: 50%;
  flex-shrink: 0;
  animation: cgPulse 1.5s ease-in-out infinite;
}

@keyframes cgPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(0.9); }
}

.cg-sp-fire {
  font-size: 14px;
  flex-shrink: 0;
}

/* Last purchase ticker */
.cg-last-purchase {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #EFF6FF;
  border-left: 3px solid #1e73be;
  border-radius: 0 8px 8px 0;
  padding: 8px 14px;
  margin-bottom: 14px;
  font-size: 12px;
  color: #1e3a8a;
}

.cg-lp-icon {
  font-size: 14px;
}

/* Short description */
.cg-product-short-desc {
  background: #F9FAFB;
  border-left: 3px solid #1e73be;
  padding: 12px 16px;
  border-radius: 0 8px 8px 0;
  font-size: 13.5px;
  line-height: 1.6;
  color: #374151;
  margin-bottom: 14px;
}

.cg-product-short-desc p:last-child {
  margin-bottom: 0;
}

/* Shipping block */
.cg-shipping-block {
  background: #F0FDF4;
  border: 1px solid #BBF7D0;
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 14px;
}

.cg-shipping-block-title {
  font-size: 13px;
  font-weight: 700;
  color: #166534;
  margin-bottom: 2px;
}

.cg-shipping-block-desc {
  font-size: 11.5px;
  color: #15803D;
}

/* Cart form (variations + add-to-cart) */
.cg-product-cart-form {
  margin: 14px 0;
}

.cg-product-cart-form .variations {
  width: 100%;
}

.cg-product-cart-form .variations th,
.cg-product-cart-form .variations td {
  padding: 8px 0;
  vertical-align: middle;
}

.cg-product-cart-form .variations th {
  font-size: 13px;
  font-weight: 600;
  color: #374151;
  text-align: left;
  padding-right: 12px;
}

.cg-product-cart-form .variations select {
  padding: 9px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 8px;
  font-size: 13px;
  min-width: 180px;
}

.cg-product-cart-form .cart {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.cg-product-cart-form .quantity {
  display: inline-flex;
  align-items: center;
  border: 1px solid #D1D5DB;
  border-radius: 8px;
  overflow: hidden;
}

.cg-product-cart-form .quantity input {
  border: 0;
  width: 60px;
  padding: 10px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
}

.cg-product-cart-form .single_add_to_cart_button {
  background: linear-gradient(135deg, #FBBF24, #F59E0B) !important;
  color: #7C2D12 !important;
  border: 0 !important;
  padding: 12px 28px !important;
  border-radius: 10px !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  cursor: pointer;
  flex: 1;
  min-width: 200px;
  transition: all 0.15s;
}

.cg-product-cart-form .single_add_to_cart_button:hover {
  background: linear-gradient(135deg, #F59E0B, #D97706) !important;
  transform: translateY(-1px);
}

/* Low-stock urgency bar */
.cg-low-stock-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #FEF2F2;
  border: 1px solid #FCA5A5;
  border-radius: 8px;
  padding: 10px 14px;
  margin-top: 10px;
  font-size: 12.5px;
  color: #7F1D1D;
  font-weight: 600;
}

.cg-low-stock-icon { font-size: 16px; }

.cg-low-stock-meter {
  flex: 1;
  height: 6px;
  background: #FCA5A5;
  border-radius: 999px;
  overflow: hidden;
  min-width: 60px;
}

.cg-low-stock-meter-fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, #DC2626, #F59E0B);
  border-radius: 999px;
}

/* Share row */
.cg-share-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 0;
  border-top: 1px solid #F3F4F6;
  margin-top: 16px;
  flex-wrap: wrap;
}

.cg-share-label {
  font-size: 11px;
  font-weight: 700;
  color: #6B7280;
  letter-spacing: 0.06em;
}

.cg-share-icons {
  display: flex;
  gap: 8px;
}

.cg-share-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  transition: transform 0.15s;
}

.cg-share-icon svg {
  width: 22px;
  height: 22px;
}

.cg-share-icon:hover {
  transform: scale(1.1);
}

.cg-share-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid #E5E7EB;
  border-radius: 50%;
  font-size: 14px;
  color: #6B7280;
  cursor: pointer;
}

.cg-share-action:hover {
  background: #F9FAFB;
}

/* Meta list */
.cg-product-meta-list {
  border-top: 1px solid #F3F4F6;
  padding-top: 14px;
  margin-top: 8px;
}

.cg-product-meta-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  padding: 8px 0;
  font-size: 13px;
}

.cg-meta-label {
  font-size: 11px;
  font-weight: 700;
  color: #6B7280;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.cg-meta-value,
.cg-meta-value a {
  color: #1e73be;
  text-decoration: none;
  font-weight: 500;
}

.cg-meta-value a:hover { text-decoration: underline; }

/* ---------- RIGHT: sticky sidebar ---------- */

.cg-sidebar-sticky {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cg-buy-box {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cg-buy-btn {
  display: block;
  text-align: center;
  padding: 12px 18px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 13.5px;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  transition: all 0.15s;
}

.cg-buy-btn--primary {
  background: linear-gradient(135deg, #1e73be, #155490);
  color: #fff;
}

.cg-buy-btn--primary:hover {
  background: linear-gradient(135deg, #155490, #0F4C81);
  color: #fff;
  transform: translateY(-1px);
}

.cg-buy-btn--yellow {
  background: linear-gradient(135deg, #FBBF24, #F59E0B);
  color: #7C2D12;
}

.cg-buy-btn--yellow:hover {
  background: linear-gradient(135deg, #F59E0B, #D97706);
  color: #7C2D12;
}

.cg-buy-btn--ghost {
  background: #fff;
  color: #1e73be;
  border: 2px solid #1e73be;
}

.cg-buy-btn--ghost:hover {
  background: #EFF6FF;
}

/* Trust list */
.cg-trust-list {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 14px;
  margin: 0;
  list-style: none;
}

.cg-trust-list li {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid #F3F4F6;
}

.cg-trust-list li:last-child { border-bottom: 0; }

.cg-trust-icon {
  font-size: 22px;
  flex-shrink: 0;
}

.cg-trust-text {
  display: flex;
  flex-direction: column;
  font-size: 12px;
  line-height: 1.4;
}

.cg-trust-text strong {
  color: #1D2327;
  font-weight: 700;
}

.cg-trust-text span {
  color: #6B7280;
}

/* Sidebar promo card */
.cg-sidebar-ad {
  display: block;
  background: linear-gradient(135deg, #1F2937, #0F172A);
  color: #fff;
  border-radius: 14px;
  padding: 18px;
  text-align: center;
  text-decoration: none;
  transition: transform 0.15s;
}

.cg-sidebar-ad:hover {
  transform: translateY(-2px);
  color: #fff;
}

.cg-sidebar-ad-tag {
  font-size: 10.5px;
  letter-spacing: 0.08em;
  color: #FBBF24;
  font-weight: 700;
  margin-bottom: 4px;
}

.cg-sidebar-ad-percent {
  font-size: 36px;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
}

.cg-sidebar-ad-text {
  font-size: 13px;
  color: #D1D5DB;
  margin-bottom: 10px;
}

.cg-sidebar-ad-btn {
  display: inline-block;
  background: #FBBF24;
  color: #7C2D12;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
}

/* Sidebar más productos */
.cg-sidebar-more {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 14px;
}

.cg-sidebar-more-head {
  border-bottom: 2px solid #1e73be;
  padding-bottom: 8px;
  margin-bottom: 10px;
}

.cg-sidebar-more-head h3 {
  font-size: 12px;
  font-weight: 800;
  color: #1D2327;
  letter-spacing: 0.06em;
  margin: 0;
}

.cg-sidebar-more-item {
  display: flex;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid #F3F4F6;
  text-decoration: none;
  color: inherit;
}

.cg-sidebar-more-item:last-child { border-bottom: 0; }

.cg-sidebar-more-img {
  width: 56px;
  height: 56px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
  background: #F3F4F6;
}

.cg-sidebar-more-info { flex: 1; min-width: 0; }

.cg-sidebar-more-name {
  font-size: 12px;
  margin: 0 0 2px;
  color: #1F2937;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cg-sidebar-more-rating {
  color: #F59E0B;
  font-size: 10px;
  letter-spacing: 1px;
}

.cg-sidebar-more-price {
  font-size: 13px;
  font-weight: 800;
  color: #1e73be;
  margin-top: 2px;
}

/* ---------- TABS UPGRADE ---------- */

.cg-product-page-v2 ~ .cg-product-tabs,
.cg-product-tabs {
  max-width: 1320px;
  margin: 24px auto;
  padding: 0 16px;
}

.cg-product-tabs .woocommerce-tabs {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  overflow: hidden;
}

.cg-product-tabs ul.tabs {
  display: flex;
  list-style: none;
  margin: 0 !important;
  padding: 0 16px !important;
  background: #fff;
  border-bottom: 1px solid #E5E7EB;
  overflow-x: auto;
  flex-wrap: nowrap;
}

.cg-product-tabs ul.tabs::before,
.cg-product-tabs ul.tabs::after { display: none !important; }

.cg-product-tabs ul.tabs li {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  flex-shrink: 0;
}

.cg-product-tabs ul.tabs li::before,
.cg-product-tabs ul.tabs li::after { display: none !important; }

.cg-product-tabs ul.tabs li a {
  display: block;
  padding: 14px 20px !important;
  font-size: 13.5px;
  font-weight: 600;
  color: #6B7280;
  text-decoration: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -1px;
}

.cg-product-tabs ul.tabs li.active a,
.cg-product-tabs ul.tabs li a:hover {
  color: #1e73be;
  border-bottom-color: #1e73be;
}

.cg-product-tabs .woocommerce-Tabs-panel {
  padding: 24px;
  font-size: 14px;
  line-height: 1.65;
  color: #374151;
}

.cg-product-tabs .woocommerce-Tabs-panel h2 {
  font-size: 18px;
  font-weight: 700;
  color: #1D2327;
  margin: 0 0 14px;
}

.cg-tab-section { margin-bottom: 22px; }
.cg-tab-section:last-child { margin-bottom: 0; }

.cg-tab-section h3 {
  font-size: 15px;
  font-weight: 700;
  color: #1D2327;
  margin: 0 0 8px;
}

.cg-tab-list {
  list-style: none;
  margin: 8px 0;
  padding: 0;
}

.cg-tab-list li {
  padding: 4px 0;
  font-size: 13px;
  color: #4B5563;
}

.cg-tab-empty {
  text-align: center;
  padding: 30px;
  color: #6B7280;
}

.cg-tab-cta {
  display: inline-block;
  padding: 10px 20px;
  background: #1e73be;
  color: #fff;
  border-radius: 8px;
  font-weight: 600;
  text-decoration: none;
}

.cg-specs-table {
  width: 100%;
  border-collapse: collapse;
}

.cg-specs-table th,
.cg-specs-table td {
  padding: 10px 14px;
  border-bottom: 1px solid #F3F4F6;
  text-align: left;
  font-size: 13px;
}

.cg-specs-table th {
  background: #F9FAFB;
  font-weight: 600;
  color: #6B7280;
  width: 35%;
}

.cg-specs-table td { color: #1F2937; }

/* ---------- STICKY MOBILE ADD-TO-CART BAR ---------- */

.cg-mobile-sticky-buy {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 999;
  background: #fff;
  border-top: 1px solid #E5E7EB;
  padding: 10px 14px;
  box-shadow: 0 -4px 16px rgba(0,0,0,0.08);
  align-items: center;
  gap: 10px;
}

.cg-mobile-sticky-buy-info { flex: 1; min-width: 0; }
.cg-mobile-sticky-buy-name {
  font-size: 11.5px;
  font-weight: 600;
  color: #1F2937;
  margin: 0;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cg-mobile-sticky-buy-price {
  font-size: 14px;
  font-weight: 800;
  color: #1e73be;
  margin-top: 2px;
}
.cg-mobile-sticky-buy-btn {
  background: linear-gradient(135deg, #FBBF24, #F59E0B);
  color: #7C2D12;
  border: 0;
  padding: 10px 18px;
  border-radius: 8px;
  font-weight: 800;
  font-size: 12.5px;
  white-space: nowrap;
}

/* ---------- MOBILE RESPONSIVE ---------- */

@media (max-width: 1100px) {
  .cg-product-3col {
    grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  }
  .cg-product-col-sidebar {
    grid-column: 1 / -1;
  }
  .cg-sidebar-sticky {
    position: static;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }
}

@media (max-width: 768px) {
  .cg-product-3col {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .cg-product-col-info { padding: 18px; }
  .cg-product-title { font-size: 20px; }
  .cg-price-current { font-size: 24px; }
  .cg-urgency-countdown { font-size: 12px; padding: 8px 12px; }
  .cg-urg-clock { margin-left: 0; width: 100%; justify-content: flex-start; }
  .cg-vendor-card-stats { gap: 4px; padding: 10px; }
  .cg-vendor-card-stat-num { font-size: 12px; }
  .cg-vendor-card-stat-label { font-size: 9px; }
  .cg-product-meta-row { grid-template-columns: 90px 1fr; }
  .cg-mobile-sticky-buy { display: flex; }
  .cg-product-page-v2 { padding-bottom: 80px; }
}
