:root{color-scheme:light;font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif;color:#1f2937;background:#eef2f5}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{min-height:44px;border:0;border-radius:8px;cursor:pointer}button:disabled,input:disabled{cursor:not-allowed;opacity:.58}input{min-height:44px;width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:0 12px;color:#0f172a;background:#fff}input:focus,button:focus{outline:3px solid rgba(37,99,235,.22);outline-offset:2px}.app-shell{min-height:100dvh;padding:28px}.loading-bar{position:fixed;top:0;left:0;z-index:1000;width:100%;height:3px;overflow:hidden;background:#2563eb1f}.loading-bar:after{content:"";position:absolute;top:0;left:-40%;width:40%;height:100%;background:#2563eb;animation:loading-slide 1s ease-in-out infinite}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;max-width:1360px;margin:0 auto 20px}.topbar h1,.section-title h2,.module h3{margin:0;letter-spacing:0}.topbar h1{font-size:clamp(28px,4vw,44px);line-height:1.1}.eyebrow{margin:0 0 8px;color:#2563eb;font-size:13px;font-weight:700}.api-status{display:grid;gap:8px;color:#475569;font-size:13px;text-align:right}.api-status a{color:#1d4ed8;font-weight:700;text-decoration:none}.api-status a:hover{text-decoration:underline}.panel{max-width:1360px;margin:0 auto 22px;padding:22px;border:1px solid #d7dee8;border-radius:8px;background:#fff;box-shadow:0 8px 24px #0f172a0f}.section-title,.module-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-title{margin-bottom:20px}.section-title h2{font-size:24px}.work-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:18px}.control-row{display:grid;grid-template-columns:1fr auto;align-items:end;gap:10px}.control-row label{display:grid;gap:8px;color:#334155;font-size:13px;font-weight:700}.control-row button,.ghost-button{padding:0 18px;color:#fff;background:#2563eb}.ghost-button{color:#1d4ed8;background:#dbeafe}.text-button{min-height:36px;padding:0 10px;color:#1d4ed8;background:#eff6ff}.text-button.danger{color:#be123c;background:#ffe4e6}.icon-button{width:44px;height:44px;color:#64748b;background:#f1f5f9;font-size:22px}.content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.module{min-width:0;padding:16px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.module.wide{grid-column:1 / -1}.module h3{margin-bottom:12px;font-size:16px}.node-list{display:flex;flex-wrap:wrap;gap:10px}.node-item{display:inline-flex;align-items:center;gap:8px;min-height:44px;padding-left:12px;border:1px solid #dbe4ee;border-radius:8px;background:#fff;color:#0f172a;font-weight:700}.result-block{display:grid;gap:8px;color:#334155;line-height:1.5}.result-block strong{color:#0f172a;font-size:18px}.result-label{color:#64748b;font-size:13px;font-weight:700}pre{max-height:220px;overflow:auto;margin:4px 0 0;padding:12px;border-radius:8px;color:#e2e8f0;background:#111827}.empty-state{display:grid;min-height:120px;place-items:center;color:#64748b;border:1px dashed #cbd5e1;border-radius:8px;background:#fff;text-align:center}.ring-track{position:relative;height:54px;border:1px solid #cbd5e1;border-radius:8px;background:linear-gradient(90deg,#2563eb14,#0f766e14),#fff;overflow:hidden}.ring-dot{position:absolute;top:8px;width:4px;height:38px;border-radius:4px}.metric-line{margin:10px 0 0;color:#64748b}.backend-table{overflow-x:auto}.table-head,.table-row{display:grid;grid-template-columns:140px minmax(240px,1fr) 100px minmax(190px,240px) 70px 260px;gap:10px;align-items:center;min-width:980px;padding:10px 0;border-bottom:1px solid #e2e8f0}.table-head{color:#64748b;font-size:13px;font-weight:700}.mono{font-family:SFMono-Regular,Consolas,monospace;font-size:13px}.status-pill{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;color:#9f1239;background:#ffe4e6;font-size:13px;font-weight:700}.status-pill.healthy{color:#047857;background:#d1fae5}.row-actions{display:flex;flex-wrap:wrap;gap:8px}.health-cell{display:grid;gap:4px}.health-cell strong{color:#0f172a;font-size:13px}.health-cell small{color:#64748b;line-height:1.35}.error-text{color:#be123c!important}.stats-grid{display:grid;grid-template-columns:1fr auto;gap:12px;color:#475569}.stats-grid strong{color:#0f172a}.toast{position:fixed;right:24px;bottom:24px;max-width:min(420px,calc(100vw - 48px));padding:14px 16px;border-radius:8px;color:#fff;background:#0f172a;box-shadow:0 10px 30px #0f172a38}.loading-mask{position:fixed;right:24px;bottom:82px;z-index:900;display:inline-flex;align-items:center;gap:10px;min-height:44px;max-width:min(420px,calc(100vw - 48px));padding:12px 14px;border:1px solid #bfdbfe;border-radius:8px;color:#1e3a8a;background:#eff6ff;box-shadow:0 10px 24px #2563eb1f;font-weight:700}.spinner{width:18px;height:18px;border:3px solid #bfdbfe;border-top-color:#2563eb;border-radius:999px;animation:spin .8s linear infinite}@keyframes loading-slide{0%{transform:translate(0)}to{transform:translate(350%)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.app-shell{padding:16px}.topbar,.section-title{align-items:flex-start;flex-direction:column}.api-status{text-align:left;word-break:break-all}.work-grid,.content-grid,.control-row{grid-template-columns:1fr}.loading-mask{right:16px;bottom:76px}}
