/*
 * Public bank directory (banks.astro) — searchable list of SPEI institutions
 * (code · name · aliases). Mirrors the app/admin APP.institutionDirectory look
 * using docs design tokens. Global stylesheet (CSP style-src 'self').
 */

.banks-tab { max-width: 1180px; }
.banks-tab__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl, 1.6rem);
  font-weight: var(--weight-bold, 700);
  color: var(--color-text);
  margin: 0 0 var(--space-2);
}
.banks-tab__lead {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin: 0 0 var(--space-5);
}

.banks-dir { display: flex; flex-direction: column; gap: var(--space-3); }

.banks-dir__toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.banks-dir__search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1 1 280px;
  min-width: 0;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 6px);
  background: var(--color-surface, var(--color-bg));
  color: var(--color-text-muted);
}
.banks-dir__search:focus-within { border-color: var(--color-link); }
.banks-dir__search input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  color: var(--color-text);
  font-size: var(--text-sm);
  outline: none;
}
.banks-dir__count {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.banks-dir__list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 6px);
  overflow: hidden;
}
.banks-dir__row {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.banks-dir__row[hidden] { display: none; }
.banks-dir__row:last-child { border-bottom: none; }
.banks-dir__row:hover { background: var(--color-bg-hover); }
.banks-dir__code {
  flex: 0 0 auto;
  min-width: 3.5ch;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold, 700);
  color: var(--color-text);
}
.banks-dir__main { min-width: 0; }
.banks-dir__name {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.banks-dir__aliases {
  margin-top: 2px;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.banks-dir__alias-lead { color: var(--color-text-muted); }
.banks-dir__aliases b { font-weight: var(--weight-semibold, 600); color: var(--color-text); }

.banks-dir__empty,
.banks-dir__state {
  padding: var(--space-6) var(--space-4);
  text-align: center;
}
.banks-dir__state-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--color-text);
  margin: 0 0 var(--space-1);
}
.banks-dir__state-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}
