:root{--bg: #f5efe3;--paper: #fff9ef;--ink: #212630;--muted: #5d6976;--line: #dfd3c2;--brand: #0d936f;--brand-soft: #d7f7ed;--accent: #e8733e;--danger: #cf3e3e;--mono: "JetBrains Mono", "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--sans: "IBM Plex Sans", "PingFang SC", "Microsoft YaHei", sans-serif}*{box-sizing:border-box}html,body,#app{width:100%;min-height:100%;margin:0;color:var(--ink);font-family:var(--sans)}body{background:radial-gradient(circle at 20% 12%,rgba(13,147,111,.2),transparent 38%),radial-gradient(circle at 88% 80%,rgba(232,115,62,.16),transparent 40%),var(--bg)}.app-shell{min-height:100vh;display:flex}.sidebar{width:240px;border-right:1px solid var(--line);background:linear-gradient(180deg,#fffaf0e6,#fff6e4eb);padding:24px 18px;position:sticky;top:0;min-height:100vh}.brand{display:flex;flex-direction:column;margin-bottom:24px}.brand-title{font-size:22px;font-weight:700;letter-spacing:.6px}.brand-sub{margin-top:6px;color:var(--muted);font-size:13px}.nav-list{display:grid;gap:10px}.nav-link{display:block;color:var(--ink);text-decoration:none;border:1px solid transparent;border-radius:12px;padding:11px 12px;transition:all .15s ease}.nav-link:hover{border-color:var(--line);background:#fffc}.nav-link.active{border-color:#0d936f73;background:var(--brand-soft)}.main-pane{flex:1;padding:22px 24px 26px}.topbar{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line);border-radius:16px;background:#fff9;padding:14px 16px;margin-bottom:16px}.user-name{font-weight:700}.user-role{color:var(--muted);font-size:13px;margin-top:4px}.view-panel{border:1px solid var(--line);background:#fffbf3eb;border-radius:18px;min-height:calc(100vh - 122px);padding:18px}.page-title{font-size:22px;margin:2px 0 14px}.page-subtitle{color:var(--muted);margin:0 0 16px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.metric-card{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}.metric-label{color:var(--muted);font-size:13px}.metric-value{font-size:28px;font-weight:700;margin-top:8px}.panel{border:1px solid var(--line);border-radius:14px;background:#fff;padding:14px;margin-top:14px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}input,select,textarea{border:1px solid #ccbda9;background:#fffef9;border-radius:10px;color:var(--ink);padding:10px 11px;font-size:14px;font-family:var(--sans)}textarea{min-height:120px;resize:vertical;font-family:var(--mono);font-size:13px}a{color:var(--brand)}button{border:1px solid transparent;border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.primary-btn{background:var(--brand);color:#fff}.ghost-btn{border-color:var(--line);background:#fff;color:var(--ink)}.warn-btn{background:var(--accent);color:#fff}.danger-btn{background:var(--danger);color:#fff}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;padding:10px;color:var(--muted);border-bottom:1px solid var(--line)}tbody td{padding:10px;border-bottom:1px solid #efe5d7}.tag{display:inline-block;border-radius:999px;padding:3px 10px;font-size:12px;border:1px solid transparent}.tag.running{color:#0a825f;border-color:#0a825f4d;background:#0a825f1a}.tag.stopped{color:#334155;border-color:#3341554d;background:#33415514}.tag.failed{color:#b52323;border-color:#b523234d;background:#b5232314}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.log-box{border:1px solid #c9bca8;border-radius:12px;background:#14171d;color:#e0e6f0;font-family:var(--mono);font-size:12px;padding:12px;min-height:320px;max-height:520px;overflow:auto;white-space:pre-wrap;word-break:break-word}.login-wrap{width:100%;min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:100%;max-width:420px;border-radius:18px;border:1px solid var(--line);background:#fffaf0e6;padding:24px}.login-tips{font-size:13px;color:var(--muted)}.error-text{color:#b52323;font-size:13px}@media(max-width:980px){.app-shell{display:block}.sidebar{width:100%;min-height:0;position:relative;border-right:0;border-bottom:1px solid var(--line)}.nav-list{grid-template-columns:repeat(auto-fit,minmax(110px,1fr))}.main-pane{padding:12px}.view-panel{min-height:0}}
