/* =======================================================
   tables.css — Bảng dữ liệu + action buttons
   ======================================================= */

/* --- Panel header (tiêu đề + nút thêm mới) --- */
.panel-header {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 16px;
}
.panel-header-title {
  font-size: 14px; font-weight: 600; color: var(--text);
}
.panel-header-spacer { flex: 1; }

/* Search box */
.search-box {
  display: flex; align-items: center; gap: 8px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 6px 12px;
  transition: border-color var(--transition);
}
.search-box:focus-within { border-color: var(--accent); }
.search-box svg { width: 13px; height: 13px; color: var(--text-dim); flex-shrink: 0; }
.search-box input {
  background: none; border: none; outline: none;
  font-size: 12px; color: var(--text);
  width: 160px;
}
.search-box input::placeholder { color: var(--text-dim); }

/* Nút thêm mới */
.btn-add {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  background: var(--accent); color: #0b0b0f;
  border-radius: var(--r); font-family: var(--mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  transition: opacity var(--transition), transform var(--transition);
}
.btn-add:hover  { opacity: 0.88; }
.btn-add:active { transform: scale(0.98); }
.btn-add svg { width: 13px; height: 13px; }

/* --- Table wrapper --- */
.table-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

table {
  width: 100%;
  border-collapse: collapse;
}

thead tr {
  border-bottom: 1px solid var(--border);
}

th {
  text-align: left;
  padding: 10px 16px;
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
  font-weight: 500;
  white-space: nowrap;
}

td {
  padding: 12px 16px;
  font-size: 13px;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

tbody tr:last-child td { border-bottom: none; }
tbody tr { transition: background var(--transition); }
tbody tr:hover { background: var(--surface2); }

/* Cột ID */
.td-id {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-dim);
}

/* Cột tên/username */
.td-name {
  font-weight: 500;
  color: var(--text);
}

/* Cột mono (version, token...) */
.td-mono {
  font-family: var(--mono);
  font-size: 12px;
}

/* Cột date */
.td-date {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
}

/* Cột actions */
.td-actions {
  display: flex; gap: 6px; align-items: center;
}

/* --- Status badges --- */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px;
  border-radius: 20px;
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.06em;
  font-weight: 500; white-space: nowrap;
}
.badge-green  { background: var(--green-dim);  color: var(--green);  border: 1px solid rgba(34,197,94,0.2); }
.badge-red    { background: var(--red-dim);    color: var(--red);    border: 1px solid rgba(239,68,68,0.2); }
.badge-amber  { background: var(--accent-dim); color: var(--accent); border: 1px solid rgba(245,158,11,0.2); }
.badge-blue   { background: var(--blue-dim);   color: var(--blue);   border: 1px solid rgba(96,165,250,0.2); }
.badge-purple { background: var(--purple-dim); color: var(--purple); border: 1px solid rgba(167,139,250,0.2); }
.badge-gray   {
  background: rgba(64,64,78,0.3);
  color: var(--text-dim);
  border: 1px solid var(--border);
}

/* --- Icon action buttons --- */
.btn-icon {
  width: 30px; height: 30px;
  border-radius: var(--r-sm);
  display: grid; place-items: center;
  color: var(--text-dim);
  border: 1px solid var(--border);
  transition: all var(--transition);
}
.btn-icon svg { width: 14px; height: 14px; }
.btn-icon:hover { color: var(--text); border-color: var(--border-hi); background: var(--surface3); }
.btn-icon.danger:hover  { color: var(--red);    border-color: rgba(239,68,68,0.35);    background: var(--red-dim); }
.btn-icon.success:hover { color: var(--green);  border-color: rgba(34,197,94,0.35);    background: var(--green-dim); }
.btn-icon.warn:hover    { color: var(--orange); border-color: rgba(251,146,60,0.35);   background: rgba(251,146,60,0.1); }
.btn-icon.info:hover    { color: var(--blue);   border-color: rgba(96,165,250,0.35);   background: var(--blue-dim); }
.btn-icon.accent:hover  { color: var(--accent); border-color: rgba(245,158,11,0.35); background: var(--accent-dim); }

/* Trạng thái trống */
.table-empty {
  text-align: center;
  padding: 48px 0;
  color: var(--text-dim);
}
.table-empty-icon { font-size: 28px; margin-bottom: 10px; opacity: 0.3; }
.table-empty-text { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; }

/* Pagination */
.pagination {
  display: flex; align-items: center; gap: 6px;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  font-family: var(--mono); font-size: 11px; color: var(--text-dim);
}
.pagination-spacer { flex: 1; }
.btn-page {
  padding: 4px 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  font-family: var(--mono); font-size: 11px;
  color: var(--text-dim);
  transition: all var(--transition);
}
.btn-page:hover:not(:disabled) { color: var(--text); border-color: var(--border-hi); background: var(--surface2); }
.btn-page:disabled { opacity: 0.3; cursor: not-allowed; }
