/* =====================================================
 * Advanced Menu Builder — Frontend (v7.6.5)
 * ===================================================== */

.amb-custom-menu-container,
.amb-custom-menu-container *{ box-sizing:border-box; }

.amb-custom-menu-container{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
}

/* =========================
 * Hamburger
 * ========================= */
.amb-hamburger-button{
  display:none; /* se activa en mobile via CSS inline */
  align-items:center;
  justify-content:center;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  line-height:1;
}
.amb-hamburger-button:focus{ outline:2px solid rgba(0,0,0,.18); outline-offset:2px; }

/* Wrapper reutilizable (iconos y burger) */
.amb-icon-wrap,
.amb-burger-icon-wrap{
  --amb-icon-size: 22px;
  --amb-icon-color: currentColor;
  --amb-icon-bg: transparent;
  --amb-icon-pad: 0px;
  --amb-icon-radius: 0px;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;

  width: calc(var(--amb-icon-size) + (var(--amb-icon-pad) * 2));
  height: calc(var(--amb-icon-size) + (var(--amb-icon-pad) * 2));
  padding: var(--amb-icon-pad);
  border-radius: var(--amb-icon-radius);
  background: var(--amb-icon-bg);
  color: var(--amb-icon-color);
}

.amb-icon-wrap .amb-icon,
.amb-burger-icon-wrap .amb-icon{
  font-size: var(--amb-icon-size);
  line-height:1;
  color: inherit;
}

.amb-icon-wrap img,
.amb-burger-icon-wrap img{
  width: var(--amb-icon-size);
  height: var(--amb-icon-size);
  object-fit:contain;
  display:block;
}

.amb-icon-wrap .amb-icon-lottie,
.amb-burger-icon-wrap .amb-burger-lottie{
  width: var(--amb-icon-size);
  height: var(--amb-icon-size);
}

/* Forzar tamaño del SVG inyectado por Lottie (evita que en mobile se rompa por estilos del tema) */
.amb-icon-wrap .amb-icon-lottie svg,
.amb-burger-icon-wrap .amb-burger-lottie svg{
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

/* =========================
 * Mobile wrappers
 * ========================= */
.amb-mobile-backdrop{ display:none; }
.amb-mobile-panel{ display:block; }

.amb-mobile-panel-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 14px 10px;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.amb-mobile-panel-title{ font-weight:800; font-size:14px; opacity:.92; }
.amb-mobile-close{
  appearance:none;
  border:0;
  background:rgba(0,0,0,.06);
  color:inherit;
  width:36px;
  height:36px;
  border-radius:12px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.amb-mobile-close:focus{ outline:2px solid rgba(0,0,0,.16); outline-offset:2px; }

/* =========================
 * Menu base
 * ========================= */
.amb-custom-menu-container .amb-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:10px;
}

.amb-custom-menu-container .amb-menu-item{ position:relative; display:flex; }

.amb-custom-menu-container .amb-menu-item > a{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:12px;
  text-decoration:none !important;
  color: var(--amb-text) !important;
  transition: transform .18s ease, opacity .18s ease, background .18s ease, box-shadow .18s ease;
  line-height:1.25;
}

.amb-custom-menu-container .amb-menu-item > a:hover,
.amb-custom-menu-container .amb-menu-item > a:focus{
  color: var(--amb-hover) !important;
}

.amb-custom-menu-container .amb-title{ display:inline-block; }

/* Toggle icon (submenus) */
.amb-custom-menu-container .amb-toggle-submenu{
  margin-left:auto;
  font-size:12px;
  opacity:.75;
  padding:6px;
  border-radius:10px;
  transition: transform .18s ease, opacity .18s ease;
}

.amb-custom-menu-container .amb-has-children.amb-active > a .amb-toggle-submenu{
  transform: rotate(180deg);
  opacity: 1;
}

/* Hover background (opcional) */
.amb-custom-menu-container.amb-hoverbg-on .amb-menu-item > a:hover,
.amb-custom-menu-container.amb-hoverbg-on .amb-menu-item.amb-active > a{
  background: var(--amb-hover-bg) !important;
}

/* =========================
 * Hover effects (desktop + admin preview)
 * ========================= */
.amb-custom-menu-container.amb-effect-lift .amb-menu-item > a:hover,
.amb-custom-menu-container.amb-effect-underline-lift .amb-menu-item > a:hover{
  transform: translateY(-2px);
}

.amb-custom-menu-container.amb-effect-glow .amb-menu-item > a:hover{
  box-shadow: 0 14px 28px rgba(0,0,0,.16);
}

.amb-custom-menu-container.amb-effect-underline .amb-menu-item > a::after,
.amb-custom-menu-container.amb-effect-underline-lift .amb-menu-item > a::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:6px;
  height:2px;
  border-radius:999px;
  background: linear-gradient(90deg, var(--amb-underline-from), var(--amb-underline-to));
  transform: scaleX(0);
  transform-origin:left;
  transition: transform .18s ease;
  opacity:.95;
}

.amb-custom-menu-container.amb-effect-underline .amb-menu-item > a:hover::after,
.amb-custom-menu-container.amb-effect-underline-lift .amb-menu-item > a:hover::after{
  transform: scaleX(1);
}

/* =========================
 * Submenus (desktop)
 * ========================= */
.amb-custom-menu-container .amb-submenu{
  position:absolute;
  top:100%;
  left:0;
  min-width:220px;
  list-style:none;
  margin:0;
  padding:8px;
  border-radius:14px;
  background: var(--amb-submenu-bg);
  box-shadow:0 18px 30px rgba(0,0,0,.22);
  opacity:0;
  transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none;
  z-index:9999;
}

.amb-custom-menu-container .amb-has-children:hover > .amb-submenu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

.amb-custom-menu-container .amb-submenu .amb-menu-item{ width:100%; }
.amb-custom-menu-container .amb-submenu .amb-menu-item > a{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
}

/* nested submenu (flyout) */
.amb-custom-menu-container .amb-submenu .amb-submenu{
  top:0;
  left:100%;
  margin-left:8px;
}

/* =========================
 * Vertical menu shortcode
 * ========================= */
.amb-custom-menu-container.amb-vertical-menu{
  align-items:stretch;
  flex-direction:column;
}
.amb-custom-menu-container.amb-vertical-menu .amb-menu{
  width:100%;
  flex-direction:column;
  align-items:stretch;
}
.amb-custom-menu-container.amb-vertical-menu .amb-menu-item{ width:100%; }
.amb-custom-menu-container.amb-vertical-menu .amb-menu-item > a{ width:100%; }



/* v7.6.9 · mobile panel logo + stronger close button */
.amb-mobile-panel-top.has-logo{
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 16px 12px;
}
.amb-mobile-panel-top.is-simple{
  justify-content:flex-end;
  padding:16px 16px 12px;
}
.amb-mobile-panel-spacer{display:block;width:1px;height:1px;opacity:0;pointer-events:none;}
.amb-mobile-panel-logo{
  display:block;
  width:auto;
  max-width:220px;
  max-height:62px;
  object-fit:contain;
}
.amb-mobile-panel-title{display:none !important;}
.amb-mobile-close{
  background:rgba(255,255,255,.12) !important;
  color:#fff !important;
  width:40px;
  height:40px;
  border-radius:12px;
  font-size:22px;
  font-weight:700;
  line-height:1;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.amb-mobile-close:hover{background:rgba(255,255,255,.18) !important;}
.amb-mobile-close:focus{outline:2px solid rgba(255,255,255,.28); outline-offset:2px;}


/* v7.6.10 · refined mobile panel hierarchy */
.amb-mobile-panel-top.has-logo{
  gap:10px;
  padding:16px 16px 10px;
}
.amb-mobile-panel-logo{
  max-width:230px;
  max-height:64px;
}
.amb-mobile-panel-extra{
  padding-top:10px;
}
.amb-mobile-panel-extra-title{
  font-size:11px !important;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.78;
}
.amb-mobile-contacts,
.amb-mobile-contacts.as-contacts{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  gap:8px 12px !important;
}
.amb-mobile-contacts .as-contact-item{
  flex:1 1 100%;
  margin:0 !important;
}
.amb-mobile-contacts.as-contacts .as-contact-item--type-facebook,
.amb-mobile-contacts.as-contacts .as-contact-item--type-instagram,
.amb-mobile-contacts.as-contacts .as-contact-item--type-youtube,
.amb-mobile-contacts.as-contacts .as-contact-item--type-x,
.amb-mobile-contacts.as-contacts .as-contact-item--type-tiktok,
.amb-mobile-contacts.as-contacts .as-contact-item--type-linkedin{
  flex:0 0 auto !important;
  width:auto !important;
}
.amb-mobile-contacts .as-contact-item .as-contact-value,
.amb-mobile-contacts .as-contact-item .as-contact-text,
.amb-mobile-contacts .as-contact-item .as-contact-link{
  font-size:10px !important;
}
.amb-mobile-contacts .as-contact-item--type-facebook,
.amb-mobile-contacts .as-contact-item--type-instagram,
.amb-mobile-contacts .as-contact-item--type-youtube,
.amb-mobile-contacts .as-contact-item--type-x,
.amb-mobile-contacts .as-contact-item--type-tiktok,
.amb-mobile-contacts .as-contact-item--type-linkedin{
  flex:0 0 auto;
}
.amb-mobile-contacts .as-contact-item--type-facebook .as-contact-link,
.amb-mobile-contacts .as-contact-item--type-instagram .as-contact-link,
.amb-mobile-contacts .as-contact-item--type-youtube .as-contact-link,
.amb-mobile-contacts .as-contact-item--type-x .as-contact-link,
.amb-mobile-contacts .as-contact-item--type-tiktok .as-contact-link,
.amb-mobile-contacts .as-contact-item--type-linkedin .as-contact-link{
  gap:0 !important;
  padding:0 !important;
}
.amb-mobile-contacts .as-contact-item--type-facebook .as-contact-value,
.amb-mobile-contacts .as-contact-item--type-instagram .as-contact-value,
.amb-mobile-contacts .as-contact-item--type-youtube .as-contact-value,
.amb-mobile-contacts .as-contact-item--type-x .as-contact-value,
.amb-mobile-contacts .as-contact-item--type-tiktok .as-contact-value,
.amb-mobile-contacts .as-contact-item--type-linkedin .as-contact-value{
  display:none !important;
}


/* v7.6.11 · socials inline in responsive drawer */
.amb-mobile-contacts.as-contacts .as-contact-item--type-facebook,
.amb-mobile-contacts.as-contacts .as-contact-item--type-instagram,
.amb-mobile-contacts.as-contacts .as-contact-item--type-youtube,
.amb-mobile-contacts.as-contacts .as-contact-item--type-x,
.amb-mobile-contacts.as-contacts .as-contact-item--type-tiktok,
.amb-mobile-contacts.as-contacts .as-contact-item--type-linkedin{
  display:inline-flex !important;
  flex:0 0 42px !important;
  width:42px !important;
  min-width:42px !important;
  max-width:42px !important;
  margin:0 !important;
}


/* Evita que modales disparados desde el panel móvil queden contenidos dentro del drawer */
.amb-mobile-panel{overflow:visible;}
.amb-mobile-panel .tesla-front-login-modal,
.amb-mobile-panel .tesla-modal,
.amb-mobile-panel .as-doc-modal,
.amb-mobile-panel .as-mv-modal-overlay{
  position:fixed !important;
  inset:0 !important;
  z-index:1000000 !important;
}
