:root { --fg:#222; --muted:#777; --bg:#fafafa; --card:#fff; --line:#e3e3e3; --accent:#3b6cdb; --ok:#2c8a3e; --warn:#b8860b; --bad:#b22222; }
* { box-sizing: border-box; }
body { font-family: -apple-system, "Helvetica Neue", "PingFang SC", "Microsoft YaHei", sans-serif; margin: 0; color: var(--fg); background: var(--bg); }
header.topbar { display:flex; align-items:center; gap:18px; padding:12px 24px; background:#fff; border-bottom:1px solid var(--line); }
header.topbar .brand { font-weight:700; color:var(--accent); text-decoration:none; }
header.topbar nav { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
header.topbar nav a { color:var(--fg); text-decoration:none; padding:4px 0; border-bottom:2px solid transparent; }
header.topbar nav a:hover { border-bottom-color:var(--accent); color:var(--accent); }
header.topbar .user { color:var(--muted); margin-left:auto; }
header.topbar button.link { background:none; border:none; color:var(--muted); cursor:pointer; }
main { max-width:1100px; margin:24px auto; padding:0 24px; }
h1 { font-size:22px; margin:8px 0 16px; }
h2 { font-size:18px; margin:24px 0 12px; }
.card { background:var(--card); border:1px solid var(--line); border-radius:8px; padding:16px; margin-bottom:16px; }
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:12px; margin-bottom:16px; }
.kpi { background:var(--card); border:1px solid var(--line); border-radius:8px; padding:14px; }
.kpi .label { color:var(--muted); font-size:13px; }
.kpi .value { font-size:22px; font-weight:700; margin-top:6px; }
table { width:100%; border-collapse:collapse; background:var(--card); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
th, td { padding:8px 12px; border-bottom:1px solid var(--line); text-align:left; font-size:14px; vertical-align:top; }
th { background:#f4f4f4; font-weight:600; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:#f9f9f9; }
.badge { display:inline-block; padding:2px 8px; border-radius:12px; font-size:12px; }
.badge.active { background:#e3f1e0; color:var(--ok); }
.badge.paused { background:#f5e6cc; color:var(--warn); }
.badge.pending { background:#e9eef9; color:var(--accent); }
.badge.approved { background:#e3f1e0; color:var(--ok); }
.badge.paid { background:#d3eaf0; color:#166; }
.badge.rejected { background:#f5d0d0; color:var(--bad); }
form.inline { display:inline; }
input, select, textarea, button { font:inherit; padding:6px 10px; border:1px solid var(--line); border-radius:6px; background:#fff; }
button { cursor:pointer; }
button.primary { background:var(--accent); color:#fff; border-color:var(--accent); }
button.danger { background:var(--bad); color:#fff; border-color:var(--bad); }
.muted { color:var(--muted); }
.error { color:var(--bad); margin:6px 0; }
.ok { color:var(--ok); margin:6px 0; }
.toolbar { display:flex; gap:8px; align-items:center; margin:12px 0; }
.toolbar form { display:flex; gap:6px; }
.code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; background:#f3f3f3; padding:2px 6px; border-radius:4px; }
.copy { background:#eee; border:1px solid var(--line); padding:2px 8px; border-radius:4px; cursor:pointer; font-size:12px; }
footer { text-align:center; color:var(--muted); padding:30px 0 50px; }
.right { text-align:right; }
.nowrap { white-space:nowrap; }
.alert { padding:10px 14px; border-radius:6px; margin-bottom:12px; }
.alert.info { background:#e9eef9; color:var(--accent); border:1px solid #c8d4ee; }
.alert.warn { background:#fff3d6; color:var(--warn); border:1px solid #e7d48b; }
