/**
 * Responsive overrides
 * @version 3.37.4
 * @date 2026-05-03
 */
@media screen and (max-width:550px) {
  #login-height {
    min-height: auto !important;
  }

  /* Base legible en móvil (~16px estándar iOS/Material) */
  html {
    font-size: 16px;
  }

  body {
    font-size: 1rem;
    line-height: 1.5;
  }

  small,
  .small {
    font-size: 0.9375rem !important;
  }

  /* Antes forzaba todos los h1 a 3em y rompía cabeceras de sección */
  #titulo-seccion h1 {
    font-size: 1.25rem !important;
    line-height: 1.35 !important;
    font-weight: 600 !important;
  }

  .container-fluid {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #titulo-seccion {
    display: block !important;
    width: 100% !important;
    margin-right: 0 !important;
    padding-right: 0 !important;
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
  }

  .body-inicio #titulo-seccion #nombre-proyecto {
    width: 100% !important;
  }

  .ocultar-mvl,
  /* Clase para ocultar elementos */
  #appname,
  /* Nombre de la aplicacion */
  .btn-sidebar,
  /* Boton para ocultar el sidebar */
  .fixed-bottom

  /* Status en el footer */
    {
    display: none !important;
  }

  /* Navbar móvil: panel detrás del botón hamburguesa (evita flex-wrap en 2 filas) */
  .crm-topnav-collapse:not(.is-open) {
    display: none !important;
  }

  .crm-topnav-collapse.is-open {
    display: block !important;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
  }

  #opt-principal {
    display: flex !important;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    overflow: visible !important;
    width: 100%;
    margin-right: 0 !important;
  }

  #opt-principal > li {
    width: 100%;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }

  #opt-principal > li:last-child {
    border-bottom: 0;
  }

  #opt-principal .nav-link {
    padding: 0.65rem 0.35rem;
    font-size: 1rem;
    white-space: normal;
  }

  /* Submenús inline: sin clipping y sin segunda fila en la barra */
  #opt-principal .dropdown-menu {
    position: static !important;
    float: none;
    width: 100%;
    margin-top: 0;
    margin-bottom: 0.25rem;
    border: 0;
    box-shadow: none;
    padding-left: 0.25rem;
    padding-top: 0;
  }

  #opt-principal .dropdown-toggle::after {
    float: right;
    margin-top: 0.45rem;
  }

  #btn-export-csv {
    margin-left: 0 !important;
  }

  #mostrar-finalizadas {
    margin-bottom: 2em !important;
  }

  [role="main"] {
    padding-top: 4em !important;
  }

  .tools-taskbar {
    width: 50% !important;
  }

  .tools-taskbar button {
    margin-bottom: 5px;
  }

  .tools-tasklist {
    width: 35% !important;
  }

  /* No comprimir columnas del listado CRM (tabla de 3 columnas + layout fixed) */
  .table-tareas-crm td.tools-tasklist {
    width: auto !important;
    max-width: none !important;
  }

  .table-tareas-crm td.tools-taskbar {
    width: auto !important;
    max-width: none !important;
  }

  #main-botonera {
    margin-top: 2em;
  }

  .lateralactivo {
    width: 100% !important;
    left: 0;
  }

  .hero-image.hero-image--visible{
    transform: translateX(2em) !important;
  }

  /* Panorama (clases en main.panorama.php): período en fila horizontal desplazable; KPI más compactos */
  .panorama-period-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    margin-left: -2px;
    margin-right: -2px;
    padding-left: 2px;
    padding-right: 2px;
  }

  .panorama-period-scroll .btn-group > .btn {
    flex-shrink: 0;
  }

  .panorama-kpi-cards .panorama-kpi-value {
    font-size: 1.65rem !important;
    line-height: 1.25 !important;
  }

  .panorama-kpi-cards .card-body {
    padding: 0.65rem 0.5rem !important;
  }

}

@media screen and (min-width:551px) {
  .crm-nav-mobile-toggle,
  .crm-topnav-mobile-bar {
    display: none !important;
  }

  .crm-topnav-collapse {
    display: flex !important;
    align-items: center;
    flex-wrap: nowrap;
    width: auto !important;
  }

  #opt-principal {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    overflow: visible !important;
    white-space: normal;
    width: auto;
  }

  #opt-principal > li {
    width: auto;
    border-bottom: 0;
  }
}
