:root {
  color-scheme: light;

  /* —— 基础调色板 —— */
  --bg: #f6f7f9;
  --panel: #ffffff;
  --panel-sunken: #fbfcfd;
  --line: #d8dde5;
  --text: #17202a;
  --muted: #637083;

  /* —— 品牌现代深青(单一来源:不在任何页内重定义颜色) —— */
  --accent: #0e7490;
  --accent-strong: #155e75;
  --accent-tint: #e0f2f7;

  /* —— 两类语义绿(不要用 --accent 代替) —— */
  --save: #15803d;       /* 省钱数 / 降幅% */

  /* —— 危险 / 破坏性 —— */
  --danger: #a13d32;

  /* —— 风险三色:文本前景 / 浅底 / 实心图形 —— */
  --risk-red: #b91c1c;   --risk-red-bg: #fef2f2;   --risk-red-solid: #ef4444;
  --risk-amber: #b45309; --risk-amber-bg: #fffbeb; --risk-amber-solid: #f59e0b;
  --risk-green: #047857; --risk-green-bg: #ecfdf5; --risk-green-solid: #22c55e;

  /* —— 字体(零 Web 字体:系统栈 + CJK 回退) —— */
  --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei",
    "Source Han Sans SC", "Noto Sans CJK SC", sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas,
    "Liberation Mono", monospace;

  /* —— 字号阶梯(px;只用 400/600/700/800) —— */
  --fs-display: 44px; --fs-h1-page: 28px; --fs-h1: 22px; --fs-h2-page: 20px;
  --fs-lead: 17px; --fs-h2: 15px; --fs-body: 14px; --fs-metric: 24px;
  --fs-sm: 13px; --fs-xs: 12px;

  /* —— 间距(8px 基) —— */
  --space-1: 4px;  --space-2: 8px;  --space-3: 12px; --space-4: 16px; --space-5: 20px;
  --space-6: 24px; --space-8: 32px; --space-10: 40px; --space-12: 48px;

  /* —— 圆角 —— */
  --radius-sm: 6px; --radius: 8px; --radius-lg: 12px; --radius-pill: 999px;

  /* —— 阴影(克制) —— */
  --shadow-sm: 0 1px 2px rgba(23, 32, 42, .04);
  --shadow-md: 0 4px 18px rgba(13, 71, 90, .10);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-width: 320px;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  line-height: 1.65; /* 中文友好基准行高;此前为 normal(~1.2)显得拥挤 */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

/* —— 基础元素默认(此前缺失)—— */
a { color: var(--accent-strong); }
a:hover { color: var(--accent); }
img { max-width: 100%; height: auto; }
textarea {
  width: 100%; min-height: 38px; padding: 8px 10px;
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--panel); color: var(--text); font: inherit; line-height: 1.6;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 28px;
  border-bottom: 1px solid var(--line);
  background: #ffffff;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.3;
}

h2 {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
}

h3 {
  line-height: 1.4;
}

.topbar p {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.icon-button {
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--text);
  font-size: 20px;
  cursor: pointer;
}

.layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(340px, 0.9fr);
  gap: 16px;
  padding: 16px;
}

.panel {
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.summary-panel {
  grid-column: 1 / -1;
}

.section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.section-title span {
  color: var(--muted);
  font-size: 12px;
}

.metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 12px;
}

.metrics div {
  min-height: 74px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfd;
}

.metrics span,
label {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.metrics strong {
  display: block;
  margin-top: 8px;
  font-size: 24px;
}

.model-list,
.project-list,
.recommendation-list,
.transaction-list {
  display: grid;
  gap: 10px;
}

.empty {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.item {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
}

.item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.item strong {
  font-size: 14px;
}

.item code {
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tag {
  padding: 3px 7px;
  border-radius: 999px;
  background: var(--accent-tint);
  color: var(--accent-strong);
  font-size: 12px;
}

.disabled {
  color: var(--danger);
}

.key-form,
.recharge-form,
.example-form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  gap: 10px;
  align-items: end;
  margin-top: 16px;
}

.token-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
  margin-top: 16px;
}

.model-form,
.project-form {
  display: grid;
  gap: 10px;
  align-items: end;
  margin-top: 16px;
}

.model-form {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.project-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wide-field {
  grid-column: span 2;
}

.check-field {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  color: var(--text);
}

.check-field input {
  width: 16px;
  min-height: 16px;
  margin: 0;
}

.project-form button {
  grid-column: 1 / -1;
}

.model-form button {
  grid-column: span 1;
}

input,
select,
button {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--text);
  font: inherit;
}

input,
select {
  margin-top: 5px;
  padding: 0 10px;
}

button {
  padding: 0 14px;
  background: var(--accent);
  color: #ffffff;
  cursor: pointer;
}

.secret-output {
  min-height: 46px;
  margin: 12px 0 0;
  overflow-x: auto;
  white-space: pre-wrap;
  color: var(--accent-strong);
  font-size: 12px;
}

.code-output {
  min-height: 132px;
  margin: 12px 0 0;
  overflow-x: auto;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfd;
  color: var(--text);
  white-space: pre;
  font-size: 12px;
  line-height: 1.55;
}

.transaction-list {
  margin-top: 12px;
}

.secondary-button {
  border-color: var(--line);
  background: #ffffff;
  color: var(--accent-strong);
}

.table-wrap {
  overflow-x: auto;
}

table {
  width: 100%;
  min-width: 920px;
  border-collapse: collapse;
  font-size: 13px;
}

th,
td {
  padding: 10px 8px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

th {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}

@media (max-width: 900px) {
  .layout,
  .metrics,
  .key-form,
  .project-form,
  .model-form,
  .token-form,
  .recharge-form,
  .example-form {
    grid-template-columns: 1fr;
  }

  .wide-field,
  .model-form button {
    grid-column: auto;
  }

  .topbar {
    padding: 16px;
  }

  .item-header {
    display: grid;
    align-items: start;
  }
}

/* Public landing page */
.landing {
  display: grid;
  gap: 44px;
  padding: 40px 32px 64px;
  max-width: 1200px;
  margin: 0 auto;
}

/* 两栏 hero:左推介、右实时数据(对标 Artificial Analysis / OpenRouter 的"先给数据") */
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 44px;
  align-items: center;
}
.hero-grid--solo { grid-template-columns: 1fr; }
.landing-hero { max-width: 600px; }
.hero-data {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--panel);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}
.hero-data .hd-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: var(--space-3); }
.hero-data .hd-head h2 { font-size: var(--fs-h2); font-weight: 700; }
.hero-data .hd-head a { font-size: var(--fs-sm); color: var(--accent-strong); text-decoration: none; white-space: nowrap; }
.hero-data .hd-foot { margin: var(--space-3) 0 0; color: var(--muted); font-size: var(--fs-xs); }
@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; gap: 28px; }
  .landing-hero { max-width: 720px; }
}

.eyebrow {
  margin: 0 0 10px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.landing-hero h1 {
  margin: 0;
  font-size: 44px;
  line-height: 1.1;
}

.landing-hero > p {
  margin-top: 16px;
  max-width: 640px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.7;
}

.landing-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.primary-link,
.ghost-link {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
}

.primary-link {
  background: var(--accent);
  color: #fff;
}

.ghost-link {
  border: 1px solid var(--line);
  color: var(--text);
}

.landing-points {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
}

/* flex 纵向 + 统一 gap:徽章/标题/正文/按钮/链接之间有均匀呼吸,不再挤成一坨 */
.landing-points article {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}

/* 徽章/胶囊 hug 内容(不被 flex 拉满宽);正文等保持 stretch 填满卡片 */
.landing-points .badge { align-self: flex-start; }

.landing-points h2 {
  margin: 0;
  font-size: 18px;
}

.landing-points p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.landing-points .source-note,
.landing-points .landing-actions,
.landing-points .muted-note { margin: 0; }

.muted-note {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.landing-hero .promise {
  margin: 0 0 14px;
  padding: 8px 12px;
  border-left: 3px solid var(--accent);
  background: var(--accent-tint);
  border-radius: 0 6px 6px 0;
  font-size: 14px;
  color: #0c4a5e;
}

/* ============================================================
   设计系统组件库(handoff README §6)— 公共类,页面不再内联颜色
   ============================================================ */

/* —— 无障碍:skip link + 统一焦点态 —— */
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  padding: 8px 14px; background: var(--accent); color: #fff;
  border-radius: 0 0 var(--radius) 0; text-decoration: none;
}
.skip-link:focus { left: 0; }
:focus-visible { outline: 2px solid var(--accent-strong); outline-offset: 2px; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* —— 标准对外导航(7 项 + /console 按钮) —— */
.nav { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.nav a {
  color: var(--muted); font-size: var(--fs-sm); text-decoration: none;
  min-height: 44px; display: inline-flex; align-items: center;
}
.nav a:hover { color: var(--text); }
.nav a[aria-current="page"] { color: var(--accent-strong); font-weight: 600; }
.nav .nav-cta {
  background: var(--accent); color: #fff; padding: 0 14px;
  border-radius: var(--radius); font-weight: 700;
}
.nav .nav-cta:hover { color: #fff; filter: brightness(1.05); }

/* —— 首页区块(OpenRouter 式:数据条 / 模型一览 / drop-in / CTA band)—— */
.home-section { display: grid; gap: var(--space-3); }
.home-section > .hd-head { margin-bottom: 0; }
.home-section .section { margin: 0; }
.home-diff { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
@media (max-width: 760px) { .home-diff { grid-template-columns: 1fr; } }
.home-cta { text-align: center; border: 1px solid var(--accent); background: var(--accent-tint); border-radius: var(--radius-lg); padding: var(--space-10) var(--space-6); display: grid; justify-items: center; gap: var(--space-3); }
.home-cta h2 { font-size: var(--fs-h2-page); font-weight: 700; }
.home-cta .landing-actions { margin: 0; }

/* —— 模型目录(OpenRouter 式:搜索 + 筛选侧栏 + 密集可排序行)—— */
.models-toolbar { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; margin: var(--space-4) 0; }
.models-toolbar input[type="search"] { flex: 1 1 220px; max-width: 380px; min-height: 40px; }
.models-toolbar select { width: auto; min-height: 40px; }
.models-count { color: var(--muted); font-size: var(--fs-sm); margin-left: auto; }
.models-layout { display: grid; grid-template-columns: 210px minmax(0, 1fr); gap: var(--space-6); align-items: start; }
.models-filters { display: grid; gap: var(--space-5); position: sticky; top: var(--space-4); }
.filter-group h3 { font-size: var(--fs-sm); font-weight: 700; margin: 0 0 var(--space-2); }
.filter-group label { display: flex; align-items: center; gap: 8px; color: var(--text); font-size: var(--fs-sm); min-height: 32px; cursor: pointer; }
.filter-group label input { width: auto; min-height: auto; min-width: auto; margin: 0; }
.model-row { display: grid; grid-template-columns: minmax(0, 1.7fr) repeat(5, minmax(0, 1fr)); gap: var(--space-3); align-items: center; padding: var(--space-3) var(--space-4); border: 1px solid var(--line); border-radius: var(--radius); background: var(--panel); margin-bottom: var(--space-2); }
.model-row .m-name { font-weight: 700; font-size: var(--fs-body); }
.model-row .m-meta { color: var(--muted); font-size: var(--fs-xs); margin-top: 3px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.model-row .m-stat { text-align: right; font-variant-numeric: tabular-nums; }
.model-row .m-stat .lbl { display: block; color: var(--muted); font-size: var(--fs-xs); }
.model-row .m-stat .val { font-size: var(--fs-sm); font-weight: 600; }
.model-row .m-stat .val.save { color: var(--save); }

/* —— OpenRouter 式模型卡片 —— */
.model-card { display: flex; gap: var(--space-3); align-items: flex-start; padding: var(--space-4); border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--panel); margin-bottom: var(--space-3); }
.model-card:hover { border-color: var(--accent); }
.oc-avatar { flex: 0 0 40px; width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: var(--fs-sm); }
.oc-body { flex: 1; min-width: 0; }
.oc-title { font-weight: 700; font-size: var(--fs-lead); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.oc-prov { color: var(--muted); font-weight: 600; }
.oc-sep { color: var(--muted); margin-left: -4px; }
.oc-desc { color: var(--muted); font-size: var(--fs-sm); margin: 5px 0 12px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.oc-src { color: var(--accent-strong); white-space: nowrap; }
.oc-note { color: var(--muted); font-size: var(--fs-xs); flex-basis: 100%; }
.badge--mod { color: var(--accent-strong); background: var(--accent-tint); }
.oc-stats { display: flex; flex-wrap: wrap; gap: var(--space-5); }
.oc-stat { display: flex; flex-direction: column; }
.oc-stat-lbl { color: var(--muted); font-size: var(--fs-xs); }
.oc-stat-val { font-weight: 700; font-variant-numeric: tabular-nums; font-size: var(--fs-body); }
@media (max-width: 820px) {
  .models-layout { grid-template-columns: 1fr; }
  .models-filters { position: static; grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .model-row { grid-template-columns: 1fr 1fr; }
  .model-row .m-id { grid-column: 1 / -1; }
  .model-row .m-stat { text-align: left; }
}

/* —— 品牌锁版(logo)—— */
.brand-link { display: inline-flex; align-items: center; min-height: 44px; }
.brand-logo { height: 30px; width: auto; display: block; }
.brand-mark { height: 28px; width: auto; display: block; }
.landing-logo { height: 52px; width: auto; display: block; margin: 0 0 18px; }

/* —— 内容页容器 —— */
.content { max-width: 1200px; margin: 0 auto; padding: var(--space-6) var(--space-5) var(--space-12); }
/* 宽容器装数据(表/网格/图全宽),窄栏装文字(正文不超易读行宽) */
.content > .sub, .content > .banner, .content > p { max-width: 760px; }
.content h1.page-title { font-size: var(--fs-h1-page); font-weight: 700; line-height: 1.25; margin: 0 0 var(--space-2); }
.content h2.section { font-size: var(--fs-h2-page); font-weight: 700; margin: var(--space-8) 0 var(--space-3); }
.content .sub { color: var(--muted); font-size: var(--fs-lead); line-height: 1.7; margin: 0 0 var(--space-3); }

/* —— 指标块 metric tile —— */
.metric-grid { display: grid; grid-template-columns: repeat(4, minmax(120px, 1fr)); gap: var(--space-3); }
.metric { min-height: 74px; padding: var(--space-4); border: 1px solid var(--line); border-radius: var(--radius); background: var(--panel-sunken); }
.metric-label { color: var(--muted); font-size: var(--fs-xs); }
.metric-value { display: block; margin-top: var(--space-2); font-size: var(--fs-metric); font-weight: 800; font-variant-numeric: tabular-nums; }
.metric-cap { color: var(--muted); font-size: var(--fs-xs); margin-top: 2px; }
.metric--save .metric-value { color: var(--save); }
.metric--warn .metric-value { color: var(--risk-amber); }

/* —— 风险徽章 badge(色 + 文字 + aria-label 三编码) —— */
.badge { display: inline-block; padding: 2px 10px; border-radius: var(--radius-pill); font-size: var(--fs-xs); font-weight: 700; }
.badge--red { color: var(--risk-red); background: var(--risk-red-bg); }
.badge--amber { color: var(--risk-amber); background: var(--risk-amber-bg); }
.badge--green { color: var(--risk-green); background: var(--risk-green-bg); }
.badge--ref { color: var(--danger); background: #fdecec; }

/* —— 承诺/提示条 banner(色 + 图标 + 文字三编码) —— */
.banner { display: flex; gap: var(--space-2); align-items: baseline; padding: var(--space-2) var(--space-3); border-left: 3px solid; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-size: var(--fs-body); margin: 0 0 var(--space-5); }
.banner--promise { border-color: var(--accent); background: var(--accent-tint); color: var(--accent-strong); }
.banner--warn { border-color: var(--risk-amber); background: var(--risk-amber-bg); color: #7c4a03; }
.banner--danger { border-color: var(--danger); background: #fdecec; color: var(--danger); }
.banner .ico { flex: 0 0 auto; }

/* —— 数据表:数字列 + 可排序指示 + 来源脚注 —— */
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
th[role="button"] { cursor: pointer; user-select: none; }
th[aria-sort="ascending"]::after { content: " ▲"; }
th[aria-sort="descending"]::after { content: " ▼"; }
th[aria-sort="none"]::after { content: " ↕"; color: var(--line); }
.source-note { margin: var(--space-2) 0 0; color: var(--muted); font-size: var(--fs-xs); line-height: 1.6; }
.source-note a { color: var(--accent-strong); }

/* —— 卡片变体 —— */
.item--feature { border-color: var(--accent); box-shadow: var(--shadow-md); position: relative; }
.item--promise > strong::before, .promise-line::before { content: "✓ "; color: var(--accent); }

/* —— 风险点列表 risk row —— */
.risk-row { display: flex; gap: var(--space-3); padding: var(--space-3) 0; border-bottom: 1px solid var(--line); }
.dot { flex: 0 0 10px; width: 10px; height: 10px; border-radius: 50%; margin-top: 5px; }
.dot--red { background: var(--risk-red-solid); }
.dot--amber { background: var(--risk-amber-solid); }
.dot--green { background: var(--risk-green-solid); }
.risk-row .rec { color: var(--accent-strong); }

/* —— CTA 按钮层级 —— */
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 0 18px; border-radius: var(--radius); font-weight: 700; text-decoration: none; cursor: pointer; border: 1px solid transparent; font: inherit; width: auto; }
.btn--primary { background: var(--accent); color: #fff; }
.btn--primary:hover { filter: brightness(1.05); }
.btn--secondary { background: #fff; color: var(--accent-strong); border-color: var(--line); }
.btn--ghost { background: transparent; color: var(--text); border-color: var(--line); }
.btn:disabled, .btn[aria-disabled="true"] { opacity: .6; cursor: default; }

/* —— 表单校验 —— */
.field-error { color: var(--danger); font-size: var(--fs-xs); margin-top: 4px; }
input[aria-invalid="true"], select[aria-invalid="true"], textarea[aria-invalid="true"] { border-color: var(--danger); }

/* —— 空 / 加载 / 错误态 —— */
.state { margin: var(--space-3) 0; color: var(--muted); font-size: var(--fs-sm); }
.state--empty { text-align: center; padding: var(--space-5); background: var(--panel-sunken); border: 1px dashed var(--line); border-radius: var(--radius); }
.state--error { color: var(--danger); }


/* —— 竖向柱状图(零依赖 SVG;按供应商配色 + 海外斜纹叠层 + 「(参照)」,a11y) —— */
.chart-title { margin: var(--space-6) 0 var(--space-2); font-size: var(--fs-h2-page); }
.chart-wrap svg { width: 100%; height: auto; display: block; }
.chart-wrap .vbar-label { fill: var(--text); font-size: 11px; }
.chart-wrap .vbar-val { fill: var(--muted); font-size: 11px; }
.chart-wrap .vbadge { fill: #fff; font-size: 9px; font-weight: 700; }
.chart-wrap .vhit { fill: transparent; cursor: default; }
.chart-wrap .vhit:hover { fill: var(--accent); fill-opacity: .07; }
.chart-tip { position: fixed; z-index: 60; pointer-events: none; max-width: 260px; background: var(--text); color: #fff; padding: 8px 10px; border-radius: var(--radius-sm); font-size: var(--fs-xs); line-height: 1.55; box-shadow: var(--shadow-md); }
.chart-tip[hidden] { display: none; }
.chart-tip strong { display: block; font-size: var(--fs-sm); margin-bottom: 2px; }
.chart-tip .t-sub { opacity: .8; margin-bottom: 2px; }
.chart-wrap .vaxis { stroke: var(--line); }
.chart-wrap .vgrid { stroke: var(--line); opacity: .4; }
.chart-wrap .vaxis-label { fill: var(--muted); font-size: 11px; }
.chart-legend { display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-4); margin: 0 0 var(--space-4); font-size: var(--fs-sm); color: var(--muted); }
.chart-legend .legend-item { display: inline-flex; align-items: center; gap: 6px; }
.chart-legend .legend-swatch { width: 12px; height: 12px; border-radius: 3px; display: inline-block; flex: 0 0 auto; }
/* 三图一行(对标 AA);窄屏堆叠 */
.chart-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-4); align-items: start; }
.chart-row .chart-col .chart-title { margin: 0 0 var(--space-1); font-size: var(--fs-h2); }
.chart-row .chart-col .source-note { margin-top: var(--space-2); }
@media (max-width: 760px) { .chart-row { grid-template-columns: 1fr; } }

/* —— 代码块 + 复制(深色营销 diff) —— */
.codecard { border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; background: #0f172a; }
.codecard .cap { display: flex; justify-content: space-between; align-items: center; padding: var(--space-2) var(--space-3); background: #1e293b; color: #cbd5e1; font-size: var(--fs-sm); }
.codecard .cap--after { background: var(--accent-strong); color: #cfeaf2; }
.codecard pre { margin: 0; padding: var(--space-4); overflow-x: auto; color: #e2e8f0; font-size: var(--fs-sm); line-height: 1.6; font-family: var(--font-mono); }
.codecard .hl { background: rgba(14, 116, 144, .4); display: inline-block; width: 100%; }
.copy { width: auto; min-height: 0; cursor: pointer; border: 1px solid #334155; background: #1e293b; color: #cbd5e1; border-radius: var(--radius-sm); padding: 2px 10px; font-size: var(--fs-xs); }
.copy.done { background: var(--save); color: #ecfdf5; border-color: var(--save); }

/* —— 合规绿灯(首屏 hero) —— */
.lamp { display: flex; gap: var(--space-3); align-items: center; padding: var(--space-4); border: 1px solid var(--line); border-radius: var(--radius); background: var(--panel-sunken); }
.lamp--green { background: var(--risk-green-bg); border-color: #a7f3d0; }
.lamp--amber { background: var(--risk-amber-bg); border-color: #fde68a; }
.lamp--red { background: var(--risk-red-bg); border-color: #fecaca; }
.lamp-dot { flex: 0 0 14px; width: 14px; height: 14px; border-radius: 50%; background: var(--muted); }
.lamp--green .lamp-dot { background: var(--risk-green-solid); }
.lamp--amber .lamp-dot { background: var(--risk-amber-solid); }
.lamp--red .lamp-dot { background: var(--risk-red-solid); }
.lamp-title { font-weight: 800; }
.lamp-sub { color: var(--muted); font-size: var(--fs-sm); margin-top: 2px; }

/* —— 各用途横条 —— */
.usebars { display: grid; gap: var(--space-2); margin-top: var(--space-2); }
.usebar { display: grid; grid-template-columns: 110px 1fr auto; gap: var(--space-3); align-items: center; font-size: var(--fs-sm); }
.usebar > span:first-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.usebar .track { height: 10px; border-radius: var(--radius-pill); background: var(--panel-sunken); border: 1px solid var(--line); overflow: hidden; }
.usebar .fill { display: block; height: 100%; background: var(--accent); }
.usebar--un .fill { background: var(--risk-amber-solid); }
.usebar .num { color: var(--muted); font-variant-numeric: tabular-nums; }

/* —— 一键接入:手动配置兜底 —— */
.manual-rows { display: grid; gap: var(--space-2); margin-top: var(--space-3); }
.manual-row { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.manual-row > .metric-label { flex: 0 0 72px; }
.manual-row code { background: var(--panel-sunken); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 2px 8px; white-space: pre-line; }

/* —— 分享卡片 —— */
.share-card { position: relative; padding: var(--space-12); background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-lg); }
.share-card .big { font-size: 48px; font-weight: 800; color: var(--save); font-variant-numeric: tabular-nums; }
.share-card .mark { position: absolute; top: var(--space-4); right: var(--space-4); color: var(--muted); font-size: var(--fs-xs); }

/* —— 统一页脚 —— */
.site-footer { border-top: 1px solid var(--line); margin-top: var(--space-12); padding: var(--space-8) var(--space-5); background: var(--panel); }
.site-footer .cols { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-6); }
.site-footer h3 { font-size: var(--fs-h2); font-weight: 700; margin: 0 0 var(--space-2); }
.site-footer a { color: var(--muted); text-decoration: none; font-size: var(--fs-sm); display: block; min-height: 28px; }
.site-footer a:hover { color: var(--text); }

/* —— 后台仪表盘布局(sidebar dashboard,学 sub2api 的布局,配色仍用弥聚) —— */
.dash-body { margin: 0; height: 100vh; overflow: hidden; background: var(--bg); }
.dash { display: flex; height: 100vh; }

.dash-sidebar { flex: 0 0 232px; width: 232px; background: var(--panel); border-right: 1px solid var(--line); display: flex; flex-direction: column; padding: var(--space-4) var(--space-3); gap: var(--space-2); overflow-y: auto; }
.dash-brand { display: flex; align-items: center; gap: 10px; padding: 4px 8px var(--space-4); text-decoration: none; color: var(--text); }
.dash-logo { width: 30px; height: 30px; }
.dash-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.dash-brand-text strong { font-size: var(--fs-h2); }
.dash-brand-text small { color: var(--muted); font-size: var(--fs-xs); }
.dash-nav { display: flex; flex-direction: column; gap: 2px; }
.dash-side-foot { margin-top: auto; padding-top: var(--space-3); border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 2px; }
.dash-nav-item { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: var(--radius); color: var(--muted); text-decoration: none; font-size: var(--fs-sm); font-weight: 600; cursor: pointer; }
.dash-nav-item:hover { background: var(--panel-sunken); color: var(--text); }
.dash-nav-item.is-active { background: var(--accent-tint); color: var(--accent-strong); }
.dash-nav-ico { flex: 0 0 18px; width: 18px; text-align: center; font-size: 14px; opacity: .85; }

.dash-main { flex: 1; min-width: 0; display: flex; flex-direction: column; height: 100vh; }
.dash-topbar { flex: 0 0 auto; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-3) var(--space-6); border-bottom: 1px solid var(--line); background: var(--panel); }
.dash-topbar-title h1 { font-size: var(--fs-h1); margin: 0; }
.dash-topbar-title p { color: var(--muted); font-size: var(--fs-sm); margin: 2px 0 0; }
.dash-topbar-right { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; justify-content: flex-end; }
.dash-health { color: var(--muted); font-size: var(--fs-sm); }
.dash-token-form { display: flex; gap: 6px; align-items: center; }
.dash-token-form input { min-height: 36px; }
.dash-token-form button { min-height: 36px; padding: 0 14px; width: auto; }

.dash-content { flex: 1; overflow-y: auto; padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-5); }
.dash-view { display: none; flex-direction: column; gap: var(--space-5); }
.dash-view.is-active { display: flex; }

.stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-4); }
.stat-card { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4); background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-lg); }
.stat-ico { flex: 0 0 44px; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; font-size: 18px; font-weight: 700; }
.stat-ico--a { background: var(--accent-tint); color: var(--accent-strong); }
.stat-ico--b { background: var(--risk-green-bg); color: var(--save); }
.stat-ico--c { background: var(--risk-amber-bg); color: var(--risk-amber); }
.stat-ico--d { background: #efeefe; color: #5b4ad1; }
.stat-body { display: flex; flex-direction: column; min-width: 0; }
.stat-label { color: var(--muted); font-size: var(--fs-xs); }
.stat-value { font-size: var(--fs-metric); font-weight: 800; font-variant-numeric: tabular-nums; }

.dash-charts { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-4); }
.chart-box { min-height: 180px; display: flex; align-items: center; justify-content: center; }
.donut-wrap { display: flex; gap: var(--space-4); align-items: center; flex-wrap: wrap; width: 100%; }
.donut-legend { display: grid; gap: 6px; flex: 1; min-width: 150px; }
.donut-leg { display: grid; grid-template-columns: 12px 1fr auto; gap: 8px; align-items: center; font-size: var(--fs-sm); }
.donut-sw { width: 12px; height: 12px; border-radius: 3px; }
.donut-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.donut-val { color: var(--muted); font-variant-numeric: tabular-nums; }
.trend-x { fill: var(--muted); font-size: 10px; }
.ops-rows { display: grid; gap: 0; }
.ops-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 4px; border-bottom: 1px solid var(--line); font-size: var(--fs-sm); }
.ops-row:last-child { border-bottom: none; }
.ops-row strong { font-variant-numeric: tabular-nums; }

@media (max-width: 1100px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } .dash-charts { grid-template-columns: 1fr; } }
@media (max-width: 820px) {
  .dash, .dash-main { height: auto; }
  .dash-body { height: auto; overflow: auto; }
  .dash { flex-direction: column; }
  .dash-sidebar { flex: 0 0 auto; width: auto; flex-direction: row; overflow-x: auto; border-right: none; border-bottom: 1px solid var(--line); }
  .dash-brand { display: none; }
  .dash-nav { flex-direction: row; }
  .dash-side-foot { margin-top: 0; border-top: none; padding-top: 0; flex-direction: row; }
  .dash-content { padding: var(--space-4); }
  .stat-grid { grid-template-columns: 1fr; }
}

/* —— 响应式 —— */
@media (max-width: 900px) {
  .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .site-footer .cols { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .metric-grid { grid-template-columns: 1fr; }
  .content { padding: var(--space-5) var(--space-4) var(--space-10); }
}
