:root { --dark:#172033; --side:#111827; --line:#e5e7eb; --blue:#2563eb; --green:#16a34a; --yellow:#ca8a04; --red:#dc2626; --muted:#6b7280; }
* { box-sizing: border-box; }
body { margin:0; font-family: Arial, "Microsoft YaHei", sans-serif; color:#111827; background:#f3f4f6; }
a { color:inherit; text-decoration:none; }
input, select, button { font:inherit; }
button, .btn { border:1px solid var(--line); background:white; padding:8px 12px; border-radius:6px; cursor:pointer; display:inline-flex; align-items:center; gap:6px; }
button.small, .btn.small { padding:6px 10px; min-width:62px; justify-content:center; }
.primary { background:var(--blue); color:white; border-color:var(--blue); }
.success { background:var(--green); color:white; border-color:var(--green); }
.warn { background:var(--yellow); color:white; border-color:var(--yellow); }
.danger { background:var(--red); color:white; border-color:var(--red); }
.mini { padding:4px 8px; margin-left:6px; }
.login-page { min-height:100vh; display:grid; place-items:center; background:linear-gradient(135deg,#eef2ff,#f8fafc); }
.login-page.dark { background:#111827; }
.login-card { width:min(420px,92vw); background:white; padding:34px; border-radius:8px; box-shadow:0 18px 55px rgba(15,23,42,.18); }
.login-card h1 { margin:0 0 8px; font-size:28px; }
.login-card p { margin:0 0 24px; color:var(--muted); }
label { display:grid; gap:6px; margin:0 0 14px; color:#374151; }
input, select { width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:6px; background:white; }
textarea { width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:6px; background:white; resize:vertical; font:inherit; }
.alert { padding:10px 12px; background:#fef2f2; color:#991b1b; border:1px solid #fecaca; border-radius:6px; margin-bottom:14px; }
.alert.ok { background:#ecfdf5; color:#166534; border-color:#bbf7d0; }
.admin-top { height:58px; background:var(--dark); color:white; display:flex; align-items:center; justify-content:space-between; padding:0 28px; }
.admin-top .brand { font-weight:700; font-size:18px; }
.admin-top nav { display:flex; gap:20px; color:#d1d5db; }
.admin-main { padding:26px; }
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:18px; }
.page-head h1 { margin:0; font-size:24px; }
.page-head span { color:var(--muted); }
.panel, .search-card, .table-panel { background:white; border:1px solid var(--line); border-radius:8px; padding:18px; margin-bottom:18px; }
.panel h2 { margin:0 0 14px; font-size:18px; }
.stat-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:14px; margin-bottom:18px; }
.stat-grid div { background:white; border:1px solid var(--line); border-radius:8px; padding:18px; }
.stat-grid b { display:block; font-size:28px; }
.stat-grid span { color:var(--muted); }
.inline-form { display:flex; gap:10px; align-items:center; }
.two-cols { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.grid-form { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; align-items:end; }
table { width:100%; border-collapse:collapse; font-size:14px; }
th, td { padding:11px 10px; border-bottom:1px solid var(--line); text-align:left; vertical-align:middle; }
th { color:#374151; background:#f9fafb; font-weight:700; }
.actions { display:flex; gap:6px; flex-wrap:wrap; }
.actions form { display:inline; }
.mono, code { font-family:Consolas, monospace; }
.badge { padding:4px 8px; border-radius:999px; background:#e5e7eb; }
.badge.valid { background:#dcfce7; color:#166534; }
.badge.disabled { background:#fee2e2; color:#991b1b; }
.narrow { max-width:520px; }
.data-shell { display:flex; min-height:100vh; background:#eef1f5; }
.data-single { display:block; }
.data-side { width:230px; background:var(--side); color:#cbd5e1; padding:20px 14px; }
.data-logo { color:white; font-size:20px; font-weight:700; padding:10px 12px 24px; }
.data-side a { display:block; padding:12px 14px; border-radius:6px; margin-bottom:8px; }
.data-side a.active, .data-side a:hover { background:#1f2937; color:white; }
.data-main { flex:1; min-width:0; }
.data-single .data-main { width:100%; min-height:100vh; }
.data-top { height:58px; background:#1f2937; color:white; display:flex; align-items:center; justify-content:space-between; padding:0 24px; }
.data-content { padding:22px; }
.search-card { display:grid; grid-template-columns:repeat(8, minmax(110px,1fr)); gap:12px; align-items:center; }
.detail-search { grid-template-columns:repeat(9, minmax(110px,1fr)); }
.field-inline { margin:0; gap:4px; font-size:12px; color:var(--muted); }
.field-inline input { margin-top:0; }
.toolbar { display:flex; gap:10px; align-items:center; margin-bottom:14px; }
.list-toolbar { flex-wrap:wrap; }
.toolbar-spacer { flex:1; min-width:20px; }
.toolbar form { display:inline; }
.thumb { width:46px; height:46px; object-fit:cover; border-radius:6px; background:#f3f4f6; }
.ellipsis { max-width:280px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.category-cell { min-width:150px; max-width:240px; color:#374151; }
.category-row { display:flex; align-items:center; justify-content:space-between; gap:18px; }
.category-row div { display:grid; gap:6px; }
.category-row span { color:var(--muted); }
.pager { display:flex; gap:12px; align-items:center; justify-content:flex-end; color:var(--muted); margin:16px 0; }
.kv { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.kv div { display:grid; gap:4px; padding:10px; background:#f9fafb; border-radius:6px; }
.kv b { color:#374151; }
pre { white-space:pre-wrap; word-break:break-word; background:#0f172a; color:#e5e7eb; padding:16px; border-radius:8px; max-height:62vh; overflow:auto; }
@media (max-width: 1000px) {
  .stat-grid, .two-cols, .grid-form, .search-card, .detail-search, .kv { grid-template-columns:1fr 1fr; }
  .data-side { width:190px; }
}
@media (max-width: 720px) {
  .data-shell { display:block; }
  .data-side { width:auto; }
  .admin-top, .data-top { height:auto; padding:14px; flex-wrap:wrap; gap:10px; }
  .stat-grid, .two-cols, .grid-form, .search-card, .detail-search, .kv { grid-template-columns:1fr; }
  .category-row { align-items:flex-start; flex-direction:column; }
}
