:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;color:#1a202c;background-color:#edf2f7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}.editor{display:flex;flex-direction:column;height:100vh;overflow:hidden}.titlebar{display:flex;align-items:center;gap:0;padding:0 16px;background:#1e293b;flex-shrink:0;height:40px;-webkit-user-select:none;user-select:none}.titlebar-brand{display:flex;align-items:center;gap:8px;padding-right:20px}.titlebar-logo{font-size:14px;font-weight:700;color:#fff;letter-spacing:-.3px}.titlebar-sep{font-size:13px;color:#64748b}.titlebar-project{font-size:13px;font-weight:400;color:#94a3b8}.titlebar-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:3px;background:#ffffff1f;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.titlebar-undoredo{display:flex;align-items:center;gap:2px;margin-left:12px}.titlebar-undoredo-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:#94a3b8;font-size:16px;cursor:pointer;border-radius:4px}.titlebar-undoredo-btn:hover:not(:disabled){background:#ffffff1a;color:#e2e8f0}.titlebar-undoredo-btn:disabled{opacity:.3;cursor:default}.app-body{display:flex;flex:1;min-height:0}.app-content{flex:1;min-width:0;display:flex;flex-direction:column;position:relative}.nav-sidebar{display:flex;flex-direction:column;width:48px;background:#1e293b;border-right:1px solid #334155;padding:8px 0;gap:2px;flex-shrink:0}.nav-sidebar-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 0;border:none;background:transparent;color:#94a3b8;cursor:pointer;border-left:2px solid transparent;transition:color .15s,background .15s}.nav-sidebar-btn:hover{color:#e2e8f0;background:#ffffff0d}.nav-sidebar-btn-active{color:#fff;background:#ffffff14;border-left-color:#3b82f6}.nav-sidebar-label{font-size:9px;font-weight:500;letter-spacing:.02em}.titlebar-btn-ai{color:#7c3aed;display:flex;align-items:center;justify-content:center}.titlebar-btn-ai:hover{background:#faf5ff;border-color:#e9d5ff;color:#6d28d9}.titlebar-btn-ai-active{background:#f5f3ff;border-color:#c4b5fd;color:#6d28d9}.titlebar-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.titlebar-btn{padding:5px 12px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#cbd5e1;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.titlebar-btn:hover{background:#ffffff1f;color:#fff}.titlebar-btn-primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.titlebar-btn-primary:hover{background:#2563eb}.titlebar-btn-subtle{border-color:transparent;background:transparent;color:#64748b}.titlebar-btn-subtle:hover{color:#94a3b8;background:#ffffff0f}.editor-grid{position:relative;padding:16px 24px}.canvas-container{flex:1;overflow:hidden;background:#edf2f7;display:flex;align-items:center;justify-content:center}.canvas-inner{position:relative}.page-tabs{display:flex;gap:0;padding:0 24px;background:#fff;border-bottom:1px solid #e2e8f0}.page-tab{padding:10px 20px;border:none;background:transparent;font-size:13px;font-weight:500;color:#718096;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.page-tab:hover{color:#2d3748}.page-tab-active{color:#3182ce;border-bottom-color:#3182ce;font-weight:600}.page-tab-rename-input{padding:4px 8px;border:1px solid #3182ce;border-radius:4px;font-size:13px;color:#2d3748;outline:none;background:#fff;min-width:80px}.status-bar{display:flex;align-items:center;justify-content:space-between;height:32px;background:#1e293b;border-top:1px solid #334155;padding:0 4px;flex-shrink:0}.status-bar-pages{display:flex;align-items:center;gap:0;overflow-x:auto;min-width:0}.status-bar-add-page{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:#94a3b8;font-size:16px;cursor:pointer;border-radius:4px;flex-shrink:0}.status-bar-add-page:hover{background:#334155;color:#e2e8f0}.status-bar-tab{padding:4px 14px;border:none;background:transparent;color:#94a3b8;font-size:12px;cursor:pointer;white-space:nowrap;border-radius:4px 4px 0 0;border-bottom:2px solid transparent;transition:color .15s,background .15s,border-color .15s}.status-bar-tab:hover{color:#e2e8f0;background:#334155}.status-bar-tab-active{color:#e2e8f0;border-bottom-color:#3b82f6}.status-bar-peer-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-left:3px;vertical-align:middle}.status-bar-rename-input{padding:2px 6px;border:1px solid #3b82f6;border-radius:3px;font-size:12px;color:#e2e8f0;background:#1e293b;outline:none;min-width:60px}.status-bar-zoom{display:flex;align-items:center;gap:4px;flex-shrink:0}.status-bar-fit{padding:2px 8px;border:none;background:transparent;color:#94a3b8;font-size:11px;cursor:pointer;border-radius:3px}.status-bar-fit:hover{background:#334155;color:#e2e8f0}.status-bar-fit-active{color:#60a5fa}.status-bar-zoom-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;color:#94a3b8;font-size:14px;cursor:pointer;border-radius:3px}.status-bar-zoom-btn:hover{background:#334155;color:#e2e8f0}.status-bar-zoom-slider{width:100px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#475569;border-radius:2px;outline:none;cursor:pointer}.status-bar-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#94a3b8;cursor:pointer}.status-bar-zoom-slider::-webkit-slider-thumb:hover{background:#e2e8f0}.status-bar-zoom-label{color:#94a3b8;font-size:11px;min-width:36px;text-align:right}.import-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:1000}.import-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;width:520px;max-height:80vh;overflow-y:auto}.import-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e2e8f0}.import-header h2{font-size:16px;font-weight:600}.import-close{border:none;background:none;font-size:22px;color:#a0aec0;cursor:pointer;line-height:1;padding:4px}.import-close:hover{color:#4a5568}.import-body{padding:16px 20px}.import-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid #e2e8f0;padding-bottom:8px}.import-tab{padding:6px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:12px;font-weight:500;color:#718096;cursor:pointer}.import-tab:hover{background:#f7fafc;color:#2d3748}.import-tab-active{background:#ebf4ff;color:#3182ce;border-color:#bee3f8}.import-form{margin-bottom:12px}.import-label{display:block;font-size:12px;font-weight:600;color:#4a5568;margin-bottom:10px}.import-input{display:block;width:100%;padding:8px 10px;margin-top:4px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-family:inherit}.import-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 2px #3182ce26}.import-file-row{display:flex;gap:8px;margin-top:4px}.import-file-row .import-input{margin-top:0;flex:1}.import-browse{padding:8px 14px;border:1px solid #e2e8f0;border-radius:6px;background:#f7fafc;font-size:13px;cursor:pointer;white-space:nowrap}.import-browse:hover{background:#edf2f7}.import-status{padding:10px 12px;border-radius:6px;font-size:13px;margin-top:12px;display:flex;align-items:center;gap:8px}.import-status-loading{background:#ebf4ff;color:#3182ce}.import-status-success{background:#f0fff4;color:#276749}.import-status-error{background:#fff5f5;color:#c53030}.import-spinner{width:16px;height:16px;border:2px solid #bee3f8;border-top-color:#3182ce;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.import-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid #e2e8f0}.import-btn{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid #e2e8f0}.import-btn-cancel{background:#fff;color:#4a5568}.import-btn-cancel:hover{background:#f7fafc}.import-btn-import{background:#3182ce;color:#fff;border-color:#3182ce}.import-btn-import:hover:not(:disabled){background:#2b6cb0}.import-btn-import:disabled{opacity:.5;cursor:not-allowed}.new-table-enter-data{display:flex;flex-direction:column;gap:8px}.new-table-column-controls{display:flex;gap:6px;flex-wrap:wrap;align-items:flex-end}.new-table-column-header{display:flex;gap:4px;align-items:center;padding:4px 6px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px}.new-table-col-name{width:100px;padding:3px 6px;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;background:#fff}.new-table-col-type{padding:3px 4px;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;background:#fff;color:#718096}.new-table-col-remove{background:none;border:none;color:#a0aec0;cursor:pointer;font-size:16px;padding:0 2px;line-height:1}.new-table-col-remove:hover:not(:disabled){color:#e53e3e}.new-table-col-remove:disabled{opacity:.3;cursor:not-allowed}.new-table-add-col,.new-table-add-row{padding:4px 10px;font-size:12px;border:1px dashed #cbd5e0;border-radius:4px;background:none;color:#718096;cursor:pointer}.new-table-add-col:hover,.new-table-add-row:hover{border-color:#3182ce;color:#3182ce}.new-table-grid-wrapper{max-height:300px;overflow:auto;border:1px solid #e2e8f0;border-radius:6px}.new-table-grid{width:100%;border-collapse:collapse;font-size:13px}.new-table-grid th{padding:6px 8px;text-align:left;font-weight:600;font-size:12px;color:#4a5568;background:#f7fafc;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:1}.new-table-grid td{padding:2px 4px;border-bottom:1px solid #f0f0f0}.new-table-row-num{width:32px;color:#a0aec0;font-size:11px;text-align:center!important}.new-table-row-actions{width:28px}.new-table-row-remove{background:none;border:none;color:#cbd5e0;cursor:pointer;font-size:16px;padding:0 4px}.new-table-row-remove:hover:not(:disabled){color:#e53e3e}.new-table-row-remove:disabled{opacity:.3;cursor:not-allowed}.new-table-cell{width:100%;padding:4px 6px;border:1px solid transparent;border-radius:3px;font-size:13px;font-family:inherit;background:transparent}.new-table-cell:focus{border-color:#3182ce;outline:none;background:#fff}.new-table-sql-input{width:100%;padding:8px 10px;border:1px solid #e2e8f0;border-radius:6px;font-family:SF Mono,Fira Code,monospace;font-size:13px;resize:vertical;background:#1e1e1e;color:#d4d4d4}.new-table-sql-input:focus{border-color:#3182ce;outline:none}.new-table-preview-btn{padding:5px 12px;font-size:12px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#4a5568;cursor:pointer;align-self:flex-start}.new-table-preview-btn:hover:not(:disabled){border-color:#3182ce;color:#3182ce}.new-table-preview-btn:disabled{opacity:.5;cursor:not-allowed}.new-table-preview-results{max-height:240px;overflow:auto;border:1px solid #e2e8f0;border-radius:6px;margin-top:8px}.new-table-calculated{display:flex;flex-direction:column;gap:8px}.new-table-type-badge{display:inline-block;padding:1px 5px;font-size:10px;font-weight:600;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.new-table-type-badge-inline{background:#e6fffa;color:#285e61}.new-table-type-badge-calculated{background:#ebf4ff;color:#2b6cb0}.new-table-type-badge-file{background:#f7fafc;color:#718096}.data-view-table-edit-btn{background:none;border:none;color:#a0aec0;cursor:pointer;font-size:11px;padding:2px 6px;border-radius:3px}.data-view-table-edit-btn:hover{color:#3182ce;background:#ebf4ff}.builder-layout{display:flex;flex-direction:column;flex:1;min-height:0}.ribbon{display:flex;align-items:center;padding:0 8px;gap:2px;background:#f8fafc;border-bottom:1px solid #e2e8f0;height:36px;flex-shrink:0}.ribbon-divider{width:1px;margin:4px;background:#e2e8f0;align-self:stretch}.ribbon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:4px;background:transparent;cursor:pointer;color:#475569;transition:all .12s;padding:0;flex-shrink:0}.ribbon-btn:hover{background:#fff;border-color:#e2e8f0;box-shadow:0 1px 2px #0000000a}.ribbon-btn-active{background:#eff6ff;border-color:#bfdbfe;color:#2563eb}.ribbon-btn-active:hover{background:#dbeafe;border-color:#93c5fd}.toolbar-overflow{position:relative}.toolbar-overflow-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001a;padding:4px;min-width:140px}.toolbar-overflow-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;border-radius:4px;background:transparent;cursor:pointer;color:#334155;font-size:13px;white-space:nowrap}.toolbar-overflow-item:hover{background:#f1f5f9}.toolbar-overflow-check{margin-left:auto;color:#2563eb}.toolbar-gap{width:4px;flex-shrink:0}.builder-toolbar-label{font-size:12px;font-weight:600;color:#718096;margin-right:4px}.builder-add-btn{padding:4px 10px;border-radius:4px;border:1px solid #e2e8f0;background:#fff;font-size:12px;cursor:pointer;color:#4a5568}.builder-add-btn:hover{background:#f7fafc;border-color:#cbd5e0}.builder-main{display:flex;flex:1;min-height:0;overflow:hidden}.builder-canvas-area{display:flex;flex-direction:column;flex:1;overflow:hidden;min-width:0;min-height:0}.report-canvas{display:flex;flex-direction:column;flex:1;min-height:0}.builder-canvas .builder-grid{background:#f7fafc;border:1px dashed #94a3b8}.builder-visual-card{cursor:default;position:relative;transition:box-shadow .15s}.builder-visual-card:hover:not(.builder-visual-selected){outline:1px solid #1a1a1a;outline-offset:0}.builder-edge-handle{position:absolute;z-index:15;cursor:grab}.builder-edge-handle:active{cursor:grabbing}.builder-edge-top{top:0;left:8px;right:8px;height:6px}.builder-edge-bottom{bottom:0;left:8px;right:8px;height:6px}.builder-edge-left{top:8px;bottom:8px;left:0;width:6px}.builder-edge-right{top:8px;bottom:8px;right:0;width:6px}.builder-visual-selected{box-shadow:0 0 0 4px #3182ce26}.builder-visual-selected:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid #3182ce;border-radius:inherit;z-index:20;pointer-events:none}.builder-resize-handle{position:absolute;right:0;bottom:0;width:14px;height:14px;background:#3182ce;cursor:nwse-resize;border-radius:2px 0 6px;z-index:10}.builder-resize-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:6px;height:6px;border-right:2px solid white;border-bottom:2px solid white}.snap-guide-vertical{width:0;border-left:1px dashed #e53e3e}.snap-guide-horizontal{height:0;border-top:1px dashed #e53e3e}.builder-field-picker{background:#fff;overflow-y:auto}.builder-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:13px;font-weight:600;color:#2d3748;border-bottom:1px solid #e2e8f0}.builder-field-group{border-bottom:1px solid #f7fafc}.builder-field-group-header{display:flex;align-items:center;gap:6px;width:100%;padding:8px 14px;border:none;background:none;font-size:12px;font-weight:600;color:#4a5568;cursor:pointer;text-align:left}.builder-field-group-header:hover{background:#f7fafc}.builder-chevron{font-size:8px;color:#a0aec0}.builder-field-list{padding:0 0 4px}.builder-field-item{display:flex;align-items:center;gap:6px;width:100%;padding:5px 14px 5px 24px;border:none;background:none;font-size:12px;color:#4a5568;cursor:pointer;text-align:left}.builder-field-item:hover{background:#ebf4ff;color:#2b6cb0}.builder-field-item.is-used{background:#ebf8ff;color:#2b6cb0}.builder-field-group-header.is-used{color:#2b6cb0}.field-well-badge{margin-left:auto;font-size:9px;font-weight:600;line-height:1;padding:2px 5px;border-radius:8px;background:#3182ce;color:#fff;white-space:nowrap;flex-shrink:0}.builder-field-icon{font-size:10px;color:#a0aec0;width:16px;text-align:center;flex-shrink:0}.builder-field-measure{font-weight:500;color:#2b6cb0}.builder-field-measure .builder-field-icon{color:#3182ce}.builder-measure-item{position:relative}.builder-measure-menu{position:absolute;left:24px;top:100%;z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:180px;overflow:hidden}.builder-measure-menu-item{display:block;width:100%;padding:8px 12px;border:none;background:none;font-size:12px;color:#4a5568;cursor:pointer;text-align:left}.builder-measure-menu-item:hover{background:#ebf4ff;color:#2b6cb0}.builder-properties-panel{background:#fff;overflow-y:auto}.builder-props-tabs{display:flex;gap:0;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:1;background:#fff}.builder-props-tab{flex:1;padding:7px 12px;border:none;border-bottom:2px solid transparent;background:#fff;font-size:12px;font-weight:500;color:#718096;cursor:pointer}.builder-props-tab:hover{background:#f7fafc;color:#2d3748}.builder-props-tab-active{color:#3182ce;font-weight:600;border-bottom-color:#3182ce;background:#ebf4ff}.builder-props-empty{padding:20px 14px;font-size:12px;color:#a0aec0;text-align:center}.builder-delete-btn{padding:3px 10px;border-radius:4px;border:1px solid #feb2b2;background:#fff5f5;font-size:11px;font-weight:500;color:#c53030;cursor:pointer}.builder-delete-btn:hover{background:#fed7d7}.builder-props-section{border-bottom:1px solid #e2e8f0}.builder-props-section-header{display:flex;align-items:center;gap:6px;width:100%;padding:8px 14px;font-size:11px;font-weight:700;color:#4a5568;text-transform:uppercase;letter-spacing:.6px;background:#f7fafc;border:none;border-bottom:1px solid #edf2f7;cursor:pointer;font-family:inherit;text-align:left}.builder-props-section-header:hover{background:#edf2f7}.builder-props-chevron{display:inline-block;width:0;height:0;border-left:4px solid #718096;border-top:3px solid transparent;border-bottom:3px solid transparent;transition:transform .15s ease}.builder-props-chevron.open{transform:rotate(90deg)}.builder-prop-group{padding:8px 14px;border-bottom:1px solid #f7fafc}.builder-prop-label{display:block;font-size:11px;font-weight:600;color:#718096;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.builder-prop-select,.builder-prop-input{display:block;width:100%;padding:4px 6px;border:1px solid #e2e8f0;border-radius:3px;font-size:12px;font-family:inherit;background:#fff}.builder-prop-select:focus,.builder-prop-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 1px #3182ce26}.builder-number-wrap input[type=number]{-moz-appearance:textfield}.builder-number-wrap input[type=number]::-webkit-inner-spin-button,.builder-number-wrap input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.builder-number-wrap{display:flex;align-items:stretch}.builder-number-wrap .builder-prop-input{flex:1;min-width:0;text-align:left;padding-left:2px;padding-right:2px;border-right:none;border-radius:3px 0 0 3px}.builder-number-arrows{display:flex;flex-direction:column;width:16px;flex-shrink:0;border:1px solid #e2e8f0;border-left:1px solid #edf2f7;border-radius:0 3px 3px 0;background:#f7fafc}.builder-number-arrows button{display:flex;align-items:center;justify-content:center;flex:1;border:none;background:transparent;cursor:pointer;padding:0;color:#a0aec0;line-height:0}.builder-number-arrows button:first-child{border-bottom:1px solid #edf2f7}.builder-number-arrows button:hover{background:#edf2f7;color:#4a5568}.builder-number-arrows button:active{background:#e2e8f0}.builder-number-wrap:focus-within .builder-prop-input{border-color:#3182ce;box-shadow:0 0 0 1px #3182ce26}.builder-number-wrap:focus-within .builder-number-arrows{border-color:#3182ce;border-left-color:#edf2f7}.builder-prop-row{display:flex;gap:4px}.builder-prop-row .builder-prop-select,.builder-prop-row .builder-select{flex:1}.builder-select{position:relative;width:100%}.builder-select-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px 6px;border:1px solid #e2e8f0;border-radius:3px;font-size:12px;font-family:inherit;background:#fff;cursor:pointer;color:#2d3748;text-align:left;gap:4px}.builder-select-trigger:hover{border-color:#cbd5e1}.builder-select-trigger:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 1px #3182ce26}.builder-select-value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.builder-select-chevron{flex-shrink:0;color:#a0aec0;transition:transform .15s}.builder-select-menu{position:absolute;top:calc(100% + 2px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:4px;box-shadow:0 4px 12px #0000001a;z-index:100;padding:2px;max-height:180px;overflow-y:auto}.builder-select-option{display:block;width:100%;padding:5px 8px;border:none;background:none;font-size:12px;font-family:inherit;color:#2d3748;text-align:left;cursor:pointer;border-radius:2px}.builder-select-option:hover{background:#f7fafc}.builder-select-option-active{background:#ebf4ff;color:#3182ce;font-weight:500}.builder-select-option-active:hover{background:#dbeafe}.builder-prop-position{display:flex;gap:8px;font-size:11px;color:#718096}.builder-prop-position>.builder-style-label{flex:1;min-width:0}.builder-title-toolbar{display:flex;align-items:center;gap:4px;margin-top:6px}.builder-toolbar-group{display:flex;align-items:center;border:1px solid #e2e8f0;border-radius:3px;overflow:hidden}.builder-toolbar-group+.builder-toolbar-group{margin-left:2px}.builder-toolbar-btn{display:flex;align-items:center;justify-content:center;width:26px;height:24px;border:none;background:#fff;color:#718096;cursor:pointer;font-size:12px;padding:0;line-height:1}.builder-toolbar-btn+.builder-toolbar-btn{border-left:1px solid #e2e8f0}.builder-toolbar-btn:hover{background:#f7fafc;color:#4a5568}.builder-toolbar-btn.active{background:#ebf4ff;color:#3182ce}.builder-toolbar-fontsize{width:36px;height:24px;border:none;background:#fff;font-size:11px;font-family:inherit;text-align:center;color:#2d3748;padding:0 2px;-moz-appearance:textfield}.builder-toolbar-fontsize::-webkit-inner-spin-button,.builder-toolbar-fontsize::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.builder-toolbar-fontsize:focus{outline:none;background:#f7fafc}.builder-style-row{margin-bottom:6px}.builder-style-label{display:block;font-size:11px;color:#718096;margin-bottom:3px}.builder-style-color-row{display:flex;gap:6px;align-items:center}.builder-style-color{width:28px;height:28px;padding:1px;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;flex-shrink:0}.builder-color-map-reset{font-size:10px;padding:0 4px;cursor:pointer;border:1px solid #ccc;border-radius:3px;background:#fff;line-height:1.4}.builder-style-value{font-size:11px;color:#718096;margin-left:6px;min-width:32px}.builder-canvas-settings-wrapper{position:relative}.builder-canvas-popover{position:absolute;top:100%;left:0;margin-top:4px;width:240px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001f;padding:12px;z-index:50;display:flex;flex-direction:column;gap:10px}.builder-canvas-popover-title{font-size:12px;font-weight:600;color:#2d3748;margin-bottom:2px}.builder-canvas-popover .builder-prop-input,.builder-canvas-popover .builder-style-color-row{margin-top:3px}.transform-editor{display:flex;flex-direction:column;flex:1;min-height:0;background:#f7fafc}.transform-editor-body{display:flex;flex:1;min-height:0;overflow:hidden}.transform-step-list{width:300px;min-width:300px;background:#fff;border-right:1px solid #e2e8f0;overflow-y:auto;display:flex;flex-direction:column}.transform-step-list-header{padding:8px 14px;font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0}.transform-step-item{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-bottom:1px solid #f7fafc;background:#fff;cursor:pointer;text-align:left;font-family:inherit;width:100%}.transform-step-item:hover{background:#f7fafc}.transform-step-selected{background:#ebf4ff!important;border-left:3px solid #3182ce}.transform-step-drag-handle{font-size:12px;color:#a0aec0;cursor:grab;flex-shrink:0;line-height:1}.transform-step-drag-handle:active{cursor:grabbing}.transform-step-content{flex:1;min-width:0}.transform-step-label{font-size:12px;font-weight:600;color:#2d3748}.transform-step-summary{font-size:11px;color:#718096;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transform-step-remove{font-size:16px;color:#a0aec0;background:none;border:none;cursor:pointer;padding:2px 6px;line-height:1;border-radius:3px;flex-shrink:0}.transform-step-remove:hover{color:#c53030;background:#fff5f5}.transform-add-step{display:flex;gap:4px;padding:8px 14px;border-bottom:1px solid #e2e8f0}.transform-add-step .builder-prop-select{flex:1}.transform-add-btn{padding:4px 10px;border-radius:4px;border:1px solid #3182ce;background:#3182ce;color:#fff;font-size:12px;font-weight:500;cursor:pointer}.transform-add-btn:hover:not(:disabled){background:#2b6cb0}.transform-add-btn:disabled{opacity:.4;cursor:not-allowed}.transform-step-config{border-top:1px solid #e2e8f0;padding:0;flex:1;overflow-y:auto}.transform-step-config-header{padding:8px 14px;font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;background:#f7fafc}.transform-config-row{display:flex;align-items:center;gap:4px;padding:4px 14px}.transform-config-arrow{color:#a0aec0;font-size:12px;flex-shrink:0}.transform-sql-textarea{font-family:SF Mono,Menlo,Monaco,Courier New,monospace;font-size:12px;resize:vertical;min-height:60px}.transform-sql-hint{font-size:11px;color:#a0aec0;margin-top:4px}.transform-sql-hint code{background:#edf2f7;padding:1px 4px;border-radius:3px;font-size:11px}.measure-editor{display:flex;flex-direction:column;height:100%;flex:1}.measure-editor-body{display:flex;flex:1;min-height:0;overflow:hidden}.measure-list{width:280px;min-width:280px;background:#fff;border-right:1px solid #e2e8f0;overflow-y:auto;display:flex;flex-direction:column}.measure-list-header{padding:8px 14px;font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0}.measure-table-group-header{padding:6px 14px;font-size:11px;font-weight:600;color:#4a5568;background:#f7fafc;border-bottom:1px solid #e2e8f0;text-transform:uppercase;letter-spacing:.3px}.measure-list-item{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-bottom:1px solid #f7fafc;background:#fff;cursor:pointer;text-align:left;width:100%}.measure-list-item:hover{background:#f7fafc}.measure-list-item-selected{background:#ebf4ff!important;border-left:3px solid #3182ce}.measure-list-item-content{flex:1;min-width:0}.measure-list-item-name{font-size:12px;font-weight:600;color:#2b6cb0}.measure-list-item-expr{font-size:11px;color:#718096;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.measure-delete-btn{background:none;border:none;color:#a0aec0;cursor:pointer;font-size:16px;padding:0 4px;line-height:1}.measure-delete-btn:hover{color:#e53e3e}.measure-add{padding:8px 14px}.measure-config{flex:1;overflow-y:auto;padding:16px}.measure-config-empty{color:#a0aec0;font-size:13px;text-align:center;padding:40px 20px}.measure-form{max-width:480px}.measure-expr-textarea{resize:vertical;font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:12px;min-height:60px}.measure-expr-hint{font-size:11px;color:#a0aec0;margin-top:2px}.measure-func-ref{margin-top:6px}.measure-func-ref-toggle{font-size:11px;color:#4299e1;background:none;border:none;cursor:pointer;padding:0;text-decoration:underline}.measure-func-ref-toggle:hover{color:#2b6cb0}.measure-func-ref-content{margin-top:6px;border:1px solid #e2e8f0;border-radius:6px;padding:6px 8px;max-height:220px;overflow-y:auto;background:#f7fafc}.measure-func-ref-category{margin-bottom:6px}.measure-func-ref-category:last-child{margin-bottom:0}.measure-func-ref-category-name{font-size:10px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.measure-func-ref-item{display:flex;gap:8px;padding:1px 0;font-size:11px;line-height:1.4}.measure-func-ref-syntax{font-family:monospace;color:#2d3748;white-space:nowrap;min-width:160px}.measure-func-ref-desc{color:#a0aec0}.measure-form-actions{display:flex;gap:8px;margin-top:16px}.measure-form-error{font-size:11px;color:#c53030;margin-top:2px}.measure-cancel-btn{background:none;border:1px solid #cbd5e0;color:#4a5568;padding:4px 14px;border-radius:4px;font-size:12px;cursor:pointer}.measure-cancel-btn:hover{background:#f7fafc}.transform-preview{flex:1;overflow:auto;display:flex;flex-direction:column;min-width:0}.transform-preview-header{padding:8px 14px;font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0}.transform-preview-status{padding:20px;text-align:center;color:#a0aec0;font-size:13px}.transform-preview-error{padding:12px 16px;margin:8px;background:#fff5f5;color:#c53030;border-radius:6px;font-size:12px}.transform-preview-table{flex:1;overflow:auto}.transform-preview-table table{width:100%;border-collapse:collapse;font-size:12px}.transform-preview-table th{text-align:left;padding:6px 10px;border-bottom:2px solid #e2e8f0;font-weight:600;color:#4a5568;position:sticky;top:0;background:#fff;white-space:nowrap}.transform-preview-table td{padding:4px 10px;border-bottom:1px solid #edf2f7;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.transform-preview-table tr:nth-child(2n){background:#f7fafc}.builder-field-transforms-btn{font-size:10px;color:#718096;background:none;border:1px solid #e2e8f0;border-radius:3px;padding:1px 6px;cursor:pointer;margin-left:auto;flex-shrink:0}.builder-field-transforms-btn:hover,.builder-split-toggle-active{background:#ebf4ff;color:#3182ce;border-color:#bee3f8}.builder-side-panel{display:flex;flex-direction:column;background:#fff;border-left:1px solid #e2e8f0;overflow:hidden;position:relative;flex-shrink:0}.builder-side-panel-collapsed{width:40px!important;min-width:40px;cursor:pointer}.builder-side-panel-collapsed:hover{background:#f7fafc}.side-panel-header{display:flex;align-items:center;padding:6px 10px;border-bottom:1px solid #e2e8f0;flex-shrink:0;gap:4px;cursor:grab}.side-panel-header:active{cursor:grabbing}.side-panel-title{flex:1;font-size:12px;font-weight:600;color:#2d3748}.side-panel-btn{border:none;background:none;color:#a0aec0;cursor:pointer;padding:2px 4px;font-size:14px;line-height:1}.side-panel-btn:hover{color:#4a5568}.side-panel-collapsed-rail{writing-mode:vertical-rl;display:flex;gap:16px;padding:12px 0;align-items:center;justify-content:center;height:100%;font-size:12px;color:#718096}.side-panel-collapsed-title{cursor:pointer}.sidebar-content{flex:1;overflow-y:auto;min-height:0}.sidebar-resize-handle{position:absolute;left:0;top:0;bottom:0;width:4px;cursor:col-resize;z-index:10}.sidebar-resize-handle:hover,.sidebar-resize-handle:active{background:#3182ce}.panel-drop-zone{display:flex;flex-direction:row;flex-shrink:0;align-items:stretch}.panel-drop-zone-empty{min-width:0;width:0;transition:min-width .15s ease}.panel-drop-zone-empty.drag-over{min-width:40px;background:#3182ce0f;border:1px dashed #90cdf4;border-radius:4px}.panel-drop-zone.drag-over{background:#3182ce08}.panel-drop-zone-left .builder-side-panel{border-left:none;border-right:1px solid #e2e8f0}.panel-drop-zone-left .sidebar-resize-handle{left:auto;right:0}.panel-drop-indicator.active{width:3px;align-self:stretch;flex-shrink:0;background:#3182ce;border-radius:2px}.side-panel-dragging{opacity:.4}.canvas-edge-drop-left{border-left:3px solid #3182ce}.canvas-edge-drop-right{border-right:3px solid #3182ce}.builder-panel-toggles{display:flex;align-items:center;gap:4px;margin-left:8px}.builder-viz-panel{background:#fff;overflow-y:auto}.builder-viz-section-label{font-size:11px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;padding:10px 14px 2px}.builder-type-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;padding:4px 14px 8px}.builder-type-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 2px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;font-size:9px;color:#718096;cursor:pointer;transition:all .15s}.builder-type-btn:hover{background:#f7fafc;border-color:#cbd5e0}.builder-type-btn-active{background:#ebf4ff;border-color:#3182ce;color:#3182ce;font-weight:600}.builder-type-btn-icon{font-size:14px}.builder-wells-section{padding:8px 0}.builder-well{padding:0 14px;margin-bottom:8px}.builder-well-label{font-size:11px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.builder-well-dropzone{min-height:32px;border:1px dashed #cbd5e0;border-radius:6px;padding:4px;transition:all .15s}.builder-well-dropzone-active{border-color:#3182ce;background:#ebf8ff}.builder-well-empty{display:flex;align-items:center;justify-content:center;padding:6px;font-size:11px;color:#a0aec0}.builder-well-drop-indicator{height:2px;background:#3182ce;border-radius:1px;margin:1px 0}.builder-well-item{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;color:#2d3748;margin-bottom:2px;cursor:grab}.builder-well-item:active{cursor:grabbing}.builder-well-item-measure{background:#ebf4ff;border-color:#bee3f8;color:#2b6cb0}.builder-well-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.builder-well-item-agg{font-size:10px;padding:1px 4px;border:1px solid #e2e8f0;border-radius:3px;background:#fff;color:#718096;cursor:pointer}.builder-well-item-agg:hover{border-color:#3182ce;color:#3182ce}.builder-well-item-remove{border:none;background:none;font-size:14px;color:#a0aec0;cursor:pointer;padding:0 2px;line-height:1}.builder-well-item-remove:hover{color:#e53e3e}.builder-analytics-section{padding:4px 12px 8px}.builder-analytics-item{border:1px solid #e2e8f0;border-radius:6px;margin-bottom:4px;overflow:hidden}.builder-analytics-item-header{display:flex;align-items:center;gap:6px;padding:5px 8px;cursor:pointer;font-size:12px;color:#4a5568;-webkit-user-select:none;user-select:none}.builder-analytics-item-header:hover{background:#f7fafc}.builder-analytics-swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}.builder-analytics-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.builder-analytics-item-props{padding:4px 8px 8px;border-top:1px solid #edf2f7;display:flex;flex-direction:column;gap:4px}.builder-prop-group-inline{display:flex;align-items:center;gap:6px}.builder-prop-label-sm{font-size:11px;color:#718096;min-width:60px;flex-shrink:0}.builder-prop-input-sm{flex:1;min-width:0;font-size:11px;padding:2px 4px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#2d3748}.builder-prop-color{width:24px;height:20px;border:1px solid #e2e8f0;border-radius:4px;padding:0;cursor:pointer}.builder-analytics-add{margin-top:4px}.builder-analytics-add select{width:100%;font-size:12px}.context-menu{position:fixed;z-index:200;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:140px;overflow:hidden;padding:4px 0}.context-menu-item{display:block;width:100%;padding:6px 12px;border:none;background:none;font-size:12px;color:#4a5568;cursor:pointer;text-align:left}.context-menu-item:hover:not(:disabled){background:#ebf4ff;color:#2b6cb0}.context-menu-item:disabled{color:#cbd5e0;cursor:default}.context-menu-item-danger:hover:not(:disabled){background:#fff5f5;color:#e53e3e}.context-menu-item-divider{border-top:1px solid #e2e8f0;margin-top:4px;padding-top:10px}.builder-well-item-rename-input{flex:1;min-width:0;border:1px solid #3182ce;border-radius:3px;padding:1px 4px;font-size:12px;color:#2d3748;outline:none;background:#fff}.builder-agg-dropdown{position:absolute;top:100%;right:0;z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:140px;overflow:hidden}.builder-agg-option{display:block;width:100%;padding:6px 12px;border:none;background:none;font-size:12px;color:#4a5568;cursor:pointer;text-align:left}.builder-agg-option:hover{background:#ebf4ff;color:#2b6cb0}.builder-agg-option-active{font-weight:600;color:#3182ce}.json-source-editor{display:flex;flex-direction:column;background:#1e1e1e;flex:1;min-height:0;height:100%;overflow:hidden}.json-editor-error{font-size:11px;color:#f48771;background:#f487711a;padding:1px 8px;border-radius:3px;margin-left:auto}.json-editor-valid{font-size:11px;color:#89d185;background:#89d1851a;padding:1px 8px;border-radius:3px;margin-left:auto}.json-editor-body{flex:1;min-height:0;overflow:hidden}.json-editor-body .cm-editor{height:100%;font-size:12.5px}.json-editor-body .cm-scroller{overflow:auto}.cm-gutterElement.cm-gutter-highlighted{background:#3182ce26;color:#569cd6}.publish-description{font-size:13px;color:#718096;line-height:1.6;margin-bottom:16px;padding:10px 12px;background:#f7fafc;border-radius:6px}.publish-summary{margin-top:12px;padding:10px 12px;background:#f7fafc;border-radius:6px}.publish-summary-title{font-size:12px;font-weight:600;color:#4a5568;margin-bottom:6px}.publish-summary-item{font-size:12px;color:#718096;padding:2px 0 2px 12px;position:relative}.publish-summary-item:before{content:"•";position:absolute;left:0;color:#a0aec0}.publish-field-hint{font-size:11px;color:#718096;margin-top:2px}.publish-field-hint-update{color:#d69e2e;font-weight:600}.builder-content{display:flex;flex:1;min-height:0}.builder-content-main{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0}.ai-panel{position:relative;display:flex;flex-direction:column;flex-shrink:0;border-left:1px solid #e2e8f0;background:#fafafa}.ai-panel-resize-handle{position:absolute;left:0;top:0;bottom:0;width:4px;cursor:col-resize;z-index:10}.ai-panel-resize-handle:hover,.ai-panel-resize-handle:active{background:#3182ce}.ai-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.ai-panel-header h3{font-size:13px;font-weight:600;color:#2d3748;margin:0}.ai-config-toggle{padding:3px 8px;border-radius:4px;border:1px solid #e2e8f0;background:#fff;font-size:11px;cursor:pointer;color:#718096}.ai-config-toggle:hover{background:#f7fafc}.ai-config{padding:10px 14px;border-bottom:1px solid #e2e8f0;background:#f7fafc;flex-shrink:0}.ai-config-label{display:block;font-size:11px;font-weight:600;color:#718096;margin-bottom:8px}.ai-config-input{display:block;width:100%;padding:5px 8px;margin-top:3px;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;outline:none;box-sizing:border-box}.ai-config-input:focus{border-color:#805ad5;box-shadow:0 0 0 1px #805ad5}.ai-config-save{margin-top:8px;padding:5px 14px;border-radius:4px;border:1px solid #805ad5;background:#805ad5;color:#fff;font-size:12px;cursor:pointer;font-weight:500}.ai-config-save:hover{background:#6b46c1}.ai-messages{flex:1;overflow-y:auto;padding:10px 14px}.ai-empty{font-size:12px;color:#a0aec0;line-height:1.6;padding:12px 0}.ai-empty em{color:#718096}.ai-message{margin-bottom:12px;padding:8px 10px;border-radius:8px;font-size:12px;line-height:1.5}.ai-message-user{background:#ebf4ff;color:#2b6cb0;margin-left:20px}.ai-message-assistant{background:#fff;color:#2d3748;border:1px solid #e2e8f0;margin-right:20px}.ai-message-content{white-space:pre-wrap;word-break:break-word}.ai-thinking{color:#a0aec0;font-style:italic}.ai-visuals-preview{margin-top:8px;padding:8px;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0}.ai-visuals-count{font-size:11px;font-weight:600;color:#4a5568;margin-bottom:6px}.ai-visuals-list{list-style:none;padding:0;margin:0 0 8px}.ai-visuals-list li{font-size:11px;color:#718096;padding:2px 0}.ai-visual-type{display:inline-block;padding:1px 5px;border-radius:3px;background:#edf2f7;color:#4a5568;font-size:10px;font-weight:600;text-transform:uppercase;margin-right:6px}.ai-insert-btn{width:100%;padding:5px 10px;border-radius:4px;border:1px solid #805ad5;background:#805ad5;color:#fff;font-size:11px;cursor:pointer;font-weight:500}.ai-insert-btn:hover:not(:disabled){background:#6b46c1}.ai-insert-btn:disabled{opacity:.5;cursor:default;background:#a0aec0;border-color:#a0aec0}.ai-error{padding:6px 14px;font-size:11px;color:#e53e3e;background:#fff5f5;border-top:1px solid #fed7d7;flex-shrink:0}.ai-input-area{display:flex;flex-direction:column;gap:6px;padding:10px 14px;border-top:1px solid #e2e8f0;background:#fff;flex-shrink:0}.ai-input-options{display:flex;align-items:center;justify-content:space-between;gap:8px}.ai-sample-values-toggle{display:flex;align-items:center;gap:4px;font-size:11px;color:#64748b;cursor:pointer;-webkit-user-select:none;user-select:none}.ai-sample-values-toggle input{margin:0;cursor:pointer}.ai-input{flex:1;padding:6px 8px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-family:inherit;resize:none;outline:none;min-height:0}.ai-input:focus{border-color:#805ad5;box-shadow:0 0 0 1px #805ad5}.ai-send-btn{padding:6px 14px;border-radius:6px;border:1px solid #805ad5;background:#805ad5;color:#fff;font-size:12px;cursor:pointer;font-weight:500;align-self:flex-end}.ai-send-btn:hover:not(:disabled){background:#6b46c1}.ai-send-btn:disabled{opacity:.5;cursor:default}.data-view{display:flex;flex-direction:column;flex:1;min-height:0}.data-view-toolbar{display:flex;align-items:center;gap:12px;padding:8px 24px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.data-view-back-btn{padding:6px 12px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;font-size:12px;font-weight:500;cursor:pointer;color:#4a5568}.data-view-back-btn:hover{background:#f7fafc}.data-view-selected-label{font-size:14px;font-weight:600;color:#2d3748}.data-view-tab-group{display:flex;gap:0;margin-left:auto;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.data-view-tab{padding:5px 12px;border:none;border-right:1px solid #e2e8f0;background:#fff;font-size:12px;font-weight:500;color:#718096;cursor:pointer}.data-view-tab:last-child{border-right:none}.data-view-tab:hover{background:#f7fafc;color:#2d3748}.data-view-tab-active{background:#ebf4ff;color:#3182ce;font-weight:600}.data-view-body{display:flex;flex:1;min-height:0;overflow:hidden}.data-view-table-list{width:220px;min-width:220px;background:#fff;border-right:1px solid #e2e8f0;overflow-y:auto}.data-view-table-item{display:block;width:100%;padding:10px 14px;border:none;border-bottom:1px solid #f7fafc;background:#fff;cursor:pointer;text-align:left;font-family:inherit}.data-view-table-item:hover{background:#f7fafc}.data-view-table-selected{background:#ebf4ff!important;border-left:3px solid #3182ce}.data-view-table-name{font-size:13px;font-weight:600;color:#2d3748}.data-view-table-meta{display:flex;align-items:center;gap:8px;margin-top:2px;font-size:11px;color:#a0aec0}.data-view-transform-badge{padding:1px 6px;border-radius:3px;background:#faf5ff;color:#805ad5;font-size:10px;font-weight:600}.data-view-preview{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.data-view-preview-header{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;color:#2d3748;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;min-height:0}.data-view-row-count{font-size:11px;font-weight:400;color:#a0aec0}.data-view-preview-empty{display:flex;justify-content:center;align-items:center;height:100%;color:#a0aec0;font-size:13px}.data-view-preview-status{padding:20px;text-align:center;color:#a0aec0;font-size:13px}.data-view-preview-error{padding:12px 16px;margin:8px;background:#fff5f5;color:#c53030;border-radius:6px;font-size:12px}.data-view-grid-wrapper{flex:1;display:flex;flex-direction:column;min-height:0;font-size:12px}.data-view-grid-header-scroll{overflow:hidden;flex-shrink:0;border-bottom:2px solid #e2e8f0;background:#fff}.data-view-grid-header{position:relative}.data-view-grid-th{display:flex;flex-direction:column;padding:6px 10px;white-space:nowrap;box-sizing:border-box}.data-view-grid-th-content{display:flex;align-items:flex-start;justify-content:space-between;gap:4px}.data-view-grid-th-text{display:flex;flex-direction:column;min-width:0;overflow:hidden}.col-sortable{cursor:pointer}.col-sortable:hover .data-view-col-name{color:#3182ce}.col-sort-indicator{font-size:9px;color:#3182ce}.col-resize-handle{position:absolute;right:0;top:0;bottom:0;width:4px;cursor:col-resize;z-index:2}.col-resize-handle:hover,.col-resize-handle:active{background:#3182ce}.col-filter-btn{flex-shrink:0;padding:0 2px;border:none;background:none;cursor:pointer;font-size:10px;line-height:1;color:#a0aec0;opacity:0;transition:opacity .1s}.data-view-grid-th:hover .col-filter-btn,.col-filter-btn-active{opacity:1}.col-filter-btn-active{color:#3182ce}.col-filter-btn:hover{color:#2d3748}.col-filter-dropdown{position:absolute;top:100%;left:0;width:220px;max-height:320px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001f;z-index:100;display:flex;flex-direction:column;font-weight:400}.col-filter-search{width:100%;padding:8px 10px;border:none;border-bottom:1px solid #e2e8f0;font-size:12px;outline:none}.col-filter-search:focus{border-bottom-color:#3182ce}.col-filter-actions{display:flex;gap:8px;padding:6px 10px;border-bottom:1px solid #edf2f7}.col-filter-actions button{border:none;background:none;color:#3182ce;cursor:pointer;font-size:11px;padding:0}.col-filter-actions button:hover{text-decoration:underline}.col-filter-list{flex:1;overflow-y:auto;max-height:200px;padding:4px 0}.col-filter-item{display:flex;align-items:center;gap:6px;padding:3px 10px;cursor:pointer;font-size:12px;color:#4a5568}.col-filter-item:hover{background:#edf2f7}.col-filter-item input[type=checkbox]{margin:0;flex-shrink:0}.col-filter-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-filter-empty{padding:8px 10px;font-size:12px;color:#a0aec0;text-align:center}.col-filter-apply{width:100%;padding:8px;border:none;border-top:1px solid #e2e8f0;background:#3182ce;color:#fff;font-size:12px;font-weight:500;cursor:pointer;border-radius:0 0 6px 6px}.col-filter-apply:hover{background:#2b6cb0}.data-view-col-name{font-weight:600;color:#2d3748}.data-view-col-type{font-size:10px;font-weight:400;color:#a0aec0;text-transform:uppercase}.data-view-grid-body{flex:1;overflow:auto;min-height:0}.data-view-grid-td{padding:4px 10px;border-bottom:1px solid #edf2f7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px;box-sizing:border-box}.data-view-grid-td-even{background:#f7fafc}.data-view-grid-td-placeholder{background:#f7fafc;opacity:.5}.model-view{display:flex;flex-direction:column;flex:1;min-height:0}.model-view-toolbar{display:flex;align-items:center;gap:12px;padding:8px 24px;background:#fff;border-bottom:1px solid #e2e8f0}.model-view-title{font-size:14px;font-weight:600;color:#2d3748}.model-view-stats{font-size:12px;color:#a0aec0}.model-view-canvas{flex:1;min-height:0}.model-table-node{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 4px #00000014;min-width:200px;max-width:260px;font-family:inherit}.model-table-header{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;font-size:12px;font-weight:700;color:#fff;background:#3182ce;border-radius:5px 5px 0 0;position:relative}.model-table-header-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.model-table-header-count{font-size:10px;font-weight:600;background:#ffffff40;border-radius:8px;padding:0 6px;line-height:18px;flex-shrink:0;margin-left:8px}.model-table-columns{max-height:260px;overflow-y:auto;padding:2px 0}.model-table-columns::-webkit-scrollbar{width:4px}.model-table-columns::-webkit-scrollbar-track{background:transparent}.model-table-columns::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:2px}.model-table-col{display:flex;align-items:center;gap:6px;padding:3px 10px;border-bottom:1px solid #f7fafc;font-size:11px}.model-table-col:last-child{border-bottom:none}.model-table-col-related{background:#ebf8ff}.model-table-col-measure{font-style:italic}.model-table-divider{height:1px;background:#e2e8f0;margin:2px 10px}.model-table-col-icon{font-size:10px;width:16px;text-align:center;flex-shrink:0}.model-table-col-name{font-weight:500;color:#2d3748;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.model-table-col-type{font-size:9px;color:#a0aec0;text-transform:uppercase;flex-shrink:0}.model-edge-label{position:absolute;font-size:12px;font-weight:700;color:#3182ce;pointer-events:none}.model-edge-center-label{position:absolute;font-size:14px;color:#718096}.model-view-hint{font-size:11px;color:#a0aec0;margin-left:auto}.model-table-col{position:relative}.model-col-handle{width:8px!important;height:8px!important;min-width:8px!important;min-height:8px!important;background:#3182ce!important;border:2px solid white!important;opacity:0;pointer-events:auto!important;cursor:crosshair;transition:opacity .15s;z-index:10}.model-col-handle-left{left:-5px!important}.model-col-handle-right{right:-5px!important}.model-table-col:hover .model-col-handle{opacity:1}.model-table-col-related .model-col-handle{opacity:.6}.model-table-col-related:hover .model-col-handle{opacity:1}.model-table-node{overflow:visible!important}.model-edge-toolbar{position:absolute;display:flex;align-items:center;gap:2px;padding:4px 6px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 2px 8px #0000001f;white-space:nowrap}.model-edge-toolbar-btn{padding:2px 8px;font-size:11px;font-weight:500;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#4a5568;cursor:pointer;transition:all .1s}.model-edge-toolbar-btn:hover{background:#edf2f7}.model-edge-toolbar-btn-active{background:#3182ce;color:#fff;border-color:#3182ce}.model-edge-toolbar-btn-active:hover{background:#2b6cb0}.model-edge-toolbar-btn-delete{color:#e53e3e;font-size:14px;font-weight:700;padding:2px 6px}.model-edge-toolbar-btn-delete:hover{background:#fff5f5;border-color:#e53e3e}.model-edge-toolbar-sep{width:1px;height:16px;background:#e2e8f0;margin:0 2px}.new-table-chooser-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;width:90vw;max-width:480px;display:flex;flex-direction:column;overflow:hidden}.new-table-chooser-body{padding:8px 24px 24px}.new-table-chooser-subtitle{margin:0 0 16px;font-size:13px;color:#718096}.new-table-chooser-grid{display:flex;flex-direction:column;gap:10px}.new-table-chooser-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s,box-shadow .15s}.new-table-chooser-card:hover{border-color:#3182ce;background:#ebf8ff;box-shadow:0 2px 8px #3182ce1a}.new-table-chooser-card-icon{font-size:24px;flex-shrink:0;width:36px;text-align:center}.new-table-chooser-card-text{display:flex;flex-direction:column;gap:2px}.new-table-chooser-card-label{font-size:14px;font-weight:600;color:#2d3748;display:block}.new-table-chooser-card-desc{font-size:12px;color:#a0aec0;display:block}.table-editor-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;width:90vw;max-width:860px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.table-editor-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1;min-height:0}.table-editor-top-row{display:flex;align-items:flex-end;gap:12px}.table-editor-mode-toggle{display:flex;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden;flex-shrink:0}.table-editor-mode-btn{padding:6px 14px;border:none;border-right:1px solid #e2e8f0;background:#fff;font-size:12px;font-weight:500;color:#718096;cursor:pointer}.table-editor-mode-btn:last-child{border-right:none}.table-editor-mode-btn:hover{background:#f7fafc;color:#2d3748}.table-editor-mode-btn-active{background:#ebf4ff;color:#3182ce;font-weight:600}.table-editor-ai-bar{display:flex;gap:6px;padding:8px 10px;background:#faf5ff;border:1px solid #e9d8fd;border-radius:8px}.table-editor-ai-input{flex:1;padding:6px 10px;border:1px solid #d6bcfa;border-radius:6px;font-size:12px;font-family:inherit;background:#fff;outline:none}.table-editor-ai-input:focus{border-color:#805ad5;box-shadow:0 0 0 2px #805ad526}.table-editor-ai-btn{padding:6px 14px;border-radius:6px;border:1px solid #805ad5;background:#805ad5;color:#fff;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap}.table-editor-ai-btn:hover:not(:disabled){background:#6b46c1}.table-editor-ai-btn:disabled{opacity:.5;cursor:not-allowed}.table-editor-grid-area{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.table-editor-col-header{display:flex;flex-direction:column;gap:3px;padding:4px 2px;width:100%}.table-editor-col-header-top{display:flex;align-items:center;gap:2px}.table-editor-col-header-name{flex:1;min-width:0;padding:2px 5px;border:1px solid transparent;border-radius:3px;font-size:12px;font-weight:600;color:#2d3748;background:transparent}.table-editor-col-header-name:hover{border-color:#e2e8f0;background:#f7fafc}.table-editor-col-header-name:focus{outline:none;border-color:#3182ce;background:#fff}.table-editor-col-header-type{width:100%;padding:1px 3px;border:1px solid transparent;border-radius:3px;font-size:10px;color:#a0aec0;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.table-editor-col-header-type:hover{border-color:#e2e8f0;background:#f7fafc;color:#718096}.table-editor-col-header-type:focus{outline:none;border-color:#3182ce;background:#fff;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.table-editor-col-header-remove{flex-shrink:0;background:none;border:none;color:#cbd5e0;cursor:pointer;font-size:14px;padding:0 2px;line-height:1;border-radius:3px}.table-editor-col-header-remove:hover{color:#e53e3e;background:#fff5f5}.table-editor-col-header-add{width:100%;height:100%;background:none;border:none;font-size:18px;color:#cbd5e0;cursor:pointer;display:flex;align-items:center;justify-content:center}.table-editor-col-header-add:hover{color:#3182ce;background:#ebf8ff}.table-editor-sql-area{display:flex;flex-direction:column;gap:8px}.table-editor-sql-input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-family:SF Mono,Fira Code,monospace;font-size:13px;resize:vertical;background:#1e1e1e;color:#d4d4d4}.table-editor-sql-input:focus{border-color:#3182ce;outline:none}.table-editor-sql-actions{display:flex;gap:8px}.table-editor-preview-btn{padding:5px 12px;font-size:12px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#4a5568;cursor:pointer}.table-editor-preview-btn:hover:not(:disabled){border-color:#3182ce;color:#3182ce}.table-editor-preview-btn:disabled{opacity:.5;cursor:not-allowed}.table-editor-preview-results{max-height:240px;overflow:auto;border:1px solid #e2e8f0;border-radius:6px}.table-editor-grid{width:100%;border-collapse:collapse;font-size:12px}.table-editor-grid th{padding:6px 8px;text-align:left;font-weight:600;font-size:12px;color:#4a5568;background:#f7fafc;border-bottom:2px solid #e2e8f0;position:sticky;top:0}.table-editor-grid td{padding:4px 8px;border-bottom:1px solid #edf2f7}.waterfall-chart,.funnel-chart{width:100%;height:100%}.gantt-chart{width:100%;height:100%;overflow:auto}.visual-textbox{line-height:1.6;word-wrap:break-word}.visual-textbox h1{font-size:20px;font-weight:700;margin:8px 0 4px}.visual-textbox h2{font-size:16px;font-weight:600;margin:6px 0 3px}.visual-textbox h3{font-size:14px;font-weight:600;margin:4px 0 2px}.visual-textbox li{margin-left:16px;list-style:disc}.visual-image img{display:block}.visual-button{padding:8px 20px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s,color .15s}.visual-button-primary{background:#3182ce;color:#fff;border-color:#3182ce}.visual-button-primary:hover:not(:disabled){background:#2b6cb0}.visual-button-secondary{background:#fff;color:#4a5568;border-color:#e2e8f0}.visual-button-secondary:hover:not(:disabled){background:#f7fafc}.visual-button:disabled{opacity:.5;cursor:not-allowed}.visual-shape-line hr{margin:0}.filter-row{background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;padding:6px 8px;margin-bottom:2px;cursor:grab}.filter-row:active{cursor:grabbing}.filter-row-measure{background:#ebf4ff;border-color:#bee3f8}.filter-row-header{display:flex;align-items:center;gap:4px}.filter-row-grip{font-size:10px;color:#a0aec0;flex-shrink:0;cursor:grab}.filter-row-header .builder-prop-select{flex:1;min-width:0}.filter-row-controls{display:flex;flex-direction:column;gap:4px;margin-top:4px}.filter-row-controls .builder-prop-select,.filter-row-controls .builder-prop-input{width:100%}.filter-between-inputs{display:flex;gap:4px}.filter-between-inputs .builder-prop-input{flex:1}.filter-empty{font-size:12px;color:#a0aec0;font-style:italic;padding:4px 0}.selection-pane{display:flex;flex-direction:column;gap:1px;padding:4px 0}.selection-pane-item{display:flex;align-items:center;gap:4px;min-height:32px;padding:2px 8px;cursor:pointer;border-left:3px solid transparent;-webkit-user-select:none;user-select:none}.selection-pane-item:hover{background:#f7fafc}.selection-pane-item-selected{border-left-color:#3182ce;background:#ebf8ff}.selection-pane-item-hidden .selection-pane-item-name{opacity:.4;text-decoration:line-through}.selection-pane-item-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selection-pane-icon-btn{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:14px;border-radius:3px;opacity:.5;line-height:1}.selection-pane-icon-btn:hover{opacity:1;background:#edf2f7}.selection-pane-icon-btn.active{opacity:1;color:#3182ce}.selection-pane-item-drop-target{border-top:2px solid #3182ce}.selection-pane-empty{font-size:12px;color:#a0aec0;font-style:italic;padding:8px;text-align:center}.builder-visual-locked{cursor:default!important}.builder-lock-indicator{position:absolute;top:4px;right:4px;font-size:12px;opacity:.5;pointer-events:none;z-index:1}.titlebar-collab-section{display:flex;align-items:center;gap:6px}.titlebar-collab-divider{width:1px;height:20px;background:#ffffff1f;margin:0 4px}.titlebar-btn-share{display:flex;align-items:center;gap:6px}.titlebar-btn-share-live{border-color:#22c55e4d;color:#86efac}.titlebar-btn-share-live:hover{border-color:#22c55e80;color:#4ade80}.titlebar-share-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0}.presence-bar{display:flex;align-items:center;padding:0 2px}.presence-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;border:2px solid #1e293b;margin-left:-8px;cursor:default;position:relative;transition:transform .15s}.presence-avatar:first-child{margin-left:0}.presence-avatar:hover{transform:translateY(-2px);z-index:10!important}.presence-overflow{margin-left:-4px;padding:0 8px;height:26px;border-radius:13px;background:#ffffff1f;color:#94a3b8;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;border:2px solid #1e293b}.stale-model-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#fefce8;border:1px solid #eab308;border-radius:6px;font-size:12px;color:#854d0e;white-space:nowrap}.stale-model-dot{width:6px;height:6px;border-radius:50%;background:#eab308;flex-shrink:0}.stale-model-refresh-btn{background:none;border:1px solid #ca8a04;border-radius:4px;padding:2px 8px;font-size:11px;color:#854d0e;cursor:pointer}.stale-model-refresh-btn:hover{background:#fef9c3}.share-panel{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000002e,0 0 0 1px #0000000f;z-index:1000;overflow:hidden;animation:share-panel-in .15s ease}@keyframes share-panel-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.share-panel-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 10px;border-bottom:1px solid #f1f5f9}.share-panel-title{font-size:13px;font-weight:600;color:#1e293b}.share-panel-status-live{display:flex;align-items:center;gap:6px;font-size:12px;color:#16a34a;font-weight:500}.share-panel-live-dot{width:6px;height:6px;border-radius:50%;background:#16a34a;animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.4}}.share-panel-error{padding:8px 16px;background:#fef2f2;color:#dc2626;font-size:12px;border-bottom:1px solid #fecaca}.share-panel-section-label{padding:10px 16px 6px;font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.share-panel-peers{padding:6px 0;max-height:260px;overflow-y:auto}.share-panel-peer{display:flex;align-items:center;gap:10px;padding:6px 16px;transition:background .1s}.share-panel-peer:hover{background:#f8fafc}.share-panel-peer-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;flex-shrink:0}.share-panel-peer-info{min-width:0}.share-panel-peer-name{font-size:13px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-panel-you{color:#94a3b8;font-weight:400}.share-panel-peer-meta{font-size:11px;color:#94a3b8}.share-panel-hint{padding:10px 16px;font-size:12px;color:#94a3b8}.share-panel-browse{padding:2px 0 8px;max-height:300px;overflow-y:auto}.share-panel-ws{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;background:none;border:none;cursor:pointer;font-size:13px;font-weight:500;color:#334155;text-align:left;transition:background .1s}.share-panel-ws:hover{background:#f8fafc}.share-panel-ws-arrow{color:#94a3b8;font-size:10px;width:12px;flex-shrink:0}.share-panel-ws-reports{padding-left:20px}.share-panel-report{display:flex;justify-content:space-between;align-items:center;width:100%;padding:6px 16px;background:none;border:none;cursor:pointer;font-size:13px;color:#475569;text-align:left;transition:background .1s}.share-panel-report:hover{background:#f8fafc}.share-panel-report:disabled{opacity:.5;cursor:default}.share-panel-report-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-panel-report-join{font-size:12px;font-weight:500;color:#3b82f6;opacity:0;transition:opacity .15s;flex-shrink:0;padding-left:8px}.share-panel-report:hover .share-panel-report-join{opacity:1}.share-panel-auth{padding:4px 16px 16px}.share-panel-field{margin-bottom:10px}.share-panel-field label{display:block;font-size:12px;font-weight:500;color:#64748b;margin-bottom:4px}.share-panel-field input{width:100%;padding:7px 10px;border-radius:6px;border:1px solid #e2e8f0;font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.share-panel-field input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.share-panel-auth-actions{display:flex;flex-direction:column;gap:8px;margin-top:14px}.share-panel-footer{padding:10px 16px;border-top:1px solid #f1f5f9}.share-panel-btn{width:100%;padding:7px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.share-panel-btn-primary{background:#3b82f6;color:#fff;border:none;width:100%;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.share-panel-btn-primary:hover{background:#2563eb}.share-panel-btn-primary:disabled{opacity:.6;cursor:default}.share-panel-btn-disconnect{background:#fff;color:#64748b;border:1px solid #e2e8f0}.share-panel-btn-disconnect:hover{color:#dc2626;border-color:#fecaca;background:#fef2f2}.share-panel-btn-link{background:none;border:none;color:#3b82f6;font-size:12px;cursor:pointer;padding:0;text-align:center}.share-panel-btn-link:hover{color:#2563eb}.sync-toast{position:fixed;bottom:16px;right:16px;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#1e293b;color:#e2e8f0;font-size:12px;font-weight:500;border-radius:8px;box-shadow:0 4px 16px #0003;z-index:2000;animation:sync-toast-in .3s ease}.sync-toast-dot{width:6px;height:6px;border-radius:50%;background:#3b82f6;flex-shrink:0}@keyframes sync-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
