*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f5f5;--surface: #fff;--border: #e5e5e5;--text: #1a1a1a;--muted: #888;--accent: #4A90D9;--danger: #E74C3C;--success: #5CB85C}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:48px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.header-left{display:flex;align-items:center;gap:6px}.breadcrumb{color:var(--muted);font-size:13px}.sep{color:#ccc}.page-title{font-size:15px;font-weight:700}.header-tabs{display:flex;gap:4px}.tab-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:5px 14px;font-size:12px;cursor:pointer;color:var(--muted);transition:all .15s}.tab-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.header-stats{display:flex;align-items:center;gap:8px;margin-left:auto}.stat{font-size:11px;color:var(--muted);background:#f0f0f0;padding:3px 10px;border-radius:12px}.clear-hl{font-size:11px;background:#fff3cd;border:1px solid #ffc107;border-radius:12px;padding:3px 10px;cursor:pointer;color:#856404}.app-body{display:flex;flex:1;overflow:hidden}.main-area{flex:1;position:relative;overflow:hidden;background:#fafafa}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:14px;color:var(--muted)}.spinner{width:36px;height:36px;border:3px solid #e0e0e0;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:10px;color:var(--danger);text-align:center;padding:40px}.error-state code{background:#f8f8f8;padding:4px 8px;border-radius:4px;font-size:12px;color:#333;margin-top:6px;display:block}.graph-hint{position:absolute;top:12px;left:12px;background:#ffffffe0;border:1px solid var(--border);border-radius:6px;padding:5px 12px;font-size:11px;color:var(--muted);pointer-events:none}.graph-legend{position:absolute;bottom:16px;left:16px;background:#ffffffed;border:1px solid var(--border);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:5px;font-size:11px;color:#444}.legend-item{display:flex;align-items:center;gap:8px}.legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.node-popup{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:12px;width:315px;box-shadow:0 8px 32px #00000024;z-index:200;overflow:hidden}.popup-header{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 14px;background:#f8f8f8;border-bottom:1px solid #eee}.popup-type{font-weight:700;font-size:13px;display:block}.popup-label{font-size:11px;color:var(--muted);display:block;margin-top:2px}.popup-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;line-height:1;flex-shrink:0}.popup-body{padding:10px 14px;max-height:290px;overflow-y:auto}.popup-row{display:flex;gap:8px;margin-bottom:5px;font-size:11px;border-bottom:1px solid #f5f5f5;padding-bottom:4px}.popup-key{color:#555;font-weight:600;min-width:130px;flex-shrink:0}.popup-val{color:#222;word-break:break-all}.popup-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid #eee}.popup-connections{font-size:11px;color:var(--muted)}.expand-btn{background:var(--text);color:#fff;border:none;border-radius:7px;padding:6px 14px;font-size:12px;cursor:pointer}.expand-btn:hover{opacity:.8}.chat-panel{width:370px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chat-title{font-weight:700;font-size:14px}.chat-subtitle{font-size:11px;color:var(--muted)}.agent-row{display:flex;align-items:center;gap:8px;margin-left:auto}.agent-icon{width:28px;height:28px;background:var(--text);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}.agent-name{font-weight:600;font-size:12px}.agent-sub{font-size:10px;color:var(--muted)}.search-toggle-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:13px}.search-bar{padding:10px 14px;border-bottom:1px solid var(--border)}.search-row-input{display:flex;gap:6px;margin-bottom:8px}.search-input{flex:1;border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:12px;outline:none}.search-input:focus{border-color:var(--accent)}.search-btn{background:var(--text);color:#fff;border:none;border-radius:6px;padding:6px 14px;font-size:12px;cursor:pointer}.search-results{max-height:200px;overflow-y:auto}.search-cat{margin-bottom:8px}.search-cat-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;margin-bottom:4px}.search-item{font-size:11px;padding:5px 8px;border-radius:5px;cursor:pointer;background:#f8f8f8;margin-bottom:3px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item:hover{background:#ebebeb}.search-empty{font-size:12px;color:var(--muted);text-align:center;padding:12px}.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.msg{display:flex;gap:8px}.msg-user{flex-direction:row-reverse}.avatar{width:26px;height:26px;flex-shrink:0;background:var(--text);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.bubble{max-width:84%;padding:10px 12px;border-radius:12px;font-size:13px;line-height:1.55}.msg-assistant .bubble{background:#f4f4f4}.msg-user .bubble{background:var(--text);color:#fff}.bubble-guardrail{background:#fff8e1!important;border:1px solid #ffc107}.msg-text{white-space:pre-wrap;word-break:break-word}.guardrail-msg{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:#856404}.guardrail-icon{font-size:16px;flex-shrink:0}.typing{display:flex;gap:4px;align-items:center;height:20px}.typing span{width:6px;height:6px;background:#bbb;border-radius:50%;animation:bounce 1s infinite}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}}.flow-trace{margin-top:10px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px}.flow-title{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:10px}.flow-steps{display:flex;flex-direction:column;align-items:flex-start;gap:0}.flow-step-wrap{display:flex;flex-direction:column;align-items:flex-start;width:100%}.flow-step{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;width:100%;background:#f8f8f8;border:1px solid var(--border)}.flow-step.found{border-color:#d4edda;background:#f0fff4}.flow-step.missing{border-color:#f5c6cb;background:#fff5f5}.flow-icon{font-size:18px;flex-shrink:0}.flow-step-info{flex:1}.flow-step-type{font-size:12px;font-weight:700;display:block}.flow-step-ids{font-size:11px;color:var(--accent)}.flow-step-missing{font-size:11px;color:var(--danger)}.flow-badge{font-size:14px;font-weight:700}.flow-badge.found{color:var(--success)}.flow-badge.missing{color:var(--danger)}.flow-arrow{font-size:16px;color:var(--muted);margin:2px 0 2px 18px}.sql-section{margin-top:8px}.sql-toggle{background:none;border:none;font-size:11px;color:var(--accent);cursor:pointer;padding:0}.sql-code{margin-top:5px;background:#1e1e1e;color:#d4d4d4;padding:10px;border-radius:6px;font-size:10px;white-space:pre-wrap;overflow-x:auto;max-height:200px}.row-count{display:block;margin-top:4px;font-size:10px;color:var(--muted)}.suggestions{padding:8px 14px;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--border);max-height:220px;overflow-y:auto}.chip{background:#f5f5f5;border:1px solid var(--border);border-radius:20px;padding:6px 12px;font-size:11px;cursor:pointer;text-align:left;color:#333;transition:background .15s}.chip:hover{background:#ebebeb}.chat-footer{display:flex;align-items:center;gap:8px;padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0}.status-dot{width:8px;height:8px;flex-shrink:0;border-radius:50%;background:#ccc}.status-dot.active{background:#4caf50}.status-dot.pulse{background:var(--accent);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.chat-input{flex:1;border:none;outline:none;font-size:13px;color:var(--text);background:transparent}.chat-input::placeholder{color:#bbb}.send-btn{background:var(--text);color:#fff;border:none;border-radius:7px;padding:7px 16px;font-size:13px;cursor:pointer;transition:opacity .15s;flex-shrink:0;font-weight:600}.send-btn:disabled{opacity:.35;cursor:not-allowed}.send-btn:hover:not(:disabled){opacity:.75}.broken-flows{padding:24px;overflow-y:auto;height:100%}.bf-header{margin-bottom:20px}.bf-header h2{font-size:20px;font-weight:700;margin-bottom:6px}.bf-header p{color:var(--muted);font-size:13px}.bf-cards{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.bf-card{flex:1;min-width:150px;background:var(--surface);border:2px solid transparent;border-radius:12px;padding:16px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;transition:all .15s;box-shadow:0 1px 4px #0000000f}.bf-card:hover{box-shadow:0 4px 12px #0000001a}.bf-card-icon{font-size:22px}.bf-card-count{font-size:26px;font-weight:800}.bf-card-label{font-size:11px;color:var(--muted);text-align:center}.bf-desc{font-size:12px;color:var(--muted);margin-bottom:16px;padding:8px 12px;background:#f8f8f8;border-radius:6px;border-left:3px solid var(--accent)}.bf-table-wrap{overflow-x:auto;background:var(--surface);border-radius:10px;border:1px solid var(--border);max-height:calc(100vh - 340px);overflow-y:auto}.bf-table{width:100%;border-collapse:collapse;font-size:12px}.bf-table th{background:#f8f8f8;padding:10px 12px;text-align:left;font-weight:600;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0}.bf-table td{padding:8px 12px;border-bottom:1px solid #f5f5f5}.bf-table tr:hover td{background:#fafafa}.bf-empty{padding:32px;text-align:center;color:var(--muted);font-size:14px}
