/* Reset simple */
*{box-sizing:border-box} html,body{margin:0;padding:0}

/* Contenedor base y tipografía */
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;color:#111;background:#fff}
.container{max-width:1080px;margin:0 auto;padding:24px}

/* Header / Footer */
.site-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0 16px;border-bottom:1px solid #eee}
.site-header .brand a{text-decoration:none;color:#111}
.site-header .menu a{margin-left:16px;text-decoration:none;color:#1a56db}
.site-footer{margin-top:40px;padding-top:16px;border-top:1px solid #eee;color:#666;font-size:14px}

/* Home: héroe + buscador */
.hero{padding:56px 0;text-align:center}
.searchbox{position:relative;max-width:720px;margin:0 auto}
.searchbox input{width:100%;padding:14px 16px;font-size:18px;border:1px solid #ddd;border-radius:8px}
.suggestions{position:absolute;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:0;border-radius:0 0 8px 8px;max-height:320px;overflow:auto;display:none;z-index:11}
.suggestions a{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;text-decoration:none;color:#222;border-top:1px solid #f3f3f3}
.suggestions a:hover{background:#f7f7f7}
.badge{font-size:12px;padding:2px 8px;border-radius:12px;background:#eef}

/* Tarjetas Top10 */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px}
.card{border:1px solid #eee;border-radius:12px;padding:16px;background:#fff}
.card h3{margin:0 0 12px 0;font-size:18px}
.card ul{list-style:none;margin:0;padding:0}
.card li{padding:8px 0;border-bottom:1px dashed #eee}
.card a{text-decoration:none;color:#1a56db}

/* A–Z–Ñ */
.az{margin: 40px 0px;text-align:center}
.az a{margin:0 4px;text-decoration:none;color:#555}
.az .active{font-weight:700}

/* Listados */
.list .item{padding:10px 0;border-bottom:1px dashed #eee;display:flex;justify-content:space-between}
.list a{text-decoration:none;color:#1a56db}
.pager{margin-top:16px;text-align:center}
.pager a{margin:0 6px;text-decoration:none}

/* Paginación mejorada */
.pager{margin-top:16px;display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:wrap}
.pager .page{padding:6px 10px;border:1px solid #ddd;border-radius:8px;text-decoration:none;color:#1a56db}
.pager .page:hover{background:#f7f7f7}
.pager .page.current{background:#1a56db;color:#fff;border-color:#1a56db;cursor:default}
.pager .page.disabled{color:#aaa;border-color:#eee;pointer-events:none}
.pager .sep{padding:0 6px;color:#999}
.pager-meta{text-align:center;color:#555;margin-top:8px;font-size:14px}


/* Informe */
.breadcrumbs{margin:8px 0 16px 0;font-size:14px}
.page-title{margin:8px 0 12px 0}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:16px 0 8px}
.kpi{border:1px solid #eee;border-radius:12px;padding:16px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.kpi-title{color:#555;font-size:13px;margin-bottom:6px}
.kpi-value{font-size:28px;font-weight:700}

/* Secciones */
.section{margin-top:28px}

/* Tablas */
.wrap-table{overflow:auto;border:1px solid #eee;border-radius:12px}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table thead th{position:sticky;top:0;background:#fafafa;border-bottom:1px solid #eee;padding:10px;text-align:left}
.table tbody td{border-top:1px dashed #f0f0f0;padding:8px 10px;vertical-align:top}
.table tbody tr:nth-child(even){background:#fcfcfd}

/* Gráfico */
.chart{border:1px solid #eee;border-radius:12px;padding:12px;background:#fff;margin-bottom:16px}
.chart svg{width:100%;height:auto;display:block}
.chart .axis{stroke:#999;stroke-width:1}
.chart .grid{stroke:#eee;stroke-width:1}
.chart .tick{fill:#555;font-size:11px}
.chart .series{stroke-width:2.5}
.chart .series-v{stroke:#1a56db}
.chart .series-f{stroke:#00a676}
.legend{display:inline-block;width:12px;height:3px;vertical-align:middle;margin:0 4px;border-radius:2px}
.legend-v{background:#1a56db}
.legend-f{background:#00a676}

/* Layout auxiliar */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width: 920px){
  .grid-2{grid-template-columns:1fr}
}


/* Herramientas de tabla */
.table-tools{display:flex;gap:12px;align-items:center;margin:8px 0 10px}
.table-tools input[type="search"]{padding:8px 10px;border:1px solid #ddd;border-radius:8px;min-width:240px}
.table-tools select{padding:6px 8px;border:1px solid #ddd;border-radius:8px}

/* Tablas responsivas tipo "stack" en móvil */
.table-responsive{width:100%;border-collapse:collapse;font-size:14px}
@media (max-width: 720px){
  .table-responsive thead{display:none}
  .table-responsive tbody tr{display:grid;grid-template-columns:1fr 1fr;gap:8px;border-bottom:1px solid #f0f0f0;padding:10px}
  .table-responsive tbody td{display:flex;gap:6px;padding:0;border:0}
  .table-responsive tbody td::before{
    content: attr(data-label) ": ";
    color:#666;min-width:120px;font-weight:600
  }
}

/* Paginación (reutiliza estilos anteriores) */
.pager{margin-top:12px;display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:wrap}
.pager .page{padding:6px 10px;border:1px solid #ddd;border-radius:8px;text-decoration:none;color:#1a56db}
.pager .page.current{background:#1a56db;color:#fff;border-color:#1a56db}
.pager .page.disabled{color:#aaa;border-color:#eee;pointer-events:none}
.pager .sep{padding:0 6px;color:#999}

/* Gráfico (añade etiquetas) */
.chart .dot{fill:#1a56db}
.chart .dot-f{fill:#00a676}
.chart .datalabel{fill:#333;font-size:10px;paint-order:stroke;stroke:#fff;stroke-width:3px;stroke-linejoin:round}

.table-tools label { display:flex; gap:6px; align-items:center; }
.table-tools input[type="date"]{ padding:6px 8px; border:1px solid #ddd; border-radius:8px; }

/* ===== A11y & UX ===== */

/* Skip link (saltar al contenido) */
.skip-link{
  position:fixed; left:12px; top:12px; z-index:1000;
  transform:translateY(-140%); transition:transform .12s ease;
  background:#0A5BD3; color:#fff; padding:10px 14px; border-radius:8px;
  text-decoration:none; box-shadow:0 2px 6px rgba(0,0,0,.15);
}
.skip-link:focus, .skip-link:focus-visible{ transform:translateY(0); outline:none }

/* Foco visible para teclado (no ocultes nunca el outline) */
:where(a, button, input, select, textarea, .pager .page){
  outline-offset:2px;
}
:where(a, button, input, select, textarea, .pager .page):focus-visible{
  outline:3px solid #0A5BD3;
  box-shadow:0 0 0 3px #E7F0FF;
}

/* Enlaces: subrayado en hover/focus para mayor claridad */
a:hover, a:focus-visible{ text-decoration:underline; text-underline-offset:3px }

/* Estado activo accesible en navegación y paginación (usa aria-current="page") */
.menu a[aria-current="page"]{
  font-weight:700; text-decoration:underline; text-underline-offset:3px;
}
.pager .page[aria-current="page"]{
  background:#1a56db; color:#fff; border-color:#1a56db; cursor:default;
}

/* Capciones de tablas (si las usas) */
.table caption{
  caption-side: top; text-align:left; font-weight:600; color:#333;
  padding:8px 10px;
}

/* Aumentar área táctil en dispositivos de puntero grueso */
@media (pointer: coarse){
  .menu a, .pager .page{ padding:10px 12px; min-height:44px }
  .table-tools input, .table-tools select{ min-height:44px }
}

/* Clase utilitaria: solo para lectores de pantalla */
.sr-only{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.sr-only.focusable:active, .sr-only.focusable:focus{
  position:static !important; width:auto; height:auto; margin:0; overflow:visible;
  clip:auto; white-space:normal;
}

/* Respetar usuarios con 'reducir movimiento' */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important }
}

/* Resaltar anclas al navegar dentro de la página */
:target{ scroll-margin-top: 16px; }
.section:target{ outline:3px solid #E7F0FF; border-radius:12px }

/* --- Filtros compactos en grid --- */
.table-tools{
  display:grid; gap:12px; align-items:end;
  grid-template-columns: 1fr 160px 160px 110px auto;  /* buscador | desde | hasta | filas | estado */
}
.table-tools fieldset{border:0; padding:0; margin:0; display:contents}
.table-tools label{display:flex; flex-direction:column; gap:6px; font-size:13px; color:#555}
.table-tools input[type="search"],
.table-tools input[type="date"],
.table-tools select{height:38px}

/* Presets (chips) */
.tools-presets{grid-column:1 / -1; display:flex; gap:8px; flex-wrap:wrap; margin-top:4px}
.chip{border:1px solid #ddd; border-radius:999px; padding:6px 10px; background:#fff; cursor:pointer}
.chip:hover{background:#f7f7f7}
.chip.active{background:#1a56db; color:#fff; border-color:#1a56db}

/* Estado a la derecha en desktop */
.tools-status{justify-self:end; font-size:14px; color:#555}

/* Responsive */
@media (max-width: 880px){
  .table-tools{ grid-template-columns: 1fr 1fr; }
  .tools-status{ justify-self:start; grid-column: 1 / -1; }
}

/* ---- Caption estilizado (barra sticky dentro de la tabla) ---- */
.table caption.cap{
  caption-side: top;
  padding: 0;               /* quitamos padding por defecto */
}

.cap-bar{
  display:flex; align-items:center; gap:12px;
  padding:12px 14px;
  background:linear-gradient(180deg, #f7faff 0%, #f2f7ff 100%);
  border-bottom:1px solid #e6efff;
  border-radius:12px 12px 0 0;          /* se integra con wrap-table */
  position: sticky; top: 0; z-index: 3; /* queda pegado al hacer scroll */
}

.cap-ico{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:8px;
  background:#1a56db; color:#fff; font-size:16px; line-height:1;
  box-shadow:0 1px 2px rgba(0,0,0,.06);
}

.cap-txt strong{ font-size:15px; color:#123; display:block }
.cap-sub{ font-size:12px; color:#556; display:block; margin-top:2px }


/* ===== Banda A–Z–Ñ mejorada ===== */
.az{
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
  margin:18px 0 20px; padding:10px 12px;
  background:#fafbff; border:1px solid #eef2ff; border-radius:999px;
}
.az a{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:36px; height:36px; padding:0 12px;
  border:1px solid transparent; border-radius:999px;
  background:#fff; color:#334; font-weight:600; text-decoration:none;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.az a:hover{ background:#f6faff; border-color:#cfe1ff; text-decoration:none }
.az a:focus-visible{
  outline:3px solid #0A5BD3; outline-offset:2px;
}

/* Letra activa */
.az a.active,
.az a[aria-current="page"]{
  background:#1a56db; color:#fff; border-color:#1a56db; cursor:default;
  box-shadow:0 2px 0 rgba(26,86,219,.15);
}

/* Tacto cómodo en móvil */
@media (pointer:coarse){
  .az a{ min-width:40px; height:40px; padding:0 14px }
}

/* (Opcional) hacer la banda sticky bajo el header en pantallas grandes
@media (min-width: 992px){
  .az{ position:sticky; top:56px; z-index:5 }
}
*/

/* ===== Footer mejorado ===== */
.site-footer{
  margin-top:40px; padding:28px 0 8px;
  background:#f8f9ff; border-top:1px solid #eef2ff; color:#444; font-size:14px;
}
.footer-grid{
  display:grid; gap:24px; grid-template-columns:2fr 1fr 1fr;
}
.footer-title{ margin:0 0 10px; font-size:16px; color:#111 }
.footer-text{ margin:0 0 8px; color:#555 }
.footer-nav{ list-style:none; margin:0; padding:0 }
.footer-nav li{ margin:6px 0 }
.footer-link, .footer-nav a{ color:#1a56db; text-decoration:none }
.footer-link:hover, .footer-nav a:hover{ text-decoration:underline }

.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:16px; padding-top:12px; color:#666; border-top:1px dashed #e5e9ff;
  font-size:13px;
}

/* Responsive */
@media (max-width: 900px){ .footer-grid{ grid-template-columns:1fr 1fr } }
@media (max-width: 640px){ .footer-grid{ grid-template-columns:1fr } .footer-bottom{ flex-direction:column; gap:6px } }


.suggestions .is-active,
.suggestions [aria-selected="true"] { background:#eef6ff; }

/* --- Touch targets 44x44 (A11y / Lighthouse) ------------------- */

/* Menú superior: separa con gap y asegura 44px de alto mínimo */
.site-header .menu{ display:flex; gap:10px; }
.site-header .menu a{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  min-height:44px; line-height:1;
  border-radius:10px;
  text-decoration:none; color:#1a56db;
  border:1px solid transparent;
}
.site-header .menu a:hover,
.site-header .menu a:focus-visible{
  background:#f4f8ff; border-color:#dbe7ff; outline:none;
}

/* Banda A–Z–Ñ: cada letra es un “pill” 44x44 */
.az{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.az a{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:44px; height:44px; padding:0 12px;
  border:1px solid #e6e6e6; border-radius:999px;
  background:#fff; color:#555; text-decoration:none;
}
.az a:hover, .az a:focus-visible{ background:#f7f7f7; outline:none; }

/* Paginación: también ≥44x44 */
.pager{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.pager .page{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:44px; min-height:44px;
  padding:8px 12px;
  border:1px solid #ddd; border-radius:8px;
  text-decoration:none; color:#1a56db;
}

/* Enlaces de items (Top10 y listados): que el link completo sea clickeable */
.card li a,
.list .item a{
  padding:12px 10px;
  min-height:44px;
}

/* Sugerencias del autocompletado: cada opción ≥44px */
.suggestions a{ min-height:44px; }
