:root {
  --rojo: #C8281E;
  --rojo-dark: #A01F17;
  --rojo-light: #E8433A;
  --blanco: #ffffff;
  --gris-claro: #F7F7F5;
  --gris: #E8E8E4;
  --gris-texto: #666660;
  --negro: #1A1A18;
  --dorado: #C89A2A;
  --crema: #FBF6ED;
  --nav-h: 80px;
  --topbar-h: 38px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Montserrat',sans-serif;background:var(--blanco);color:var(--negro);overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;}

.topbar{height:var(--topbar-h);background:var(--rojo);display:flex;align-items:center;justify-content:space-between;padding:0 48px;font-size:12px;color:rgba(255,255,255,0.9);letter-spacing:0.3px;}
.topbar-left{display:flex;gap:24px;align-items:center;}
.topbar-left span{display:flex;align-items:center;gap:6px;}
.topbar-right{display:flex;gap:12px;align-items:center;}
.topbar-social{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid rgba(255,255,255,0.4);border-radius:4px;font-size:13px;font-weight:700;transition:background .2s,border-color .2s;cursor:pointer;}
.topbar-social:hover{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.7);}

.navbar{height:var(--nav-h);background:var(--blanco);display:flex;align-items:center;padding:0 48px;box-shadow:0 2px 16px rgba(0,0,0,0.07);position:sticky;top:0;z-index:200;gap:32px;}
.logo-wrap{display:flex;align-items:center;gap:14px;flex:0 0 auto;}
.logo-badge{width:54px;height:54px;background:var(--rojo);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:white;font-weight:900;font-size:10px;letter-spacing:0.5px;line-height:1.4;text-transform:uppercase;}
.logo-badge span:first-child{font-size:16px;font-family:'Lora',serif;font-weight:600;font-style:italic;}
.logo-text strong{display:block;font-size:15px;font-weight:800;color:var(--rojo-dark);letter-spacing:-0.3px;}
.logo-text em{display:block;font-size:10.5px;color:var(--gris-texto);font-style:normal;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;margin-top:2px;}
.nav-menu{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;}
.nav-item{position:relative;}
.nav-link{display:flex;align-items:center;gap:5px;padding:8px 18px;font-size:13px;font-weight:600;color:var(--negro);letter-spacing:0.3px;text-transform:uppercase;border-bottom:3px solid transparent;transition:all .2s;cursor:pointer;white-space:nowrap;}
.nav-link:hover,.nav-link.active{color:var(--rojo);border-bottom-color:var(--rojo);}
.dropdown{position:absolute;top:100%;left:0;background:white;border-top:3px solid var(--rojo);box-shadow:0 8px 32px rgba(0,0,0,0.12);min-width:220px;opacity:0;pointer-events:none;transform:translateY(8px);transition:all .22s;z-index:300;}
.nav-item:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0);}
.dropdown a{display:block;padding:12px 20px;font-size:13px;font-weight:500;color:var(--negro);border-bottom:1px solid var(--gris);transition:background .15s,color .15s;cursor:pointer;}
.dropdown a:last-child{border-bottom:none;}
.dropdown a:hover{background:var(--crema);color:var(--rojo);}
.nav-right{display:flex;align-items:center;gap:12px;}
.btn-cart{display:flex;align-items:center;gap:8px;background:var(--rojo);color:white;border:none;cursor:pointer;padding:10px 20px;border-radius:6px;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;letter-spacing:0.3px;transition:background .2s,transform .15s;position:relative;}
.btn-cart:hover{background:var(--rojo-dark);transform:translateY(-1px);}
.cart-badge{background:var(--dorado);color:white;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;}

.hero{position:relative;width:100%;height:520px;overflow:hidden;background:#111;}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .9s ease;display:flex;align-items:center;}
.slide.active{opacity:1;}
.slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);transition:transform 8s ease;}
.slide.active .slide-bg{transform:scale(1);}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,8,8,.72) 0%,rgba(10,8,8,.25) 55%,transparent 100%);}
.slide-content{position:relative;z-index:2;padding:0 80px;max-width:680px;}
.slide-tag{display:inline-block;background:var(--rojo);color:white;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:2px;margin-bottom:18px;}
.slide-content h1{font-family:'Lora',serif;font-size:54px;font-weight:600;color:white;line-height:1.12;margin-bottom:14px;text-shadow:0 2px 12px rgba(0,0,0,.3);}
.slide-content p{font-size:17px;color:rgba(255,255,255,.85);font-weight:300;margin-bottom:28px;line-height:1.6;}
.slide-cta{display:inline-flex;align-items:center;gap:10px;background:var(--rojo);color:white;padding:14px 30px;border-radius:5px;font-size:14px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;transition:all .2s;cursor:pointer;border:none;font-family:'Montserrat',sans-serif;}
.slide-cta:hover{background:var(--rojo-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,40,30,.35);}
.hero-nav{position:absolute;bottom:28px;left:80px;display:flex;gap:10px;z-index:3;}
.hero-dot{width:32px;height:4px;border-radius:2px;background:rgba(255,255,255,.35);cursor:pointer;transition:all .3s;}
.hero-dot.active{background:var(--rojo);width:48px;}
.hero-arrows{position:absolute;right:48px;bottom:24px;display:flex;gap:8px;z-index:3;}
.hero-arrow{width:44px;height:44px;border:2px solid rgba(255,255,255,.5);background:transparent;color:white;font-size:18px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.hero-arrow:hover{background:var(--rojo);border-color:var(--rojo);}

.section-header{text-align:center;margin-bottom:48px;}
.section-eyebrow{display:inline-block;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--rojo);margin-bottom:12px;}
.section-header h2{font-family:'Lora',serif;font-size:38px;font-weight:600;color:var(--negro);line-height:1.2;margin-bottom:14px;}
.section-header p{font-size:16px;color:var(--gris-texto);font-weight:300;max-width:580px;margin:0 auto;line-height:1.7;}
.divider{width:48px;height:3px;background:var(--rojo);margin:16px auto 0;}

.quienes{display:grid;grid-template-columns:1fr 1fr;min-height:480px;}
.quienes-img{position:relative;overflow:hidden;background:linear-gradient(135deg,#8B2010 0%,#C8281E 40%,#E8A080 100%);display:flex;align-items:center;justify-content:center;font-size:120px;}
.quienes-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.1) 0%,transparent 60%);}
.quienes-body{background:var(--crema);padding:80px 64px;display:flex;flex-direction:column;justify-content:center;}
.quienes-body .section-eyebrow{text-align:left;}
.quienes-body h2{font-family:'Lora',serif;font-size:40px;font-weight:600;color:var(--negro);margin-bottom:20px;line-height:1.2;}
.quienes-body p{font-size:16px;color:var(--gris-texto);line-height:1.8;margin-bottom:16px;font-weight:300;}
.quienes-stats{display:flex;gap:40px;margin-top:32px;}
.stat{border-left:3px solid var(--rojo);padding-left:16px;}
.stat-num{font-size:36px;font-weight:800;color:var(--rojo);line-height:1;}
.stat-label{font-size:12px;color:var(--gris-texto);font-weight:500;letter-spacing:0.5px;margin-top:4px;text-transform:uppercase;}
.btn-outline{display:inline-flex;align-items:center;gap:8px;margin-top:32px;border:2px solid var(--rojo);color:var(--rojo);padding:12px 24px;font-size:13px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;border-radius:4px;transition:all .2s;cursor:pointer;width:fit-content;background:transparent;}
.btn-outline:hover{background:var(--rojo);color:white;}

.marcas-section{background:var(--gris-claro);padding:72px 48px;}
.marcas-grid{display:flex;justify-content:center;align-items:stretch;gap:24px;flex-wrap:wrap;max-width:900px;margin:0 auto;}
.marca-card{background:white;border-radius:12px;padding:40px 48px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 16px rgba(0,0,0,.06);flex:1;min-width:200px;max-width:260px;transition:all .25s;cursor:pointer;border:2px solid transparent;}
.marca-card:hover{border-color:var(--rojo);transform:translateY(-4px);box-shadow:0 10px 32px rgba(200,40,30,.12);}
.marca-icon{font-size:52px;margin-bottom:16px;}
.marca-name{font-family:'Lora',serif;font-size:20px;font-weight:600;color:var(--negro);text-align:center;margin-bottom:6px;}
.marca-desc{font-size:12px;color:var(--gris-texto);text-align:center;line-height:1.5;font-weight:400;}

/* ── BANNER CATÁLOGO ── */
.cat-hero{position:relative;height:320px;display:flex;align-items:center;justify-content:center;text-align:center;background-size:cover;background-position:center;background-color:var(--negro);}
.cat-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(44,10,5,.75),rgba(200,40,30,.55));}
.cat-hero-content{position:relative;z-index:1;padding:0 24px;}
.cat-hero-tag{display:inline-block;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--rojo-light,#f87171);font-weight:600;margin-bottom:14px;}
.cat-hero-content h2{font-family:'Lora',serif;font-size:48px;font-weight:600;color:white;margin:0 0 12px;}
.cat-hero-content p{font-size:16px;color:rgba(255,255,255,.75);font-weight:300;margin:0;}
@media(max-width:768px){.cat-hero{height:220px;}.cat-hero-content h2{font-size:30px;}}

.catalogo-section{padding:80px 48px;background:white;}
.cat-filters{display:flex;justify-content:center;gap:10px;margin-bottom:48px;flex-wrap:wrap;}
.filter-btn{padding:10px 24px;border-radius:30px;border:2px solid var(--gris);background:white;font-size:13px;font-weight:600;cursor:pointer;font-family:'Montserrat',sans-serif;color:var(--gris-texto);transition:all .2s;letter-spacing:0.3px;}
.filter-btn:hover,.filter-btn.active{border-color:var(--rojo);background:var(--rojo);color:white;}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.prod-card{border-radius:12px;overflow:hidden;border:1px solid var(--gris);background:white;transition:all .25s;cursor:pointer;}
.prod-card:hover{transform:translateY(-5px);box-shadow:0 14px 40px rgba(0,0,0,.1);border-color:transparent;}
.prod-img{height:200px;display:flex;align-items:center;justify-content:center;font-size:60px;position:relative;overflow:hidden;}
.prod-tag-badge{position:absolute;top:12px;left:12px;background:var(--rojo);color:white;font-size:10px;font-weight:700;letter-spacing:1px;padding:4px 10px;border-radius:20px;text-transform:uppercase;}
.prod-body{padding:20px;}
.prod-marca{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--rojo);margin-bottom:6px;}
.prod-body h3{font-family:'Lora',serif;font-size:18px;font-weight:600;color:var(--negro);margin-bottom:4px;}
.prod-pres{font-size:12px;color:var(--gris-texto);margin-bottom:12px;line-height:1.5;}
.prod-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--gris);}
.prod-precio{font-size:20px;font-weight:800;color:var(--rojo);}
.btn-add{background:var(--rojo);color:white;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:20px;font-weight:700;font-family:'Montserrat',sans-serif;}
.btn-add:hover{background:var(--rojo-dark);transform:scale(1.1);}

.nosotros-strip{background:var(--rojo);color:white;padding:80px 48px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;}
.strip-item{padding:0 48px;display:flex;flex-direction:column;align-items:center;text-align:center;border-right:1px solid rgba(255,255,255,.2);}
.strip-item:last-child{border-right:none;}
.strip-icon{font-size:42px;margin-bottom:16px;opacity:.9;}
.strip-item h3{font-family:'Lora',serif;font-size:22px;font-weight:600;margin-bottom:12px;}
.strip-item p{font-size:14px;opacity:.8;line-height:1.7;font-weight:300;}

.historia-section{background:var(--crema);padding:80px 48px;}
.timeline{max-width:900px;margin:0 auto;position:relative;}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--gris);transform:translateX(-50%);}
.tl-item{display:flex;gap:48px;align-items:flex-start;margin-bottom:48px;position:relative;}
.tl-item:nth-child(odd){flex-direction:row;}
.tl-item:nth-child(even){flex-direction:row-reverse;}
.tl-item:nth-child(odd) .tl-body{text-align:right;}
.tl-item:nth-child(even) .tl-body{text-align:left;}
.tl-body{flex:1;}
.tl-year{font-size:38px;font-weight:900;color:var(--rojo);font-family:'Montserrat',sans-serif;line-height:1;margin-bottom:8px;}
.tl-body h4{font-size:16px;font-weight:700;color:var(--negro);margin-bottom:6px;}
.tl-body p{font-size:14px;color:var(--gris-texto);line-height:1.7;font-weight:300;}
.tl-dot-wrap{flex:0 0 auto;width:48px;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;padding-top:6px;}
.tl-dot{width:20px;height:20px;border-radius:50%;background:var(--rojo);border:4px solid white;box-shadow:0 0 0 3px var(--rojo);}

.contacto-section{padding:80px 48px;background:white;}
.contacto-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;max-width:1100px;margin:0 auto;}
.contacto-info h3{font-family:'Lora',serif;font-size:28px;font-weight:600;color:var(--negro);margin-bottom:24px;}
.ci-item{display:flex;gap:16px;margin-bottom:24px;}
.ci-icon{width:44px;height:44px;background:var(--crema);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.ci-item strong{display:block;font-size:14px;font-weight:700;color:var(--negro);margin-bottom:3px;}
.ci-item span{font-size:14px;color:var(--gris-texto);}
.mapa-placeholder{background:var(--gris-claro);border-radius:12px;height:180px;margin-top:24px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gris-texto);border:2px dashed var(--gris);flex-direction:column;gap:8px;}
.form-card{background:var(--gris-claro);border-radius:16px;padding:44px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:12px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:var(--negro);margin-bottom:8px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid transparent;background:white;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:14px;color:var(--negro);transition:border-color .2s;outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--rojo);}
.form-group textarea{height:110px;resize:vertical;}
.policy-box{background:white;border-radius:8px;padding:14px 16px;font-size:12px;color:var(--gris-texto);line-height:1.6;margin-bottom:16px;border-left:3px solid var(--rojo);}
.check-row{display:flex;align-items:center;gap:10px;margin-bottom:20px;cursor:pointer;}
.check-row input{width:16px;height:16px;accent-color:var(--rojo);}
.check-row span{font-size:13px;color:var(--negro);font-weight:500;}
.btn-submit{width:100%;background:var(--rojo);color:white;border:none;cursor:pointer;padding:15px;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;transition:all .2s;}
.btn-submit:hover{background:var(--rojo-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,40,30,.3);}

footer{background:#111;color:rgba(255,255,255,.75);}
.footer-top{padding:60px 48px 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:48px;}
.footer-logo{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.footer-logo-badge{width:50px;height:50px;background:var(--rojo);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:white;font-weight:900;font-size:9px;letter-spacing:0.5px;text-transform:uppercase;}
.footer-logo-badge span:first-child{font-size:14px;font-family:'Lora',serif;font-style:italic;font-weight:600;}
.footer-col-title{font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:white;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--rojo);display:inline-block;}
.footer-col p{font-size:13px;line-height:1.9;}
.footer-col a{display:block;font-size:13px;line-height:2;color:rgba(255,255,255,.65);transition:color .2s;}
.footer-col a:hover{color:var(--rojo);}
.footer-social{display:flex;gap:10px;margin-top:20px;}
.f-social{width:36px;height:36px;border:1px solid rgba(255,255,255,.2);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:rgba(255,255,255,.7);transition:all .2s;cursor:pointer;}
.f-social:hover{background:var(--rojo);border-color:var(--rojo);color:white;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 48px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,.35);}

.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:400;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(2px);}
.cart-overlay.open{opacity:1;pointer-events:all;}
.cart-panel{position:fixed;top:0;right:-460px;width:460px;height:100vh;background:white;z-index:401;transition:right .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;}
.cart-panel.open{right:0;}
.cart-head{background:var(--rojo);color:white;padding:24px 28px;display:flex;justify-content:space-between;align-items:center;}
.cart-head h3{font-family:'Lora',serif;font-size:22px;font-weight:600;}
.cart-close{background:none;border:none;color:white;font-size:24px;cursor:pointer;line-height:1;padding:2px 6px;}
.cart-close:hover{opacity:.7;}
.cart-body{flex:1;overflow-y:auto;padding:24px 28px;}
.cart-empty-state{text-align:center;padding:60px 20px;}
.cart-empty-state .empty-emoji{font-size:56px;margin-bottom:16px;}
.cart-empty-state p{font-size:15px;color:var(--gris-texto);}
.c-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--gris);}
.c-item-icon{font-size:38px;flex-shrink:0;}
.c-item-info{flex:1;}
.c-item-info h4{font-size:15px;font-weight:600;color:var(--negro);margin-bottom:2px;}
.c-marca{font-size:11px;color:var(--gris-texto);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:6px;}
.c-item-price{font-size:16px;font-weight:800;color:var(--rojo);}
.c-item-qty{display:flex;align-items:center;gap:10px;margin-top:8px;}
.qty-btn{width:28px;height:28px;border-radius:50%;border:2px solid var(--rojo);background:white;color:var(--rojo);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:'Montserrat',sans-serif;}
.qty-btn:hover{background:var(--rojo);color:white;}
.qty-n{font-size:15px;font-weight:700;min-width:22px;text-align:center;}
.c-del{background:none;border:none;cursor:pointer;color:#ccc;font-size:20px;padding:4px;transition:color .2s;}
.c-del:hover{color:var(--rojo);}
.cart-foot{padding:20px 28px;border-top:2px solid var(--gris);}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.cart-total-row span{font-size:15px;color:var(--gris-texto);font-weight:500;}
.cart-total-row strong{font-size:26px;font-weight:900;color:var(--rojo);font-family:'Lora',serif;}
.btn-wa{width:100%;background:#25D366;color:white;border:none;cursor:pointer;padding:16px;border-radius:10px;font-family:'Montserrat',sans-serif;font-size:15px;font-weight:800;letter-spacing:0.5px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s;}
.btn-wa:hover{background:#128C7E;transform:translateY(-2px);}
.btn-wa:disabled{background:#bbb;cursor:not-allowed;transform:none;}

.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--negro);color:white;padding:13px 28px;border-radius:30px;font-size:14px;font-weight:600;z-index:600;transition:transform .3s;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.25);}
.toast.show{transform:translateX(-50%) translateY(0);}

@media(max-width:900px){
  .topbar{padding:0 16px;font-size:10px;}
  .navbar{padding:0 16px;gap:12px;}
  .nav-link{padding:6px 10px;font-size:11px;}
  .logo-text{display:none;}
  .slide-content{padding:0 32px;}
  .slide-content h1{font-size:34px;}
  .quienes{grid-template-columns:1fr;}
  .quienes-img{height:240px;}
  .prod-grid{grid-template-columns:repeat(2,1fr);}
  .nosotros-strip{grid-template-columns:1fr;}
  .strip-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.2);padding:32px;}
  .contacto-grid,.footer-top{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .cart-panel{width:100%;right:-100%;}
  .timeline::before{left:24px;}
  .tl-item,.tl-item:nth-child(even){flex-direction:row;gap:24px;}
  .tl-item:nth-child(odd) .tl-body,.tl-item:nth-child(even) .tl-body{text-align:left;}
  .tl-dot-wrap{width:24px;}
  .catalogo-section{padding:48px 16px;}
  .contacto-section{padding:32px 16px;}
}

/* ── HAMBURGUESA ── */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:4px;order:-1;}
.hamburger span{display:block;width:22px;height:2px;background:var(--negro);border-radius:2px;transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:149;}
.mobile-overlay.open{display:block;}

@media(max-width:768px){
  .hamburger{display:flex;}
  .nav-menu{
    display:none !important;
    flex-direction:column !important;
    position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;
    background:white;z-index:150;
    box-shadow:0 8px 24px rgba(0,0,0,.12);
    padding:8px 0;overflow-y:auto;
  }
  .nav-menu.open{display:flex !important;}
  .nav-item{width:100%;border-bottom:1px solid #f0f0f0;}
  .nav-link{width:100%;padding:16px 24px;font-size:15px;border-bottom:none;}
  .nav-link:hover,.nav-link.active{background:#fef5f5;color:var(--rojo);}
  .dropdown{display:none !important;}
  .logo-text{display:none;}
}

/* ── MÓVIL PEQUEÑO ── */
@media(max-width:480px){
  /* Topbar: ocultar info, solo redes */
  .topbar-left{display:none;}
  .topbar{justify-content:flex-end;padding:0 12px;}

  /* Navbar compacto */
  .navbar{padding:0 12px;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .navbar::-webkit-scrollbar{display:none;}
  .nav-link{padding:6px 8px;font-size:10px;letter-spacing:0;white-space:nowrap;flex-shrink:0;}

  /* Carrito */
  .cart-btn{padding:8px 12px;font-size:12px;}

  /* Hero más bajo en móvil */
  .hero{height:340px;}
  .slide-content{padding:0 20px;max-width:100%;}
  .slide-content h1{font-size:24px;margin-bottom:10px;}
  .slide-content p{font-size:13px;margin-bottom:18px;}
  .slide-cta{padding:10px 20px;font-size:12px;}
  .hero-nav{left:20px;bottom:16px;}
  .hero-arrows{right:16px;bottom:12px;}
  .hero-arrow{width:36px;height:36px;font-size:14px;}

  /* Banner catálogo */
  .cat-hero{height:180px;}
  .cat-hero-content h2{font-size:22px;}
  .cat-hero-content p{font-size:12px;}

  /* Productos: 1 columna en pantalla muy pequeña */
  .prod-grid{grid-template-columns:1fr;}
  .prod-card{display:flex;flex-direction:row;gap:0;}
  .prod-img{width:100px;min-width:100px;height:100px;border-radius:12px 0 0 12px;}
  .prod-body{padding:12px;}
  .prod-body h3{font-size:13px;}

  /* Marcas grid */
  .marcas-grid{grid-template-columns:1fr;}

  /* Secciones con menos padding */
  .catalogo-section{padding:32px 12px;}
  .cat-filters{gap:6px;}
  .filter-btn{padding:7px 14px;font-size:11px;}

  /* Footer */
  .footer-top{gap:24px;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}

  /* Cart panel full width */
  .cart-panel{width:100%;right:-100%;}
  .cart-header{padding:16px;}
  .cart-body{padding:12px;}
}
