/* ===============================
   Drawer Cart (Right) - Full CSS
   ===============================
   🔧 Guía rápida de “dónde tocar qué”
   ----------------------------------------------------------------
   1) Colores / tokens:              :root
   2) Fondo azul + panel:            .pc-cart-drawer__panel
   3) Botón cerrar (X grande):       .pc-cart-drawer__close
   4) Lista scrolleable:             .woocommerce-mini-cart
   5) Card (caja de producto):       .woocommerce-mini-cart-item / li
   6) X roja quitar producto:        a.remove
   7) Imagen del producto:           .woocommerce-mini-cart img
   8) Nombre del producto:           .woocommerce-mini-cart-item > a:not(.remove)
   9) Precio/cantidad por item:      .quantity
   10) Barra inferior (sticky):
       - Subtotal:                   .woocommerce-mini-cart__total
       - Botones:                    .woocommerce-mini-cart__buttons
   ----------------------------------------------------------------
   ✅ Fix solicitado hoy:
   - Ese “hueco azul” entre subtotal y botones NO es margin, es el
     “gap” porque cada bloque sticky es una tarjeta separada.
   - Solución: envolver ambos en una sola “tarjeta” visual usando:
     - fondo consistente
     - quitar bottoms/offsets inconsistentes
     - y dejar SOLO padding interno (sin separación).
*/

/* ===============================
   0) TOKENS
   =============================== */
:root {
  --pc-color-primary: #0b5ed7;     /* azul marca (panel) */
  --pc-cart-card: #f3f5f7;         /* fondo cards y barra inferior */
  --pc-cart-border: #e5e7eb;       /* borde suave */
  --pc-cart-text: #0f172a;         /* texto principal */
  --pc-cart-muted: #475569;        /* texto secundario */
  --pc-cart-white: #ffffff;

  /* Ajustes rápidos (cámbialos aquí) */
  --pc-cart-radius: 16px;
  --pc-cart-gap: 12px;

  --pc-cart-img: 82px;             /* tamaño imagen item */
  --pc-cart-remove: 28px;          /* tamaño x roja */
  --pc-cart-remove-radius: 10px;

  --pc-cart-title-size: 18px;      /* nombre producto */
  --pc-cart-price-size: 14px;      /* qty + precio item */

  --pc-cart-subtotal-size: 18px;   /* texto subtotal */
  --pc-cart-subtotal-pad: 14px;    /* padding subtotal */

  --pc-cart-btn-pad: 12px;         /* padding botones */
  --pc-cart-btn-radius: 12px;

  /* Alturas aproximadas para sticky calculations */
  --pc-cart-footer-gap: 12px;      /* separación del footer respecto al borde inferior */
}

/* ===============================
   1) WRAPPER + OVERLAY
   =============================== */
.pc-cart-drawer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
}

.pc-cart-drawer.is-open {
  pointer-events: auto;
}

.pc-cart-drawer__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.pc-cart-drawer.is-open .pc-cart-drawer__overlay {
  opacity: 1;
}

/* ===============================
   2) PANEL (azul)
   =============================== */
.pc-cart-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(460px, 92vw);
  height: 100vh;

  background: var(--pc-color-primary);
  transform: translateX(100%);
  transition: transform 0.25s ease;

  display: flex;
  flex-direction: column;

  box-shadow: -18px 0 40px rgba(0, 0, 0, 0.18);
  overscroll-behavior: contain;
}

.pc-cart-drawer.is-open .pc-cart-drawer__panel {
  transform: translateX(0);
}

/* ===============================
   3) BOTÓN CERRAR (X)
   =============================== */
.pc-cart-drawer__close {
  position: absolute;
  top: 12px;
  right: 12px;

  width: 40px;
  height: 40px;
  border-radius: 12px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.18);
  padding: 0;

  cursor: pointer;
  font-size: 26px;
  line-height: 1;
  color: #fff;

  z-index: 10;
}

.pc-cart-drawer__close:hover {
  background: rgba(255, 255, 255, 0.18);
}

/* ===============================
   4) CONTENEDOR INTERNO
   =============================== */
.pc-cart-drawer__content {
  padding: 58px 16px 14px; /* espacio para la X */
  flex: 1;
  min-height: 0;

  display: flex;
  flex-direction: column;
}

/* ===============================
   5) LISTA (SCROLL REAL)
   =============================== */
.pc-cart-drawer__content .woocommerce-mini-cart {
  list-style: none;
  margin: 0;
  padding: 0;

  flex: 1;
  min-height: 0;
  overflow: auto;

  display: flex;
  flex-direction: column;
  gap: var(--pc-cart-gap);

  padding-right: 6px;

  /* 🔧 IMPORTANTE:
     Reserva espacio para “barra inferior” sticky (subtotal+botones).
     Si subes/bajas el tamaño del footer, ajusta esto.
  */
  padding-bottom: 180px;

  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* Scrollbar (opcional) */
.pc-cart-drawer__content .woocommerce-mini-cart::-webkit-scrollbar {
  width: 10px;
}
.pc-cart-drawer__content .woocommerce-mini-cart::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  border: 2px solid rgba(0, 0, 0, 0);
  background-clip: padding-box;
}
.pc-cart-drawer__content .woocommerce-mini-cart::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 999px;
}

/* ===============================
   6) CARD DEL PRODUCTO
   =============================== */
.pc-cart-drawer__content .woocommerce-mini-cart-item,
.pc-cart-drawer__content .woocommerce-mini-cart li {
  position: relative;

  background: var(--pc-cart-card);
  border: 1px solid var(--pc-cart-border);
  border-radius: var(--pc-cart-radius);

  /* 🔧 padding card (si quieres más aire) */
  padding: 14px 14px 14px 52px; /* espacio remove */
}

/* ===============================
   7) X ROJA (quitar producto)
   =============================== */
.pc-cart-drawer__content a.remove {
  position: absolute;
  top: 14px;
  left: 14px;

  width: var(--pc-cart-remove);
  height: var(--pc-cart-remove);
  border-radius: var(--pc-cart-remove-radius);

  display: inline-flex;
  align-items: center;
  justify-content: center;

  text-decoration: none;
  font-size: 18px;
  line-height: 1;

  color: #b91c1c;
  background: #fee2e2;
}

.pc-cart-drawer__content a.remove:hover {
  filter: brightness(0.95);
}

/* ===============================
   8) LINK PRINCIPAL (imagen + nombre)
   =============================== */
.pc-cart-drawer__content .woocommerce-mini-cart-item > a:not(.remove),
.pc-cart-drawer__content .woocommerce-mini-cart li > a:not(.remove) {
  display: grid;
  grid-template-columns: var(--pc-cart-img) 1fr;
  column-gap: 14px;
  align-items: center;

  text-decoration: none;
  color: var(--pc-cart-text);
  font-weight: 900;

  min-height: var(--pc-cart-img);
  line-height: 1.15;

  /* 🔧 tamaño nombre producto */
  font-size: var(--pc-cart-title-size);
}

/* Imagen */
.pc-cart-drawer__content .woocommerce-mini-cart-item img,
.pc-cart-drawer__content .woocommerce-mini-cart li img {
  width: var(--pc-cart-img);
  height: var(--pc-cart-img);
  object-fit: contain;

  background: var(--pc-cart-white);
  border: 1px solid var(--pc-cart-border);
  border-radius: 14px;

  padding: 8px;
  margin: 0;
}

/* ===============================
   9) Qty + Price por item
   =============================== */
.pc-cart-drawer__content .quantity {
  display: block;
  margin-top: 8px;

  font-weight: 800;
  font-size: var(--pc-cart-price-size);
  color: var(--pc-cart-muted);
}

/* ===============================
   10) BARRA INFERIOR (STICKY)
   ✅ Fix: QUITAR espacio azul entre subtotal y botones
   =============================== */

/* Ambos bloques existen fuera del UL. Los convertimos en una sola tarjeta visual. */
.pc-cart-drawer__content .woocommerce-mini-cart__total,
.pc-cart-drawer__content .woocommerce-mini-cart__buttons {
  flex: 0 0 auto;
  margin: 0; /* 🔧 evita separaciones raras */
}

/* --- Subtotal: parte superior de la tarjeta --- */
.pc-cart-drawer__content .woocommerce-mini-cart__total {
  position: sticky;
  bottom: calc(var(--pc-cart-footer-gap) + 64px); /* 64px aprox del área de botones */

  z-index: 6;

  padding: var(--pc-cart-subtotal-pad) var(--pc-cart-subtotal-pad);

  display: flex;
  justify-content: space-between;
  align-items: center;

  background: var(--pc-cart-card);
  border: 1px solid var(--pc-cart-border);
  border-bottom: 0;
  border-radius: var(--pc-cart-radius) var(--pc-cart-radius) 0 0;

  box-shadow: 0 -14px 24px rgba(0, 0, 0, 0.1);

  /* 🔧 tamaño del subtotal */
  font-size: var(--pc-cart-subtotal-size);
  font-weight: 900;
  color: var(--pc-cart-text);
}

/* 🔧 Asegura que el monto siempre se vea */
.pc-cart-drawer__content .woocommerce-mini-cart__total .woocommerce-Price-amount,
.pc-cart-drawer__content .woocommerce-mini-cart__total .amount {
  color: var(--pc-cart-text);
  font-weight: 900;
}

/* --- Botones: parte inferior de la tarjeta --- */
.pc-cart-drawer__content .woocommerce-mini-cart__buttons {
  position: sticky;
  bottom: var(--pc-cart-footer-gap);

  z-index: 7;

  /* ✅ aquí estaba tu “hueco”: bottom + padding + bordes.
     Ahora los pegamos como UNA sola tarjeta.
  */
  padding: var(--pc-cart-btn-pad) var(--pc-cart-btn-pad) var(--pc-cart-btn-pad);

  display: flex;
  gap: 12px;

  background: var(--pc-cart-card);
  border: 1px solid var(--pc-cart-border);
  border-top: 0;
  border-radius: 0 0 var(--pc-cart-radius) var(--pc-cart-radius);

  box-shadow: 0 -14px 24px rgba(0, 0, 0, 0.1);
}

/* Botones estilo */
.pc-cart-drawer__content .woocommerce-mini-cart__buttons a.button {
  flex: 1;
  text-align: center;

  border-radius: var(--pc-cart-btn-radius);
  padding: 12px 14px;

  font-weight: 900;
  text-decoration: none;

  border: 1px solid var(--pc-cart-border);
}

/* View cart */
.pc-cart-drawer__content .woocommerce-mini-cart__buttons a.button:not(.checkout) {
  background: #fff;
  color: var(--pc-cart-text);
}

/* Checkout */
.pc-cart-drawer__content .woocommerce-mini-cart__buttons a.button.checkout {
  background: var(--pc-color-primary);
  color: #fff;
  border-color: transparent;
}

.pc-cart-drawer__content .woocommerce-mini-cart__buttons a.button:hover {
  filter: brightness(0.97);
}

/* ===============================
   11) EMPTY STATE
   =============================== */
.pc-cart-drawer__content .woocommerce-mini-cart__empty-message,
.pc-cart-drawer__content .woocommerce-mini-cart-empty {
  margin: 0;
  padding: 16px;
  border-radius: var(--pc-cart-radius);

  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: #fff;
  font-weight: 700;
}

/* ===============================
   12) MOBILE TWEAKS
   =============================== */
@media (max-width: 480px) {
  .pc-cart-drawer__content {
    padding: 58px 12px 12px;
  }

  .pc-cart-drawer__content .woocommerce-mini-cart-item,
  .pc-cart-drawer__content .woocommerce-mini-cart li {
    padding: 12px 12px 12px 48px;
    border-radius: 14px;
  }

  /* 🔧 Ajusta tamaños mobile */
  :root {
    --pc-cart-img: 74px;
    --pc-cart-title-size: 17px;
    --pc-cart-subtotal-size: 18px;
  }

  /* reserva extra para footer */
  .pc-cart-drawer__content .woocommerce-mini-cart {
    padding-bottom: 190px;
  }

  /* sticky subtotal (encima de botones) */
  .pc-cart-drawer__content .woocommerce-mini-cart__total {
    bottom: calc(var(--pc-cart-footer-gap) + 66px);
  }

  .pc-cart-drawer__close {
    top: 10px;
    right: 10px;
  }
}

/* ===============================
   13) ESTADOS UX
   =============================== */
.pc-cart-is-loading .pc-cart-drawer__panel {
  cursor: progress;
}

.pc-cart-item-is-removing {
  opacity: 0.55;
  pointer-events: none;
  transition: opacity 0.15s ease;
}