
/* === 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%)}