.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0f;--card: #12121a;--card-hover: #1a1a2e;--border: #1e1e2e;--text: #e4e4e7;--text-dim: #71717a;--accent: #6366f1;--accent-hover: #818cf8;--success: #10b981;--warning: #f59e0b;--muted: #6b7280;--purple: #8b5cf6;--danger: #ef4444}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100vh}#root{height:100vh;display:flex;flex-direction:column}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px;width:380px}.login-card h1{font-size:24px;font-weight:700;margin-bottom:8px}.login-card p{color:var(--text-dim);margin-bottom:28px;font-size:14px}.login-card input{width:100%;padding:12px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;margin-bottom:14px;outline:none;transition:border .2s}.login-card input:focus{border-color:var(--accent)}.login-card button{width:100%;padding:12px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.login-card button:hover{background:var(--accent-hover)}.login-error{color:var(--danger);font-size:13px;margin-bottom:12px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:56px;background:var(--card);border-bottom:1px solid var(--border);flex-shrink:0;z-index:100}.topbar-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:10px}.topbar-title span{color:var(--accent)}.topbar-actions{display:flex;align-items:center;gap:12px}.view-toggle{display:flex;background:var(--bg);border-radius:8px;overflow:hidden;border:1px solid var(--border)}.view-toggle button{padding:6px 14px;border:none;background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .2s}.view-toggle button.active{background:var(--accent);color:#fff}.btn-logout{padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .2s}.btn-logout:hover{border-color:var(--danger);color:var(--danger)}.canvas-container{flex:1;position:relative}.react-flow__background{background:var(--bg)!important}.react-flow__minimap,.react-flow__controls{background:var(--card)!important;border-radius:8px!important;border:1px solid var(--border)!important}.react-flow__controls button{background:var(--card)!important;color:var(--text)!important;border-color:var(--border)!important}.react-flow__controls button:hover{background:var(--card-hover)!important}.react-flow__edge-path{stroke:var(--accent)!important;stroke-width:2}.react-flow__handle{width:8px!important;height:8px!important;background:var(--accent)!important;border:2px solid var(--card)!important}.saas-node{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:220px;max-width:260px;cursor:pointer;transition:all .2s}.saas-node:hover{border-color:var(--accent);box-shadow:0 0 20px #6366f126}.saas-node-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.saas-node-icon{font-size:24px}.saas-node-name{font-size:14px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saas-node-status{padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-active{background:#10b98126;color:var(--success)}.status-development{background:#f59e0b26;color:var(--warning)}.status-paused{background:#6b728026;color:var(--muted)}.status-idea{background:#8b5cf626;color:var(--purple)}.saas-node-desc{font-size:12px;color:var(--text-dim);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:18px}.saas-node-progress{height:4px;background:var(--border);border-radius:4px;overflow:hidden}.saas-node-progress-bar{height:100%;border-radius:4px;transition:width .3s}.saas-node-meta{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--text-dim)}.fab{width:52px;height:52px;border-radius:14px;background:var(--accent);border:none;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #6366f166;transition:all .2s}.fab:hover{transform:scale(1.05);background:var(--accent-hover)}.panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:200;opacity:0;transition:opacity .3s;pointer-events:none}.panel-overlay.open{opacity:1;pointer-events:all}.side-panel{position:fixed;top:0;right:-500px;width:480px;height:100vh;background:var(--card);border-left:1px solid var(--border);z-index:201;transition:right .3s ease;overflow-y:auto;display:flex;flex-direction:column}.side-panel.open{right:0}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.panel-header h2{font-size:18px;font-weight:600}.panel-close{background:none;border:none;color:var(--text-dim);font-size:20px;cursor:pointer;padding:4px}.panel-close:hover{color:var(--text)}.panel-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.panel-tab{flex:1;padding:12px;text-align:center;font-size:13px;font-weight:500;color:var(--text-dim);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.panel-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.panel-body{flex:1;padding:24px;overflow-y:auto}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:500;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;outline:none;transition:border .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn{padding:10px 20px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{background:transparent;border:1px solid var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-secondary{background:var(--bg);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover{border-color:var(--accent)}.panel-actions{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;flex-shrink:0}.list-view{flex:1;padding:20px;overflow-y:auto}.search-bar{margin-bottom:16px}.search-bar input{width:100%;padding:12px 16px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:14px;outline:none}.search-bar input:focus{border-color:var(--accent)}.list-table{width:100%;border-collapse:collapse}.list-table th{text-align:left;padding:12px 16px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.list-table th:hover{color:var(--text)}.list-table td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border)}.list-table tr{cursor:pointer;transition:background .15s}.list-table tbody tr:hover{background:var(--card-hover)}.doc-item,.timeline-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg);border-radius:8px;margin-bottom:8px}.doc-item-info{flex:1}.doc-item-name{font-size:14px;font-weight:500}.doc-item-meta{font-size:12px;color:var(--text-dim)}.doc-item-delete,.timeline-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px}.doc-item-delete:hover,.timeline-delete:hover{color:var(--danger)}.timeline-item{flex-direction:column;align-items:flex-start}.timeline-date{font-size:11px;color:var(--text-dim)}.timeline-content{font-size:14px}.add-form{display:flex;gap:8px;margin-top:12px}.add-form input{flex:1;padding:10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;outline:none}.add-form button{padding:10px 16px;border-radius:8px;background:var(--accent);border:none;color:#fff;font-size:13px;cursor:pointer;white-space:nowrap}.conn-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:8px;margin-bottom:8px}.conn-item span{flex:1;font-size:14px}.conn-label{font-size:12px;color:var(--accent)}.upload-zone{border:2px dashed var(--border);border-radius:10px;padding:24px;text-align:center;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .2s;margin-bottom:12px}.upload-zone:hover{border-color:var(--accent);color:var(--accent)}.saas-node-logo-img{width:32px;height:32px;border-radius:6px;object-fit:contain;flex-shrink:0;margin-left:auto}.note-node{background:var(--card);border:2px solid #f59e0b;border-radius:12px;padding:14px;min-width:200px;max-width:240px;cursor:pointer;transition:all .2s}.note-node:hover{box-shadow:0 0 20px #f59e0b33}.note-node-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.note-node-icon{font-size:20px}.note-node-title{font-size:13px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-node-content{font-size:12px;color:var(--text-dim);line-height:1.5;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.fab-container{position:fixed;bottom:28px;right:28px;z-index:50;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.react-flow__minimap{bottom:90px!important;right:10px!important}.fab-menu{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.fab-menu-item{padding:10px 18px;border-radius:10px;background:var(--card);border:1px solid var(--border);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap;text-align:left;box-shadow:0 4px 12px #0006}.fab-menu-item:hover{border-color:var(--accent);background:var(--card-hover)}.doc-item-action{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;opacity:.6;transition:opacity .15s}.doc-item-action:hover{opacity:1}.preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:300;display:flex;align-items:center;justify-content:center}.preview-modal{background:var(--card);border:1px solid var(--border);border-radius:16px;width:90vw;max-width:800px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.preview-header h3{font-size:15px;font-weight:600}.preview-body{flex:1;overflow-y:auto;padding:20px}.preview-text{font-family:JetBrains Mono,monospace,Courier New;font-size:13px;line-height:1.7;white-space:pre-wrap;word-break:break-word;color:var(--text);background:var(--bg);padding:16px;border-radius:8px}.edge-label{background:var(--card);padding:2px 8px;border-radius:4px;font-size:11px;color:var(--accent);border:1px solid var(--border)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:400;display:flex;align-items:center;justify-content:center}.modal-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:28px;width:380px}.modal-card h3{font-size:16px;font-weight:600;margin-bottom:16px}.modal-card input{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;outline:none;margin-bottom:16px}.modal-card input:focus{border-color:var(--accent)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal-actions button{padding:8px 18px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer}.modal-btn-cancel{background:var(--bg);color:var(--text-dim);border:1px solid var(--border)!important}.modal-btn-confirm{background:var(--accent);color:#fff}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}
