/* ---------- Paleta "Quiet Cry" ---------- */
:root {
  --azul: #4f6d8c;          /* azul acero: botones / activos */
  --azul-oscuro: #2d3142;   /* navy oscuro: titulos, logo */
  --fondo: #e9edf3;         /* fondo claro */
  --blanco: #ffffff;        /* tarjetas */
  --texto: #2d3142;
  --gris: #5e6675;
  --borde: #d6dce6;
  --verde: #3f9e8c;         /* menta/teal: positivo */
  --rojo: #c1565a;          /* rojo apagado */
  --ambar: #c08a3e;
  --sombra: 0 2px 10px rgba(45, 49, 66, 0.10);
  --menta: #a8d8cc;         /* menta clara: acentos suaves */
}

/* ---------- Modo oscuro (se activa con <html data-tema="oscuro">) ---------- */
:root[data-tema="oscuro"] {
  --azul: #4f7cff;
  --azul-oscuro: #aebfff;
  --fondo: #0e1320;
  --blanco: #1b2233;
  --texto: #e7eaf3;
  --gris: #9aa4ba;
  --borde: #2c3447;
  --sombra: 0 2px 10px rgba(0, 0, 0, 0.45);
}
:root[data-tema="oscuro"] .boton:hover { background: #3a63e0; }
:root[data-tema="oscuro"] th,
:root[data-tema="oscuro"] .acordeon-cabecera:hover,
:root[data-tema="oscuro"] .barra-resumen .tarjeta-resumen,
:root[data-tema="oscuro"] .tabla-detalle-cobro th,
:root[data-tema="oscuro"] .tabla-pago th,
:root[data-tema="oscuro"] .tarjetas-resumen.en-linea .tarjeta-resumen,
:root[data-tema="oscuro"] .fila-total { background: #232c40; }
:root[data-tema="oscuro"] input,
:root[data-tema="oscuro"] select,
:root[data-tema="oscuro"] textarea { background: #141a28; color: var(--texto); border-color: var(--borde); }
:root[data-tema="oscuro"] .boton.secundario { background: #2a3346; color: var(--texto); }
:root[data-tema="oscuro"] .boton.secundario:hover { background: #333d54; }

* { box-sizing: border-box; margin: 0; padding: 0; }

/* Escala general del programa: reduce un poco el tamaño de todo para que no se
   vea tan grande (como con mucho zoom) y quede en un tamaño mediano. Afecta a
   todas las pantallas porque todas usan esta hoja de estilos. */
html { zoom: 0.85; }

body {
  font-family: "Segoe UI", Arial, sans-serif;
  background: var(--fondo);
  color: var(--texto);
  min-height: 100vh;
}

/* ---------- Logo ---------- */
.logo { display: flex; align-items: center; gap: 10px; }
.logo img { height: 38px; }
.logo .logo-texto { font-size: 22px; font-weight: 700; letter-spacing: 2px; color: var(--azul-oscuro); }
.logo .logo-sub { font-size: 13px; color: var(--gris); font-weight: 600; }

/* ---------- Pantallas de login ---------- */
.pantalla-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #16244f 0%, #1f4fd8 100%);
  padding: 20px;
}
.tarjeta-login {
  background: var(--blanco);
  border-radius: 14px;
  padding: 36px 32px;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
  text-align: center;
}
.tarjeta-login .logo { justify-content: center; margin-bottom: 8px; }
.tarjeta-login h1 { font-size: 20px; margin: 8px 0 2px; color: var(--azul-oscuro); }
.tarjeta-login p.detalle { color: var(--gris); font-size: 13px; margin-bottom: 22px; }

.campo { text-align: left; margin-bottom: 14px; }
.campo label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 5px; color: var(--texto); }
.campo input, .campo select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--borde);
  border-radius: 8px;
  font-size: 14px;
  background: var(--blanco);
}
.campo input:focus, .campo select:focus { outline: 2px solid var(--azul); border-color: transparent; }

.boton {
  display: inline-block;
  background: var(--azul);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 11px 18px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
  text-decoration: none;
}
.boton:hover { background: var(--azul-oscuro); }
.boton.secundario { background: #e6ebf2; color: var(--azul-oscuro); }
.boton.secundario:hover { background: #d8dfe9; }
.boton.peligro { background: var(--rojo); }
.boton.chico { width: auto; padding: 7px 12px; font-size: 13px; }

.enlace-alterno { display: block; margin-top: 18px; font-size: 13px; color: var(--gris); }
.enlace-alterno a { color: var(--azul); font-weight: 600; text-decoration: none; }

.mensaje-error { color: var(--rojo); font-size: 13px; margin-top: 10px; min-height: 18px; }

/* ---------- Portal de entrada ---------- */
.portal-opciones { display: flex; gap: 18px; flex-wrap: wrap; justify-content: center; }
.portal-opcion {
  background: var(--blanco);
  border-radius: 14px;
  padding: 30px 26px;
  width: 290px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
  text-align: center;
  text-decoration: none;
  color: var(--texto);
  transition: transform .15s;
}
.portal-opcion:hover { transform: translateY(-4px); }
.portal-opcion .num { font-size: 12px; font-weight: 700; color: var(--azul); letter-spacing: 1px; }
.portal-opcion h2 { font-size: 18px; margin: 6px 0; color: var(--azul-oscuro); }
.portal-opcion p { font-size: 13px; color: var(--gris); }

/* ---------- Estructura general de paneles ---------- */
.encabezado {
  background: var(--blanco);
  border-bottom: 1px solid var(--borde);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 22px;
  position: sticky;
  top: 0;
  z-index: 10;
}
.encabezado .derecha { display: flex; align-items: center; gap: 18px; }
.fecha-hora { text-align: right; }
.fecha-hora .hora { font-size: 18px; font-weight: 700; color: var(--azul-oscuro); }
.fecha-hora .fecha { font-size: 12px; color: var(--gris); text-transform: capitalize; }
.usuario-actual { text-align: right; border-left: 1px solid var(--borde); padding-left: 18px; }
.usuario-actual .nombre { font-weight: 700; font-size: 14px; }
.usuario-actual .perfil { font-size: 11px; color: var(--gris); letter-spacing: .5px; }

.disposicion { display: flex; min-height: calc(100vh - 63px); }

/* ---------- Menu lateral ---------- */
.menu-lateral {
  width: 230px;
  background: var(--blanco);
  border-right: 1px solid var(--borde);
  padding: 18px 12px;
  flex-shrink: 0;
}
.menu-lateral .titulo-menu { font-size: 11px; font-weight: 700; color: var(--gris); letter-spacing: 1px; margin: 14px 10px 6px; }
.menu-lateral button, .menu-lateral a {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 11px 12px;
  margin-bottom: 4px;
  background: none;
  border: none;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--texto);
  cursor: pointer;
  text-align: left;
  text-decoration: none;
}
.menu-lateral button:hover { background: #e6ebf2; }
.menu-lateral button.activo { background: var(--azul); color: #fff; }

.contenido { flex: 1; padding: 24px; overflow-x: auto; }
.contenido h2 { font-size: 20px; color: var(--azul-oscuro); margin-bottom: 16px; }

/* ---------- Tarjetas resumen ---------- */
.tarjetas-resumen { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 20px; }
.tarjeta-resumen {
  background: var(--blanco);
  border: 1px solid var(--borde);
  border-radius: 12px;
  padding: 16px 20px;
  min-width: 170px;
  box-shadow: var(--sombra);
}
.tarjeta-resumen .valor { font-size: 26px; font-weight: 700; color: var(--azul-oscuro); }
.tarjeta-resumen .etiqueta { font-size: 12px; color: var(--gris); font-weight: 600; }
.tarjeta-resumen.activas .valor { color: var(--verde); }
.tarjeta-resumen.bloqueadas .valor { color: var(--rojo); }
/* Variante "en línea": tarjetas más bajitas y estiradas a lo largo, con el
   número y la etiqueta en la misma línea (usada en la plataforma). */
.tarjetas-resumen.en-linea .tarjeta-resumen {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  min-width: 0;
}
.tarjetas-resumen.en-linea .tarjeta-resumen .valor { font-size: 20px; line-height: 1; }
.tarjetas-resumen.en-linea .tarjeta-resumen .etiqueta { font-size: 12px; white-space: nowrap; }

/* Barra de resumen: selector de operador a la izquierda, contadores a la derecha */
.barra-resumen {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  background: var(--blanco);
  border: 1px solid var(--borde);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 20px;
  box-shadow: var(--sombra);
}
.barra-resumen .tarjetas-resumen { margin-bottom: 0; }
.barra-resumen .tarjeta-resumen { box-shadow: none; background: #edf0f5; min-width: 150px; padding: 12px 16px; }
/* Modo operador: nombre grande a la IZQUIERDA, selector a la DERECHA y las
   tarjetas en una fila debajo. */
.nombre-operador-grande { font-size: 34px; font-weight: 800; color: var(--azul-oscuro); line-height: 1.1; }
.barra-resumen.modo-operador { align-items: center; }
.barra-resumen.modo-operador #contenedorSelOperador { margin-left: auto; order: 1; }
.barra-resumen.modo-operador #nombreOperadorGrande { order: 0; }
.barra-resumen.modo-operador .tarjetas-resumen { flex-basis: 100%; order: 2; }
/* Tarjetas en fila, bajitas y estiradas: numero y etiqueta en la misma linea */
.barra-resumen.modo-operador .tarjetas-resumen { flex-direction: row; flex-wrap: wrap; align-items: stretch; gap: 10px; }
.barra-resumen.modo-operador .tarjeta-resumen {
  display: flex; flex-direction: row; align-items: center; gap: 10px;
  min-width: 180px; padding: 8px 16px;
}
.barra-resumen.modo-operador .tarjeta-resumen .valor { font-size: 20px; line-height: 1; }
.barra-resumen.modo-operador .tarjeta-resumen .etiqueta { white-space: nowrap; }
.selector-operador label { display: block; font-size: 11px; font-weight: 700; color: var(--gris); letter-spacing: 1px; margin-bottom: 5px; }
.selector-operador select {
  padding: 10px 12px;
  border: 1px solid var(--borde);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  min-width: 220px;
  background: var(--blanco);
  color: var(--texto);
}
.selector-operador select:focus { outline: 2px solid var(--azul); border-color: transparent; }

/* Tarjetas que funcionan como botones */
.tarjeta-resumen.clic { cursor: pointer; transition: transform .12s, box-shadow .12s; }
.tarjeta-resumen.clic:hover { transform: translateY(-3px); box-shadow: 0 8px 18px rgba(20, 48, 126, 0.18); border-color: var(--azul); }

/* ---------- Cobranza del día: lista desplegable (acordeón) ---------- */
.lista-acordeon { display: flex; flex-direction: column; gap: 8px; }
.acordeon-item { border: 1px solid var(--borde); border-radius: 10px; background: var(--blanco); box-shadow: var(--sombra); overflow: hidden; }
.acordeon-cabecera {
  display: flex; justify-content: space-between; align-items: center;
  padding: 13px 18px; cursor: pointer; user-select: none;
  font-size: 14px; color: var(--azul-oscuro);
}
.acordeon-cabecera:hover { background: #edf0f5; }
.acordeon-cabecera .flecha { color: var(--verde); font-size: 13px; transition: transform .18s; }
.acordeon-item.abierto .acordeon-cabecera .flecha { transform: rotate(180deg); }
.etiqueta-atrasada { display: inline-block; margin-left: 8px; padding: 1px 8px; border-radius: 10px; background: #fdecec; color: var(--rojo); font-size: 11px; font-weight: 700; vertical-align: middle; }
.acordeon-cuerpo { padding: 4px 18px 16px; border-top: 1px solid var(--borde); }
.acordeon-acciones { text-align: right; margin-top: 6px; display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 8px; }
.acordeon-acciones .boton { width: auto; min-width: 150px; }
.tabla-detalle-cobro { width: 100%; border-collapse: collapse; margin: 12px 0 6px; }
.tabla-detalle-cobro th, .tabla-detalle-cobro td { border: 1px solid var(--borde); padding: 9px 12px; text-align: left; font-size: 13px; }
.tabla-detalle-cobro th { background: #edf0f5; color: var(--gris); font-weight: 700; font-size: 11px; letter-spacing: .4px; }

/* ---------- Pantalla de pago ---------- */
.tabla-pago th { background: #edf0f5; color: var(--gris); font-size: 11px; letter-spacing: .4px; width: 1%; white-space: nowrap; }
.tabla-pago td { font-size: 14px; }
.campo-valor-cuota { width: 140px; padding: 9px 12px; border: 2px solid var(--azul); border-radius: 8px; font-size: 16px; font-weight: 700; color: var(--azul-oscuro); }
.campo-valor-cuota:focus { outline: 2px solid var(--azul); border-color: transparent; }
.nota-pago { font-size: 12.5px; color: var(--gris); margin: 0 0 12px; }

/* Campo de contraseña con boton de ver/ocultar */
.campo-clave { position: relative; }
.campo-clave input { padding-right: 44px; }
.boton-ver-clave {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; font-size: 17px;
  color: var(--gris); padding: 4px 6px; line-height: 1;
}
.boton-ver-clave:hover { color: var(--azul); }

/* ---------- Tablas ---------- */
.tabla-contenedor { background: var(--blanco); border: 1px solid var(--borde); border-radius: 12px; overflow: auto; box-shadow: var(--sombra); }
table { width: 100%; border-collapse: collapse; font-size: 14px; }
th { background: #edf0f5; text-align: left; padding: 11px 14px; font-size: 12px; letter-spacing: .5px; color: var(--gris); border-bottom: 1px solid var(--borde); }
td { padding: 11px 14px; border-bottom: 1px solid var(--borde); }
tr:last-child td { border-bottom: none; }

.insignia { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: 11px; font-weight: 700; }
.insignia.activa { background: #e7f6ec; color: var(--verde); }
.insignia.bloqueada { background: #fdecec; color: var(--rojo); }
.insignia.perfil { background: #e6ebf2; color: var(--azul-oscuro); }
.insignia.super { background: var(--azul-oscuro); color: #fff; }

/* ---------- Barra de acciones ---------- */
.barra-acciones { display: flex; gap: 10px; align-items: center; margin-bottom: 16px; flex-wrap: wrap; }
.barra-acciones input[type="text"], .barra-acciones input[type="search"] {
  padding: 9px 12px; border: 1px solid var(--borde); border-radius: 8px; font-size: 14px; min-width: 230px; background: var(--blanco);
}

/* ---------- Pestañas del panel de sociedad ---------- */
.pestanas { display: flex; gap: 6px; flex-wrap: wrap; border-bottom: 2px solid var(--borde); margin-bottom: 18px; }
.pestanas button {
  background: none; border: none; padding: 10px 16px; font-size: 14px; font-weight: 600;
  color: var(--gris); cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px;
}
.pestanas button.activo { color: var(--azul); border-bottom-color: var(--azul); }
.subpestanas { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.subpestanas button {
  background: var(--blanco); border: 1px solid var(--borde); border-radius: 99px;
  padding: 7px 16px; font-size: 13px; font-weight: 600; color: var(--gris); cursor: pointer;
}
.subpestanas button.activo { background: var(--azul); border-color: var(--azul); color: #fff; }
/* Número (contador) integrado dentro de cada botón de filtro */
.subpestanas button .conteo-sub {
  display: inline-block; min-width: 18px; margin-left: 6px; padding: 1px 7px;
  border-radius: 99px; background: var(--borde); color: var(--azul-oscuro);
  font-size: 12px; font-weight: 800; text-align: center;
}
.subpestanas button.activo .conteo-sub { background: rgba(255, 255, 255, 0.25); color: #fff; }
/* Flecha que despliega los datos del cliente */
.flecha-detalle {
  background: var(--blanco); border: 1px solid var(--borde); color: var(--azul-oscuro);
  border-radius: 8px; padding: 4px 9px; font-size: 12px; cursor: pointer;
  line-height: 1; transition: transform 0.15s ease, background 0.15s ease;
}
.flecha-detalle:hover { background: #eef2ff; }
.flecha-detalle.abierta { transform: rotate(180deg); background: var(--azul); color: #fff; border-color: var(--azul); }
/* Panel de datos relevantes del cliente (rejilla) */
.fila-detalle-cliente > td { background: #f0fdf4; padding: 0; }
.detalle-cliente {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1px; background: #bbf7d0; border: 1px solid #bbf7d0; margin: 8px;
}
.detalle-cliente .dc-celda { background: #f0fdf4; padding: 9px 12px; display: flex; flex-direction: column; gap: 3px; }
.detalle-cliente .dc-etiqueta { font-size: 11px; font-weight: 700; color: #15803d; letter-spacing: 0.02em; }
.detalle-cliente .dc-valor { font-size: 14px; font-weight: 600; color: var(--azul-oscuro); }

/* Letrero de aviso (por ejemplo, cliente que ya tiene un crédito hábil) */
.letrero-aviso {
  background: #fff7ed; border: 1px solid #fdba74; color: #9a3412;
  border-radius: 10px; padding: 14px 16px; margin: 6px 0 16px;
  font-size: 14px; font-weight: 600; line-height: 1.5;
}

/* ---------- Ventanas modales ---------- */
.fondo-modal {
  position: fixed; inset: 0; background: rgba(15, 23, 42, 0.55);
  display: none; align-items: center; justify-content: center; z-index: 50; padding: 20px;
}
.fondo-modal.visible { display: flex; }
.modal {
  background: var(--blanco); border-radius: 14px; padding: 26px; width: 100%; max-width: 430px;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.modal h3 { color: var(--azul-oscuro); margin-bottom: 16px; font-size: 17px; }
.modal .acciones-modal { display: flex; gap: 10px; margin-top: 18px; }
.modal textarea {
  width: 100%; min-height: 70px; padding: 10px 12px; border: 1px solid var(--borde);
  border-radius: 8px; font-size: 14px; font-family: inherit; resize: vertical;
}

.clave-generada {
  background: #f0fdf4; border: 1px dashed var(--verde); border-radius: 10px;
  padding: 14px; text-align: center; margin: 12px 0;
}
.clave-generada .clave { font-size: 24px; font-weight: 700; letter-spacing: 3px; color: var(--verde); font-family: Consolas, monospace; }
.clave-generada p { font-size: 12px; color: var(--gris); margin-top: 6px; }

.vacio { text-align: center; color: var(--gris); padding: 40px 20px; font-size: 14px; }

.nota-permiso { background: #fff7ed; border: 1px solid #fed7aa; color: var(--ambar); border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 16px; }

/* Modal amplio para formularios grandes (creditos, reparcelado, etc.) */
.modal-amplio { max-width: 560px; max-height: 90vh; overflow-y: auto; }
/* Modal ancho (ej. reparcelar): la informacion se ve completa sin scroll lateral */
.modal-ancho { max-width: 880px; width: 94vw; }
.fila-campos { display: flex; gap: 12px; }
.fila-campos .campo { flex: 1; }

/* Tipo de pago MUY visible en cada cliente */
.insignia.pago-SEMANAL { background: #e0f2fe; color: #0369a1; }
.insignia.pago-QUINCENAL { background: #fef9c3; color: #a16207; }
.insignia.pago-MENSUAL { background: #fce7f3; color: #be185d; }
.insignia.grande { font-size: 13px; padding: 5px 12px; }

/* Foto del cliente en las tablas */
.foto-cliente { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; border: 2px solid var(--borde); }
.sin-foto {
  display: inline-block; background: #fdecec; color: var(--rojo); border: 1px dashed var(--rojo);
  border-radius: 6px; padding: 3px 7px; font-size: 10px; font-weight: 700;
}

/* Fila de totales en las tablas */
tr.fila-total td { background: #f0f4ff; font-weight: 700; color: var(--azul-oscuro); border-top: 2px solid var(--azul); }

/* Mensajes grandes despues de pagar */
.resultado-pago { text-align: center; padding: 22px 10px; }
.resultado-pago .icono { font-size: 46px; }
.resultado-pago h3 { margin: 10px 0 6px; }
.resultado-pago.saldada h3 { color: var(--verde); }
.resultado-pago p { color: var(--gris); font-size: 14px; }

/* Banner de auditorias recibidas (operador) */
.banner-auditoria { background: #eef4ff; border: 1px solid #c7d8ff; border-radius: 10px; padding: 12px 16px; margin-bottom: 14px; font-size: 13px; }
.banner-auditoria strong { color: var(--azul-oscuro); }

/* Campana de notificaciones (encabezado) */
.campana-notif { position: relative; }
.boton-campana {
  position: relative; background: var(--blanco); border: 1px solid var(--borde);
  border-radius: 10px; padding: 7px 11px; font-size: 16px; line-height: 1; cursor: pointer;
}
.boton-campana:hover { background: #eef2ff; }
.punto-notif {
  position: absolute; top: -4px; right: -4px; width: 11px; height: 11px;
  background: var(--rojo); border-radius: 50%; border: 2px solid #fff;
}
.panel-notif {
  position: absolute; right: 0; top: calc(100% + 8px); width: 330px; max-height: 60vh;
  overflow-y: auto; background: #fff; border: 1px solid var(--borde); border-radius: 12px;
  box-shadow: 0 10px 30px rgba(20, 48, 126, 0.18); z-index: 200; padding: 8px;
}
.notif-titulo { font-size: 11px; font-weight: 700; color: var(--gris); letter-spacing: 1px; padding: 6px 8px; }
.notif-item { background: #eef4ff; border: 1px solid #c7d8ff; border-radius: 10px; padding: 10px; margin: 6px; }
.notif-fecha { font-weight: 700; color: var(--azul-oscuro); font-size: 13px; margin-bottom: 4px; }
.notif-texto { font-size: 13px; margin-bottom: 8px; line-height: 1.4; }
.notif-vacia { padding: 18px; text-align: center; color: var(--gris); font-size: 13px; }

/* Tabla de cobros generada del credito */
.tabla-cobros-marco { border: 2px solid var(--azul-oscuro); border-radius: 10px; overflow: hidden; margin-top: 12px; }
.tabla-cobros-marco .cabecera-cobros { background: var(--azul-oscuro); color: #fff; padding: 10px 14px; font-weight: 700; font-size: 14px; }
.tabla-cobros-marco input[type="date"] { border: 1px solid var(--borde); border-radius: 6px; padding: 4px 6px; font-size: 13px; }

/* Tarjetas pequeñas de contadores por interfaz */
.mini-contadores { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.mini-contadores span { background: var(--blanco); border: 1px solid var(--borde); border-radius: 99px; padding: 6px 14px; font-size: 12px; font-weight: 700; color: var(--gris); }
.mini-contadores b { color: var(--azul-oscuro); }
