/* =============================================
   EXTRACTOR DE DATOS DNI - Estilos Principales
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* --- Variables Globales --- */
:root {
  --color-primario: #1A56DB;
  --color-primario-oscuro: #1240A8;
  --color-primario-claro: #EBF0FD;
  --color-exito: #0E9F6E;
  --color-exito-claro: #DEF7EC;
  --color-error: #E02424;
  --color-error-claro: #FDE8E8;
  --color-advertencia: #FF8A00;
  --color-advertencia-claro: #FFF3CD;
  --color-no-encontrado: #F59E0B;
  --color-no-encontrado-claro: #FEF3C7;

  --fondo-principal: #F8FAFC;
  --fondo-blanco: #FFFFFF;
  --fondo-gris-claro: #F1F5F9;

  --borde-color: #E2E8F0;
  --borde-radius-sm: 6px;
  --borde-radius-md: 10px;
  --borde-radius-lg: 14px;
  --borde-radius-xl: 20px;

  --texto-principal: #0F172A;
  --texto-secundario: #475569;
  --texto-terciario: #94A3B8;

  --sombra-sm: 0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --sombra-md: 0 4px 16px rgba(0,0,0,0.08);
  --sombra-lg: 0 10px 40px rgba(0,0,0,0.10);

  --fuente-principal: 'IBM Plex Sans', sans-serif;
  --fuente-mono: 'IBM Plex Mono', monospace;

  --transicion: 0.18s ease;
  --ancho-nav: 260px;
}

/* --- Reset & Base --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; scroll-behavior: smooth; }
body {
  font-family: var(--fuente-principal);
  background: var(--fondo-principal);
  color: var(--texto-principal);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }
button { cursor: pointer; font-family: var(--fuente-principal); }
input, select, textarea { font-family: var(--fuente-principal); }

/* --- Layout Principal --- */
.layout-principal {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* --- Barra de Navegación --- */
.navbar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--fondo-blanco);
  border-bottom: 1px solid var(--borde-color);
  padding: 0 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 58px;
  box-shadow: var(--sombra-sm);
}

.navbar-marca {
  display: flex;
  align-items: center;
  gap: 10px;
}
.navbar-icono {
  width: 36px; height: 36px;
  background: var(--color-primario);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: 17px;
}
.navbar-titulo { font-size: 0.95rem; font-weight: 700; color: var(--texto-principal); }
.navbar-subtitulo { font-size: 0.72rem; color: var(--texto-terciario); font-weight: 400; }

.navbar-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
}
.navbar-menu a {
  padding: 6px 14px;
  border-radius: var(--borde-radius-sm);
  font-size: 0.87rem;
  font-weight: 500;
  color: var(--texto-secundario);
  transition: all var(--transicion);
}
.navbar-menu a:hover { background: var(--fondo-gris-claro); color: var(--texto-principal); }
.navbar-menu a.activo {
  color: var(--color-primario);
  font-weight: 600;
  border-bottom: 2px solid var(--color-primario);
  border-radius: 0;
}

.navbar-usuario {
  display: flex; align-items: center; gap: 12px;
}
.btn-icono {
  width: 36px; height: 36px; border: none;
  background: transparent; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--texto-secundario); font-size: 17px;
  transition: background var(--transicion);
}
.btn-icono:hover { background: var(--fondo-gris-claro); }
.avatar-usuario {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--color-primario);
  color: white; font-size: 0.8rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.nombre-usuario { font-size: 0.85rem; font-weight: 500; }

/* --- Contenido Principal --- */
.contenido-principal {
  flex: 1;
  padding: 32px 28px;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

/* --- Tarjetas --- */
.tarjeta {
  background: var(--fondo-blanco);
  border: 1px solid var(--borde-color);
  border-radius: var(--borde-radius-lg);
  box-shadow: var(--sombra-sm);
}
.tarjeta-padding { padding: 24px; }

/* --- Botones --- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 18px; border: none; border-radius: var(--borde-radius-sm);
  font-size: 0.88rem; font-weight: 600;
  transition: all var(--transicion); cursor: pointer;
  white-space: nowrap;
}
.btn-primario {
  background: var(--color-primario); color: white;
}
.btn-primario:hover { background: var(--color-primario-oscuro); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(26,86,219,0.3); }
.btn-secundario {
  background: transparent; color: var(--texto-secundario);
  border: 1px solid var(--borde-color);
}
.btn-secundario:hover { background: var(--fondo-gris-claro); color: var(--texto-principal); }
.btn-exito { background: var(--color-exito); color: white; }
.btn-exito:hover { background: #0a8560; }
.btn-error { background: transparent; color: var(--color-error); border: 1.5px solid var(--color-error); }
.btn-error:hover { background: var(--color-error-claro); }
.btn-grande {
  padding: 13px 28px; font-size: 0.97rem;
  border-radius: var(--borde-radius-md);
  width: 100%; justify-content: center;
}
.btn-soft {
  background: var(--color-primario-claro);
  color: var(--color-primario);
  padding: 6px 14px;
  border-radius: var(--borde-radius-sm);
  font-size: 0.82rem;
  font-weight: 600;
  border: 1px solid transparent;
  transition: all var(--transicion);
}
.btn-soft:hover {
  background: var(--color-primario);
  color: white;
  transform: translateY(-1px);
}

/* --- Badges de Estado --- */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 99px; font-size: 0.78rem; font-weight: 600;
}
.badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; }
.badge-exito { background: var(--color-exito-claro); color: var(--color-exito); }
.badge-exito::before { background: var(--color-exito); }
.badge-error { background: var(--color-error-claro); color: var(--color-error); }
.badge-error::before { background: var(--color-error); }
.badge-proceso { background: #DBEAFE; color: #1D4ED8; }
.badge-proceso::before { background: #1D4ED8; }
.badge-revision { background: var(--color-advertencia-claro); color: var(--color-advertencia); }
.badge-revision::before { background: var(--color-advertencia); }
.badge-no-encontrado { background: var(--color-no-encontrado-claro); color: var(--color-no-encontrado); }
.badge-no-encontrado::before { background: var(--color-no-encontrado); }

/* --- Tablas --- */
.tabla-contenedor {
  overflow-x: auto;
  border-radius: var(--borde-radius-md);
}
.tabla {
  width: 100%; border-collapse: collapse;
  font-size: 0.875rem;
}
.tabla thead th {
  background: var(--fondo-gris-claro);
  padding: 10px 16px;
  text-align: left;
  font-size: 0.75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--texto-secundario);
  border-bottom: 1px solid var(--borde-color);
}
.tabla tbody tr {
  border-bottom: 1px solid var(--borde-color);
  transition: background var(--transicion);
}
.tabla tbody tr:last-child { border-bottom: none; }
.tabla tbody tr:hover { background: var(--fondo-gris-claro); }
.tabla tbody td { padding: 13px 16px; color: var(--texto-principal); }
.tabla .mono { font-family: var(--fuente-mono); font-size: 0.85rem; }

/* --- Inputs --- */
.input-campo {
  width: 100%; padding: 9px 14px;
  border: 1px solid var(--borde-color);
  border-radius: var(--borde-radius-sm);
  font-size: 0.88rem; color: var(--texto-principal);
  background: var(--fondo-blanco);
  transition: border-color var(--transicion), box-shadow var(--transicion);
}
.input-campo:focus {
  outline: none;
  border-color: var(--color-primario);
  box-shadow: 0 0 0 3px rgba(26,86,219,0.1);
}
.input-grupo {
  position: relative;
}
.input-grupo .icono-input {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--texto-terciario); pointer-events: none;
}
.input-grupo .input-campo { padding-left: 38px; }

/* --- Modales --- */
.modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15,23,42,0.5);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease;
}
.modal-overlay.activo { opacity: 1; pointer-events: all; }
.modal-contenido {
  background: var(--fondo-blanco);
  border-radius: var(--borde-radius-xl);
  padding: 32px;
  max-width: 500px; width: 90%;
  box-shadow: var(--sombra-lg);
  transform: scale(0.95);
  transition: transform 0.2s ease;
}
.modal-overlay.activo .modal-contenido { transform: scale(1); }

/* --- Notificaciones Toast --- */
.toast-contenedor {
  position: fixed; bottom: 24px; right: 24px; z-index: 2000;
  display: flex; flex-direction: column; gap: 10px;
}
.toast {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  background: var(--texto-principal); color: white;
  border-radius: var(--borde-radius-md);
  box-shadow: var(--sombra-lg);
  min-width: 280px; max-width: 380px;
  font-size: 0.88rem; font-weight: 500;
  animation: toastEntrar 0.25s ease;
}
.toast-exito { background: var(--color-exito); }
.toast-error { background: var(--color-error); }
.toast-info { background: var(--color-primario); }
@keyframes toastEntrar {
  from { transform: translateX(100px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

/* --- Utilidades --- */
.flex { display: flex; }
.flex-centro { display: flex; align-items: center; justify-content: center; }
.flex-entre { display: flex; align-items: center; justify-content: space-between; }
.gap-8 { gap: 8px; }
.gap-12 { gap: 12px; }
.gap-16 { gap: 16px; }
.gap-24 { gap: 24px; }
.mb-8 { margin-bottom: 8px; }
.mb-12 { margin-bottom: 12px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mb-32 { margin-bottom: 32px; }
.texto-secundario { color: var(--texto-secundario); }
.texto-terciario { color: var(--texto-terciario); }
.texto-exito { color: var(--color-exito); }
.texto-error { color: var(--color-error); }
.texto-primario { color: var(--color-primario); }
.texto-sm { font-size: 0.82rem; }
.texto-xs { font-size: 0.75rem; }
.peso-600 { font-weight: 600; }
.peso-700 { font-weight: 700; }
.oculto { display: none !important; }
.mono { font-family: var(--fuente-mono); }

/* --- Grid de Estadísticas --- */
.grid-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.stat-tarjeta {
  background: var(--fondo-blanco);
  border: 1px solid var(--borde-color);
  border-radius: var(--borde-radius-lg);
  padding: 20px;
  box-shadow: var(--sombra-sm);
}
.stat-icono {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 19px; margin-bottom: 12px;
}
.stat-icono-azul { background: var(--color-primario-claro); color: var(--color-primario); }
.stat-icono-verde { background: var(--color-exito-claro); color: var(--color-exito); }
.stat-icono-rojo { background: var(--color-error-claro); color: var(--color-error); }
.stat-icono-naranja { background: var(--color-no-encontrado-claro); color: var(--color-no-encontrado); }
.stat-icono-morado { background: #EDE9FE; color: #7C3AED; }
.stat-etiqueta { font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--texto-terciario); margin-bottom: 4px; }
.stat-valor { font-size: 1.7rem; font-weight: 700; color: var(--texto-principal); }
.stat-badge { font-size: 0.75rem; font-weight: 600; }

/* --- Barra de Progreso --- */
.barra-progreso-contenedor { background: var(--fondo-gris-claro); border-radius: 99px; height: 8px; overflow: hidden; }
.barra-progreso { height: 100%; border-radius: 99px; background: var(--color-primario); transition: width 0.4s ease; }
.barra-progreso-exito { background: var(--color-exito); }

/* --- Animación Pulse (procesando) --- */
@keyframes pulso { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }
.animacion-pulso { animation: pulso 1.5s ease-in-out infinite; }

/* --- Círculo de Progreso SVG --- */
.circulo-progreso-svg {
  transform: rotate(-90deg);
}
.circulo-progreso-fondo { fill: none; stroke: var(--borde-color); stroke-width: 10; }
.circulo-progreso-valor { fill: none; stroke: var(--color-primario); stroke-width: 10; stroke-linecap: round; transition: stroke-dashoffset 0.5s ease; }

/* --- Página Tablero --- */
.accesos-rapidos { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.acceso-item {
  border-radius: var(--borde-radius-lg);
  padding: 24px; cursor: pointer;
  transition: all var(--transicion);
  border: 1px solid var(--borde-color);
  background: none;
  font-family: inherit;
  font-size: inherit;
  text-align: left;
  width: 100%;
  outline: none;
}
.acceso-item:hover { transform: translateY(-2px); box-shadow: var(--sombra-md); }
.acceso-principal { background: var(--color-primario); color: white; border-color: var(--color-primario); }
.acceso-principal .acceso-desc { color: rgba(255,255,255,0.8); }
.acceso-secundario { background: var(--fondo-blanco); }
.acceso-icono {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; margin-bottom: 14px;
}
.acceso-principal .acceso-icono { background: rgba(255,255,255,0.2); color: white; }
.acceso-secundario .acceso-icono { background: var(--color-primario-claro); color: var(--color-primario); }
.acceso-titulo { font-size: 1.05rem; font-weight: 700; margin-bottom: 6px; }
.acceso-desc { font-size: 0.85rem; color: var(--texto-secundario); margin-bottom: 14px; }
.acceso-link { font-size: 0.85rem; font-weight: 600; display: flex; align-items: center; gap: 6px; }
.acceso-principal .acceso-link { color: white; }
.acceso-secundario .acceso-link { color: var(--color-primario); }

/* --- Zona de Carga de Archivos --- */
.zona-carga {
  border: 2px dashed var(--borde-color);
  border-radius: var(--borde-radius-lg);
  padding: 36px 24px;
  text-align: center;
  cursor: pointer;
  transition: all var(--transicion);
  background: var(--fondo-blanco);
}
.zona-carga:hover, .zona-carga.arrastre-sobre {
  border-color: var(--color-primario);
  background: var(--color-primario-claro);
}
.zona-carga-icono { font-size: 2rem; color: var(--color-primario); margin-bottom: 10px; }
.zona-carga-texto { font-size: 0.9rem; color: var(--texto-secundario); }
.zona-carga-texto strong { color: var(--color-primario); cursor: pointer; }
.zona-carga-subtext { font-size: 0.78rem; color: var(--texto-terciario); margin-top: 6px; }

/* --- Puntos de Datos --- */
.punto-datos-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 0; border-bottom: 1px solid var(--borde-color);
}
.punto-datos-item:last-child { border-bottom: none; }
.punto-datos-info { display: flex; align-items: center; gap: 10px; }
.punto-datos-icono { font-size: 1.1rem; color: var(--texto-terciario); }
.punto-datos-nombre { font-size: 0.88rem; font-weight: 600; }
.punto-datos-desc { font-size: 0.77rem; color: var(--texto-terciario); }

/* Checkbox custom */
.checkbox-custom {
  width: 18px; height: 18px; border-radius: 4px;
  border: 2px solid var(--borde-color);
  cursor: pointer; appearance: none; background: white;
  transition: all var(--transicion);
  flex-shrink: 0;
}
.checkbox-custom:checked {
  background: var(--color-primario);
  border-color: var(--color-primario);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center; background-size: 11px;
}

/* --- Confianza Bar --- */
.confianza-contenedor { display: flex; align-items: center; gap: 8px; }
.confianza-barra { width: 70px; height: 6px; background: var(--fondo-gris-claro); border-radius: 99px; overflow: hidden; }
.confianza-fill { height: 100%; border-radius: 99px; }
.confianza-alta { background: var(--color-exito); }
.confianza-media { background: var(--color-advertencia); }
.confianza-baja { background: var(--color-error); }
.confianza-texto { font-size: 0.82rem; font-weight: 600; }

/* --- Paginación --- */
.paginacion {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-top: 1px solid var(--borde-color);
  font-size: 0.82rem; color: var(--texto-secundario);
}
.paginacion-botones { display: flex; gap: 6px; }
.btn-pag {
  width: 32px; height: 32px; border-radius: var(--borde-radius-sm);
  border: 1px solid var(--borde-color); background: var(--fondo-blanco);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem; color: var(--texto-secundario); cursor: pointer;
  transition: all var(--transicion);
}
.btn-pag:hover:not(:disabled) { background: var(--color-primario-claro); color: var(--color-primario); border-color: var(--color-primario); }
.btn-pag:disabled { opacity: 0.4; cursor: not-allowed; }

/* --- Log de Actividad (Procesamiento) --- */
.log-entrada {
  display: grid;
  grid-template-columns: 40px 130px 1fr 140px 1fr 1fr;
  gap: 8px; align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--borde-color);
  font-size: 0.85rem;
  transition: background var(--transicion);
}
.log-entrada:hover { background: var(--fondo-gris-claro); }
.log-entrada.procesando { background: #EFF6FF; border-left: 3px solid var(--color-primario); }
.log-icono-estado { font-size: 1.1rem; display: flex; justify-content: center; }

/* --- Historial --- */
.filtro-barra {
  display: flex; align-items: center; gap: 12px;
  padding: 16px; border-bottom: 1px solid var(--borde-color);
  flex-wrap: wrap;
}

/* --- Donut Chart --- */
.donut-contenedor { position: relative; display: inline-block; }
.donut-centro {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
}

/* --- API Keys --- */
.api-key-campo {
  font-family: var(--fuente-mono);
  background: var(--fondo-gris-claro);
  padding: 10px 14px;
  border-radius: var(--borde-radius-sm);
  font-size: 0.82rem;
  color: var(--texto-secundario);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* --- Página de Facturación --- */
.plan-card {
  border: 2px solid var(--borde-color);
  border-radius: var(--borde-radius-lg);
  padding: 24px;
  transition: all var(--transicion);
}
.plan-card.activo { border-color: var(--color-primario); background: var(--color-primario-claro); }
.plan-card:hover:not(.activo) { border-color: var(--texto-terciario); }

/* --- Scrollbar personalizado --- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--borde-color); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--texto-terciario); }

/* --- Responsivo --- */
@media (max-width: 768px) {
  .navbar { padding: 0 16px; }
  .contenido-principal { padding: 16px; }
  .navbar-menu { display: none; }
  .accesos-rapidos { grid-template-columns: 1fr; }
  .grid-stats { grid-template-columns: 1fr 1fr; }
  .log-entrada { grid-template-columns: 30px 1fr 1fr; }
  .log-entrada > *:nth-child(n+4) { display: none; }
}