:root{--bg: #0b1020;--panel: #141b2e;--panel-2: #1b2440;--border: #2a3354;--text: #e6ebf5;--muted: #93a0c0;--accent: #4f8cff;--accent-2: #7c5cff;--good: #36d399;--bad: #ff5d6c;--warn: #ffb454;--chip: #233056}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:radial-gradient(1200px 600px at 70% -10%,#16203f 0%,transparent),var(--bg);background-color:var(--bg);color:var(--text)}.app{display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:center;gap:16px;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--panel)}.brand{font-weight:700;letter-spacing:.3px}.brand span{color:var(--accent)}.tag{font-size:12px;color:var(--muted)}.spacer{flex:1}.pill{font-size:12px;padding:4px 10px;border-radius:999px;background:var(--chip);border:1px solid var(--border);color:var(--muted)}.pill.admin{color:var(--accent-2);border-color:var(--accent-2)}.tabs{display:flex;gap:6px}.tab{padding:6px 14px;border-radius:8px;cursor:pointer;font-size:14px;border:1px solid transparent;color:var(--muted)}.tab.active{background:var(--panel-2);color:var(--text);border-color:var(--border)}.btn{background:var(--accent);color:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.btn:hover{filter:brightness(1.08)}.btn.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.btn.sm{padding:4px 10px;font-size:12px}.btn.danger{background:var(--bad)}.btn.good{background:var(--good);color:#07291d}.btn:disabled{opacity:.5;cursor:not-allowed}.main{flex:1;display:grid;grid-template-columns:380px 1fr;overflow:hidden}.main.user-only{grid-template-columns:1fr}.chat{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--panel)}.chat-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.msg{padding:10px 14px;border-radius:12px;max-width:92%;line-height:1.4;font-size:14px}.msg.user{align-self:flex-end;background:var(--accent);color:#fff}.msg.bot{align-self:flex-start;background:var(--panel-2);border:1px solid var(--border)}.msg .small{color:var(--muted);font-size:12px;margin-top:6px}.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border)}.chat-input input{flex:1;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px}.toggle-row{display:flex;align-items:center;gap:8px;padding:0 12px 10px;font-size:12px;color:var(--muted)}.switch{position:relative;width:38px;height:20px;background:var(--chip);border-radius:999px;cursor:pointer;border:1px solid var(--border)}.switch.on{background:var(--accent-2)}.knob{position:absolute;top:1px;left:1px;width:16px;height:16px;border-radius:50%;background:#fff;transition:.15s}.switch.on .knob{left:19px}.stagewrap{overflow-y:auto;padding:18px 22px}.stagewrap h2{margin:0 0 4px;font-size:16px}.stagewrap .sub{color:var(--muted);font-size:13px;margin-bottom:14px}.flow{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.node{flex:1;min-width:120px;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--panel);position:relative;overflow:hidden}.node .n-title{font-size:12px;color:var(--muted)}.node .n-state{font-size:13px;font-weight:600;margin-top:4px}.node.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 24px -6px var(--accent)}.node.done{border-color:var(--good)}.node.error{border-color:var(--bad)}.node .ms{position:absolute;right:8px;bottom:6px;font-size:10px;color:var(--muted)}.card{border:1px solid var(--border);border-radius:12px;background:var(--panel);padding:14px 16px;margin-bottom:14px}.card h3{margin:0 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.kv{font-size:13px;color:var(--text)}.chip{display:inline-block;background:var(--chip);border:1px solid var(--border);border-radius:8px;padding:3px 8px;margin:3px 4px 0 0;font-size:12px}.chip .sc{color:var(--accent);margin-left:6px}.sql{font-family:Cascadia Code,Consolas,monospace;font-size:12.5px;white-space:pre-wrap;background:#0a0f1f;border:1px solid var(--border);border-radius:10px;padding:12px;color:#d7e3ff}.emb{display:flex;gap:3px;flex-wrap:wrap}.emb span{width:14px;height:14px;border-radius:3px;display:inline-block}.checks{display:flex;flex-direction:column;gap:6px}.check{display:flex;align-items:center;gap:8px;font-size:13px}.dot{width:10px;height:10px;border-radius:50%}.dot.ok{background:var(--good)}.dot.no{background:var(--bad)}.route-badge{display:inline-block;padding:6px 12px;border-radius:8px;font-weight:700;font-size:13px}.route-badge.reuse{background:#36d39926;color:var(--good);border:1px solid var(--good)}.route-badge.generate{background:#7c5cff26;color:var(--accent-2);border:1px solid var(--accent-2)}table.grid{width:100%;border-collapse:collapse;font-size:13px}table.grid th,table.grid td{border:1px solid var(--border);padding:6px 10px;text-align:left}table.grid th{background:var(--panel-2);color:var(--muted)}.login-wrap{display:flex;align-items:center;justify-content:center;height:100vh}.login-box{width:340px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:26px}.login-box h1{font-size:20px;margin:0 0 4px}.login-box p{color:var(--muted);font-size:13px;margin:0 0 18px}.login-box label{font-size:12px;color:var(--muted);display:block;margin:12px 0 4px}.login-box input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.pw-wrap{position:relative}.pw-wrap input{padding-right:40px}.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;color:var(--muted);padding:4px;line-height:0;display:flex;align-items:center}.pw-eye:hover{color:var(--text)}.login-box .btn{width:100%;margin-top:18px}.err{color:var(--bad);font-size:13px;margin-top:10px}.hint{font-size:12px;color:var(--muted);margin-top:14px;line-height:1.6}.users{padding:22px;overflow-y:auto}.users h2{margin:0 0 14px}.userform{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.userform input,.userform select{padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.metric-big{font-size:40px;font-weight:800;color:var(--accent)}.muted{color:var(--muted)}.trace-wrap{display:flex;flex-direction:column;overflow:hidden;background:#070b16}.trace-head{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--panel)}.trace-title{font-family:Cascadia Code,Consolas,monospace;font-size:13px;color:var(--muted);letter-spacing:.5px}.trace-status{font-size:12px;color:var(--muted)}.trace-status.live{color:var(--good)}.trace-status.done{color:var(--muted)}.terminal{flex:1;overflow-y:auto;padding:14px 16px;font-family:Cascadia Code,Consolas,monospace;font-size:12.5px;line-height:1.55;background:#070b16}.t-line{display:flex;align-items:flex-start;gap:10px;white-space:pre-wrap;word-break:break-word;animation:traceIn .18s ease-out}@keyframes traceIn{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}.t-time{color:#3f4c6b;flex:0 0 56px;text-align:right;-webkit-user-select:none;user-select:none}.t-gutter{flex:0 0 34px;text-align:right;opacity:.8;-webkit-user-select:none;user-select:none}.t-text{flex:1}.t-dim{color:#3f4c6b}.t-stage{margin-top:10px}.t-stagebar{color:#4f8cff;flex:0 0 auto}.t-stage .t-time{flex:0 0 56px}.trace-result{border-top:1px solid var(--border);padding:12px 16px;max-height:240px;overflow:auto;background:var(--panel)}.trace-result-head{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:8px}.workspace{flex:1;display:flex;overflow:hidden}.chat-center{flex:1;display:flex;justify-content:center;overflow:hidden;padding:18px}.workspace.with-preview .chat-center{justify-content:center}.chat{width:100%;max-width:760px;height:100%;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden;border-right:1px solid var(--border)}.chat-top{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--panel-2)}.chat-module{display:flex;align-items:center;gap:8px}.chat-module select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px}.preview-drawer{width:620px;flex:0 0 620px;height:100%;border-left:1px solid var(--border);background:#070b16;display:flex;flex-direction:column;animation:slideIn .22s ease-out}@keyframes slideIn{0%{transform:translate(30px);opacity:0}to{transform:none;opacity:1}}.preview-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--panel);font-size:13px;font-weight:600}.preview-drawer .trace-wrap{flex:1}.preview-drawer .trace-head{display:none}.datasource-page{flex:1;overflow:auto;padding:32px;display:flex;justify-content:center}.datasource-container{width:100%;max-width:600px}.datasource-container h2{margin-bottom:8px;font-size:24px}.datasource-container .desc{color:var(--muted);margin-bottom:24px;line-height:1.5}.form-section{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.form-section label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:500}.form-section input,.form-section select{padding:8px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:14px}.form-section input:focus,.form-section select:focus{outline:none;border-color:var(--accent)}.config-info{padding:12px;background:var(--panel);border:1px solid var(--border);border-radius:6px;margin-bottom:16px;font-size:13px;color:var(--muted)}.success-msg{padding:12px;background:#22c55e1a;border:1px solid var(--good);border-radius:6px;color:var(--good);margin-bottom:16px;font-size:14px}.error-msg{padding:12px;background:#ff5d6c1a;border:1px solid var(--bad);border-radius:6px;color:var(--bad);margin-bottom:16px;font-size:14px}.button-row{display:flex;gap:12px;margin-bottom:24px}.info-box{padding:16px;background:var(--panel);border:1px solid var(--border);border-radius:8px}.info-box h4{margin-bottom:12px;font-size:14px;font-weight:600}.info-box ul{margin:0;padding-left:20px;font-size:13px;line-height:1.8;color:var(--muted)}.modules-page{flex:1;overflow-y:auto;padding:22px 28px}.modules-head{display:flex;align-items:center;justify-content:space-between}.modules-head h2{margin:0}.mod-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.golden{margin-top:14px;border-top:1px dashed var(--border);padding-top:14px}.golden-form{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.golden-form input,.golden-form textarea,.golden-form select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:13px;font-family:inherit}.golden-form textarea{font-family:Cascadia Code,Consolas,monospace;font-size:12px}.golden-item{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-top:1px solid var(--border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#03060fa8;display:flex;align-items:center;justify-content:center;z-index:50}.modal{width:460px;max-height:86vh;overflow-y:auto;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px}.modal h3{margin:0 0 14px}.modal label{display:block;font-size:12px;color:var(--muted);margin:12px 0 4px}.modal input[type=text],.modal input:not([type]),.modal select{width:100%;padding:9px 11px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px}.filefield{margin-top:12px}.filerow{display:flex;align-items:center;gap:10px}.filerow input[type=file]{font-size:12px;color:var(--muted)}.ok-badge{color:var(--good);font-size:12px}
