/* ══ HERO ══ */
.page-hero{background:linear-gradient(135deg,#1e2530 0%,#2d3548 55%,#3a1b18 100%);color:#fff;padding:44px 20px 40px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.hero-label{display:inline-block;background:rgba(192,57,43,.25);border:1px solid rgba(192,57,43,.4);color:#fca5a5;font-size:12px;font-weight:700;letter-spacing:.5px;padding:4px 12px;border-radius:20px;margin-bottom:12px;position:relative}
.page-hero h1{font-size:clamp(22px,4vw,32px);font-weight:800;margin-bottom:8px;position:relative}
.page-hero h1 span{color:#fca5a5}
.page-hero p{font-size:14px;color:rgba(255,255,255,.7);max-width:520px;margin:0 auto;position:relative}

/* ══ STATS ══ */
.stats-bar{background:var(--white);border-bottom:1px solid var(--border)}
.stats-bar-w{max-width:1240px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:repeat(4,1fr)}
@media(max-width:700px){.stats-bar-w{grid-template-columns:repeat(2,1fr)}}
.stat-item{padding:14px 16px;text-align:center;border-right:1px solid var(--border)}.stat-item:last-child{border-right:none}
.stat-item .si-icon{font-size:20px;margin-bottom:3px}
.stat-item .si-title{font-size:12.5px;font-weight:700;color:var(--text)}
.stat-item .si-sub{font-size:11px;color:var(--muted)}

/* ══ LAYOUT ══ */
.page-body{max-width:1240px;margin:28px auto;padding:0 20px;display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
@media(max-width:960px){.page-body{grid-template-columns:1fr}}

/* ══ MAIN COL ══ */
.main-col{display:flex;flex-direction:column;gap:20px}

/* Cabecera sección */
.cat-header{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cat-header-left h2{font-size:18px;font-weight:800}
.cat-header-left p{font-size:13px;color:var(--muted);margin-top:2px}
.cat-header-badge{background:#fef2f2;border:1px solid #fecaca;color:var(--red);font-size:12px;font-weight:700;padding:5px 12px;border-radius:20px;white-space:nowrap}

/* Toolbar */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.toolbar-search{position:relative;flex:1;min-width:180px}
.toolbar-search input{width:100%;padding:8px 34px 8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-s);font-size:13px;outline:none;background:var(--bg);transition:border-color .2s}
.toolbar-search input:focus{border-color:var(--red);background:var(--white)}
.toolbar-search span{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--muted);pointer-events:none}
.toolbar-count{font-size:13px;color:var(--muted);white-space:nowrap}
.sort-select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-s);font-size:13px;color:var(--text);background:var(--white);outline:none;cursor:pointer;transition:border-color .2s}
.sort-select:focus{border-color:var(--red)}

/* ══ GRID DE PRODUCTOS ══ */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
@media(max-width:540px){.prod-grid{grid-template-columns:repeat(2,1fr);gap:10px}}

.prod-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.13);border-color:#fecaca}

.prod-img{position:relative;overflow:hidden;background:#f0f0f0;aspect-ratio:4/3}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.prod-card:hover .prod-img img{transform:scale(1.05)}
.badge-vd{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:20px;letter-spacing:.3px}
.badge-stock{position:absolute;top:8px;right:8px;background:#22c55e;color:#fff;font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:20px}
.badge-sin-stock{position:absolute;top:8px;right:8px;background:red;color:#fff;font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:20px}

.prod-body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:8px}
.prod-body h3{font-size:13.5px;font-weight:700;color:var(--text);line-height:1.35}
.prod-price{display:flex;align-items:baseline;gap:6px}
.prod-price .price{font-size:20px;font-weight:800;color:var(--red)}
.prod-price .iva{font-size:11.5px;color:var(--muted);font-weight:500}
.prod-price .price-num{font-size:20px;font-weight:800;color:var(--red)}

.prod-actions{margin-top:auto;display:flex;flex-direction:column;gap:8px}
.btn-add-cart{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:linear-gradient(135deg,var(--red),var(--red-d));color:#fff;border:none;border-radius:var(--radius-s);font-size:13px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;width:100%}
.btn-add-cart:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(192,57,43,.35)}
.btn-add-cart:active{transform:none}
.btn-cotizar{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px;background:var(--green);color:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-s);font-size:12.5px;font-weight:600;cursor:pointer;transition:border-color .2s,color .2s;width:100%}
.btn-cotizar:hover{border-color:var(--green);color:var(--white)}

/* Toast carrito */
.toast{position:fixed;bottom:80px;right:24px;z-index:400;background:#1e2530;color:#fff;padding:12px 18px;border-radius:var(--radius-s);font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow);opacity:0;transform:translateY(10px);transition:opacity .3s,transform .3s;pointer-events:none}
.toast.show{opacity:1;transform:translateY(0)}

/* Sin resultados */
.no-results{display:none;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:40px;text-align:center;color:var(--muted)}
.no-results .nr-icon{font-size:36px;margin-bottom:10px}

/* CTA box */
.cta-box{background:linear-gradient(135deg,#1e2530,#2d3548);color:#fff;border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column;gap:14px}
.cta-box h3{font-size:16px;font-weight:700}
.cta-box p{font-size:13px;color:rgba(255,255,255,.7)}
.cta-btns{display:flex;gap:10px;flex-wrap:wrap}
.cta-btn-wa{background:var(--green);color:#fff;padding:10px 18px;border-radius:var(--radius-s);font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px;transition:background .2s}.cta-btn-wa:hover{background:#1ebe5d}
.cta-btn-mail{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);padding:10px 18px;border-radius:var(--radius-s);font-size:13px;font-weight:600;transition:background .2s}.cta-btn-mail:hover{background:rgba(255,255,255,.2)}

/* ══ SIDEBAR ══ */
.sidebar{display:flex;flex-direction:column;gap:20px}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card-head{padding:14px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.card-head .ch-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;background:#fee2e2}
.card-head h3{font-size:14px;font-weight:700}
.card-head p{font-size:12px;color:var(--muted)}
.card-body{padding:14px 18px}

/* Subcategorías sidebar */
.subcat-nav a{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--bg);font-size:13px;color:var(--muted);transition:color .15s}
.subcat-nav a:last-child{border-bottom:none}
.subcat-nav a:hover{color:var(--red)}
.subcat-nav a.current{color:var(--red);font-weight:700}
.subcat-nav a .sn-dot{width:5px;height:5px;border-radius:50%;background:#ddd;flex-shrink:0;transition:background .15s}
.subcat-nav a:hover .sn-dot,.subcat-nav a.current .sn-dot{background:var(--red)}

/* Otras categorías */
.other-cats a{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--bg);font-size:13px;color:var(--text);transition:color .15s}
.other-cats a:last-child{border-bottom:none}
.other-cats a:hover{color:var(--red)}
.other-cats a .oc-icon{font-size:15px;width:20px;text-align:center}
.other-cats a .oc-arr{margin-left:auto;font-size:12px;color:#ccc;transition:color .15s}
.other-cats a:hover .oc-arr,.other-cats a.active-cat .oc-arr{color:var(--red)}
.other-cats a.active-cat{color:var(--red);font-weight:700}

/* Contacto sidebar */
.contact-list li{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--bg)}.contact-list li:last-child{border-bottom:none}
.cl-icon{font-size:15px;width:20px;text-align:center;margin-top:1px;flex-shrink:0}
.cl-label{font-size:11px;color:var(--muted);font-weight:500}
.cl-val{font-size:13px;font-weight:600;color:var(--text)}.cl-val a{color:var(--red)}.cl-val a:hover{text-decoration:underline}
.wa-big-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--green);color:#fff;border-radius:var(--radius-s);padding:11px;font-size:13.5px;font-weight:700;width:100%;transition:background .2s,transform .15s}.wa-big-btn:hover{background:#1ebe5d;transform:translateY(-1px)}

/* Links útiles */
.links-list a{display:flex;align-items:center;gap:7px;padding:8px 0;border-bottom:1px solid var(--bg);font-size:13px;color:var(--muted);transition:color .15s}.links-list a:last-child{border-bottom:none}.links-list a:hover{color:var(--red)}

/* Newsletter */
.nl-form{display:flex;flex-direction:column;gap:10px}
.nl-input{padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius-s);font-size:13.5px;outline:none;background:var(--bg);transition:border-color .2s}.nl-input:focus{border-color:var(--red);background:var(--white)}
.nl-btn{padding:9px;background:var(--red);color:#fff;border:none;border-radius:var(--radius-s);font-size:13.5px;font-weight:700;cursor:pointer;transition:background .2s}.nl-btn:hover{background:var(--red-d)}

/* ══ FOOTER ══ */
.site-footer{background:#1e2530;color:#8a96a3;padding:48px 0 0;margin-top:48px;font-size:13.5px}
.footer-w{max-width:1240px;margin:0 auto;padding:0 20px 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:860px){.footer-w{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-w{grid-template-columns:1fr}}
.footer-brand img{height:34px;margin-bottom:12px;filter:brightness(0) invert(1);opacity:.8}
.footer-brand p{font-size:13px;line-height:1.7;color:#657585;margin-bottom:14px}
.footer-brand ul li{display:flex;gap:8px;margin-bottom:7px;font-size:13px}.footer-brand ul a:hover{color:#fff}
.footer-col h4{color:#fff;font-size:13px;font-weight:700;margin-bottom:13px;padding-bottom:7px;border-bottom:1px solid #2e3a4a}
.footer-col ul li{margin-bottom:7px}
.footer-col ul a{color:#657585;font-size:13px;transition:color .18s}.footer-col ul a:hover{color:#fff}
.footer-bottom{background:#151b25;padding:15px 20px;text-align:center;font-size:12.5px;color:#454f5e;border-top:1px solid #2e3a4a}
.footer-bottom a{color:#454f5e}.footer-bottom a:hover{color:#fff}

/* ══ WHATSAPP FLOTANTE ══ */
.float-wa{position:fixed;bottom:24px;right:24px;z-index:250;background:var(--green);color:#fff;border-radius:50px;padding:12px 18px;display:flex;align-items:center;gap:9px;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform .2s,box-shadow .2s;font-size:13px;font-weight:700}.float-wa:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.float-wa .fw-text strong{display:block;font-size:13.5px}.float-wa .fw-text span{font-size:11.5px;opacity:.85}

@media(max-width:640px){
  .page-hero{padding:32px 16px}
  .card-body{padding:12px 14px}
  .float-wa .fw-text{display:none}
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .prod-price .price-num{font-size:17px}
}
.subcat-nav, .other-cats, .links-list{
    background: #fff;
}