/* =============================================================================
   console.css — DTmember 用户端控制台 (style_id: saas-shadcn)
   视觉 1:1 参照 templates/saas-shadcn/preview/saas-shadcn.html。
   业务代码：所有颜色/间距/圆角/阴影/字号 均引用 var(--*) token（仅 0 / 1px 允许裸值）。
   ============================================================================= */

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  height: 100%;
  background: var(--color-surface-base);
  color: var(--color-text-primary);
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  -webkit-font-smoothing: antialiased;
}
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; }
a { color: var(--color-brand-primary-600); text-decoration: none; }
a:hover { text-decoration: underline; }
::selection { background: var(--color-brand-primary-200); color: var(--color-text-primary); }

:focus-visible {
  outline: var(--border-width-2) solid var(--color-border-focus);
  outline-offset: var(--border-width-2);
}

::-webkit-scrollbar { width: var(--spacing-3); height: var(--spacing-3); }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--color-border-default);
  border-radius: var(--radius-full);
  border: var(--border-width-2) solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--color-border-strong); background-clip: padding-box; }
* { scrollbar-width: thin; scrollbar-color: var(--color-border-default) transparent; }

:root { --sb-w: var(--comp-width-sm); --tb-h: var(--comp-height-xl); }

/* ---------- Layout ---------- */
.app { display: grid; grid-template-columns: var(--sb-w) 1fr; grid-template-rows: var(--tb-h) 1fr; height: 100%; }
.app.no-shell { grid-template-columns: 1fr; grid-template-rows: 1fr; }
.app.no-shell .topbar, .app.no-shell .sidebar { display: none; }
.topbar { grid-column: 1 / -1; }
.sidebar {
  grid-row: 2; overflow-y: auto;
  background: var(--color-surface-raised);
  border-right: var(--border-width-1) solid var(--color-border-subtle);
}
.main { grid-row: 2; overflow: auto; padding: var(--spacing-6) var(--spacing-8); }
.app.no-shell .main { grid-row: 1; }
.main.center { display: grid; place-items: center; padding: var(--spacing-6); }

/* ---------- TopBar ---------- */
.topbar {
  display: flex; align-items: center; gap: var(--spacing-4);
  padding: 0 var(--spacing-4);
  background: var(--color-surface-raised);
  border-bottom: var(--border-width-1) solid var(--color-border-subtle);
}
.brand { display: flex; align-items: center; gap: var(--spacing-2); font-weight: var(--font-weight-semibold); }
.brand-mark {
  width: var(--comp-height-sm); height: var(--comp-height-sm);
  border-radius: var(--radius-md);
  background: var(--color-brand-primary-600);
  color: var(--color-text-onBrand);
  display: grid; place-items: center;
  font-weight: var(--font-weight-bold); font-size: var(--font-size-sm);
  letter-spacing: var(--letter-spacing-tight);
}
.brand-mark.brand-logo {
  display: block;
  object-fit: contain;
  background: transparent;
  padding: 2px;
}
.search {
  flex: 1; max-width: var(--comp-width-3xl); margin: 0 auto;
  display: flex; align-items: center; gap: var(--spacing-2);
  height: var(--comp-height-md); padding: 0 var(--spacing-3);
  background: var(--color-surface-base);
  border: var(--border-width-1) solid var(--color-border-default);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
}
.search input { flex: 1; background: transparent; border: 0; outline: 0; }
.kbd {
  font-family: var(--font-family-mono); font-size: var(--font-size-xs);
  padding: var(--comp-spacing-0-5) var(--spacing-2);
  border: var(--border-width-1) solid var(--color-border-default);
  border-radius: var(--radius-sm);
  background: var(--color-surface-raised);
  color: var(--color-text-secondary);
}
.tb-actions { display: flex; align-items: center; gap: var(--spacing-2); margin-left: auto; }
.icon-btn {
  width: var(--comp-height-md); height: var(--comp-height-md); border-radius: var(--radius-md);
  display: grid; place-items: center; color: var(--color-text-secondary);
  position: relative;
}
.icon-btn:hover { background: var(--color-surface-base); color: var(--color-text-primary); }
.icon-btn .dot {
  position: absolute; top: var(--spacing-2); right: var(--spacing-2);
  width: var(--spacing-2); height: var(--spacing-2); border-radius: var(--radius-full);
  background: var(--color-red-500);
  border: var(--border-width-2) solid var(--color-surface-raised);
}

/* ---------- Avatar ---------- */
.avatar {
  flex-shrink: 0;
  width: var(--spacing-8); height: var(--spacing-8);
  border-radius: var(--radius-full);
  background: var(--color-surface-sunken);
  color: var(--color-text-secondary);
  border: var(--border-width-1) solid var(--color-border-default);
  display: inline-grid; place-items: center;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-tight);
}
.avatar.sq { border-radius: var(--radius-md); }
.avatar.xs { width: var(--spacing-6); height: var(--spacing-6); font-size: var(--font-size-xs); }
.avatar.sm { width: var(--comp-height-sm); height: var(--comp-height-sm); font-size: var(--font-size-xs); }
.avatar.lg { width: var(--spacing-12); height: var(--spacing-12); font-size: var(--font-size-lg); }
.avatar.xl { width: var(--spacing-16); height: var(--spacing-16); font-size: var(--font-size-xl); }
.avatar.tint-1 { color: var(--color-chart-categorical1); border-color: color-mix(in srgb, var(--color-chart-categorical1) 38%, var(--color-border-default)); background: color-mix(in srgb, var(--color-chart-categorical1) 12%, var(--color-surface-sunken)); }
.avatar.tint-2 { color: var(--color-chart-categorical2); border-color: color-mix(in srgb, var(--color-chart-categorical2) 38%, var(--color-border-default)); background: color-mix(in srgb, var(--color-chart-categorical2) 12%, var(--color-surface-sunken)); }
.avatar.tint-3 { color: var(--color-chart-categorical3); border-color: color-mix(in srgb, var(--color-chart-categorical3) 38%, var(--color-border-default)); background: color-mix(in srgb, var(--color-chart-categorical3) 12%, var(--color-surface-sunken)); }
.avatar.tint-4 { color: var(--color-chart-categorical4); border-color: color-mix(in srgb, var(--color-chart-categorical4) 38%, var(--color-border-default)); background: color-mix(in srgb, var(--color-chart-categorical4) 12%, var(--color-surface-sunken)); }
.avatar.tint-5 { color: var(--color-chart-categorical5); border-color: color-mix(in srgb, var(--color-chart-categorical5) 38%, var(--color-border-default)); background: color-mix(in srgb, var(--color-chart-categorical5) 12%, var(--color-surface-sunken)); }
.avatar.tint-6 { color: var(--color-chart-categorical6); border-color: color-mix(in srgb, var(--color-chart-categorical6) 38%, var(--color-border-default)); background: color-mix(in srgb, var(--color-chart-categorical6) 12%, var(--color-surface-sunken)); }

/* ---------- Sidebar ---------- */
.nav { padding: var(--spacing-3); }
.nav-group-title {
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  color: var(--color-text-tertiary);
  text-transform: uppercase; letter-spacing: var(--letter-spacing-wide);
  padding: var(--spacing-2) var(--spacing-3); margin-top: var(--spacing-3);
}
.nav-item {
  display: flex; align-items: center; gap: var(--spacing-3);
  padding: var(--spacing-2) var(--spacing-3);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  cursor: pointer; position: relative;
  font-weight: var(--font-weight-medium);
  margin: 1px 0;
  transition: background var(--duration-fast) var(--ease-standard),
              color var(--duration-fast) var(--ease-standard);
}
.nav-item .ic { width: var(--icon-size-lg); height: var(--icon-size-lg); flex: 0 0 var(--icon-size-lg); }
.nav-item .count {
  margin-left: auto; font-size: var(--font-size-xs);
  background: var(--color-surface-base);
  color: var(--color-text-tertiary);
  padding: 1px var(--spacing-2);
  border-radius: var(--radius-full);
}
.nav-item:hover { background: var(--color-surface-base); color: var(--color-text-primary); }
.nav-item.active { background: var(--color-surface-base); color: var(--color-brand-primary-600); }
.nav-item.active::before {
  content: ""; position: absolute; left: -1px; top: var(--spacing-2); bottom: var(--spacing-2);
  width: var(--border-width-2); border-radius: var(--radius-full);
  background: var(--color-brand-primary-600);
}
.nav-divider { height: 1px; background: var(--color-border-subtle); margin: var(--spacing-3) var(--spacing-2); }

/* ---------- Page header ---------- */
.page-header { display: flex; align-items: flex-start; gap: var(--spacing-4); margin-bottom: var(--spacing-6); }
.page-title { font-size: var(--font-size-3xl); font-weight: var(--font-weight-bold); letter-spacing: var(--letter-spacing-tight); }
.page-sub { color: var(--color-text-secondary); margin-top: var(--spacing-1); }
.page-actions { margin-left: auto; display: flex; gap: var(--spacing-2); align-items: center; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: var(--spacing-2);
  height: var(--comp-height-md); padding: 0 var(--spacing-4);
  border-radius: var(--radius-md);
  border: var(--border-width-1) solid transparent;
  font-weight: var(--font-weight-medium); font-size: var(--font-size-sm);
  transition: background var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.btn:focus-visible { outline: var(--border-width-2) solid var(--color-border-focus); outline-offset: var(--border-width-2); }
.btn-primary { background: var(--color-brand-primary-600); color: var(--color-text-onBrand); }
.btn-primary:hover { background: var(--color-brand-primary-700); }
.btn-primary:active { background: var(--color-brand-primary-800); }
.btn-secondary { background: var(--color-surface-raised); color: var(--color-text-primary); border-color: var(--color-border-default); }
.btn-secondary:hover { background: var(--color-surface-base); border-color: var(--color-border-strong); }
.btn-ghost { background: transparent; color: var(--color-text-primary); }
.btn-ghost:hover { background: var(--color-surface-base); }
.btn-danger { background: var(--color-red-500); color: var(--color-text-onBrand); }
.btn-danger:hover { background: var(--color-red-700); }
.btn-link { background: transparent; color: var(--color-brand-primary-600); padding: 0; height: auto; }
.btn-link:hover { text-decoration: underline; }
.btn[disabled], .btn[aria-disabled="true"] { opacity: var(--opacity-40); pointer-events: none; }
.btn-sm { height: var(--comp-height-sm); padding: 0 var(--spacing-3); font-size: var(--font-size-xs); }
.btn-lg { height: var(--comp-height-lg); padding: 0 var(--spacing-5); font-size: var(--font-size-base); }
.btn-icon { width: var(--comp-height-md); padding: 0; justify-content: center; }
.btn-block { width: 100%; justify-content: center; }
.field > .btn:not(.btn-block) { align-self: flex-start; }

/* ---------- Card / Section ---------- */
.card {
  background: var(--color-surface-raised);
  border: var(--border-width-1) solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--spacing-5);
  box-shadow: var(--shadow-sm);
}
.card-h { display: flex; align-items: center; gap: var(--spacing-3); margin-bottom: var(--spacing-4); }
.card-h h3 { font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); }
.card-h .right { margin-left: auto; display: flex; gap: var(--spacing-2); align-items: center; }
.card-stacked { padding: 0; overflow: hidden; }
.card-stacked > .card-section { padding: var(--spacing-5); }
.card-stacked > .card-section + .card-section { border-top: var(--border-width-1) solid var(--color-border-subtle); }
.section { margin-bottom: var(--spacing-8); }
.section-title { font-size: var(--font-size-xl); font-weight: var(--font-weight-semibold); margin-bottom: var(--spacing-4); }

/* ---------- Grid utility ---------- */
.grid { display: grid; gap: var(--spacing-4); }
.g-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.g-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.g-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.muted { color: var(--color-text-secondary); }
.tertiary { color: var(--color-text-tertiary); }
.row { display: flex; align-items: center; gap: var(--spacing-3); }
.stack { display: flex; flex-direction: column; gap: var(--spacing-3); }
.spacer { flex: 1; }
.xs-text { font-size: var(--font-size-xs); }
.sm-text { font-size: var(--font-size-sm); }

/* ---------- KPI Card ---------- */
.kpi { display: flex; flex-direction: column; gap: var(--spacing-2); }
.kpi-label { color: var(--color-text-secondary); font-size: var(--font-size-sm); display: flex; align-items: center; gap: var(--spacing-2); }
.kpi-value { font-size: var(--font-size-3xl); font-weight: var(--font-weight-bold); letter-spacing: var(--letter-spacing-tight); }
.kpi-delta { display: inline-flex; align-items: center; gap: var(--spacing-1); font-size: var(--font-size-xs); font-weight: var(--font-weight-medium); }
.kpi-delta.up { color: var(--color-green-500); }
.kpi-delta.down { color: var(--color-red-500); }

/* ---------- Pill / Badge / Tag ---------- */
.pill {
  display: inline-flex; align-items: center; gap: var(--comp-spacing-1-5);
  height: var(--spacing-6); padding: 0 var(--spacing-2);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs); font-weight: var(--font-weight-medium);
  border: var(--border-width-1) solid var(--color-border-default);
  background: var(--color-surface-base);
  color: var(--color-text-secondary);
}
.pill::before { content: ""; width: var(--comp-spacing-1-5); height: var(--comp-spacing-1-5); border-radius: var(--radius-full); background: currentColor; }
.pill.success { color: var(--color-status-success-fg); border-color: var(--color-status-success-border); background: var(--color-status-success-bg); }
.pill.warning { color: var(--color-status-warning-fg); border-color: var(--color-status-warning-border); background: var(--color-status-warning-bg); }
.pill.error   { color: var(--color-status-error-fg);   border-color: var(--color-status-error-border);   background: var(--color-status-error-bg); }
.pill.info    { color: var(--color-status-info-fg);    border-color: var(--color-status-info-border);    background: var(--color-status-info-bg); }
.pill.no-dot::before { display: none; }
.llm-test-msg { margin: 0; }
.llm-test-msg.is-ok { color: var(--color-status-success-fg); }
.llm-test-msg.is-fail { color: var(--color-status-error-fg); }
.model-test-result { display: inline-block; white-space: nowrap; }
.model-test-result.is-ok { color: var(--color-status-success-fg); font-weight: var(--font-weight-medium); }
.model-test-result.is-fail { color: var(--color-status-error-fg); font-weight: var(--font-weight-medium); }
.badge {
  display: inline-block; min-width: var(--spacing-5); height: var(--spacing-5); padding: 0 var(--comp-spacing-1-5);
  background: var(--color-brand-primary-600); color: var(--color-text-onBrand);
  border-radius: var(--radius-full); font-size: var(--font-size-xs);
  text-align: center; line-height: var(--spacing-5); font-weight: var(--font-weight-semibold);
}
.tag {
  display: inline-flex; align-items: center; gap: var(--spacing-1);
  padding: 0 var(--spacing-2); height: var(--spacing-6); border-radius: var(--radius-sm);
  background: var(--color-surface-base); color: var(--color-text-primary);
  border: var(--border-width-1) solid var(--color-border-subtle);
  font-size: var(--font-size-xs);
}
.tag .x { color: var(--color-text-tertiary); cursor: pointer; }

/* ---------- Form controls ---------- */
.field { display: flex; flex-direction: column; gap: var(--spacing-2); }
.field-row { display: grid; grid-template-columns: var(--comp-width-xs) 1fr; gap: var(--spacing-4); align-items: flex-start; padding: var(--spacing-4) 0; }
.field-row + .field-row { border-top: var(--border-width-1) solid var(--color-border-subtle); }
.field-row .lhs { padding-top: var(--spacing-2); }
.field-row .lhs .l { font-weight: var(--font-weight-medium); }
.field-row .lhs .h { color: var(--color-text-secondary); font-size: var(--font-size-sm); margin-top: var(--spacing-1); }
.label { font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); color: var(--color-text-primary); }
.input, .textarea, .select {
  height: var(--comp-height-md); padding: 0 var(--spacing-3);
  background: var(--color-surface-raised);
  border: var(--border-width-1) solid var(--color-border-default);
  border-radius: var(--radius-md); color: var(--color-text-primary);
  outline: 0; width: 100%;
  transition: border-color var(--duration-fast) var(--ease-standard),
              box-shadow var(--duration-fast) var(--ease-standard);
}
.input::placeholder, .textarea::placeholder { color: var(--color-text-tertiary); }
.input:focus, .textarea:focus, .select:focus {
  border-color: var(--color-border-focus);
  box-shadow: 0 0 0 var(--spacing-1) var(--color-brand-primary-100);
}
.input[aria-invalid="true"] { border-color: var(--color-red-500); }
.input[disabled] { background: var(--color-surface-base); color: var(--color-text-disabled); }
.input.sm { height: var(--comp-height-sm); font-size: var(--font-size-sm); }
.input.code { letter-spacing: var(--spacing-2); font-family: var(--font-family-mono); }
.textarea { height: auto; padding: var(--spacing-3); min-height: var(--spacing-24); resize: vertical; line-height: var(--line-height-normal); }
.help { font-size: var(--font-size-xs); color: var(--color-text-tertiary); }
.help.error { color: var(--color-red-500); }
.input-group { display: flex; align-items: stretch; }
.input-group .input { border-radius: 0; flex: 1; }
.input-group > :first-child { border-top-left-radius: var(--radius-md); border-bottom-left-radius: var(--radius-md); }
.input-group > :last-child { border-top-right-radius: var(--radius-md); border-bottom-right-radius: var(--radius-md); }
.input-group .ig-addon {
  display: inline-flex; align-items: center; padding: 0 var(--spacing-3);
  background: var(--color-surface-base); border: var(--border-width-1) solid var(--color-border-default);
  color: var(--color-text-secondary); font-size: var(--font-size-sm);
}
.input-group .ig-addon + .input { border-left: 0; }
.input-group .input + .ig-addon { border-left: 0; }

/* Number input: hide native spinners, use custom stepper */
.input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
.input[type="number"]::-webkit-outer-spin-button,
.input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.number-stepper { position: relative; display: flex; width: 100%; }
.number-stepper > .input[type="number"] {
  padding-right: calc(var(--spacing-8) + var(--spacing-2));
  border-top-right-radius: var(--radius-md);
  border-bottom-right-radius: var(--radius-md);
}
.number-stepper > .stepper {
  position: absolute; top: 1px; right: 1px; bottom: 1px;
  width: var(--spacing-8);
  display: flex; flex-direction: column;
  border-left: var(--border-width-1) solid var(--color-border-default);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  overflow: hidden;
}
.number-stepper > .stepper .stepper-btn {
  flex: 1; display: flex; align-items: center; justify-content: center;
  padding: 0; border: 0; background: var(--color-surface-base);
  color: var(--color-text-secondary); cursor: pointer;
  transition: background var(--duration-fast) var(--ease-standard),
              color var(--duration-fast) var(--ease-standard);
}
.number-stepper > .stepper .stepper-btn + .stepper-btn {
  border-top: var(--border-width-1) solid var(--color-border-subtle);
}
.number-stepper > .stepper .stepper-btn:hover {
  background: var(--color-surface-sunken);
  color: var(--color-text-primary);
}
.number-stepper > .stepper .stepper-btn:active {
  background: var(--color-brand-primary-100);
  color: var(--color-brand-primary-600);
}
.number-stepper > .stepper .stepper-btn svg {
  width: 12px; height: 12px; pointer-events: none;
}
.number-stepper > .input:focus + .stepper .stepper-btn {
  border-color: var(--color-border-focus);
}
.input-group .number-stepper { flex: 1; min-width: 0; }
.input-group .number-stepper > .input { border-radius: 0; }
.input-group .number-stepper > .stepper { border-radius: 0; }
.input-group > .number-stepper:not(:first-child) > .input {
  border-top-left-radius: 0; border-bottom-left-radius: 0;
}
.input-group > .number-stepper:not(:last-child) > .input,
.input-group > .number-stepper:not(:last-child) > .stepper {
  border-top-right-radius: 0; border-bottom-right-radius: 0;
}

.checkbox, .radio { display: inline-flex; align-items: center; gap: var(--spacing-2); cursor: pointer; }
.checkbox input, .radio input {
  appearance: none; width: var(--spacing-4); height: var(--spacing-4);
  border: var(--border-width-1) solid var(--color-border-strong);
  background: var(--color-surface-raised);
  border-radius: var(--radius-sm); display: grid; place-items: center;
  flex: 0 0 var(--spacing-4);
}
.radio input { border-radius: var(--radius-full); }
.checkbox input:checked, .radio input:checked { background: var(--color-brand-primary-600); border-color: var(--color-brand-primary-600); }
.checkbox input:checked::after { content: ""; width: var(--spacing-2); height: var(--spacing-1); border-left: var(--border-width-2) solid var(--color-text-onBrand); border-bottom: var(--border-width-2) solid var(--color-text-onBrand); transform: rotate(-45deg) translate(1px,-1px); }
.radio input:checked::after { content: ""; width: var(--comp-spacing-1-5); height: var(--comp-spacing-1-5); background: var(--color-text-onBrand); border-radius: var(--radius-full); }

.check-row {
  display: flex; align-items: flex-start; gap: var(--spacing-3);
  cursor: pointer; user-select: none;
  padding: var(--spacing-2) 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-sm);
}
.check-row input[type="checkbox"] {
  appearance: none; width: var(--spacing-4); height: var(--spacing-4); margin-top: 2px;
  border: var(--border-width-1) solid var(--color-border-strong);
  background: var(--color-surface-raised);
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  flex: 0 0 var(--spacing-4);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.check-row input[type="checkbox"]:checked {
  background: var(--color-brand-primary-600);
  border-color: var(--color-brand-primary-600);
}
.check-row input[type="checkbox"]:checked::after {
  content: ""; width: var(--spacing-2); height: var(--spacing-1);
  border-left: var(--border-width-2) solid var(--color-text-onBrand);
  border-bottom: var(--border-width-2) solid var(--color-text-onBrand);
  transform: rotate(-45deg) translate(1px,-1px);
}
.check-row input[type="checkbox"]:focus-visible {
  outline: var(--border-width-2) solid var(--color-border-focus);
  outline-offset: 2px;
}

/* ---------- Switch (shadcn) ---------- */
.switch {
  display: flex; align-items: center; gap: var(--spacing-3);
  cursor: pointer; user-select: none;
}
.switch input {
  position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;
}
.switch-track {
  position: relative; flex: 0 0 44px; width: 44px; height: 24px;
  border-radius: var(--radius-full);
  background: var(--color-surface-sunken);
  border: var(--border-width-1) solid var(--color-border-default);
  transition: background var(--duration-normal) var(--ease-standard),
              border-color var(--duration-normal) var(--ease-standard);
}
.switch-track::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 18px; height: 18px; border-radius: var(--radius-full);
  background: var(--color-surface-raised);
  border: var(--border-width-1) solid var(--color-border-subtle);
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration-normal) var(--ease-standard),
              background var(--duration-normal) var(--ease-standard),
              border-color var(--duration-normal) var(--ease-standard);
}
.switch input:checked + .switch-track {
  background: var(--color-brand-primary-600);
  border-color: var(--color-brand-primary-600);
}
.switch input:checked + .switch-track::after {
  transform: translateX(20px);
  background: var(--color-text-onBrand);
  border-color: transparent;
}
.switch input:focus-visible + .switch-track {
  outline: var(--border-width-2) solid var(--color-border-focus);
  outline-offset: 2px;
}
.switch-label {
  display: flex; flex-direction: column; gap: 2px; min-width: 0;
}
.switch-label strong { font-weight: var(--font-weight-medium); font-size: var(--font-size-sm); }

/* ---------- Segmented ---------- */
.segmented { display: inline-flex; padding: var(--spacing-1); background: var(--color-surface-base); border-radius: var(--radius-md); gap: var(--comp-spacing-0-5); border: var(--border-width-1) solid var(--color-border-subtle); }
.segmented button { padding: var(--spacing-1) var(--spacing-3); border-radius: var(--radius-sm); color: var(--color-text-secondary); font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); }
.segmented button[aria-pressed="true"] { background: var(--color-surface-raised); color: var(--color-text-primary); box-shadow: var(--shadow-sm); }

/* ---------- Tabs ---------- */
.tabs { display: flex; gap: 0; border-bottom: var(--border-width-1) solid var(--color-border-subtle); margin-bottom: var(--spacing-5); }
.tab { padding: var(--spacing-3) var(--spacing-4); color: var(--color-text-secondary); font-weight: var(--font-weight-medium); border-bottom: var(--border-width-2) solid transparent; margin-bottom: -1px; cursor: pointer; }
.tab:hover { color: var(--color-text-primary); }
.tab[aria-selected="true"] { color: var(--color-brand-primary-600); border-bottom-color: var(--color-brand-primary-600); }

/* ---------- Table ---------- */
.table-wrap { border: var(--border-width-1) solid var(--color-border-subtle); border-radius: var(--radius-lg); overflow: hidden; background: var(--color-surface-raised); }
.table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); }
.table th, .table td { padding: var(--spacing-3) var(--spacing-4); text-align: left; }
.table thead { background: var(--color-surface-base); color: var(--color-text-secondary); font-weight: var(--font-weight-semibold); font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: var(--letter-spacing-wide); }
.table thead th { border-bottom: var(--border-width-1) solid var(--color-border-subtle); }
.table tbody tr { border-top: var(--border-width-1) solid var(--color-border-subtle); }
.table tbody tr:hover { background: var(--color-surface-base); }
.table .num { text-align: right; font-variant-numeric: tabular-nums; }
.table .check-col { width: var(--comp-height-md); }

/* ---------- Adaptive table (全部模型等) ---------- */
.table-adaptive-wrap { overflow-x: auto; }
.table-adaptive {
  table-layout: auto;
  width: 100%;
}
.table-adaptive th,
.table-adaptive td {
  white-space: normal;
  word-break: break-word;
  vertical-align: middle;
}
.table-adaptive .col-name,
.table-adaptive .cell-name { min-width: 6rem; }
.table-adaptive .col-provider,
.table-adaptive .cell-provider { min-width: 4rem; }
.table-adaptive .col-type,
.table-adaptive .cell-type { width: 1%; white-space: nowrap; }
.table-adaptive .col-url,
.table-adaptive .cell-url { min-width: 8rem; max-width: 20rem; }
.table-adaptive .col-model,
.table-adaptive .cell-model { min-width: 6rem; max-width: 14rem; }
.table-adaptive .col-weight,
.table-adaptive .cell-weight {
  min-width: 3.5rem;
  width: 3.5rem;
  white-space: nowrap;
  text-align: center;
  font-variant-numeric: tabular-nums;
  text-transform: none;
  letter-spacing: normal;
}
.table-adaptive .col-status,
.table-adaptive .cell-status { width: 1%; white-space: nowrap; }
.table-adaptive .col-actions,
.table-adaptive .cell-actions {
  min-width: 17rem;
  width: 17rem;
  white-space: nowrap;
}
.table-adaptive .table-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--spacing-1);
  justify-content: flex-end;
  align-items: center;
}
.table-adaptive .table-actions form { display: inline-flex; margin: 0; flex-shrink: 0; }
.table-adaptive .table-actions .btn {
  flex: 0 0 auto;
  width: auto;
  white-space: nowrap;
  padding-left: var(--spacing-2);
  padding-right: var(--spacing-2);
}

/* ---------- Pagination ---------- */
.pagination { display: inline-flex; gap: var(--comp-spacing-0-5); }
.pagination .pg {
  min-width: var(--spacing-8); height: var(--spacing-8); padding: 0 var(--spacing-2);
  border-radius: var(--radius-sm);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-text-secondary); font-size: var(--font-size-sm);
}
.pagination .pg:hover { background: var(--color-surface-base); color: var(--color-text-primary); }
.pagination .pg[aria-current="page"] { background: var(--color-brand-primary-600); color: var(--color-text-onBrand); }
.pagination .pg[disabled] { opacity: var(--opacity-40); pointer-events: none; }

/* ---------- List ---------- */
.list-item { display: flex; align-items: center; gap: var(--spacing-3); padding: var(--spacing-3); border-radius: var(--radius-md); }
.list-item:hover { background: var(--color-surface-base); }
.avgrp { display: inline-flex; }
.avgrp .avatar { width: var(--comp-height-sm); height: var(--comp-height-sm); font-size: var(--font-size-xs); border: var(--border-width-2) solid var(--color-surface-raised); margin-left: calc(-1 * var(--spacing-2)); }
.avgrp .avatar:first-child { margin-left: 0; }

/* ---------- Progress / Spinner / Skeleton ---------- */
.progress { width: 100%; height: var(--comp-spacing-1-5); background: var(--color-surface-base); border-radius: var(--radius-full); overflow: hidden; }
.progress.sm { height: var(--spacing-1); }
.progress > div { height: 100%; background: var(--color-brand-primary-600); border-radius: var(--radius-full); transition: width var(--duration-normal) var(--ease-standard); }
.progress > div.ok { background: var(--color-green-500); }
.spinner { width: var(--spacing-4); height: var(--spacing-4); border-radius: var(--radius-full); border: var(--border-width-2) solid var(--color-surface-base); border-top-color: var(--color-brand-primary-600); animation: spin 800ms linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.skeleton { background: var(--color-surface-base); border-radius: var(--radius-md); animation: shimmer 1400ms ease-in-out infinite; }
@keyframes shimmer { 0%,100% { opacity: var(--opacity-60); } 50% { opacity: var(--opacity-100); } }

/* ---------- Alert / Toast ---------- */
.alert {
  display: flex; align-items: flex-start; gap: var(--spacing-3);
  padding: var(--spacing-3) var(--spacing-4);
  border: var(--border-width-1) solid var(--color-border-default);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
}
.alert.success { background: var(--color-status-success-bg); border-color: var(--color-status-success-border); color: var(--color-status-success-fg); }
.alert.warning { background: var(--color-status-warning-bg); border-color: var(--color-status-warning-border); color: var(--color-status-warning-fg); }
.alert.error   { background: var(--color-status-error-bg);   border-color: var(--color-status-error-border);   color: var(--color-status-error-fg); }
.alert.info    { background: var(--color-status-info-bg);    border-color: var(--color-status-info-border);    color: var(--color-status-info-fg); }
.alert .body { color: var(--color-text-primary); flex: 1; }
.toast {
  position: fixed; right: var(--spacing-6); bottom: var(--spacing-6); z-index: var(--z-toast);
  display: inline-flex; align-items: center; gap: var(--spacing-3);
  padding: var(--spacing-3) var(--spacing-4);
  background: var(--color-surface-raised);
  border: var(--border-width-1) solid var(--color-border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
}

/* ---------- Empty / Code ---------- */
.empty { display: flex; flex-direction: column; align-items: center; gap: var(--spacing-3); padding: var(--spacing-12) var(--spacing-6); color: var(--color-text-tertiary); text-align: center; }
.empty .glyph { width: var(--spacing-16); height: var(--spacing-16); border-radius: var(--radius-full); background: var(--color-surface-base); display: grid; place-items: center; color: var(--color-text-secondary); }
.empty h4 { color: var(--color-text-primary); font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); }
pre.code, code.inline {
  font-family: var(--font-family-mono); font-size: var(--font-size-sm);
  background: var(--color-surface-base);
  border: var(--border-width-1) solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
}
pre.code { padding: var(--spacing-4); overflow: auto; line-height: var(--line-height-relaxed); }
code.inline { padding: 1px var(--comp-spacing-1-5); }

/* ---------- Markdown body (docs / generated content) ---------- */
.markdown-body { font-size: var(--font-size-sm); line-height: var(--line-height-relaxed); color: var(--color-text-secondary); }
.markdown-body p { margin-bottom: var(--spacing-3); }
.markdown-body p:last-child { margin-bottom: 0; }
.markdown-body pre { background: var(--color-surface-base); border: var(--border-width-1) solid var(--color-border-subtle); border-radius: var(--radius-md); padding: var(--spacing-4); overflow-x: auto; font-family: var(--font-family-mono); font-size: var(--font-size-sm); line-height: var(--line-height-relaxed); margin: var(--spacing-3) 0; }
.markdown-body code { font-family: var(--font-family-mono); font-size: var(--font-size-xs); background: var(--color-surface-base); padding: 1px var(--spacing-1-5); border-radius: var(--radius-sm); color: var(--color-text-primary); }
.markdown-body pre code { background: transparent; padding: 0; }
.markdown-body table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); margin: var(--spacing-3) 0; }
.markdown-body table th, .markdown-body table td { padding: var(--spacing-2) var(--spacing-3); border: var(--border-width-1) solid var(--color-border-subtle); text-align: left; }
.markdown-body table th { background: var(--color-surface-base); font-weight: var(--font-weight-semibold); color: var(--color-text-primary); }
.markdown-body table tbody tr:nth-child(even) { background: var(--color-surface-sunken); }
.markdown-body ul, .markdown-body ol { padding-left: var(--spacing-5); margin: var(--spacing-2) 0; }
.markdown-body li { margin: var(--spacing-1) 0; }
.markdown-body blockquote { border-left: var(--border-width-2) solid var(--color-brand-primary-600); padding-left: var(--spacing-3); margin: var(--spacing-3) 0; color: var(--color-text-secondary); }
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4 { font-weight: var(--font-weight-semibold); color: var(--color-text-primary); margin: var(--spacing-4) 0 var(--spacing-2); }
.markdown-body strong { color: var(--color-text-primary); }
.markdown-body a { color: var(--color-brand-primary-600); }
.markdown-body hr { border: 0; border-top: var(--border-width-1) solid var(--color-border-subtle); margin: var(--spacing-4) 0; }

/* ---------- Charts (pure SVG) ---------- */
.chart { width: 100%; aspect-ratio: 600 / 220; }
.chart-grid { stroke: var(--color-chart-gridLine); stroke-dasharray: 2 4; }
.chart-axis { fill: var(--color-chart-axisLabel); font-size: var(--font-size-xs); font-family: var(--font-family-mono); }
.chart-line { fill: none; stroke: var(--color-chart-categorical1); stroke-width: 2; }
.chart-area { fill: var(--color-chart-categorical1); opacity: var(--opacity-10); }
.chart-bar  { fill: var(--color-chart-categorical1); }
.chart-bar2 { fill: var(--color-chart-categorical2); }

/* ---------- Scrim / Drawer / Dialog ---------- */
.scrim { position: fixed; inset: 0; background: color-mix(in srgb, var(--color-neutral-950) 45%, transparent); z-index: var(--z-overlay); display: none; }
.scrim.show { display: block; }
.dialog {
  position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: var(--comp-width-3xl); max-width: calc(100vw - var(--spacing-8));
  background: var(--color-surface-raised);
  border: var(--border-width-1) solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-modal); display: none; flex-direction: column;
}
.dialog.show { display: flex; }
.dialog header { padding: var(--spacing-5); font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); }
.dialog .body { padding: 0 var(--spacing-5) var(--spacing-5); color: var(--color-text-secondary); }
.dialog footer { padding: var(--spacing-4) var(--spacing-5); border-top: var(--border-width-1) solid var(--color-border-subtle); display: flex; gap: var(--spacing-2); justify-content: flex-end; }

/* ---------- Auth (sign-in) ---------- */
.auth-card { width: var(--comp-width-360); max-width: calc(100vw - var(--spacing-8)); }
.auth-card .brand-mark { width: var(--spacing-10); height: var(--spacing-10); margin: 0 auto var(--spacing-3); }
.auth-card .brand-mark.brand-logo { display: block; margin-left: auto; margin-right: auto; }
.auth-card h2 { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); text-align: center; }
.auth-card .sub { color: var(--color-text-secondary); text-align: center; margin-top: var(--spacing-2); }
.divider-text {
  display: flex; align-items: center; gap: var(--spacing-3);
  color: var(--color-text-tertiary); font-size: var(--font-size-xs);
  text-transform: uppercase; letter-spacing: var(--letter-spacing-wide);
  margin: var(--spacing-4) 0;
}
.divider-text::before, .divider-text::after { content: ""; flex: 1; height: 1px; background: var(--color-border-subtle); }
.auth-tabs {
  display: flex; gap: var(--spacing-2); padding: var(--spacing-1);
  background: var(--color-surface-sunken); border-radius: var(--radius-md);
}
.auth-tab {
  flex: 1; padding: var(--spacing-2) var(--spacing-3);
  border: none; border-radius: var(--radius-sm); background: transparent;
  color: var(--color-text-secondary); font-size: var(--font-size-sm); cursor: pointer;
}
.auth-tab.active {
  background: var(--color-surface); color: var(--color-text-primary);
  box-shadow: var(--shadow-sm); font-weight: var(--font-weight-medium);
}

/* ---------- Pricing ---------- */
.price-card { display: flex; flex-direction: column; gap: var(--spacing-4); }
.price-card.highlight { border-color: var(--color-brand-primary-600); position: relative; }
.price-card.highlight::before {
  content: "推荐";
  position: absolute; top: calc(-1 * var(--spacing-2)); left: 50%; transform: translateX(-50%);
  background: var(--color-brand-primary-600); color: var(--color-text-onBrand);
  padding: var(--comp-spacing-0-5) var(--spacing-3); border-radius: var(--radius-full);
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wide);
}
.price-card .name { font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: var(--letter-spacing-wide); }
.price-card .amount { font-size: var(--font-size-4xl); font-weight: var(--font-weight-bold); letter-spacing: var(--letter-spacing-tight); }
.price-card .amount small { font-size: var(--font-size-base); color: var(--color-text-tertiary); font-weight: var(--font-weight-regular); }
.price-card ul { list-style: none; display: flex; flex-direction: column; gap: var(--spacing-2); }
.price-card ul li { display: flex; align-items: center; gap: var(--spacing-2); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.check-ic { width: var(--spacing-4); height: var(--spacing-4); flex: 0 0 var(--spacing-4); color: var(--color-green-500); }

/* ---------- Manage mock data ---------- */
.mock-data-banner {
  display: flex; align-items: center; gap: var(--spacing-3); flex-wrap: wrap;
  padding: var(--spacing-3) var(--spacing-4);
  background: color-mix(in srgb, var(--color-status-warning-bg) 72%, transparent);
  border: var(--border-width-1) solid var(--color-status-warning-border);
  border-radius: var(--radius-lg);
}
.mock-data-banner-text { flex: 1; min-width: 12rem; font-size: var(--font-size-sm); color: var(--color-text-secondary); }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
