:root { --bg:#f4f7fb; --card:#fff; --line:#e2e8f0; --ink:#132238; --muted:#64748b; --blue:#315bea; --red:#dc2626; --green:#059669; }
* { box-sizing:border-box; }
body { margin:0; font-family:"Segoe UI","Microsoft YaHei",Arial,sans-serif; color:var(--ink); background:var(--bg); }
.sidebar { position:fixed; inset:0 auto 0 0; width:225px; background:#fff; border-right:1px solid var(--line); padding:28px 14px; display:flex; flex-direction:column; }
.brand { padding:0 12px 28px; color:#0f172a; font-size:26px; font-weight:700; }
.brand span { display:block; margin-top:6px; font-size:13px; font-weight:500; color:var(--muted); }
nav a { display:block; margin:3px 0; padding:13px 14px; border-radius:9px; color:#334155; text-decoration:none; font-weight:600; }
nav a:hover { background:#e8eeff; color:var(--blue); }
.user { margin-top:auto; padding:14px 12px; color:var(--muted); font-size:13px; border-top:1px solid var(--line); }
.link { border:0; background:none; color:var(--blue); padding:8px 0 0; cursor:pointer; }
.workspace { margin-left:225px; padding:30px; min-height:100vh; }
.auth-workspace { min-height:100vh; display:grid; place-items:center; }
.login-card { width:400px; background:#fff; padding:42px; border:1px solid var(--line); border-radius:18px; box-shadow:0 16px 42px #dce4f2; }
.login-card h1 { margin:0 0 6px; }
.login-card p { color:var(--muted); margin:0 0 28px; }
.login-card .auth-note { margin:16px 0 0; font-size:14px; }
.login-card .auth-note a { color:var(--blue); font-weight:700; }
.wide { width:100%; margin-top:12px; }
h1 { font-size:28px; margin:0 0 6px; }
h2 { margin:0 0 18px; font-size:18px; }
p { color:var(--muted); margin:0; }
.page-header { display:flex; align-items:flex-start; justify-content:space-between; gap:20px; margin-bottom:24px; }
.page-header .actions, .actions { display:flex; gap:10px; align-items:center; }
.card { background:var(--card); border:1px solid var(--line); border-radius:14px; padding:22px; margin-bottom:18px; }
.stats { display:flex; gap:16px; margin-bottom:20px; }
.stats article { min-width:178px; background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px 22px; }
.stats small { display:block; color:var(--muted); margin-bottom:8px; }
.stats strong { font-size:29px; }
.toolbar { display:flex; justify-content:space-between; gap:14px; margin-bottom:18px; }
.search { display:flex; width:500px; }
input, select, textarea { display:block; width:100%; margin-top:7px; padding:11px 12px; border:1px solid #cbd5e1; border-radius:8px; background:#fff; font:inherit; }
textarea { resize:vertical; }
label { display:block; font-size:14px; color:#475569; margin-bottom:14px; font-weight:600; }
button, .button { display:inline-flex; justify-content:center; align-items:center; padding:11px 17px; background:#fff; border:1px solid #cbd5e1; border-radius:8px; font:inherit; font-weight:600; color:#334155; cursor:pointer; text-decoration:none; }
button.primary, .button.primary { border-color:var(--blue); background:var(--blue); color:#fff; }
button.danger { color:var(--red); border-color:#fecaca; background:#fff; }
button.small { padding:7px 11px; font-size:13px; }
table { width:100%; border-collapse:collapse; font-size:14px; }
th { text-align:left; color:var(--muted); font-weight:600; padding:0 12px 13px; }
td { border-top:1px solid var(--line); padding:14px 12px; }
td a { color:var(--blue); text-decoration:none; font-weight:600; }
.empty { text-align:center; color:var(--muted); padding:34px; }
.pill { padding:5px 9px; border-radius:99px; background:#e2e8f0; font-size:12px; font-weight:700; }
.pill.running, .pill.scheduled { color:var(--blue); background:#e8eeff; }
.pill.finished { color:var(--green); background:#d1fae5; }
.pill.error, .pill.stopped { color:var(--red); background:#fee2e2; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-grid .card { margin:0; }
.form-grid .full { grid-column:1 / -1; }
.fields { display:grid; gap:14px; }
.fields.two { grid-template-columns:1fr 1fr; }
.fields.three { grid-template-columns:1fr 1fr 1.35fr; }
.checks { padding:10px 0 15px; display:flex; flex-wrap:wrap; gap:14px; }
.checks label, label.check { display:flex; align-items:center; gap:7px; margin:0 0 12px; }
.checks input, label.check input { width:auto; margin:0; }
.hint { margin:0 0 18px; color:var(--muted); }
.split { display:flex; align-items:flex-start; gap:18px; }
.compact { width:390px; flex:none; }
.grow { flex:1; }
.list { width:330px; flex:none; }
.list article { position:relative; padding:14px 0; border-bottom:1px solid var(--line); }
.list span { display:block; font-size:13px; color:var(--muted); margin-top:5px; padding-right:60px; }
.list form { position:absolute; top:11px; right:0; }
.flash { padding:12px 16px; margin-bottom:18px; border-radius:8px; background:#d1fae5; color:#065f46; }
.flash.danger { background:#fee2e2; color:#991b1b; }
code { background:#eef2ff; color:#3730a3; padding:2px 5px; border-radius:4px; }
@media (max-width:980px) { .sidebar { width:190px; } .workspace { margin-left:190px; padding:18px; } .form-grid, .split { display:block; } .compact,.list { width:auto; } .stats { flex-wrap:wrap; } }
