/* ===================================================================== */
/*  Shoplite – estilos-tienda.css (unificado y sin reglas duplicadas)     */
/* ===================================================================== */

/* ====== Tienda Básica – base ====== */
.tienda-catalogo { margin: 1rem 0; }

.lista-productos{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .75rem;
}

.producto-item{
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: .5rem;
  align-items: center;
  padding: .75rem;
  border: 1px solid #e5e7eb;
  border-radius: .5rem;
  background: transparent;
}

.producto-nombre{ font-weight: 600; }
.producto-precio{ opacity: .85; }

.tienda-carrito{ margin: 1.5rem 0; }

/* Accesibilidad */
.sr-only{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ===================================================================== */
/*  Botones (familia .boton-tienda)                                       */
/* ===================================================================== */
.boton-tienda{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .5rem .9rem;
  border-radius: .5rem;
  border: 1px solid transparent;
  text-decoration: none;
  line-height: 1.2;
  cursor: pointer;
  user-select: none;
}

.boton-tienda:hover{ filter: brightness(0.98); }

/* variantes (selección desde el admin) */
.boton-tienda.clasico      { background:#2563eb; color:#fff; border-color:#1e40af; }
.boton-tienda.moderno      { background:#111827; color:#fff; border-color:#111827; }
.boton-tienda.minimalista  { background:#fff; color:#111; border-color:#e5e7eb; }
.boton-tienda.elegante     { background:#4b5563; color:#fff; border-color:#374151; }
.boton-tienda.retro        { background:#f59e0b; color:#111; border-color:#b45309; }
.boton-tienda.oscuro       { background:#000; color:#fff; border-color:#111; }
.boton-tienda.neon         { background:#10b981; color:#0b2e1f; border-color:#047857; }

/* ===================================================================== */
/*  Catálogo en cards (NUEVO shortcodes: .shoplite-grid / .shoplite-item) */
/* ===================================================================== */
.shoplite-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  align-items: stretch;
}

.shoplite-item{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 10px 28px rgba(0,0,0,.12);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.shoplite-item a{
  text-decoration: none;
  color: inherit;
}

.shoplite-item img{
  width: 100%;
  height: auto;
  border-radius: 12px;
  display: block;
}

.shoplite-item h3{
  margin: 4px 0 0;
  font-size: 1.05rem;
  line-height: 1.25;
}

.shoplite-item-price{
  font-weight: 700;
  margin-top: 2px;
}

.tb-add-to-cart-form{ margin-top: auto; } /* botón abajo, cards alineadas */

/* ===================================================================== */
/*  Catálogo en cards (compat: .tb-grid / .tb-card por si aún lo usas)    */
/* ===================================================================== */
.tienda-catalogo .tb-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  align-items: stretch;
}

.tienda-catalogo .tb-card{
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 1px 6px rgba(0,0,0,12);
}

.tienda-catalogo .tb-thumb{ display:block; margin-bottom: 10px; }
.tienda-catalogo .tb-thumb img{
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  display: block;
}

.tienda-catalogo .tb-title{ margin: 6px 0 6px; }
.tienda-catalogo .tb-price{ margin: 0 0 12px; font-weight: 700; }

.tienda-catalogo .tb-actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.tienda-catalogo .tb-link{
  font-size: .9em;
  text-decoration: underline;
  opacity: .85;
}

/* ===================================================================== */
/*  Carrito en cards                                                      */
/* ===================================================================== */
.grid-carrito{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}

.card-carrito{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.12);
}

.carrito-row{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.carrito-info{
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1 1 auto;
  min-width: 160px;
}

.carrito-nombre{
  font-weight: 700;
  font-size: 1.05rem;
  line-height: 1.3;
}

.carrito-precio-unit{
  font-size: .9rem;
  opacity: .75;
}

.carrito-cantidad{ flex: 0 0 auto; }
.carrito-cantidad input[type="number"]{
  width: 90px;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid #ddd;
}

.carrito-subtotal{
  font-size: 1.1rem;
  font-weight: 800;
}

.carrito-actions{
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

/* Totales y botones inferiores */
.carrito-total{
  display: flex;
  justify-content: flex-end;
  gap: .5rem;
  margin-top: .75rem;
  flex-wrap: wrap;
}

.carrito-botones{
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .75rem;
}

/* ===================================================================== */
/*  Fix texto vertical (tema raro / writing-mode)                          */
/* ===================================================================== */
.tienda-carrito .carrito-nombre,
.tienda-carrito .carrito-precio-unit,
.tienda-carrito .carrito-info{
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  white-space: normal !important;
  word-break: break-word;
}

/* Por si algún tema impone anchuras mínimas */
.tienda-carrito *, .tb-checkout *{ max-width: 100%; }

/* ===================================================================== */
/*  PayPal / Stripe – responsive                                           */
/* ===================================================================== */
#tb-paypal-container iframe{ max-width: 100%; }
#tb-paypal-container, #tb-paypal-container iframe{ position: relative; z-index: 0; }

:root{
  --pay-height: clamp(40px, 4.5vw, 48px);
  --pay-gutter: clamp(6px, 1.2vw, 12px);
  --pay-radius: clamp(6px, 1vw, 10px);
}

.em-pay-buttons{
  display:flex;
  flex-wrap:wrap;
  gap: clamp(8px, 1.6vw, 14px);
  align-items:stretch;
}

.em-pay-buttons .pay-slot{
  flex: 1 1 min(420px, 100%);
  padding-inline: var(--pay-gutter);
}

.em-pay-buttons .pay-slot > *{ width: 100%; }

/* Stripe “nativo” */
.stripe-btn,
#tb-pagar-stripe{
  all: unset;
  box-sizing: border-box;
  display:flex;
  align-items:center;
  justify-content:center;
  height: var(--pay-height);
  width: 100%;
  background:#635BFF;
  color:#fff;
  border-radius: var(--pay-radius);
  font-weight: 700;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  letter-spacing:.2px;
  box-shadow: 0 1px 0 rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.08);
  transition: filter .15s ease, transform .02s ease;
  cursor: pointer;
  padding: 0 16px;
}

.stripe-btn:hover,
#tb-pagar-stripe:hover{ filter: brightness(.96); }

.stripe-btn:active,
#tb-pagar-stripe:active{ transform: translateY(1px); }

/* PayPal: que no colapse mientras carga */
#tb-paypal-container{ min-height: var(--pay-height); }
#tb-paypal-container > div{ width:100% !important; }

@media (max-width: 480px){
  .em-pay-buttons{ gap: clamp(10px, 4vw, 16px); }
}

/* ===================================================================== */
/*  Checkout layout (si existe)                                            */
/* ===================================================================== */
.tb-checkout, .shoplite-checkout, .pagina-pagos{ --checkout-side: 360px; }

.tb-checkout-grid, .shoplite-checkout-grid, .pagina-pagos-grid{
  display: grid;
  grid-template-columns: 1fr var(--checkout-side);
  gap: 24px;
  align-items: start;
}

@media (max-width: 980px){
  .tb-checkout-grid, .shoplite-checkout-grid, .pagina-pagos-grid{
    grid-template-columns: 1fr;
  }
}

@media (min-width: 992px){
  .checkout-aside{
    position: sticky;
    top: 16px;
  }
}

/* ===================================================================== */
/*  Paginación                                                             */
/* ===================================================================== */
.shoplite-pagination ul,
ul.page-numbers{
  list-style: none;
  padding: 0;
  margin: 10px 0;
  text-align: left;
}

.shoplite-pagination ul li,
ul.page-numbers li{
  display: inline-block;
  margin: 0 6px;
}

.shoplite-pagination a{ text-decoration: none; }

/* ===================================================================== */
/*  Ajustes de espaciado (UX)                                             */
/* ===================================================================== */

.tb-checkout,
.shoplite-checkout{
  margin-top: 20px;
}