:root{
  --brand:#6f3cf6;
  --brand-2:#9b5cfb;
  --brand-3:#ec4899;
  --bg:#f6f7fb;
  --card:#ffffff;
  --muted:#6b7280;
  --ring:rgba(111,60,246,.35);
}
html,body{height:100%}
body{background:var(--bg);color:#0f172a;font-synthesis-weight:none}

/* Shell */
.app-shell{max-width:1200px;margin:0 auto;padding:0 24px}

/* -------- NAVBAR -------- */
.navbar{background:#fff;border-bottom:1px solid rgba(2,6,23,.06);position:sticky;top:0;z-index:50}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:800}
.brand-badge{
  width:36px;height:36px;border-radius:50%;
  background:conic-gradient(from 180deg at 50% 50%, var(--brand), var(--brand-2), var(--brand-3));
  box-shadow:0 10px 24px rgba(111,60,246,.28)
}
.search-wrap{position:relative}
.search-wrap .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#64748b}
.input{
  width:100%;border:1px solid rgba(2,6,23,.12);border-radius:12px;padding:.62rem .9rem .62rem 2.2rem;background:#fff
}
.input:focus{outline:3px solid var(--ring);border-color:transparent}

/* right action buttons */
.icon-btn{
  width:38px;height:38px;border-radius:12px;display:grid;place-items:center;
  background:#fff;border:1px solid rgba(2,6,23,.1);position:relative;
  transition:all .15s; color:#6b6f86;
}
.icon-btn:hover{box-shadow:0 8px 24px rgba(15,23,42,.08);transform:translateY(-1px);color:var(--brand)}
.icon-btn .dot{
  position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:999px;background:var(--brand-3);
  box-shadow:0 0 0 4px rgba(236,72,153,.18)
}
.badge-dot{
  position:absolute;top:-6px;right:-6px;background:var(--brand);color:#fff;border-radius:999px;
  font-size:.65rem;padding:.05rem .35rem;border:2px solid #fff
}
.avatar{width:38px;height:38px;border-radius:12px;overflow:hidden;border:1px solid rgba(2,6,23,.1)}

/* menu pills */
.menu-row{display:flex;align-items:center;gap:.35rem;overflow-x:auto;padding-bottom:.2rem}
.navpill{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.55rem .8rem;border-radius:12px;
  color:#5b5fc6;background:transparent;border:1px solid transparent;
  font-weight:600
}
.navpill svg{width:18px;height:18px}
.navpill:hover{background:rgba(111,60,246,.08)}
.navpill.active{background:rgba(111,60,246,.12);border-color:rgba(111,60,246,.25);color:var(--brand)}

/* ------- Cards / dashboard ------- */
.card{background:var(--card);border-radius:16px;box-shadow:0 6px 20px rgba(15,23,42,.06);border:1px solid rgba(2,6,23,.06)}
.card-gradient{
  background: radial-gradient(120% 120% at -10% -10%, rgba(111,60,246,.15), transparent 60%),
              radial-gradient(120% 120% at 110% -20%, rgba(236,72,153,.12), transparent 50%),
              var(--card);
}
.kpi .label{font-size:.82rem;color:var(--muted)}
.kpi .value{font-size:1.85rem;font-weight:800}
.badge{font-size:.75rem;padding:.2rem .5rem;border-radius:999px;background:rgba(111,60,246,.12);color:var(--brand)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;border-radius:12px;border:1px solid rgba(2,6,23,.08);background:#fff;transition:.15s}
.btn:hover{box-shadow:0 8px 24px rgba(15,23,42,.08);transform:translateY(-1px)}
.btn-primary{background:var(--brand);color:#fff;border-color:transparent}
.chart-box{height:240px}

/* Overlay de descarga */
.dl-overlay{position:fixed;inset:0;background:rgba(8,11,20,.58);backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;z-index:9999}
.dl-overlay.hidden{display:none}
.dl-box{position:relative;width:200px;height:200px;border-radius:24px;
  background:linear-gradient(180deg,#0b0f1a,#141a2a);border:1px solid #2a3350;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.dl-logo{width:92px;height:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.dl-ring{position:absolute;width:150px;height:150px;border-radius:50%;
  border:4px solid rgba(255,255,255,.08);border-top-color:rgba(255,255,255,.55);
  animation:dl-spin 1.1s linear infinite}
.dl-text{color:#cbd5e1;font-weight:700;letter-spacing:.3px;font-size:14px;animation:dl-pulse 1.4s ease-in-out infinite;margin-top:6px}
@keyframes dl-spin{to{transform:rotate(360deg)}}
@keyframes dl-pulse{0%,100%{opacity:.75}50%{opacity:1}}

/* Footer */
.footer{color:var(--muted);font-size:.9rem}

/* Utility for print hide */
.no-print{display:block}
@media print{.no-print{display:none}}

/* --- Navbar Xintra (tu diseño, sin cambiar HTML) --- */
.navbar{
  position: sticky;        /* opcional: queda fijo al hacer scroll */
  top: 0; z-index: 40;
  background: #ffffffcc;   /* sutil translucidez */
  backdrop-filter: blur(6px);
  border-bottom: 1px solid #eef2ff;
  /* 👇 asegura “aire” uniforme debajo en TODAS las páginas */
  margin-bottom: 1.25rem;  /* ~mb-5 */
}

/* logo de imagen en el brand */
.navbar .brand img{ display:block; height:2rem; width:auto; }

/* contenedor ancho consistente */
.app-shell{ max-width:1200px; margin:0 auto; padding:0 1.25rem; }

/* fila de menú con pills */
.menu-row{ display:flex; flex-wrap:wrap; gap:.5rem 1rem; }

.navpill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .75rem; border-radius:.75rem;
  color:#4b5563; transition:.15s;
}
.navpill:hover{ background:rgba(124,58,237,.08); color:#111827; }
.navpill.active{ background:rgba(124,58,237,.16); color:#111827; }

.icon-btn{
  height:2.25rem;width:2.25rem;border-radius:.75rem;
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border:1px solid #eee;
  position:relative;
}
.icon-btn:hover{ box-shadow:0 6px 16px rgba(0,0,0,.06); }

.badge-dot{
  position:absolute; top:-6px; right:-6px; font-size:.65rem;
  background:#7c3aed; color:#fff; border-radius:9999px; padding:2px 6px;
}
.dot{
  position:absolute; top:6px; right:6px; height:8px; width:8px;
  background:#ec4899; border-radius:50%;
}


/* -------- Dashboard nuevo -------- */
.hero-card{position:relative;color:#fff;padding:2.4rem;border:0;background:var(--card);box-shadow:none;}
.hero-card .hero-gradient{position:absolute;inset:0;background:linear-gradient(135deg,#312e81,#7c3aed 55%,#ec4899);opacity:.96;}
.hero-card .hero-content{position:relative;display:flex;flex-direction:column;gap:2rem;z-index:1;}
@media (min-width:1024px){.hero-card .hero-content{flex-direction:row;justify-content:space-between;align-items:flex-end;}}
.hero-copy{max-width:34rem;display:flex;flex-direction:column;gap:1rem;}
.hero-eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;color:rgba(255,255,255,.75);}
.hero-title{font-size:1.95rem;font-weight:800;line-height:1.2;}
.hero-subtitle{font-size:.95rem;color:rgba(255,255,255,.8);display:flex;flex-wrap:wrap;gap:.35rem .65rem;align-items:center;}
.hero-subdued{color:rgba(255,255,255,.65);font-size:.85rem;}
.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;}
.hero-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.7);}
.hero-value{font-size:2.2rem;font-weight:800;display:block;}
.hero-footer{position:relative;z-index:1;margin-top:2rem;display:flex;flex-wrap:wrap;gap:1rem 1.5rem;justify-content:space-between;align-items:center;}
.hero-chip{background:rgba(15,23,42,.18);border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.85);border-radius:14px;padding:.75rem 1.1rem;display:flex;flex-direction:column;font-size:.85rem;gap:.3rem;min-width:180px;}
.hero-chip strong{font-size:1.35rem;}
.hero-actions{display:flex;flex-wrap:wrap;gap:.6rem;}
.hero-card .btn{border-color:rgba(255,255,255,.18);color:#0f172a;}
.hero-card .btn.btn-primary{color:#fff;box-shadow:0 16px 38px rgba(17,24,39,.28);}

.spotlight{padding:2rem 2.2rem;display:flex;flex-direction:column;gap:1.6rem;}
.spotlight-eyebrow{text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;color:#6366f1;font-weight:700;}
.spotlight-title{font-size:1.45rem;font-weight:700;color:#0f172a;}
.spotlight-metrics{display:grid;gap:1.1rem;}
.spotlight-metrics div{display:flex;flex-direction:column;gap:.3rem;}
.spotlight-metrics dt{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;}
.spotlight-metrics dd{font-size:1.5rem;font-weight:700;color:#111827;}
.spotlight-footer{border-top:1px solid rgba(15,23,42,.08);padding-top:1.1rem;}
.spotlight-note{font-size:.85rem;color:#64748b;}

.section-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.25rem;padding:1.8rem 2rem;border-bottom:1px solid rgba(15,23,42,.08);}
.section-title{font-size:1.25rem;font-weight:700;color:#0f172a;}
.section-subtitle{font-size:.95rem;color:#6b7280;}

.tablist{display:flex;gap:.6rem;background:rgba(79,70,229,.08);padding:.4rem;border-radius:14px;}
.tab{padding:.55rem 1.2rem;border-radius:12px;font-weight:600;font-size:.9rem;color:#4338ca;background:transparent;border:0;cursor:pointer;transition:.15s;}
.tab:hover{background:rgba(79,70,229,.12);}
.tab.is-active{background:#fff;color:#111827;box-shadow:0 8px 20px rgba(79,70,229,.25);}
.tab-panel{padding:1.5rem 2rem 2rem;}
.tab-panel[hidden]{display:none;}

.batch-list{display:flex;flex-direction:column;gap:1rem;}
.batch-item{padding:1.2rem 1.4rem;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#fff;display:flex;flex-direction:column;gap:.75rem;transition:border-color .15s,box-shadow .15s;}
.batch-item:hover{border-color:rgba(79,70,229,.25);box-shadow:0 12px 28px rgba(79,70,229,.12);}
.batch-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;}
.batch-title{font-weight:700;font-size:1.05rem;color:#0f172a;}
.batch-meta{font-size:.82rem;color:#64748b;margin-top:.35rem;display:flex;gap:.5rem;flex-wrap:wrap;}
.batch-status{font-size:.72rem;font-weight:700;padding:.4rem .65rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;}
.batch-body{display:flex;align-items:baseline;gap:.65rem;font-size:.95rem;color:#475569;}
.batch-number{font-size:1.45rem;font-weight:800;color:#0f172a;}
.batch-progress{height:6px;width:100%;border-radius:999px;background:rgba(15,23,42,.08);overflow:hidden;}
.batch-progress span{display:block;height:100%;border-radius:inherit;}
.batch-empty{padding:1.4rem;border-radius:14px;background:rgba(15,23,42,.04);text-align:center;color:#6b7280;font-size:.9rem;}

.badge-pep{background:rgba(16,185,129,.16);color:#047857;}
.badge-concursal{background:rgba(251,191,36,.18);color:#b45309;}
.badge-onu{background:rgba(14,165,233,.16);color:#0e7490;}

.breakdown-card{padding:1.8rem;display:flex;flex-direction:column;gap:1.4rem;}
.breakdown-card header{display:flex;flex-direction:column;gap:.6rem;}
.breakdown-card h3{font-weight:700;font-size:1.1rem;color:#0f172a;}
.breakdown-card p{color:#64748b;font-size:.9rem;}
.breakdown-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;}
.breakdown-metrics div{display:flex;flex-direction:column;gap:.3rem;}
.breakdown-metrics dt{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;}
.breakdown-metrics dd{font-size:1.2rem;font-weight:700;color:#0f172a;}

.chart-card{min-height:360px;display:flex;flex-direction:column;gap:1.5rem;}
.chart-canvas{margin-top:1rem;height:270px;border-radius:18px;background:rgba(15,23,42,.03);display:flex;align-items:center;justify-content:center;}
.chart-legend{display:flex;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:#475569;}
.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:.35rem;}
.legend-processed{background:#4f46e5;}
.legend-detected{background:#ec4899;}

.activity-card{display:flex;flex-direction:column;gap:1.4rem;}
.activity-feed{display:flex;flex-direction:column;gap:1.1rem;margin-top:.4rem;}
.activity-item{display:flex;gap:1rem;align-items:flex-start;}
.activity-pill{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#0f172a;background:rgba(79,70,229,.15);}
.activity-body{flex:1;display:flex;flex-direction:column;gap:.3rem;}
.activity-body h4{font-size:1rem;font-weight:600;color:#0f172a;}
.activity-meta{font-size:.82rem;color:#6b7280;display:flex;gap:.6rem;flex-wrap:wrap;}
.activity-empty{padding:1.2rem;border-radius:14px;background:rgba(15,23,42,.04);text-align:center;color:#6b7280;font-size:.9rem;}

.status-finished{background:rgba(16,185,129,.2);color:#047857;}
.status-running{background:rgba(79,70,229,.18);color:#4338ca;}
.status-queued{background:rgba(148,163,184,.2);color:#475569;}
.status-error{background:rgba(248,113,113,.2);color:#b91c1c;}

.progress-pep{background:linear-gradient(90deg,#10b981,#059669);}
.progress-concursal{background:linear-gradient(90deg,#fbbf24,#f97316);}
.progress-onu{background:linear-gradient(90deg,#38bdf8,#0ea5e9);}

.badge-onu,.badge-pep,.badge-concursal{padding:.35rem .8rem;border-radius:999px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}

@media (max-width:768px){
  .hero-card{padding:2rem;}
  .hero-stats{grid-template-columns:1fr;}
  .tab-panel{padding:1.5rem;}
  .breakdown-metrics{grid-template-columns:repeat(2,minmax(0,1fr));}
}

.batch-muted{font-size:.9rem;color:#64748b;}
.activity-pill-pep{background:rgba(16,185,129,.18);color:#047857;}
.activity-pill-concursal{background:rgba(251,191,36,.2);color:#92400e;}
.activity-pill-onu{background:rgba(14,165,233,.2);color:#075985;}
.breakdown-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .9rem;border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
/* ----------- Datatable batches ----------- */
.datatable-card{padding:2rem 2.2rem;display:flex;flex-direction:column;gap:1.75rem}
.datatable-header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem}
.datatable-title{font-size:1.35rem;font-weight:700;color:#0f172a}
.datatable-subtitle{font-size:.92rem;color:#64748b;max-width:36rem}
.datatable-actions{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}
.datatable-search{position:relative;display:flex;align-items:center}
.datatable-search .icon{position:absolute;left:0.85rem;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#94a3b8}
.datatable-input{padding:.6rem 1rem .6rem 2.6rem;border:1px solid rgba(15,23,42,.1);border-radius:12px;min-width:240px;background:#fff;transition:border-color .15s,box-shadow .15s}
.datatable-input:focus{outline:none;border-color:rgba(79,70,229,.45);box-shadow:0 0 0 3px rgba(129,140,248,.25)}
.datatable-per-page{display:flex;align-items:center;gap:.5rem;background:#f1f5f9;padding:.35rem .7rem;border-radius:999px}
.datatable-select{border:0;background:transparent;font-weight:600;color:#4338ca;padding:.2rem .4rem;outline:none}
.datatable-wrapper{overflow:auto;border:1px solid rgba(15,23,42,.08);border-radius:18px}
.datatable-table{min-width:880px;width:100%;border-collapse:separate;border-spacing:0}
.datatable-table thead tr{background:rgba(79,70,229,.08)}
.datatable-table th{padding:0.85rem 1rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#4338ca;font-weight:700;border-bottom:1px solid rgba(79,70,229,.2)}
.datatable-table th .sort-btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:700;text-transform:inherit;letter-spacing:inherit;color:inherit;background:transparent;border:0;padding:0;cursor:pointer}
.datatable-table th .sort-btn::after{content:'';width:10px;height:10px;mask:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="none"%3E%3Cpath d="M5.5 7.5 10 3l4.5 4.5M14.5 12.5 10 17l-4.5-4.5" stroke="currentColor" stroke-width="1.4" stroke-linecap="round" stroke-linejoin="round"/%3E%3C/svg%3E') center/contain no-repeat;opacity:.45;transition:opacity .15s,transform .15s}
.datatable-table th .sort-btn.is-asc::after{transform:rotate(180deg);opacity:.9}
.datatable-table th .sort-btn.is-desc::after{opacity:.9}
.datatable-table th .sort-btn:focus-visible{outline:2px solid rgba(99,102,241,.5);outline-offset:2px;border-radius:6px}
.datatable-table td{padding:0.85rem 1rem;font-size:.95rem;color:#334155;border-bottom:1px solid rgba(15,23,42,.05);background:#fff}
.datatable-table tbody tr:hover td{background:rgba(79,70,229,.05)}
.datatable-empty{text-align:center;padding:2.5rem 1rem;font-size:.95rem;color:#64748b;background:#f8fafc}
.datatable-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.datatable-status{font-size:.85rem;color:#64748b}
.datatable-pagination{display:flex;align-items:center;gap:.75rem}
.page-btn{border:1px solid rgba(15,23,42,.12);background:#fff;border-radius:12px;padding:.55rem 1.1rem;font-weight:600;font-size:.85rem;color:#4338ca;transition:.15s;min-width:110px;display:flex;align-items:center;justify-content:center}
.page-btn[disabled]{opacity:.45;pointer-events:none}
.page-btn:not([disabled]):hover{box-shadow:0 10px 24px rgba(79,70,229,.18);transform:translateY(-1px)}
.page-list{display:flex;gap:.4rem;flex-wrap:wrap}
.page-pill{min-width:40px;height:38px;border-radius:12px;border:1px solid rgba(15,23,42,.1);background:#fff;color:#475569;font-weight:600;font-size:.85rem;display:flex;align-items:center;justify-content:center;padding:0 .6rem;transition:.15s}
.page-pill:hover{border-color:rgba(79,70,229,.35);color:#4338ca}
.page-pill.is-active{background:#4338ca;color:#fff;border-color:#4338ca;box-shadow:0 10px 24px rgba(79,70,229,.25)}
.badge-type{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.badge-type.pep{background:rgba(16,185,129,.16);color:#047857}
.badge-type.concursal{background:rgba(251,191,36,.18);color:#92400e}
.badge-type.onu{background:rgba(59,130,246,.16);color:#1d4ed8}
.progress-track{width:140px;height:8px;border-radius:999px;background:rgba(15,23,42,.08);overflow:hidden}
.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#4f46e5,#ec4899)}
.status-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.status-chip.finished{background:rgba(16,185,129,.18);color:#047857}
status-chip.running{background:rgba(129,140,248,.2);color:#4338ca}
.status-chip.queued{background:rgba(148,163,184,.2);color:#475569}
.status-chip.error{background:rgba(248,113,113,.2);color:#b91c1c}
.action-group{display:flex;justify-content:flex-end;gap:.45rem}
.action-group .btn{padding:.5rem .85rem;border-radius:10px;font-size:.8rem}
@media (max-width:1024px){
  .datatable-card{padding:1.6rem}
  .datatable-wrapper{border-radius:14px}
  .datatable-table{min-width:720px}
}
@media (max-width:640px){
  .datatable-actions{width:100%}
  .datatable-search{flex:1}
  .datatable-input{width:100%}
  .datatable-per-page{width:100%;justify-content:space-between}
  .page-btn{min-width:0;padding:.5rem .9rem}
}