:root{
  /* Marca */
  --azul:#5B67D6; --azul-osc:#3342CC; --azul-pressed:#2B37AB;
  --accent:#8B34E7; --accent-soft:#F6F0FD;
  /* Superficies */
  --gris:#F2F3F8; --header:#2D2E3D; --header-active:#3A3B4D; --input-bg:#EAF0FD;
  /* Bordes */
  --borde:#E3E3E8; --borde-strong:#CDCEDA; --borde-focus:#5B67D6;
  /* Texto */
  --texto:#1F2230; --suave:#575975; --muted:#9B9DB5;
  /* Estados */
  --verde:#167E54; --verde-soft:#E9F7F0; --verde-dark:#115F40;
  --aviso:#E0A21A; --aviso-soft:#FBE7B4;
  --rojo:#C23535; --rojo-soft:#FBEAEA;
  --info:#2E7DB8; --info-soft:#E8F2FA;
  /* Alias */
  --primario:#5B67D6;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--texto);background:var(--gris)}
a{color:#3342CC;text-decoration:none}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:#fff;padding:36px;border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.08);
  width:100%;max-width:380px}
.login-card h1{font-size:20px;margin:0 0 6px}
.login-card .sub{color:var(--suave);font-size:14px;margin:0 0 22px}
.login-card label{display:block;font-size:13px;font-weight:600;margin-bottom:14px}
.login-card input{width:100%;margin-top:6px;padding:11px;border:1px solid var(--borde);
  border-radius:8px;font-size:14px;background:var(--input-bg);color:var(--texto)}
.login-card input::placeholder{color:var(--muted)}
.login-card input:focus{outline:2px solid var(--borde-focus);outline-offset:0}
.login-card button{width:100%;margin-top:8px}
.alert{background:var(--rojo-soft);color:var(--rojo);padding:10px 12px;border-radius:8px;
  font-size:13px;margin-bottom:16px}

/* ---------- Botones ---------- */
button,.btn{display:inline-block;background:var(--azul);color:#fff;border:none;
  padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
button:hover,.btn:hover{background:var(--azul-osc)}
button:active,.btn:active{background:var(--azul-pressed)}
.btn.ghost{background:transparent;color:#3342CC;border:1px solid var(--azul)}
.topbar .btn.ghost{color:#fff;border-color:rgba(255,255,255,.45)}
.topbar .btn.ghost:hover{background:rgba(255,255,255,.15)}
.btn.ghost:hover{background:#F1F2FB}
.btn.small{padding:6px 12px;font-size:12px}
.btn.primary{background:var(--verde)}
.btn.primary:hover{background:#0f5c3c}

/* ---------- Topbar ---------- */
.topbar{background:var(--header);color:#fff;display:flex;justify-content:space-between;
  align-items:center;padding:14px 24px}
.brand{font-weight:700;font-size:17px}
.user-box{display:flex;align-items:center;gap:14px;font-size:14px}
.role{font-style:normal;font-size:11px;padding:2px 8px;border-radius:20px;margin-left:6px}
.role-admin{background:#FBE7B4;color:#633806}
.role-usuario{background:#E3E5F7;color:#232D8B}

/* ---------- Contenedor ---------- */
.container{max-width:1180px;margin:24px auto;padding:0 20px}

/* ---------- Filtros ---------- */
.filtros{background:#fff;border:1px solid var(--borde);border-radius:12px;padding:16px;
  display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}
.field{display:flex;flex-direction:column;font-size:12px;font-weight:600;color:var(--suave)}
.field.grow{flex:1;min-width:200px}
.field select,.field input{margin-top:5px;padding:9px;border:1px solid var(--borde);
  border-radius:8px;font-size:14px;color:var(--texto);background:var(--input-bg)}
.field select:focus,.field input:focus{outline:2px solid var(--borde-focus);outline-offset:0}
.field.actions{flex-direction:row;gap:8px;align-items:center}

/* Multi-select personalizado */
.multi-select{position:relative;margin-top:5px}
.ms-trigger{display:flex;justify-content:space-between;align-items:center;
  padding:9px;border:1px solid var(--borde);border-radius:8px;font-size:14px;
  color:var(--texto);background:var(--input-bg);cursor:pointer;min-width:160px;user-select:none}
.ms-trigger:hover{border-color:#aaa}
.ms-arrow{font-size:11px;color:var(--suave);margin-left:8px}
.ms-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;
  background:#fff;border:1px solid var(--borde);border-radius:8px;
  z-index:200;min-width:220px;max-height:220px;overflow-y:auto;
  box-shadow:0 4px 12px rgba(0,0,0,.1)}
.ms-dropdown.open{display:block}
.ms-option{display:flex;align-items:center;gap:8px;padding:8px 12px;
  font-size:13px;font-weight:400;color:var(--texto);cursor:pointer}
.ms-option:hover{background:var(--gris)}
.ms-option input{width:15px;height:15px;cursor:pointer;accent-color:var(--primario)}

.resumen{display:flex;gap:24px;margin:18px 4px 10px;font-size:14px;color:var(--suave)}
.resumen strong{color:var(--texto)}

/* ---------- Barra masiva ---------- */
.bulk-bar{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--borde);
  border-radius:10px;padding:12px 16px;margin-bottom:10px;flex-wrap:wrap}
.check-all{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.hint{font-size:12px;color:var(--suave)}
.resultado-badge{display:flex;align-items:center;gap:6px;background:#E3E5F7;
  border-radius:8px;padding:6px 12px;font-size:13px;white-space:nowrap}
.resultado-num{font-size:18px;font-weight:800;color:#232D8B;line-height:1}
.resultado-label{font-weight:600;color:#232D8B}
.resultado-sep{color:var(--suave)}
.resultado-monto{font-weight:700;color:var(--texto)}
.bulk-opciones{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.bulk-radio{font-size:13px;font-weight:600;display:flex;align-items:center;gap:5px;cursor:pointer}
.acciones-recibo{white-space:nowrap;display:flex;gap:4px;align-items:center}

/* ---------- Tabla ---------- */
.grid{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--borde);
  border-radius:10px;overflow:hidden;font-size:14px}
.grid th,.grid td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--borde)}
.grid th{background:var(--gris);font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:#575975}
.grid tbody tr:hover{background:#F1F2FB}
.grid .num{text-align:right;font-variant-numeric:tabular-nums}
.grid .empty{text-align:center;color:var(--suave);padding:30px}

.tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;background:#eef1f5;color:#445}
.tag-ordinario{background:#E9F7F0;color:#115F40}
.tag-finiquito{background:#FBEAEA;color:#C23535}
.tag-aguinaldo{background:#FBE7B4;color:#633806}
.tag-bono{background:#E3E5F7;color:#232D8B}
.tag-ptu{background:#F6F0FD;color:#6917C0}

/* ---------- Admin ---------- */
.admin-badge{font-size:11px;font-weight:700;background:#FBE7B4;color:#633806;
  padding:2px 8px;border-radius:20px;margin-left:10px;vertical-align:middle}
.topbar-nav{display:flex;align-items:center;gap:4px;flex:1;margin-left:24px}
.nav-link{color:rgba(255,255,255,.75);font-size:14px;font-weight:600;padding:6px 14px;
  border-radius:8px;transition:background .15s}
.nav-link:hover{background:rgba(255,255,255,.12);color:#fff}
.nav-link.active{background:rgba(255,255,255,.18);color:#fff}

.page-header{display:flex;justify-content:space-between;align-items:center;margin:0 0 18px}
.page-title{font-size:20px;font-weight:700;margin:0}

.row-inactivo td{opacity:.5}
.permisos-cell{max-width:320px}
.perm-tag{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;
  border-radius:20px;margin:2px 2px;white-space:nowrap}
.perm-admin{background:#FBE7B4;color:#633806}
.perm-cliente{background:#E9F7F0;color:#115F40}
.perm-plan{background:#E3E5F7;color:#232D8B}
.perm-vacio{font-size:12px;color:var(--suave)}
.status-dot{font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}
.status-dot.activo{background:#E6F4EE;color:#167E54}
.status-dot.inactivo{background:#FAEAEA;color:#C23535}
.acciones-cell{white-space:nowrap;display:flex;gap:6px;align-items:center}
.btn-desactivar{background:transparent;color:var(--rojo);border:1px solid var(--rojo)}
.btn-desactivar:hover{background:#fdecea}
.btn-activar{background:transparent;color:var(--verde);border:1px solid var(--verde)}
.btn-activar:hover{background:#e4f3ec}

.form-card{background:#fff;border:1px solid var(--borde);border-radius:12px;padding:24px;
  display:flex;flex-direction:column;gap:28px}
.form-section{display:flex;flex-direction:column;gap:14px}
.section-title{font-size:15px;font-weight:700;margin:0 0 4px;color:var(--texto)}
.section-hint{font-size:13px;color:var(--suave);margin:0 0 10px}
.form-row{display:flex;flex-wrap:wrap;gap:16px}
.form-label{display:flex;flex-direction:column;font-size:12px;font-weight:600;
  color:var(--suave);flex:1;min-width:220px}
.form-label input,.form-label select{margin-top:6px;padding:10px;border:1px solid var(--borde);
  border-radius:8px;font-size:14px;color:var(--texto);background:var(--input-bg)}
.check-label{flex-direction:row;align-items:center;gap:8px;font-size:14px;color:var(--texto)}
.check-label input{width:16px;height:16px;margin:0}
.form-actions{display:flex;gap:10px;padding-top:4px}

.permisos-grid{display:flex;gap:24px;flex-wrap:wrap}
.permisos-col{flex:1;min-width:260px;display:flex;flex-direction:column;gap:6px}
.permisos-titulo{font-size:13px;font-weight:700;margin:0 0 8px;color:var(--texto)}
.perm-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;
  padding:6px 10px;border-radius:8px;border:1px solid var(--borde);background:var(--input-bg)}
.perm-check:hover{background:#E5E0F5}
.perm-check input{width:15px;height:15px;flex-shrink:0}
.perm-check-cliente{color:var(--suave);font-size:12px}
.permisos-niveles{display:flex;gap:16px;flex-wrap:wrap}
.permisos-nivel{flex:1;min-width:220px;display:flex;flex-direction:column;gap:5px}
.perm-proyecto{background:#f0e7fb;color:#6b3fa0}
.nivel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.nivel-acciones{display:flex;gap:4px}
.btn-nivel{font-size:11px;padding:2px 8px;border-radius:6px;border:1px solid var(--borde);
  background:#fff;color:var(--suave);cursor:pointer;font-weight:600}
.btn-nivel:hover{background:var(--gris);color:var(--texto)}
.depto-reg-select{width:100%;padding:8px;border:1px solid var(--borde);border-radius:8px;
  font-size:13px;margin-bottom:6px;color:var(--texto)}
.depto-lista{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}
.depto-codigo{font-size:11px;font-weight:700;color:#3342CC;min-width:80px;
  font-family:monospace}

/* ---------- Jobs / Generación ---------- */
.cfdi-count-box{background:#E3E5F7;color:#232D8B;font-size:13px;font-weight:700;
  padding:8px 14px;border-radius:8px;text-align:center;margin-bottom:8px}
.progress-wrap{display:flex;flex-direction:column;gap:4px}
.progress-bar{height:8px;background:#eef1f5;border-radius:4px;overflow:hidden;min-width:120px}
.progress-fill{height:100%;background:var(--primario);border-radius:4px;transition:width .4s}
.progress-label{font-size:12px;color:var(--suave)}
.err-cnt{color:var(--rojo);font-weight:600}
.job-status{font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px}
.job-pendiente{background:#eef1f5;color:#6b7785}
.job-corriendo{background:#E8F2FA;color:#2E7DB8}
.job-completado{background:#E6F4EE;color:#167E54}
.job-error{background:#FAEAEA;color:#C23535}
.ts{font-size:12px;color:var(--suave);white-space:nowrap}
.gen-feedback{display:flex;align-items:center;gap:10px;background:#E8F2FA;color:#2E7DB8;
  font-size:14px;font-weight:600;padding:12px 16px;border-radius:10px;margin-bottom:12px}
.gen-spinner{width:18px;height:18px;border:3px solid #C5E0F2;border-top-color:#2E7DB8;
  border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Grupos / Regpat ---------- */
.regpats-cell{max-width:500px}
.regpat-id{font-size:11px;color:var(--suave);min-width:28px}
.regpat-search{margin-bottom:10px}
.regpat-search-input{width:100%;max-width:400px;padding:9px 12px;border:1px solid var(--borde);
  border-radius:8px;font-size:14px}
.regpat-list{display:flex;flex-direction:column;gap:5px;max-height:420px;overflow-y:auto;
  border:1px solid var(--borde);border-radius:10px;padding:10px;background:#fafbfd}
