/* ============================================================
   DataWeaver Gateway Admin — Shared Components
   依赖:tokens.css
   ============================================================ */

/* ── Section label ───────────────────────────────────────── */
.sec-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .7px;
  margin-top: 22px;
  margin-bottom: 10px;
}
.sec-label:first-child { margin-top: 0; }

/* ── Stat cards (grid) ───────────────────────────────────── */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}

.card {
  background: var(--card);
  border: 1px solid var(--b);
  border-radius: var(--r-md);
  padding: 15px;
  transition: border-color var(--fast);
  box-shadow: var(--sh-sm);
}
.card:hover { border-color: var(--bh); }

.card-al  { border-top: 2px solid var(--accent); }
.card-gl  { border-top: 2px solid var(--green); }
.card-rl  { border-top: 2px solid var(--red); }
.card-sl  { border-top: 2px solid var(--sky); }
.card-aml { border-top: 2px solid var(--amber); }
.card-tl  { border-top: 2px solid var(--teal); }

.card-lbl {
  font-size: 10.5px;
  font-weight: 500;
  color: var(--t2);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 10px;
}
.card-val {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -.5px;
  line-height: 1;
  color: var(--t0);
  font-variant-numeric: tabular-nums;
}
.card-sub { font-size: 11px; color: var(--t3); margin-top: 5px; }

/* ── Tables ──────────────────────────────────────────────── */
.tbl-wrap {
  background: var(--card);
  border: 1px solid var(--b);
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: 16px;
  box-shadow: var(--sh-sm);
}

.tbl-wrap table { width: 100%; border-collapse: collapse; }

.tbl-wrap thead th {
  background: var(--s2);
  padding: 9px 14px;
  text-align: left;
  font-size: 10px;
  font-weight: 600;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .6px;
  border-bottom: 1px solid var(--b);
}
.tbl-wrap tbody tr { border-top: 1px solid var(--b); transition: background var(--fast); }
.tbl-wrap tbody tr:first-child { border-top: none; }
.tbl-wrap tbody tr:hover { background: var(--s3); }
.tbl-wrap tbody td {
  padding: 9px 14px;
  font-size: 12.5px;
  vertical-align: middle;
  color: var(--t1);
}

.td-mono { font-family: var(--font-mono); font-size: 11px; }
.td-dim  { color: var(--t2); }
.td-link { cursor: pointer; }
.td-link:hover td { color: var(--accent); }

/* ── Badges ──────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  border-radius: var(--r-sm);
  padding: 2px 7px;
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1.5;
}
.bg { background: var(--g-bg);  color: var(--green);  border: 1px solid var(--g-bd); }
.br { background: var(--r-bg);  color: var(--red);    border: 1px solid var(--r-bd); }
.bb { background: var(--sk-bg); color: var(--sky);    border: 1px solid var(--sk-bd); }
.ba { background: var(--am-bg); color: var(--amber);  border: 1px solid var(--am-bd); }
.bc { background: var(--a-bg);  color: var(--accent); border: 1px solid var(--a-bd); }
.bt { background: var(--tl-bg); color: var(--teal);   border: 1px solid var(--tl-bd); }
.bn { background: var(--s3);    color: var(--t2);     border: 1px solid var(--b); }

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: var(--r-sm);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  font-family: var(--font-sans);
  transition: all var(--fast) var(--ease);
  white-space: nowrap;
  letter-spacing: -.1px;
}
.btn:active   { transform: scale(.97); }
.btn:focus-visible { outline: 2px solid var(--sky); outline-offset: 2px; }

.btn-p  { background: var(--accent); color: #fff; box-shadow: 0 0 12px rgba(255, 92, 92, .28); }
.btn-p:hover { background: var(--accent-h); box-shadow: 0 0 20px rgba(255, 92, 92, .4); }

.btn-g  { background: var(--s2); color: var(--t1); border: 1px solid var(--b); }
.btn-g:hover  { background: var(--s3); border-color: var(--bh); }

.btn-d  { background: var(--r-bg); color: var(--red); border: 1px solid var(--r-bd); }
.btn-d:hover  { background: rgba(239, 68, 68, .15); }

.btn-tl { background: var(--tl-bg); color: var(--teal); border: 1px solid var(--tl-bd); }
.btn-tl:hover { background: rgba(20, 184, 166, .15); }

.btn-sm { padding: 4px 9px; font-size: 11px; }

/* ── Inputs ──────────────────────────────────────────────── */
.inp {
  background: var(--s2);
  border: 1px solid var(--b);
  color: var(--t1);
  border-radius: var(--r-sm);
  padding: 7px 11px;
  font-size: 12.5px;
  font-family: var(--font-sans);
  outline: none;
  transition: border-color var(--fast), box-shadow var(--fast);
}
.inp:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--a-glow); }
.inp::placeholder { color: var(--t3); }
select.inp { cursor: pointer; }
select option { background: var(--s2); }
textarea.inp {
  resize: vertical;
  font-family: var(--font-mono);
  font-size: 11.5px;
  min-height: 80px;
}

.form-input {
  background: var(--s2);
  border: 1px solid var(--b);
  border-radius: var(--r-sm);
  padding: 6px 10px;
  font-size: 12px;
  color: var(--t1);
  outline: none;
  transition: border-color var(--fast);
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-sans);
}
.form-input:focus { border-color: var(--accent); }
.form-input option { background: var(--s1); }
textarea.form-input { font-family: var(--font-mono); }

.form-group { display: flex; flex-direction: column; }
.form-row   { margin-bottom: 12px; }
.form-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--t2);
  margin-bottom: 5px;
  display: block;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.form-hint { font-size: 10.5px; color: var(--t3); margin-top: 4px; }

/* ── Page tabs ───────────────────────────────────────────── */
.pg-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--b);
  margin-bottom: 16px;
}
.pg-tab {
  padding: 9px 18px;
  font-size: 12px;
  font-weight: 500;
  color: var(--t2);
  cursor: pointer;
  border: none;
  background: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: all var(--fast) var(--ease);
  font-family: var(--font-sans);
}
.pg-tab:hover  { color: var(--t1); }
.pg-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.pg-tab-panel  { display: none; }
.pg-tab-panel.active { display: block; }

/* ── Empty state ─────────────────────────────────────────── */
.empty { text-align: center; padding: 44px 24px; }
.empty-icon  { width: 34px; height: 34px; margin: 0 auto 12px; opacity: .2; color: var(--t2); }
.empty-title { font-size: 13.5px; font-weight: 600; color: var(--t2); margin-bottom: 4px; }
.empty-hint  { font-size: 11.5px; color: var(--t3); }

/* ── Skeleton ────────────────────────────────────────────── */
.skel {
  border-radius: 4px;
  background: linear-gradient(90deg, var(--s2) 25%, var(--s3) 50%, var(--s2) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.6s infinite;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Toast ───────────────────────────────────────────────── */
/* 右上角:右下角留给 Copilot 气泡(meeting-admin 外壳),底部留给状态栏 */
#toast-wrap {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 7px;
  max-width: min(360px, calc(100vw - 36px));
  pointer-events: none;
}
.toast {
  pointer-events: auto;
  background: var(--s2);
  border: 1px solid var(--bh);
  border-radius: var(--r-md);
  padding: 9px 13px;
  font-size: 12.5px;
  color: var(--t1);
  display: flex;
  align-items: center;
  gap: 8px;
  box-shadow: var(--sh-lg);
  animation: slideIn var(--dur) var(--ease);
  max-width: 100%;
  word-break: break-word;
}
.toast-g { border-color: var(--g-bd); }
.toast-r { border-color: var(--r-bd); }
@keyframes slideIn {
  from { transform: translateX(12px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
/* 兼容:保留旧动画名,避免外部样式引用断裂 */
@keyframes slideUp {
  from { transform: translateX(12px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

/* ── Modal ───────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .65);
  backdrop-filter: blur(4px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur);
}
.modal-overlay.open { opacity: 1; pointer-events: all; }

.modal {
  background: var(--card);
  border: 1px solid var(--bh);
  border-radius: var(--r-lg);
  padding: 22px;
  width: min(520px, 90vw);
  box-shadow: var(--sh-lg);
  transform: scale(.97);
  transition: transform var(--dur) var(--ease);
}
.modal-overlay.open .modal { transform: scale(1); }

.modal-title { font-size: 16px; font-weight: 700; color: var(--t0); margin-bottom: 4px; }
.modal-desc  { font-size: 12px; color: var(--t2); margin-bottom: 16px; }
.modal-head  {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  font-size: 15px;
  font-weight: 700;
  color: var(--t0);
}
.modal-body  { margin-bottom: 8px; }
.modal-foot  {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--b);
}
.modal-close {
  background: none;
  border: none;
  font-size: 20px;
  color: var(--t3);
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
  border-radius: var(--r-sm);
}
.modal-close:hover { color: var(--t1); background: var(--s1); }

/* ── Theme toggle ────────────────────────────────────────── */
.theme-toggle {
  background: none;
  border: 1px solid var(--b);
  border-radius: var(--r-sm);
  width: 30px;
  height: 30px;
  cursor: pointer;
  color: var(--t2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--fast);
}
.theme-toggle:hover { border-color: var(--bh); color: var(--t1); }

/* ── Code block ──────────────────────────────────────────── */
.code {
  background: var(--s2);
  border: 1px solid var(--b);
  border-radius: var(--r-sm);
  padding: 12px 14px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--t2);
  white-space: pre-wrap;
  overflow-x: auto;
  max-height: 400px;
  overflow-y: auto;
}

/* ── Common utility (anti-mistake) ───────────────────────── */
:where(button, a, [role="button"]) { cursor: pointer; }
:where(button, a):focus-visible    { outline: 2px solid var(--sky); outline-offset: 2px; }

/* tabular numerals for stat / count cells */
.num-tabular { font-variant-numeric: tabular-nums; }
