/* ===================================================
   CHIRINO CUSTOM — WooCommerce Styles
   =================================================== */

/* ---- General resets for WC ---- */
.woocommerce,
.woocommerce-page {
  color: var(--color-text);
}

.woocommerce a { color: var(--color-primary); }
.woocommerce a:hover { color: var(--color-primary-h); }

/* Los botones .btn no deben heredar el color de enlace de WC
   (si no, el texto teal queda invisible sobre el fondo teal) */
.woocommerce a.btn-primary,
.woocommerce a.btn-primary:hover { color: #fff; }
.woocommerce a.btn-accent,
.woocommerce a.btn-accent:hover  { color: #000; }
.woocommerce a.btn-outline       { color: var(--color-heading); }

/* ---- Notices ---- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  background: var(--color-surface) !important;
  border-top-color: var(--color-primary) !important;
  color: var(--color-text) !important;
  border-radius: 0 var(--radius) var(--radius) 0;
}
.woocommerce-error { border-top-color: #e74c3c !important; }
.woocommerce-info  { border-top-color: var(--color-accent) !important; }

/* ---- Breadcrumb ---- */
.woocommerce .woocommerce-breadcrumb {
  color: var(--color-muted);
  font-size: 0.85rem;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--color-muted); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--color-primary); }

/* ---- Shop Archive ---- */
.shop-header {
  padding: calc(var(--header-h) + 3rem) 0 3rem;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-shop-filters {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-result-count {
  color: var(--color-muted);
  font-size: 0.9rem;
  margin: 0;
}

.woocommerce-ordering select {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  border-radius: var(--radius);
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  cursor: pointer;
  outline: none;
  transition: border-color var(--transition);
}
.woocommerce-ordering select:hover,
.woocommerce-ordering select:focus {
  border-color: var(--color-primary);
}

/* WC products loop */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce ul.products li.product {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition);
  margin: 0;
  float: none;
}
.woocommerce ul.products li.product:hover {
  border-color: var(--color-primary);
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}

.woocommerce ul.products li.product a img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  transition: transform 0.4s ease;
  margin: 0;
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.08); }

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  padding: 1rem 1.25rem 0.25rem;
  margin: 0;
}

.woocommerce ul.products li.product .price {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  color: var(--color-primary);
  padding: 0 1.25rem;
  display: block;
}
.woocommerce ul.products li.product .price del {
  color: var(--color-muted);
  font-size: 1rem;
  margin-right: 0.3rem;
}

.woocommerce ul.products li.product .button {
  display: block;
  margin: 0.75rem 1.25rem 1.25rem;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: var(--radius);
  padding: 0.65rem 1rem;
  font-family: var(--font-heading);
  font-size: 1rem;
  letter-spacing: 0.05em;
  cursor: pointer;
  text-align: center;
  transition: all var(--transition);
}
.woocommerce ul.products li.product .button:hover {
  background: var(--color-primary-h);
  transform: translateY(-1px);
}

/* Sale badge */
.woocommerce span.onsale {
  background: var(--color-accent) !important;
  color: #000 !important;
  font-family: var(--font-heading);
  font-size: 0.9rem;
  border-radius: 4px;
  min-height: auto;
  min-width: auto;
  line-height: 1;
  padding: 4px 10px;
  top: 0.75rem;
  left: 0.75rem;
}

/* ---- Single Product ---- */
.single-product-layout {
  display: grid;
  grid-template-columns: 3fr 2fr; /* fr descuenta el gap, %= lo ignora y desborda */
  gap: 3rem;
  padding: 3rem 0;
}

/* Prevent grid children from overflowing their column.
   Los items de grid tienen min-width:auto por defecto, así que NO se
   achican por debajo de su contenido (los tabs con flex-wrap:nowrap
   suman ~413px de min-content y desbordan el viewport en mobile). */
.product-gallery { min-width: 0; overflow: hidden; }
.product-info    { min-width: 0; }
.single-product-layout > .woocommerce-tabs {
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}
/* Los tabs internos pueden scrollear horizontalmente si no entran */
.single-product-layout .wc-tabs-wrapper,
.single-product-layout .woocommerce-Tabs-panel { min-width: 0; max-width: 100%; }

/* ---- Carrusel de producto ---- */
.product-carousel { position: relative; }

.pc-viewport {
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 1/1;
}

.pc-track {
  display: flex;
  height: 100%;
  transition: transform 0.4s cubic-bezier(.2, .8, .2, 1);
  will-change: transform;
}

.pc-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
}
.pc-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  box-sizing: border-box;
}

/* Flechas */
.pc-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10, 10, 10, 0.55);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 50%;
  cursor: pointer;
  z-index: 2;
  padding: 0;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  transition: background var(--transition), opacity var(--transition);
}
.pc-arrow:hover { background: var(--color-primary); }
.pc-arrow svg { width: 22px; height: 22px; }
.pc-prev { left: 0.75rem; }
.pc-next { right: 0.75rem; }

/* Miniaturas en carrusel horizontal */
.pc-thumbs {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  padding-bottom: 4px;
}
.pc-thumbs::-webkit-scrollbar { height: 6px; }
.pc-thumbs::-webkit-scrollbar-thumb {
  background: var(--color-border);
  border-radius: 3px;
}
.pc-thumb {
  flex: 0 0 72px;
  width: 72px;
  display: block;
  padding: 0;
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 1;
  cursor: pointer;
  scroll-snap-align: start;
  transition: border-color var(--transition);
}
.pc-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pc-thumb:hover { border-color: var(--color-primary); }
.pc-thumb.active { border-color: var(--color-primary); }

/* Producto con una sola imagen: sin flechas ni miniaturas */
.product-carousel.is-single .pc-arrow,
.product-carousel.is-single .pc-thumbs { display: none; }

/* Product info */
.product-info .product-category-badge { margin-bottom: 1rem; }

.product-info .product_title {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  color: var(--color-heading);
  margin-bottom: 1rem;
}

.product-info .woocommerce-product-rating {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.product-info .price {
  font-family: var(--font-heading);
  font-size: 2.2rem;
  color: var(--color-primary);
  margin-bottom: 1.25rem;
  display: block;
}
.product-info .price del { color: var(--color-muted); font-size: 1.5rem; margin-right: 0.5rem; }
.product-info .price ins { text-decoration: none; }

.product-info .woocommerce-product-details__short-description {
  color: var(--color-muted);
  font-size: 0.95rem;
  line-height: 1.7;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 1.5rem;
}

/* Quantity */
.product-info .quantity input[type="number"] {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  border-radius: var(--radius);
  padding: 0.65rem 1rem;
  font-size: 1rem;
  width: 80px;
  text-align: center;
  outline: none;
  transition: border-color var(--transition);
}
.product-info .quantity input[type="number"]:focus { border-color: var(--color-primary); }

/* Add to cart button */
.product-info .single_add_to_cart_button,
.product-info button[name="add-to-cart"] {
  background: var(--color-primary) !important;
  color: #fff !important;
  border: 2px solid var(--color-primary) !important;
  border-radius: var(--radius) !important;
  padding: 0.85rem 2rem !important;
  font-family: var(--font-heading) !important;
  font-size: 1.15rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  height: auto !important;
  line-height: 1 !important;
}
.product-info .single_add_to_cart_button:hover,
.product-info button[name="add-to-cart"]:hover {
  background: var(--color-primary-h) !important;
  border-color: var(--color-primary-h) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(42,138,138,0.4) !important;
}

.product-info .cart {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}

/* Trust badges */
.product-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 1.25rem;
  background: rgba(42,138,138,0.05);
  border: 1px solid rgba(42,138,138,0.2);
  border-radius: var(--radius-lg);
  margin-top: 1.5rem;
}
.trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.4rem;
}
.trust-item svg   { width: 28px; height: 28px; color: var(--color-primary); }
.trust-item span  { font-size: 0.75rem; color: var(--color-muted); font-weight: 500; }

/* Tabs */
.woocommerce-tabs {
  margin-top: 2.5rem;
  grid-column: 1 / -1;
}

.woocommerce-tabs ul.tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--color-border);
  padding: 0;
  list-style: none;
  margin: 0 0 2rem;
}
.woocommerce-tabs ul.tabs li {
  margin: 0;
  padding: 0;
}
.woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 0.85rem 1.5rem;
  color: var(--color-muted);
  font-weight: 500;
  font-size: 0.95rem;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--transition);
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}
.woocommerce-tabs ul.tabs::before,
.woocommerce-tabs ul.tabs::after { display: none; }
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce-tabs .panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  color: var(--color-text);
}
.woocommerce-tabs .panel h2 { display: none; }

/* Related products */
.related.products { margin-top: 4rem; }
.related.products > h2 {
  font-family: var(--font-heading);
  font-size: 2rem;
  color: var(--color-heading);
  margin-bottom: 1.5rem;
}

/* ---- Cart ---- */
.woocommerce-cart table.cart {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border-collapse: collapse;
  width: 100%;
}
.woocommerce-cart table.cart th {
  background: var(--color-bg);
  color: var(--color-muted);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--color-border);
}
.woocommerce-cart table.cart td {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  vertical-align: middle;
}
.woocommerce-cart table.cart td a { color: var(--color-text); }
.woocommerce-cart table.cart td.product-price,
.woocommerce-cart table.cart td.product-subtotal {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  color: var(--color-primary);
}

.cart_totals {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
}
.cart_totals h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  color: var(--color-heading);
  margin-bottom: 1.5rem;
}
.cart_totals table { width: 100%; }
.cart_totals th { color: var(--color-muted); font-size: 0.85rem; text-transform: uppercase; padding: 0.5rem 0; }
.cart_totals td { color: var(--color-text); text-align: right; font-family: var(--font-heading); font-size: 1.1rem; }
.cart_totals .order-total td { color: var(--color-primary); font-size: 1.5rem; }

.wc-proceed-to-checkout .checkout-button {
  width: 100%;
  margin-top: 1rem;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: var(--radius);
  padding: 1rem;
  font-family: var(--font-heading);
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--transition);
  text-align: center;
  display: block;
}
.wc-proceed-to-checkout .checkout-button:hover {
  background: var(--color-primary-h);
}

/* ---- Checkout ---- */
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout h3 {
  font-family: var(--font-heading);
  color: var(--color-heading);
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.woocommerce-checkout .form-row label {
  color: var(--color-muted);
  font-size: 0.875rem;
  margin-bottom: 0.4rem;
  display: block;
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  border-radius: var(--radius);
  padding: 0.75rem 1rem;
  width: 100%;
  font-size: 0.95rem;
  transition: border-color var(--transition);
  outline: none;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus { border-color: var(--color-primary); }

#place_order {
  background: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  padding: 1rem 2rem !important;
  font-family: var(--font-heading) !important;
  font-size: 1.2rem !important;
  letter-spacing: 0.08em !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  width: 100%;
}
#place_order:hover { background: var(--color-primary-h) !important; }

/* ---- Reviews / Stars ---- */
.star-rating { color: var(--color-accent); }
.woocommerce p.stars a { color: var(--color-accent); }

/* =====================================================
   RESPONSIVE — Single Product
   ===================================================== */

/* Tablet grande: galería encima, info abajo */
@media (max-width: 1024px) {
  .woocommerce ul.products   { grid-template-columns: repeat(3, 1fr); }

  .single-product-layout {
    grid-template-columns: 1fr;
    gap: 1.75rem;
    padding: 1.75rem 0;
  }

  /* Galería acotada al centro en tablet */
  .product-gallery {
    max-width: 560px;
    margin: 0 auto;
    width: 100%;
  }

  /* Sticky no tiene sentido en 1 col */
  .product-gallery { position: static; }
}

/* Móvil */
@media (max-width: 768px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }

  /* Layout */
  .single-product-layout {
    gap: 1.25rem;
    padding: 1rem 0 2rem;
  }

  /* Galería full width */
  .product-gallery { max-width: 100%; }

  /* Título */
  .product-info .product_title {
    font-size: clamp(1.6rem, 6vw, 2rem);
    margin-bottom: 0.6rem;
  }

  /* Precio */
  .product-info .price {
    font-size: 1.8rem;
    margin-bottom: 0.75rem;
  }

  /* Descripción corta */
  .product-info .woocommerce-product-details__short-description {
    font-size: 0.9rem;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
  }

  /* Carrito: cantidad + botón en columna */
  .product-info .cart {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .product-info .quantity {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

  .product-info .quantity input[type="number"] {
    width: 80px;
  }

  /* Botón full width */
  .product-info .single_add_to_cart_button,
  .product-info button[name="add-to-cart"] {
    width: 100% !important;
    justify-content: center !important;
    padding: 1rem 1.5rem !important;
    font-size: 1rem !important;
  }

  /* Trust badges: 3 en una fila, más compactos */
  .product-trust {
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    padding: 0.85rem 0.75rem;
  }

  .trust-item svg  { width: 22px; height: 22px; }
  .trust-item span { font-size: 0.65rem; }

  /* Tabs: scroll horizontal si no entran */
  .woocommerce-tabs ul.tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
  .woocommerce-tabs ul.tabs li a {
    white-space: nowrap;
    padding: 0.7rem 1rem;
    font-size: 0.85rem;
  }

  /* Breadcrumb */
  .breadcrumb {
    font-size: 0.78rem;
    flex-wrap: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* Móvil chico */
@media (max-width: 480px) {
  .woocommerce ul.products { grid-template-columns: 1fr; }

  /* Carrusel en mobile: flechas más chicas y miniaturas un poco más grandes */
  .pc-arrow { width: 34px; height: 34px; }
  .pc-arrow svg { width: 18px; height: 18px; }
  .pc-prev { left: 0.5rem; }
  .pc-next { right: 0.5rem; }
  .pc-thumb { flex: 0 0 60px; width: 60px; }

  /* Título */
  .product-info .product_title { font-size: 1.5rem; }

  /* Precio */
  .product-info .price { font-size: 1.6rem; }

  /* Trust badges: sigue 3 en fila pero más mini */
  .product-trust { padding: 0.75rem 0.5rem; gap: 0.25rem; }
  .trust-item svg  { width: 20px; height: 20px; }
  .trust-item span { font-size: 0.6rem; }

  /* Tabs: scroll */
  .woocommerce-tabs ul.tabs li a { padding: 0.65rem 0.85rem; font-size: 0.8rem; }

  /* Medios de pago: ajustar texto */
  .ctda-fila-label    { font-size: 13px; }
  .ctda-fila-icono    { font-size: 16px; width: 22px; }
  .ctda-precio-destacado .woocommerce-Price-amount,
  .ctda-precio-destacado bdi { font-size: 17px !important; }
  .ctda-fila-cuotas .ctda-fila-precio .woocommerce-Price-amount,
  .ctda-fila-cuotas .ctda-fila-precio bdi { font-size: 17px !important; }
}

/* ===================================================
   BLOCK CHECKOUT (WooCommerce 8+)
   =================================================== */

/* Contenedor principal */
.wp-block-woocommerce-checkout.wc-block-checkout {
  padding: 2rem 0 4rem;
}

/* ---- Inputs y campos ---- */
.wc-block-components-text-input input,
.wc-block-components-text-input input:focus,
.wc-block-components-textarea textarea,
.wc-block-components-select select {
  background-color: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: var(--radius) !important;
  box-shadow: none !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
}
.wc-block-components-text-input input:focus,
.wc-block-components-textarea textarea:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(42,138,138,0.15) !important;
}
.wc-block-components-text-input label,
.wc-block-components-textarea label,
.wc-block-components-select label {
  color: var(--color-muted) !important;
  font-size: 0.85rem !important;
  background: var(--color-surface) !important;
}
/* Select dropdown — wc-block-components (singular) */
.wc-block-components-select,
.wc-block-components-select .wc-block-components-select__container {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  box-shadow: none !important;
}
.wc-block-components-select select {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: none !important;
  box-shadow: none !important;
}
/* Select dropdown — wc-blocks-components (plural, country/state) */
.wc-blocks-components-select__container {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  box-shadow: none !important;
}
.wc-blocks-components-select__container:focus-within {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px rgba(42,138,138,0.15) !important;
}
.wc-blocks-components-select__select {
  background: transparent !important;
  color: var(--color-text) !important;
  border: none !important;
  box-shadow: none !important;
}
/* Combobox (país, provincia) */
.components-combobox-control__suggestions-container,
.components-form-token-field__suggestions-list {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
}
.components-form-token-field__suggestion {
  color: var(--color-text) !important;
}
.components-form-token-field__suggestion:hover,
.components-form-token-field__suggestion.is-selected {
  background: var(--color-primary) !important;
  color: #fff !important;
}

/* ---- Secciones / pasos ---- */
.wc-block-components-checkout-step {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.25rem !important;
}
.wc-block-components-checkout-step__title {
  color: var(--color-heading) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.9rem !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
}
/* Número de paso */
.wc-block-components-checkout-step__heading-content {
  color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

/* ---- Sidebar: resumen del carrito (prominente) ---- */
.wp-block-woocommerce-checkout-totals-block {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 1.5rem !important;
}
/* Título "Resumen del pedido" */
.wc-block-components-order-summary__button,
.wc-block-order-summary-totals-block h2,
.wp-block-woocommerce-checkout-order-summary-block h2 {
  color: var(--color-heading) !important;
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}
/* ─────────────────────────────────────────────────────────────────
   ORDER SUMMARY ITEM — Block Checkout sidebar
   Minimal CSS: dejamos que WC Blocks maneje el layout interno
   (mismo que usa en el Cart Block, que ya se ve bien) y solo
   aplicamos theming visual del tema oscuro.
   ───────────────────────────────────────────────────────────────── */

.wc-block-components-order-summary-item {
  padding: 0.85rem 0 !important;
  border-bottom: 1px solid var(--color-border) !important;
  gap: 0.85rem !important;
}

/* Theming visual de la imagen (sin tocar dimensiones) */
.wc-block-components-order-summary-item__image {
  border-radius: var(--radius) !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-bg, #0a0a0a) !important;
  overflow: hidden !important;
}

/* Ocultar el badge de cantidad de WC Blocks — usamos el "× N" inline
   al lado del nombre en su lugar (más legible y consistente con cart) */
.wc-block-components-order-summary-item__quantity {
  display: none !important;
}

/* "× N" inline al lado del nombre del producto (inyectado por JS) */
.chirino-qty-inline {
  display: inline-block;
  margin-left: .4rem;
  padding: 2px 8px;
  background: rgba(42, 138, 138, .18);
  color: var(--color-primary) !important;
  border-radius: 999px;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: .85rem;
  letter-spacing: .03em;
  vertical-align: middle;
  white-space: nowrap;
}
/* Nombre */
.wc-block-components-order-summary-item__name {
  color: var(--color-text) !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
}
/* Precio unitario */
.wc-block-components-order-summary-item__individual-amount {
  color: var(--color-muted) !important;
  font-size: 0.8rem !important;
}
/* Precio total del ítem */
.wc-block-components-order-summary-item__total-price {
  color: var(--color-primary) !important;
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
}
/* Filas de totales */
.wc-block-components-totals-item {
  border-color: var(--color-border) !important;
  color: var(--color-text) !important;
}
.wc-block-components-totals-item__label { color: var(--color-muted) !important; }
.wc-block-components-totals-item__value {
  color: var(--color-text) !important;
  font-family: var(--font-heading) !important;
}
/* Total final */
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  color: var(--color-heading) !important;
  font-family: var(--font-heading) !important;
  font-size: 1.05rem !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  color: var(--color-primary) !important;
  font-family: var(--font-heading) !important;
  font-size: 1.4rem !important;
}

/* Cupón */
.wc-block-components-totals-coupon__content input {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: var(--radius) !important;
}
.wc-block-components-totals-coupon__content input:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
}
.wc-block-components-button.wc-block-components-totals-coupon__button {
  background: transparent !important;
  border: 1px solid var(--color-primary) !important;
  color: var(--color-primary) !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.05em !important;
}
.wc-block-components-button.wc-block-components-totals-coupon__button:hover {
  background: var(--color-primary) !important;
  color: #fff !important;
}

/* ---- Botón Realizar pedido ---- */
.wc-block-components-checkout-place-order-button {
  background: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-heading) !important;
  font-size: 1.1rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 1rem 2rem !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  box-shadow: 0 4px 15px rgba(42,138,138,0.3) !important;
  margin-top: 1rem !important;
}
.wc-block-components-checkout-place-order-button:hover {
  background: var(--color-primary-h) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(42,138,138,0.45) !important;
}

/* ---- Volver al carrito ---- */
.wc-block-components-checkout-return-to-cart-button {
  color: var(--color-muted) !important;
  font-size: 0.875rem !important;
  transition: color var(--transition) !important;
  text-decoration: none !important;
}
.wc-block-components-checkout-return-to-cart-button:hover {
  color: var(--color-primary) !important;
}

/* ---- Avisos / errores ---- */
.wc-block-components-notice--error {
  background: rgba(231,76,60,0.08) !important;
  border-left-color: #e74c3c !important;
  color: var(--color-text) !important;
  border-radius: var(--radius) !important;
}
.wc-block-components-notice--info,
.wc-block-checkout__contact-fields .wc-block-components-notice {
  background: rgba(42,138,138,0.08) !important;
  border-left-color: var(--color-primary) !important;
  border-radius: var(--radius) !important;
  color: var(--color-muted) !important;
  font-size: 0.875rem !important;
}

/* Checkbox */
.wc-block-components-checkbox input[type="checkbox"] {
  accent-color: var(--color-primary);
}
.wc-block-components-checkbox .wc-block-components-checkbox__label {
  color: var(--color-muted) !important;
  font-size: 0.875rem !important;
}

/* Términos y condiciones */
.wc-block-checkout__terms {
  color: var(--color-muted) !important;
  font-size: 0.85rem !important;
}
.wc-block-checkout__terms a { color: var(--color-primary) !important; }

/* ---- Responsive block checkout ---- */
@media (max-width: 768px) {
  .wp-block-woocommerce-checkout.wc-block-checkout {
    padding: 1.5rem 0 3rem;
  }
}

/* ============================================================
   CARRITO + CHECKOUT INTEGRADO
   Página /carro/ con Cart Block arriba y checkout clásico abajo
   ============================================================ */

/* Ocultar botón "Pasar al pago" del Cart Block (el checkout ya está abajo) */
.woocommerce-cart .wc-block-cart__submit-container,
.woocommerce-cart .wc-block-components-checkout-return-to-cart-button {
  display: none !important;
}

/* Ocultar cupón del carrito — solo se usa en el checkout */
.woocommerce-cart .wc-block-components-totals-coupon,
.woocommerce-cart .wp-block-woocommerce-cart-order-summary-coupon-form-block,
.woocommerce-cart .coupon {
  display: none !important;
}

/* Ocultar aviso "Se agregó X. Ver carrito" en la página del carrito
   (es redundante porque el carrito ya está visible arriba) */
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .chirino-inline-checkout .woocommerce-message {
  display: none !important;
}

/* Ocultar el link "Ver carrito" que WooCommerce mete debajo del botón
   "Agregar al carrito" en los archivos de tienda y la home.
   Ya tenemos nuestro propio toast/drawer que muestra eso. */
.woocommerce a.added_to_cart,
.woocommerce-loop-product__link + a.added_to_cart,
li.product a.added_to_cart,
.added_to_cart.wc-forward {
  display: none !important;
}

/* También: cuando WC marca un botón como "agregado" (cambia el texto a
   "Ver carrito"), forzarlo a mantener el estilo original */
.woocommerce a.button.added::after,
.woocommerce button.added::after {
  display: none !important;
}

/* Wrapper del checkout inline */
.chirino-inline-checkout {
  margin-top: 6rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--color-border);
}

.chirino-inline-checkout-header {
  margin-bottom: 2rem;
}
.chirino-inline-checkout-header h2 {
  font-family: var(--font-heading);
  color: var(--color-heading);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  margin: 0 0 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ---- Layout 2 columnas (≥ 900px) ---- */
.chirino-inline-checkout .woocommerce,
.chirino-inline-checkout .woocommerce form.woocommerce-checkout {
  width: 100% !important;
  float: none !important;
}

@media (min-width: 900px) {
  /* Grid base (sin JS) — estructura original de 3 hijos */
  .chirino-inline-checkout form.woocommerce-checkout {
    display: grid !important;
    grid-template-columns: 1fr 400px !important;
    grid-template-areas:
      "billing heading"
      "billing review" !important;
    gap: 0 2rem !important;
    align-items: start !important;
  }

  .chirino-inline-checkout #customer_details {
    grid-area: billing !important;
    width: auto !important;
    float: none !important;
  }

  .chirino-inline-checkout #order_review_heading {
    grid-area: heading !important;
    width: auto !important;
    float: none !important;
    align-self: end !important;
    margin-top: 0 !important;
    padding-bottom: 0.6rem !important;
    border-bottom: 1px solid var(--color-border) !important;
  }

  .chirino-inline-checkout #order_review {
    grid-area: review !important;
    width: auto !important;
    float: none !important;
    position: sticky !important;
    top: calc(var(--header-h, 5rem) + 1.5rem) !important;
  }

  /* ---- Grid mejorado cuando JS envuelve heading + review ---- */
  /* JS añade .chirino-sidebar-ready al form y crea #chirino-order-sidebar */
  .chirino-inline-checkout form.chirino-sidebar-ready {
    grid-template-columns: 1fr 400px !important;
    grid-template-areas: "billing sidebar" !important;
    grid-template-rows: auto !important;
  }

  /* El #order_review pierde su sticky propio; lo hereda del wrapper */
  .chirino-inline-checkout form.chirino-sidebar-ready #order_review {
    position: static !important;
    grid-area: unset !important;
  }
  .chirino-inline-checkout form.chirino-sidebar-ready #order_review_heading {
    grid-area: unset !important;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 0.75rem;
    margin-bottom: 0;
  }

  /* col2-set: quitar float interno de WooCommerce */
  .chirino-inline-checkout .col2-set .col-1,
  .chirino-inline-checkout .col2-set .col-2 {
    float: none !important;
    width: 100% !important;
  }
}

/* ---- Sidebar wrapper — creado por JS ---- */
#chirino-order-sidebar {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

@media (min-width: 900px) {
  #chirino-order-sidebar {
    grid-area: sidebar;
    align-self: start;
    position: sticky;
    top: calc(var(--header-h, 5rem) + 1.5rem);
    /* Transición suave cuando pasa a modo "flotando" */
    transition:
      box-shadow 0.4s ease,
      transform 0.4s cubic-bezier(.2,.8,.3,1);
  }

  /* Estado "pegado al techo" — efecto flotante */
  #chirino-order-sidebar.is-stuck {
    transform: translateY(2px);
    box-shadow:
      0 20px 60px rgba(0, 0, 0, 0.4),
      0 0 0 1px rgba(42, 138, 138, 0.25);
  }

  #chirino-order-sidebar.is-stuck #order_review {
    border-color: rgba(42, 138, 138, 0.35) !important;
  }

  #chirino-order-sidebar.is-stuck #order_review_heading {
    border-bottom-color: rgba(42, 138, 138, 0.3);
    color: var(--color-primary) !important;
  }
}

/* ---- Encabezados de sección ---- */
.chirino-inline-checkout .woocommerce-billing-fields > h3,
.chirino-inline-checkout .woocommerce-shipping-fields > h3,
.chirino-inline-checkout .woocommerce-additional-fields > h3,
.chirino-inline-checkout #order_review_heading {
  font-family: var(--font-heading) !important;
  color: var(--color-heading) !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  margin: 0 0 1rem !important;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--color-border);
}

/* ---- Filas del formulario ---- */
.chirino-inline-checkout .form-row {
  margin-bottom: 1rem !important;
}
.chirino-inline-checkout .form-row label {
  color: var(--color-muted) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 0.4rem !important;
  display: block;
}
.chirino-inline-checkout .form-row .required { color: var(--color-primary) !important; }

/* ---- Inputs, selects, textarea ---- */
.chirino-inline-checkout .form-row input[type="text"],
.chirino-inline-checkout .form-row input[type="email"],
.chirino-inline-checkout .form-row input[type="tel"],
.chirino-inline-checkout .form-row input[type="number"],
.chirino-inline-checkout .form-row input[type="password"],
.chirino-inline-checkout .form-row select,
.chirino-inline-checkout .form-row textarea {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: var(--radius) !important;
  padding: 0.75rem 1rem !important;
  width: 100% !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  transition: border-color var(--transition) !important;
  box-sizing: border-box;
}
.chirino-inline-checkout .form-row input:focus,
.chirino-inline-checkout .form-row select:focus,
.chirino-inline-checkout .form-row textarea:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(42,138,138,0.15) !important;
}
.chirino-inline-checkout .form-row select option {
  background: var(--color-surface);
  color: var(--color-text);
}

/* ---- Sección "Tu pedido" (order review) ---- */
.chirino-inline-checkout #order_review {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 1.5rem !important;
}
.chirino-inline-checkout .woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
}
.chirino-inline-checkout .woocommerce-checkout-review-order-table th,
.chirino-inline-checkout .woocommerce-checkout-review-order-table td {
  padding: 0.65rem 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  font-size: 0.9rem;
}

/* Cantidad ("× 2") al lado del nombre del producto — visible y destacada */
.chirino-inline-checkout .woocommerce-checkout-review-order-table .product-quantity,
.chirino-inline-checkout .woocommerce-checkout-review-order-table .product-name strong.product-quantity {
  display: inline-block !important;
  visibility: visible !important;
  color: var(--color-primary) !important;
  font-weight: 700 !important;
  margin-left: 0.4rem;
  font-family: var(--font-heading);
  font-size: 0.95rem;
}

/* Cantidad en el Block Cart / Block Checkout — asegurar visibilidad del badge ×N */
.wc-block-components-order-summary-item__quantity,
.wc-block-cart-item__quantity .wc-block-components-quantity-selector__input {
  color: #fff !important;
  font-weight: 700 !important;
}
.chirino-inline-checkout .woocommerce-checkout-review-order-table thead th {
  color: var(--color-muted) !important;
  font-size: 0.75rem !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.chirino-inline-checkout .woocommerce-checkout-review-order-table .order-total th,
.chirino-inline-checkout .woocommerce-checkout-review-order-table .order-total td {
  color: var(--color-primary) !important;
  font-family: var(--font-heading) !important;
  font-size: 1.1rem !important;
  border-bottom: none !important;
  padding-top: 1rem !important;
}

/* ---- Métodos de pago ---- */
.chirino-inline-checkout .payment_methods {
  background: transparent !important;
  border: none !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 1rem 0 !important;
}
.chirino-inline-checkout .payment_methods li {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  padding: 0.75rem 1rem !important;
  margin-bottom: 0.5rem !important;
}
.chirino-inline-checkout .payment_methods li label {
  color: var(--color-text) !important;
  font-size: 0.9rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  cursor: pointer;
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem;
}
.chirino-inline-checkout .payment_methods li input[type="radio"] {
  accent-color: var(--color-primary);
  width: auto !important;
}
.chirino-inline-checkout .payment_box {
  background: transparent !important;
  color: var(--color-muted) !important;
  font-size: 0.85rem !important;
  margin-top: 0.5rem;
  padding: 0 !important;
}

/* ---- Privacidad / términos ---- */
.chirino-inline-checkout .woocommerce-privacy-policy-text,
.chirino-inline-checkout .woocommerce-terms-and-conditions-wrapper {
  color: var(--color-muted) !important;
  font-size: 0.82rem !important;
  margin-bottom: 1rem !important;
}
.chirino-inline-checkout .woocommerce-privacy-policy-text a,
.chirino-inline-checkout .woocommerce-terms-and-conditions-wrapper a {
  color: var(--color-primary) !important;
}

/* ---- Botón Realizar pedido ---- */
.chirino-inline-checkout #place_order {
  background: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-heading) !important;
  font-size: 1.1rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  padding: 1rem 2rem !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  box-shadow: 0 4px 15px rgba(42,138,138,0.3) !important;
  margin-top: 1rem !important;
  display: block !important;
}
.chirino-inline-checkout #place_order:hover {
  filter: brightness(1.15) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(42,138,138,0.45) !important;
}

/* ---- Avisos / validación ---- */
.chirino-inline-checkout .woocommerce-error,
.chirino-inline-checkout .woocommerce-message,
.chirino-inline-checkout .woocommerce-info {
  background: var(--color-surface) !important;
  border-top: 3px solid var(--color-primary) !important;
  color: var(--color-text) !important;
  border-radius: var(--radius) !important;
  padding: 1rem 1.25rem !important;
  margin-bottom: 1.5rem !important;
  font-size: 0.9rem !important;
}
.chirino-inline-checkout .woocommerce-error {
  border-top-color: #e74c3c !important;
}

/* ---- Select2 (si está activo) ---- */
.chirino-inline-checkout .select2-container--default .select2-selection--single {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  height: auto !important;
  padding: 0.75rem 1rem !important;
}
.chirino-inline-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--color-text) !important;
  line-height: 1.4 !important;
  padding: 0 !important;
}
.chirino-inline-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%);
  right: 0.75rem !important;
}
.select2-dropdown {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
}
.select2-results__option {
  color: var(--color-text) !important;
}
.select2-results__option--highlighted[aria-selected] {
  background: var(--color-primary) !important;
  color: #fff !important;
}

/* ---- Responsive: una columna en mobile ---- */
@media (max-width: 899px) {
  .chirino-inline-checkout .woocommerce {
    display: block !important;
  }
}

/* ============================================================
   PÁGINA "PEDIDO RECIBIDO" (thankyou) — Chirino
   ============================================================ */
.chirino-thankyou { max-width: 720px; margin: 0 auto; padding: 1rem 0 3rem; }

/* Banner de estado */
.cto-banner {
  display: flex; align-items: center; gap: 16px;
  padding: 20px 22px; border-radius: var(--radius-lg, 12px);
  margin-bottom: 1.5rem; border: 1px solid var(--color-border, #1e3838);
  background: var(--color-surface, #0d1f1f);
}
.cto-banner-ico {
  flex-shrink: 0; width: 48px; height: 48px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 24px;
}
.cto-banner h2 { margin: 0 0 4px; font-size: 1.25rem; font-family: var(--font-heading, inherit); color: var(--color-heading, #fff); }
.cto-banner p  { margin: 0; font-size: .9rem; color: var(--color-muted, #8aa); line-height: 1.5; }
.cto-banner--ok   { border-color: #2a9a58; }
.cto-banner--ok   .cto-banner-ico { background: #1a6b3a; color: #5de096; }
.cto-banner--wait { border-color: #2a8a8a; }
.cto-banner--wait .cto-banner-ico { background: #0a2a2a; color: #6fd0d0; }
.cto-banner--info .cto-banner-ico { background: #1a2828; color: #9cc; }
.cto-banner--fail { border-color: #b3402f; }
.cto-banner--fail .cto-banner-ico { background: #5a1c14; color: #ff7a66; }

/* Tarjeta resumen */
.cto-card {
  background: var(--color-surface, #0d1f1f); border: 1px solid var(--color-border, #1e3838);
  border-radius: var(--radius-lg, 12px); padding: 18px 22px; margin-bottom: 1.5rem;
}
.cto-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 14px; }
.cto-sum-item { display: flex; flex-direction: column; gap: 3px; }
.cto-sum-item span   { font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--color-muted, #6a8a8a); }
.cto-sum-item strong { font-size: 1.05rem; color: var(--color-heading, #e0f0f0); font-weight: 800; }

/* Datos bancarios */
.cto-bank-wrap { margin-bottom: 1.5rem; }
.cto-bank-title { font-size: 1.05rem; margin: 0 0 12px; color: var(--color-heading, #fff); font-family: var(--font-heading, inherit); }
.cto-bank-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.cto-bank-card {
  background: #0a1f1f; border: 1px solid #1e3838; border-left: 3px solid #2a8a8a;
  border-radius: 10px; padding: 16px 18px;
}
.cto-bank-bank { font-size: .95rem; font-weight: 800; color: #C8B98A; margin-bottom: 10px; }
.cto-bank-row { display: flex; align-items: center; gap: 10px; padding: 7px 0; border-top: 1px solid #142626; }
.cto-bank-row:first-of-type { border-top: none; }
.cto-bank-row > span { flex: 0 0 70px; font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; color: #5a7a7a; }
.cto-bank-row > b { flex: 1; min-width: 0; font-size: .95rem; color: #d0e8e8; word-break: break-all; font-family: monospace; }
.cto-copy {
  flex-shrink: 0; background: #14403f; color: #6fd0d0; border: 1px solid #2a8a8a;
  border-radius: 6px; padding: 5px 12px; font-size: .75rem; font-weight: 700; cursor: pointer;
  transition: background .15s, color .15s;
}
.cto-copy:hover { background: #2a8a8a; color: #fff; }
.cto-copy.is-ok { background: #1a6b3a; border-color: #2a9a58; color: #5de096; }

.cto-actions { display: flex; gap: 12px; flex-wrap: wrap; margin: 1rem 0 2rem; }

/* Tabla de detalles más prolija */
.chirino-thankyou .woocommerce-order-details__title,
.chirino-thankyou .woocommerce-column__title { font-family: var(--font-heading, inherit); color: var(--color-heading, #fff); }
.chirino-thankyou table.woocommerce-table--order-details { width: 100%; border-collapse: collapse; }
.chirino-thankyou table.woocommerce-table--order-details th,
.chirino-thankyou table.woocommerce-table--order-details td { padding: 12px 10px; border-bottom: 1px solid var(--color-border, #1e3838); }

@media (max-width: 600px) {
  .cto-banner { flex-direction: row; padding: 16px; gap: 12px; }
  .cto-banner h2 { font-size: 1.1rem; }
}

/* ============================================================
   CHECKOUT COMPACTO — pares de campos lado a lado (incl. mobile)
   ============================================================ */
.chirino-inline-checkout .woocommerce-billing-fields__field-wrapper,
.chirino-inline-checkout .woocommerce-shipping-fields__field-wrapper { overflow: hidden; }

.chirino-inline-checkout .form-row-first,
.chirino-inline-checkout .form-row-last {
  float: left;
  width: 48% !important;
  clear: none !important;
  box-sizing: border-box;
}
.chirino-inline-checkout .form-row-first { margin-right: 4%; }
.chirino-inline-checkout .form-row-last  { float: right; margin-right: 0; }
.chirino-inline-checkout .form-row-wide  { clear: both !important; width: 100% !important; }

/* En pantallas muy chicas mantener 2 columnas (objetivo: compactar) */
@media (max-width: 480px) {
  .chirino-inline-checkout .form-row-first,
  .chirino-inline-checkout .form-row-last { width: 48% !important; }
}

/* ============================================================
   CARRITO — imagen de producto + responsive (apilado en mobile)
   ============================================================ */
.woocommerce-cart table.cart td.product-thumbnail img {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: var(--radius);
  display: block;
  border: 1px solid var(--color-border);
}

/* Input de cantidad — oscuro y compacto en TODOS los tamaños */
.woocommerce-cart table.cart td.product-quantity .quantity input.qty {
  width: 70px;
  background: var(--color-surface);
  color: var(--color-heading);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 0.5rem;
  text-align: center;
}

/* Ocultar el botón "Actualizar carrito" (se actualiza solo) */
.woocommerce-cart table.cart td.actions button[name="update_cart"],
.woocommerce-cart table.cart td.actions input[name="update_cart"] {
  display: none !important;
}

/* Sacar el botón "Ir a finalizar la compra" (el checkout está embebido abajo) */
.woocommerce-cart .wc-proceed-to-checkout {
  display: none !important;
}

/* Caja "Total del carrito" más chica y a la derecha */
.woocommerce-cart .cart_totals {
  width: 340px !important;
  max-width: 100%;
  float: right;
}
.woocommerce-cart .cart_totals h2 {
  font-size: 1.05rem !important;
  margin-bottom: 0.5rem !important;
}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
  font-size: 0.85rem !important;
  padding: 0.4rem 0 !important;
}
.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
  font-size: 1rem !important;
}

/* ---- Desktop: carrito en 2 columnas (tabla izq + totales der, al lado) ---- */
@media (min-width: 769px) {
  .woocommerce-cart .woocommerce::after { content: ""; display: table; clear: both; }

  .woocommerce-cart .woocommerce-cart-form {
    float: left;
    width: 63%;
  }
  .woocommerce-cart .cart-collaterals {
    float: right;
    width: 34%;
    margin-top: 0;
  }
  .woocommerce-cart .cart-collaterals .cart_totals {
    width: 100% !important;
    float: none;
  }

  /* Filas más compactas (producto / precio / cantidad) */
  .woocommerce-cart table.cart td { padding: 0.55rem 0.9rem !important; }
  .woocommerce-cart table.cart td.product-thumbnail img { width: 56px; height: 56px; }

  /* Centrar precio/cantidad/subtotal con sus encabezados */
  .woocommerce-cart table.cart th.product-price,
  .woocommerce-cart table.cart td.product-price,
  .woocommerce-cart table.cart th.product-quantity,
  .woocommerce-cart table.cart td.product-quantity,
  .woocommerce-cart table.cart th.product-subtotal,
  .woocommerce-cart table.cart td.product-subtotal {
    text-align: center !important;
  }
  .woocommerce-cart table.cart td.product-quantity .quantity {
    display: inline-flex;
    justify-content: center;
  }

  /* "PRODUCTO" alineado con el comienzo del nombre del producto */
  .woocommerce-cart table.cart th.product-name { text-align: left !important; }

  /* Caja "Total del carrito" más compacta en altura */
  .woocommerce-cart .cart_totals { padding: 18px 20px !important; }
  .woocommerce-cart .cart_totals h2 { margin: 0 0 0.5rem !important; padding-bottom: 0.5rem !important; }
  .woocommerce-cart .cart_totals table th,
  .woocommerce-cart .cart_totals table td { padding: 0.3rem 0 !important; }
}


@media (max-width: 768px) {
  /* Ocultar el encabezado de tabla (causaba el desfasaje) */
  .woocommerce-cart table.cart thead { display: none; }

  .woocommerce-cart table.cart,
  .woocommerce-cart table.cart tbody,
  .woocommerce-cart table.cart tr,
  .woocommerce-cart table.cart td {
    display: block;
    width: 100% !important;
    box-sizing: border-box;
  }

  /* Item como tarjeta: fila1 imagen+nombre · fila2 precio/cantidad/subtotal */
  .woocommerce-cart table.cart tr.cart_item {
    border-bottom: none;
    display: grid;
    grid-template-columns: 64px 1fr 1fr 1fr;
    grid-template-areas:
      "img name name name"
      "img price qty subtotal";
    column-gap: 16px;
    row-gap: 8px;
    align-items: center;
    position: relative;
    padding: 0.6rem 0.7rem;
  }
  /* Divisor SOLO entre items consecutivos (nunca debajo del último) */
  .woocommerce-cart table.cart tr.cart_item + tr.cart_item {
    border-top: 1px solid var(--color-border);
  }
  /* Sin líneas internas en las celdas (la "líneita" molesta bajo el nombre) */
  .woocommerce-cart table.cart tr.cart_item td { border: none !important; }

  .woocommerce-cart table.cart td {
    border: none;
    padding: 0.2rem 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    text-align: right;
  }

  /* Imagen (columna izquierda, ocupa las dos filas) */
  .woocommerce-cart table.cart td.product-thumbnail {
    grid-area: img;
    align-self: center;
    padding: 0 !important;
  }
  /* La × (eliminar): chiquita, arriba a la derecha de la tarjeta */
  .woocommerce-cart table.cart td.product-remove {
    position: absolute;
    top: 0.6rem;
    right: 0.6rem;
    left: auto !important;
    width: auto !important;
    padding: 0 !important;
    display: block;
  }
  .woocommerce-cart table.cart td.product-remove a.remove {
    font-size: 18px;
    line-height: 1;
  }
  /* Nombre arriba, al lado de la imagen */
  .woocommerce-cart table.cart td.product-name { grid-area: name; }

  /* Fila inferior: 3 columnas (precio · cantidad · subtotal), etiqueta arriba */
  .woocommerce-cart table.cart td.product-price    { grid-area: price; }
  .woocommerce-cart table.cart td.product-quantity { grid-area: qty; }
  .woocommerce-cart table.cart td.product-subtotal { grid-area: subtotal; }

  .woocommerce-cart table.cart td.product-price,
  .woocommerce-cart table.cart td.product-quantity,
  .woocommerce-cart table.cart td.product-subtotal {
    width: auto !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    text-align: center;
  }
  /* La etiqueta (PRECIO/CANTIDAD/SUBTOTAL) arriba, chiquita */
  .woocommerce-cart table.cart td.product-price::before,
  .woocommerce-cart table.cart td.product-quantity::before,
  .woocommerce-cart table.cart td.product-subtotal::before {
    flex: none;
    font-size: 0.62rem;
  }

  /* Etiqueta de cada celda usando el data-title de WooCommerce */
  .woocommerce-cart table.cart td::before {
    content: attr(data-title);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-muted);
    font-weight: 600;
    flex-shrink: 0;
  }

  /* Celdas sin etiqueta (remove, thumbnail, nombre) */
  .woocommerce-cart table.cart td.product-remove,
  .woocommerce-cart table.cart td.product-thumbnail,
  .woocommerce-cart table.cart td.product-name {
    justify-content: flex-start;
    text-align: left;
  }
  .woocommerce-cart table.cart td.product-remove::before,
  .woocommerce-cart table.cart td.product-thumbnail::before,
  .woocommerce-cart table.cart td.product-name::before { content: ""; }
  .woocommerce-cart table.cart td.product-thumbnail img { width: 64px; height: 64px; }

  /* Nombre como título de la tarjeta (centrado, compacto) */
  .woocommerce-cart table.cart td.product-name {
    display: block;
    font-family: var(--font-heading);
    font-size: 0.9rem;
    line-height: 1.15;
    color: var(--color-heading);
    padding: 0 0 0.1rem;
    text-align: center !important;
  }

  /* Filas de la derecha compactas */
  .woocommerce-cart table.cart td.product-price,
  .woocommerce-cart table.cart td.product-quantity,
  .woocommerce-cart table.cart td.product-subtotal {
    padding: 0.18rem 0;
    font-size: 0.82rem;
    line-height: 1.2;
  }
  /* Subtotal destacado */
  .woocommerce-cart table.cart td.product-subtotal .woocommerce-Price-amount,
  .woocommerce-cart table.cart td.product-subtotal bdi {
    font-weight: 700;
  }

  /* Cantidad compacta + estilo oscuro (no recuadro blanco) */
  .woocommerce-cart table.cart td.product-quantity .quantity { flex: 0 0 auto; }
  .woocommerce-cart table.cart td.product-quantity .quantity input.qty {
    width: 52px;
    background: var(--color-surface);
    color: var(--color-heading);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.2rem 0.3rem;
    text-align: center;
  }

  /* Fila de acciones (cupón + actualizar) */
  .woocommerce-cart table.cart td.actions { display: block; text-align: center; }
  .woocommerce-cart table.cart td.actions::before { content: ""; }
  .woocommerce-cart table.cart td.actions .coupon { display: flex; gap: 0.5rem; margin-bottom: 0.75rem; }
  .woocommerce-cart table.cart td.actions .coupon input { flex: 1; }
}

/* ============================================================
   FIX overflow horizontal en mobile (carrito con checkout embebido)
   El <select> oculto de Select2 (Provincia) se extendía a ~568px y
   ensanchaba toda la página, descolocando el header. Lo clippeamos
   correctamente (técnica screen-reader-only).
   ============================================================ */
.chirino-inline-checkout select.select2-hidden-accessible,
.select2-hidden-accessible {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
}
.chirino-inline-checkout .select2-container,
.chirino-inline-checkout .select2 { max-width: 100% !important; }

/* Selects nativos (provincia/país) al 100% de su columna — no fijos a 375px.
   Excluye el <select> oculto de Select2 (ese va en 1px arriba). */
.chirino-inline-checkout select:not(.select2-hidden-accessible),
.chirino-inline-checkout input[type="text"],
.chirino-inline-checkout input[type="email"],
.chirino-inline-checkout input[type="tel"] {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.woocommerce-cart .chirino-inline-checkout { overflow-x: clip; }

/* ============================================================
   MOBILE: caja "Total del carrito" más fina y compacta
   ============================================================ */
@media (max-width: 768px) {
  .woocommerce-cart .cart_totals {
    width: 100% !important;
    padding: 16px 18px !important;
  }
  .woocommerce-cart .cart_totals h2 {
    font-size: 0.95rem !important;
    margin: 0 0 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .woocommerce-cart .cart_totals table { margin: 0 !important; }
  .woocommerce-cart .cart_totals table th,
  .woocommerce-cart .cart_totals table td {
    padding: 0.28rem 0 !important;
    font-size: 0.82rem !important;
    line-height: 1.25 !important;
  }
  .woocommerce-cart .cart_totals .order-total th,
  .woocommerce-cart .cart_totals .order-total td {
    font-size: 0.95rem !important;
    padding-top: 0.45rem !important;
  }
}

/* ============================================================
   CARRITO — stepper de cantidad − [n] + (propio) + título centrado
   ============================================================ */
/* Contenedor tipo pastilla */
.woocommerce-cart table.cart td.product-quantity .quantity {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--color-surface);
}
/* Botones − / + */
.woocommerce-cart table.cart td.product-quantity .quantity .ctda-step {
  width: 30px;
  border: none;
  background: transparent;
  color: var(--color-heading);
  font-size: 17px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.woocommerce-cart table.cart td.product-quantity .quantity .ctda-step:hover {
  background: var(--color-primary);
  color: #fff;
}
/* Input sin borde propio ni flechas nativas */
.woocommerce-cart table.cart td.product-quantity .quantity input.qty {
  width: 42px !important;
  border: none !important;
  background: transparent !important;
  color: var(--color-heading);
  text-align: center;
  padding: 0.4rem 0 !important;
  -moz-appearance: textfield;
  appearance: textfield;
}
.woocommerce-cart table.cart td.product-quantity .quantity input.qty::-webkit-outer-spin-button,
.woocommerce-cart table.cart td.product-quantity .quantity input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Título "Total del carrito" centrado */
.woocommerce-cart .cart_totals h2 { text-align: center; }

/* ============================================================
   CARRITO mobile — separación entre bloques (no encimados)
   ============================================================ */
@media (max-width: 768px) {
  /* Espacio entre la tarjeta de productos y la caja de totales */
  .woocommerce-cart .cart-collaterals { margin-top: 1.5rem !important; }
}
/* Espacio antes del bloque "Completar pedido" (checkout embebido) */
.chirino-inline-checkout {
  margin-top: 6rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--color-border);
}
.chirino-inline-checkout-header { margin-bottom: 1.5rem; }
