:root{color-scheme:dark;--bg: #0c0f12;--panel: #141a21;--border: #243040;--text: #e8edf4;--muted: #8b9aad;--accent: #3d8bfd;--danger: #f14c4c;--ok: #3dd68c;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;line-height:1.45}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit}button{cursor:pointer}.appShell{display:flex;min-height:100%}.sidebar{width:200px;border-right:1px solid var(--border);background:var(--panel);padding:16px 12px;display:flex;flex-direction:column;gap:8px}.sidebarBrand{font-weight:600;font-size:14px;margin-bottom:8px;padding:0 8px}.navLink{display:block;padding:8px 10px;border-radius:6px;color:var(--text);text-decoration:none}.navLink:hover{background:#ffffff0f;text-decoration:none}.navLink.active{background:#3d8bfd2e;color:#cfe4ff}.main{flex:1;padding:20px 24px;overflow:auto}.pageTitle{font-size:18px;font-weight:600;margin:0 0 16px}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}.input,.select,.textarea{background:#0a0d10;border:1px solid var(--border);border-radius:6px;color:var(--text);padding:8px 10px;min-width:160px}.textarea{min-width:240px;min-height:72px;resize:vertical}.btn{border:1px solid var(--border);background:#1a222c;color:var(--text);border-radius:6px;padding:8px 14px}.btn:hover{background:#222c38}.btnPrimary{border-color:#2563b8;background:#1d4ed8;color:#fff}.btnPrimary:hover{background:#2563eb}.btnDanger{border-color:#9b2c2c;background:#7f1d1d;color:#fecaca}.btnDanger:hover{background:#991b1b}.btnGhost{background:transparent}.tableWrap{border:1px solid var(--border);border-radius:8px;overflow:auto}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th,table.data td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}table.data th{background:#10161d;color:var(--muted);font-weight:500}table.data tr:last-child td{border-bottom:none}.muted{color:var(--muted);font-size:12px}.err{color:#fca5a5;font-size:13px;margin:8px 0 0}.card{max-width:400px;margin:48px auto;padding:24px;border:1px solid var(--border);border-radius:10px;background:var(--panel)}.card h1{margin:0 0 16px;font-size:18px}.field{margin-bottom:12px}.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}.field .input,.field .textarea{width:100%}.modalBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{width:min(520px,100%);max-height:90vh;overflow:auto;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:18px}.modal h2{margin:0 0 14px;font-size:16px}.modalActions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.rowActions{display:flex;flex-wrap:wrap;gap:6px}.floatDock{position:fixed;right:12px;bottom:12px;z-index:40;display:flex;flex-direction:column;gap:8px;width:min(520px,calc(100vw - 24px))}.floatStrip{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);box-shadow:0 8px 24px #00000059}.floatStripTitle{font-weight:700;min-width:1.5rem}.puppetWrap{min-height:100vh;padding:16px;background:var(--bg);color:var(--text)}.puppetHeader{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
