/**
 * SPVSMA — Cabezote / topbar Santa María (encima de AdminLTE).
 * Carga después de sm-shell.css. DataTables: sin selectores de .table genéricos.
 */

body.spvsma-sm-theme .main-header {
  background: #fff !important;
  border-bottom: 1px solid var(--sm-line, #e5e7eb) !important;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.04);
  z-index: 1030;
  /* AdminLTE fija max-height 100px; si el contenido crece, puede desajustarse el layout */
  max-height: none !important;
}

body.spvsma-sm-theme .main-header .navbar.sm-navbar-main {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  min-height: var(--sm-nav-row-min, var(--sm-header-height, 76px));
  padding-right: 16px;
  margin-bottom: 0 !important;
  /*
   * Logo dentro del nav: quitamos margin-left heredado de AdminLTE (.navbar { margin-left: 230px }).
   * En ≥992 la anchura efectiva del .logo igualamos al lateral (blocks abajo).
   */
  margin-left: 0 !important;
  width: 100% !important;
  box-sizing: border-box;
  background: #fff !important;
}

body.spvsma-sm-theme .main-header .navbar.sm-navbar-main > .logo {
  float: none !important;
}

/* Escritorio: violeta mismo ancho que .main-sidebar (230 cuando el menú está abierto). Colapsado → icono mínimo (ver bloque ≥768). */
@media (min-width: 992px) {
  body.spvsma-sm-theme.sidebar-mini:not(.sidebar-collapse) .main-header .navbar.sm-navbar-main > .logo {
    flex: 0 0 230px !important;
    width: 230px !important;
    min-width: 230px !important;
    max-width: 230px !important;
    box-sizing: border-box !important;
    align-self: stretch !important;
  }

  /* Sin sidebar-mini (plantillas raras): fallback al ancho expandido */
  body.spvsma-sm-theme:not(.sidebar-mini) .main-header .navbar.sm-navbar-main > .logo {
    flex: 0 0 230px !important;
    width: 230px !important;
    min-width: 230px !important;
    max-width: 230px !important;
    align-self: stretch !important;
  }

  /* AdminLTE suma margin-left al navbar al colapsar; cabezote SM ya controla el logo en bloque ≥768. */
  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-header .navbar.sm-navbar-main {
    margin-left: 0 !important;
  }

  /*
   * El ancho del bloque ya igual al sidebar; la imagen seguía limitada a ~44px → se veía “mini”.
   * Llenar el hueco del header (logo lineal) sin deformar.
   */
  body.spvsma-sm-theme.sidebar-mini:not(.sidebar-collapse) .main-header .navbar.sm-navbar-main > .logo,
  body.spvsma-sm-theme:not(.sidebar-mini) .main-header .navbar.sm-navbar-main > .logo {
    padding: 6px 14px !important;
  }

  body.spvsma-sm-theme.sidebar-mini:not(.sidebar-collapse) .main-header .navbar.sm-navbar-main > .logo .logo-lg,
  body.spvsma-sm-theme:not(.sidebar-mini) .main-header .navbar.sm-navbar-main > .logo .logo-lg {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    flex: 1 1 auto;
    min-height: 0;
  }

  body.spvsma-sm-theme.sidebar-mini:not(.sidebar-collapse) .main-header .navbar.sm-navbar-main > .logo .logo-lg img,
  body.spvsma-sm-theme:not(.sidebar-mini) .main-header .navbar.sm-navbar-main > .logo .logo-lg img {
    display: block !important;
    max-height: calc(var(--sm-header-height, 76px) - 12px) !important;
    height: auto !important;
    width: auto !important;
    max-width: calc(230px - 28px) !important;
    margin: 0 auto !important;
    padding: 2px !important;
    object-fit: contain !important;
    box-sizing: border-box !important;
    flex-shrink: 0 !important;
  }
}

/*
 * AdminLTE: sidebar-mini + sidebar-collapse muestra solo 50px de menú (iconos).
 * En Santa María “colapsado” = mismo comportamiento que sin mini: lateral fuera de pantalla + contenido a ancho completo.
 */
@media (min-width: 768px) {
  /*
   * Sin aside visible: el bloque morado no debe ocupar 230px; solo marca mínima (icono) + enlace a inicio.
   */
  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-header .navbar.sm-navbar-main > .logo {
    flex: 0 0 52px !important;
    width: 52px !important;
    min-width: 52px !important;
    max-width: 52px !important;
    padding: 4px 6px !important;
    box-sizing: border-box !important;
    align-self: stretch !important;
    overflow: hidden !important;
    background: transparent !important;
    border-right: 1px solid var(--sm-line, #e5e7eb) !important;
  }

  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-header .navbar.sm-navbar-main > .logo:hover {
    background: rgba(141, 60, 143, 0.08) !important;
  }

  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-header .navbar.sm-navbar-main > .logo .logo-lg {
    display: none !important;
  }

  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-header .navbar.sm-navbar-main > .logo .logo-mini {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    margin: 0 !important;
  }

  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-header .navbar.sm-navbar-main > .logo .logo-mini img {
    display: block !important;
    max-height: 34px !important;
    max-width: 34px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    padding: 3px !important;
    margin: 0 auto !important;
  }

  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .content-wrapper,
  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-footer {
    margin-left: 0 !important;
  }

  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .main-sidebar {
    -webkit-transform: translate(-230px, 0) !important;
    -ms-transform: translate(-230px, 0) !important;
    -o-transform: translate(-230px, 0) !important;
    transform: translate(-230px, 0) !important;
    width: 230px !important;
  }

  /* Desactivar tooltips/flotantes del modo mini mientras está oculto */
  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > a > span:not(.pull-right),
  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > .treeview-menu,
  body.spvsma-sm-theme.sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > a > .pull-right-container {
    display: none !important;
  }
}

body.spvsma-sm-theme .main-header .logo {
  background: linear-gradient(135deg, #8d3c8f, #5f2c82) !important;
  border-right: none !important;
  height: var(--sm-header-height, 76px) !important;
  line-height: normal !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.spvsma-sm-theme .main-header .logo:hover {
  background: linear-gradient(135deg, #9a459c, #6b348f) !important;
}

body.spvsma-sm-theme .main-header .logo .logo-lg img,
body.spvsma-sm-theme .main-header .logo .logo-mini img {
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.95);
}

/* Por defecto un tope razonable en móvil; ≥992 logo-lg se redefine arriba (sin tope ~44px en escritorio). */
@media (max-width: 991px) {
  body.spvsma-sm-theme .main-header .logo .logo-lg img,
  body.spvsma-sm-theme .main-header .logo .logo-mini img {
    padding: 6px;
    max-height: 44px;
  }
}

/* Toggle lateral */
body.spvsma-sm-theme .main-header .sidebar-toggle {
  float: none !important;
  width: 42px;
  height: 42px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #eef6ff !important;
  color: var(--sm-blue, #2f80ed) !important;
  margin: 0 6px 0 8px !important;
  padding: 0 !important;
  line-height: 1 !important;
  flex-shrink: 0;
}

body.spvsma-sm-theme .main-header .sidebar-toggle:hover {
  background: #dfeefe !important;
}

/* Menú mosaico */
body.spvsma-sm-theme .menu-mosaico-toggle {
  border-radius: 12px !important;
  border: 1px solid var(--sm-line, #e5e7eb) !important;
  background: #fff !important;
  color: var(--sm-blue, #2f80ed) !important;
  width: 42px !important;
  height: 42px !important;
  margin-right: 8px !important;
}

body.spvsma-sm-theme .menu-mosaico-toggle:hover {
  background: #f8fafc !important;
}

/* Título contextual de la ruta */
body.spvsma-sm-theme .sm-topbar-title-wrap {
  flex: 0 1 360px;
  max-width: min(360px, 34vw);
  min-width: 0;
  padding: 0 10px;
}

body.spvsma-sm-theme .sm-title-block strong {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: var(--sm-text, #1f2937);
  line-height: 1.25;
}

body.spvsma-sm-theme .sm-title-block span {
  display: block;
  font-size: 12px;
  color: var(--sm-muted, #6b7280);
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* CTA venta */
body.spvsma-sm-theme a.sm-action-primary.sm-action-venta {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  border: 0;
  background: var(--sm-blue, #2f80ed) !important;
  color: #fff !important;
  padding: 11px 16px !important;
  border-radius: 14px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  box-shadow: 0 6px 14px rgba(47, 128, 237, 0.25);
  white-space: nowrap;
  margin-right: 8px;
}

body.spvsma-sm-theme a.sm-action-primary.sm-action-venta:hover {
  color: #fff !important;
  filter: brightness(1.05);
}

/* Barra empresa / sucursal → pastillas */
body.spvsma-sm-theme .spvsma-contexto-barra {
  max-width: min(520px, 46vw) !important;
  margin-left: 6px !important;
  margin-right: 6px !important;
}

body.spvsma-sm-theme .spvsma-contexto-grupo {
  border-radius: 14px !important;
  overflow: visible !important;
  box-shadow: none !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  background: transparent !important;
}

body.spvsma-sm-theme .spvsma-contexto-pill {
  min-height: auto !important;
  padding: 8px 13px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-radius: 14px !important;
  border: 1px solid var(--sm-line, #e5e7eb) !important;
  background: #fafafa !important;
  color: var(--sm-text, #1f2937) !important;
  border-right-width: 1px !important;
}

body.spvsma-sm-theme .spvsma-contexto-pill .fa-building,
body.spvsma-sm-theme .spvsma-contexto-pill .fa-map-marker {
  color: var(--sm-blue, #2f80ed) !important;
}

body.spvsma-sm-theme .spvsma-contexto-pill--warning {
  border-color: #fcd34d !important;
  background: #fffbeb !important;
}

body.spvsma-sm-theme .spvsma-contexto-cambiar {
  border-radius: 14px !important;
  border: 1px solid var(--sm-line, #e5e7eb) !important;
  background: #fff !important;
  padding: 8px 14px !important;
  min-height: auto !important;
  font-weight: 700 !important;
}

/* Navegación rápida: mantener scroll; solo suavizar botones */
body.spvsma-sm-theme .navbar-quick-nav .btn-quick-nav:not(.btn-quick-primary) {
  border-radius: 14px !important;
  border: 1px solid var(--sm-line, #e5e7eb) !important;
}

body.spvsma-sm-theme .navbar-quick-nav .btn-quick-primary {
  border-radius: 14px !important;
}

/* Agrupación derecha */
body.spvsma-sm-theme .navbar-right-actions {
  gap: 10px !important;
}

/* Notificaciones campana */
body.spvsma-sm-theme .navbar-custom-menu .notifications-menu > .dropdown-toggle {
  width: 42px;
  height: 42px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--sm-line, #e5e7eb);
  border-radius: 14px;
  background: #fff;
  padding: 0 !important;
}

body.spvsma-sm-theme .navbar-custom-menu .notifications-menu > .dropdown-toggle .fa {
  font-size: 18px;
  color: var(--sm-text, #1f2937);
}

/* Usuario */
body.spvsma-sm-theme #user-menu-simple {
  border: 1px solid var(--sm-line, #e5e7eb) !important;
  border-radius: 18px !important;
  padding: 7px 12px !important;
  background: #fff !important;
  gap: 10px !important;
}

body.spvsma-sm-theme #user-menu-simple .user-foto {
  width: 36px !important;
  height: 36px !important;
  border: none !important;
  border-radius: 50% !important;
}

body.spvsma-sm-theme #user-menu-simple .btn-salir {
  border-radius: 12px !important;
  padding: 9px 14px !important;
}

@media (max-width: 1200px) {
  body.spvsma-sm-theme .spvsma-contexto-barra {
    display: none !important;
  }

  body.spvsma-sm-theme .sm-title-block span {
    display: none;
  }
}

@media (max-width: 991px) {
  body.spvsma-sm-theme .sm-topbar-title-wrap {
    display: none !important;
  }

  /*
   * Cinta “Crear venta / Productos / …”: en tablet/móvil satura la barra superior.
   * Navegar por sidebar o menú mosaico.
   */
  body.spvsma-sm-theme .navbar-quick-nav {
    display: none !important;
  }

  body.spvsma-sm-theme .main-header .navbar.sm-navbar-main {
    padding-right: 8px !important;
    padding-left: 2px !important;
    flex-wrap: nowrap !important;
    min-height: var(--sm-nav-row-min, 48px) !important;
  }

  /*
   * Una sola barra: orden hamburguesa → ícono (logo-mini) → menú mosaico.
   * El resto permanece order:0 (antes de estos) sólo si sigue en el DOM y visible.
   */
  body.spvsma-sm-theme .navbar.sm-navbar-main > .sidebar-toggle {
    order: 1;
    width: 44px !important;
    height: 44px !important;
    margin: 0 2px 0 8px !important;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .logo {
    order: 2;
    width: auto !important;
    flex: 0 0 auto !important;
    align-self: stretch !important;
    height: auto !important;
    min-height: var(--sm-nav-row-min, 56px) !important;
    max-height: none !important;
    padding: 2px 4px !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .logo .logo-lg {
    display: none !important;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .logo .logo-mini {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100%;
    flex: 0 0 auto;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .logo .logo-mini img.img-responsive {
    width: auto !important;
    max-width: none !important;
    height: calc(var(--sm-nav-row-min, 56px) - 10px) !important;
    max-height: calc(var(--sm-nav-row-min, 56px) - 10px) !important;
    min-height: 36px !important;
    padding: 3px !important;
    border-radius: 12px !important;
    object-fit: contain;
    flex-shrink: 0;
    box-sizing: content-box !important;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .menu-mosaico-toggle {
    order: 3;
    width: 44px !important;
    height: 44px !important;
    margin-right: 4px !important;
    margin-left: 0 !important;
    flex-shrink: 0;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .sm-action-primary.sm-action-venta {
    order: 50;
    flex-shrink: 0;
  }

  body.spvsma-sm-theme .navbar.sm-navbar-main > .navbar-right-actions {
    order: 100;
    margin-left: auto !important;
    flex-wrap: nowrap !important;
    flex-shrink: 0;
    min-width: 0;
    gap: 6px !important;
    align-items: center;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  body.spvsma-sm-theme .navbar-right-actions::-webkit-scrollbar {
    display: none;
    height: 0;
    width: 0;
  }

  body.spvsma-sm-theme #user-menu-simple {
    padding: 4px 8px !important;
    gap: 6px !important;
    border-radius: 12px !important;
    flex-shrink: 0;
  }

  body.spvsma-sm-theme #user-menu-simple .user-foto {
    width: 30px !important;
    height: 30px !important;
  }

  body.spvsma-sm-theme #user-menu-simple .btn-salir {
    padding: 6px 10px !important;
    font-size: 12px !important;
    white-space: nowrap;
  }

  body.spvsma-sm-theme .navbar-custom-menu {
    flex-shrink: 0;
  }

  body.spvsma-sm-theme .navbar-custom-menu .notifications-menu > .dropdown-toggle {
    width: 36px !important;
    height: 36px !important;
  }

  body.spvsma-sm-theme .main-header .navbar-custom-menu .navbar-nav > li > a {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    line-height: 1.2 !important;
  }
}

@media (max-width: 767px) {
  body.spvsma-sm-theme #user-menu-simple .user-name {
    display: none !important;
  }
}
