/* assets/css/tienda.css — Minitienda. Lenguaje visual de la familia (ServiciosAgs / miAguas).
   --mk* = marca Minitienda (fija). --pri/--sec = color de la tienda actual (inyectado). */
:root{
  --mk:#7048e8; --mk2:#9775fa; --mk-deep:#5f3dc4; --mk-glow:rgba(112,72,232,.16);
  --bg:#f4f2fb; --bg2:#eee9f9; --surface:#fff; --surface2:#faf8ff;
  --border:#e6e0f6; --border2:#d8cff0;
  --text:#1d1633; --text2:#473f63; --muted:#8980a6;
  --azul:#1a6fd4; --rojo:#e23b3b; --ambar:#f08c00; --verde-wa:#3fa53b;
  --pri:#7048e8; --sec:#e5dbff;            /* default = marca; cada tienda lo sobreescribe */
  --radius:14px; --shadow:0 2px 16px rgba(60,40,120,.09); --shadow-lg:0 10px 36px rgba(60,40,120,.16);
  --display:'Nunito',sans-serif; --body:'Nunito',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--body);min-height:100vh;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--mk);outline-offset:2px;border-radius:6px}

/* ── HEADER ── */
.ac-header{background:var(--surface);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:100;padding:10px 20px;box-shadow:0 2px 12px rgba(60,40,120,.07)}
.ac-header-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.ac-logo{display:flex;align-items:center;gap:9px;flex-shrink:0;font-family:var(--display);font-weight:900;font-size:1.2rem;letter-spacing:-.02em}
.ac-logo .mk{width:40px;height:40px;border-radius:11px;background:linear-gradient(145deg,var(--mk2),var(--mk-deep));display:grid;place-items:center;color:#fff;font-size:1.05rem;box-shadow:0 4px 12px var(--mk-glow)}
.ac-logo b{color:var(--mk-deep)}
.ac-search-wrap{flex:1;min-width:220px}
.ac-search-form{display:flex;align-items:center;background:var(--bg);border:2px solid var(--border);border-radius:50px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.ac-search-form:focus-within{border-color:var(--mk2);box-shadow:0 0 0 3px var(--mk-glow)}
.ac-search-form > i{padding:0 14px;color:var(--mk);font-size:.9rem}
.ac-search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:var(--body);font-size:.95rem;padding:11px 0}
.ac-search-input::placeholder{color:var(--muted)}
.ac-search-btn{background:linear-gradient(135deg,var(--mk2),var(--mk-deep));border:none;color:#fff;padding:11px 22px;font-family:var(--body);font-weight:800;font-size:.9rem;cursor:pointer;transition:opacity .2s}
.ac-search-btn:hover{opacity:.9}
.ac-pill{display:inline-flex;align-items:center;gap:7px;border-radius:50px;padding:9px 16px;font-family:var(--body);font-weight:700;font-size:.86rem;border:2px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;transition:.15s;white-space:nowrap}
.ac-pill:hover{border-color:var(--mk2);color:var(--mk-deep)}
.ac-pill i{color:var(--mk)}
.ac-cart{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--mk2),var(--mk-deep));color:#fff;font-weight:800;border-radius:50px;padding:9px 16px;white-space:nowrap}
.ac-cart .badge{background:#fff;color:var(--mk-deep);border-radius:50px;min-width:20px;height:20px;display:inline-grid;place-items:center;font-size:.78rem;padding:0 5px}

/* ── FILTROS ── */
.ac-filtros{max-width:1400px;margin:0 auto;padding:14px 20px 18px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.ac-filtros select{background:var(--surface);border:2px solid var(--border);border-radius:50px;color:var(--text);padding:9px 16px;font-family:var(--body);font-size:.86rem;font-weight:700;outline:none;cursor:pointer;transition:border-color .2s}
.ac-filtros select:focus{border-color:var(--mk2);box-shadow:0 0 0 3px var(--mk-glow)}
.ac-filtrar{background:linear-gradient(135deg,var(--mk2),var(--mk-deep));border:none;color:#fff;border-radius:50px;padding:9px 22px;font-family:var(--body);font-weight:800;font-size:.86rem;cursor:pointer;transition:opacity .2s}
.ac-filtrar:hover{opacity:.9}
.ac-btn-limpiar{background:none;border:2px solid var(--rojo);color:var(--rojo);border-radius:50px;padding:8px 18px;font-family:var(--body);font-size:.86rem;font-weight:800;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;gap:7px}
.ac-btn-limpiar:hover{background:var(--rojo);color:#fff}
.ac-count{color:var(--muted);font-size:.86rem;font-weight:700;margin-left:auto;background:var(--surface);border:1.5px solid var(--border);border-radius:50px;padding:7px 15px}

/* ── SECCIÓN ── */
.ac-sec{max-width:1400px;margin:0 auto;padding:8px 20px 0}
.ac-sec-title{font-family:var(--display);font-weight:900;font-size:1.35rem;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.ac-sec-title::before{content:'';width:5px;height:22px;border-radius:3px;background:linear-gradient(var(--mk2),var(--mk-deep))}
.ac-back{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:700;font-size:.88rem;margin:14px 0}
.ac-back:hover{color:var(--mk-deep)}

/* ── DESTACADOS (fila scroll) ── */
.ac-dest{display:flex;gap:14px;overflow-x:auto;padding:2px 0 8px;scrollbar-width:none}
.ac-dest::-webkit-scrollbar{display:none}
.ac-dest-card{flex:0 0 270px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:13px;transition:.18s;box-shadow:var(--shadow)}
.ac-dest-card:hover{transform:translateY(-3px);border-color:var(--mk2);box-shadow:var(--shadow-lg)}
.ac-dest-ico{width:50px;height:50px;border-radius:13px;flex-shrink:0;display:grid;place-items:center;font-size:1.3rem;color:#fff;font-family:var(--display);font-weight:900;overflow:hidden;background:linear-gradient(145deg,var(--mk2),var(--mk-deep))}
.ac-dest-ico img{width:100%;height:100%;object-fit:cover}
.ac-dest-info{min-width:0}
.ac-dest-giro{font-size:.7rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.ac-dest-nom{font-family:var(--display);font-weight:800;font-size:1rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-dest-link{font-size:.8rem;font-weight:800;color:var(--mk-deep);margin-top:2px}

/* ── GRID + CARDS ── */
.ac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px;padding-bottom:60px}
.ac-card{background:var(--surface);border:2px solid var(--border2);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.22s;box-shadow:0 4px 16px rgba(40,28,80,.09),0 1px 4px rgba(40,28,80,.06)}
.ac-card:hover{border-color:var(--mk2);box-shadow:0 14px 32px rgba(40,28,80,.16);transform:translateY(-4px)}
.ac-card-top{display:block;color:inherit}
.ac-card-img{position:relative;height:175px;overflow:hidden;background:var(--sec)}
.ac-card-img img{width:100%;height:100%;object-fit:cover}
.ac-card-badge{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.95);border-radius:50px;padding:4px 11px;font-size:.72rem;font-weight:800;color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,.12)}
.ac-card-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--pri)}
.ac-card-star{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:50%;background:#fff;color:var(--ambar);display:grid;place-items:center;font-size:.85rem;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.ac-card-oferta{position:absolute;bottom:10px;right:10px;background:var(--rojo);color:#fff;border-radius:50px;padding:3px 10px;font-size:.68rem;font-weight:800;letter-spacing:.03em;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.ac-card-body{padding:16px;display:flex;flex-direction:column;flex:1}
.ac-card-nom{font-family:var(--display);font-weight:800;font-size:1.05rem;line-height:1.2;margin-bottom:5px}
.ac-card-desc{font-size:.82rem;color:var(--text2);line-height:1.4;margin-bottom:11px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.ac-card-meta{display:flex;flex-wrap:wrap;gap:6px 12px;margin-bottom:13px;font-size:.78rem;font-weight:700}
.ac-card-meta .precio{color:var(--pri);font-size:1.05rem;font-weight:900}
.ac-card-meta .antes{color:var(--muted);font-weight:600;text-decoration:line-through;margin-left:6px;font-size:.85rem}
.ac-card-meta .info{color:var(--muted)}
.ac-card-meta i{margin-right:3px;color:var(--mk)}
.ac-card-actions{display:flex;gap:8px}
.ac-card-ver{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--surface2);border:1.5px solid var(--border2);color:var(--mk-deep);border-radius:11px;padding:10px;font-family:var(--display);font-weight:800;font-size:.82rem;transition:.15s}
.ac-card-ver:hover{background:#f1ecff;border-color:var(--mk2)}
.ac-card-add{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:linear-gradient(135deg,var(--mk2),var(--mk-deep));color:#fff;border:none;border-radius:11px;padding:10px;font-family:var(--display);font-weight:800;font-size:.82rem;cursor:pointer;transition:.15s}
.ac-card-add:hover{transform:translateY(-1px)}
.ac-card-wa{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:linear-gradient(135deg,#5ec45a,#3fa53b);color:#fff;border-radius:11px;padding:10px;font-family:var(--display);font-weight:800;font-size:.82rem;transition:.15s}
.ac-card-wa:hover{transform:translateY(-1px)}
.ac-empty{text-align:center;padding:60px 20px;color:var(--muted)}
.ac-empty i{font-size:2.5rem;color:var(--border2);margin-bottom:14px}
.ac-empty h3{font-family:var(--display);color:var(--text2);margin-bottom:6px}

/* ── HERO DE TIENDA ── */
.ac-tienda-hero{background:linear-gradient(180deg,var(--sec),transparent);border-bottom:1px solid var(--border)}
.ac-tienda-hero-in{max-width:1400px;margin:0 auto;padding:22px 20px 14px;display:flex;gap:16px;align-items:center}
.ac-tienda-logo{width:84px;height:84px;border-radius:18px;object-fit:cover;border:3px solid #fff;box-shadow:var(--shadow);background:#fff;flex:0 0 auto}
.ac-tienda-hero h1{font-family:var(--display);font-size:1.7rem;font-weight:900;letter-spacing:-.02em;margin-bottom:3px}
.ac-tienda-hero p{color:var(--text2);font-size:.95rem;max-width:680px}
.ac-tienda-portada{max-width:1400px;margin:14px auto 0;padding:0 20px}
.ac-tienda-portada img{width:100%;height:180px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}

/* ── DETALLE PRODUCTO ── */
.ac-detalle{max-width:1100px;margin:0 auto;padding:10px 20px 50px;display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.ac-detalle .foto{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:1/1;object-fit:cover;width:100%;background:var(--sec)}
.ac-detalle h1{font-family:var(--display);font-size:1.9rem;font-weight:900;margin-bottom:8px}
.ac-detalle .precio{font-size:1.7rem;font-weight:900;color:var(--pri);display:block;margin:6px 0 16px}
.ac-detalle .precio .antes{font-size:1rem;color:var(--muted);text-decoration:line-through;margin-left:8px;font-weight:700}
.ac-detalle p{color:var(--text2);line-height:1.6}
.qty{display:inline-flex;align-items:center;border:2px solid var(--border2);border-radius:11px;overflow:hidden;margin-right:10px}
.qty button{width:42px;height:44px;border:0;background:#fff;font-size:20px;cursor:pointer;font-family:inherit;color:var(--mk-deep)}
.qty button:hover{background:var(--bg2)}
.qty input{width:50px;height:44px;border:0;text-align:center;font-family:inherit;font-size:16px;font-weight:800}

/* ── BOTONES ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-family:var(--display);font-weight:800;font-size:.95rem;border:0;border-radius:11px;padding:12px 20px;transition:.15s}
.btn:active{transform:translateY(1px)}
.btn-pri{background:linear-gradient(135deg,var(--mk2),var(--mk-deep));color:#fff}
.btn-pri:hover{filter:brightness(.96)}
.btn-wa{background:linear-gradient(135deg,#5ec45a,#3fa53b);color:#fff}
.btn-wa:hover{filter:brightness(.97)}
.btn-ghost{background:#fff;color:var(--text);border:2px solid var(--border2)}
.btn-ghost:hover{background:var(--surface2)}
.btn-block{width:100%}

/* ── CARRITO ── */
.ac-wrap{max-width:1100px;margin:0 auto;padding:0 20px 50px}
.cart-cols{display:grid;grid-template-columns:1fr 330px;gap:22px;align-items:start}
.linea{display:flex;gap:12px;align-items:center;background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:11px;margin-bottom:11px;box-shadow:var(--shadow)}
.linea img{width:66px;height:66px;border-radius:11px;object-fit:cover;background:var(--sec);flex:0 0 auto}
.linea .info{flex:1;min-width:0}
.linea .info b{display:block;font-family:var(--display);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.linea .info .precio{color:var(--pri);font-weight:800;font-size:.9rem}
.linea .qcell{width:62px}
.linea .qcell input{width:100%;border:2px solid var(--border2);border-radius:9px;padding:8px;text-align:center;font-family:inherit;font-weight:800}
.linea .sub{min-width:78px;text-align:right;font-weight:900;font-family:var(--display)}
.resumen{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:sticky;top:84px}
.resumen .row{display:flex;justify-content:space-between;margin:7px 0;color:var(--text2);font-weight:700}
.resumen .total{font-family:var(--display);font-size:1.25rem;font-weight:900;color:var(--text);border-top:2px solid var(--border);padding-top:11px;margin-top:11px}
.campo{display:block;margin:11px 0}
.campo label{display:block;font-weight:800;font-size:.82rem;margin-bottom:5px;color:var(--text2)}
.campo input,.campo textarea{width:100%;font-family:inherit;font-size:.95rem;border:2px solid var(--border2);border-radius:10px;padding:11px 13px}
.campo input:focus,.campo textarea:focus{outline:none;border-color:var(--mk2);box-shadow:0 0 0 3px var(--mk-glow)}
details.checkout summary{list-style:none}
details.checkout summary::-webkit-details-marker{display:none}
.aviso{background:var(--sec);color:var(--mk-deep);border-radius:var(--radius);padding:13px 16px;margin:14px 0;font-weight:700}
.ok-box{background:#ebfbee;border:2px solid #b2f2bb;color:#2b8a3e;border-radius:var(--radius);padding:22px;margin:22px 0}
.ok-box h2{font-family:var(--display)}
.vacio{text-align:center;color:var(--muted);padding:60px 20px}

/* ── ECO-TABS (derecha) + panel ── */
.eco-tabs{position:fixed;right:0;top:120px;z-index:1050;display:flex;flex-direction:column-reverse;gap:6px;align-items:flex-end}
.eco-tab{writing-mode:vertical-rl;text-orientation:mixed;color:#fff;font-family:var(--display);font-size:11px;font-weight:800;letter-spacing:.04em;padding:11px 6px;border-radius:12px 0 0 12px;box-shadow:0 4px 16px rgba(13,35,64,.25);transition:padding-right .15s}
.eco-tab:hover{padding-right:11px;color:#fff}
.eco-mundo{width:46px;height:46px;border-radius:50%;border:none;cursor:pointer;margin:0 8px 4px 0;background:linear-gradient(180deg,var(--mk2),var(--mk-deep));color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(13,35,64,.28)}
.eco-back{position:fixed;inset:0;background:rgba(13,35,64,.45);z-index:1200;opacity:0;pointer-events:none;transition:opacity .3s}
.eco-back.visible{opacity:1;pointer-events:auto}
.eco-panel{position:fixed;top:0;right:0;height:100%;width:min(360px,90vw);z-index:1201;background:var(--surface);border-left:1px solid var(--border);transform:translateX(105%);transition:transform .35s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;box-shadow:-16px 0 50px rgba(28,39,51,.18)}
.eco-panel.abierto{transform:translateX(0)}
.eco-panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);font-family:var(--display);font-size:15px;font-weight:800}
.eco-panel-x{background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);width:30px;height:30px;border-radius:50%;line-height:1}
.eco-panel-body{padding:12px;overflow-y:auto}
.eco-card{display:flex;align-items:center;gap:13px;padding:14px;border-radius:14px;border:1px solid var(--border);margin-bottom:10px;transition:.12s}
.eco-card:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(28,39,51,.1)}
.eco-card-ico{width:46px;height:46px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;font-family:var(--display);font-weight:900}
.eco-card-ico--logo{background:#fff!important;border:1px solid var(--border);padding:5px}
.eco-card-ico--logo img{width:100%;height:100%;object-fit:contain}
.eco-card-nom{font-family:var(--display);font-size:15px;font-weight:800;display:block}
.eco-card-desc{font-size:12.5px;color:var(--muted);line-height:1.35;margin-top:2px;display:block}
.eco-card-arrow{color:var(--muted);font-size:18px;margin-left:auto}

/* ── TAB ABRE TU TIENDA (izquierda) + sidebar ── */
.pub-tab{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:250;writing-mode:vertical-rl;text-orientation:mixed;border:none;cursor:pointer;background:linear-gradient(180deg,var(--mk2),var(--mk-deep));color:#fff;font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.04em;padding:14px 7px;border-radius:0 12px 12px 0;box-shadow:0 4px 16px rgba(13,35,64,.25);transition:padding-left .15s}
.pub-tab:hover{padding-left:11px}
.pubn-overlay{position:fixed;inset:0;background:rgba(13,35,64,.45);z-index:1300;opacity:0;pointer-events:none;transition:opacity .3s}
.pubn-overlay.open{opacity:1;pointer-events:auto}
.pubn-panel{position:fixed;top:0;left:0;height:100%;width:min(360px,90vw);z-index:1301;background:#fff;border-right:1px solid var(--border);transform:translateX(-105%);transition:transform .35s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;box-shadow:16px 0 50px rgba(28,39,51,.18)}
.pubn-panel.open{transform:translateX(0)}
.pubn-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);font-family:var(--display);font-size:16px;font-weight:800}
.pubn-x{background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);width:32px;height:32px;border-radius:50%;line-height:1}
.pubn-body{padding:16px 18px;overflow-y:auto}
.pubn-pitch{font-size:.92rem;color:var(--text2);line-height:1.55;margin:0 0 16px}
.pubn-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.pubn-chips span{background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:50px;padding:6px 12px;font-size:.8rem;font-weight:700}
.pubn-cta{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--mk2),var(--mk-deep));color:#fff;border-radius:14px;padding:14px;box-shadow:0 4px 16px var(--mk-glow);transition:transform .12s}
.pubn-cta:hover{transform:translateY(-1px);color:#fff}
.pubn-cta .ico{width:42px;height:42px;border-radius:10px;background:#fff;color:var(--mk-deep);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}

/* ── RESPONSIVE ── */
@media(max-width:760px){
  .ac-detalle{grid-template-columns:1fr}
  .cart-cols{grid-template-columns:1fr}
  .resumen{position:static}
  .ac-tienda-hero h1{font-size:1.4rem}
}
@media(max-width:640px){
  .ac-header-inner{gap:10px}
  .ac-logo{order:1}
  .ac-search-wrap{order:2;flex:1 1 100%;min-width:0}
  .eco-tabs{top:auto;bottom:74px}
  .eco-tab{font-size:9px;padding:8px 4px}
  .eco-mundo{width:40px;height:40px;font-size:18px}
  .pub-tab{font-size:10px;padding:11px 5px}
  .ac-grid{grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:12px}
  .ac-card-img{height:140px}
}
@media(min-width:641px){.ac-filtros,.ac-sec,.ac-wrap{padding-right:52px}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.ac-card:hover{transform:none}}
