/* ========================================
   MOLTRAN RESPONSIVE FIXES
   Correcciones unificadas de responsividad
   ======================================== */

/* === VARIABLES CSS PARA BREAKPOINTS === */
:root {
  --breakpoint-xl: 1199px;
  --breakpoint-lg: 991px;
  --breakpoint-md: 767px;
  --breakpoint-sm: 575px;
  --sidebar-width: 240px;
  --sidebar-width-small: 220px;
  --topbar-height: 70px;
  --primary-color: #096f30;
  --accent-color: #ffe958;
  --transition-speed: 0.25s;
}

/* === BASE RESPONSIVE SETTINGS === */
html,
body {
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

body {
  position: relative;
}

/* === SIDEBAR MENU RESPONSIVE === */
.left.side-menu {
  transition: transform var(--transition-speed) ease;
  position: fixed;
  top: var(--topbar-height);
  bottom: 0;
  height: calc(100vh - var(--topbar-height));
  width: var(--sidebar-width);
  z-index: 1001;
  background: #fff;
  box-shadow: none;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* CORRECCIÓN CRÍTICA: Asegurar que el sidebar esté por encima del overlay cuando está abierto */
body.show-left .left.side-menu {
  z-index: 1001 !important;
}

/* === HAMBURGER BUTTON === */
.button-menu-mobile {
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--primary-color);
  font-size: 21px;
  line-height: var(--topbar-height);
  padding: 0 15px;
  position: relative;
  z-index: 1001;
  transition: color 0.2s ease;
  /* CORRECCIÓN 2: Asegurar que el botón hamburguesa siempre sea visible */
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.button-menu-mobile:hover {
  color: #6abc47;
}

.button-menu-mobile:focus {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* CORRECCIÓN 2: Cambiar color cuando el menú está abierto pero mantener visible */
body.show-left .button-menu-mobile {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  /* CORRECCIÓN ADICIONAL: Asegurar posicionamiento correcto */
  position: relative !important;
  z-index: 1010 !important;
  pointer-events: auto !important;
  /* Asegurar que no sea cubierto por otros elementos */
  background: rgba(255, 255, 255, 0.1) !important;
  border-radius: 4px;
}

body.show-left .button-menu-mobile:hover {
  background: rgba(255, 255, 255, 0.2) !important;
}

body.show-left .button-menu-mobile i {
  color: var(--accent-color);
  /* Asegurar que el icono sea visible */
  display: inline-block !important;
  opacity: 1 !important;
}

/* === OVERLAY PARA CERRAR MENU EN MOBILE === */
.sidebar-overlay {
  position: fixed;
  top: var(--topbar-height);
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition-speed) ease;
  /* CORRECCIÓN: Asegurar que no intercepte clics del botón hamburguesa */
  pointer-events: none;
}

body.show-left .sidebar-overlay {
  opacity: 1;
  visibility: visible;
  /* CORRECCIÓN: Habilitar pointer-events solo cuando el menú está abierto */
  pointer-events: auto;
}

/* CORRECCIÓN CRÍTICA: Z-index del botón hamburguesa debe ser el más alto */
.button-menu-mobile {
  z-index: 1010 !important;
  position: relative !important;
}

/* CORRECCIÓN: Cuando el menú está abierto, el botón debe seguir siendo el más alto */
body.show-left .button-menu-mobile {
  z-index: 1010 !important;
  position: relative !important;
}

/* CORRECCIÓN: Asegurar que el topbar no cubra el botón */
.topbar {
  z-index: 999 !important;
}

.topbar .topbar-left {
  z-index: 999 !important;
}

/* === RESPONSIVE BREAKPOINTS === */

/* Desktop Grande (1200px+) */
@media (min-width: 1200px) {
  .content-page {
    margin-left: var(--sidebar-width);
    transition: margin-left var(--transition-speed) ease;
  }

  .left.side-menu {
    transform: translateX(0);
    position: fixed;
  }

  .sidebar-overlay {
    display: none;
  }
}

/* Desktop Mediano (992px - 1199px) */
@media (max-width: 1199px) {
  .content-page {
    margin-left: 0 !important;
  }

  .left.side-menu {
    transform: translateX(-100%);
  }

  body.show-left .left.side-menu {
    transform: translateX(0);
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
  }

  /* CORRECCIÓN: Asegurar que los textos del menú sean visibles en móvil */
  body.mobile-menu #sidebar-menu ul li a span {
    display: inline !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* CORRECCIÓN 1: Forzar menú completo (no collapsed) en móvil */
  body.show-left .left.side-menu {
    width: var(--sidebar-width) !important;
  }

  body.show-left #sidebar-menu ul li a span {
    display: inline !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  body.show-left #sidebar-menu ul li a i {
    display: inline-block !important;
    margin-right: 15px !important;
  }

  /* CORRECCIÓN ADICIONAL: Forzar visibilidad de textos en todos los estados móviles */
  @media (max-width: 1199px) {
    #sidebar-menu ul li a span {
      display: inline !important;
      opacity: 1 !important;
      visibility: visible !important;
    }

    /* CORRECCIÓN 1: Prevenir modo collapsed en móvil */
    #wrapper.enlarged .left.side-menu {
      width: var(--sidebar-width) !important;
    }

    #wrapper.enlarged #sidebar-menu ul li a span {
      display: inline !important;
      opacity: 1 !important;
      visibility: visible !important;
    }
  }
}

/* Tablets (768px - 991px) */
@media (max-width: 991px) {
  .content-page {
    margin-left: 0 !important;
  }

  .left.side-menu {
    width: var(--sidebar-width);
    transform: translateX(-100%);
  }

  body.show-left .left.side-menu {
    transform: translateX(0);
  }

  /* Ajustar tamaño de elementos */
  #sidebar-menu ul li a {
    font-size: 14px;
    padding: 10px 15px;
  }
}

/* Mobile Landscape (576px - 767px) */
@media (max-width: 767px) {
  .left.side-menu {
    width: var(--sidebar-width);
    transform: translateX(-100%);
  }

  #sidebar-menu ul li a {
    font-size: 13px;
    padding: 8px 15px;
  }

  .content-page .content {
    padding: 10px 10px 60px 10px;
  }

  /* Tables responsive */
  table {
    font-size: 12px;
  }

  .table-responsive-mobile {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .table-responsive-mobile > table {
    min-width: 640px;
  }
}

/* Mobile Portrait (hasta 575px) */
@media (max-width: 575px) {
  .left.side-menu {
    width: var(--sidebar-width-small);
    transform: translateX(-100%);
  }

  #sidebar-menu ul li a {
    font-size: 12px;
    padding: 7px 12px;
  }

  table {
    font-size: 11px;
  }

  /* Botones de acción responsive */
  .actions {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  a.btn_action_table {
    width: 100%;
    text-align: center;
    padding: 8px 12px;
    font-size: 12px;
    min-height: 44px; /* Touch-friendly */
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

/* === BOTONES RESPONSIVE === */
.btn-responsive {
  min-height: 44px;
  padding: 8px 16px;
  touch-action: manipulation;
}

@media (max-width: 575px) {
  .btn-responsive {
    width: 100%;
    margin-bottom: 8px;
  }

  .btn-group-responsive {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .btn-group-responsive .btn {
    width: 100%;
    margin: 0;
  }
}

/* === ACCIONES EN GRILLA === */
.actions_responsive {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
  padding-bottom: 12px;
}

@media (max-width: 767px) {
  .actions_responsive {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 575px) {
  .actions_responsive {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }

  .actions_responsive a.btn_action_table {
    width: 100%;
    text-align: center;
  }
}

/* === FAB MENU FALLBACK === */
.menu-fab-toggle {
  position: fixed;
  top: 15px;
  left: 15px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--primary-color);
  color: var(--accent-color);
  border: none;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 1500;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  cursor: pointer;
  transition: all 0.2s ease;
}

.menu-fab-toggle:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
}

.menu-fab-toggle i {
  font-size: 20px;
}

/* Mostrar FAB cuando el botón hamburguesa no está visible */
body.no-hamburger .menu-fab-toggle {
  display: flex;
}

/* === MEJORAS DE ACCESIBILIDAD === */
@media (prefers-reduced-motion: reduce) {
  .left.side-menu,
  .button-menu-mobile,
  .sidebar-overlay {
    transition: none;
  }
}

/* === FOCUS VISIBLE === */
.left.side-menu a:focus-visible,
.button-menu-mobile:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* === LANDSCAPE ORIENTATION === */
@media (max-height: 500px) and (orientation: landscape) {
  .left.side-menu {
    width: 200px;
  }

  #sidebar-menu ul li a {
    font-size: 12px;
    padding: 6px 12px;
  }
}

/* === CORRECCIÓN FINAL: SOBRESCRIBIR ESTILOS CONFLICTIVOS === */
/* Sobrescribir cualquier estilo de style.css que pueda ocultar el botón */
@media (max-width: 900px) {
  body.show-left .button-menu-mobile {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1010 !important;
    position: relative !important;
    pointer-events: auto !important;
  }

  body.show-left .button-menu-mobile i {
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
    color: var(--accent-color) !important;
  }
}

/* Asegurar que funcione en todos los breakpoints móviles */
@media (max-width: 1199px) {
  .button-menu-mobile {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1010 !important;
    position: relative !important;
  }

  body.show-left .button-menu-mobile {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1010 !important;
    position: relative !important;
    pointer-events: auto !important;
  }
}

/* === CORRECCIÓN FINAL: SOBRESCRIBIR ESTILOS CONFLICTIVOS === */
/* Sobrescribir cualquier estilo de style.css que pueda ocultar el botón */
@media (max-width: 900px) {
  body.show-left .button-menu-mobile {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1010 !important;
    position: relative !important;
    pointer-events: auto !important;
  }

  body.show-left .button-menu-mobile i {
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
    color: var(--accent-color) !important;
  }
}

/* Asegurar que funcione en todos los breakpoints móviles */
@media (max-width: 1199px) {
  .button-menu-mobile {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1010 !important;
    position: relative !important;
  }

  body.show-left .button-menu-mobile {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1010 !important;
    position: relative !important;
    pointer-events: auto !important;
  }
}
