/* PlaitoMaths admin DB viewer — builds on tutor.css + tokens.css */
.reset-row { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; margin-top: var(--sp-3); }
.reset-row select, .reset-row input { padding: 9px 12px; font: inherit; border: 1.5px solid var(--border-2); border-radius: var(--r-sm); }
.reset-row input { width: 140px; }
.reset-row .btn.danger { color: var(--bad); border-color: var(--bad); }

.tabs { display: flex; flex-wrap: wrap; gap: 6px; margin: var(--sp-5) 0 var(--sp-3); }
.tab { appearance: none; border: 1.5px solid var(--border-2); background: var(--surface); cursor: pointer;
  font: inherit; font-weight: 700; padding: 8px 14px; border-radius: var(--r-pill); color: var(--ink); }
.tab:hover { border-color: var(--brand); }
.tab.active { background: var(--brand); border-color: var(--brand); color: #fff; }
.tab .n { font-weight: 800; opacity: .7; margin-left: 6px; }

.grid-card { padding: var(--sp-4) var(--sp-5); }
.grid-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-3); }
.grid-scroll { overflow: auto; max-height: 65vh; margin-top: var(--sp-3); border: 1px solid var(--border); border-radius: var(--r-sm); }
.dbgrid { border-collapse: collapse; width: 100%; font-size: var(--fs-sm); }
.dbgrid th, .dbgrid td { border: 1px solid var(--border); padding: 6px 10px; text-align: left; vertical-align: top;
  white-space: nowrap; max-width: 380px; overflow: hidden; text-overflow: ellipsis; }
.dbgrid th { position: sticky; top: 0; background: var(--surface-2); font-weight: 800; z-index: 1; }
.dbgrid tbody tr:nth-child(even) { background: var(--surface-2); }
.dbgrid td.null { color: var(--ink-3); font-style: italic; }
