:root{--red:#8f1d18;--red-dark:#67110e;--gold:#d99728;--cream:#fff7e8;--paper:#fffdf8;--ink:#261f1b;--muted:#665b52;--line:#eadcc7;--green:#187a45;--shadow:0 18px 46px rgba(38,31,27,.10)}*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:var(--paper);line-height:1.55}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.topbar{display:flex;justify-content:center;gap:22px;padding:8px 16px;background:var(--red-dark);color:#fff;font-size:14px}.topbar a{text-decoration:underline;text-underline-offset:3px}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,253,248,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(12px)}.nav-wrap{display:grid;grid-template-columns:auto auto minmax(320px,1fr) minmax(200px,300px) auto auto;gap:14px;align-items:center;max-width:1240px;margin:0 auto;padding:10px 20px}.brand{display:flex;align-items:center}.brand img{width:170px;height:auto;max-height:76px;object-fit:contain}.main-nav{display:flex;align-items:center;gap:16px;font-weight:700;font-size:14px}.main-nav a:hover,.category-strip a:hover,.footer-links a:hover{color:var(--red)}.search{display:flex;align-items:center;gap:8px;min-width:0;padding:0 12px;border:1px solid var(--line);border-radius:6px;background:#fff}.search svg,.cart-link svg,.icon-button svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.search input{width:100%;min-width:0;border:0;outline:0;padding:11px 0;font:inherit}.header-action,.button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;border-radius:6px;border:1px solid transparent;font-weight:800;cursor:pointer;font-size:14px}.whatsapp,.primary{background:var(--green);color:#fff}.secondary{background:var(--red);color:#fff}.ghost{background:#fff;border-color:var(--line);color:var(--ink)}.wa-button,.wa-inline{display:inline-flex;align-items:center;justify-content:center;gap:7px}.wa-logo{width:26px;height:26px;flex:0 0 26px;object-fit:contain}.wa-icon-only{width:50px;min-width:50px;height:50px;min-height:50px;padding:6px;border-radius:8px;background:transparent;box-shadow:none}.wa-icon-only .wa-logo{width:38px;height:38px;flex-basis:38px}.header-action.wa-icon-only{border:0}.floating-wa.wa-icon-only{right:18px;bottom:18px}.wa-inline{color:var(--green);font-weight:900}.cart-link{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-width:48px;min-height:42px;border:1px solid var(--line);border-radius:6px;background:#fff;font-weight:800}.menu-toggle{display:none;background:#fff;border:1px solid var(--line);border-radius:6px;color:var(--ink);min-height:42px;min-width:42px}.category-strip{display:flex;gap:10px;overflow-x:auto;max-width:1240px;margin:0 auto;padding:0 20px 12px;scrollbar-width:thin}.category-strip a{flex:0 0 auto;padding:7px 12px;border:1px solid var(--line);border-radius:999px;background:var(--cream);font-size:13px;font-weight:700}.hero-shop{display:grid;grid-template-columns:minmax(0,1fr) 46%;align-items:center;gap:38px;min-height:560px;max-width:1240px;margin:0 auto;padding:48px 20px 34px}.hero-copy h1{margin:0 0 12px;font-family:Georgia,'Times New Roman',serif;font-size:clamp(46px,8vw,88px);line-height:.94;color:var(--red);letter-spacing:0}.hero-copy p{max-width:650px;font-size:19px;color:var(--muted)}.hero-media img{aspect-ratio:1;object-fit:cover;border-radius:8px;box-shadow:var(--shadow)}.hero-actions,.card-actions,.detail-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.eyebrow{margin:0 0 8px;color:var(--red);font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:0}.section{max-width:1240px;margin:0 auto;padding:46px 20px}.band{max-width:none;background:var(--cream);border-block:1px solid var(--line)}.metric-row{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.metric-row div{display:grid;gap:2px}.metric-row strong{font-size:28px;color:var(--red)}.metric-row span{color:var(--muted)}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:20px}.section-heading h2,.content-page h2,.cart-box h2,.checkout-form h2{margin:0;font-size:28px;line-height:1.15}.section-heading a{color:var(--red);font-weight:800}.product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.product-card{display:grid;grid-template-rows:auto 1fr;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff;min-width:0}.product-card .product-image{display:block;aspect-ratio:1;background:var(--cream);overflow:hidden}.related-products .product-card .product-image{aspect-ratio:1}.product-card img{width:100%;height:100%;aspect-ratio:1;object-fit:cover;transition:transform .2s ease}.product-card:hover img{transform:scale(1.025)}.product-info{padding:14px;display:flex;flex-direction:column;gap:8px}.product-info h2{margin:0;font-size:18px;line-height:1.2}.product-info p{margin:0;color:var(--muted)}.price{color:var(--red);font-size:21px}.detail-link{color:var(--green);font-weight:800;font-size:14px}.category-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.category-tile{position:relative;overflow:hidden;min-height:190px;border-radius:8px;background:var(--red);color:#fff;box-shadow:var(--shadow)}.category-tile img{width:100%;height:190px;object-fit:cover;filter:brightness(.72)}.category-tile span,.category-tile small{position:absolute;left:14px;right:14px;z-index:1}.category-tile span{bottom:34px;font-weight:900;font-size:18px;line-height:1.15}.category-tile small{bottom:12px}.split{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:28px;align-items:start}.split h2,.page-hero h1{margin:0 0 12px;font-size:clamp(32px,5vw,54px);line-height:1.02;color:var(--red);font-family:Georgia,'Times New Roman',serif}.info-panel,.cart-box,.checkout-form{border:1px solid var(--line);border-radius:8px;background:#fff;padding:20px;box-shadow:var(--shadow)}.page-hero{max-width:1240px;margin:0 auto;padding:54px 20px 30px}.page-hero.compact{min-height:250px;display:flex;flex-direction:column;justify-content:center}.page-hero p{max-width:780px;color:var(--muted);font-size:18px}.shop-tools{max-width:1240px;margin:0 auto;padding:0 20px 12px;display:grid;grid-template-columns:minmax(260px,1fr) 260px auto;gap:12px;align-items:end}.shop-tools label,.checkout-form label{display:grid;gap:6px;color:var(--muted);font-weight:700}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:6px;padding:12px;font:inherit;color:var(--ink);background:#fff}.product-detail{max-width:1240px;margin:0 auto;padding:48px 20px;display:grid;grid-template-columns:48% minmax(0,1fr);gap:38px;align-items:start}.detail-media{aspect-ratio:1;background:var(--cream);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}.detail-media img{width:100%;height:100%;aspect-ratio:1;object-fit:cover}.detail-copy h1{margin:0 0 12px;font-size:clamp(34px,5vw,60px);line-height:1.02;color:var(--red);font-family:Georgia,'Times New Roman',serif}.spec-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:22px 0}.spec-list div{border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--cream)}.spec-list dt{color:var(--muted);font-weight:800;font-size:13px}.spec-list dd{margin:2px 0 0;font-weight:900}.notice{color:var(--muted);font-size:14px}.cart-layout{max-width:1240px;margin:0 auto;padding:20px;display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:22px;align-items:start}.cart-item{display:grid;grid-template-columns:76px minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}.cart-item img{width:76px;height:76px;border-radius:6px;object-fit:cover}.cart-item h3{margin:0;font-size:17px}.qty-control{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#fff}.qty-control button{width:34px;height:34px;border:0;background:var(--cream);cursor:pointer;font-weight:900}.qty-control span{width:38px;text-align:center;font-weight:900}.remove-btn{border:0;background:transparent;color:var(--red);font-weight:900;cursor:pointer}.cart-summary{margin-top:18px;padding-top:18px;border-top:2px solid var(--line)}.cart-summary strong{color:var(--red);font-size:28px}.checkout-form{display:grid;gap:13px}.full{width:100%}.content-page{max-width:900px;margin:0 auto;padding:20px 20px 60px;font-size:18px}.info-grid,.contact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:24px}.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.info-grid>div,.contact-grid section{border:1px solid var(--line);border-radius:8px;background:#fff;padding:18px}.sitemap-list{columns:2}.site-footer{margin-top:40px;background:#211915;color:#fff7e8}.footer-grid{max-width:1240px;margin:0 auto;padding:44px 20px;display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:26px}.footer-grid h2{margin:0 0 10px;font-size:18px;color:#f5c56b}.footer-links{display:grid;gap:8px}.copyright{border-top:1px solid rgba(255,255,255,.16);text-align:center;padding:16px;font-size:14px}.copyright a{color:#f5c56b;font-weight:900;text-decoration:underline;text-underline-offset:3px}.floating-wa{position:fixed;right:18px;bottom:18px;z-index:40;background:var(--green);color:#fff;border-radius:999px;padding:12px 18px;box-shadow:var(--shadow);font-weight:900}.empty-cart{padding:22px;background:var(--cream);border-radius:8px;border:1px solid var(--line)}@media(max-width:1060px){.nav-wrap{grid-template-columns:auto auto 1fr auto}.main-nav{grid-column:1/-1;display:none;flex-wrap:wrap;padding-top:8px}.main-nav.is-open{display:flex}.menu-toggle{display:inline-flex;align-items:center;justify-content:center}.search{grid-column:3/4}.header-action{display:none}.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.hero-shop,.product-detail,.cart-layout{grid-template-columns:1fr}.hero-media{order:-1}.metric-row{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.topbar{display:grid;gap:3px;text-align:center;font-size:12px}.nav-wrap{grid-template-columns:auto 42px 42px;gap:10px;padding:10px 14px}.brand img{width:118px;max-height:58px}.search{grid-column:1/-1;grid-row:2}.hero-shop{min-height:auto;padding-top:22px;gap:20px}.hero-copy h1{font-size:48px}.section-heading{display:grid;align-items:start}.product-grid,.category-grid,.metric-row,.info-grid,.contact-grid,.footer-grid,.shop-tools,.split,.spec-list{grid-template-columns:1fr}.product-card{grid-template-columns:1fr;grid-template-rows:auto 1fr}.product-card img{height:100%;min-height:0}.card-actions{display:grid;grid-template-columns:1fr}.cart-item{grid-template-columns:60px minmax(0,1fr)}.cart-item>div:last-child{grid-column:2;justify-self:start}.sitemap-list{columns:1}.floating-wa{right:12px;bottom:12px}}
/* =========================================================
   Ajustes Keduin 2026-06-03
   Corrección de imágenes cuadradas, tarjetas y WhatsApp
   ========================================================= */

/* Tarjetas parejas y estructura estable */
.product-grid{
  align-items: stretch;
}
.product-card{
  display: flex !important;
  flex-direction: column !important;
  height: 100%;
}
.product-card .product-image{
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  background: #fff8ef !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.product-card .product-image > img{
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
}
.product-info{
  flex: 1 1 auto !important;
}
.card-actions,
.detail-actions,
.hero-actions{
  align-items: center !important;
}
.card-actions{
  margin-top: auto !important;
}

/* Fichas individuales: imagen cuadrada sin cortar diseños con texto/logo */
.detail-media{
  aspect-ratio: 1 / 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #fff8ef !important;
}
.detail-media img{
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Categorías también cuadradas */
.category-tile{
  aspect-ratio: 1 / 1 !important;
  min-height: unset !important;
}
.category-tile img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Botones profesionales y consistentes */
.button,
.header-action,
.cart-link,
.product-btn,
.whatsapp-btn,
.detail-whatsapp-btn{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  line-height: 1.2 !important;
  white-space: normal;
}
.card-actions .button{
  flex: 1 1 auto;
  min-width: 140px;
}
.wa-button,
.wa-inline{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
}

/* Íconos de WhatsApp: nunca deben heredar estilos de imágenes de producto */
.wa-logo,
.button .wa-logo,
.header-action .wa-logo,
.wa-button .wa-logo,
.wa-inline .wa-logo,
.product-card .wa-logo,
.detail-actions .wa-logo,
.checkout-form .wa-logo{
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  max-width: 20px !important;
  min-height: 20px !important;
  max-height: 20px !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: contain !important;
  flex: 0 0 20px !important;
  display: inline-block !important;
  transform: none !important;
}
.product-card:hover .wa-logo,
.product-card:hover .button img,
.product-card:hover .wa-inline img{
  transform: none !important;
}

/* Botón WhatsApp solo ícono en header */
.wa-icon-only,
.header-action.wa-icon-only{
  width: 46px !important;
  min-width: 46px !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  background: var(--green) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.wa-icon-only .wa-logo,
.header-action.wa-icon-only .wa-logo{
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  max-width: 24px !important;
  min-height: 24px !important;
  max-height: 24px !important;
  flex: 0 0 24px !important;
}

/* Botón flotante WhatsApp */
.floating-wa,
.floating-whatsapp,
.whatsapp-floating{
  position: fixed !important;
  right: 18px !important;
  bottom: 18px !important;
  width: 54px !important;
  min-width: 54px !important;
  height: 54px !important;
  min-height: 54px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--green) !important;
  color: #fff !important;
  z-index: 999 !important;
  box-shadow: 0 8px 22px rgba(0,0,0,.18) !important;
}
.floating-wa .wa-logo,
.floating-whatsapp .wa-logo,
.whatsapp-floating .wa-logo,
.floating-wa img,
.floating-whatsapp img,
.whatsapp-floating img{
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  max-width: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
  flex: 0 0 28px !important;
  object-fit: contain !important;
  transform: none !important;
}

/* Evitar que los botones con íconos se rompan en móvil */
@media(max-width:720px){
  .product-grid{
    grid-template-columns: 1fr !important;
  }
  .card-actions{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .floating-wa,
  .floating-whatsapp,
  .whatsapp-floating{
    width: 48px !important;
    min-width: 48px !important;
    height: 48px !important;
    min-height: 48px !important;
    right: 14px !important;
    bottom: 14px !important;
  }
  .floating-wa .wa-logo,
  .floating-whatsapp .wa-logo,
  .whatsapp-floating .wa-logo,
  .floating-wa img,
  .floating-whatsapp img,
  .whatsapp-floating img{
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
  }
}

/* === Ajustes Keduin: categorías compactas, WhatsApp original y cotización especial === */
.category-strip{
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  align-items:center !important;
  gap:7px !important;
  overflow:visible !important;
  max-width:1240px !important;
  margin:0 auto !important;
  padding:8px 14px 12px !important;
  scrollbar-width:none !important;
}
.category-strip::-webkit-scrollbar{display:none !important;}
.category-strip a{
  flex:0 0 auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:30px !important;
  padding:6px 10px !important;
  border-radius:999px !important;
  font-size:12px !important;
  font-weight:800 !important;
  line-height:1 !important;
  white-space:nowrap !important;
  background:#fff8ec !important;
  border:1px solid #ead4b7 !important;
  color:#3b2316 !important;
  transition:all .18s ease !important;
}
.category-strip a:hover,
.category-strip a:focus-visible,
.category-strip a.active{
  background:var(--red) !important;
  border-color:var(--red) !important;
  color:#fff !important;
  transform:translateY(-1px);
}

.card-actions,.detail-actions{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  align-items:center !important;
}
.product-card .card-actions .button{flex:1 1 130px;min-height:38px;padding:9px 11px;font-size:13px;}
.quote-qty-btn{background:#fff !important;border:1px solid #d6bc92 !important;color:#6c3a18 !important;}
.quote-qty-btn:hover,.quote-qty-btn:focus-visible{background:#fff2dc !important;color:var(--red) !important;}
.detail-actions .quote-qty-btn{min-height:42px;}

/* WhatsApp flotante: solo logo original, sin círculo externo */
.floating-wa,
.floating-whatsapp,
.whatsapp-floating{
  position:fixed !important;
  right:18px !important;
  bottom:18px !important;
  z-index:9999 !important;
  width:54px !important;
  height:54px !important;
  min-width:54px !important;
  min-height:54px !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.floating-wa img,
.floating-whatsapp img,
.whatsapp-floating img,
.floating-wa .wa-logo,
.floating-whatsapp .wa-logo,
.whatsapp-floating .wa-logo{
  width:54px !important;
  height:54px !important;
  max-width:54px !important;
  max-height:54px !important;
  object-fit:contain !important;
  display:block !important;
  flex:0 0 auto !important;
}

/* Modal de cotización especial */
.quote-modal-backdrop{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.52);display:flex;align-items:center;justify-content:center;padding:18px;}
.quote-modal{width:min(560px,100%);max-height:92vh;overflow:auto;background:#fffdf8;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 80px rgba(0,0,0,.24);padding:20px;}
.quote-modal header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px;}
.quote-modal h2{margin:0;color:var(--red);font-size:24px;line-height:1.15;font-family:Georgia,'Times New Roman',serif;}
.quote-modal p{margin:5px 0 0;color:var(--muted);}
.quote-modal-close{border:0;background:transparent;font-size:28px;line-height:1;cursor:pointer;color:var(--muted);}
.quote-form{display:grid;gap:10px;}
.quote-form label{display:grid;gap:5px;font-weight:800;color:var(--muted);}
.quote-form input,.quote-form textarea,.quote-form select{border:1px solid var(--line);border-radius:8px;padding:11px;font:inherit;background:#fff;color:var(--ink);}
.quote-form .quote-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.quote-form .quote-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:8px;}
.quote-product-summary{padding:10px;border-radius:8px;background:var(--cream);border:1px solid var(--line);font-weight:800;}

@media(max-width:768px){
  .category-strip{
    flex-wrap:nowrap !important;
    justify-content:flex-start !important;
    overflow-x:auto !important;
    overflow-y:hidden !important;
    padding:8px 14px 10px !important;
    scroll-snap-type:x proximity;
    -webkit-overflow-scrolling:touch;
  }
  .category-strip a{font-size:11.5px !important;padding:6px 9px !important;min-height:29px !important;scroll-snap-align:start;}
  .floating-wa,.floating-whatsapp,.whatsapp-floating{width:48px !important;height:48px !important;min-width:48px !important;min-height:48px !important;right:14px !important;bottom:14px !important;}
  .floating-wa img,.floating-whatsapp img,.whatsapp-floating img,.floating-wa .wa-logo,.floating-whatsapp .wa-logo,.whatsapp-floating .wa-logo{width:48px !important;height:48px !important;max-width:48px !important;max-height:48px !important;}
  .quote-form .quote-grid{grid-template-columns:1fr;}
  .product-card .card-actions .button{flex:1 1 100%;}
}


/* Ajustes Keduin: look moderno, categorías desplegables, buscador sutil y WhatsApp limpio */
.topbar{font-size:13px;padding:6px 14px;letter-spacing:.1px}
.nav-wrap{gap:10px;grid-template-columns:auto auto minmax(0,1fr) minmax(160px,280px) auto auto;padding:8px 18px}.main-nav{gap:14px}.search{justify-self:end;width:min(100%,280px);min-height:38px;border-radius:999px;background:#fffdf8;border-color:#eadcc7;box-shadow:0 4px 18px rgba(38,31,27,.04);padding:0 11px}.search svg{width:18px;height:18px;color:#6c5f56}.search input{padding:8px 0;font-size:14px}.search input::placeholder{color:#8a7b70}.category-menu-wrap{max-width:1240px;margin:0 auto;padding:0 20px 10px;display:flex;flex-direction:column;align-items:center}.category-toggle-btn{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:8px 16px;border:1px solid #ead4b7;border-radius:999px;background:#fff8ec;color:#3b2316;font-weight:900;font-size:13px;cursor:pointer;box-shadow:0 8px 24px rgba(38,31,27,.05);transition:.2s ease}.category-toggle-btn:hover,.category-toggle-btn.is-open{background:#8f1d18;color:#fff;border-color:#8f1d18}.category-toggle-btn span{transition:transform .2s ease}.category-toggle-btn.is-open span{transform:rotate(180deg)}.category-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;max-width:980px;margin:10px auto 0;padding:0;overflow:visible;scrollbar-width:none}.category-strip[hidden]{display:none!important}.category-strip a{padding:7px 12px;font-size:12px;border-radius:999px;background:#fff;border-color:#ead4b7;color:#3b2316;box-shadow:0 3px 12px rgba(38,31,27,.04);line-height:1}.category-strip a:hover{background:#8f1d18;color:#fff;border-color:#8f1d18}.eyebrow{font-size:12px;letter-spacing:.02em;color:#7a5b42}.product-info .eyebrow{color:#6f6258}.wa-logo{width:22px;height:22px;max-width:22px;max-height:22px;object-fit:contain}.wa-icon-only,.header-action.wa-icon-only,.floating-wa.wa-icon-only{background:transparent!important;border:0!important;border-radius:0!important;box-shadow:none!important;padding:0!important}.header-action.wa-icon-only{width:42px!important;min-width:42px!important;height:42px!important;min-height:42px!important}.header-action.wa-icon-only .wa-logo{width:34px!important;height:34px!important;max-width:34px!important;max-height:34px!important}.floating-wa.wa-icon-only{width:56px!important;min-width:56px!important;height:56px!important;min-height:56px!important;right:18px!important;bottom:18px!important;display:flex;align-items:center;justify-content:center}.floating-wa.wa-icon-only .wa-logo{width:56px!important;height:56px!important;max-width:56px!important;max-height:56px!important;filter:drop-shadow(0 8px 16px rgba(0,0,0,.18))}.wa-inline .wa-logo{width:20px!important;height:20px!important;max-width:20px!important;max-height:20px!important}.button,.header-action{border-radius:10px}.quote-modal{border-radius:18px;box-shadow:0 24px 80px rgba(38,31,27,.18)}.quote-modal input::placeholder,.quote-modal textarea::placeholder{color:#8a7b70}.quote-product-summary{border-radius:10px}.quote-grid{gap:10px}@media(max-width:1060px){.nav-wrap{grid-template-columns:auto auto minmax(0,1fr) auto auto}.search{grid-column:3/4;max-width:240px}.category-menu-wrap{align-items:stretch}.category-toggle-btn{align-self:center}.category-strip{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;max-width:100%;-webkit-overflow-scrolling:touch}.category-strip a{flex:0 0 auto}}@media(max-width:640px){.nav-wrap{grid-template-columns:auto auto 1fr auto;gap:8px}.brand img{width:128px}.search{grid-column:1/-1;justify-self:stretch;width:100%;max-width:none;min-height:36px}.search input{font-size:13px}.category-menu-wrap{padding:0 14px 8px}.category-toggle-btn{min-height:34px;font-size:12px;padding:7px 14px}.floating-wa.wa-icon-only{width:48px!important;min-width:48px!important;height:48px!important;min-height:48px!important;right:13px!important;bottom:13px!important}.floating-wa.wa-icon-only .wa-logo{width:48px!important;height:48px!important;max-width:48px!important;max-height:48px!important}.quote-grid{grid-template-columns:1fr!important}}


/* =========================================================
   Ajustes finales Keduin: portada, categorías y footer moderno
   ========================================================= */
.topbar{display:none!important}
.category-strip[hidden]{display:none!important}
.category-menu-wrap{max-width:1240px;margin:0 auto;padding:0 20px 12px;position:relative}
.category-toggle-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid #ead4b7;background:#fff8ec;color:#3b2316;border-radius:999px;padding:9px 16px;font-weight:900;cursor:pointer;box-shadow:0 6px 14px rgba(38,31,27,.06)}
.category-toggle-btn:hover,.category-toggle-btn.is-open{background:var(--red);border-color:var(--red);color:#fff}
.category-menu-wrap .category-strip:not([hidden]){display:flex!important;position:absolute;left:20px;right:20px;top:calc(100% + 6px);z-index:80;flex-wrap:wrap;gap:8px;max-width:none;margin:0;padding:14px;background:#fffdf8;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 42px rgba(38,31,27,.14);overflow:visible}
.category-menu-wrap .category-strip a{font-size:13px;padding:7px 12px;background:#fff8ec;border-radius:999px}
.search{max-width:230px;min-height:38px;border-radius:999px;background:#fffdf8;box-shadow:0 6px 16px rgba(38,31,27,.05)}
.search input{padding:8px 0;font-size:14px}.search svg{width:17px;height:17px;color:#7a6b61}
.hero-cover{max-width:none;min-height:620px;margin:0;padding:86px 20px;grid-template-columns:1fr;background:linear-gradient(90deg,rgba(33,25,21,.72),rgba(143,29,24,.42)),url('/assets/img/hero/hero-panaderia-abstracta.svg');background-size:cover;background-position:center;position:relative;overflow:hidden}
.hero-cover:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 28%,rgba(255,247,232,.22),transparent 34%),linear-gradient(180deg,rgba(255,253,248,.05),rgba(33,25,21,.18));pointer-events:none}
.hero-cover .hero-copy{position:relative;z-index:1;max-width:1240px;width:100%;margin:0 auto;color:#fff7e8}
.hero-cover .hero-copy h1{color:#fff7e8;text-shadow:0 10px 30px rgba(0,0,0,.26)}
.hero-cover .hero-copy p{color:#fff7e8;max-width:720px}.hero-cover .eyebrow{color:#f5c56b}
.hero-cover .button.primary{background:#187a45;color:#fff}.hero-cover .button.secondary{background:#8f1d18;color:#fff;border-color:#8f1d18}
.footer-grid{grid-template-columns:1.15fr 1.15fr 1fr 1fr}.footer-note{font-size:13px;color:#d9c9b8}.social-links span{color:#fff7e8}.payment-card{border:1px solid var(--line);border-radius:12px;background:var(--cream);padding:16px;margin:12px 0 18px}.payment-card p{margin:6px 0}
@media(max-width:1060px){.nav-wrap{grid-template-columns:auto auto minmax(180px,1fr) auto}.search{max-width:100%}.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.category-menu-wrap{padding:0 14px 10px}.category-menu-wrap .category-strip:not([hidden]){left:14px;right:14px;max-height:60vh;overflow:auto}.hero-cover{min-height:520px;padding:64px 18px}.hero-cover .hero-copy h1{font-size:50px}.footer-grid{grid-template-columns:1fr}.search{grid-column:1/-1;max-width:100%}}


/* Ajuste final: WhatsApp original, búsqueda y portada limpia */
.hero-actions .button.secondary{display:none!important;}
.hero-actions .button.primary{font-size:15px;padding:12px 20px;border-radius:10px;}
.wa-logo{object-fit:contain!important;}
.header-action.wa-icon-only{background:transparent!important;border:0!important;box-shadow:none!important;border-radius:0!important;padding:0!important;}
.header-action.wa-icon-only .wa-logo{width:36px!important;height:36px!important;max-width:36px!important;max-height:36px!important;filter:drop-shadow(0 4px 10px rgba(0,0,0,.10));}
.floating-wa.wa-icon-only,.floating-wa,.floating-whatsapp,.whatsapp-floating{background:transparent!important;border:0!important;box-shadow:none!important;border-radius:0!important;padding:0!important;}
.floating-wa.wa-icon-only .wa-logo,.floating-wa .wa-logo,.floating-wa img,.floating-whatsapp img,.whatsapp-floating img{width:54px!important;height:54px!important;max-width:54px!important;max-height:54px!important;filter:drop-shadow(0 8px 16px rgba(0,0,0,.18));}
.wa-inline .wa-logo{width:21px!important;height:21px!important;max-width:21px!important;max-height:21px!important;filter:none!important;}
.search{max-width:260px!important;}
.search input{text-transform:none!important;}
@media(max-width:640px){.floating-wa.wa-icon-only .wa-logo,.floating-wa .wa-logo,.floating-wa img,.floating-whatsapp img,.whatsapp-floating img{width:48px!important;height:48px!important;max-width:48px!important;max-height:48px!important}.header-action.wa-icon-only .wa-logo{width:32px!important;height:32px!important;}}


/* ===== Rediseño editorial Keduin junio 2026 ===== */
.nav-wrap{grid-template-columns:auto auto minmax(0,1fr) minmax(180px,250px) auto auto;gap:12px;padding:10px 20px}
.main-nav{gap:14px;align-items:center}
.main-nav a,.nav-dropdown-trigger{font-size:14px;font-weight:800;color:var(--ink);background:none;border:0;padding:0;cursor:pointer}
.nav-dropdown{position:relative}
.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:6px}
.nav-dropdown-trigger span{font-size:11px;transition:transform .2s ease}
.nav-dropdown:hover .nav-dropdown-trigger span,.nav-dropdown:focus-within .nav-dropdown-trigger span,.nav-dropdown.is-open .nav-dropdown-trigger span{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:calc(100% + 12px);left:0;min-width:290px;display:grid;gap:6px;padding:14px;background:#fffef9;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 40px rgba(38,31,27,.14);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease,visibility .2s ease;z-index:80}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu,.nav-dropdown.is-open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{padding:8px 10px;border-radius:10px;font-size:13px;font-weight:700}
.nav-dropdown-menu a:hover{background:var(--cream)}
.nav-dropdown-menu .nav-dropdown-all{margin-top:6px;padding-top:12px;border-top:1px solid var(--line);color:var(--red);font-weight:900}
.category-menu-wrap{display:none!important}
.hero-editorial{max-width:none;min-height:640px;margin:0;padding:110px 20px 88px;display:grid;grid-template-columns:1fr;align-items:center;background:linear-gradient(90deg,rgba(33,25,21,.72) 0%,rgba(33,25,21,.58) 35%,rgba(143,29,24,.22) 100%),url('/assets/img/editorial/hero-main.webp') center/cover no-repeat;position:relative;overflow:hidden}
.hero-editorial::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(0,0,0,.10));pointer-events:none}
.hero-editorial .hero-copy{max-width:1240px;margin:0 auto;position:relative;z-index:1;color:#fff7e8}
.hero-editorial .hero-copy h1{color:#fff7e8;font-size:clamp(52px,9vw,96px);text-shadow:0 12px 34px rgba(0,0,0,.3)}
.hero-editorial .hero-copy p{font-size:20px;max-width:700px;color:#fff7e8}
.hero-editorial .eyebrow{color:#f5c56b;font-size:14px;letter-spacing:.08em}
.hero-editorial .button.light{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.26);color:#fff;backdrop-filter:blur(8px)}
.hero-mini-points{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.hero-mini-points span{padding:8px 12px;border-radius:999px;background:rgba(255,247,232,.16);border:1px solid rgba(255,247,232,.18);font-weight:700;font-size:13px}
.editorial-section{padding-top:58px}
.editorial-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.editorial-card{position:relative;min-height:280px;border-radius:22px;overflow:hidden;background:#f5efe6;box-shadow:var(--shadow)}
.editorial-card.large{grid-column:span 2;min-height:360px}
.editorial-card.wide{grid-column:span 2;min-height:320px}
.editorial-card img{width:100%;height:100%;object-fit:cover}
.editorial-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(33,25,21,.72) 100%)}
.editorial-copy{position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff;z-index:1}
.editorial-copy h3{margin:0 0 8px;font-size:26px;font-family:Georgia,'Times New Roman',serif}
.editorial-copy p{margin:0;color:rgba(255,247,232,.94)}
.showcase-split{display:grid;grid-template-columns:minmax(0,1fr) 1.08fr;gap:28px;align-items:center}
.showcase-copy h2,.gallery-banner-copy h2{margin:0 0 12px;font-size:clamp(34px,5vw,56px);line-height:1.04;color:var(--red);font-family:Georgia,'Times New Roman',serif}
.feature-list{display:grid;gap:10px;padding:0;margin:20px 0 0;list-style:none}
.feature-list li{position:relative;padding-left:22px;color:var(--muted);font-weight:700}
.feature-list li::before{content:'•';position:absolute;left:0;top:-2px;color:var(--gold);font-size:22px;line-height:1}
.showcase-visual{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;align-items:stretch}
.showcase-main,.showcase-stack img{width:100%;height:100%;object-fit:cover;border-radius:20px;box-shadow:var(--shadow)}
.showcase-stack{display:grid;grid-template-rows:1fr 1fr;gap:16px}
.gallery-banner{max-width:none;background:linear-gradient(180deg,#fffdf8,#fff7e8);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.gallery-banner-copy{max-width:1240px;margin:0 auto 20px;padding:0 20px}
.gallery-banner-track{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;padding:0 20px}
.gallery-banner-track img{width:100%;height:260px;object-fit:cover;border-radius:20px;box-shadow:var(--shadow)}
.metric-row{display:none!important}
.band{display:none!important}
.section-heading h2{font-family:Georgia,'Times New Roman',serif;color:var(--red)}
.category-tile{min-height:220px}
.category-tile img{height:220px}
@media(max-width:1100px){.nav-wrap{grid-template-columns:auto auto 1fr auto auto}.nav-dropdown-menu{left:auto;right:0}.editorial-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.editorial-card.large,.editorial-card.wide{grid-column:span 2}.showcase-split{grid-template-columns:1fr}.showcase-visual{grid-template-columns:1fr 1fr}}
@media(max-width:860px){.main-nav{gap:12px}.nav-dropdown-menu{position:static;min-width:unset;box-shadow:none;border:0;padding:10px 0 0;background:transparent;opacity:1;visibility:visible;transform:none;display:none}.nav-dropdown.is-open .nav-dropdown-menu{display:grid}.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{display:grid}.nav-dropdown-menu a{padding:7px 10px;background:#fff;border:1px solid var(--line)}.hero-editorial{min-height:560px;padding:88px 18px 70px}.hero-editorial .hero-copy p{font-size:18px}.gallery-banner-track{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.hero-editorial{min-height:500px;padding:72px 16px 58px;background-position:72% center}.hero-editorial .hero-copy h1{font-size:54px}.hero-mini-points{gap:8px}.hero-mini-points span{font-size:12px;padding:7px 10px}.editorial-grid,.gallery-banner-track,.showcase-visual{grid-template-columns:1fr}.editorial-card.large,.editorial-card.wide{grid-column:auto;min-height:280px}.showcase-stack{grid-template-rows:auto}.gallery-banner-track img{height:220px}.nav-wrap{grid-template-columns:auto auto 1fr auto}.main-nav{padding-top:8px}.search{grid-column:1/-1;order:10}.nav-dropdown-menu{gap:8px;padding-top:10px}}


/* ===== Corrección definitiva WhatsApp SVG limpio ===== */
.wa-logo,
img.wa-logo,
.wa-inline .wa-logo,
.header-action.wa-icon-only .wa-logo,
.floating-wa.wa-icon-only .wa-logo,
.floating-wa .wa-logo,
.floating-wa img,
.whatsapp-floating img,
.floating-whatsapp img {
  display: block !important;
  object-fit: contain !important;
  object-position: center !important;
  image-rendering: auto !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  aspect-ratio: 1 / 1 !important;
}

.header-action.wa-icon-only,
.floating-wa.wa-icon-only,
.floating-wa,
.whatsapp-floating,
.floating-whatsapp {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: visible !important;
}

.header-action.wa-icon-only {
  width: 42px !important;
  min-width: 42px !important;
  height: 42px !important;
  min-height: 42px !important;
}

.header-action.wa-icon-only .wa-logo {
  width: 34px !important;
  height: 34px !important;
  max-width: 34px !important;
  max-height: 34px !important;
}

.floating-wa.wa-icon-only,
.floating-wa {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  width: 60px !important;
  min-width: 60px !important;
  height: 60px !important;
  min-height: 60px !important;
  z-index: 9999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.floating-wa.wa-icon-only .wa-logo,
.floating-wa .wa-logo,
.floating-wa img {
  width: 60px !important;
  height: 60px !important;
  max-width: 60px !important;
  max-height: 60px !important;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.16)) !important;
}

.wa-inline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
}

.wa-inline .wa-logo {
  width: 20px !important;
  height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
  flex: 0 0 20px !important;
  filter: none !important;
}

.button .wa-logo,
.detail-link .wa-logo {
  width: 20px !important;
  height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
}

@media (max-width: 640px) {
  .floating-wa.wa-icon-only,
  .floating-wa {
    right: 14px !important;
    bottom: 14px !important;
    width: 52px !important;
    min-width: 52px !important;
    height: 52px !important;
    min-height: 52px !important;
  }

  .floating-wa.wa-icon-only .wa-logo,
  .floating-wa .wa-logo,
  .floating-wa img {
    width: 52px !important;
    height: 52px !important;
    max-width: 52px !important;
    max-height: 52px !important;
  }
}


/* ===== Ajustes portada y secciones junio 2026 ===== */
.hero-editorial{background:linear-gradient(90deg,rgba(33,25,21,.66) 0%,rgba(33,25,21,.50) 35%,rgba(33,25,21,.16) 100%),url('/assets/img/editorial/hero-new.webp') center/cover no-repeat !important;min-height:680px}
.hero-editorial .hero-copy{max-width:1240px}
.showcase-split{grid-template-columns:minmax(0,1fr) minmax(340px,500px);gap:32px;align-items:center}
.showcase-single{display:flex;align-items:center;justify-content:center}
.single-visual{width:100%;max-width:460px;height:auto;display:block;border-radius:24px;box-shadow:var(--shadow)}
.gallery-banner-single{max-width:1240px;margin:0 auto;padding:0 20px}
.gallery-banner-single img{width:100%;max-width:780px;display:block;margin:0 auto;border-radius:24px;box-shadow:var(--shadow)}
@media(max-width:860px){.hero-editorial{min-height:560px;background-position:center}.showcase-split{grid-template-columns:1fr}.single-visual{max-width:520px}.gallery-banner-single img{max-width:100%}}
@media(max-width:640px){.hero-editorial{min-height:500px;background-position:center}.gallery-banner-copy{padding:0 16px}.gallery-banner-single{padding:0 16px}.single-visual{border-radius:18px}.gallery-banner-single img{border-radius:18px}}


/* ===== WhatsApp CTA definitivo: cápsula + SVG inline ===== */
.wa-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  min-height: 54px !important;
  padding: 0 28px !important;
  border-radius: 999px !important;
  background: #c9665f !important;
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  border: none !important;
  box-shadow: 0 10px 24px rgba(201, 102, 95, 0.28) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
  cursor: pointer !important;
  white-space: nowrap !important;
}

.wa-cta:hover {
  transform: translateY(-2px) !important;
  background: #b95751 !important;
  box-shadow: 0 14px 30px rgba(201, 102, 95, 0.35) !important;
}

.wa-cta-icon,
.wa-mini-icon {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
  max-width: 22px !important;
  max-height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 22px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  background: transparent !important;
}

.wa-cta-icon svg,
.wa-mini-icon svg {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
  max-width: 22px !important;
  max-height: 22px !important;
  display: block !important;
  aspect-ratio: 1 / 1 !important;
  transform: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.nav-wa-cta {
  min-height: 42px !important;
  padding: 0 18px !important;
  font-size: 14px !important;
}

.nav-wa-cta .wa-cta-icon {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
  flex-basis: 20px !important;
}

.nav-wa-cta .wa-cta-icon svg {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
}

.detail-link.wa-inline {
  background: transparent !important;
  color: var(--green) !important;
  box-shadow: none !important;
  border: 0 !important;
}

.detail-link.wa-inline .wa-mini-icon {
  width: 19px !important;
  height: 19px !important;
  min-width: 19px !important;
  min-height: 19px !important;
  max-width: 19px !important;
  max-height: 19px !important;
  flex-basis: 19px !important;
}

.detail-link.wa-inline .wa-mini-icon svg {
  width: 19px !important;
  height: 19px !important;
  min-width: 19px !important;
  min-height: 19px !important;
  max-width: 19px !important;
  max-height: 19px !important;
}

.floating-wa,
.whatsapp-floating,
.floating-whatsapp,
.wa-float-clean {
  display: none !important;
}

img.wa-logo {
  display: none !important;
}

@media (max-width: 768px) {
  .wa-cta {
    width: 100% !important;
    max-width: 320px !important;
    min-height: 52px !important;
    padding: 0 22px !important;
    font-size: 15px !important;
  }

  .nav-wa-cta {
    width: auto !important;
    min-height: 40px !important;
    padding: 0 14px !important;
    font-size: 13px !important;
  }
}


/* ===== Ajustes visuales finales junio 2026 ===== */
.search,.catalog-search,[data-catalog-search]{display:none !important;}
.nav-wrap{gap:14px}
.nav-wrap .wa-cta.nav-wa-cta{display:none !important;}
.showcase-split{grid-template-columns:minmax(0,1fr) minmax(300px,440px) !important;align-items:center !important;}
.showcase-single{display:flex;justify-content:center;align-items:center;}
.single-visual{width:100%;max-width:420px;height:auto;border-radius:24px;box-shadow:var(--shadow)}
.gallery-banner-single img{width:100%;max-width:760px;display:block;margin:0 auto;border-radius:24px;box-shadow:var(--shadow)}
.icon-category-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:18px}
.category-tile.icon-tile{background:#f9f4ec;border:1px solid #dbc7af;border-radius:22px;padding:14px 14px 16px;text-align:center;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:flex-start;min-height:290px;box-shadow:none;}
.category-tile.icon-tile img.category-icon-png{width:100%;height:auto;max-width:190px;aspect-ratio:auto;object-fit:contain;background:none;border-radius:16px;display:block;}
.category-tile.icon-tile span{color:#8b2b1f;font-size:1.12rem;font-weight:800;line-height:1.15;text-shadow:none;}
.category-tile.icon-tile small{color:#6f6256;font-size:.95rem;font-weight:600;}
.category-tile::after{display:none !important}
.qty-picker{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap;width:100%;}
.qty-picker-label{font-size:.92rem;font-weight:700;color:#6b5a4d;}
.qty-picker-select{appearance:none;background:#fff;border:1px solid #d2c1ab;border-radius:12px;padding:10px 12px;min-width:78px;font-weight:700;color:#432;}
.card-actions,.detail-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.card-actions .button,.detail-actions .button{flex:initial;}
.hero-actions .wa-cta{display:none !important;}
@media (max-width: 1100px){.icon-category-grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media (max-width: 860px){.showcase-split{grid-template-columns:1fr !important}.single-visual{max-width:460px}.icon-category-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 640px){.icon-category-grid{grid-template-columns:1fr}.category-tile.icon-tile{min-height:unset}.gallery-banner-single img,.single-visual{border-radius:18px}}


/* ===== Ajuste final Keduin: WhatsApp flotante + botones rojos uniformes ===== */

/* Botón flotante inferior: usa la imagen app entregada por Keduin */
.wa-float {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: transparent !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.22) !important;
  padding: 0 !important;
  margin: 0 !important;
  text-decoration: none !important;
}

.wa-float img {
  width: 62px !important;
  height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  object-fit: contain !important;
  display: block !important;
  border: 0 !important;
  background: transparent !important;
}

/* No ocultar el nuevo flotante */
.floating-wa,
.whatsapp-floating,
.floating-whatsapp,
.wa-float-clean {
  display: none !important;
}

/* Botones principales: cambiar verdes por rojo corporativo */
.button.primary,
.product-card .button.primary,
.detail-actions .button.primary,
.card-actions .button.primary,
button[data-add-to-cart],
a.button.primary {
  background: #8f1d18 !important;
  border-color: #8f1d18 !important;
  color: #ffffff !important;
  box-shadow: 0 8px 20px rgba(143,29,24,.18) !important;
}

.button.primary:hover,
.product-card .button.primary:hover,
.detail-actions .button.primary:hover,
.card-actions .button.primary:hover,
button[data-add-to-cart]:hover,
a.button.primary:hover {
  background: #731410 !important;
  border-color: #731410 !important;
  transform: translateY(-1px);
}

/* Botones horizontales WhatsApp: ícono pequeño limpio, nunca el cuadrado grande */
.wa-cta,
.wa-btn,
.detail-link.wa-inline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 44px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.wa-cta,
.wa-btn {
  background: #8f1d18 !important;
  border: 1px solid #8f1d18 !important;
  color: #ffffff !important;
  box-shadow: 0 8px 20px rgba(143,29,24,.16) !important;
}

.wa-cta:hover,
.wa-btn:hover {
  background: #731410 !important;
  border-color: #731410 !important;
  transform: translateY(-1px);
}

.detail-link.wa-inline {
  color: #087b42 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Tamaño único para íconos pequeños horizontales */
.wa-mini-icon,
.wa-cta-icon {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 18px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 50% !important;
  overflow: hidden !important;
}

.wa-mini-icon svg,
.wa-cta-icon svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  display: block !important;
  aspect-ratio: 1 / 1 !important;
}

/* Portada: ambos botones con el mismo diseño, alto y borde */
.hero-actions {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.hero-actions .button,
.hero-actions .wa-cta {
  min-height: 50px !important;
  padding: 0 24px !important;
  border-radius: 999px !important;
  font-size: 15px !important;
  font-weight: 900 !important;
}

.hero-actions .wa-cta {
  display: inline-flex !important;
}

/* Si una regla anterior escondía el WhatsApp de portada, lo reactivamos */
.hero-actions .wa-cta,
.hero-actions a[href*="wa.me"] {
  display: inline-flex !important;
}

/* Select de cantidad más limpio junto a Agregar al pedido */
.qty-picker {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: 100% !important;
  margin: 4px 0 8px !important;
}

.qty-picker-label {
  font-size: 13px !important;
  font-weight: 800 !important;
  color: #665b52 !important;
}

.qty-picker-select {
  height: 38px !important;
  border-radius: 10px !important;
  border: 1px solid #d2c1ab !important;
  background: #fff !important;
  padding: 0 12px !important;
  min-width: 78px !important;
  font-weight: 900 !important;
  color: #432 !important;
}

/* Mejorar consistencia visual de botones en tarjetas */
.card-actions .button,
.detail-actions .button {
  min-height: 42px !important;
  border-radius: 10px !important;
  font-size: 14px !important;
}

@media (max-width: 768px) {
  .wa-float {
    right: 16px !important;
    bottom: 16px !important;
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }

  .wa-float img {
    width: 56px !important;
    height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
  }

  .hero-actions .button,
  .hero-actions .wa-cta {
    width: auto !important;
    min-height: 48px !important;
    padding: 0 20px !important;
  }
}


/* ===== Cantidad manual + pedido al detal ===== */
.qty-picker-manual {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: 100% !important;
  margin: 4px 0 10px !important;
}

.qty-picker-input {
  width: 100% !important;
  max-width: 180px !important;
  height: 42px !important;
  border-radius: 10px !important;
  border: 1px solid #d2c1ab !important;
  background: #fff !important;
  padding: 0 12px !important;
  font-weight: 900 !important;
  color: #432 !important;
  font-size: 15px !important;
}

.qty-picker-input:focus {
  outline: 2px solid rgba(143,29,24,.22) !important;
  border-color: #8f1d18 !important;
}

.retail-order-btn {
  background: #fff !important;
  border: 1px solid #8f1d18 !important;
  color: #8f1d18 !important;
  box-shadow: none !important;
}

.retail-order-btn:hover {
  background: #fff7e8 !important;
  color: #731410 !important;
  border-color: #731410 !important;
}

.card-actions,
.detail-actions {
  align-items: center !important;
}

.card-actions .retail-order-btn,
.detail-actions .retail-order-btn {
  min-height: 42px !important;
  border-radius: 10px !important;
  padding: 0 16px !important;
}

@media (max-width: 640px) {
  .qty-picker-input {
    max-width: 100% !important;
  }

  .card-actions .button,
  .detail-actions .button,
  .card-actions .retail-order-btn,
  .detail-actions .retail-order-btn {
    width: 100% !important;
  }
}


/* ===== Buscador y categorías funcionando ===== */
.catalog-tools {
  display: grid !important;
  grid-template-columns: minmax(260px, 1fr) minmax(220px, 300px) auto;
  gap: 14px;
  align-items: end;
  margin: 34px 0 28px;
}

.catalog-tool {
  display: grid;
  gap: 8px;
  font-weight: 800;
  color: #5e5047;
}

.catalog-tool span {
  font-size: 13px;
}

.catalog-tools input[data-catalog-search],
.catalog-tools select[data-category-filter] {
  display: block !important;
  width: 100% !important;
  height: 48px !important;
  border: 1px solid #d9c6ad !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: #2f2621 !important;
  padding: 0 14px !important;
  font-weight: 700 !important;
  font-size: 15px !important;
}

.catalog-tools input[data-catalog-search]:focus,
.catalog-tools select[data-category-filter]:focus {
  outline: 2px solid rgba(143,29,24,.18) !important;
  border-color: #8f1d18 !important;
}

.catalog-cart-btn {
  height: 48px !important;
  border-radius: 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 22px !important;
  white-space: nowrap !important;
}

.catalog-results {
  margin: -12px 0 22px;
  font-weight: 800;
  color: #8f1d18;
}

/* Anula la regla vieja que ocultaba el buscador */
.catalog-tools [data-catalog-search],
.catalog-tools .search-tool,
.catalog-tools input {
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

@media (max-width: 860px) {
  .catalog-tools {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .catalog-cart-btn {
    width: 100%;
  }
}


/* ===== Fix final filtro de categorías ===== */
[data-product-card][hidden] {
  display: none !important;
}

.catalog-tools {
  display: grid !important;
  grid-template-columns: minmax(280px, 1fr) minmax(220px, 300px) auto !important;
  gap: 14px !important;
  align-items: end !important;
  margin: 34px 0 28px !important;
}

.catalog-tools input[data-catalog-search],
.catalog-tools select[data-category-filter] {
  display: block !important;
  width: 100% !important;
  height: 48px !important;
  border: 1px solid #d9c6ad !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: #2f2621 !important;
  padding: 0 14px !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.catalog-results {
  color: #8f1d18 !important;
  font-weight: 900 !important;
  margin: -12px 0 22px !important;
}

@media (max-width: 860px) {
  .catalog-tools {
    grid-template-columns: 1fr !important;
  }
}


/* ===== Corrección menú: sin WhatsApp lateral y sin menú duplicado ===== */
.menu-whatsapp {
  display: none !important;
}

@media (max-width: 780px) {
  .desktop-nav-line {
    display: none !important;
  }
}

/* Si una página antigua carga este CSS, evita que el menú bajo logo aparezca sin diseño */
.site-header + .desktop-nav-line,
.site-header .desktop-nav-line {
  display: none !important;
}


/* ===== FIX DEFINITIVO WHATSAPP FLOTANTE: PNG cuadrado sin deformación ===== */
.wa-float-clean {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: transparent !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.22) !important;
  transform: none !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

.wa-float-clean img {
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  border: 0 !important;
  border-radius: 18px !important;
  padding: 0 !important;
  margin: 0 !important;
  transform: none !important;
  background: transparent !important;
  aspect-ratio: 1 / 1 !important;
  box-shadow: none !important;
}

.wa-float-clean::before,
.wa-float-clean::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 768px) {
  .wa-float-clean {
    right: 15px !important;
    bottom: 15px !important;
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }

  .wa-float-clean img {
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }
}

:root{
  --red:#8f1d18;
  --red2:#72130f;
  --cream:#fff8ec;
  --cream2:#f7efe2;
  --ink:#281d18;
  --muted:#685b52;
  --line:#e5d2bb;
  --green:#128c4a;
  --shadow:0 16px 45px rgba(66,45,30,.12);
}
*{box-sizing:border-box}
body{margin:0;background:#fffaf1;color:var(--ink);font-family:Arial,system-ui,-apple-system,Segoe UI,sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.store-header{position:sticky;top:0;background:#fffaf1;border-bottom:1px solid var(--line);z-index:1000}
.topbar{height:76px;display:grid;grid-template-columns:90px 1fr 90px;align-items:center;max-width:1240px;margin:auto;padding:0 18px}
.brand{justify-self:center}
.brand img{height:58px;width:auto}
.menu-btn,.cart-pill,.drawer-head button{border:1px solid var(--line);background:#fff;border-radius:14px;min-height:44px;font-weight:900;cursor:pointer}
.menu-btn{width:54px;font-size:26px}
.cart-pill{justify-self:end;display:inline-flex;align-items:center;gap:8px;padding:0 14px}
.cart-icon{font-size:22px}.cart-icon-img{width:24px;height:24px;display:block;object-fit:contain;border-radius:6px;flex:0 0 24px}.cart-pill [data-cart-count]{background:#333;color:#fff;border-radius:999px;min-width:25px;height:25px;display:inline-flex;align-items:center;justify-content:center;font-weight:900}
.side-menu,.cart-drawer{position:fixed;top:0;bottom:0;background:#fffaf1;z-index:1200;width:min(390px,92vw);box-shadow:var(--shadow);transition:transform .25s ease}
.side-menu{left:0;transform:translateX(-105%)}.cart-drawer{right:0;transform:translateX(105%)}
.side-menu.is-open,.cart-drawer.is-open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.36);z-index:1100;display:none}.drawer-overlay.is-open{display:block}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid var(--line)}
.drawer-head strong{font-size:20px}.drawer-head button{width:42px;font-size:28px}
.side-menu nav{display:grid;gap:4px;padding:18px}.side-menu a{padding:12px;border-radius:12px;font-weight:800}.side-menu a:hover{background:var(--cream2)}.side-menu hr{width:100%;border:0;border-top:1px solid var(--line)}
.hero{min-height:610px;display:flex;align-items:center;background:linear-gradient(90deg,rgba(32,21,15,.70),rgba(32,21,15,.28)),url('/assets/img/editorial/hero-new.webp') center/cover no-repeat;color:#fff}
.hero-inner{max-width:1240px;margin:auto;padding:80px 20px}.eyebrow{text-transform:uppercase;letter-spacing:.07em;font-size:12px;font-weight:900;color:#8d6a3a}.hero .eyebrow{color:#ffd89a}
h1,h2{font-family:Georgia,'Times New Roman',serif;color:var(--red);line-height:1.03} .hero h1{font-size:clamp(52px,9vw,96px);color:#fff;margin:10px 0}.hero p{font-size:20px;max-width:680px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 18px;border-radius:11px;font-weight:900;border:1px solid transparent;cursor:pointer;text-align:center}
.btn.primary,.button.primary{background:var(--red)!important;color:#fff!important;border-color:var(--red)!important}.btn.primary:hover{background:var(--red2)!important}
.btn.ghost{background:#fff;color:var(--red);border-color:var(--line)}.btn.outline{background:#fffaf1;color:var(--red);border-color:#d5bda2}
.container,.section{max-width:1240px;margin:auto;padding:54px 20px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:24px}.section-head h2{font-size:42px;margin:0}.section-head p{color:var(--muted)}
.catalog-tools{display:grid;grid-template-columns:minmax(280px,1fr) minmax(220px,300px) minmax(220px,300px);gap:14px;align-items:end;margin:30px 0}.tool{display:grid;gap:8px;font-weight:900;color:#5f5148}.tool input,.tool select{height:48px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:0 14px;font-weight:800;font-size:15px}
.results{color:var(--red);font-weight:900;margin:0 0 20px}
.product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}.product-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}.product-image{background:#fff4e6;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}.product-image img{width:100%;height:100%;object-fit:contain}.product-info{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}.product-info h3{margin:0;font-size:18px}.price{font-size:22px;color:var(--red)}
.card-actions{display:grid;gap:8px;margin-top:auto}.card-actions .btn{width:100%}
.product-detail{display:grid;grid-template-columns:minmax(0,1fr) 520px;gap:34px;align-items:start}.detail-image{background:#fff4e6;border:1px solid var(--line);border-radius:18px;overflow:hidden}.detail-image img{width:100%;height:100%;object-fit:contain}.detail-info h1{font-size:46px;margin:0 0 14px}.detail-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:20px 0}.meta-box{border:1px solid var(--line);border-radius:12px;background:var(--cream);padding:14px}.meta-box small{display:block;font-weight:900;color:var(--muted);margin-bottom:5px}.detail-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:16px 0}.detail-actions .btn{width:100%}.note{font-size:14px;color:var(--muted)}
.qty-control{display:flex;align-items:center;border:1px solid #d1bba0;border-radius:12px;background:#fff;overflow:hidden;width:fit-content}.qty-control button{width:42px;height:42px;border:0;background:#fff4e6;font-size:24px;font-weight:900;cursor:pointer}.qty-control input{width:78px;height:42px;border:0;text-align:center;font-weight:900;font-size:16px}.product-qty{margin:6px 0;width:100%}.product-qty input{flex:1}
.related-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.related-row .product-card .card-actions{display:none}
.cart-items{padding:14px;display:grid;gap:12px;max-height:calc(100vh - 230px);overflow:auto}.cart-item{display:grid;grid-template-columns:78px 1fr auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px;background:#fff}.cart-item img{width:78px;height:78px;object-fit:contain;background:#fff4e6;border-radius:8px}.cart-item h4{margin:0}.cart-summary{padding:16px;border-top:1px solid var(--line);display:grid;gap:10px}
.checkout{display:grid;grid-template-columns:1fr 420px;gap:24px}.checkout-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;display:grid;gap:12px}.checkout-form label{display:grid;gap:7px;font-weight:800}.checkout-form input,.checkout-form select,.checkout-form textarea{border:1px solid var(--line);border-radius:10px;min-height:44px;padding:10px;font-weight:700}
.quote-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.38);z-index:2000;display:flex;align-items:center;justify-content:center;padding:18px}.quote-modal{width:min(680px,96vw);max-height:92vh;overflow:auto;background:#fffaf1;border-radius:18px;box-shadow:var(--shadow)}.quote-modal header{display:flex;justify-content:space-between;padding:18px;border-bottom:1px solid var(--line)}.quote-modal form{display:grid;gap:12px;padding:18px}.quote-modal input,.quote-modal textarea{border:1px solid var(--line);border-radius:10px;min-height:44px;padding:10px}
.store-footer{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:#211914;color:#fff4e7;padding:40px 20px}.store-footer h3{margin-top:0}.store-footer a{display:block;color:#fff4e7;margin:6px 0}.copyright{background:#150f0c;color:#fff;padding:16px;text-align:center}
@media(max-width:1000px){.product-grid{grid-template-columns:repeat(3,1fr)}.product-detail,.checkout{grid-template-columns:1fr}.detail-actions{grid-template-columns:1fr}.store-footer{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.product-grid,.related-row{grid-template-columns:1fr 1fr}.catalog-tools{grid-template-columns:1fr}.topbar{grid-template-columns:70px 1fr 70px}.brand img{height:48px}.hero{min-height:500px}.section{padding:40px 16px}.section-head{display:block}.store-footer{grid-template-columns:1fr}}
@media(max-width:460px){.product-grid,.related-row{grid-template-columns:1fr}.hero h1{font-size:48px}}

/* ===== Ajustes visuales: tipografías elegantes + WhatsApp ===== */
body {
  font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif !important;
  font-weight: 400;
  letter-spacing: -0.01em;
}

p, li, label, input, select, textarea {
  font-weight: 400 !important;
}

.product-info h3,
.detail-info h1,
.section-head h2,
.nosotros-content h2,
.nosotros-hero h1 {
  letter-spacing: -0.02em;
}

.product-info h3 {
  font-weight: 650 !important;
}

.product-info p,
.meta-box strong,
.tool,
.note {
  font-weight: 500 !important;
}

.btn,
.menu-btn,
.cart-pill {
  font-weight: 750 !important;
}

.eyebrow {
  font-weight: 700 !important;
  letter-spacing: .08em;
}

.wa-float-clean {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 62px;
  height: 62px;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.22);
  background: transparent;
}

.wa-float-clean img {
  width: 62px;
  height: 62px;
  object-fit: contain;
  display: block;
}

.menu-whatsapp {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  background: #e9fff0;
  color: #127a3a !important;
  border: 1px solid #b7ebc7;
}

.menu-whatsapp img {
  width: 24px;
  height: 24px;
}

.nosotros-hero {
  min-height: 520px;
  display: flex;
  align-items: center;
  background: linear-gradient(90deg, rgba(37,23,15,.70), rgba(37,23,15,.25)), url('/assets/img/editorial/hero-new.webp') center/cover no-repeat;
  color: #fff;
}

.nosotros-hero__content {
  max-width: 1180px;
  margin: auto;
  padding: 80px 20px;
}

.nosotros-hero h1 {
  color: #fff;
  font-size: clamp(52px, 8vw, 92px);
  margin: 10px 0;
}

.nosotros-hero p {
  max-width: 720px;
  font-size: 20px;
  line-height: 1.55;
}

.nosotros-content {
  display: grid;
  gap: 34px;
  line-height: 1.72;
  font-size: 18px;
}

.nosotros-content article {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: clamp(22px, 4vw, 38px);
  box-shadow: 0 12px 38px rgba(66,45,30,.07);
}

.nosotros-content h2 {
  margin: 0 0 16px;
  font-size: clamp(30px, 4vw, 48px);
}

.nosotros-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 22px;
}

.info-card {
  background: var(--cream) !important;
}

.final-message {
  background: linear-gradient(135deg, #fff8ec, #fff) !important;
  border-color: #dabf9e !important;
}

@media (max-width: 760px) {
  .nosotros-grid {
    grid-template-columns: 1fr;
  }

  .wa-float-clean {
    width: 56px;
    height: 56px;
    right: 15px;
    bottom: 15px;
  }

  .wa-float-clean img {
    width: 56px;
    height: 56px;
  }
}

/* ===== Menú bajo logo + áreas políticas ===== */
.store-header {
  background: #fffaf1;
}

.desktop-nav-line {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 18px 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  border-top: 1px solid rgba(229,210,187,.45);
}

.desktop-nav-line a {
  color: var(--ink);
  font-weight: 750;
  font-size: 15px;
  padding: 10px 4px 0;
  position: relative;
}

.desktop-nav-line a::after {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: -5px;
  height: 2px;
  border-radius: 999px;
  background: var(--red);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .2s ease;
}

.desktop-nav-line a:hover::after {
  transform: scaleX(1);
}

.policy-menu-block {
  display: grid;
  gap: 7px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.policy-menu-block strong {
  color: var(--red);
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.policy-menu-block a {
  font-size: 14px;
  padding: 8px 10px !important;
}

.store-footer {
  grid-template-columns: repeat(5, 1fr) !important;
}

.policy-page {
  max-width: 920px;
}

.policy-page h1 {
  font-size: clamp(42px, 6vw, 72px);
  margin: 0 0 18px;
}

.policy-page h2 {
  margin-top: 28px;
}

.policy-page p {
  font-size: 18px;
  line-height: 1.72;
  color: #4d4038;
}

@media (max-width: 1050px) {
  .store-footer {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 780px) {
  .desktop-nav-line {
    display: none;
  }

  .store-footer {
    grid-template-columns: 1fr !important;
  }
}


/* ===== Corrección menú: sin WhatsApp lateral y sin menú duplicado ===== */
.menu-whatsapp {
  display: none !important;
}

@media (max-width: 780px) {
  .desktop-nav-line {
    display: none !important;
  }
}

/* Si una página antigua carga este CSS, evita que el menú bajo logo aparezca sin diseño */
.site-header + .desktop-nav-line,
.site-header .desktop-nav-line {
  display: none !important;
}


/* ===== FIX DEFINITIVO WHATSAPP FLOTANTE: PNG cuadrado sin deformación ===== */
.wa-float-clean {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: transparent !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.22) !important;
  transform: none !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

.wa-float-clean img {
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  border: 0 !important;
  border-radius: 18px !important;
  padding: 0 !important;
  margin: 0 !important;
  transform: none !important;
  background: transparent !important;
  aspect-ratio: 1 / 1 !important;
  box-shadow: none !important;
}

.wa-float-clean::before,
.wa-float-clean::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 768px) {
  .wa-float-clean {
    right: 15px !important;
    bottom: 15px !important;
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }

  .wa-float-clean img {
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }
}

/* ===== Página Precios de despacho ===== */
.dispatch-prices-page {
  max-width: 1240px;
}

.dispatch-hero {
  background: linear-gradient(135deg, #fff3d7, #fffaf1);
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: clamp(28px, 5vw, 56px);
  box-shadow: 0 18px 44px rgba(66,45,30,.08);
  margin-bottom: 28px;
}

.dispatch-hero h1 {
  font-size: clamp(46px, 7vw, 84px);
  margin: 8px 0 14px;
}

.dispatch-hero .lead {
  font-size: 20px;
  line-height: 1.6;
  max-width: 820px;
  color: #5e5047;
}

.dispatch-map-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: 12px;
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 28px;
}

.dispatch-map-card img {
  width: 100%;
  height: auto;
  border-radius: 18px;
  object-fit: contain;
}

.dispatch-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
  margin-bottom: 34px;
}

.dispatch-free {
  background: linear-gradient(135deg, #fff1bf, #fffaf1) !important;
  border-color: #e0ad33 !important;
}

.dispatch-rates {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: clamp(22px, 4vw, 38px);
  box-shadow: 0 15px 40px rgba(66,45,30,.08);
}

.dispatch-rate-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}

.dispatch-rate {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: center;
  border: 1px solid #ead7bd;
  background: #fffaf1;
  border-radius: 16px;
  padding: 14px;
}

.dispatch-rate strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 999px;
  background: #f1c447;
  color: #2b1d13;
  font-size: 20px;
  font-weight: 900;
}

.dispatch-rate p {
  margin: 0;
  color: #4d4038;
  line-height: 1.45;
}

.dispatch-important {
  margin-top: 22px;
  border-left: 5px solid var(--red);
  padding: 18px 20px;
  background: #fff4e7;
  border-radius: 16px;
}

.dispatch-cta {
  padding-top: 0;
}

@media (max-width: 820px) {
  .dispatch-summary,
  .dispatch-rate-grid {
    grid-template-columns: 1fr;
  }

  .dispatch-rate {
    grid-template-columns: 1fr;
  }

  .dispatch-rate strong {
    width: fit-content;
    padding: 0 18px;
  }
}

:root{
  --red:#8f1d18;
  --red2:#72130f;
  --cream:#fff8ec;
  --cream2:#f7efe2;
  --ink:#281d18;
  --muted:#685b52;
  --line:#e5d2bb;
  --green:#128c4a;
  --shadow:0 16px 45px rgba(66,45,30,.12);
}
*{box-sizing:border-box}
body{margin:0;background:#fffaf1;color:var(--ink);font-family:Arial,system-ui,-apple-system,Segoe UI,sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.store-header{position:sticky;top:0;background:#fffaf1;border-bottom:1px solid var(--line);z-index:1000}
.topbar{height:76px;display:grid;grid-template-columns:90px 1fr 90px;align-items:center;max-width:1240px;margin:auto;padding:0 18px}
.brand{justify-self:center}
.brand img{height:58px;width:auto}
.menu-btn,.cart-pill,.drawer-head button{border:1px solid var(--line);background:#fff;border-radius:14px;min-height:44px;font-weight:900;cursor:pointer}
.menu-btn{width:54px;font-size:26px}
.cart-pill{justify-self:end;display:inline-flex;align-items:center;gap:8px;padding:0 14px}
.cart-icon{font-size:22px}.cart-icon-img{width:24px;height:24px;display:block;object-fit:contain;border-radius:6px;flex:0 0 24px}.cart-pill [data-cart-count]{background:#333;color:#fff;border-radius:999px;min-width:25px;height:25px;display:inline-flex;align-items:center;justify-content:center;font-weight:900}
.side-menu,.cart-drawer{position:fixed;top:0;bottom:0;background:#fffaf1;z-index:1200;width:min(390px,92vw);box-shadow:var(--shadow);transition:transform .25s ease}
.side-menu{left:0;transform:translateX(-105%)}.cart-drawer{right:0;transform:translateX(105%)}
.side-menu.is-open,.cart-drawer.is-open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.36);z-index:1100;display:none}.drawer-overlay.is-open{display:block}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid var(--line)}
.drawer-head strong{font-size:20px}.drawer-head button{width:42px;font-size:28px}
.side-menu nav{display:grid;gap:4px;padding:18px}.side-menu a{padding:12px;border-radius:12px;font-weight:800}.side-menu a:hover{background:var(--cream2)}.side-menu hr{width:100%;border:0;border-top:1px solid var(--line)}
.hero{min-height:610px;display:flex;align-items:center;background:linear-gradient(90deg,rgba(32,21,15,.70),rgba(32,21,15,.28)),url('/assets/img/editorial/hero-new.webp') center/cover no-repeat;color:#fff}
.hero-inner{max-width:1240px;margin:auto;padding:80px 20px}.eyebrow{text-transform:uppercase;letter-spacing:.07em;font-size:12px;font-weight:900;color:#8d6a3a}.hero .eyebrow{color:#ffd89a}
h1,h2{font-family:Georgia,'Times New Roman',serif;color:var(--red);line-height:1.03} .hero h1{font-size:clamp(52px,9vw,96px);color:#fff;margin:10px 0}.hero p{font-size:20px;max-width:680px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 18px;border-radius:11px;font-weight:900;border:1px solid transparent;cursor:pointer;text-align:center}
.btn.primary,.button.primary{background:var(--red)!important;color:#fff!important;border-color:var(--red)!important}.btn.primary:hover{background:var(--red2)!important}
.btn.ghost{background:#fff;color:var(--red);border-color:var(--line)}.btn.outline{background:#fffaf1;color:var(--red);border-color:#d5bda2}
.container,.section{max-width:1240px;margin:auto;padding:54px 20px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:24px}.section-head h2{font-size:42px;margin:0}.section-head p{color:var(--muted)}
.catalog-tools{display:grid;grid-template-columns:minmax(280px,1fr) minmax(220px,300px) minmax(220px,300px);gap:14px;align-items:end;margin:30px 0}.tool{display:grid;gap:8px;font-weight:900;color:#5f5148}.tool input,.tool select{height:48px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:0 14px;font-weight:800;font-size:15px}
.results{color:var(--red);font-weight:900;margin:0 0 20px}
.product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}.product-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}.product-image{background:#fff4e6;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}.product-image img{width:100%;height:100%;object-fit:contain}.product-info{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}.product-info h3{margin:0;font-size:18px}.price{font-size:22px;color:var(--red)}
.card-actions{display:grid;gap:8px;margin-top:auto}.card-actions .btn{width:100%}
.product-detail{display:grid;grid-template-columns:minmax(0,1fr) 520px;gap:34px;align-items:start}.detail-image{background:#fff4e6;border:1px solid var(--line);border-radius:18px;overflow:hidden}.detail-image img{width:100%;height:100%;object-fit:contain}.detail-info h1{font-size:46px;margin:0 0 14px}.detail-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:20px 0}.meta-box{border:1px solid var(--line);border-radius:12px;background:var(--cream);padding:14px}.meta-box small{display:block;font-weight:900;color:var(--muted);margin-bottom:5px}.detail-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:16px 0}.detail-actions .btn{width:100%}.note{font-size:14px;color:var(--muted)}
.qty-control{display:flex;align-items:center;border:1px solid #d1bba0;border-radius:12px;background:#fff;overflow:hidden;width:fit-content}.qty-control button{width:42px;height:42px;border:0;background:#fff4e6;font-size:24px;font-weight:900;cursor:pointer}.qty-control input{width:78px;height:42px;border:0;text-align:center;font-weight:900;font-size:16px}.product-qty{margin:6px 0;width:100%}.product-qty input{flex:1}
.related-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.related-row .product-card .card-actions{display:none}
.cart-items{padding:14px;display:grid;gap:12px;max-height:calc(100vh - 230px);overflow:auto}.cart-item{display:grid;grid-template-columns:78px 1fr auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px;background:#fff}.cart-item img{width:78px;height:78px;object-fit:contain;background:#fff4e6;border-radius:8px}.cart-item h4{margin:0}.cart-summary{padding:16px;border-top:1px solid var(--line);display:grid;gap:10px}
.checkout{display:grid;grid-template-columns:1fr 420px;gap:24px}.checkout-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;display:grid;gap:12px}.checkout-form label{display:grid;gap:7px;font-weight:800}.checkout-form input,.checkout-form select,.checkout-form textarea{border:1px solid var(--line);border-radius:10px;min-height:44px;padding:10px;font-weight:700}
.quote-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.38);z-index:2000;display:flex;align-items:center;justify-content:center;padding:18px}.quote-modal{width:min(680px,96vw);max-height:92vh;overflow:auto;background:#fffaf1;border-radius:18px;box-shadow:var(--shadow)}.quote-modal header{display:flex;justify-content:space-between;padding:18px;border-bottom:1px solid var(--line)}.quote-modal form{display:grid;gap:12px;padding:18px}.quote-modal input,.quote-modal textarea{border:1px solid var(--line);border-radius:10px;min-height:44px;padding:10px}
.store-footer{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:#211914;color:#fff4e7;padding:40px 20px}.store-footer h3{margin-top:0}.store-footer a{display:block;color:#fff4e7;margin:6px 0}.copyright{background:#150f0c;color:#fff;padding:16px;text-align:center}
@media(max-width:1000px){.product-grid{grid-template-columns:repeat(3,1fr)}.product-detail,.checkout{grid-template-columns:1fr}.detail-actions{grid-template-columns:1fr}.store-footer{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.product-grid,.related-row{grid-template-columns:1fr 1fr}.catalog-tools{grid-template-columns:1fr}.topbar{grid-template-columns:70px 1fr 70px}.brand img{height:48px}.hero{min-height:500px}.section{padding:40px 16px}.section-head{display:block}.store-footer{grid-template-columns:1fr}}
@media(max-width:460px){.product-grid,.related-row{grid-template-columns:1fr}.hero h1{font-size:48px}}

/* ===== Ajustes visuales: tipografías elegantes + WhatsApp ===== */
body {
  font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif !important;
  font-weight: 400;
  letter-spacing: -0.01em;
}

p, li, label, input, select, textarea {
  font-weight: 400 !important;
}

.product-info h3,
.detail-info h1,
.section-head h2,
.nosotros-content h2,
.nosotros-hero h1 {
  letter-spacing: -0.02em;
}

.product-info h3 {
  font-weight: 650 !important;
}

.product-info p,
.meta-box strong,
.tool,
.note {
  font-weight: 500 !important;
}

.btn,
.menu-btn,
.cart-pill {
  font-weight: 750 !important;
}

.eyebrow {
  font-weight: 700 !important;
  letter-spacing: .08em;
}

.wa-float-clean {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 62px;
  height: 62px;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.22);
  background: transparent;
}

.wa-float-clean img {
  width: 62px;
  height: 62px;
  object-fit: contain;
  display: block;
}

.menu-whatsapp {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  background: #e9fff0;
  color: #127a3a !important;
  border: 1px solid #b7ebc7;
}

.menu-whatsapp img {
  width: 24px;
  height: 24px;
}

.nosotros-hero {
  min-height: 520px;
  display: flex;
  align-items: center;
  background: linear-gradient(90deg, rgba(37,23,15,.70), rgba(37,23,15,.25)), url('/assets/img/editorial/hero-new.webp') center/cover no-repeat;
  color: #fff;
}

.nosotros-hero__content {
  max-width: 1180px;
  margin: auto;
  padding: 80px 20px;
}

.nosotros-hero h1 {
  color: #fff;
  font-size: clamp(52px, 8vw, 92px);
  margin: 10px 0;
}

.nosotros-hero p {
  max-width: 720px;
  font-size: 20px;
  line-height: 1.55;
}

.nosotros-content {
  display: grid;
  gap: 34px;
  line-height: 1.72;
  font-size: 18px;
}

.nosotros-content article {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: clamp(22px, 4vw, 38px);
  box-shadow: 0 12px 38px rgba(66,45,30,.07);
}

.nosotros-content h2 {
  margin: 0 0 16px;
  font-size: clamp(30px, 4vw, 48px);
}

.nosotros-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 22px;
}

.info-card {
  background: var(--cream) !important;
}

.final-message {
  background: linear-gradient(135deg, #fff8ec, #fff) !important;
  border-color: #dabf9e !important;
}

@media (max-width: 760px) {
  .nosotros-grid {
    grid-template-columns: 1fr;
  }

  .wa-float-clean {
    width: 56px;
    height: 56px;
    right: 15px;
    bottom: 15px;
  }

  .wa-float-clean img {
    width: 56px;
    height: 56px;
  }
}

/* ===== Menú bajo logo + áreas políticas ===== */
.store-header {
  background: #fffaf1;
}

.desktop-nav-line {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 18px 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  border-top: 1px solid rgba(229,210,187,.45);
}

.desktop-nav-line a {
  color: var(--ink);
  font-weight: 750;
  font-size: 15px;
  padding: 10px 4px 0;
  position: relative;
}

.desktop-nav-line a::after {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: -5px;
  height: 2px;
  border-radius: 999px;
  background: var(--red);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .2s ease;
}

.desktop-nav-line a:hover::after {
  transform: scaleX(1);
}

.policy-menu-block {
  display: grid;
  gap: 7px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.policy-menu-block strong {
  color: var(--red);
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.policy-menu-block a {
  font-size: 14px;
  padding: 8px 10px !important;
}

.store-footer {
  grid-template-columns: repeat(5, 1fr) !important;
}

.policy-page {
  max-width: 920px;
}

.policy-page h1 {
  font-size: clamp(42px, 6vw, 72px);
  margin: 0 0 18px;
}

.policy-page h2 {
  margin-top: 28px;
}

.policy-page p {
  font-size: 18px;
  line-height: 1.72;
  color: #4d4038;
}

@media (max-width: 1050px) {
  .store-footer {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 780px) {
  .desktop-nav-line {
    display: none;
  }

  .store-footer {
    grid-template-columns: 1fr !important;
  }
}


/* ===== Corrección menú: sin WhatsApp lateral y sin menú duplicado ===== */
.menu-whatsapp {
  display: none !important;
}

@media (max-width: 780px) {
  .desktop-nav-line {
    display: none !important;
  }
}

/* Si una página antigua carga este CSS, evita que el menú bajo logo aparezca sin diseño */
.site-header + .desktop-nav-line,
.site-header .desktop-nav-line {
  display: none !important;
}


/* ===== FIX DEFINITIVO WHATSAPP FLOTANTE: PNG cuadrado sin deformación ===== */
.wa-float-clean {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: transparent !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.22) !important;
  transform: none !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

.wa-float-clean img {
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  max-width: 62px !important;
  max-height: 62px !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  border: 0 !important;
  border-radius: 18px !important;
  padding: 0 !important;
  margin: 0 !important;
  transform: none !important;
  background: transparent !important;
  aspect-ratio: 1 / 1 !important;
  box-shadow: none !important;
}

.wa-float-clean::before,
.wa-float-clean::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 768px) {
  .wa-float-clean {
    right: 15px !important;
    bottom: 15px !important;
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }

  .wa-float-clean img {
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    border-radius: 16px !important;
  }
}

/* ===== Página Precios de despacho ===== */
.dispatch-prices-page {
  max-width: 1240px;
}

.dispatch-hero {
  background: linear-gradient(135deg, #fff3d7, #fffaf1);
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: clamp(28px, 5vw, 56px);
  box-shadow: 0 18px 44px rgba(66,45,30,.08);
  margin-bottom: 28px;
}

.dispatch-hero h1 {
  font-size: clamp(46px, 7vw, 84px);
  margin: 8px 0 14px;
}

.dispatch-hero .lead {
  font-size: 20px;
  line-height: 1.6;
  max-width: 820px;
  color: #5e5047;
}

.dispatch-map-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: 12px;
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 28px;
}

.dispatch-map-card img {
  width: 100%;
  height: auto;
  border-radius: 18px;
  object-fit: contain;
}

.dispatch-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
  margin-bottom: 34px;
}

.dispatch-free {
  background: linear-gradient(135deg, #fff1bf, #fffaf1) !important;
  border-color: #e0ad33 !important;
}

.dispatch-rates {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: clamp(22px, 4vw, 38px);
  box-shadow: 0 15px 40px rgba(66,45,30,.08);
}

.dispatch-rate-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}

.dispatch-rate {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: center;
  border: 1px solid #ead7bd;
  background: #fffaf1;
  border-radius: 16px;
  padding: 14px;
}

.dispatch-rate strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 999px;
  background: #f1c447;
  color: #2b1d13;
  font-size: 20px;
  font-weight: 900;
}

.dispatch-rate p {
  margin: 0;
  color: #4d4038;
  line-height: 1.45;
}

.dispatch-important {
  margin-top: 22px;
  border-left: 5px solid var(--red);
  padding: 18px 20px;
  background: #fff4e7;
  border-radius: 16px;
}

.dispatch-cta {
  padding-top: 0;
}

@media (max-width: 820px) {
  .dispatch-summary,
  .dispatch-rate-grid {
    grid-template-columns: 1fr;
  }

  .dispatch-rate {
    grid-template-columns: 1fr;
  }

  .dispatch-rate strong {
    width: fit-content;
    padding: 0 18px;
  }
}


/* ===== FIX MÓVIL FINAL: menú lateral, carrito y modales ===== */

/* Bloquea el scroll de la página cuando el menú, carrito o modal están abiertos */
body.drawer-open,
body.modal-open {
  overflow: hidden !important;
  touch-action: none !important;
}

/* El menú lateral debe desplazarse por dentro, no mover la web de fondo */
.side-menu,
.cart-drawer {
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
}

/* En móvil el menú debe ocupar casi todo el alto y no cortarse */
@media (max-width: 780px) {
  .side-menu {
    width: min(88vw, 380px) !important;
    max-width: 88vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    padding-bottom: 42px !important;
  }

  .side-menu nav {
    padding-bottom: 80px !important;
  }

  .drawer-head {
    position: sticky !important;
    top: 0 !important;
    background: #fffaf1 !important;
    z-index: 2 !important;
  }
}

/* Carrito: el número no debe salirse del cuadro */
.cart-pill {
  position: relative !important;
  min-width: 86px !important;
  height: 52px !important;
  padding: 0 14px !important;
  justify-content: center !important;
  overflow: visible !important;
}

.cart-icon-img {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  min-height: 28px !important;
  object-fit: contain !important;
}

.cart-pill [data-cart-count] {
  position: absolute !important;
  top: -8px !important;
  right: -8px !important;
  min-width: 30px !important;
  height: 30px !important;
  padding: 0 7px !important;
  border-radius: 999px !important;
  background: #303030 !important;
  color: #ffffff !important;
  border: 2px solid #fffaf1 !important;
  font-size: 14px !important;
  line-height: 1 !important;
  z-index: 3 !important;
}

@media (max-width: 540px) {
  .cart-pill {
    min-width: 72px !important;
    height: 48px !important;
    padding: 0 12px !important;
  }

  .cart-icon-img {
    width: 25px !important;
    height: 25px !important;
    min-width: 25px !important;
    min-height: 25px !important;
  }

  .cart-pill [data-cart-count] {
    top: -7px !important;
    right: -7px !important;
    min-width: 28px !important;
    height: 28px !important;
    font-size: 13px !important;
  }
}

/* Modal de cotización/detal: adaptado al móvil */
.quote-modal-backdrop {
  align-items: flex-start !important;
  justify-content: center !important;
  padding: 12px !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
}

.quote-modal {
  width: min(680px, 100%) !important;
  max-width: 100% !important;
  max-height: calc(100dvh - 24px) !important;
  margin: 0 auto !important;
  overflow-y: auto !important;
  border-radius: 18px !important;
}

.quote-modal header {
  position: sticky !important;
  top: 0 !important;
  background: #fffaf1 !important;
  z-index: 2 !important;
}

.quote-modal form {
  display: grid !important;
  gap: 14px !important;
}

.quote-modal label {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
  font-size: 16px !important;
  line-height: 1.3 !important;
}

.quote-modal input,
.quote-modal textarea {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  font-size: 16px !important;
}

.quote-modal textarea {
  min-height: 96px !important;
  resize: vertical !important;
}

.quote-modal .btn {
  width: 100% !important;
  min-height: 52px !important;
}

@media (max-width: 540px) {
  .quote-modal-backdrop {
    padding: 10px !important;
  }

  .quote-modal {
    width: 100% !important;
    border-radius: 16px !important;
    max-height: calc(100dvh - 20px) !important;
  }

  .quote-modal header {
    padding: 14px 16px !important;
  }

  .quote-modal form {
    padding: 16px !important;
  }

  .quote-modal p {
    font-size: 15px !important;
    line-height: 1.35 !important;
  }

  .quote-modal label {
    font-size: 15px !important;
  }
}
