/* LOGO DE LOGIN   */
.auth-logo img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  object-fit: contain;
}


/* Clases globales para las medidas de botones, deben de ser en multiplos de 5ch. */
.row-fluid {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
}


@media (max-width: 1164px) {
  .row-fluid {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.5rem;
  }

  .row-fluid>.col-md-2 {
    flex: 1 1 0 !important;
    max-width: 100% !important;
    min-width: 0;
  }
}

.text-boton-peq {
  font-size: 0.69rem;
  color: #ffffff;
}

.collapse {
  transition: height 0.35s ease;
  /* Además agrega overflow hidden para que no se vea contenido fuera */
  overflow: hidden;
}

.cotiaziones-header {
  background-color: var(--header-coti) !important;
  color: var(--text-color) !important;
}

.margen-header {
  background-color: var(--header-margen) !important;
  color: var(--text-color) !important;
}


.tabla-colapsable {
  display: flex;
  flex-direction: column;
  border: 1px solid #dee2e6;
  font-size: 0.9rem;
}

.tabla-header,
.fila-lider,
.fila-miembro,
.fila-alcance {
  display: grid;
  grid-template-columns: 2fr repeat(6, 1fr);
  padding: 0.5rem 1rem;
  align-items: center;
  border-bottom: 1px solid #dee2e6;
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.tabla-header {
  background-color: var(--modal-header-bg);
  font-weight: bold;
  text-align: center;
}

.tabla-header-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #f1f3f5;
  padding: 12px 20px;
  border: 1px solid #dee2e6;
  border-radius: 6px;
  font-weight: 500;
  color: #212529;
  margin-bottom: 12px;
}

.tabla-header-top .header-title {
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  gap: 6px;
}

.tabla-header-top .header-period {
  font-size: 1rem;
  color: #495057;
}


.fila-lider {
  cursor: pointer;
  background-color: var(--tipo-opcion-bg);
}

.fila-lider:hover,
.fila-miembro:hover {
  background-color: var(--hover-cotizaciones);
  transform: scale(1.01);
}

.collapse-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease, opacity 0.5s ease;
  display: flex;
  flex-direction: column;
  opacity: 0;
}

.collapse-content.open {
  max-height: 1000px;
  opacity: 1;
}

.fila-miembro,
.fila-alcance {
  background-color: var(--tipo-opcion-bg);
}

.fila-alcance {
  background-color: var(--fila-alcance);
  font-weight: bold;
}

.cotiaziones-header {
  background-color: var(--header-coti);
  color: var(--text-color);
}

.margen-header {
  background-color: var(--header-margen);
  color: var(--text-color);
}

.short-number {
  max-width: 100px;
  width: 80px;
}

#panel-detalle-usuario {
  overflow: hidden;
  transition: max-height 0.4s ease;
}

#panel-detalle-usuario.abierto {
  max-height: 1000px;
  /* ajusta según el contenido máximo esperado */
}

.fila-miembro {
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.fila-miembro.seleccionado {
  background-color: #d4edc9;
  /* un verde pistache clarito */
}

.equipo-detalle {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  padding: 0 1rem;
}

.equipo-detalle.abierto {
  max-height: 500px;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.equipo-card {
  background-color: #f9fbff;
}




/* .btn-principal {
  min-width: 20ch;
   
} */

/* @media (max-width: 1162px) {
  .btn-principal {
  flex: 1 1 0;
  min-width: 0;
  }
}
@media (min-width: 1320px) {
  .btn-principal {
    min-width: 30ch !important;
  }
} */



.btn-secundario {
  min-width: 15ch;
}

/* @media (max-width: 768px) {
  .btn-secundario {
    min-width: 20ch;
  }
}

@media (max-width: 480px) {
  .btn-principal {
    min-width: 12ch;
  }
} */
.col-5ch {
  min-width: 5ch !important;
  max-width: 5ch !important;
}

.col-10ch {
  min-width: 10ch;
  max-width: 10ch;
}

.col-15ch {
  min-width: 15ch;
  /* 30 caracteres */
  max-width: 15ch;
  /* 30 caracteres */
}

.col-20ch {
  min-width: 20ch;
  max-width: 20ch;
}

.col-25ch {
  min-width: 25ch;
  max-width: 25ch;
}

/* RESPONSIVIDAD */
.row>.col.responsive {
  flex: 1 1 0;
  min-width: 0;
}


.text-titulo {
  font-size: var(--fuente-titulo);
  color: var(--text-color) !important;
}

.text-subtitulo {
  font-size: var(--fuent-subtitulo);
  color: var(--text-color) !important;
}

.text-normal {
  font-size: var(--fuente-normal);
  color: var(--text-color) !important;
}

.text-peq {
  font-size: var(--fuente-peq);
  color: var(--text-color) !important;
}

.color-fuente {
  color: var(--text-color);
}



/*  Añade más:
.icon-carrito { mask-image:url('/assets/icons/carrito.svg'); }
.icon-globo   { mask-image:url('/assets/icons/globo.svg'); } */

.sidebar-link {
  display: flex;
  align-items: center;
  gap: .5rem;
  color: #4a4a4a;
  /* color normal */
  transition: color .25s;
}

.text-primary {
  color: var(--mc-azul) !important;
}

.text-primary-emphasis {
  color: var(--mc-azul) !important;

}

.btn-primary {
  background-color: var(--mc-azul);
  border-color: var(--mc-azul);
}

.btn-success {
  background-color: var(--mc-verde);
  border-color: var(--mc-verde);
}

.btn-limpiar {
  width: 20ch;
}

.caja-paginado {
  width: 70px;
}


/* ────────────────────────────────────────────────────────────────────────────────
    Estilos para Right Bar
──────────────────────────────────────────────────────────────────────────────── */
.right-bar {
  background-color: var(--bs-body-bg);
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.1);
  color: var(--bs-body-color);
}

.rightbar-title h5 {
  font-weight: 600;
  font-size: 1rem;
}

.right-bar a {
  transition: all 0.2s ease-in-out;
}

.right-bar a:hover {
  background-color: rgba(0, 123, 255, 0.1);
  border-radius: 0.375rem;
  padding-left: 0.5rem;
}

#progress1,
#progress2 {
  min-height: 60px;
  padding-left: 10px;
}

#sidebar-menu ul li a:hover i,
#sidebar-menu ul li a:hover svg,
#sidebar-menu ul li a:hover .icon,
#sidebar-menu ul li a:hover .menu-item {
  color: var(--sidebar-menu-item-hover-color);
}

/* body[data-sidebar-size="sm"] #sidebar-menu {
   margin-top: 39px;
} */


/* ─────────────────────────────────────────────────────────────────────────────────
   Hover slide-in para las opciones del sidebar
   ------------------------------------------------------------------
   1.  Añadimos transición suave a color, fondo y transform.
   2.  En :hover y en el estado .mm-active (el que usa MetisMenu
       cuando la ruta está seleccionada) desplazamos 4 px a la derecha.
─────────────────────────────────────────────────────────────── */
.vertical-menu,
.vertical-menu a,
.vertical-menu .menu-item {
  transition:
    width 0.3s ease,
    max-width 0.3s ease,
    opacity 0.3s ease,
    background-color 0.3s ease;
}

#sidebar-menu .metismenu>li>a {
  display: flex;
  align-items: center;
  transition: background-color .20s ease, color .20s ease, transform .20s ease;
}

#sidebar-menu .metismenu>li>a>svg {
  width: 20px;
  height: 20px;
}


/* efecto cuando el cursor pasa encima  */
#sidebar-menu .metismenu>li>a:hover,
#sidebar-menu .metismenu>li.mm-active>a .icon {
  transform: translateX(4px);
}



/* Z-index de modal y fondo */
.modal-backdrop {
  z-index: 4 !important;
}

.modal {
  z-index: 1050 !important;
}


/* ───── Estilo de opciones tipo tarjeta ───── */
.tipo-opcion-card {
  text-decoration: none;
  display: block;
  border: 2px solid transparent;
  border-radius: 0.65rem;
  background: #eaebf3d7;
  color: #2b2f38;
  transition: all 0.25s ease-in-out;
  box-shadow: 0 0 0 transparent;
}

.tipo-opcion-card:hover {
  border-color: #5b6dfa;
  background: #eef1f9;
  box-shadow: 0 0 0 2px rgba(91, 109, 250, 0.2);
  text-decoration: none;
}

.tipo-opcion-card:focus {
  outline: none;
  border-color: #5b6dfa;
  box-shadow: 0 0 0 3px rgba(91, 109, 250, 0.25);
}


.opcion-card-body {
  padding: 1rem 1.25rem;
}

.opcion-card-body strong {
  font-weight: 700;
  display: block;
  margin-bottom: 0.25rem;
  color: #2b2f38;
  /* título más oscuro */
}

.opcion-card-body p {
  margin: 0;
  color: #4f5d6b;
  /* texto auxiliar más visible */
  font-size: 0.875rem;
}

/* ─────────────── Modal tipo cuenta - Dark Mode ─────────────── */
#modalTipoCuenta .modal-content {
  background-color: var(--modal-bg);
  color: var(--modal-color);
  border: var(--modal-border);
  box-shadow: var(--modal-shadow);
}

#modalTipoCuenta .modal-header {
  background-color: var(--modal-header-bg) !important;
  color: var(--modal-header-color);

}

#modalTipoCuenta .modal-title {
  color: var(--modal-header-color);
}

#modalTipoCuenta .modal-body {
  background-color: var(--modal-body-bg);
}

#modalTipoCuenta .modal-body p {
  color: var(--color-fuente);
}


/* Tarjetas */
.tipo-opcion-card {
  background: var(--tipo-opcion-bg);
  border: 1px solid var(--tipo-opcion-border);
  color: var(--tipo-opcion-text);
}

.tipo-opcion-card:hover {
  background: var(--tipo-opcion-hover-bg);
  border-color: var(--tipo-opcion-hover-border);
  box-shadow: var(--tipo-opcion-hover-shadow);
}

.tipo-opcion-card:focus {
  box-shadow: var(--tipo-opcion-focus-shadow);
}

.opcion-card-body strong {
  color: var(--tipo-opcion-body-strong);
}

.opcion-card-body p {
  color: var(--tipo-opcion-body-p);
}


/* ─────────────── Termina Estilos del modal/popup Nueva Cuenta ─────────────────── */


/* Reduce padding de cabecera y cuerpo */
.contenedorContactos .contacto-block .card-header {
  padding: .5rem .75rem;
  font-size: .95rem;
}

.contenedorContactos .contacto-block .card-body {
  padding: .75rem;
}

/* Ajusta el gutter interno de filas dentro de la ficha */
.contenedorContactos .contacto-block .row.g-2 {
  --bs-gutter-x: .5rem;
  --bs-gutter-y: .5rem;
}

/* Campos un poco más compactos */
.contenedorContactos .contacto-block .form-control,
.contenedorContactos .contacto-block .form-select {
  padding: .375rem .75rem;
  font-size: .9rem;
}

.contacto-block .form-label {
  font-size: .875rem;
}

/* Encabezados de sección en flujo vertical */
/* Este ya es el predeterminado para todas las cards */

.card-header {
  background-color: var(--card-header-bg);
  color: var(--card-header-color);
  display: flex;
  flex-direction: column;
  /* por defecto columna */
  align-items: flex-start;
  gap: .5rem;
  padding: .75rem 1rem;
}

.card-header--row {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 0;
  padding: .5rem 1rem;
}

/* –– BOTÓN “Agregar Contacto” –– */
.card-header #agregarContacto {
  margin: 0;
  /* ya no lo empujamos */
  padding: .25rem .75rem;
  /* versión compacta */
  font-size: .875rem;
  /* un poco más pequeño */
  align-self: flex-start;
  /* asegúrate de que quede a la izquierda */
  border-radius: .375rem;
  /* igual que otros botones sm */
}

.card-header-filtros {
  background-color: rgba(66, 92, 199, 0.1);
  font-weight: 700;
}


/* — Hacer más angosto el card de “Cuenta Empresarial” — */
.section-card-cuenta-empresarial {
  width: 100%;
  margin-bottom: 1.5rem;
  /* espacio debajo */
}

.card-body {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  padding: 1.25rem 1.25rem;
  color: var(--text-color) !important;
  background-color: var(--card-body-bg);
}

/* Base común para ambos tiles */
.tile-agregar-contacto,
.tile-agregar-entrega,
.tile-agregar-facturacion {
  background-color: transparent !important;
  border: 2px dashed rgba(var(--bs-primary-rgb), 0.6);
  color: var(--bs-primary);
  transition: transform .2s ease,
    box-shadow .2s ease,
    background-color .2s ease,
    border-color .2s ease,
    color .2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 100%;
}

/* Ajuste de icono y texto interno */
.tile-agregar-contacto p,
.tile-agregar-entrega p,
.tile-agregar-facturacion p {
  margin: .5rem 0 0;
  font-size: .9rem;
}

/* Hover Light Mode */
.tile-agregar-contacto:hover,
.tile-agregar-entrega:hover,
.tile-agregar-facturacion:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  background-color: rgba(var(--bs-primary-rgb), 0.1);
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}

.tile-agregar-contacto:hover i,
.tile-agregar-contacto:hover p,
.tile-agregar-entrega:hover i,
.tile-agregar-entrega:hover p,
.tile-agregar-facturacion:hover i,
.tile-agregar-facturacion:hover p {
  color: var(--bs-primary);
}

/* Estilos <th> historial de pedidos */
#tblPedidos thead th,
#tblCotizaciones thead th {
  cursor: pointer;
  transition: background-color .15s;
}

#tblPedidos thead th:hover,
#tblCotizaciones thead th:hover {
  background: var(--tabla-header-hover-bg);
  /* azul clarito */
}

/* Flecha genérica */
.sort-arrow::after {
  content: "⇅";
  /* flecha doble vertical */
  font-size: .75rem;
  opacity: .3;
  margin-left: .25rem;
}

/* Estado orden ascendente */
#tblPedidos thead th.asc .sort-arrow::after {
  content: "▲";
  /* flecha arriba */
  opacity: 1;
  color: #0d6efd;
  /* azul Bootstrap */
}

/* Estado orden descendente */
#tblPedidos thead th.desc .sort-arrow::after {
  content: "▼";
  /* flecha abajo */
  opacity: 1;
  color: #0d6efd;
}

.timeline {
  border-left: 2px solid #e2e8f0;
  /* gris clarito */
  list-style: none;
  padding-left: 1rem;
}

.timeline li::before {
  content: '';
  position: absolute;
  left: -6px;
  top: 4px;
  width: 10px;
  height: 10px;
  background: #0d6efd;
  /* azul Bootstrap */
  border-radius: 50%;
}

.object-fit-cover {
  object-fit: cover;
}

/* ───────────────────────────────────────────────
     Estilos de tabla clientes/index.blade.php
   ─────────────────────────────────────────────── */

/* ───────── Tabla con layout fijo y altura homogénea ───────── */
#tabla-clientes {
  table-layout: fixed;
  border-radius: 0.25rem;
  /* bordes redondeados */

}

.active>.page-link {
  background-color: var(--mc-azul);
  border-color: var(--mc-azul);
}

.active>.page-link:hover {
  opacity: 0.9;
}

.table-responsive {
  border-radius: 0.25rem;
}

/* Estilo de encabezados de tabla del sistema */
.table thead {
  background-color: var(--tabla-header-bg);
  color: var(--tabla-header-text);
  font-size: var(--bs-body-font-size);
  font-weight: 600;
}

.header-tabla {
  background-color: var(--tabla-header-bg) !important;
}

#tblPedidos thead tr th,
#tblCotizaciones thead tr th {
  background: var(--tabla-header-bg);
}

#tblCotizaciones tfoot tr th,
#tblPedidos tfoot tr th {
  background-color: var(--tabla-header-bg);
}

#tblCotizaciones th,
#tblCotizaciones td {
  padding: 5px 14px;
}

#tblPedidos th,
#tblPedidos td,
#tblCotizaciones th,
#tblCotizaciones td {
  padding: 5px 12px;
  
}

/* ====== Flechas de orden con efectos ====== */
/* contenedor de la flecha para evitar “saltos” de layout */
#tblPedidos thead th .sort-arrow,
#tblCotizaciones thead th .sort-arrow {
  display: inline-block;
  min-width: 1ch;
  margin-left: .25rem;
}

/* estado base */
#tblPedidos thead th .sort-arrow::after,
#tblCotizaciones thead th .sort-arrow::after {
  content: "⇅";
  display: inline-block;
  opacity: .35;
  transform: translateY(1px) rotate(0deg);
  transition: transform .18s ease, color .18s ease, opacity .18s ease;
}

/* hover general del th ↑ opacidad de la flecha */
#tblPedidos thead th:hover .sort-arrow::after,
#tblCotizaciones thead th:hover .sort-arrow::after {
  opacity: .7;
}

/* th activo (columna ordenada) */
#tblPedidos thead th.sorted,
#tblCotizaciones thead th.sorted {
  background: var(--tabla-header-hover-bg);
}

/* flecha activa (mismo glifo ▲, rotación para continuidad visual) */
#tblPedidos thead th.asc .sort-arrow::after,
#tblCotizaciones thead th.asc .sort-arrow::after {
  content: "▲";
  opacity: 1;
  color: #0d6efd;
  transform: translateY(-1px) rotate(0deg);
}

#tblPedidos thead th.desc .sort-arrow::after,
#tblCotizaciones thead th.desc .sort-arrow::after {
  content: "▲";
  /* usamos el mismo triángulo… */
  opacity: 1;
  color: #0d6efd;
  transform: translateY(2px) rotate(180deg);
  /* …y lo rotamos 180° */
}

/* pequeña animación “bump” al hacer click */
@keyframes sort-bump {
  0% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-1px) scale(1.12);
  }

  100% {
    transform: translateY(0) scale(1);
  }
}

#tblPedidos thead th.bump .sort-arrow::after,
#tblCotizaciones thead th.bump .sort-arrow::after {
  animation: sort-bump .18s ease;
}


tfoot>tr>th {
  background: var(--tabla-header-bg);
}

/* Hover en cualquier thead (usa los vars que Bootstrap ya define) */
#tabla-clientes thead th:hover {
  background-color: var(--bs-table-bg) !important;
  color: var(--bs-table-hover-color) !important;
}

#tabla-clientes th,
#tabla-clientes td {
  vertical-align: middle;
  height: 48px;
  /* altura uniforme */
  padding-top: .5rem !important;
  padding-bottom: .5rem !important;
  overflow: hidden;
  /* recorte general */
}

/* ───────── Sticky columns ───────── */
/* ID Cliente (max 5 chars → 5ch) - Ciclo (columna 8) */
.tabla-col-id {
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--tabla-header-bg) !important;
  width: 11ch;
}

/* Empresa (max 30 chars → 30ch) */
.tabla-col-empresa {
  position: sticky;
  left: 0;
  z-index: 3;
  background: var(--bs-table-bg);
  width: 30ch;
}

/* Contactos */
.tabla-col-contacto {
  width: 25ch;
  background: var(--tabla-header-bg);
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

/* Telefono  (columna 4: 10 dígitos) */
.tabla-col-telefono {
  background: var(--tabla-header-bg);
  width: 15ch;
  align-items: center;
}

.tabla-col-correo {
  width: 25ch;
  background: var(--tabla-header-bg);
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

/* Sector (columna 6: “Gobierno” → 8 caracteres) */
.tabla-col-sector {
  width: 10ch;
  background: var(--tabla-header-bg);
  text-align: center;
  white-space: nowrap;
}


/* Segmento (columna 7: “Macasa Cuentas Especiales” → 25 caracteres) */
.tabla-col-segmento {
  width: 22ch;
  background: var(--tabla-header-bg);
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.tabla-col-ciclo {
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--tabla-header-bg) !important;
  width: 11ch;
}

.tabla-col-asignado {
  background: var(--tabla-header-bg);
  width: 15ch;
  align-items: center;
}

/* Flechas genéricas */
.sort-arrow::after {
  content: "⇅";
  font-size: .75rem;
  opacity: .3;
  margin-left: .25rem;
}

/* Asc y Desc */
#tabla-clientes thead th.asc .sort-arrow::after {
  content: "▲";
  opacity: 1;
  color: #0d6efd;
}

#tabla-clientes thead th.desc .sort-arrow::after {
  content: "▼";
  opacity: 1;
  color: #0d6efd;
}

/* ───────────────────────────────────────────────
   ESTILOS PARA NOTAS
   ─────────────────────────────────────────────── */
.body-notas {
  max-height: 535px;
  overflow-y: auto;
  background: var(--color-body-nota);
  border-radius: 8px;
  padding: 1rem 12rem 1rem 12rem;
  scroll-behavior: smooth;

}

/* ───────────────────────────────────────────────
   Termina Estilos de tabla clientes/index.blade.php
   ─────────────────────────────────────────────── */


#tablaPermisosCatalogo-wrapper,
#listaRolesConPermiso-wrapper {
  max-height: 400px;
  overflow-y: auto;
}

/* Arrancamos con “modo traspaso”: ocultamos la columna de archivado */
.col-archivar {
  display: none;
}

.col-traspaso {
  display: table-cell;
}

/* Cuando entres en modo archivado, este background ayuda a reforzar la acción */


/* Ajuste visual de los checkboxes */
.client-checkbox {
  margin: 0;
  transform: scale(1.2);
}


/* Contenedor del switch */
.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 28px;
}

/* Oculta el input real */
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

/* El slider */
.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: background-color .3s;
}

/* El círculo */
.slider:before {
  position: absolute;
  content: "";
  height: 22px;
  width: 22px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: transform .3s;
}

/* Cuando está ON */
input:checked+.slider {
  background-color: var(--bs-danger);
}

/* Mueve el círculo al estado ON */
input:checked+.slider:before {
  transform: translateX(22px);
}

/* Bordes redondeados */
.slider.round {
  border-radius: 28px;
}

.slider.round:before {
  border-radius: 50%;
}

/* === SWITCH =================================================== */
.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 28px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background: #ccc;
  transition: background .3s;
}

.slider:before {
  content: "";
  position: absolute;
  bottom: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  background: #fff;
  transition: transform .3s;
}

input:checked+.slider {
  background: var(--bs-danger);
}

input:checked+.slider:before {
  transform: translateX(22px);
}

.slider.round {
  border-radius: 28px;
}

.slider.round:before {
  border-radius: 50%;
}

/* === TRANSICIONES SUAVES ====================================== */
/* body,
.vertical-menu,
#logo-box,
#page-topbar,
.bg-light-subtle {
  transition: background-color .3s ease;
} */

/* === MODO ARCHIVADO (clase en <html>) ========================= */
/* .archivar-mode body                { background:var(--modo-archivado-body-bg)!important; }
.archivar-mode .vertical-menu      { background:var(--modo-archivado-sidebar-bg)!important; border-color: var(--modo-archivado-sidebar-bg)!important ; }
.archivar-mode #logo-box           { background:var(--modo-archivado-sidebar-bg)!important; }
.archivar-mode #page-topbar        { background:var(--modo-archivado-body-bg)!important; border-color: var(--modo-archivado-sidebar-bg)!important;}
.archivar-mode .bg-light-subtle    { background:rgba(var(--bs-danger-rgb),.2)!important; } */

/* 2) Sólo coloreamos las filas que tengan la clase .table-danger */
.archivar-mode tbody tr.table-danger>td {
  /* fondo rojo suave */
  background-color: rgba(var(--bs-danger-rgb), .2) !important;
  /* texto rojo oscuro */
  color: rgb(var(--bs-danger-rgb)) !important;
}

/* Columnas: por defecto vemos solo traspaso */
.col-archivar {
  display: none;
}

.col-traspaso {
  display: table-cell;
}


/* contenedor switch exactamente como en clientes/transfer */
.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 28px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background-color: #ccc;
  transition: background-color .3s;
}

.slider:before {
  content: "";
  position: absolute;
  bottom: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  background-color: white;
  transition: transform .3s;
}

input:checked+.slider {
  background-color: var(--bs-success);
}

input:checked+.slider:before {
  transform: translateX(22px);
}

.slider.round {
  border-radius: 28px;
}

.slider.round:before {
  border-radius: 50%;
}

/* Ajuste visual de los checkboxes */
.client-checkbox {
  margin: 0;
  transform: scale(1.2);
}

/* Modo multiselección: fondo verde suave */
/* .selection-mode body {
  background-color: var(--bs-success-bg-subtle) !important;
}
.selection-mode .vertical-menu,
.selection-mode #logo-box,
.selection-mode #page-topbar,
.selection-mode .bg-light-subtle {
  background-color: rgba(var(--bs-success-rgb), .2) !important;
} */
/* Solo coloreamos las filas marcadas con .table-success */
.selection-mode tbody tr.table-success>td {
  /* fondo verde suave */
  background-color: rgba(var(--bs-success-rgb), .2) !important;
  /* texto verde oscuro */
  color: rgb(var(--bs-success-rgb)) !important;
}

/* Columnas: por defecto ocultas */
.col-select {
  display: none;
}

/* 1) Limitar altura total del body y habilitar scroll */
#modalFacturacion .modal-dialog-scrollable .modal-body {
  max-height: 70vh;
  /* ocupa hasta 70% de la altura de la ventana */
  overflow-y: auto;
  /* scroll vertical cuando sobrepasa */
  padding: 0rem 2rem 0rem 2rem;
  /* espacio interior uniforme */
}

/* 2) Estilo del contenedor de la tabla */
#modalFacturacion .table-responsive {
  border: 1px solid #dee2e6;
  /* línea sutil alrededor */
  border-radius: 0.375rem;
  /* esquinas redondeadas */
  background-color: #ffffff;
  /* fondo blanco */
}

/* 3) Opcional: refinar el aspecto del modal-content */
#modalFacturacion .modal-content {
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

/* 1) Columna de acción súper estrecha */
#modalFacturacion .select-col {
  width: 60px;
  padding: 0;
}

/* 2) Botón outline más compacto */
#modalFacturacion .seleccionar-direccion {
  padding: .25rem .4rem;
  border-radius: .25rem;
  transition: background-color .2s, border-color .2s, color .2s;
}

/* 3) Hover: relleno primario */
#modalFacturacion .seleccionar-direccion:hover {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}

/* 4) Estado “predeterminado” */
#modalFacturacion .table-success .seleccionar-direccion {
  border-color: var(--bs-success);
  background-color: var(--bs-success);
  color: #fff;
}


/* ================================
   HOMOGENEIZAR ESTILOS modalEntrega
   ================================ */

/* 1) Limitar altura y habilitar scroll igual que modalFacturacion */
#modalEntrega .modal-dialog-scrollable .modal-body {
  max-height: 70vh;
  /* ocupa hasta el 70% de la ventana */
  overflow-y: auto;
  /* scroll interno vertical */
  padding: 0rem 2rem;
  /* mismo padding que en Facturación */
}

/* 2) Marco y fondo de la tabla */
#modalEntrega .table-responsive {
  border: 1px solid #dee2e6;
  border-radius: 0.375rem;
  background-color: #ffffff;
}

/* 3) Sombra suave para el contenido */
#modalEntrega .modal-content {
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

/* 4) Columna de acción (checkbox/button) estrecha */
#modalEntrega .select-col {
  width: 60px;
  padding: 0;
}

/* 5) Botón de selección compacto y con transición */
#modalEntrega .seleccionar-entrega {
  padding: .25rem .4rem;
  border-radius: .25rem;
  transition: background-color .2s, border-color .2s, color .2s;
}

/* 6) Hover: mismo relleno primario */
#modalEntrega .seleccionar-entrega:hover {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}

/* 7) Estado “predeterminado”: verde suave */
#modalEntrega .table-success .seleccionar-entrega {
  border-color: var(--bs-success);
  background-color: var(--bs-success);
  color: #fff;
}

/* Limita ancho de columnas de números */
#tablaPartidas th.text-end,
#tablaPartidas td.text-end {
  white-space: nowrap;
}

/* Botón de eliminar más pequeño visualmente */
#tablaPartidas .btn.btn-xs {
  padding: 2px 6px;
  font-size: 0.75rem;
  line-height: 1;
}

/* =========================
   TABLA DE PARTIDAS
   ========================= */

/* 1) Layout + anchos por encabezado (+1 espacio a cada lado)
   Deja "Descripción" elástica */
:root {
  --w-partida: 9ch;
  /* ' partida '  */
  --w-noparte: 14ch;
  /* ' No. de Parte ' */
  --w-precio: 8ch;
  /* ' Precio '   */
  --w-costo: 7ch;
  /* ' Costo '    */
  --w-cantidad: 10ch;
  /* ' Cantidad ' */
  --w-importe: 9ch;
  /* ' Importe '  */
  --w-margen: 8ch;
  /* ' Margen '   */
  --w-margenpct: 10ch;
  /* ' % Margen ' */
  --w-acciones: 96px;
  /* botones      */
}

.table-partidas {
  width: 100%;
}

.table-partidas.table-fixed {
  table-layout: fixed;
}

.table-partidas col:nth-child(1) {
  width: var(--w-partida);
}

.table-partidas col:nth-child(2) {
  width: var(--w-noparte);
}

.table-partidas col:nth-child(3) {
  /* Descripción: ocupa el resto */
}

.table-partidas col:nth-child(4) {
  width: var(--w-precio);
}

.table-partidas col:nth-child(5) {
  width: var(--w-costo);
}

.table-partidas col:nth-child(6) {
  width: var(--w-cantidad);
}

.table-partidas col:nth-child(7) {
  width: var(--w-importe);
}

.table-partidas col:nth-child(8) {
  width: var(--w-margen);
}

.table-partidas col:nth-child(9) {
  width: var(--w-margenpct);
}

.table-partidas col:nth-child(10) {
  width: var(--w-acciones);
}

/* 2) Alineación:
   - Todo CENTRADO (thead + tbody + acciones)
   - EXCEPTO columna 3 (Descripción) que va a la izquierda y admite multilínea */
.table-partidas thead th,
.table-partidas tbody td {
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
}

.table-partidas thead th:nth-child(3),
.table-partidas tbody td:nth-child(3) {
  text-align: left;
}

/* 3) Descripción: máximo 5 renglones + "…" sin afectar el td */
.table-partidas td.col-desc {
  white-space: normal;
}

.table-partidas td.col-desc>.desc-text {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  line-clamp: 5;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.25;
}

@supports not (-webkit-line-clamp: 5) {
  .table-partidas td.col-desc>.desc-text {
    max-height: calc(1.25em * 5);
    overflow: hidden;
  }
}

/* 4) Botonera de acciones centrada siempre */
.table-partidas td .btn {
  margin: 0 .15rem;
}

/* 5) Separación superior mínima entre formulario y tabla */
#tablaPartidas {
  margin-top: .5rem;
}

.rightbar-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 1039;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
}
body.right-bar-enabled .rightbar-overlay{
  opacity: 1;
  pointer-events: auto;
}

/* Asegura que el panel flote sobre el overlay */
.right-bar{ z-index: 1040; }


:root{
  --rightbar-w: 360px;
  --rightbar-speed: var(--sidebar-speed, 180ms);
}

/* Panel off-canvas por defecto, por encima del overlay */
.right-bar{
  position: fixed;
  top: 0; right: 0;
  width: var(--rightbar-w);
  height: 100dvh;
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
  box-shadow: 0 0 0 1px rgba(0,0,0,.05), 0 12px 30px rgba(0,0,0,.18);
  transform: translateX(100%);
  transition: transform var(--rightbar-speed) ease;
  z-index: 1040;
}
body.right-bar-enabled .right-bar{
  transform: translateX(0); /* <- fuerza entrada */
}

/* Overlay único */
.rightbar-overlay{
  position: fixed;
  inset: 0;
  background: rgba(33,37,41,.55);
  z-index: 1039;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--rightbar-speed) ease;
}
body.right-bar-enabled .rightbar-overlay{
  opacity: 1;
  pointer-events: auto;
}
