/* bisaas 控制台样式 —— 浅色默认 + 深色主题（data-theme="dark"） */
:root {
  color-scheme: light;
  --bg: #f6f8fa;
  --panel: #ffffff;
  --border: #d0d7de;
  --text: #1f2328;
  --muted: #656d76;
  --accent: #0969da;
  --accent2: #218bff;
  --accent-soft: #0969da14;
  --field-bg: #ffffff;
  --code-bg: #eff2f5;
  --th-bg: #f6f8fa;
  --hover: #f0f3f6;
  --good: #1a7f37;
  --bad: #cf222e;
  --shadow: 0 1px 3px rgba(27,31,36,.08);
}
html[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0e1116;
  --panel: #161b22;
  --border: #21262d;
  --text: #e6edf3;
  --muted: #7d8590;
  --accent: #58a6ff;
  --accent2: #1f6feb;
  --accent-soft: #1f6feb22;
  --field-bg: #0d1117;
  --code-bg: #0d1117;
  --th-bg: #161b22;
  --hover: #1b2129;
  --good: #7ee787;
  --bad: #ff7b72;
  --shadow: none;
}

* { box-sizing: border-box; }
body { margin: 0; font: 14px/1.5 -apple-system, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif; background: var(--bg); color: var(--text); }
a { color: var(--accent); text-decoration: none; }

nav.top { display: flex; align-items: center; gap: 4px; padding: 10px 20px; border-bottom: 1px solid var(--border); flex-wrap: wrap; background: var(--panel); }
nav.top .brand { font-weight: 700; font-size: 16px; margin-right: 14px; }
nav.top .brand small { color: var(--muted); font-weight: 400; font-size: 11px; }
nav.top a.link { padding: 6px 12px; border-radius: 6px; color: var(--text); font-size: 13px; }
nav.top a.link:hover { background: var(--hover); }
nav.top a.link.active { background: var(--accent-soft); color: var(--accent); }
nav.top .spacer { flex: 1; }
nav.top select { background: var(--field-bg); color: var(--text); border: 1px solid var(--border); border-radius: 6px; padding: 6px 10px; font-size: 13px; }
nav.top button.theme { background: transparent; border: 1px solid var(--border); color: var(--text); border-radius: 6px; padding: 5px 10px; cursor: pointer; font-size: 13px; margin-left: 8px; }

main { padding: 22px; max-width: 1200px; margin: 0 auto; }
h1.page { font-size: 18px; margin: 0 0 18px; font-weight: 600; }

.panel { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 16px; margin-bottom: 18px; box-shadow: var(--shadow); }
.panel h2 { font-size: 14px; margin: 0 0 12px; font-weight: 600; color: var(--text); }
.row { display: flex; gap: 10px; flex-wrap: wrap; align-items: end; }
.field { display: flex; flex-direction: column; gap: 4px; }
.field label { font-size: 11px; color: var(--muted); }
select, input, textarea { background: var(--field-bg); color: var(--text); border: 1px solid var(--border); border-radius: 6px; padding: 7px 9px; font-size: 13px; font-family: inherit; }
textarea { width: 100%; min-height: 120px; font-family: ui-monospace, Menlo, monospace; }
button { background: var(--accent); color: #fff; border: 0; border-radius: 6px; padding: 8px 16px; font-size: 13px; cursor: pointer; }
button:hover { filter: brightness(1.08); }
button.ghost { background: var(--panel); border: 1px solid var(--border); color: var(--text); }
button.sm { padding: 4px 9px; font-size: 12px; }

.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin-bottom: 18px; }
.card { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; box-shadow: var(--shadow); }
.card .n { font-size: 26px; font-weight: 700; }
.card .l { color: var(--muted); font-size: 12px; margin-top: 3px; }

#chart, .chart { height: 340px; }
table { width: 100%; border-collapse: collapse; font-size: 12px; }
th, td { text-align: left; padding: 7px 9px; border-bottom: 1px solid var(--border); vertical-align: top; }
th { color: var(--muted); font-weight: 500; }
td.ev { color: var(--good); font-weight: 600; }
.muted { color: var(--muted); }
.err { color: var(--bad); font-size: 12px; }
.scroll { max-height: 460px; overflow: auto; }

/* 漏斗 */
.funnel-step { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.funnel-step .bar { height: 34px; background: linear-gradient(90deg, var(--accent2), var(--accent)); border-radius: 6px; min-width: 2px; }
.funnel-step .meta { font-size: 12px; color: var(--text); white-space: nowrap; }

/* 留存矩阵 */
.retn td.cell { text-align: center; color: var(--text); }
.retn .cohort { color: var(--muted); white-space: nowrap; }
