/* =============================================================
   DIPRENA · Portal CMS — Reporteador parametrizable
   Hereda tokens y patrones de styles.css + dashboard.css.
   ============================================================= */

.reporteador-page { padding-bottom: 56px; }

.active-filters-summary {
  font-size: 12px;
  color: var(--text-mute);
  background: var(--bg-soft);
  padding: 6px 12px;
  border-radius: 14px;
  border: 1px solid var(--border-soft);
}

/* Layout 3 columnas: sidebar wizard · main · panel derecho */
.rep-layout {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: 20px;
  align-items: start;
}
/* Sin esto, los items del grid heredan min-width: auto y la tabla (que tiene
   min-width: 720px) empuja la pagina entera en mobile. */
.rep-layout > * { min-width: 0; }

.rep-sidebar,
.rep-rightpanel {
  position: sticky;
  top: 88px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Wizard steps */
.wizard-step {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 12px;
}
.step-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px;
  background: var(--navy);
  color: #fff;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
}
.step-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  text-transform: none;
  letter-spacing: 0;
  margin: 0;
}

.checkbox-list { display: flex; flex-direction: column; gap: 6px; }
.checkbox-list label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  padding: 4px 0;
}
.checkbox-list input[type="checkbox"] {
  accent-color: var(--blue);
  width: 14px; height: 14px;
}
.checkbox-list label:has(input:disabled) { opacity: .5; cursor: not-allowed; }

.btn-generate {
  width: 100%;
  padding: 11px 18px;
  gap: 8px;
  background: var(--navy);
}
.btn-generate:hover { background: var(--navy-soft); }

/* ─── Main · Resultados ─── */
.rep-main { display: flex; flex-direction: column; gap: 16px; }

.results-header {
  display: flex; justify-content: space-between; align-items: flex-end; gap: 16px;
  padding: 4px 4px 8px;
  flex-wrap: wrap;
}
.results-title {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--navy);
  margin: 0;
}
.results-count {
  font-size: 12px;
  color: var(--text-mute);
  margin-top: 4px;
}
.view-tabs {
  display: inline-flex;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  overflow: hidden;
}
.view-tab {
  padding: 8px 14px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--text-mute);
  transition: .15s;
}
.view-tab:hover { color: var(--blue); }
.view-tab.is-active { background: var(--navy); color: var(--white); }

/* Toolbar de la tabla */
.dt-toolbar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--border-soft);
  flex-wrap: wrap;
}
.dt-toolbar-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.dt-actions { display: flex; gap: 8px; align-items: center; }
.dt-btn {
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  padding: 7px 12px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text);
  cursor: pointer;
  transition: .15s;
}
.dt-btn:hover { border-color: var(--blue); color: var(--blue); }
.dt-btn.primary { background: var(--blue); color: #fff; border-color: var(--blue); }
.dt-btn.primary:hover { background: #1862C8; border-color: #1862C8; }
.sort-select {
  padding: 7px 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--white);
  font-family: inherit;
  font-size: 12px;
  color: var(--text);
}
.sort-select:focus { outline: none; border-color: var(--blue); }

/* Tabla */
.rep-table-wrap {
  overflow-x: auto;
}
.rep-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  min-width: 720px;
}
.rep-table thead th {
  background: var(--bg-soft);
  color: var(--text-mute);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.rep-table thead th.num,
.rep-table tbody td.num,
.rep-table tfoot td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.rep-table tbody td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: middle;
}
.rep-table tbody tr:hover td { background: var(--blue-bg); }
.rep-table td.col-codigo { color: var(--text-faint); font-weight: 600; font-variant-numeric: tabular-nums; width: 60px; }
.rep-table td.col-name { color: var(--text); font-weight: 500; max-width: 320px; }
.rep-table td.col-name .col-sub { display: block; font-size: 11px; color: var(--text-mute); margin-top: 2px; }
.rep-table tfoot td {
  background: rgba(11,36,81,0.04);
  padding: 12px 14px;
  font-weight: 700;
  color: var(--navy);
  border-top: 1px solid var(--border);
}
.tbl-empty { padding: 28px; color: var(--text-mute); text-align: center; }

/* Semáforo + barra porcentual */
.pct-cell { display: inline-flex; align-items: center; gap: 8px; }
.pct-cell .semaforo { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.pct-cell .pct-bar  { width: 80px; height: 5px; background: var(--border-soft); border-radius: 3px; overflow: hidden; }
.pct-cell .pct-bar > span { display: block; height: 100%; }
.pct-cell .pct-num { font-weight: 700; font-variant-numeric: tabular-nums; }

/* Paginación */
.pagination {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 18px;
  border-top: 1px solid var(--border-soft);
  flex-wrap: wrap;
  gap: 8px;
}
.page-info { font-size: 12px; color: var(--text-mute); }
.page-btns { display: flex; gap: 4px; }
.page-btn {
  min-width: 30px; height: 30px;
  padding: 0 8px;
  border: 1px solid var(--border);
  background: var(--white);
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  transition: .15s;
}
.page-btn:hover { border-color: var(--blue); color: var(--blue); }
.page-btn.is-active { background: var(--navy); border-color: var(--navy); color: #fff; }
.page-btn:disabled { opacity: .4; cursor: not-allowed; }

/* Panel derecho · export cards */
.export-card,
.saved-report {
  display: flex; align-items: flex-start; gap: 10px;
  width: 100%;
  text-align: left;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  background: var(--white);
  cursor: pointer;
  font-family: inherit;
  transition: .15s;
  margin-bottom: 8px;
}
.export-card:hover,
.saved-report:hover { border-color: var(--blue); background: var(--blue-bg); }
.export-icon {
  width: 22px;
  height: 22px;
  fill: var(--blue);
  flex-shrink: 0;
}
.vt-icon,
.dt-btn-icon {
  width: 14px;
  height: 14px;
  fill: currentColor;
  margin-right: 6px;
  vertical-align: -2px;
}
.export-name { display: block; font-size: 12px; font-weight: 700; color: var(--text); }
.export-desc { display: block; font-size: 10px; color: var(--text-mute); margin-top: 2px; }
.sr-name { display: block; font-size: 12px; font-weight: 600; color: var(--navy); }
.sr-meta { display: block; font-size: 10px; color: var(--text-mute); margin-top: 2px; }

/* Vista resumen */
.summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 18px;
}
.summary-tile {
  background: var(--bg-soft);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-sm);
  padding: 16px;
}
.summary-tile .label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-mute);
  letter-spacing: 0.6px;
  text-transform: uppercase;
}
.summary-tile .value {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--navy);
  margin-top: 6px;
  font-variant-numeric: tabular-nums;
}

/* Responsive */
@media (max-width: 1200px) {
  .rep-layout { grid-template-columns: 260px 1fr; }
  .rep-rightpanel { grid-column: 1 / span 2; position: static; flex-direction: row; flex-wrap: wrap; }
  .rep-rightpanel .filter-card { flex: 1 1 280px; }
}
@media (max-width: 860px) {
  .rep-layout { grid-template-columns: 1fr; }
  .rep-sidebar { position: static; }
  .rep-rightpanel { grid-column: auto; }
  .summary-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  /* Header del reporteador: titulo y acciones se apilan */
  .dash-header { flex-direction: column; align-items: stretch; gap: 16px; }
  .dash-header h1 { font-size: 22px; }
  .dash-header__actions { flex-wrap: wrap; }

  /* Header de las cards: titulo arriba, tabs/acciones abajo */
  .card__header { flex-direction: column; align-items: stretch; gap: 12px; }
  .view-tabs { width: 100%; }

  /* Summary cards en una columna en pantallas muy chicas */
  .summary-grid { grid-template-columns: 1fr; }

  /* Reduce padding de la tabla para que cada columna pese menos */
  .rep-table thead th,
  .rep-table tbody td { padding: 10px 12px; }
  .rep-table { min-width: 600px; }
  .rep-table td.col-name { max-width: 220px; }
  .pct-cell .pct-bar { width: 60px; }

  /* Footer apilado */
  .dash-footer { flex-direction: column; align-items: flex-start; gap: 8px; }
}
