*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-hover: #475569;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--accent: #3b82f6;--accent-hover: #2563eb;--accent-light: #60a5fa;--success: #10b981;--danger: #ef4444;--border: #334155;--shadow: rgba(0, 0, 0, .3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}#root{width:100vw;height:100vh}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app-content{display:flex;flex:1;overflow:hidden}.drag-overlay{background:var(--accent);color:#fff;padding:12px 24px;border-radius:8px;box-shadow:0 4px 12px var(--shadow);font-weight:500}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0006;max-width:480px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title-wrapper{display:flex;align-items:center;gap:12px}.modal-icon{flex-shrink:0}.modal-icon.success{color:var(--success)}.modal-icon.error{color:var(--danger)}.modal-icon.warning{color:#f59e0b}.modal-icon.info,.modal-icon.confirm{color:var(--accent)}.modal-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-content{padding:24px;flex:1;overflow-y:auto}.modal-message{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border)}.modal-btn{padding:8px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}.modal-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.modal-btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.modal-btn-secondary{background:var(--bg-tertiary);border-color:var(--border);color:var(--text-primary)}.modal-btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent)}.canvas{flex:1;position:relative;background:var(--bg-primary);background-image:linear-gradient(rgba(59,130,246,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.1) 1px,transparent 1px);background-size:20px 20px;overflow:hidden;cursor:default}.canvas.drag-over{background-color:#3b82f61a}.canvas-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--text-muted);font-size:16px}.canvas-node{position:absolute;min-width:200px;background:var(--bg-secondary);border:2px solid var(--border);border-radius:8px;padding:12px;cursor:move;transition:all .2s;box-shadow:0 2px 8px var(--shadow)}.canvas-node:hover{border-color:var(--accent);box-shadow:0 4px 12px var(--shadow)}.canvas-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f633}.canvas-node.dragging{opacity:.8;cursor:grabbing}.canvas-node-icon{font-size:24px;margin-bottom:8px}.canvas-node-content{display:flex;flex-direction:column;gap:4px}.canvas-node-name{font-weight:600;font-size:14px;color:var(--text-primary)}.canvas-node-description{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;padding:16px;display:flex;flex-direction:column}.sidebar-section{margin-bottom:24px}.sidebar-header{display:flex;align-items:center;gap:8px;padding:8px 12px;color:var(--text-primary);font-weight:600;font-size:14px;cursor:pointer;border-radius:6px;transition:background .2s;position:relative}.sidebar-header:hover{background:var(--bg-tertiary)}.sidebar-header span{flex:1}.sidebar-add-btn{background:var(--accent);border:none;border-radius:4px;color:#fff;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .2s}.sidebar-add-btn:hover{background:var(--accent-hover)}.sidebar-list{margin-top:8px;display:flex;flex-direction:column;gap:4px}.sidebar-item{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;cursor:grab;color:var(--text-secondary);font-size:14px;transition:all .2s;-webkit-user-select:none;user-select:none}.sidebar-item:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--text-primary)}.sidebar-item.dragging{opacity:.5;cursor:grabbing}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border)}.sidebar-docs-link{display:flex;align-items:center;gap:8px;padding:10px 12px;color:var(--text-secondary);text-decoration:none;font-size:14px;border-radius:6px;transition:all .2s}.sidebar-docs-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-leann-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;width:100%;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;margin-bottom:8px}.sidebar-leann-btn:hover{background:var(--accent-hover)}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border);height:60px;flex-shrink:0}.toolbar-left{display:flex;align-items:center;gap:24px}.toolbar-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.project-name-input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:6px 12px;color:var(--text-primary);font-size:14px;min-width:200px}.project-name-input:focus{outline:none;border-color:var(--accent)}.toolbar-actions{display:flex;gap:8px}.toolbar-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:14px;transition:all .2s}.toolbar-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.toolbar-btn-primary{background:var(--accent);border-color:var(--accent)}.toolbar-btn-primary:hover{background:var(--accent-hover)}.dropdown{position:relative;width:100%}.dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text-primary);font-size:14px;font-family:inherit;cursor:pointer;transition:all .2s;min-height:38px}.dropdown-trigger:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent)}.dropdown-trigger:focus{outline:none;border-color:var(--accent)}.dropdown-trigger:disabled{opacity:.5;cursor:not-allowed}.dropdown-value{flex:1;text-align:left}.dropdown-icon{transition:transform .2s;color:var(--text-secondary);flex-shrink:0;margin-left:8px}.dropdown-icon.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px var(--shadow);z-index:10000;max-height:200px;overflow-y:auto;padding:4px}.dropdown-option{width:100%;display:block;padding:8px 12px;background:transparent;border:none;border-radius:4px;color:var(--text-primary);font-size:14px;text-align:left;cursor:pointer;transition:background .2s}.dropdown-option:hover{background:var(--bg-tertiary)}.dropdown-option.selected{background:var(--accent);color:#fff}.dropdown-option.selected:hover{background:var(--accent-hover)}.dropdown-menu::-webkit-scrollbar{width:6px}.dropdown-menu::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.config-panel{width:400px;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.config-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.config-panel-header h2{font-size:18px;font-weight:600;color:var(--text-primary)}.config-panel-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.config-panel-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.config-panel-content{flex:1;overflow-y:auto;padding:20px}.config-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.config-field textarea{resize:vertical;min-height:80px}.config-checkbox-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;padding:8px;background:var(--bg-tertiary);border-radius:6px}.config-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px;border-radius:4px;transition:background .2s}.config-checkbox:hover{background:var(--bg-hover)}.config-checkbox input[type=checkbox]{cursor:pointer}.config-parameters-list{display:flex;flex-direction:column;gap:8px}.config-parameter{display:grid;grid-template-columns:1fr 120px 1fr auto auto;gap:8px;align-items:center;padding:8px;background:var(--bg-tertiary);border-radius:6px}.config-parameter .dropdown{min-width:0}.config-parameter input{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;padding:6px 8px;color:var(--text-primary);font-size:12px}.config-parameter button{background:var(--danger);border:none;color:#fff;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.config-btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.config-btn-danger:hover{background:#dc2626}.config-empty{color:var(--text-muted);font-size:12px;padding:8px;text-align:center}.config-env-item button{background:var(--danger);border:none;color:#fff;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.leann-panel-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000}.leann-panel{background:var(--bg-secondary);border-radius:8px;width:95%;max-width:1400px;height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.leann-panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color)}.leann-panel-title{display:flex;align-items:center;gap:12px}.leann-panel-title h2{margin:0;font-size:24px;color:var(--text-primary)}.leann-panel-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.leann-panel-close:hover{background:var(--bg-hover)}.leann-panel-content{display:flex;flex:1;overflow:hidden}.leann-sidebar{width:280px;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;background:var(--bg-tertiary)}.leann-main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.leann-section-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color)}.leann-section-header h3{margin:0;font-size:16px;color:var(--text-primary)}.leann-add-btn{background:var(--accent);border:none;color:#fff;width:28px;height:28px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.leann-add-btn:hover{background:var(--accent-hover)}.leann-create-form{padding:16px;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.leann-create-form input{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;padding:8px;color:var(--text-primary);font-size:14px}.leann-create-form input:focus{outline:none;border-color:var(--accent)}.leann-form-actions{display:flex;gap:8px;margin-top:4px}.leann-db-list,.leann-table-list{flex:1;overflow-y:auto;padding:8px}.leann-db-item,.leann-table-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:6px;cursor:pointer;transition:background .2s;margin-bottom:4px}.leann-db-item:hover,.leann-table-item:hover{background:var(--bg-hover)}.leann-db-item.active,.leann-table-item.active{background:var(--accent);color:#fff}.leann-db-info,.leann-table-info{flex:1;min-width:0}.leann-db-name,.leann-table-name{font-weight:500;font-size:14px;margin-bottom:2px}.leann-db-desc,.leann-table-desc{font-size:12px;color:var(--text-secondary);opacity:.8;margin-bottom:2px}.leann-table-meta{font-size:11px;color:var(--text-muted)}.leann-db-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.leann-db-item.active .leann-db-desc,.leann-table-item.active .leann-table-desc,.leann-db-item.active .leann-table-meta,.leann-table-item.active .leann-table-meta{color:#fffc}.leann-delete-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;opacity:.6}.leann-delete-btn:hover{background:var(--danger);color:#fff;opacity:1}.leann-empty-state,.leann-empty-main{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--text-secondary);text-align:center}.leann-empty-main{flex:1}.leann-empty-main svg{margin-bottom:16px;opacity:.5}.leann-tables-panel{width:250px;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;background:var(--bg-tertiary)}.leann-records-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.leann-quick-actions{display:flex;gap:8px}.leann-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s;background:var(--bg-tertiary);color:var(--text-primary)}.leann-btn:hover{background:var(--bg-hover)}.leann-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.leann-btn-primary:hover{background:var(--accent-hover)}.leann-btn-secondary{background:var(--bg-secondary);border-color:var(--border)}.leann-query-result{padding:12px 16px;margin:0 16px;border-radius:4px;font-size:13px}.leann-query-result.success{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.3)}.leann-query-result.error{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.leann-result-count,.leann-result-time{margin-top:4px;font-size:12px}.leann-result-error{font-weight:500}.leann-records-table{flex:1;overflow:auto;padding:16px}.leann-records-table table{width:100%;border-collapse:collapse;font-size:13px}.leann-records-table th{background:var(--bg-tertiary);padding:10px;text-align:left;font-weight:500;color:var(--text-primary);border-bottom:2px solid var(--border-color);position:sticky;top:0;z-index:10}.leann-records-table td{padding:10px;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.leann-records-table tr:hover{background:var(--bg-hover)}.leann-delete-btn-small{background:transparent;border:none;color:var(--danger);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.leann-delete-btn-small:hover{background:#ef444433}.leann-query-panel-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:3000}.leann-query-panel{background:var(--bg-secondary);border-radius:8px;width:90%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.leann-query-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color)}.leann-query-header h3{margin:0;font-size:20px;color:var(--text-primary)}.leann-query-content{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:20px}.leann-query-type-selector{display:flex;align-items:center;gap:12px}.leann-query-type-selector label{font-weight:500;color:var(--text-primary)}.leann-query-type-selector select{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:8px 12px;color:var(--text-primary);font-size:14px;cursor:pointer}.leann-query-type-selector select:focus{outline:none;border-color:var(--accent)}.leann-query-field-selector{display:flex;flex-direction:column;gap:8px}.leann-query-field-selector label{font-weight:500;color:var(--text-primary)}.leann-field-checkboxes{display:flex;flex-wrap:wrap;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:4px}.leann-field-checkboxes label{display:flex;align-items:center;gap:6px;font-weight:400;cursor:pointer}.leann-field-checkboxes input[type=checkbox]{cursor:pointer}.leann-query-limit{display:flex;align-items:center;gap:12px}.leann-query-limit label{font-weight:500;color:var(--text-primary)}.leann-query-limit input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:8px 12px;color:var(--text-primary);font-size:14px;width:100px}.leann-query-limit input:focus{outline:none;border-color:var(--accent)}.leann-query-insert{display:flex;flex-direction:column;gap:12px}.leann-query-insert label{font-weight:500;color:var(--text-primary)}.leann-insert-field{display:flex;flex-direction:column;gap:6px}.leann-insert-field label{font-size:13px;font-weight:400;color:var(--text-secondary)}.leann-insert-field input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:8px 12px;color:var(--text-primary);font-size:14px}.leann-insert-field input:focus{outline:none;border-color:var(--accent)}.leann-query-conditions{display:flex;flex-direction:column;gap:12px}.leann-query-conditions label{font-weight:500;color:var(--text-primary)}.leann-condition-row{display:flex;gap:8px;align-items:center}.leann-condition-row select,.leann-condition-row input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:8px 12px;color:var(--text-primary);font-size:13px}.leann-condition-row select{flex:1;cursor:pointer}.leann-condition-row input{flex:2}.leann-condition-row button{background:var(--danger);border:none;color:#fff;width:32px;height:32px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.leann-condition-row button:hover{background:#dc2626}.leann-query-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border-color)}.settings-panel-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-panel{background:var(--bg-secondary);border-radius:8px;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.settings-panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color)}.settings-panel-header h2{margin:0;font-size:24px;color:var(--text-primary)}.settings-panel-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.settings-panel-close:hover{background:var(--bg-hover)}.settings-panel-content{padding:20px;overflow-y:auto;flex:1;position:relative}.config-env-item{display:grid;grid-template-columns:1fr auto 1fr auto;gap:8px;align-items:center;padding:8px;background:var(--bg-tertiary);border-radius:6px;position:relative}.config-env-item .dropdown{position:relative;z-index:1}.config-env-item input{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;padding:6px 8px;color:var(--text-primary);font-size:12px}.config-env-item span{color:var(--text-secondary);font-weight:500}.config-env-item button{background:var(--danger);border:none;color:#fff;width:200px;margin:20px 0;height:24px;border-radius:4px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.config-env-list{display:flex;flex-direction:column;gap:8px}.config-help-text{font-size:12px;color:var(--text-secondary);margin:8px 0;font-style:italic}.config-form{display:flex;flex-direction:column;gap:20px}.config-field{display:flex;flex-direction:column;gap:8px}.config-field label{font-size:14px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;justify-content:space-between}.config-field input,.config-field textarea{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text-primary);font-size:14px;font-family:inherit}.config-field input:focus,.config-field textarea:focus{outline:none;border-color:var(--accent)}.config-add-btn{background:var(--accent);border:none;color:#fff;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;transition:background .2s}.config-add-btn:hover{background:var(--accent-hover)}.config-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border)}.config-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.config-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.config-btn-primary:hover{background:var(--accent-hover)}.config-btn-secondary{background:var(--bg-secondary);border-color:var(--border);color:var(--text-primary)}.config-btn-secondary:hover{background:var(--bg-hover)}
