/* ==========================================================================
   Tema verde + sidebar compacto y expandible (Bootstrap 5)
   Archivo: public/assets/css/app.css
   ========================================================================== */

/* ---------- Paleta y tokens ---------- */
/* ========= PALETA (solo ajustes de color) ========= */
:root {
  /* Mantengo tu verde (está bien). Solo agrego 2 utilidades */
  --brand-50:  #f0f7ff;
  --brand-100: #e0effe;
  --brand-200: #bae0fd;
  --brand-300: #7cc8fb;
  --brand-400: #38a9f8;
  --brand-500: #0e8ce9;
  --brand-600: #026dc7; /* Color principal (el que era tu verde 600) */
  --brand-700: #0357a1;
  --brand-800: #074a85;
  --brand-900: #0c3f6d;

  --brand-600-rgb: 2, 109, 199; /* Actualizado para las transparencias */

  /* Neutros: cambia de “carbón” a “slate” (se ve más moderno y consistente) */
  --bg: #0b1220;          /* fondo sidebar */
  --bg-2: #0a0f1a;        /* topbar un poco más oscuro */
  --surface: #0f172a;     /* superficies dark (inputs, hover sutil) */
  --surface-2: #111c33;   /* variación para overlays/hover */

  --text: #e2e8f0;        /* texto principal en dark */
  --muted: #94a3b8;       /* texto secundario en dark */
  --border: rgba(148, 163, 184, .16); /* subo el borde para que se “lea” mejor */

  /* Tema claro del contenido: un poco más neutro (menos verdoso) */
  --content-bg: #f8fcf8;
  --content-surface: #ffffff;
  --content-text: #0f172a;
  --content-muted: #64748b;

  /* Extras útiles */
  --ring: rgba(var(--brand-600-rgb), .25);
  --sidebar-active-bg: rgba(var(--brand-600-rgb), .14);
  --sidebar-hover-bg: rgba(var(--brand-600-rgb), .10);
}

/* ---------- Base ---------- */
* {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

body {
  background: linear-gradient(180deg, var(--bg), var(--bg-2));
  color: var(--text);
}

a,
.link {
  color: var(--brand-400);
}

a:hover,
.link:hover {
  color: var(--brand-300);
}

.text-muted {
  color: var(--muted) !important;
}

/* ---------- Topbar ---------- */
.topbar,
.navbar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.navbar-brand {
  font-weight: 700;
  letter-spacing: .2px;
}

/* ---------- Sidebar ---------- */
.sidebar {
  background: var(--surface);
}

/* Móvil = offcanvas; Escritorio (>=lg) = fijo y colapsado */
@media (min-width: 992px) {
  .app {
    min-height: 100vh;
    display: flex;
  }

  .sidebar.offcanvas-lg {
    transform: none !important;
    visibility: visible !important;
    position: sticky;
    top: 0;
    height: 100vh;
    border-right: 1px solid var(--border);
    width: var(--sidebar-w);
    transition: width .18s ease-in-out;
    overflow: hidden;
    flex: 0 0 var(--sidebar-w);
    min-width: var(--sidebar-w);

    /* oculta texto al colapsar */
  }

  /* Expande al hover */
  .sidebar.offcanvas-lg:hover {
    width: var(--sidebar-w-expanded);
    flex-basis: var(--sidebar-w-expanded);
    min-width: var(--sidebar-w-expanded);

  }

  .sidebar .offcanvas-body {
    display: flex;
    flex-direction: column;
    padding: .25rem 0;
  }

  .app-main {
    flex: 1;
    min-width: 0;
  }
}

/* Header del offcanvas */
.sidebar .offcanvas-header {
  border-bottom: 1px solid var(--border);
}

/* Items del menú (compactos) */
.sidebar .list-group-item {
  background: transparent;
  color: var(--text);
  border: 0;
  border-left: 3px solid transparent;
  border-radius: 0;
  padding: .55rem .6rem;
  display: flex;
  align-items: center;
}

/* Ícono reducido */
.sidebar .list-group-item i {
  width: 1.25rem;
  min-width: 1.25rem;
  text-align: center;
  margin-right: .35rem;
  opacity: .95;
  font-size: 1.05rem;
}

/* Texto colapsable: oculto por defecto, visible al hover (>=lg) */
@media (min-width: 992px) {
  .sidebar .nav-text {
    opacity: 0;
    width: 0;
    margin-left: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    transition: opacity .15s ease, width .15s ease, margin-left .15s ease;
  }

  .sidebar.offcanvas-lg:hover .nav-text {
    opacity: 1;
    width: auto;
    margin-left: .25rem;
  }
}

/* Hover / activo */
.sidebar .list-group-item:hover {
  background: rgba(255, 255, 255, .03);
}

.sidebar .list-group-item.active {
  background: rgba(5, 150, 105, .14);
  border-left-color: var(--brand-600);
  color: var(--text);
  font-weight: 600;
}

/* ---------- Botones ---------- */
.btn-brand,
.btn-success,
.btn-primary {
  background: var(--brand-600) !important;
  border-color: var(--brand-700) !important;
}

.btn-brand:hover,
.btn-success:hover,
.btn-primary:hover {
  background: var(--brand-700) !important;
  border-color: var(--brand-800) !important;
}

.btn-outline-light {
  color: var(--text);
  border-color: rgba(255, 255, 255, .25);
}

.btn-outline-light:hover {
  background: rgba(255, 255, 255, .08);
}

/* Cambio integrado: Azul para login sin clases nuevas */
.auth-right .btn-brand,
.auth-right .btn-success,
.auth-right .btn-primary {
  background: #3b82f6 !important;
  border-color: #2563eb !important;
}

.btn-brand:hover,
.btn-success:hover,
.btn-primary:hover {
  background: var(--brand-700) !important;
  border-color: var(--brand-800) !important;
}

.auth-right .btn-brand:hover,
.auth-right .btn-success:hover,
.auth-right .btn-primary:hover {
  background: #2563eb !important;
}

/* ---------- Cards / contenedores (modo oscuro base) ---------- */
.card.glass {
  background: rgba(255, 255, 255, .03);
  border: 1px solid var(--border);
  border-radius: 1rem;
}

.bg-surface {
  background: var(--surface);
}

.bg-surface-2 {
  background: var(--surface-2);
}

/* ---------- Panel verde para tablas/listas (oscuro por defecto) ---------- */
.panel-green {
  background: linear-gradient(180deg,
      rgba(var(--brand-600-rgb), .10),
      rgba(var(--brand-700-rgb), .10));
  border: 1px solid rgba(var(--brand-600-rgb), .35);
  border-radius: 1rem;
  box-shadow: 0 10px 30px rgba(var(--brand-700-rgb), .14);
}

.table {
  --bs-table-bg: transparent;
  color: var(--text);
}

.table thead th {
  background: rgba(var(--brand-600-rgb), .18);
  color: #e7f4ef;
}

/* Ajuste para no afectar otras áreas: heredar color del table */
.table tbody td {
  color: inherit;
}

.table> :not(caption)>*>* {
  border-bottom-color: var(--border);
}

.panel-green .table tbody tr:hover {
  background: rgba(var(--brand-600-rgb), .10);
}

.panel-green .btn-outline-light:hover {
  background: rgba(var(--brand-600-rgb), .20);
}

/* ---------- Miniaturas ---------- */
.img-thumb {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: .5rem;
}

/* ---------- Helpers ---------- */
.hr-soft {
  border: 0;
  border-top: 1px solid var(--border);
  margin: .75rem 0;
}

/* ==========================================================================
   TEMA CLARO PARA EL ÁREA DE CONTENIDO (excluye sidebar)
   ========================================================================== */

/* Lienzo claro */
.app-main {
  background: var(--content-bg);
}

/* Aplica a <main> con class="content-area" */
.content-area {
  background: var(--content-bg);
  min-height: calc(100vh - 56px);
  /* altura completa bajo la topbar */
  color: var(--content-text);
}

/* Tarjetas en blanco dentro del contenido claro */
.content-area .card.glass {
  background: var(--content-surface);
  border: 1px solid rgba(0, 0, 0, .06);
  color: var(--content-text);
}

.content-area .card.glass .text-secondary {
  color: #5b6b7b !important;
}

/* Panel verde en modo claro (más suave) */
.content-area .panel-green {
  background: linear-gradient(180deg,
      rgba(var(--brand-600-rgb), .06),
      rgba(var(--brand-700-rgb), .06));
  border-color: rgba(var(--brand-600-rgb), .25);
}

/* Tablas modo claro (aunque en la vista tengan .table-dark) */
.content-area .table {
  --bs-table-bg: #ffffff;
  color: #111827;
}

.content-area .table thead th {
  background: rgba(var(--brand-600-rgb), .12);
  color: #0b3b2b;
  /* verde oscuro legible */
}

.content-area .table> :not(caption)>*>* {
  border-bottom-color: rgba(0, 0, 0, .06);
}

/* QUITA el negro del hover y usa un tinte verde suave */
.content-area .table-hover tbody tr:hover {
  background: rgba(var(--brand-600-rgb), .10) !important;
}

/* Rayado opcional si usas .table-striped */
.content-area .table-striped>tbody>tr:nth-of-type(odd)>* {
  --bs-table-accent-bg: rgba(var(--brand-600-rgb), .06);
}

/* Botones contorno dentro de contenido claro */
.content-area .btn-outline-light {
  color: #1f2937;
  border-color: rgba(31, 41, 55, .3);
}

.content-area .btn-outline-light:hover {
  background: rgba(31, 41, 55, .06);
}

/* Accesibilidad: foco con teclado en filas */
.content-area .table tbody tr:focus-within {
  outline: 2px solid rgba(var(--brand-600-rgb), .35);
  outline-offset: -2px;
}

/* === DataTables x Tema Verde === */

.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_info {
  color: var(--content-text);
}

/* buscador */
.dataTables_wrapper .dataTables_filter input {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, .12);
  border-radius: .5rem;
  padding: .35rem .6rem;
  outline: none;
}

.dataTables_wrapper .dataTables_filter input:focus {
  border-color: rgba(var(--brand-600-rgb), .6);
  box-shadow: 0 0 0 .2rem rgba(var(--brand-600-rgb), .15);
}

/* selector de “mostrar N” */
.dataTables_wrapper .dataTables_length select {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, .12);
  border-radius: .5rem;
  padding: .35rem .6rem;
}

/* encabezado de tabla coherente al panel verde */
table.dataTable thead th,
table.dataTable thead td {
  background: rgba(var(--brand-600-rgb), .12) !important;
  color: #0b3b2b;
  border-bottom: 1px solid rgba(var(--brand-600-rgb), .25) !important;
}

/* hover de filas, suave en verde */
table.dataTable tbody tr:hover {
  background: rgba(var(--brand-600-rgb), .07) !important;
}

/* paginación */
.dataTables_wrapper .dataTables_paginate .pagination .page-item .page-link {
  color: var(--brand-600);
  border: 1px solid rgba(0, 0, 0, .1);
}

.dataTables_wrapper .dataTables_paginate .pagination .page-item.active .page-link,
.dataTables_wrapper .dataTables_paginate .pagination .page-item .page-link:hover {
  background: var(--brand-600);
  border-color: var(--brand-600);
  color: #fff;
}

/* Responsive rows (detalles) */
table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control:before,
table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control:before {
  background-color: var(--brand-600);
}

@media (max-width: 575.98px){
  .table-responsive .table { font-size: .85rem; }
  .table-responsive .table th,
  .table-responsive .table td { padding: .45rem .5rem; }
}


/* Header de catálogo: arregla título + acciones en mobile */
@media (max-width: 575.98px){
  .table-header{
    display: flex;
    flex-direction: column;
    gap: .5rem;
  }

  .table-header .table-title{
    display: block !important;  /* por si algo lo oculta */
    position: relative;
    z-index: 2;                 /* por si quedara overlay */
    text-align: center;
  }

  .table-header .table-actions{
    position: static !important;  /* override position-absolute (!important) */
    inset: auto !important;       /* MATA top/left/right/bottom (top-50/start-0) */
    transform: none !important;   /* MATA translate-middle-y */
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    z-index: 1;
  }
}


/* Buscador en topbar */
/* Evita que el form estire el input a lo ancho de la topbar */
#dt-global-search-form {
  flex: 0 0 auto;
}

.topbar .container-fluid {
  position: relative;
}

/* El formulario queda centrado horizontal y verticalmente en la barra */
.search-center {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: clamp(260px, 40vw, 520px);
  /* tamaño controlado */
}

/* Input de búsqueda más pequeño */
.topbar-search-input {
  width: clamp(220px, 24vw, 360px);
  /* ancho máx. 360px, puede ser menos según viewport */
  max-width: 360px;
  padding: .35rem .75rem;
  font-size: .875rem;
  /* tamaño pequeño */
  height: 34px;
  /* compacto */
}

/* En pantallas muy grandes puedes permitir un poco más si quieres */
@media (min-width: 1400px) {
  .topbar-search-input {
    max-width: 400px;
  }
}

.topbar-search-input:focus {
  border-color: rgba(var(--brand-600-rgb), .6);
  box-shadow: 0 0 0 .2rem rgba(var(--brand-600-rgb), .18);
}

/* ---------- Brand del sidebar ---------- */
.sidebar-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  height: 56px;
  border-bottom: 1px solid var(--border);
  padding-inline: .5rem;
}

/* Logo compacto (se ve bien colapsado) */
.sidebar .brand-logo {
  width: 36px;
  height: 36px;
  border-radius: .75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  /* sin fondo para que la imagen se vea tal cual */
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.brand-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  color: inherit;
}

.brand-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
  /* un poco de aire dentro del marco */
}

.sidebar .brand-img {
  height: 22px;
  /* un poco más pequeño en sidebar */
}

.brand-text {
  font-weight: 700;
  white-space: nowrap;
}

/* Ajuste suave en pantallas pequeñas */
@media (max-width: 991.98px) {
  .sidebar .brand-logo {
    width: 32px;
    height: 32px;
  }

  .brand-img {
    padding: 3px;
  }
}

/* Mismo patrón de “nav-text” para el texto de la marca */
.sidebar .brand-text {
  opacity: 0;
  width: 0;
  margin-left: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  transition: opacity .15s ease, width .15s ease, margin-left .15s ease;
}

/* Al expandir sidebar por hover en escritorio, mostramos el texto */
@media (min-width: 992px) {
  .sidebar.offcanvas-lg:hover .sidebar-brand {
    justify-content: flex-start;
    padding-left: .75rem;
  }

  .sidebar.offcanvas-lg:hover .brand-text {
    opacity: 1;
    width: auto;
    margin-left: .25rem;
  }
}

/*dashboard*/
.kpi-card .kpi-icon {
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: .75rem;
  font-size: 1.25rem;
}

/* === FIX CRÍTICO KPI (SOLO MOBILE) === */
@media (max-width: 575.98px){

  /* Permite que el layout envuelva y no se aplaste en col-6 */
  .kpi-card .card-body{
    flex-wrap: wrap !important;
    align-items: flex-start !important;
  }

  /* El icono ocupa su fila visual y no empuja el texto */
  .kpi-card .kpi-icon{
    margin-right: 0 !important;   /* anula tu me-3 en mobile */
    margin-bottom: .35rem !important;
    width: 36px;
    height: 36px;
    font-size: 1.1rem;
    flex: 0 0 auto;
  }

  /* El bloque de texto se va a 100% del ancho */
  .kpi-card .card-body > div:last-child{
    flex: 0 0 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  /* Tipografías más compactas y ordenadas */
  .kpi-card .kpi-label{
    margin-bottom: .1rem;
    line-height: 1.15;
  }

  .kpi-card .kpi-value{
    line-height: 1.1;
    font-size: 1.05rem;  /* fijo para evitar “saltos raros” */
    white-space: nowrap;
  }
}



/**LOGIN***/

/* ===== Auth (pantalla partida) ===== */

.bg-info-login-left{
  background-color: var(--brand-500) !important;
}

.auth-body {
  background: var(--content-bg);
}

/* Contenedor: 50/50 en >=lg */
.auth-split {
  display: grid;
  grid-template-columns: 1fr;
  /* móvil: 1 col */
}

@media (min-width: 992px) {
  .auth-split {
    grid-template-columns: 1fr 1fr;
    /* desktop: 50/50 */
  }
}

/* Columna izquierda (hero verde) */
.auth-left {
  background: radial-gradient(60% 60% at 20% 30%, rgba(59, 130, 246, 0.2), transparent 70%),
              linear-gradient(180deg, #1e3a8a 0%, #0f172a 100%) !important;
  color: #f1f5f9;
}

.auth-left-card {
  max-width: 520px;
  width: 100%;
}

.auth-illustration {
  width: 100%;
  min-height: 200px;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  backdrop-filter: blur(12px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
/* Columna derecha (form) */
.auth-right {
  background: #fff;
  /* contraste con el formulario */
  color: #0f172a;
}

/* Inputs grandes coherentes */
.auth-right .form-control {
  border-color: rgba(0, 0, 0, .12);
}

/* Inputs con foco azul en login */
.auth-right .form-control:focus {
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 .2rem rgba(59, 130, 246, .15) !important;
}

/* Links en azul */
.auth-right a,
.auth-right .link-offset-2 {
  color: #3b82f6 !important;
}

/* ===== Sidebar: grupos con submenú (minimal) ===== */
/* Solo añade comportamiento para agrupar opciones sin afectar lo demás */
.sidebar .nav-group {
  position: relative;
}

/* Botón del grupo con el mismo look que un item normal */
.sidebar .nav-group-toggle {
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  display: flex;
  align-items: center;
  gap: .25rem;
  padding: .55rem .6rem;
  color: var(--text);
}

/* Chevron a la derecha (solo visible cuando el sidebar está expandido) */
.sidebar .nav-chevron {
  margin-left: auto;
  opacity: .65;
  transition: transform .2s ease;
  display: none;
}

@media (min-width: 992px) {
  .sidebar.offcanvas-lg:hover .nav-chevron {
    display: block;
  }
}

.sidebar .nav-group-toggle[aria-expanded="true"] .nav-chevron {
  transform: rotate(180deg);
}

/* Submenú (usa .collapse en móvil). En desktop lo mostramos al hover. */
.sidebar .nav-sub {
  padding: 0;
  margin: .1rem 0 .4rem;
}

.sidebar .nav-sub .list-group-item {
  padding: .45rem .6rem .45rem 1.85rem;
  /* indent visual */
  font-size: .95rem;
  border-left: 1px solid var(--border);
}

.sidebar .nav-sub .list-group-item i {
  margin-right: .35rem;
}

.sidebar .nav-sub .list-group-item.active {
  background: rgba(5, 150, 105, .14);
  border-left-color: var(--brand-600);
}

/* Desktop: mantener ocultos los submenús para un sidebar compacto,
   y mostrarlos solo al pasar el mouse por el grupo cuando el sidebar está expandido */
@media (min-width: 992px) {
  .sidebar .nav-sub.collapse {
    display: none !important;
    height: auto !important;
  }

  .sidebar .nav-sub.collapse.show {
    display: none !important;
  }

  .sidebar.offcanvas-lg:hover .nav-group:hover>.nav-sub {
    display: block !important;
  }
}


/* ===== User menu (topbar) ===== */
.topbar .btn-user {
  background: transparent;
  border: 0;
  padding: .125rem .25rem;
  border-radius: 999px;
}

.topbar .avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #fff;
  color: #111;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  border: 1px solid rgba(0, 0, 0, .1);
}

.topbar .btn-user:hover .avatar {
  box-shadow: 0 0 0 .2rem rgba(var(--brand-600-rgb), .18);
}

.dropdown-menu .dropdown-item i {
  width: 1rem;
  /* alinea íconos */
}

.dropdown-menu .dropdown-item:active {
  background: rgba(var(--brand-600-rgb), .12);
  color: inherit;
}


/* Switch más grande y con colores personalizados */
.form-check.form-switch .form-check-input.toggle-bloqueado {
  width: 3rem;
  height: 1.6rem;
  cursor: pointer;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.05);
}

/* color cuando está apagado */
.form-check.form-switch .form-check-input.toggle-bloqueado {
  background-color: #ced4da;
}

/* color cuando está encendido (bloqueado) */
.form-check.form-switch .form-check-input.toggle-bloqueado:checked {
  background-color: #12e132;
  /* rojo */
  border-color: #12e132;
}

/* transición suave del ‘thumb’ */
.form-check.form-switch .form-check-input.toggle-bloqueado {
  transition: background-color .25s ease, border-color .25s ease, box-shadow .25s ease;
}


/*POS*/
/* ======================================= */
/* POS NUEVO: Desktop fijo + scroll interno */
/* ======================================= */

/* Contenedor principal POS */
.pos-container {
  max-width: 1400px;
  margin: 15px auto;
  background-color: #FFF;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Fila principal */
.pos-container>.row.h-100 {
  margin: 0;
}

/* Columna izquierda (productos) */
.pos-container>.row.h-100>.col-md-8 {
  background-color: #F8F9FA;
  padding: 15px;
}

/* Área de lista del carrito */
.pos-scrollable-grid-area,
.pos-selected-list-area {
  flex: 1 1 auto;
  overflow-y: auto !important;
  min-height: 0;
  padding: 10px;
}

/* --- CARDS DE PRODUCTO --- */
.pos-item-card {
  border: 1px solid #edf2f7;
  transition: all 0.2s ease;
  cursor: pointer;
  border-radius: 5px !important;
  overflow: hidden;
}

.pos-item-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.pos-item-card.selected {
  background-color: #d1e7dd;
  border-color: #0d6efd;
  box-shadow: 0 0 0 3px #0d6efd;
}

.pos-card-img-top {
  height: 90px;
  object-fit: cover;
}

.pos-item-card .card-title {
  font-size: 0.9rem;
}

/* Productos sin stock */
.pos-item-card.out-of-stock {
  opacity: 0.6;
  pointer-events: none;
  border: 2px solid #dc3545;
  cursor: not-allowed;
}

/* --- ITEMS DEL CARRITO --- */
.pos-container #selectedItemsList {
  margin: 0;
  padding: 0;
  list-style: none;
}

.pos-cart-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 5px;
  border-bottom: 1px solid #f1f3f5;
}

/* Buscador estilizado */
#searchBar {
  border-radius: 10px;
  border: 1px solid #dee2e6;
  padding-left: 40px;
  /* Espacio para el icono si usas absolute */
}

#cancel-button:hover {
  background-color: #fff5f5;
  border-radius: 4px;
}

/* Scrollbar estética para el grid */
#itemGridScroll::-webkit-scrollbar {
  width: 6px;
}

#itemGridScroll::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 10px;
}

.pos-cart-item:last-child {
  border-bottom: none;
}

.pos-item-info {
  flex: 1;
  padding-right: 8px;
}

.pos-item-controls input[type="number"] {
  width: 55px;
  text-align: center;
  border-radius: 6px;
  border: 1px solid #ced4da;
}

/* --- RESUMEN Y BOTONES --- */
.pos-summary {
  background: #fff;
  border-top: 2px solid #f8f9fa;
  padding: 20px;
  flex-shrink: 0;
  /* Evita que los botones se compriman o desaparezcan */
}

.pos-actions {
  padding-top: 1rem;
}

.pos-action-button-custom {
  width: 100%;
  padding: 12px;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 6px;
}

/* Botón Cancelar */
.btn-outline-danger {
  color: #dc3545;
  border-color: #dc3545;
}

.btn-outline-danger:hover {
  background-color: #dc3545;
  color: #FFF;
}

/* ===== MOBILE: stack normal, scroll de página ===== */
@media (max-width: 991.98px) {

  .pos-container {
    height: auto !important;
    margin: 0;
  }

  .pos-scrollable-grid-area,
  .pos-selected-list-area {
    max-height: 50vh;
  }

  /* El grid de productos scrollea un poco en móvil */
  .pos-scrollable-grid-area {
    max-height: 55vh;
    overflow-y: auto;
  }

  /* La lista del carrito también puede scrollear */
  .pos-selected-list-area {
    max-height: 40vh;
    overflow-y: auto;
  }
}

/* ==========================================================
   FIX POS: carrito con scroll en escritorio
   ========================================================== */
@media (min-width: 992px) {

  /* La tarjeta POS ocupa casi toda la ventana y no recorta por fuera */
  .pos-container {
    height: calc(100vh - 120px) !important;
    margin: 10px auto !important;
  }

  .pos-container .col-md-8 {
    background-color: #F8F9FA;
    padding: 20px;
    display: flex;
    flex-direction: column;
  }

  .pos-cart-col {
    background-color: #FFF;
    border-left: 1px solid #e9ecef;
    display: flex !important;
    flex-direction: column !important;
    padding: 0 !important;
  }

  /* La fila interna usa el alto completo del contenedor */
  .pos-container>.row.h-100 {
    margin: 0;
    flex: 1;
    min-height: 0;
    /* Permite que el contenido interno haga scroll */
  }

  /* Ambas columnas se comportan como columnas flex a altura completa */
  .pos-container>.row.h-100>.col-md-8,
  .pos-container>.row.h-100>.col-md-4.pos-cart-col {
    display: flex;
    flex-direction: column;
    min-height: 0;
  }

  /* ---- GRID DE PRODUCTOS (IZQUIERDA) ---- */
  .pos-container .pos-scrollable-grid-area {
    flex: 1 1 auto;
    /* ocupa el espacio libre entre el título y el footer gris */
    min-height: 0;
    overflow-y: auto;
    /* aparece scroll cuando haga falta */
  }

  /* ---- CARRITO (DERECHA) ---- */

  /* La LISTA del carrito es la que scrollea */
  .pos-container .pos-cart-col .pos-selected-list-area {
    flex: 1 1 auto;
    /* ocupa todo el espacio entre el título y el resumen */
    min-height: 0;
    overflow-y: auto;
    /* 👈 aquí aparece el scroll cuando hay muchos productos */
  }

  /* Subtotal, TOTAL y botones quedan pegados abajo y no se tapan */
  .pos-container .pos-cart-col .pos-summary,
  .pos-container .pos-cart-col .pos-actions {
    flex-shrink: 0;
    /* no se encogen ni desaparecen cuando la lista crece */
  }

  /* Scrollbar siempre visible para que el usuario sepa que hay más items */
  .pos-scrollable-grid-area::-webkit-scrollbar,
  .pos-selected-list-area::-webkit-scrollbar {
    width: 6px;
  }

  .pos-scrollable-grid-area::-webkit-scrollbar-thumb,
  .pos-selected-list-area::-webkit-scrollbar-thumb {
    background: #adb5bd;
    border-radius: 10px;
  }
}


/* Ajuste para que el buscador no se pegue a los bordes en móviles pequeños */
@media (max-width: 576px) {
  .bg-white.border-bottom.py-2 {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  #searchBar {
    font-size: 16px !important;
    /* Evita que iOS haga zoom automático al clickar */
  }
}

/* Mejora la apariencia del buscador para que sea una sola unidad sólida */
#searchBar:focus {
  background-color: #fff !important;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.1) !important;
  border: 1px solid #0d6efd !important;
}


/*COMPONENTE DE INPUT FILE*/
/* Contenedor general */
.componente-file {
  width: 100%;
}

/* Label que envuelve todo el control */
.componente-file-label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0.9rem;
  border-radius: 0.75rem;
  border: 1px solid var(--bs-border-color, #ced4da);
  background-color: #ffffff;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background-color 0.2s ease,
    transform 0.1s ease;
}

/* Ocultamos el input nativo */
.componente-file-input {
  display: none;
}

/* Botón de acción */
.componente-file-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 1rem;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 600;
  border: none;
  background: var(--bs-success, #198754);
  color: #ffffff;
  white-space: nowrap;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.09);
  transition:
    background-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.1s ease;
}

/* Texto del archivo */
.componente-file-text {
  flex: 1;
  font-size: 0.875rem;
  color: #495057;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Hover y focus dentro del componente */
.componente-file-label:hover {
  border-color: var(--bs-success, #198754);
  background-color: #f8fffb;
  box-shadow: 0 0 0 2px rgba(25, 135, 84, 0.12);
}

.componente-file-label:focus-within {
  border-color: var(--bs-primary, #0d6efd);
  box-shadow: 0 0 0 2px rgba(13, 110, 253, 0.25);
}

/* Efecto en el botón al hover */
.componente-file-label:hover .componente-file-btn {
  background: var(--bs-success-rgb, #157347);
  transform: translateY(-1px);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.12);
}

/* Versión "drag over" (se activa con JS opcional) */
.componente-file-label.componente-file-label--dragover {
  border-style: dashed;
  border-color: var(--bs-primary, #0d6efd);
  background-color: #f3f7ff;
}

/* Responsivo: en pantallas chicas, apila el botón y el texto */
@media (max-width: 576px) {
  .componente-file-label {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }

  .componente-file-text {
    width: 100%;
  }

  .componente-file-btn {
    width: 100%;
  }
}


/*SPLASH APP*/
/* Splash overlay (FORZADO para que no lo tumbe otro CSS) */
#app-splash{
  position: fixed !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;

  z-index: 99999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  background: #fff !important;
}


/* Elimina puntos de lista y ajusta márgenes */
#selectedItemsList {
    list-style: none;
    padding: 0;
}

/* Hace que el input de cantidad sea más discreto */
.pos-cart-item input[type="number"] {
    height: 30px;
    padding: 0 5px;
    border-radius: 4px;
    border: 1px solid #dee2e6;
    width: 45px !important;
}

/* Quita las flechas del input para ahorrar espacio (opcional) */
.pos-cart-item input::-webkit-outer-spin-button,
.pos-cart-item input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}