/* Vista — Base de eventos (tabla de todos los eventos: en venta + pasados) */
.tabla-wrap{max-width:var(--page-max-width);margin:0 auto;padding:24px var(--page-padding-x)}
.tabla-hd{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}

.tabla-tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:16px 0 14px}
.tabla-tools .filtros{display:flex;gap:6px;margin:0}  /* reset del margin-bottom heredado de actions.css */
/* Misma altura exacta en select, botones de filtro e input para que queden alineados */
.tabla-tools select,
.tabla-tools .filtros button,
.tabla-tools #tabla-q{height:36px;line-height:1;padding-top:0;padding-bottom:0}
#tabla-q{
  background:var(--bg-card);border:0.5px solid var(--bd-2);color:var(--tx-1);
  border-radius:var(--radius);padding-left:12px;padding-right:12px;font-size:13px;font-family:inherit;
  min-width:200px;flex:1;color-scheme:dark;-webkit-appearance:none;appearance:none;
}
.tabla-count{font-size:12px;color:var(--tx-3);margin-left:auto;white-space:nowrap}

.tabla-scroll{overflow-x:auto;border:0.5px solid var(--bd-1);border-radius:var(--radius)}
table.tabla{width:100%;border-collapse:collapse;font-size:13px;min-width:780px}
table.tabla th,table.tabla td{padding:9px 12px;text-align:left;border-bottom:0.5px solid var(--bd-1);white-space:nowrap;vertical-align:middle}
table.tabla thead th{
  position:sticky;top:0;background:var(--bg-surface);color:var(--tx-2);
  font-weight:500;font-size:12px;cursor:pointer;user-select:none;z-index:1;
}
table.tabla thead th:hover,table.tabla thead th.active{color:var(--tx-1)}
table.tabla th.num,table.tabla td.num{text-align:right;font-variant-numeric:tabular-nums}
table.tabla tbody tr.clk{cursor:pointer}
table.tabla tbody tr.clk:hover{background:var(--bg-hover)}
table.tabla tbody tr:last-child td{border-bottom:0}

/* Separador de mes — solo aparece cuando se ordena por fecha. Línea coloreada
   por estación (--mh) para romper visualmente. */
table.tabla tr.t-monthsep td{
  padding:18px 12px 8px;
  background:var(--bg-page);
  border-top:1.5px solid var(--mh);
  border-bottom:0;
  cursor:default;
}
table.tabla tr.t-monthsep:hover td{background:var(--bg-page)}
.t-monthsep-label{
  font-size:11px;text-transform:uppercase;letter-spacing:0.1em;font-weight:600;
  color:var(--mh);
}
.t-monthsep-count{
  font-size:11px;color:var(--tx-3);margin-left:10px;font-variant-numeric:tabular-nums;
}

.t-name{font-weight:500;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.t-venue{color:var(--tx-2)}
.t-fecha{color:var(--tx-1)}
.t-sub{font-size:11px;color:var(--tx-3)}
.t-excl{font-size:10px;color:var(--tx-3);margin-left:6px}
.t-pm{font-size:10px;color:var(--tx-2);margin-left:6px;padding:2px 6px;border:0.5px dashed var(--bd-2);border-radius:99px;font-weight:500}
.t-acts{text-align:right;white-space:nowrap}
.t-acts .t-act{
  background:transparent;border:0.5px solid var(--bd-2);color:var(--tx-2);
  border-radius:var(--radius);padding:3px 7px;font-size:12px;cursor:pointer;
  margin-left:4px;font-family:inherit;line-height:1;
}
.t-acts .t-act:hover{color:var(--tx-1);background:var(--bg-page)}
.t-acts .t-act.danger:hover{color:var(--danger-tx);border-color:var(--danger);background:var(--danger-bg)}
.fillcell{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.t-bar{height:5px;width:90px;background:var(--bg-surface);border-radius:99px;overflow:hidden}
.t-bar>div{height:100%}
.t-empty{text-align:center;color:var(--tx-3);padding:24px}

@media (max-width:520px){
  .tabla-wrap{padding:16px 16px}
  .tabla-tools{gap:6px;flex-wrap:wrap}
  /* Cada control en su fila para evitar que el buscador colapse a ~100px junto
     a los filtros (bug visible a 375px). flex-basis:100% fuerza salto de línea
     dentro del flex-wrap. */
  .tabla-tools select,
  .tabla-tools .filtros,
  #tabla-q{flex-basis:100%;min-width:0;width:100%}
  .tabla-tools .filtros{justify-content:flex-start}
  /* Count a su propia línea */
  .tabla-count{margin-left:0;width:100%}
}

/* Botón de acceso a la base de eventos desde la cabecera del dashboard */
.navbtn{
  display:inline-flex;align-items:center;gap:6px;text-decoration:none;
  background:var(--info-bg);border:0.5px solid var(--info);color:var(--info-tx);
  border-radius:var(--radius);padding:7px 12px;font-size:13px;cursor:pointer;
}
.navbtn:hover{background:rgba(55,138,221,0.26)}

/* A1/A4 — foco visible en filas y cabeceras operables por teclado */
.tabla tr.clk:focus-visible{outline:2px solid var(--info);outline-offset:-2px}
.tabla th[data-sort]:focus-visible{outline:2px solid var(--info);outline-offset:-2px}
.t-cmp:focus-visible{outline:2px solid var(--info);outline-offset:2px}
/* U4 — indicador de llenado >120% (vendido supera el aforo) */
.t-overfill{font-size:10px;color:var(--tx-3);cursor:help}
