/* =========================================
   Base y CONTENEDOR centrado (site-wide)
   ========================================= */
*,
*::before,
*::after { box-sizing: border-box; }

img, video, iframe { max-width: 100%; height: auto; display: block; }

.container{
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-left: max(1rem, env(safe-area-inset-left));
  padding-right: max(1rem, env(safe-area-inset-right));
}

@media (max-width: 768px){
  .container{
    padding-left: max(1rem, env(safe-area-inset-left));
    padding-right: max(1rem, env(safe-area-inset-right));
  }
}

/* =========================================
   TIENDA (panel general)
   ========================================= */
.shop-bg{
  background-color: var(--primario);
  min-height: 100vh;
  position: relative;
  isolation: isolate;

  /* Preset de cuadrícula “bien marcada” */
  --grid-size: 64px;
  --grid-size-mobile: 48px;
  --grid-color-rgb: var(--cuaternario-rgb, 61,43,31);
  --grid-alpha: .16;

  /* Malla aplicada directo al fondo primario */
  background-image:
    linear-gradient(rgba(var(--grid-color-rgb), var(--grid-alpha)) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--grid-color-rgb), var(--grid-alpha)) 1px, transparent 1px);
  background-size: var(--grid-size) var(--grid-size),
                   var(--grid-size) var(--grid-size);
  background-position: center top;

  /* (compat) variables originales */
  --page-grid-size: 64px;
  --page-grid-size-md: 56px;
  --page-grid-size-sm: 44px;
  --page-line-rgb: var(--secundario-rgb, 138,64,32);
  --page-line-alpha: .14;
}
@media (min-width: 1024px){
  /* mantenemos la malla y sólo ajustamos el color base */
  .shop-bg{ background-color: var(--primario) !important; }
}
/* anulamos el pseudo-elemento previo para evitar doble patrón */
.shop-bg::before{ content:none !important; }

.shop-bg > *{ position: relative; z-index: 1; }
@media (max-width: 1200px){
  .shop-bg{
    background-size: var(--grid-size) var(--grid-size),
                     var(--grid-size) var(--grid-size);
  }
}
@media (max-width: 768px){
  .shop-bg{
    background-size: var(--grid-size-mobile) var(--grid-size-mobile),
                     var(--grid-size-mobile) var(--grid-size-mobile);
  }
}

/* Vars del módulo tienda */
.tienda-section{
  padding: .5rem 0;
  color:#e5e7eb;
  --card-h: 337px;                 /* altura uniforme desktop */
  --media-aspect: 16/7;
  --shop-grid-size: 64px;
  --shop-grid-size-md: 56px;
  --shop-grid-size-sm: 44px;
  --shop-vignette: radial-gradient(120% 90% at 50% 40%, transparent 55%, rgba(0,0,0,.25) 100%);
}
.tienda-section .container{
  position: relative; isolation:isolate;
  border:1px solid #1f2630; background:var(--cuaternario);
  box-shadow:0 18px 40px rgba(0,0,0,.22); overflow:clip;
}
.tienda-section .container::before{
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(var(--secundario-rgb,138,64,32), .18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--secundario-rgb,138,64,32), .18) 1px, transparent 1px);
  background-size: var(--shop-grid-size) var(--shop-grid-size), var(--shop-grid-size) var(--shop-grid-size);
}
.tienda-section .container::after{
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:0; pointer-events:none;
  background: var(--shop-vignette);
}

/* Título */
.tienda-title{
  font-size: clamp(1.4rem, 3.5vw, 2.2rem);
  font-weight: 800;
  margin: 0 0 1rem;
  text-align: center;
}

/* Banners */
.banner-promo{
  background:var(--sexto); border:1px solid var(--primario); color:#000;
  border-radius:16px; padding:.9rem 1rem; margin-bottom:1rem;
}
.banner-promo h3{ margin:.1rem 0 .3rem; }
.banner-promo p{ opacity:.85; }

.mini-banner{
  background: var(--octavo); color:#000; text-align:center;
  border:1px solid var(--secundario);
  padding:.55rem .9rem; margin-bottom:1.2rem; border-radius:12px; font-weight:600;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
}

/* Buscador / Orden */
.buscador-box{
  display:flex; flex-wrap:wrap; align-items:center; gap:.5rem;
  margin-bottom:.9rem;
}
.buscador-box input,
.buscador-box select{
  background:var(--sexto); color:#fff;
  border:1px solid var(--primario); border-radius:999px;
  padding:.5rem .9rem; outline:none;
}
.buscador-box input::placeholder{ color:#94a3b8; }
#reset{
  background:var(--primario); color:#000;
  border:1px solid var(--secundario); border-radius:999px; cursor:pointer;
}
#filtro-categoria{
  padding:.5rem 1rem; border-radius:2rem; border:none; background:#444; color:#fff; cursor:pointer;
}
@media (max-width: 992px){
  .buscador-box{ flex-direction: column; align-items: stretch; gap: .55rem; }
  .buscador-box input, .buscador-box select, #reset, #filtro-categoria{ width: 100%; }
}

/* GRID productos 5–4–3–2 */
.productos-grid{
  position: relative;
  display:grid; gap:16px;
  grid-template-columns: repeat(5, 1fr);
  align-items: stretch;
}
@media (max-width:1400px){ .productos-grid{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width:1200px){ .productos-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width:768px){  .productos-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); gap:12px; } }
@media (max-width:480px){  .productos-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px; } }

/* =========================================
   CARD de producto
   ========================================= */
.producto-card{
  position: relative;
  background:rgba(var(--primario), var(--primario)); color:#fff;
  border:2px solid var(--primario); border-radius:14px;
  padding:.7rem;
  display:flex; flex-direction:column; gap:.4rem;
  height: var(--card-h);                 /* ✅ altura uniforme por variable */
  box-shadow:0 10px 30px rgba(0,0,0,.18);
  transition:.22s ease;
  overflow: hidden;
}
.producto-card:hover{ transform: translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.28); }

/* Imagen */
.producto-media{
  position: relative;
  aspect-ratio: var(--media-aspect);
  border-radius: 10px;
  overflow: hidden;
  background:#000;
  display:grid; place-items:center;
  flex: 0 0 auto;
}
.producto-media a{ display:block; width:100%; height:100%; color:transparent !important; text-decoration:none !important; }
.producto-img{ max-width:100%; max-height:100%; width:auto; height:auto; display:block; object-fit:contain; }
.producto-img[src=""], .producto-img:not([src]){ display:none; }

/* Textos */
.producto-nombre{
  font-size:1rem; line-height:1.2; margin:.05rem 0 0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  min-height: calc(1.2em * 2);
  word-break: break-word;
}
.producto-descripcion{
  font-size:.9rem; color:#cbd5e1; margin:0;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  min-height: calc(1.25em * 3);
}

/* Meta/marca */
.producto-card .meta,
.producto-card .marca,
.producto-card small{
  font-size:.82rem; opacity:.95;
  display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden;
  min-height: 1.15em;
}

/* Precio + rating */
.producto-precio{ margin:.18rem 0 0; font-weight:800; text-align:center; font-size:1.02rem; }
.rating{ font-size:.86rem; color:gold; margin-top:.06rem; text-align:center; display:block; }
.rating-num{ font-size:.76rem; opacity:.7; color:#ccc; text-align:center; }

/* Acciones (siempre abajo) */
.acciones{
  display:flex; flex-direction: column; align-items:center; gap:.35rem;
  margin-top:auto;                       /* ✅ empuja los botones al fondo */
}
.btn-comprar,
.btn-alt{
  display:inline-flex; align-items:center; justify-content:center;
  height:32px; padding:0 12px; line-height:1;
  font-size:.92rem; font-weight:800; border:0; border-radius:999px; white-space:nowrap;
}
.btn-comprar{ background:var(--primario); color:#0b0b0b; transition: transform .12s ease, box-shadow .12s ease; }
.btn-comprar:hover{ transform:translateY(-1px); box-shadow:0 10px 20px rgba(34,211,238,.25); }
.btn-alt{ background:var(--primario); color:#000; border:1px solid var(--secundario);}



/* Badges */
.etiquetas{ position:absolute; top:8px; left:8px; display:flex; gap:.35rem; z-index:3; }
.etiqueta{ background:var(--primario); color:#fff; font-size:.68rem; padding:.18rem .45rem; border-radius:.4rem; text-transform:uppercase; }
.etiqueta.nuevo{ background:var(--cuarto); }
.etiqueta.personalizado{ background:var(--quinto); }
.producto-card .etiquetas{ top:8px; left:8px; right:auto; transform:none; }
.producto-card .etiqueta{ font-size:.68rem; padding:.18rem .45rem; border-radius:.4rem; }

/* CTA final */
.ver-tienda{ text-align:center; margin:3rem 0 1.5rem; }
.ver-tienda a, .ver-tienda .btn-comprar.grande{
  display:inline-flex; align-items:center; justify-content:center;
  text-decoration:none; width:min(100%, 520px); margin-inline:auto; border-radius:999px;
}

/* Categoría */
.categoria-titulo{
  font:700 2rem "tipografia3";
  color:var(--secundario);
  text-align:center;
  margin:3rem 0 1.5rem;
}

/* Paginación */
.shop-pagination nav{ display:flex; justify-content:center; margin:1rem 0 0; }
.shop-pagination .pagination{
  display:flex; gap:.35rem; flex-wrap:wrap; background:transparent; padding:.2rem; border-radius:12px;
}
.shop-pagination .page-link{
  background:#0b1020; color:#e5e7eb; border:1px solid #293246;
  padding:.42rem .66rem; border-radius:10px; min-width: 38px; min-height: 38px;
  display:inline-flex; align-items:center; justify-content:center; text-decoration:none;
}
.shop-pagination .page-item.active .page-link,
.shop-pagination .active .page-link{ background:var(--secundario,#22d3ee); color:#0b0b0b; border-color:transparent; }
.shop-pagination .page-item.disabled .page-link{ opacity:.5; cursor:not-allowed; }
.shop-pagination nav .text-sm, .shop-pagination nav > p { display:none; }

/* Navbar fix */
nav ul { display:flex; align-items:center; gap: 1.4rem; }
nav li { display:flex; align-items:center; }
nav form { margin: 0; }
nav a, nav button{
  display:inline-flex; align-items:center; justify-content:center;
  height:44px; padding:0 .7rem; background:transparent; border:0; font:inherit; color:inherit; line-height:1; cursor:pointer;
}

/* =========================================
   Carrusel (base)
   ========================================= */
.tienda-carousel{
  --gap: 14px;
  --item-w: 240px;
  --item-h: 240px;
  position: relative;
  margin: 1rem 0 1.8rem;
  --car-badge-top: 6px; --car-badge-right: 6px;
  --car-badge-bottom: auto; --car-badge-left: auto;
  --car-badge-tx: 0; --car-badge-ty: 0;
  --car-badge-font: .50rem; --car-badge-px: .28rem; --car-badge-py: .08rem; --car-badge-radius: .28rem;
}
.car-viewport{ overflow: hidden; }
.car-track{
  display:grid; grid-auto-flow:column; grid-auto-columns:var(--item-w);
  gap:var(--gap); align-items:stretch; scroll-snap-type:x mandatory;
  overflow-x:auto; padding: 6px; scroll-behavior:smooth; -webkit-overflow-scrolling:touch;
}
.car-track::-webkit-scrollbar{ height: 8px; }
.car-track::-webkit-scrollbar-thumb{ background:#0003; border-radius:999px; }
.car-item{
  display:flex; flex-direction:column; gap:.45rem;
  background:#B0885F; color:#e5e7eb; border:1px solid var(--primario); border-radius:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.18); padding:.6rem; text-decoration:none;
  scroll-snap-align:start; min-height:var(--item-h);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease; overflow:hidden; position: relative;
}
.car-item:hover{ transform: translateY(-2px); box-shadow: 0 16px 40px rgba(0,0,0,.28); border-color:#2b3346; }
.car-imgwrap{
  position: relative; aspect-ratio: 16/9; width:100%; overflow:hidden; border-radius:10px; margin:0; background:#000;
  display:grid; place-items:center;
}
.car-imgwrap img{
  max-width:100%; max-height:100%; width:auto; height:auto; display:block; object-fit:contain;
  font-size:0; color:transparent;
}
.car-imgwrap img:not([src]),
.car-imgwrap img[src=""], .car-imgwrap img[src="#"], .car-imgwrap img[src=" "],
.car-imgwrap img[src="null"], .car-imgwrap img[src="undefined"], .car-imgwrap img[src="about:blank"]{ display:none !important; }
.car-meta{ display:flex; justify-content:space-between; align-items:flex-start; gap:.5rem; }
.car-name{
  font-size:.9rem; line-height:1.18; margin:0; font-weight:700; color:#000;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; flex:1 1 auto;
}
.car-price{ font-weight:800; color:#000; white-space:nowrap; }
.car-btn{
  position:absolute; top:50%; transform:translateY(-50%); height:40px; width:40px; border-radius:999px; border:none;
  background:rgba(255,255,255,.9); box-shadow:0 6px 16px rgba(0,0,0,.15);
  display:grid; place-items:center; cursor:pointer; transition:transform .12s ease, background .12s ease; z-index:1;
}
.car-btn:hover{ transform:translateY(-50%) scale(1.06); background:#fff; }
.car-prev{ left:-6px; } .car-next{ right:-6px; }
.tienda-carousel .car-imgwrap{ position: relative; }
.tienda-carousel .car-imgwrap .etiquetas{
  position:absolute; top: var(--car-badge-top); right: var(--car-badge-right);
  bottom: var(--car-badge-bottom); left: var(--car-badge-left);
  transform: translate(var(--car-badge-tx), var(--car-badge-ty));
  display:flex; gap:.25rem; z-index:5;
}
.tienda-carousel .car-imgwrap .etiqueta{
  font-size: var(--car-badge-font); padding: var(--car-badge-py) var(--car-badge-px);
  border-radius: var(--car-badge-radius); line-height:1; background:var(--secundario,#22d3ee);
  color:#0b0b0b; box-shadow:0 2px 10px rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.25);
}
.tienda-carousel .car-imgwrap .etiqueta.descuento,
.tienda-carousel .car-imgwrap .etiqueta.off,
.tienda-carousel .car-imgwrap .etiqueta[data-type="off"]{
  background:#36c274; color:#062d17; border-color:rgba(255,255,255,.2);
}
.car-badge-tl{ --car-badge-top:6px; --car-badge-left:6px; --car-badge-right:auto; --car-badge-bottom:auto; }
.car-badge-tr{ --car-badge-top:6px; --car-badge-right:6px; --car-badge-left:auto; --car-badge-bottom:auto; }
.car-badge-bl{ --car-badge-bottom:6px; --car-badge-left:6px; --car-badge-top:auto; --car-badge-right:auto; }
.car-badge-br{ --car-badge-bottom:6px; --car-badge-right:6px; --car-badge-top:auto; --car-badge-left:auto; }

/* ====== Ajustes CELULAR manteniendo altura fija ====== */
@media (max-width: 768px){
  .tienda-section{
    --card-h: 339px;          /* ✅ MISMA ALTURA en móvil */
    --media-aspect: 16/11;    /* imagen un poco más alta para equilibrar */
  }

  .producto-card{ padding:.6rem; border-radius:22px; gap:0rem; }

  .producto-nombre{ font-size:.97rem; -webkit-line-clamp:2; }
  .producto-descripcion{ font-size:.86rem; -webkit-line-clamp:2; }
  .producto-precio{ font-size:1rem; margin-top:.2rem; }
  .rating{ font-size:.8rem; margin-top:.15rem; }

  /* Botones al 100% y siempre abajo */
  .acciones{ margin-top:auto; gap:0rem; }
  .acciones .btn-comprar,
  .acciones .btn-alt{
    width:100%; height:30px; font-size:.95rem; padding:0 44px;
  }

  .producto-media{ border-radius:12px; }
}

/* Extra angosto */
@media (max-width: 380px){
  .tienda-section{ --card-h: 390px; } /* da un pelín más de aire en teléfonos muy chicos */
  .producto-descripcion{ -webkit-line-clamp:2; }
  .acciones .btn-comprar,
  .acciones .btn-alt{ height:34px; font-size:.92rem; }
}

/* Buscador tema independiente */
#buscador{
  --buscador-bg: var(--terciario);
  --buscador-fg: #000;
  --buscador-ph: #000;
  --buscador-bc: var(--primario);
  background: var(--buscador-bg) !important;
  color: var(--buscador-fg) !important;
  border-color: var(--buscador-bc) !important;
}
#buscador::placeholder{ color: var(--buscador-ph); }

.search--claro{
  --buscador-bg:#625648;
  --buscador-fg:#1a120b;
  --buscador-ph:#6b5b4b;
  --buscador-bc:#d9bf9f;
}
.search--oscuro{
  --buscador-bg:#2b2a29;
  --buscador-fg:#f8fafc;
  --buscador-ph:#cbd5e1;
  --buscador-bc:#444;
}
/* Orden en móvil: Buscar → Reset → Todas las categorías → Ordenar */
@media (max-width: 992px){
  /* ya es flex-direction: column; mantenemos eso */
  .buscador-box #buscador{ order: 0; } /* input arriba */

  /* Buscar (submit) primero */
  .buscador-box button[type="submit"],
  .buscador-box input[type="submit"],
  .buscador-box .btn-buscar,
  .buscador-box #btn-buscar{ order: 1; }

  /* Reset segundo */
  .buscador-box #reset{ order: 2; }

  /* Todas las categorías tercero */
  .buscador-box #filtro-categoria{ order: 3; }

  /* Ordenar cuarto (incluyo variantes por si el id difiere) */
  .buscador-box #ordenar,
  .buscador-box #orden,
  .buscador-box select[name="orden"],
  .buscador-box select[name="order"],
  .buscador-box select[name="sort"]{ order: 4; }
}
