/**
 * GENOTIPIA — Rediseño checkout
 * Archivo separado para no entrar en conflicto con style.css del child theme.
 * Se carga sólo en /finalizar-compra/ con dependencia del style.css del padre.
 *
 * Para revertir el rediseño completo: desactivar el wp_enqueue_style
 * en /inc/genotipia-checkout.php (línea con genotipia_checkout_assets).
 *
 * Última actualización: 29/04/2026 (Alberto / srpulpo works)
 */

/* ============================================================
   VARIABLES
   ============================================================ */
:root {
  --gnt-primary: #4f3df5;
  --gnt-primary-hover: #3d2bd6;
  --gnt-bg-summary: #f4f4f7;
  --gnt-bg-toggle: #f9f9fb;
  --gnt-text: #1a1a1a;
  --gnt-text-muted: #6b6b76;
  --gnt-border: #e4e4ea;
  --gnt-success: #16a34a;
  --gnt-strike: #b8b8c2;
  --gnt-radius: 12px;
  --gnt-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

/* ============================================================
   1. LAYOUT — ancho máx, centrado, columnas 56/44 sin wrap
   ============================================================ */
body.woocommerce-checkout main#main {
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

body.woocommerce-checkout form.checkout {
  max-width: 100%;
  margin: 0;
  padding: 0;
}

body.woocommerce-checkout form.checkout > .row {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: nowrap;
  gap: 2rem;
  align-items: flex-start;
  margin: 0;
  max-width: 100%;
  width: 100%;
}

body.woocommerce-checkout form.checkout > .row > .large-7 {
  flex: 0 1 56%;
  max-width: 56%;
  width: 56%;
  min-width: 0;
  padding: 0;
  margin: 0;
  float: none;
}

body.woocommerce-checkout form.checkout > .row > .large-5 {
  flex: 0 1 44%;
  max-width: 44%;
  width: 44%;
  min-width: 0;
  padding: 0;
  margin: 0;
  float: none;
}

@media (max-width: 849px) {
  body.woocommerce-checkout form.checkout > .row {
    flex-direction: column;
    flex-wrap: wrap;
  }
  body.woocommerce-checkout form.checkout > .row > .large-7,
  body.woocommerce-checkout form.checkout > .row > .large-5 {
    flex: 0 0 100%;
    max-width: 100%;
    width: 100%;
  }
}

/* ============================================================
   2. CAJA DEL RESUMEN (TU PEDIDO)
   ============================================================ */
body.woocommerce-checkout .checkout-sidebar {
  background-color: var(--gnt-bg-summary);
  border-radius: var(--gnt-radius);
  padding: 1.75rem 1.5rem;
  box-shadow: var(--gnt-shadow);
}

body.woocommerce-checkout .col-inner.has-border {
  border: none;
  padding: 0;
}

body.woocommerce-checkout h3#order_review_heading {
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--gnt-text);
  margin: 0 0 1.25rem 0;
  padding-top: 0;
  overflow: visible;
  line-height: 1.4;
}

/* ============================================================
   3. TARJETA DEL PRODUCTO
   ============================================================ */
.gnt-product-card {
  background: #fff;
  border-radius: var(--gnt-radius);
  overflow: hidden;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}

/* Sin imagen - card más compacta, alineada con cards de listado de Iria */
.gnt-product-card__body {
  padding: 1.1rem 1.25rem 1.25rem 1.25rem;
}

.gnt-product-card__badge {
  display: inline-block;
  background: var(--gnt-primary);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 0.6rem;
}

.gnt-product-card__title {
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.35;
  margin: 0 0 0.6rem 0;
  color: var(--gnt-text);
}

/* Bullets de metadatos (duración · modalidad · créditos) */
.gnt-product-card__meta {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.85rem;
  font-size: 0.875rem;
  color: var(--gnt-text-muted);
}

.gnt-product-card__meta li {
  position: relative;
  margin: 0;
  padding: 0;
}

/* Separador · entre items (no después del último) */
.gnt-product-card__meta li:not(:last-child)::after {
  content: "·";
  position: absolute;
  right: -0.6rem;
  top: 0;
  color: var(--gnt-text-muted);
}

.gnt-product-card__qty {
  font-size: 0.85rem;
  color: var(--gnt-text-muted);
  margin: 0.5rem 0 0 0;
}

/* ============================================================
   4. PRECIOS Y TOTAL
   ============================================================ */
.gnt-prices {
  margin: 1.25rem 0 1rem 0;
  padding-top: 1rem;
  border-top: 1px solid var(--gnt-border);
}

.gnt-prices__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 0.95rem;
  color: var(--gnt-text);
  margin-bottom: 0.5rem;
}

.gnt-prices__row--original .gnt-prices__value--strike {
  text-decoration: line-through;
  color: var(--gnt-strike);
}

.gnt-prices__row--discount .gnt-prices__value {
  color: var(--gnt-success);
  font-weight: 600;
}

.gnt-prices__label {
  color: var(--gnt-text-muted);
}

.gnt-prices__value {
  font-weight: 500;
  text-align: right;
}

.gnt-total {
  margin: 1rem 0 1.5rem 0;
  padding-top: 1rem;
  border-top: 1px solid var(--gnt-border);
}

.gnt-total__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: nowrap;
  gap: 0.75rem;
}

.gnt-total__label {
  flex: 1 1 auto;
  font-size: 1rem;
  font-weight: 600;
  color: var(--gnt-text);
}

.gnt-total__value {
  flex: 0 0 auto;
  text-align: right;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--gnt-text);
  line-height: 1;
}

.gnt-total__value .woocommerce-Price-amount,
.gnt-total__value .amount,
.gnt-total__value bdi,
.gnt-total__value strong {
  display: inline;
  float: none;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--gnt-text);
}

.gnt-total__tax-note {
  display: block;
  width: 100%;
  text-align: right;
  font-size: 0.8rem;
  font-weight: 400;
  color: var(--gnt-text-muted);
  margin: 0.4rem 0 0 0;
}

/* ============================================================
   5. BULLETS DE BENEFICIOS
   ============================================================ */
.gnt-benefits {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem 0;
}

.gnt-benefits__item {
  position: relative;
  padding-left: 1.6rem;
  font-size: 0.9rem;
  color: var(--gnt-text);
  margin-bottom: 0.55rem;
  line-height: 1.4;
}

.gnt-benefits__item::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gnt-success);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.4;
}

/* ============================================================
   6. MENSAJE POST-PAGO
   ============================================================ */
.gnt-postpay-note {
  background: #fff;
  border: 1px solid var(--gnt-border);
  border-radius: 8px;
  padding: 0.85rem 1rem;
  margin: 1rem 0;
  font-size: 0.85rem;
  color: var(--gnt-text-muted);
  line-height: 1.5;
  display: flex;
  gap: 0.6rem;
  align-items: flex-start;
}

.gnt-postpay-note__icon {
  color: var(--gnt-primary);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 0.05rem;
}

/* ============================================================
   7. MÉTODOS DE PAGO
   ============================================================ */
body.woocommerce-checkout .checkout-sidebar #payment {
  background: transparent;
  padding: 0;
  margin-top: 1rem;
}

body.woocommerce-checkout .wc_payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1.25rem 0;
}

body.woocommerce-checkout .wc_payment_method {
  background: #fff;
  border: 1px solid var(--gnt-border);
  border-radius: 8px;
  padding: 0.85rem 1rem;
  margin-bottom: 0.5rem;
  list-style: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

body.woocommerce-checkout .wc_payment_method::before {
  display: none;
}

body.woocommerce-checkout .wc_payment_method label {
  font-weight: 500;
  color: var(--gnt-text);
  cursor: pointer;
  margin: 0;
}

body.woocommerce-checkout .wc_payment_method:has(input:checked) {
  border-color: var(--gnt-primary);
  box-shadow: 0 0 0 1px var(--gnt-primary);
}

body.woocommerce-checkout .payment_box {
  background: transparent !important;
  font-size: 0.85rem;
  color: var(--gnt-text-muted);
  padding: 0.5rem 0 0 0 !important;
  margin-top: 0.4rem;
}

body.woocommerce-checkout .payment_box::before {
  display: none;
}

/* ============================================================
   8. BOTÓN "PAGAR X €"
   ============================================================ */
body.woocommerce-checkout #place_order,
body.woocommerce-checkout button.button.alt {
  background-color: var(--gnt-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  padding: 1rem 1.5rem !important;
  width: 100%;
  letter-spacing: 0.01em;
  transition: background-color 0.2s, transform 0.1s;
  box-shadow: 0 4px 14px rgba(79, 61, 245, 0.25);
}

body.woocommerce-checkout #place_order:hover,
body.woocommerce-checkout button.button.alt:hover {
  background-color: var(--gnt-primary-hover) !important;
  transform: translateY(-1px);
}

body.woocommerce-checkout #place_order:active {
  transform: translateY(0);
}

/* ============================================================
   9. INPUTS DEL FORMULARIO
   ============================================================ */
body.woocommerce-checkout .woocommerce-billing-fields h3 {
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--gnt-text);
  margin-bottom: 1.5rem;
}

body.woocommerce-checkout .form-row label {
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--gnt-text);
  margin-bottom: 0.4rem;
}

body.woocommerce-checkout .form-row .input-text,
body.woocommerce-checkout .form-row select,
body.woocommerce-checkout .select2-selection {
  border: 1px solid var(--gnt-border) !important;
  border-radius: 8px !important;
  padding: 0.75rem 0.9rem !important;
  font-size: 0.95rem;
  background: #fff;
  transition: border-color 0.2s, box-shadow 0.2s;
  min-height: 48px;
}

body.woocommerce-checkout .form-row .input-text:focus,
body.woocommerce-checkout .form-row select:focus {
  border-color: var(--gnt-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(79, 61, 245, 0.12) !important;
}

/* ============================================================
   10. CUPÓN
   ============================================================ */
body.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
  background: transparent;
  border: none;
  padding: 0 0 1.25rem 0;
  font-size: 0.9rem;
  color: var(--gnt-text-muted);
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle .showcoupon {
  color: var(--gnt-primary);
  font-weight: 500;
}

/* ============================================================
   11. TOGGLE EMPRESA (switch moderno)
   Por defecto OCULTA: empresa, dirección, ZIP, población, provincia.
   El JS añade clase .gnt-empresa-on al form cuando se activa el switch.
   Selectores por ID porque WC siempre los pone (#billing_X_field).
   ============================================================ */

.gnt-empresa-toggle-wrapper {
  margin: 0 0 1.5rem 0;
  padding: 0.85rem 1rem;
  background: var(--gnt-bg-toggle);
  border: 1px solid var(--gnt-border);
  border-radius: 10px;
}

.gnt-empresa-toggle {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  margin: 0;
  user-select: none;
}

.gnt-empresa-toggle input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}

.gnt-empresa-toggle__slider {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  background: #d4d4dc;
  border-radius: 999px;
  transition: background 0.2s;
  flex-shrink: 0;
}

.gnt-empresa-toggle__slider::before {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s;
  box-shadow: 0 2px 4px rgba(0,0,0,0.15);
}

.gnt-empresa-toggle input[type="checkbox"]:checked + .gnt-empresa-toggle__slider {
  background: var(--gnt-primary);
}

.gnt-empresa-toggle input[type="checkbox"]:checked + .gnt-empresa-toggle__slider::before {
  transform: translateX(20px);
}

.gnt-empresa-toggle__label {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--gnt-text);
}

/* OCULTAR campos opcionales por defecto - selectores por ID
   (más seguros que clases custom porque son siempre los mismos en WC) */
body.woocommerce-checkout #billing_company_field,
body.woocommerce-checkout #billing_address_1_field,
body.woocommerce-checkout #billing_address_2_field,
body.woocommerce-checkout #billing_postcode_field,
body.woocommerce-checkout #billing_city_field,
body.woocommerce-checkout #billing_state_field {
  display: none;
}

/* MOSTRAR campos cuando el toggle está activo */
body.woocommerce-checkout form.checkout.gnt-empresa-on #billing_company_field,
body.woocommerce-checkout form.checkout.gnt-empresa-on #billing_address_1_field,
body.woocommerce-checkout form.checkout.gnt-empresa-on #billing_address_2_field,
body.woocommerce-checkout form.checkout.gnt-empresa-on #billing_postcode_field,
body.woocommerce-checkout form.checkout.gnt-empresa-on #billing_city_field,
body.woocommerce-checkout form.checkout.gnt-empresa-on #billing_state_field {
  display: block;
}


/* ============================================================
   CARRITO (/carrito/) — GENOTIPIA — versión consolidada
   Reusa el sistema de cards .gnt-card de Manu (style.css ~6133)
   con modificador --cart para anular el hover invertido del listado.
   Última actualización: 04/05/2026 (sesión 4)
   ============================================================ */

/* Cabecera del cart que mantenemos: layout 2 col Flatsome */
body.woocommerce-cart .gnt-cart-line {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1.5rem;
  align-items: stretch;
  padding: 0;
  border-bottom: 1px solid var(--gnt-border);
}

body.woocommerce-cart .gnt-cart-line:last-of-type {
  border-bottom: 0;
}

body.woocommerce-cart .gnt-cart-list {
  background: transparent;
  padding: 0;
  margin-bottom: 1rem;
}

/* ----- CARD adaptada al carrito ----- */
body.woocommerce-cart .gnt-card--cart {
  /* Si el padre .gnt-card aplica padding/box-shadow/border, lo respetamos */
  width: 100%;
  position: relative;
}

/* Hover sutil: solo el título cambia de color, el resto NO se invierte */
body.woocommerce-cart .gnt-card--cart:hover,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__top,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__title-wrap,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__features,
body.woocommerce-cart .gnt-card--cart:hover .gnt-cart-card__bottom {
  background: inherit !important;
  color: inherit !important;
}

body.woocommerce-cart .gnt-card--cart:hover .gnt-card__date,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__label,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__features,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__features span,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__features span::before,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__installments {
  color: var(--gnt-text-muted) !important;
  background: inherit !important;
}

body.woocommerce-cart .gnt-card--cart .gnt-card__title a,
body.woocommerce-cart .gnt-card--cart:hover .gnt-card__title a {
  color: var(--gnt-text);
  text-decoration: none;
  transition: color 0.2s ease;
}

body.woocommerce-cart .gnt-card--cart:hover .gnt-card__title a {
  color: var(--gnt-primary) !important;
}

/* Anular badge invertido del hover (que pueda venir de .gnt-card:hover .gnt-badge) */
body.woocommerce-cart .gnt-card--cart:hover .gnt-badge,
body.woocommerce-cart .gnt-card--cart:hover .gnt-badge--top {
  background: var(--gnt-primary) !important;
  color: #fff !important;
}

/* ----- BOTTOM de la card en carrito (cantidad + eliminar) ----- */
body.woocommerce-cart .gnt-cart-card__bottom {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gnt-border);
}

body.woocommerce-cart .gnt-cart-card__qty {
  flex-shrink: 0;
}

body.woocommerce-cart .gnt-cart-card__qty .ux-quantity {
  display: inline-flex;
  align-items: center;
}

body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form {
  background: #fff !important;
  color: var(--gnt-text) !important;
  border: 1px solid var(--gnt-border) !important;
  min-width: 30px;
  height: 32px;
  font-weight: 500 !important;
  border-radius: 0;
}

body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form:hover {
  background: var(--gnt-bg-toggle) !important;
  color: var(--gnt-primary) !important;
  border-color: var(--gnt-primary) !important;
}

body.woocommerce-cart .gnt-cart-card__qty .qty {
  width: 44px;
  height: 32px;
  text-align: center;
  font-size: 0.9rem;
  border: 1px solid var(--gnt-border);
  border-left: 0;
  border-right: 0;
  background: #fff;
  margin: 0;
}

body.woocommerce-cart .gnt-cart-card__remove a.remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: transparent;
  color: var(--gnt-text-muted);
  font-size: 1.3rem;
  line-height: 1;
  text-decoration: none;
  transition: all 0.2s ease;
}

body.woocommerce-cart .gnt-cart-card__remove a.remove:hover {
  background: rgba(220, 38, 38, 0.1);
  color: #dc2626;
}

/* ----- COLUMNA DERECHA: totales del item ----- */
body.woocommerce-cart .gnt-cart-line__totals {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 0.4rem;
  padding: 1.25rem;
  background: var(--gnt-bg-summary);
  border-radius: var(--gnt-radius);
}

body.woocommerce-cart .gnt-cart-line__price-old,
body.woocommerce-cart .gnt-cart-line__price-old .woocommerce-Price-amount,
body.woocommerce-cart .gnt-cart-line__price-old bdi {
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--gnt-strike);
  text-decoration: line-through;
}

body.woocommerce-cart .gnt-cart-line__price-current,
body.woocommerce-cart .gnt-cart-line__price-current .woocommerce-Price-amount,
body.woocommerce-cart .gnt-cart-line__price-current bdi {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--gnt-primary);
  line-height: 1.1;
}

body.woocommerce-cart .gnt-cart-line__savings {
  display: inline-block;
  background: rgba(79, 61, 245, 0.1);
  color: var(--gnt-primary);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  margin-top: 0.2rem;
}

/* ----- FOOTER de acciones (Seguir comprando + Actualizar carrito) ----- */
body.woocommerce-cart .gnt-cart-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 0.25rem 0.25rem;
  border-top: 1px solid var(--gnt-border);
  margin-top: 1rem;
}

/* "Seguir comprando" outline morado */
body.woocommerce-cart .button-continue-shopping,
body.woocommerce-cart a.button-continue-shopping.is-outline,
body.woocommerce-cart a.button-continue-shopping.button.primary.is-outline {
  background: transparent !important;
  color: var(--gnt-primary) !important;
  border: 1px solid var(--gnt-primary) !important;
  border-radius: 8px !important;
  padding: 0.65rem 1.25rem !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin: 0 !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

body.woocommerce-cart .button-continue-shopping:hover,
body.woocommerce-cart a.button-continue-shopping.is-outline:hover {
  background: var(--gnt-primary) !important;
  color: #fff !important;
}

/* Update cart neutro */
body.woocommerce-cart button[name="update_cart"].gnt-cart-update {
  background: transparent !important;
  color: var(--gnt-text-muted) !important;
  border: 1px solid var(--gnt-border) !important;
  border-radius: 8px !important;
  padding: 0.5rem 1.1rem !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

body.woocommerce-cart button[name="update_cart"].gnt-cart-update:hover:not([disabled]) {
  background: var(--gnt-bg-toggle) !important;
  color: var(--gnt-text) !important;
  border-color: var(--gnt-text-muted) !important;
}

body.woocommerce-cart button[name="update_cart"].gnt-cart-update[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ----- COLUMNA SIDEBAR (totales globales del carrito) ----- */
body.woocommerce-cart .gnt-cart-sidebar {
  background: var(--gnt-bg-summary);
  border-radius: var(--gnt-radius);
  padding: 1.5rem;
  box-shadow: var(--gnt-shadow);
}

/* Ocultar el thead/h2 duplicado */
body.woocommerce-cart .cart_totals > table:first-of-type thead,
body.woocommerce-cart .cart_totals > table:first-of-type:not(.shop_table) {
  display: none;
}

body.woocommerce-cart .cart_totals h2 {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gnt-text);
  margin: 0 0 1rem 0;
  padding: 0 0 0.75rem 0;
  border-bottom: 1px solid var(--gnt-border);
}

body.woocommerce-cart .cart_totals .shop_table {
  width: 100%;
  border: 0;
  background: transparent;
}

body.woocommerce-cart .cart_totals .shop_table th,
body.woocommerce-cart .cart_totals .shop_table td {
  padding: 0.6rem 0;
  border: 0;
  background: transparent;
  font-size: 0.95rem;
}

body.woocommerce-cart .cart_totals .shop_table th {
  font-weight: 500;
  color: var(--gnt-text-muted);
  text-align: left;
}

body.woocommerce-cart .cart_totals .shop_table td {
  text-align: right;
  color: var(--gnt-text);
}

body.woocommerce-cart .cart_totals .order-total th,
body.woocommerce-cart .cart_totals .order-total td {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--gnt-text);
  padding-top: 0.85rem;
  border-top: 1px solid var(--gnt-border);
}

body.woocommerce-cart .cart_totals .includes_tax {
  display: block;
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--gnt-text-muted);
  margin-top: 0.2rem;
}

/* Botón "Finalizar compra" morado */
body.woocommerce-cart .wc-proceed-to-checkout {
  margin-top: 1.25rem;
  padding: 0;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
  display: block !important;
  width: 100% !important;
  background: var(--gnt-primary) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 10px !important;
  padding: 0.95rem 1rem !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  text-align: center !important;
  text-decoration: none !important;
  letter-spacing: 0.01em !important;
  margin: 0 !important;
  transition: background 0.2s ease !important;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover {
  background: var(--gnt-primary-hover) !important;
}

/* Cupón sidebar */
body.woocommerce-cart .gnt-cart-coupon {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--gnt-border);
}

body.woocommerce-cart .gnt-cart-coupon .widget-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--gnt-text);
  margin: 0 0 0.6rem 0;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

body.woocommerce-cart .gnt-cart-coupon input.input-text {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--gnt-border);
  border-radius: 8px;
  font-size: 0.9rem;
  background: #fff;
  margin-bottom: 0.5rem;
}

body.woocommerce-cart .gnt-cart-coupon button {
  width: 100%;
  background: transparent !important;
  color: var(--gnt-primary) !important;
  border: 1px solid var(--gnt-primary) !important;
  border-radius: 8px !important;
  padding: 0.7rem 1rem !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
}

body.woocommerce-cart .gnt-cart-coupon button:hover {
  background: var(--gnt-primary) !important;
  color: #fff !important;
}

/* Esconder thead/labels mobile-only de la tabla original */
body.woocommerce-cart .show-for-small,
body.woocommerce-cart .mobile-product-price {
  display: none !important;
}

/* ----- Responsive móvil ----- */
@media (max-width: 849px) {
  body.woocommerce-cart .gnt-cart-line {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  body.woocommerce-cart .gnt-cart-line__totals {
    align-items: flex-start;
  }
}
/* ============================================================
   FIN sección CARRITO consolidada
   ============================================================ */

/* ============================================================
   CARRITO — PARCHE FIXES SESIÓN 5 (04/05/2026)
   - Cabecera Producto / Total
   - Quitar caja gris del precio derecho
   - Margin entre items
   - Ocultar mensaje "se ha añadido al carrito"
   ============================================================ */

/* Cabecera Producto / Total */
body.woocommerce-cart .gnt-cart-list-header {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1.5rem;
  padding: 0 0 0.75rem 0;
  margin-bottom: 0.75rem;
  border-bottom: 1px solid var(--gnt-border);
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gnt-text-muted);
}

body.woocommerce-cart .gnt-cart-list-header__product {
  text-align: left;
}

body.woocommerce-cart .gnt-cart-list-header__total {
  text-align: right;
}

/* Margin entre items del carrito */
body.woocommerce-cart .gnt-cart-line {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
}

body.woocommerce-cart .gnt-cart-line:last-of-type {
  margin-bottom: 0.5rem;
}

/* Quitar caja gris del precio (era pesada visualmente) */
body.woocommerce-cart .gnt-cart-line__totals {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0.5rem 0 !important;
  border-radius: 0 !important;
}

/* Ocultar mensaje "X se ha añadido al carrito" en cart */
body.woocommerce-cart .woocommerce-message,
body.woocommerce-cart .woocommerce-notices-wrapper .woocommerce-message {
  display: none !important;
}

/* Responsive: cabecera oculta en móvil (los items se apilan) */
@media (max-width: 849px) {
  body.woocommerce-cart .gnt-cart-list-header {
    display: none;
  }
}
/* ============================================================
   FIN parche fixes sesión 5
   ============================================================ */

/* ============================================================
   CARRITO — PARCHE FIXES SESIÓN 6 (04/05/2026)
   Ocultar botones acciones (auto-update vía JS sustituye el Update cart)
   ============================================================ */

/* Ocultar el bloque entero de acciones con sus 2 botones */
body.woocommerce-cart .gnt-cart-actions {
  display: none !important;
}
/* ============================================================
   FIN parche fixes sesión 6
   ============================================================ */

/* ============================================================
   CARRITO — RESPONSIVE COMPLETO (sesión 7, 04/05/2026)
   - Precio unitario dentro de la card (.gnt-cart-card__price-inline)
   - Mobile: layout 2 columnas mantenido, no apilado
   - Botones cantidad reparados en mobile
   - Tap targets 44px en touch
   ============================================================ */

/* Precio unitario DENTRO de la card (debajo de bullets, encima de cantidad) */
body.woocommerce-cart .gnt-cart-card__price-inline {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
  font-size: 1rem;
  line-height: 1.3;
}

body.woocommerce-cart .gnt-cart-card__price-inline del,
body.woocommerce-cart .gnt-cart-card__price-inline del .woocommerce-Price-amount,
body.woocommerce-cart .gnt-cart-card__price-inline del bdi {
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--gnt-strike) !important;
  text-decoration: line-through;
}

body.woocommerce-cart .gnt-cart-card__price-inline ins,
body.woocommerce-cart .gnt-cart-card__price-inline ins .woocommerce-Price-amount,
body.woocommerce-cart .gnt-cart-card__price-inline ins bdi {
  text-decoration: none;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--gnt-primary) !important;
  background: transparent;
}

/* Si NO hay descuento (sin del/ins, solo amount), mantener tamaño */
body.woocommerce-cart .gnt-cart-card__price-inline > .woocommerce-Price-amount {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--gnt-text);
}

/* En desktop la columna derecha solo muestra subtotal + ahorra (sin tachado) */
body.woocommerce-cart .gnt-cart-line__totals {
  align-items: flex-end;
  text-align: right;
}

/* ----- MOBILE ----- */
@media (max-width: 849px) {
  /* Mantener 2 columnas en mobile: card ancha + totales estrechos */
  body.woocommerce-cart .gnt-cart-line {
    grid-template-columns: 1fr auto;
    gap: 1rem;
  }

  /* Cabecera oculta */
  body.woocommerce-cart .gnt-cart-list-header {
    display: none;
  }

  /* Columna derecha más compacta */
  body.woocommerce-cart .gnt-cart-line__totals {
    align-items: flex-end;
    min-width: 90px;
    padding: 0;
    gap: 0.25rem;
  }

  body.woocommerce-cart .gnt-cart-line__price-current,
  body.woocommerce-cart .gnt-cart-line__price-current .woocommerce-Price-amount,
  body.woocommerce-cart .gnt-cart-line__price-current bdi {
    font-size: 1.1rem !important;
    line-height: 1.1;
  }

  body.woocommerce-cart .gnt-cart-line__savings {
    font-size: 0.7rem;
    padding: 0.15rem 0.5rem;
    white-space: nowrap;
  }

  /* Card más compacta en mobile */
  body.woocommerce-cart .gnt-card--cart {
    padding: 1rem !important;
  }

  /* Bullets más pequeñas */
  body.woocommerce-cart .gnt-card--cart .gnt-card__features {
    font-size: 0.8rem;
    gap: 0.3rem 0.6rem;
  }

  /* Precio inline en mobile: misma línea sin wrap si cabe */
  body.woocommerce-cart .gnt-cart-card__price-inline {
    margin-top: 0.5rem;
    font-size: 0.95rem;
  }

  /* Bottom (cantidad + X) más compacto */
  body.woocommerce-cart .gnt-cart-card__bottom {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    gap: 0.75rem;
  }
}

/* ----- ARREGLAR BOTONES DE CANTIDAD (rotos en mobile) ----- */
body.woocommerce-cart .gnt-cart-card__qty .ux-quantity {
  display: inline-flex !important;
  align-items: stretch;
  border: 1px solid var(--gnt-border);
  border-radius: 6px;
  overflow: hidden;
  background: #fff;
  height: 36px;
}

body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form {
  position: static !important;
  width: 36px !important;
  min-width: 36px !important;
  height: 36px !important;
  background: transparent !important;
  color: var(--gnt-text) !important;
  border: 0 !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 1.1rem !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form:hover {
  background: var(--gnt-bg-toggle) !important;
  color: var(--gnt-primary) !important;
}

body.woocommerce-cart .gnt-cart-card__qty .qty {
  width: 40px !important;
  min-width: 40px !important;
  height: 36px !important;
  text-align: center !important;
  font-size: 0.9rem !important;
  border: 0 !important;
  border-left: 1px solid var(--gnt-border) !important;
  border-right: 1px solid var(--gnt-border) !important;
  border-radius: 0 !important;
  background: #fff !important;
  margin: 0 !important;
  padding: 0 !important;
  -moz-appearance: textfield;
}

body.woocommerce-cart .gnt-cart-card__qty .qty::-webkit-outer-spin-button,
body.woocommerce-cart .gnt-cart-card__qty .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* X de eliminar: tap target más grande */
body.woocommerce-cart .gnt-cart-card__remove a.remove {
  width: 36px;
  height: 36px;
  font-size: 1.4rem;
}

/* ----- MOBILE PEQUEÑO (< 480px iPhone SE) ----- */
@media (max-width: 480px) {
  body.woocommerce-cart .gnt-cart-line {
    gap: 0.75rem;
  }

  body.woocommerce-cart .gnt-card--cart {
    padding: 0.85rem !important;
  }

  body.woocommerce-cart .gnt-card--cart .gnt-card__title {
    font-size: 0.95rem !important;
    line-height: 1.3 !important;
  }

  body.woocommerce-cart .gnt-cart-line__totals {
    min-width: 80px;
  }

  body.woocommerce-cart .gnt-cart-line__price-current,
  body.woocommerce-cart .gnt-cart-line__price-current .woocommerce-Price-amount,
  body.woocommerce-cart .gnt-cart-line__price-current bdi {
    font-size: 1rem !important;
  }

  /* Cantidad ocupa ancho disponible */
  body.woocommerce-cart .gnt-cart-card__bottom {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
}
/* ============================================================
   FIN responsive sesión 7
   ============================================================ */

/* ============================================================
   CARRITO — fix centrado vertical de +/- cantidad (sesión 8, 04/05/2026)
   El value del <input type="button"> de Flatsome se renderiza con
   métricas raras: usamos line-height = height + ajuste fino con padding.
   ============================================================ */
body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form {
  line-height: 34px !important;        /* casi igual a height 36px, deja 1px arriba y abajo */
  padding: 0 !important;
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  text-align: center !important;
  vertical-align: middle !important;
}
/* ============================================================
   FIN fix centrado +/- cantidad
   ============================================================ */

/* ============================================================
   CARRITO — fix2 cantidad (sesión 9, 04/05/2026)
   El input.button.is-form de Flatsome tiene min-height: 48px que
   sobrevivía a height:36px. Forzamos min/max-height y reseteo total.
   ============================================================ */
body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form,
body.woocommerce-cart .gnt-cart-card__qty input.ux-quantity__button.is-form,
body.woocommerce-cart .gnt-cart-card__qty input.ux-quantity__button {
  width: 36px !important;
  min-width: 36px !important;
  max-width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  line-height: 36px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  font-size: 1.1rem !important;
  font-weight: 500 !important;
  text-align: center !important;
  vertical-align: middle !important;
  box-sizing: border-box !important;
  background: transparent !important;
  color: var(--gnt-text) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.woocommerce-cart .gnt-cart-card__qty .ux-quantity__button.is-form:hover {
  background: var(--gnt-bg-toggle) !important;
  color: var(--gnt-primary) !important;
}

/* El input numérico también: forzar misma altura */
body.woocommerce-cart .gnt-cart-card__qty input.qty {
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  line-height: 36px !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}
/* ============================================================
   FIN fix2 cantidad
   ============================================================ */
