/* ============================================================
   NsStore.mx - Fix menú lateral izquierdo en mobile
   Archivo: themes/ap_office/css/local/sidebar_mobile_fix.css
   ============================================================ */

/* --- 1. Columna izquierda visible y bien ordenada en mobile --- */
@media (max-width: 991px) {
  /* El sidebar aparece DESPUÉS del contenido central en mobile */
  #left_column {
    float: none !important;
    width: 100% !important;
    padding-left: 15px;
    padding-right: 15px;
  }

  /* El centro también ocupa 100% en mobile */
  #center_column {
    float: none !important;
    width: 100% !important;
  }

  /* Orden: primero el contenido, luego el sidebar */
  #columns .row {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
  }

  #center_column {
    -webkit-order: 1;
    order: 1;
  }

  #left_column {
    -webkit-order: 2;
    order: 2;
  }
}

/* --- 2. El accordion del sidebar en mobile --- */
/* Cuando el JS activa el modo acordeón, los bloques se colapsan con slideUp.
   Pero el click en .title_block debe funcionar correctamente */
@media (max-width: 767px) {
  /* Cabecera del bloque: cursor pointer para indicar que es clickable */
  #left_column .block .title_block,
  #left_column .block h4.title_block {
    cursor: pointer;
    user-select: none;
    -webkit-user-select: none;
    padding: 12px 15px;
    margin: 0;
  }

  /* Ícono de flecha toggling */
  #left_column .block .title_block:after {
    display: block;
    content: "\f055"; /* fa-plus-circle */
    font-family: "FontAwesome";
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
  }

  #left_column .block .title_block.active:after {
    content: "\f056"; /* fa-minus-circle */
  }

  #left_column .block {
    position: relative;
  }

  /* El block_content colapsado por JS (slideUp) necesita overflow hidden */
  #left_column.accordion .block .block_content {
    overflow: hidden;
  }

  /* Asegurar que cuando el block_content se expande no quede oculto por z-index */
  #left_column .block_content {
    position: relative;
    z-index: 1;
  }

  /* Listas del sidebar - visibles y no cortadas */
  #left_column .block_content ul,
  #left_column .block_content li {
    overflow: visible !important;
    visibility: visible !important;
  }

  /* Fix para el filtro por capas (blocklayered) que se corta */
  #layered_block_left .block_content {
    max-height: none !important;
    overflow: visible !important;
  }
}

/* --- 3. Corrección del menú superior en mobile (vínculos) --- */
@media (max-width: 767px) {
  /* El menú sf-menu en mobile: los items se apilan verticalmente */
  #block_top_menu .sf-menu > li {
    display: block;
    width: 100%;
  }

  /* Los submenús deben ser accesibles */
  #block_top_menu .sf-menu > li > a {
    display: block;
    padding: 10px 15px;
    border-bottom: 1px solid rgba(0,0,0,0.08);
  }

  /* Submenús de segundo nivel */
  #block_top_menu .sf-menu li ul {
    position: static !important;
    display: none;
    width: 100% !important;
    box-shadow: none;
    border: none;
    background: rgba(0,0,0,0.03);
    padding-left: 15px;
  }

  /* Cuando se hace hover o click (JS maneja el toggle) */
  #block_top_menu .sf-menu li.sfHover > ul,
  #block_top_menu .sf-menu li:focus > ul {
    display: block;
  }

  /* Fix z-index para que los submenús no queden detrás de otros elementos */
  #leo-megamenu {
    position: relative;
    z-index: 1000;
  }

  #block_top_menu {
    overflow: visible !important;
  }

  /* Botón hamburger del .cat-title */
  .cat-title {
    cursor: pointer;
    display: block;
    padding: 12px 15px;
    font-weight: bold;
  }
}

/* --- 4. Fix overflow oculto que traga las capas del sidebar --- */
/* Este es el bug más común: un padre con overflow:hidden corta los hijos */
#columns {
  overflow: visible !important;
}

#left_column,
#left_column .block,
#left_column .block_content {
  overflow: visible !important;
}

/* Excepto cuando el accordion lo colapsa (el JS le pone style="display:none") */
#left_column.accordion .block .block_content[style*="display: none"],
#left_column.accordion .block .block_content[style*="display:none"] {
  overflow: hidden !important;
}

/* --- 5. Asegurar que los z-index no escondan el sidebar --- */
@media (max-width: 991px) {
  #left_column {
    z-index: auto;
  }
  
  /* El slider/slideshow no tape el sidebar */
  #slideshow {
    z-index: 1;
    position: relative;
  }
}
