/* =========================================================
   STORE MODERN — diseño tipo SkyUltraPlus PreBots
   - Banner hero arriba con imagen de categoría
   - Sidebar VERTICAL estrecho con nombres de categorías estilo "✦ Nombre ✦"
   - Grid 2 col de productos con bullets, ciclo de cobro y botón
   100% theme-driven (var(--acc), --acc2, --gradient, --card)
   ========================================================= */

.sp-page{display:flex;flex-direction:column;gap:14px;max-width:1200px}

/* =============== HERO BANNER =============== */
.sp-hero{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  border:1px solid color-mix(in srgb,var(--acc) 32%,transparent);
  min-height:160px;
  display:grid;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 30%,var(--card)),color-mix(in srgb,var(--acc2) 24%,var(--card)));
}
.sp-hero-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:0;
}
.sp-hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 75%,transparent),color-mix(in srgb,var(--acc2) 60%,transparent));
  backdrop-filter:blur(2px);
}
.sp-hero-content{
  position:relative;z-index:2;
  padding:26px 28px;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-start;
}
.sp-hero-icon{
  width:54px;height:54px;
  border-radius:14px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  font-size:26px;
  margin-bottom:4px;
}
.sp-hero-title{
  margin:0;
  font-size:30px;
  font-weight:900;
  letter-spacing:-.015em;
  color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.35);
  line-height:1.1;
}
.sp-hero-title .sp-deco{color:rgba(255,255,255,.85);font-size:22px;display:inline-block;transform:translateY(-2px)}
.sp-hero-desc{
  margin:0;
  font-size:13.5px;
  font-weight:600;
  color:rgba(255,255,255,.92);
  text-shadow:0 1px 8px rgba(0,0,0,.4);
  line-height:1.55;
  max-width:640px;
}
.sp-credits{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.sp-credit-pill{
  display:inline-flex;
  flex-direction:column;
  padding:7px 14px;
  border-radius:13px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:#fff;
}
.sp-credit-pill .sp-credit-cur{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:rgba(255,255,255,.88);
  line-height:1.1;
}
.sp-credit-pill b{
  font-size:14px;
  font-weight:900;
  color:#fff;
  margin-top:2px;
  line-height:1.1;
}

/* =============== SEARCH + TABS =============== */
.sp-search-tabs{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px 14px;
  border-radius:18px;
  background:var(--card);
  border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);
}
.sp-search-row{display:flex;gap:8px}
.sp-search{
  flex:1;
  display:flex;
  align-items:center;
  gap:8px;
  padding:0 14px;
  height:42px;
  border-radius:12px;
  background:color-mix(in srgb,var(--acc) 6%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);
}
.sp-search:focus-within{border-color:var(--acc);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 16%,transparent)}
.sp-search i{color:var(--acc);font-size:17px}
.sp-search input{
  flex:1;
  background:none;border:0;outline:none;
  color:var(--text);
  font-weight:600;
  font-size:13.5px;
  padding:0;margin:0;
  width:100%;min-width:0;
  height:auto;
}
.sp-search input::placeholder{color:color-mix(in srgb,var(--text) 50%,transparent)}

.sp-tabs{display:flex;gap:8px;flex-wrap:wrap}
.sp-tab{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:9px 14px;
  border-radius:11px;
  background:color-mix(in srgb,var(--acc) 6%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 18%,transparent);
  color:color-mix(in srgb,var(--text) 78%,transparent);
  font-size:12.5px;
  font-weight:800;
  text-decoration:none;
  transition:background .18s,border-color .18s,color .18s;
}
.sp-tab:hover{
  background:color-mix(in srgb,var(--acc) 14%,transparent);
  color:var(--text);
}
.sp-tab.active{
  background:var(--gradient);
  color:#fff;
  border-color:transparent;
  box-shadow:0 6px 16px color-mix(in srgb,var(--acc) 32%,transparent);
}
.sp-tab i{font-size:14px}
.sp-tab-count{
  display:inline-flex;
  align-items:center;justify-content:center;
  min-width:18px;height:18px;
  padding:0 5px;
  border-radius:999px;
  background:color-mix(in srgb,var(--card) 35%,transparent);
  font-size:10.5px;
  font-weight:900;
  margin-left:2px;
}
.sp-tab.active .sp-tab-count{background:rgba(255,255,255,.25)}

.sp-results-count{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:0 4px;
  font-size:12px;
  font-weight:800;
  color:color-mix(in srgb,var(--text) 70%,transparent);
}
.sp-results-count i{color:var(--acc);font-size:14px}

/* =============== LAYOUT 2 COL =============== */
.sp-layout{
  display:grid;
  grid-template-columns:140px minmax(0,1fr);
  gap:14px;
  align-items:start;
}

/* =============== SIDEBAR VERTICAL DE CATEGORÍAS =============== */
.sp-cats{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:12px 8px;
  border-radius:18px;
  background:linear-gradient(180deg,color-mix(in srgb,var(--card) 92%,transparent),var(--card));
  border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);
  position:sticky;
  top:90px;
}
.sp-cats-head{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:6px 0 12px;
  margin-bottom:6px;
  border-bottom:1px solid color-mix(in srgb,var(--acc) 16%,transparent);
}
.sp-cats-head i{
  display:grid;place-items:center;
  width:34px;height:34px;
  border-radius:10px;
  background:var(--gradient);
  color:#fff;
  font-size:17px;
}
.sp-cats-head b{
  font-size:11px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--acc);
  text-align:center;
}
.sp-cat-item{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:10px 8px;
  border-radius:10px;
  text-decoration:none;
  color:var(--text);
  opacity:.82;
  border:1px solid transparent;
  font-size:12.5px;
  font-weight:800;
  text-align:center;
  letter-spacing:-.005em;
  transition:background .15s,opacity .15s,color .15s,border-color .15s;
}
.sp-cat-item:hover{
  background:color-mix(in srgb,var(--acc) 10%,transparent);
  opacity:1;
}
.sp-cat-item.active{
  background:color-mix(in srgb,var(--acc) 16%,transparent);
  color:var(--acc);
  border-color:color-mix(in srgb,var(--acc) 32%,transparent);
  opacity:1;
}
.sp-cat-name{
  flex:1 1 auto;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
  /* Emojis nativos a todo color: no aplicar text-fill-color ni background-clip */
  -webkit-text-fill-color:currentColor;
  font-variant-emoji:emoji;
}

/* =============== GRID PRODUCTOS (2 cols) =============== */
.sp-products{min-width:0}
.sp-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

/* =============== CARD PRODUCTO =============== */
.sp-card{
  display:flex;
  flex-direction:column;
  background:var(--card);
  border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);
  border-radius:18px;
  overflow:hidden;
  transition:transform .22s,box-shadow .22s,border-color .22s;
}
.sp-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 38px color-mix(in srgb,var(--acc) 22%,transparent);
  border-color:color-mix(in srgb,var(--acc) 42%,transparent);
}

/* Imagen cuadrada con object-fit:contain (foto completa, no recortada) */
.sp-card-img{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 22%,var(--card)),color-mix(in srgb,var(--acc2) 16%,var(--card)));
  display:grid;
  place-items:center;
  overflow:hidden;
}
.sp-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.sp-card-img-fallback{
  width:100%;height:100%;
  display:grid;place-items:center;
  font-size:36px;
  color:#fff;
  opacity:.7;
}

/* Badge AVAILABLE / AGOTADO */
.sp-stock-badge{
  position:absolute;
  top:12px;right:12px;
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:5px 11px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.sp-stock-badge.ok{
  background:color-mix(in srgb,#22c55e 65%,transparent);
  color:#fff;
  border:1px solid color-mix(in srgb,#22c55e 80%,transparent);
}
.sp-stock-badge.out{
  background:color-mix(in srgb,var(--danger) 65%,transparent);
  color:#fff;
  border:1px solid color-mix(in srgb,var(--danger) 80%,transparent);
}
.sp-stock-badge i{font-size:12px}

.sp-card-body{
  padding:14px 16px 16px;
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:1;
}
.sp-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}
.sp-card-body h3{
  margin:0;
  font-size:16px;
  font-weight:900;
  letter-spacing:-.012em;
  color:var(--text);
  line-height:1.2;
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex:1 1 auto;
  min-width:0;
}
.sp-card-body h3 i{color:var(--acc);font-size:16px;flex-shrink:0}

/* Pill del ciclo de cobro (Mensual / Cada 3 min / Pago único) */
.sp-cycle-pill{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 10px;
  border-radius:999px;
  background:color-mix(in srgb,var(--acc) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 28%,transparent);
  color:var(--acc);
  font-size:10.5px;
  font-weight:900;
  letter-spacing:-.005em;
  white-space:nowrap;
}
.sp-cycle-pill i{font-size:12px}

/* Bullets de la descripción */
.sp-card-bullets{
  list-style:none;
  padding:0;
  margin:2px 0 4px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.sp-card-bullets li{
  display:flex;
  align-items:flex-start;
  gap:4px;
  font-size:12.5px;
  font-weight:700;
  color:color-mix(in srgb,var(--text) 86%,transparent);
  line-height:1.4;
}
.sp-card-bullets li i{
  color:var(--acc);
  font-size:14px;
  flex-shrink:0;
  margin-top:1px;
}
.sp-card-bullets li span{flex:1;min-width:0}

.sp-card-desc{
  margin:2px 0 0;
  font-size:12px;
  line-height:1.5;
  color:color-mix(in srgb,var(--text) 65%,transparent);
  font-weight:600;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.sp-card-foot{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:8px;
  margin-top:auto;
  padding-top:8px;
  border-top:1px dashed color-mix(in srgb,var(--acc) 18%,transparent);
}
.sp-card-price small{
  display:block;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:color-mix(in srgb,var(--text) 55%,transparent);
}
.sp-card-price b{
  display:block;
  font-size:20px;
  font-weight:900;
  letter-spacing:-.015em;
  color:var(--acc);
  margin-top:2px;
  background:var(--gradient);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.sp-details-link{
  width:32px;height:32px;
  border-radius:9px;
  display:grid;place-items:center;
  background:color-mix(in srgb,var(--acc) 12%,transparent);
  color:var(--acc);
  text-decoration:none;
  font-size:16px;
  transition:background .15s,transform .15s;
}
.sp-details-link:hover{background:color-mix(in srgb,var(--acc) 24%,transparent);transform:translateY(-1px)}

.sp-card-warn{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:11px;
  font-weight:700;
  color:var(--danger);
  margin-top:2px;
}
.sp-card-warn i{font-size:13px}

.sp-buy-form{margin:6px 0 0}
.sp-buy-btn{
  width:100%;
  padding:11px 14px;
  border:0;
  border-radius:12px;
  background:var(--gradient);
  color:#fff!important;
  font-size:13px;
  font-weight:900;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  letter-spacing:.005em;
  box-shadow:0 8px 22px color-mix(in srgb,var(--acc) 38%,transparent);
  transition:transform .15s,box-shadow .15s;
  margin-top:4px;
}
.sp-buy-btn:hover:not(:disabled){
  transform:translateY(-1px);
  box-shadow:0 12px 28px color-mix(in srgb,var(--acc) 48%,transparent);
}
.sp-buy-btn:disabled{
  background:color-mix(in srgb,var(--text) 14%,transparent);
  color:color-mix(in srgb,var(--text) 50%,transparent)!important;
  cursor:not-allowed;
  box-shadow:none;
}
.sp-buy-btn i{font-size:15px}

/* Empty state */
.sp-empty{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  padding:48px 24px;
  text-align:center;
  background:var(--card);
  border:1px dashed color-mix(in srgb,var(--acc) 28%,transparent);
  border-radius:18px;
  grid-column:1/-1;
}
.sp-empty i{font-size:42px;color:var(--acc);opacity:.7}
.sp-empty b{font-size:17px;font-weight:900;color:var(--text);margin-top:6px}
.sp-empty span{font-size:13px;color:color-mix(in srgb,var(--text) 65%,transparent);font-weight:600}

/* =============== DETALLE DE PRODUCTO =============== */
.sp-detail-page{display:flex;flex-direction:column;gap:14px;max-width:1100px}
.sp-back-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  font-weight:800;
  color:var(--acc);
  text-decoration:none;
  width:max-content;
  padding:8px 14px;
  border-radius:10px;
  background:color-mix(in srgb,var(--acc) 12%,transparent);
  transition:background .15s,transform .15s;
}
.sp-back-link:hover{background:color-mix(in srgb,var(--acc) 22%,transparent);transform:translateX(-2px)}
.sp-detail{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.sp-detail-image{
  position:relative;
  aspect-ratio:1/1;
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 22%,var(--card)),color-mix(in srgb,var(--acc2) 16%,var(--card)));
  border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);
  display:grid;place-items:center;
}
.sp-detail-image img{width:100%;height:100%;object-fit:cover;display:block}
.sp-detail-info{display:flex;flex-direction:column;gap:14px}
.sp-product-cat{
  display:inline-flex;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  color:var(--acc);
  text-transform:uppercase;
  width:max-content;
}
.sp-detail-info h1{
  margin:0;
  font-size:30px;
  letter-spacing:-.025em;
  line-height:1.05;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.sp-detail-info h1 i{color:var(--acc);font-size:26px}
.sp-detail-desc{
  margin:0;
  font-size:14px;
  line-height:1.6;
  color:color-mix(in srgb,var(--text) 78%,transparent);
  font-weight:600;
}
.sp-detail-price{
  padding:18px 22px;
  border-radius:16px;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 14%,transparent),color-mix(in srgb,var(--acc2) 10%,transparent));
  border:1px solid color-mix(in srgb,var(--acc) 28%,transparent);
}
.sp-detail-price small{
  display:block;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--acc);
}
.sp-detail-price b{
  display:block;
  font-size:30px;
  font-weight:900;
  letter-spacing:-.025em;
  color:var(--text);
  margin-top:4px;
}
.sp-detail-info .sp-credits{margin-top:0}
.sp-detail-info .sp-credit-pill{
  background:color-mix(in srgb,var(--acc) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 28%,transparent);
  color:var(--text);
}
.sp-detail-info .sp-credit-pill .sp-credit-cur{color:var(--acc)}
.sp-detail-info .sp-credit-pill b{color:var(--text)}

.sp-detail-info-box{
  display:flex;
  align-items:flex-start;
  gap:8px;
  padding:14px 16px;
  border-radius:14px;
  background:color-mix(in srgb,var(--acc) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);
  font-size:13px;
  line-height:1.55;
  color:color-mix(in srgb,var(--text) 80%,transparent);
  font-weight:600;
}
.sp-detail-info-box i{color:var(--acc);font-size:17px;flex-shrink:0;margin-top:1px}

/* =============== RESPONSIVE =============== */
/* Sidebar vertical SIEMPRE a la izquierda, solo cambia de ancho */
@media(max-width:980px){
  .sp-layout{grid-template-columns:110px minmax(0,1fr);gap:10px}
  .sp-cats{padding:8px 6px}
  .sp-cat-item{font-size:11.5px;padding:8px 6px}
  .sp-cats-head i{width:28px;height:28px;font-size:14px}
  .sp-detail{grid-template-columns:1fr}
  .sp-detail-info h1{font-size:24px}
  .sp-hero-content{padding:22px 20px}
  .sp-hero-title{font-size:24px}
}
@media(max-width:680px){
  .sp-layout{grid-template-columns:88px minmax(0,1fr);gap:8px}
  .sp-cats{padding:6px 4px}
  .sp-cat-item{font-size:10.5px;padding:7px 4px;gap:3px}
  .sp-cat-name{font-size:10.5px}
  .sp-cats-head{padding:4px 0 8px}
  .sp-cats-head i{width:24px;height:24px;font-size:12px}
}
@media(max-width:560px){
  .sp-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .sp-card-body{padding:12px 12px 14px}
  .sp-card-body h3{font-size:14px}
  .sp-card-bullets li{font-size:11.5px}
  .sp-cycle-pill{font-size:9.5px;padding:3px 8px}
  .sp-card-price b{font-size:18px}
  .sp-buy-btn{font-size:12px;padding:10px 12px}
  .sp-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .sp-tab{flex:0 0 auto;font-size:11.5px;padding:8px 12px}
  .sp-hero-title{font-size:22px}
  .sp-hero-desc{font-size:12.5px}
}
@media(max-width:430px){
  .sp-layout{grid-template-columns:72px minmax(0,1fr);gap:6px}
  .sp-grid{grid-template-columns:1fr;gap:10px}
  .sp-cats{padding:6px 3px}
  .sp-cat-item{padding:6px 2px;font-size:9.5px}
  .sp-cat-name{font-size:10px}
}
