
/* === Font cargado DENTRO del style === */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

/* ==========================================================================
   ENCAPSULAMIENTO: TODAS las reglas bajo #vxn-menu
   ========================================================================== */
#vxn-menu,
#vxn-menu *,
#vxn-menu *::before,
#vxn-menu *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
#vxn-menu { font-family: 'Poppins', 'Segoe UI', system-ui, sans-serif; }
#vxn-menu a { text-decoration: none; color: inherit; }
#vxn-menu ul,
#vxn-menu li { list-style: none; }
#vxn-menu button { font-family: inherit; cursor: pointer; border: none; background: none; }

#vxn-menu form {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  box-shadow: none;
  display: block;
}

#vxn-menu .vxn-logo-img { max-width: 100%; height: auto; display: block; }
#vxn-menu .vxn-brand-logo img {
  max-width: 100%;
  max-height: 28px;
  height: auto;
  display: block;
  object-fit: contain;
}

#vxn-menu .vxn-ico { width: 13px; height: 13px; flex-shrink: 0; display: inline-block; vertical-align: middle; }
#vxn-menu .vxn-topbar .vxn-ico { width: 11px; height: 11px; }
#vxn-menu .vxn-srch-btn .vxn-ico { width: 15px; height: 15px; }
#vxn-menu .vxn-dd-item .vxn-ico { width: 15px; height: 15px; margin-right: 6px; }
#vxn-menu .vxn-mci .vxn-ico { width: 13px; height: 13px; }
#vxn-menu .vxn-mob-link .vxn-ico { width: 16px; height: 16px; margin-right: 6px; }

/* === TOKENS === */
#vxn-menu {
  --v-dk: #353535;
  --v-accent: #00B2A6;
  --v-accent-h: #009990;
  --v-accent-soft: #e8f5f4;
  --v-orange: #F36F21;
  --v-yellow: #FFD100;
  --v-grad: linear-gradient(90deg, #00B2A6 0%, #F36F21 50%, #FFD100 100%);
  --v-bg: #ffffff;
  --v-sf: #F7F8F9;
  --v-tx: #2D2D2D;
  --v-tx2: #6B7280;
  --v-tx3: #9CA3AF;
  --v-brd: #E5E7EB;
  --v-shd: 0 8px 30px rgba(0, 0, 0, 0.10);
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1050;
  font-size: 13px;
  line-height: 1.5;
  color: var(--v-tx);
}

#vxn-menu .vxn-gradline { height: 3px; background: var(--v-grad); }

/* ======================== TOP BAR ======================== */
#vxn-menu .vxn-topbar {
  background: var(--v-dk);
  color: #b0b0b0;
  font-size: 11px;
  padding: 5px 0;
  letter-spacing: .3px;
}
#vxn-menu .vxn-topbar-in {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
#vxn-menu .vxn-topbar a { color: #ccc; font-weight: 500; transition: color .2s; }
#vxn-menu .vxn-topbar a:hover { color: #fff; }
#vxn-menu .vxn-tb-phones { white-space: nowrap; }
#vxn-menu .vxn-tb-links { display: flex; gap: 16px; align-items: center; }

/* ======================== HEADER ======================== */
#vxn-menu .vxn-hdr { background: var(--v-bg); border-bottom: 1px solid var(--v-brd); }
#vxn-menu .vxn-hdr-in {
  max-width: 1320px;
  margin: 0 auto;
  padding: 10px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
}
#vxn-menu .vxn-logo { flex-shrink: 0; height: 40px; display: block; }
#vxn-menu .vxn-logo-img { height: 40px; width: auto; }

#vxn-menu .vxn-srch { flex: 1; max-width: 580px; }
#vxn-menu .vxn-srch-box {
  display: flex;
  align-items: center;
  background: var(--v-sf);
  border: 1.5px solid var(--v-brd);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
#vxn-menu .vxn-srch-box:focus-within {
  border-color: var(--v-accent);
  box-shadow: 0 0 0 3px rgba(0, 178, 166, .1);
}
#vxn-menu .vxn-srch-in {
  flex: 1;
  padding: 9px 14px;
  border: none;
  outline: none;
  background: transparent;
  font-size: 13px;
  color: var(--v-tx);
  font-family: inherit;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
  min-height: 0;
  line-height: 1.5;
}
#vxn-menu .vxn-srch-in::placeholder { color: var(--v-tx3); }

#vxn-menu .vxn-srch-btn {
  padding: 9px 16px;
  background: var(--v-accent);
  color: #fff;
  display: flex;
  align-items: center;
  transition: background .2s;
}
#vxn-menu .vxn-srch-btn:hover { background: var(--v-accent-h); }

/* ======================== AUTOCOMPLETE DROPDOWN ======================== */
#vxn-menu .vxn-srch { position: relative; }
#vxn-menu .vxn-srch-dd {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--v-bg);
  border: 1px solid var(--v-brd);
  border-radius: 10px;
  box-shadow: var(--v-shd);
  max-height: 420px;
  overflow-y: auto;
  z-index: 1070;
  display: none;
  padding: 6px;
}
#vxn-menu .vxn-srch-dd.vxn-open { display: block; }
#vxn-menu .vxn-srch-hdr {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--v-tx3);
  font-weight: 700;
  padding: 8px 10px 4px;
  border-bottom: 1px solid var(--v-brd);
  margin-bottom: 4px;
}
#vxn-menu .vxn-srch-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: background .12s;
  text-decoration: none;
  color: var(--v-tx);
}
#vxn-menu .vxn-srch-item:hover,
#vxn-menu .vxn-srch-item.vxn-active {
  background: var(--v-sf);
}
#vxn-menu .vxn-srch-item-main { flex: 1; min-width: 0; }
#vxn-menu .vxn-srch-item-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--v-tx);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#vxn-menu .vxn-srch-item-label mark {
  background: transparent;
  color: var(--v-accent);
  font-weight: 700;
  padding: 0;
}
#vxn-menu .vxn-srch-item-badge {
  font-size: 9.5px;
  padding: 2px 7px;
  border-radius: 10px;
  background: var(--v-sf);
  color: var(--v-tx2);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
  flex-shrink: 0;
  border: 1px solid var(--v-brd);
}
#vxn-menu .vxn-srch-item-badge.vxn-b-cat { background: #E8F5F4; color: var(--v-accent-h); border-color: #c5e5e2; }
#vxn-menu .vxn-srch-item-badge.vxn-b-model { background: #FEF3E8; color: var(--v-orange); border-color: #f5d9be; }
#vxn-menu .vxn-srch-item-badge.vxn-b-brand { background: #EEF0FF; color: #4752c3; border-color: #d5daf5; }
#vxn-menu .vxn-srch-item-badge.vxn-b-solution { background: #FFF8E1; color: #9E7B00; border-color: #efe0a8; }
#vxn-menu .vxn-srch-item-badge.vxn-b-service { background: #F5F5F5; color: var(--v-tx2); border-color: var(--v-brd); }
#vxn-menu .vxn-srch-view-all {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--v-accent);
  background: var(--v-accent-soft);
  border-radius: 6px;
  margin-top: 4px;
  transition: background .12s;
  text-decoration: none;
}
#vxn-menu .vxn-srch-view-all:hover { background: #d9f0ee; }
#vxn-menu .vxn-srch-empty {
  padding: 18px 12px;
  text-align: center;
  font-size: 12px;
  color: var(--v-tx3);
}

#vxn-menu .vxn-acts { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
#vxn-menu .vxn-abtn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid var(--v-brd);
  background: transparent;
  color: var(--v-tx);
  transition: all .2s;
  position: relative;
  cursor: pointer;
}
#vxn-menu .vxn-abtn:hover { border-color: #ccc; background: var(--v-sf); }
#vxn-menu .vxn-abtn-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--v-sf);
  display: flex;
  align-items: center;
  justify-content: center;
}
#vxn-menu .vxn-abtn-txt { font-size: 11px; line-height: 1.3; text-align: left; }
#vxn-menu .vxn-abtn-txt .vxn-sm { display: block; color: var(--v-tx3); font-weight: 400; }
#vxn-menu .vxn-abtn-txt .vxn-bd { display: block; font-weight: 600; color: var(--v-tx); }
#vxn-menu .vxn-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: #DC2626;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* ======================== DROPDOWN GENÉRICO ======================== */
#vxn-menu .vxn-dd {
  position: absolute;
  top: calc(100% + 4px);
  background: var(--v-bg);
  border: 1px solid var(--v-brd);
  border-radius: 10px;
  padding: 6px;
  box-shadow: var(--v-shd);
  z-index: 1060;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity .15s ease, visibility .15s ease, transform .15s ease;
  pointer-events: none;
}
#vxn-menu .vxn-dd.vxn-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

#vxn-menu .vxn-dd--center {
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
}
#vxn-menu .vxn-dd--center.vxn-open {
  transform: translateX(-50%) translateY(0);
}

#vxn-menu .vxn-dd a.vxn-dd-item {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--v-tx);
  border-radius: 6px;
  transition: background .12s;
}
#vxn-menu .vxn-dd a.vxn-dd-item:hover { background: var(--v-sf); }

/* ======================== AUTH STATE (invitado / logueado) ======================== */
/* Por defecto mostramos el estado invitado (más seguro).
   El JS alterna a .vxn-is-logged en el <body> si detecta usuario autenticado. */
#vxn-menu .vxn-auth-user { display: none; }
#vxn-menu .vxn-auth-guest { display: block; }
body.vxn-is-logged #vxn-menu .vxn-auth-user { display: block; }
body.vxn-is-logged #vxn-menu .vxn-auth-guest { display: none; }
/* Para el span del botón user en header (los divs internos pueden ser flex) */
#vxn-menu .vxn-abtn .vxn-auth-user,
#vxn-menu .vxn-abtn .vxn-auth-guest { line-height: 1.3; }
#vxn-menu .vxn-dd-divider { height: 1px; background: var(--v-brd); margin: 4px 6px; }
#vxn-menu .vxn-dd-item--primary { color: var(--v-accent); font-weight: 600; }
#vxn-menu .vxn-dd-item--primary:hover { background: var(--v-accent-soft); }

/* ======================== NAV BAR ======================== */
#vxn-menu .vxn-nav { background: var(--v-sf); border-top: 1px solid var(--v-brd); }
#vxn-menu .vxn-nav-in {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  gap: 0;
  position: relative;
}
#vxn-menu .vxn-cat-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  color: var(--v-tx);
  font-weight: 600;
  font-size: 13px;
  font-family: inherit;
  transition: all .2s;
}
#vxn-menu .vxn-cat-btn:hover { background: rgba(0, 0, 0, .04); }
#vxn-menu .vxn-cat-btn.active { background: var(--v-dk); color: #fff; }
#vxn-menu .vxn-cat-arr { font-size: 9px; transition: transform .2s; margin-left: 2px; }
#vxn-menu .vxn-cat-btn.active .vxn-cat-arr { transform: rotate(180deg); }
#vxn-menu .vxn-sep { width: 1px; height: 20px; background: var(--v-brd); margin: 0 2px; flex-shrink: 0; }

#vxn-menu .vxn-nl {
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--v-tx2);
  transition: all .2s;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  display: inline-block;
}
#vxn-menu .vxn-nl:hover { color: var(--v-tx); border-bottom-color: var(--v-dk); }

/* Accesos destacados en nav bar */
#vxn-menu .vxn-nl-star {
  color: var(--v-accent);
  font-weight: 600;
}
#vxn-menu .vxn-nl-star:hover {
  color: var(--v-accent-h);
  border-bottom-color: var(--v-accent);
}

/* ======================== MEGA MENU ======================== */
#vxn-menu .vxn-mega {
  position: absolute;
  top: 100%;
  left: 0;
  width: 920px;
  display: flex;
  background: var(--v-bg);
  border: 1px solid var(--v-brd);
  border-radius: 0 0 12px 12px;
  overflow: hidden;
  box-shadow: var(--v-shd);
  z-index: 1060;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity .15s ease, visibility .15s ease, transform .15s ease;
  pointer-events: none;
}
#vxn-menu .vxn-mega.vxn-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
#vxn-menu .vxn-mega-left {
  width: 230px;
  border-right: 1px solid var(--v-brd);
  padding: 6px 0;
  background: var(--v-sf);
  flex-shrink: 0;
  max-height: 520px;
  overflow-y: auto;
}
#vxn-menu .vxn-mega-cat {
  padding: 9px 14px;
  cursor: pointer;
  font-size: 12.5px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-left: 3px solid transparent;
  transition: all .12s;
  color: var(--v-tx2);
}
#vxn-menu .vxn-mega-cat:hover,
#vxn-menu .vxn-mega-cat.active {
  background: var(--v-bg);
  color: var(--v-tx);
  font-weight: 600;
  border-left-color: var(--v-dk);
}
#vxn-menu .vxn-mega-cat .vxn-mci { width: 16px; text-align: center; }
#vxn-menu .vxn-mega-right { flex: 1; padding: 16px 20px; overflow-y: auto; max-height: 520px; }
#vxn-menu .vxn-mega-sec {
  display: inline-block;
  vertical-align: top;
  min-width: 185px;
  margin-right: 22px;
  margin-bottom: 12px;
}
#vxn-menu .vxn-mega-sec h4 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--v-tx2);
  margin-bottom: 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--v-brd);
}
#vxn-menu .vxn-mega-sec a {
  display: block;
  padding: 3px 0;
  font-size: 12px;
  color: var(--v-tx2);
  transition: all .12s;
}
#vxn-menu .vxn-mega-sec a:hover { color: var(--v-tx); padding-left: 3px; }
#vxn-menu .vxn-mega-sec a.vxn-subseries {
  font-size: 11px;
  padding: 2px 0 2px 10px;
  color: var(--v-tx3);
}
#vxn-menu .vxn-mega-sec a.vxn-subseries:hover { color: var(--v-tx); padding-left: 13px; }

#vxn-menu .vxn-mega-cta {
  margin-top: 8px;
  padding: 9px 12px;
  background: var(--v-sf);
  border: 1px dashed var(--v-brd);
  border-radius: 8px;
  font-size: 11px;
  color: var(--v-tx2);
  clear: both;
}
#vxn-menu .vxn-mega-cta strong { color: var(--v-tx); }
#vxn-menu .vxn-mega-cta a { display: inline; padding: 0; color: var(--v-accent); font-weight: 600; }

#vxn-menu .vxn-featured-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: var(--v-sf);
  border: 1px solid var(--v-brd);
  border-radius: 8px;
  margin-top: 8px;
  transition: all .2s;
}
#vxn-menu .vxn-featured-card:hover { border-color: #bbb; box-shadow: 0 2px 10px rgba(0, 0, 0, .06); }

/* ======================== BRANDS DROPDOWN ======================== */
#vxn-menu .vxn-brands-dd {
  width: 540px;
  padding: 16px;
}
#vxn-menu .vxn-bdd-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--v-tx2);
  font-weight: 700;
  margin-bottom: 12px;
}
#vxn-menu .vxn-bdd-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
#vxn-menu .vxn-brand-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--v-brd);
  transition: all .2s;
}
#vxn-menu .vxn-brand-card:hover { border-color: #bbb; background: var(--v-sf); }
#vxn-menu .vxn-brand-logo {
  width: 40px;
  height: 40px;
  border-radius: 6px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  border: 1px solid #eee;
  flex-shrink: 0;
  overflow: hidden;
}
#vxn-menu .vxn-brand-name { font-weight: 600; font-size: 12px; color: var(--v-tx); }
#vxn-menu .vxn-brand-link { font-size: 10px; color: var(--v-tx2); }

/* ======================== LLAVE EN MANO ======================== */
#vxn-menu .vxn-llave-dd {
  width: 320px;
  padding: 12px;
}
#vxn-menu .vxn-ldd-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--v-tx2);
  font-weight: 700;
  margin-bottom: 8px;
  padding: 0 6px;
}
#vxn-menu .vxn-llave-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 10px;
  border-radius: 6px;
  transition: background .12s;
  gap: 8px;
}
#vxn-menu .vxn-llave-item:hover { background: var(--v-sf); }
#vxn-menu .vxn-li-name { font-weight: 600; font-size: 12.5px; color: var(--v-tx); }
#vxn-menu .vxn-li-desc { font-size: 10.5px; color: var(--v-tx3); }
#vxn-menu .vxn-li-arr { color: var(--v-tx3); font-size: 13px; flex-shrink: 0; }

/* ======================== SOPORTE ======================== */
#vxn-menu .vxn-soporte-dd {
  min-width: 200px;
}

/* ======================== MOBILE ======================== */
#vxn-menu .vxn-hamburger {
  display: none;
  flex-direction: column;
  justify-content: space-around;
  width: 26px;
  height: 26px;
  padding: 0;
  flex-shrink: 0;
}
#vxn-menu .vxn-hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: var(--v-tx);
  border-radius: 1px;
  transition: all .3s;
}
#vxn-menu .vxn-mob-panel {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: var(--v-bg);
  z-index: 1100;
  overflow-y: auto;
  padding: 0;
}
#vxn-menu .vxn-mob-panel.vxn-open { display: block; }
#vxn-menu .vxn-mob-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 18px;
  border-bottom: 1px solid var(--v-brd);
}
#vxn-menu .vxn-mob-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--v-sf);
  color: var(--v-tx);
  display: flex;
  align-items: center;
  justify-content: center;
}
#vxn-menu .vxn-mob-link {
  display: flex;
  align-items: center;
  padding: 13px 18px;
  font-size: 14px;
  font-weight: 500;
  color: var(--v-tx);
  border-bottom: 1px solid var(--v-brd);
  transition: background .12s;
}
#vxn-menu .vxn-mob-link:hover { background: var(--v-sf); }
#vxn-menu .vxn-mob-sub { display: none; padding: 0 18px 8px; background: var(--v-sf); }
#vxn-menu .vxn-mob-sub.vxn-open { display: block; }
#vxn-menu .vxn-mob-sub h5 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--v-tx2);
  margin: 10px 0 4px;
}
#vxn-menu .vxn-mob-sub a { display: block; padding: 5px 0; font-size: 13px; color: var(--v-tx2); }
#vxn-menu .vxn-mob-sub a:hover { color: var(--v-tx); }
#vxn-menu .vxn-mob-toggle-arrow { float: right; font-size: 11px; color: var(--v-tx3); transition: transform .2s; }

#vxn-menu-spacer { display: block; width: 100%; }

body.vxn-body-locked {
  overflow: hidden;
}

@media (prefers-reduced-motion: reduce) {
  #vxn-menu .vxn-dd,
  #vxn-menu .vxn-mega,
  #vxn-menu .vxn-mega-cat,
  #vxn-menu .vxn-mega-sec a,
  #vxn-menu .vxn-cat-arr,
  #vxn-menu .vxn-abtn,
  #vxn-menu .vxn-nl,
  #vxn-menu .vxn-brand-card,
  #vxn-menu .vxn-featured-card,
  #vxn-menu .vxn-llave-item,
  #vxn-menu .vxn-srch-box,
  #vxn-menu .vxn-hamburger span {
    transition-duration: 0.01ms !important;
  }
}

@media (max-width: 1068px) {
  #vxn-menu .vxn-nav-in { display: none !important; }
  #vxn-menu .vxn-hamburger { display: flex; }
  #vxn-menu .vxn-tb-links { display: none; }
  #vxn-menu .vxn-srch { max-width: 100%; }
}
@media (max-width: 640px) {
  #vxn-menu .vxn-abtn-txt { display: none; }
  #vxn-menu .vxn-abtn { padding: 6px 8px; }
  #vxn-menu .vxn-hdr-in { gap: 8px; padding: 8px 12px; }
  #vxn-menu .vxn-topbar { font-size: 10px; padding: 4px 0; }
  #vxn-menu .vxn-topbar-in { padding: 0 12px; }
  #vxn-menu .vxn-logo-img { height: 32px; }
}

/* ======================== OCULTAR HEADER NATIVO ODOO ======================== */
/* ⚠️ Reglas intencionalmente globales — ocultan el header nativo de Odoo 18 */
body > header#top,
header#top.o_header_standard,
header#top.o_header_affixed {
  display: none !important;
  height: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
  min-height: 0 !important;
  max-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}
/* FIX TÍTULOS — solo achica los títulos y los limita a 3 líneas */
#products_grid .o_wsale_product_information .o_wsale_products_item_title {
    font-size: clamp(0.78rem, 0.45rem + 1.5cqw, 1rem);
    line-height: 1.3;
    margin-bottom: 0.35rem;
    
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    
    min-height: calc(1.3em * 3);
    
    word-break: break-word;
    overflow-wrap: anywhere;
}


/* ... otros bloques de CSS que ya tenías (mega menu, etc.) ... */

/* FIX TÍTULOS — único cambio recomendado, bajo riesgo */
#products_grid .o_wsale_product_information .o_wsale_products_item_title {
    font-size: clamp(0.78rem, 0.45rem + 1.5cqw, 1rem);
    line-height: 1.3;
    margin-bottom: 0.35rem;
    
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    
    min-height: calc(1.3em * 3);
    
    word-break: break-word;
    overflow-wrap: anywhere;
}

/* ============================================================
   PULIDOS SHOP CARDS — Mejoras visuales finales       ← ESTO ES LO NUEVO
   ============================================================ */

#products_grid .o_wsale_products_grid_table,
#products_grid .o_wsale_products_grid_table_md {
    gap: 1.5rem !important;
}

#products_grid .oe_product_cart {
    border: 1px solid #e5e5e5;
    border-radius: 10px;
    padding: 0.75rem;
    transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
    background-color: #ffffff;
}

#products_grid .oe_product_cart:hover {
    box-shadow: 0 6px 20px rgba(0, 178, 166, 0.12);
    transform: translateY(-3px);
    border-color: #00B2A6;
}

#products_grid .product_default_code:nth-of-type(2) strong {
    color: #00B2A6;
}

#products_grid .product_default_code:nth-of-type(1) strong {
    color: #555;
}



<!-- ===================== HTML ===================== -->

#vxn-menu .vxn-topbar{transition:max-height .3s ease,padding .3s ease,opacity .2s ease;overflow:hidden;max-height:64px}
#vxn-menu.vxn-scrolled .vxn-topbar{max-height:0;padding-top:0;padding-bottom:0;opacity:0}

/* === Auditoria v10: contraste, foco, responsive movil === */
#vxn-menu .vxn-topbar{color:#c7c7c7}
#vxn-menu .vxn-mega-cat:focus-visible,#vxn-menu .vxn-nl:focus-visible,#vxn-menu .vxn-cat-btn:focus-visible,#vxn-menu .vxn-srch-item:focus-visible,#vxn-menu a:focus-visible,#vxn-menu button:focus-visible{outline:2px solid var(--v-accent);outline-offset:2px}
@media(max-width:640px){
  #vxn-menu .vxn-srch-in{font-size:16px}
  #vxn-menu .vxn-hamburger{width:30px;height:30px;padding:5px 2px;box-sizing:content-box}
  #vxn-menu .vxn-srch-dd{max-height:62vh}
  #vxn-menu .vxn-srch-item{padding:11px 12px}
}
@media(max-width:480px){
  #vxn-menu .vxn-tb-phones{font-size:9px;letter-spacing:0}
}
/* === v11: fix header movil (overflow a lo ancho) === */
#vxn-menu .vxn-srch{min-width:0}
@media(max-width:640px){
  #vxn-menu .vxn-hdr-in{flex-wrap:wrap;row-gap:10px}
  #vxn-menu .vxn-logo{margin-right:auto}
  #vxn-menu .vxn-srch{order:9;flex:1 1 100%;max-width:100%}
  #vxn-menu .vxn-acts{flex-shrink:0}
}
/* === v12: safe-area (notch) en landscape === */
@media(orientation:landscape) and (max-width:1068px){
  #vxn-menu .vxn-topbar-in,#vxn-menu .vxn-hdr-in,#vxn-menu .vxn-nav-in{padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right))}
}
/* === v13: matar overflow horizontal del documento (sin romper sticky) === */
html,body{overflow-x:clip;max-width:100%}
#vxn-menu{max-width:100%}
#vxn-menu .vxn-topbar-in,#vxn-menu .vxn-hdr-in,#vxn-menu .vxn-nav-in{max-width:min(1320px,100%)}
/* ===== VEXIN Shop Sidebar — toque LIGERO (sin bordes-caja, sin sticky) ===== */
.o_wsale_products_grid_before_rail{font-family:'Poppins',system-ui,sans-serif}
.o_wsale_products_grid_before_rail a:hover{color:#00B2A6}
.o_wsale_products_grid_before_rail .active>a,
.o_wsale_products_grid_before_rail a.active,
.o_wsale_products_grid_before_rail li.active>a{color:#00B2A6;font-weight:600}
.o_wsale_products_grid_before_rail .accordion-button:not(.collapsed){color:#00B2A6}
.o_wsale_products_grid_before_rail .accordion-button:focus{box-shadow:none}
.o_wsale_products_grid_before_rail .form-check-input{accent-color:#00B2A6}
.o_wsale_products_grid_before_rail .form-check-input:checked{background-color:#00B2A6;border-color:#00B2A6}
.o_wsale_products_grid_before_rail input[type=range]{accent-color:#00B2A6}
.o_wsale_products_grid_before_rail .o_wsale_price_range .progress-bar,
.o_wsale_products_grid_before_rail .o_wsale_price_range_origin{background-color:#00B2A6 !important}
/* un poco de aire en la lista de categorias */
.o_wsale_products_grid_before_rail li{margin-bottom:3px}
.o_wsale_products_grid_before_rail .form-check{padding-top:3px;padding-bottom:3px}

/* ===== Fix solape preexistente: ocultar offcanvas de filtros en DESKTOP ===== */
@media(min-width:992px){
  aside#o_wsale_offcanvas:not(.show){visibility:hidden !important;transform:translateX(100%) !important;pointer-events:none !important}
}

/* Offcanvas de filtros por encima del menu sticky en movil (z-index menu=1050) */
#o_wsale_offcanvas.offcanvas{z-index:1060 !important}
.offcanvas-backdrop.show{z-index:1059 !important}

/* Secciones de filtro sin caja (consistente con categorias flush) */
.o_wsale_products_grid_before_rail .accordion{--bs-accordion-border-width:0px;--bs-accordion-border-color:transparent}
.o_wsale_products_grid_before_rail .accordion-item{border:0 !important;background:transparent;border-radius:0 !important}
.o_wsale_products_grid_before_rail .accordion-button{padding-left:2px;padding-right:2px}
.o_wsale_products_grid_before_rail #o_wsale_price_range_option,
.o_wsale_products_grid_before_rail #wsale_products_attributes_collapse{border-top:1px solid #EDEFF1;padding-top:8px;margin-top:8px}

/* ===== Navegacion de categorias: legibilidad + trail activo + touch ===== */
.o_wsale_products_grid_before_rail .products_categories a{
  display:block;padding:3px 8px;border-radius:6px;font-size:13.5px;line-height:1.4;transition:background .12s,color .12s
}
.o_wsale_products_grid_before_rail .products_categories a:hover{background:#F2FBFA;color:#00B2A6}
.o_wsale_products_grid_before_rail .products_categories .active>a,
.o_wsale_products_grid_before_rail .products_categories a.active,
.o_wsale_products_grid_before_rail .products_categories li.active>a{
  background:#E8F9F8;color:#00B2A6;font-weight:600
}
/* sub-niveles mas tenues e indentados (jerarquia clara) */
.o_wsale_products_grid_before_rail .products_categories ul ul a{font-size:13px;color:#6B7280;padding-left:20px}
/* boton 'Filtros' movil: badge-ready + marca */
.o_wsale_products_grid_before_rail .accordion-button{min-height:42px}

/* ===== Carrusel del shop estilo CyberPuerta: compacto + contenido ===== */
body.vxn-shop section.s_carousel_wrapper.o_half_screen_height{height:auto !important;min-height:0 !important}
body.vxn-shop section.s_carousel_wrapper{margin:14px 10px 8px;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.08)}
/* Banner anclado a col-9 (anti-empalme en monitores anchos) */
@media(min-width:992px) and (max-width:1199.98px){body.vxn-shop section.s_carousel_wrapper{width:auto;max-width:none;margin:14px calc(50vw - 480px) 12px calc(50vw - 228px);border-radius:14px}}
@media(min-width:1200px) and (max-width:1399.98px){body.vxn-shop section.s_carousel_wrapper{width:auto;max-width:none;margin:14px calc(50vw - 570px) 12px calc(50vw - 273px);border-radius:14px}}
@media(min-width:1400px){body.vxn-shop section.s_carousel_wrapper{width:auto;max-width:none;margin:14px calc(50vw - 660px) 12px calc(50vw - 318px);border-radius:14px}}
body.vxn-shop section.s_carousel_wrapper .carousel-item{height:210px !important;min-height:210px !important;max-height:210px !important;padding:0 !important;overflow:hidden;background-size:cover !important;background-position:center !important}
body.vxn-shop section.s_carousel_wrapper .carousel-item .container{height:100%;display:flex;align-items:center;justify-content:center;padding-bottom:26px}
body.vxn-shop section.s_carousel_wrapper .carousel-item .container > .row{width:100%;margin:0}
body.vxn-shop section.s_carousel_wrapper .carousel-inner{height:210px}
body.vxn-shop section.s_carousel_wrapper .carousel,
body.vxn-shop section.s_carousel_wrapper .carousel-inner{border-radius:14px}
body.vxn-shop section.s_carousel_wrapper .carousel-indicators [data-bs-target]{width:10px;height:10px;border-radius:50%}

body.vxn-shop section.s_carousel_wrapper .carousel-indicators{bottom:6px;margin-bottom:0;z-index:6}
body.vxn-shop section.s_carousel_wrapper .carousel-indicators [data-bs-target]{margin:0 4px;background:rgba(255,255,255,.55)}
body.vxn-shop section.s_carousel_wrapper .carousel-indicators .active{background:#00B2A6}

/* ===== CyberPuerta proportions: subir Categorias al nivel del banner (desktop) ===== */
@media(min-width:992px){
  body.vxn-shop .o_wsale_products_grid_before_rail{margin-top:-228px !important;position:relative;z-index:20 !important}
}

/* ===== Fix accordion fantasma: toggle de subcategorias sin caja (solo chevron) ===== */
.o_wsale_products_grid_before_rail .o_categories_recursive_button,
.o_wsale_products_grid_before_rail .o_categories_recursive_button:not(.collapsed),
.o_wsale_products_grid_before_rail .o_categories_recursive_button:hover,
.o_wsale_products_grid_before_rail .o_categories_recursive_button:focus{background:transparent !important;box-shadow:none !important;border:0 !important;min-height:0 !important;padding:0 !important}

/* ===== Fix dots estirados: circulos pequenos forzados ===== */
body.vxn-shop section.s_carousel_wrapper .carousel-indicators{align-items:center}
body.vxn-shop section.s_carousel_wrapper .carousel-indicators button,
body.vxn-shop section.s_carousel_wrapper .carousel-indicators [data-bs-target]{box-sizing:border-box !important;width:9px !important;height:9px !important;min-width:9px !important;min-height:9px !important;max-height:9px !important;border-radius:50% !important;margin:0 4px !important;padding:0 !important;border:0 !important;flex:0 0 9px !important;align-self:center !important;opacity:1 !important;text-indent:0 !important;background:rgba(255,255,255,.6) !important}
body.vxn-shop section.s_carousel_wrapper .carousel-indicators button.active,
body.vxn-shop section.s_carousel_wrapper .carousel-indicators [data-bs-target].active{background:#00B2A6 !important}

/* ===== CyberPuerta: jerarquia categorias + flechas carrusel ===== */
body.vxn-shop .o_wsale_products_grid_before_rail h6.o_categories_collapse_title,
body.vxn-shop .o_wsale_products_grid_before_rail h6.accordion-header{margin-bottom:2px !important}
body.vxn-shop .o_wsale_products_grid_before_rail .o_categories_collapse_title .accordion-button{min-height:0 !important;font-size:15px;font-weight:700}
body.vxn-shop .o_wsale_products_grid_before_rail .wsale_products_categories_list .nav.flex-column{margin-bottom:6px !important;margin-top:2px !important}
body.vxn-shop .o_wsale_products_grid_before_rail .nav-item{margin-bottom:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .nav-item > a{padding:4px 8px !important}
body.vxn-shop .o_wsale_products_grid_before_rail .accordion-button{min-height:0 !important}

/* ===== Quitar gap Categorias -> primer item ===== */
body.vxn-shop .o_wsale_products_grid_before_rail .o_categories_collapse_title{margin:0 !important;padding:0 !important;line-height:1.2 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .o_categories_collapse_title .accordion-button{padding:0 !important;min-height:0 !important;line-height:1.2 !important}
body.vxn-shop .o_wsale_products_grid_before_rail #o_wsale_categories,
body.vxn-shop .o_wsale_products_grid_before_rail .wsale_products_categories_list{margin:0 !important;padding:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail #o_wsale_categories > .nav,
body.vxn-shop .o_wsale_products_grid_before_rail .wsale_products_categories_list .nav{margin:6px 0 6px 0 !important;padding:0 !important}

/* ===== Reducir el titulo gigante de categoria (H1) en el shop ===== */
body.vxn-shop #wrap h1{font-size:clamp(24px,2.4vw,34px) !important;line-height:1.15 !important;margin-bottom:.4rem !important}

/* ===== Categorias: quitar chevron + aplastar boton alto (el gap real) ===== */
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .o_categories_collapse_title{margin:0 !important;padding:0 !important;border:0 !important;line-height:1.1 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .o_categories_collapse_title .accordion-button{padding:0 !important;min-height:0 !important;height:auto !important;line-height:1.2 !important;margin:0 !important;pointer-events:none}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .o_categories_collapse_title .accordion-button::after{display:none !important;content:none !important;width:0 !important;margin:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .accordion-item{border:0 !important;margin:0 !important;padding:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail #o_wsale_categories{margin:0 !important;padding:0 !important;border:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail #o_wsale_categories .nav.flex-column{margin:6px 0 8px 0 !important;padding:0 !important}

/* ===== Cerrar el gap Categorias->lista a la fuerza (margen negativo) ===== */
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories #o_wsale_categories{margin-top:-40px !important}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories #o_wsale_categories .nav.flex-column{margin-top:0 !important;padding-top:0 !important}

/* ===== Categorias: nombres en 1 linea + quitar espacio extra de subcats ===== */
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories a{font-size:13px !important;white-space:nowrap !important;overflow:visible !important;text-overflow:clip !important}
body.vxn-shop .o_wsale_products_grid_before_rail .o_categories_recursive_button{margin-left:4px !important}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .nav-item .accordion-header.d-flex{margin-bottom:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .nav-item .accordion-collapse:not(.show){display:none !important;margin:0 !important;padding:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .nav-item{margin-bottom:2px !important}

/* ===== Auditoria: pulido autonomo (A11y + perceptual + back-to-top) ===== */
body.vxn-shop a:focus-visible,body.vxn-shop button:focus-visible,body.vxn-shop input:focus-visible,body.vxn-shop .form-check-input:focus-visible{outline:2px solid #00B2A6 !important;outline-offset:2px !important}
body.vxn-shop .o_wsale_products_grid_before_rail .form-check{min-height:34px;display:flex;align-items:center}
body.vxn-shop #products_grid .oe_product_cart{transition:box-shadow .25s ease,transform .25s ease,border-color .25s ease}
@media (prefers-reduced-motion: reduce){body.vxn-shop *,#vxn-menu *{animation-duration:.001ms !important;transition-duration:.001ms !important}}
#vxn-menu .vxn-topbar{color:#cfcfcf}
#vxn-totop{position:fixed;right:24px;bottom:92px;width:44px;height:44px;border-radius:50%;background:#136B64;color:#fff;border:0;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.22);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s,transform .25s,visibility .25s;z-index:1040;cursor:pointer}
#vxn-totop.show{opacity:1;visibility:visible;transform:translateY(0)}
#vxn-totop:hover{background:#00B2A6}
@media(max-width:768px){#vxn-totop{right:16px;bottom:82px;width:40px;height:40px}}

/* ===== Categorias: nombres completos en 1 linea (chevron a la derecha, sin apretar) ===== */
body.vxn-shop .o_wsale_products_grid_before_rail .products_categories .accordion-header.d-flex a{flex:0 0 auto !important;min-width:0 !important;overflow:visible !important;text-overflow:clip !important}
body.vxn-shop .o_wsale_products_grid_before_rail .o_categories_recursive_button{flex:0 0 auto !important;width:auto !important;margin-left:auto !important}

/* ===== CRO: resaltar CTA 'Contactar Asesor' en ficha de producto ===== */
#contact_us_wrappe_vexinr{margin:14px 0 4px !important}
#contact_us_wrappe_vexinr section,#contact_us_wrappe_vexinr .container{padding:0 !important;max-width:none !important;margin:0 !important}
#contact_us_wrappe_vexinr .btn_cta{
  display:inline-flex !important;align-items:center;justify-content:center;
  background:#136B64 !important;border:0 !important;color:#fff !important;
  font-weight:700 !important;font-size:15px !important;letter-spacing:.2px;
  padding:13px 28px !important;border-radius:10px !important;min-width:250px;
  box-shadow:0 4px 14px rgba(19,107,100,.28) !important;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease !important;
}
#contact_us_wrappe_vexinr .btn_cta:hover{background:#00B2A6 !important;transform:translateY(-2px) !important;box-shadow:0 8px 22px rgba(0,178,166,.36) !important;color:#fff !important}
#contact_us_wrappe_vexinr .btn_cta:focus-visible{outline:2px solid #00B2A6 !important;outline-offset:3px !important}

/* ===== FICHA DE PRODUCTO: jerarquia de textos + CTA ===== */
body.vxn-shop #wrap h1[itemprop="name"]:not(#vxnx){font-size:clamp(16px,1.35vw,21px) !important;line-height:1.3 !important;font-weight:700 !important;color:#1f2d2b !important;margin-bottom:.55rem !important}
body.vxn-shop #add_to_cart{background:#F7941D !important;border-color:#F7941D !important;color:#fff !important;font-weight:700 !important;font-size:16px !important;padding:13px 32px !important;border-radius:10px !important;box-shadow:0 4px 16px rgba(247,148,29,.30) !important;transition:transform .18s ease,box-shadow .18s ease,background .18s ease !important;animation:vxnCartPulse 2.6s ease-in-out infinite}
body.vxn-shop #add_to_cart:hover{background:#e07d00 !important;border-color:#e07d00 !important;transform:translateY(-2px) !important;box-shadow:0 9px 26px rgba(247,148,29,.48) !important;animation:none}
@keyframes vxnCartPulse{0%,100%{box-shadow:0 4px 16px rgba(247,148,29,.28)}50%{box-shadow:0 6px 24px rgba(247,148,29,.52)}}
@media (prefers-reduced-motion: reduce){body.vxn-shop #add_to_cart{animation:none !important}}
body.vxn-shop #wrap [itemprop="description"]{font-size:15px !important;line-height:1.6 !important;color:#3a3a3a !important}

/* Descripcion completa: ancho de lectura + separador de seccion */
body.vxn-shop #product_full_description{max-width:1080px;margin:26px auto 0 !important;padding-top:22px;border-top:1px solid #ececec}

/* ===== Stock badge (coherente con tarjetas) + Trust badges ===== */
body.vxn-shop .vxn-stock{display:inline-block;font-weight:600;font-size:13.5px;padding:4px 13px;border-radius:20px;margin:2px 0 6px}
body.vxn-shop .vxn-stock.vxn-in{background:#e7f7ef;color:#0a7d4f}
body.vxn-shop .vxn-stock.vxn-in i{color:#16b16b}
body.vxn-shop .vxn-stock.vxn-out{background:#f3f3f3;color:#8a8a8a}
body.vxn-shop .vxn-trust{display:flex;flex-wrap:wrap;gap:9px 18px;margin:14px 0 4px;padding-top:12px;border-top:1px solid #f0f0f0}
body.vxn-shop .vxn-trust-item{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:#3a3a3a;font-weight:500}
body.vxn-shop .vxn-trust-item i{color:#00B2A6;font-size:15px}

/* Bajo Pedido + ETA */
body.vxn-shop .vxn-stock.vxn-order{background:#fff3e0;color:#c47a12}
body.vxn-shop .vxn-stock.vxn-order i{color:#e8951e}
body.vxn-shop .vxn-eta{display:block;font-size:12.5px;color:#8a8a8a;margin:5px 0 6px}

/* === Movil: no colapsar topbar en scroll (evita temblor del header sticky) === */
@media(max-width:1068px){
  #vxn-menu .vxn-topbar{transition:none !important}
  #vxn-menu.vxn-scrolled .vxn-topbar{max-height:64px !important;opacity:1 !important;padding-top:4px !important;padding-bottom:4px !important}
}

/* Auditoria movil: touch target del hamburger 44x44 (HIG) */
@media(max-width:1068px){
  #vxn-menu .vxn-hamburger{width:44px !important;height:44px !important;justify-content:center !important;gap:5px;margin-left:-9px}
  #vxn-menu .vxn-hamburger span{width:24px}
}

/* === Auditoria movil 4-6 === */
@media(max-width:768px){
  .s_website_form input,.s_website_form select,.s_website_form textarea,
  #vxn-menu .vxn-srch-in,input.form-control,select.form-control,textarea.form-control{font-size:16px !important}
}
body.vxn-menu-open{overflow:hidden !important}
@media(max-width:640px){#vxn-menu .vxn-hdr-in{padding:11px 16px !important}}

/* === Filtro Marca/atributos: casillas alineadas, tamano correcto, sin empalme === */
body.vxn-shop .o_wsale_products_grid_before_rail .form-check{display:flex !important;align-items:center;gap:9px;padding-left:0 !important;margin:0 0 7px !important;min-height:0 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .form-check-input{margin:0 !important;float:none !important;width:16px !important;height:16px !important;min-width:16px;flex:0 0 16px;cursor:pointer}
body.vxn-shop .o_wsale_products_grid_before_rail .form-check-input:checked{background-color:#00B2A6 !important;border-color:#00B2A6 !important}
body.vxn-shop .o_wsale_products_grid_before_rail .form-check-label{margin:0 !important;padding:0 !important;line-height:1.25;font-size:13.5px;cursor:pointer}
