/* 巧儒 OA 极简样式 */
:root {
  --c-bg: #f7f7f5;
  --c-fg: #1f2328;
  --c-muted: #6b7280;
  --c-border: #e5e7eb;
  --c-accent: #0a4d4d;
  --c-accent-hover: #0d6363;
  --c-error: #b91c1c;
  --c-error-bg: #fef2f2;
  --c-notice: #064e3b;
  --c-notice-bg: #ecfdf5;
  --c-card: #ffffff;
  --r: 6px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Hiragino Sans GB',
               'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  background: var(--c-bg);
  color: var(--c-fg);
  font-size: 14px;
  line-height: 1.55;
}
a { color: var(--c-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 12px 24px;
  background: var(--c-card);
  border-bottom: 1px solid var(--c-border);
}
.topbar .brand { font-weight: 600; font-size: 16px; color: var(--c-fg); }
.topbar .nav { display: flex; gap: 16px; flex: 1; }
.topbar .nav a { color: var(--c-muted); }
.topbar .nav a:hover { color: var(--c-fg); }
.topbar .user { display: flex; align-items: center; gap: 12px; color: var(--c-muted); }
.topbar .user button.link {
  border: none; background: none; color: var(--c-muted); cursor: pointer;
  padding: 0; font: inherit; text-decoration: underline;
}

.main { max-width: 1080px; margin: 24px auto; padding: 0 24px; }
.foot {
  text-align: center; color: var(--c-muted); padding: 24px 0;
  font-size: 12px;
}

.panel {
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r);
  padding: 20px 24px;
  margin-bottom: 20px;
}
.panel.narrow { max-width: 480px; }
.panel h2 { margin-top: 0; font-size: 16px; }

.muted { color: var(--c-muted); }
.muted.small, .small { font-size: 12px; }
.error {
  background: var(--c-error-bg); color: var(--c-error);
  border: 1px solid #fecaca; padding: 8px 12px; border-radius: var(--r);
  margin-bottom: 12px;
}
.notice {
  background: var(--c-notice-bg); color: var(--c-notice);
  border: 1px solid #a7f3d0; padding: 12px 16px; border-radius: var(--r);
  margin-bottom: 16px;
}
.notice p { margin: 6px 0; }
.big-mono {
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', monospace;
  font-size: 18px; letter-spacing: 0.5px;
  background: #fff; border: 1px solid var(--c-border); padding: 8px 12px;
  border-radius: var(--r); display: inline-block;
}
.flashes { margin-bottom: 16px; }
.flash {
  background: #fef9c3; color: #854d0e; padding: 8px 12px;
  border-radius: var(--r); margin-bottom: 8px;
}

form label { display: block; margin-bottom: 12px; }
form label.check { display: inline-flex; gap: 6px; align-items: center; }
form input[type="text"],
form input[type="password"],
form input[type="date"],
form select {
  display: block;
  width: 100%; max-width: 320px;
  padding: 8px 10px;
  border: 1px solid var(--c-border); border-radius: var(--r);
  background: #fff;
  font: inherit;
}
form button {
  background: var(--c-accent); color: #fff; border: none;
  padding: 8px 18px; border-radius: var(--r); cursor: pointer;
  font: inherit;
}
form button:hover { background: var(--c-accent-hover); }
form button.link {
  background: none; color: var(--c-accent); padding: 0;
  text-decoration: underline; cursor: pointer;
}
form button[disabled] { color: #9ca3af; cursor: not-allowed; text-decoration: none; }
form.inline { display: inline; }
form.row { display: flex; gap: 16px; flex-wrap: wrap; align-items: flex-end; }
form.row label { margin-bottom: 0; }
form.filters { display: flex; gap: 16px; flex-wrap: wrap; align-items: flex-end; margin-bottom: 16px; }
form.filters label { margin-bottom: 0; }

.latest-list {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.card {
  display: block;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r);
  padding: 14px 16px;
  color: var(--c-fg);
  text-decoration: none;
}
.card:hover {
  border-color: var(--c-accent);
  text-decoration: none;
}
.card-type { display: block; font-weight: 600; }
.card-meta { display: block; color: var(--c-muted); font-size: 12px; margin-top: 4px; }
.card-mtime { display: block; color: var(--c-muted); font-size: 11px; margin-top: 8px; }

.grid {
  width: 100%; border-collapse: collapse; margin-top: 8px;
}
.grid.wide { table-layout: auto; }
.grid th, .grid td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--c-border);
  text-align: left;
  font-size: 13px;
}
.grid th { color: var(--c-muted); font-weight: 500; background: #fafaf9; }
.grid .actions { white-space: nowrap; }
.grid .actions .inline + .inline { margin-left: 12px; }
.disabled { color: var(--c-error); }
.badge {
  display: inline-block; font-size: 11px;
  padding: 1px 6px; margin-left: 6px;
  background: #fef3c7; color: #854d0e; border-radius: 4px;
}
.pager { margin-top: 16px; display: flex; gap: 16px; }

.login-body {
  background: var(--c-bg);
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh; padding: 24px;
}
.login-card {
  background: #fff; border: 1px solid var(--c-border); border-radius: var(--r);
  padding: 32px; width: 100%; max-width: 360px;
}
.login-card h1 { margin: 0 0 4px; font-size: 20px; }
.login-card form input { width: 100%; max-width: none; }
.login-card form button { width: 100%; margin-top: 8px; }
