*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-width: 240px;--color-primary: #0f766e;--color-bg: #f5f5f5;--color-sidebar: #1e293b;--color-sidebar-text: #e2e8f0;--color-sidebar-active: #0f766e}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:#1e293b}.app-layout{display:flex;height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);color:var(--color-sidebar-text);display:flex;flex-direction:column;flex-shrink:0}.sidebar-brand{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand h2{font-size:16px;font-weight:600;letter-spacing:.5px}.sidebar-nav{display:flex;flex-direction:column;padding:8px;gap:2px}.sidebar-link{display:block;padding:10px 12px;border-radius:6px;color:var(--color-sidebar-text);text-decoration:none;font-size:14px;transition:background .15s}.sidebar-link:hover{background:#ffffff14}.sidebar-link.active{background:var(--color-sidebar-active);color:#fff;font-weight:500}.main-content{flex:1;padding:24px;overflow:hidden;display:flex;flex-direction:column}.tier-config{display:flex;flex-direction:column;height:100%;min-height:0}.tier-config-header{margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}.tier-config-header-left h1{font-size:22px;font-weight:700;color:#0f172a}.tier-config-header-left p{font-size:13px;color:#64748b;margin-top:4px}.btn-sql{padding:8px 18px;font-size:13px;font-weight:600;color:var(--color-primary);background:#fff;border:2px solid var(--color-primary);border-radius:8px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s;white-space:nowrap;flex-shrink:0}.btn-sql:hover{background:var(--color-primary);color:#fff}.tier-tabs{display:flex;gap:12px;margin-bottom:20px}.tier-tab{flex:1;position:relative;background:#fff;border:2px solid transparent;border-radius:10px;padding:14px 16px;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s;overflow:hidden;font-family:inherit}.tier-tab:hover{box-shadow:0 2px 8px #00000014}.tier-tab.active{box-shadow:0 2px 12px #0000001a}.tier-tab-name{display:block;font-size:14px;font-weight:600;margin-bottom:2px;transition:color .15s}.tier-tab-desc{display:block;font-size:12px;color:#94a3b8;font-style:italic;margin-bottom:8px}.tier-tab-stats{display:flex;gap:12px;font-size:12px;color:#64748b}.tier-tab-indicator{position:absolute;bottom:0;left:0;right:0;height:3px;opacity:0;transition:opacity .15s}.tier-tab.active .tier-tab-indicator{opacity:1}.tier-config-panels{display:flex;gap:16px;flex:1;min-height:0}.panel-left{width:340px;flex-shrink:0;background:#fff;border-radius:10px;border:1px solid #e2e8f0;overflow-y:auto}.panel-right{flex:1;background:#fff;border-radius:10px;border:1px solid #e2e8f0;overflow-y:auto}.panel-placeholder{display:flex;align-items:center;justify-content:center;height:200px;color:#94a3b8;font-size:14px}.group-tree{display:flex;flex-direction:column;height:100%}.group-tree-header{padding:12px 16px;font-size:12px;color:#64748b;border-bottom:1px solid #e2e8f0}.group-tree-tier-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.group-tree-tier-name{font-size:13px;font-weight:600;color:#334155;min-width:0}.group-tree-add-root{flex-shrink:0;padding:4px 12px;font-size:12px;font-weight:500;color:#fff;background:var(--color-primary);border:none;border-radius:5px;cursor:pointer;font-family:inherit}.group-tree-add-root:hover{opacity:.9}.group-tree-list{flex:1;overflow-y:auto;padding:4px 0}.group-tree-empty{padding:24px 16px;text-align:center;color:#94a3b8;font-size:13px}.group-node{display:flex;align-items:center;padding:7px 12px;cursor:pointer;transition:background .1s;gap:4px}.group-node:hover{background:#f1f5f9}.group-node.selected{background:#e0f2fe}.group-node-arrow{width:14px;font-size:11px;color:#94a3b8;flex-shrink:0;text-align:center}.group-node-icon{font-size:14px;flex-shrink:0;margin-right:4px}.group-node-info{flex:1;min-width:0}.group-node-name{display:block;font-size:13px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-node-counts{display:block;font-size:11px;color:#94a3b8}.group-node-add{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#64748b;background:transparent;border:1px solid #cbd5e1;border-radius:4px;cursor:pointer;flex-shrink:0;opacity:0;transition:opacity .1s,background .1s;font-family:inherit}.group-node:hover .group-node-add{opacity:1}.group-node-add:hover{background:#e2e8f0;color:#334155}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:24px;width:420px;max-width:90vw;box-shadow:0 20px 60px #00000026}.modal-title{font-size:16px;font-weight:600;margin-bottom:20px;color:#0f172a}.modal-field{margin-bottom:16px}.modal-field label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.modal-field .required{color:#dc2626}.modal-field input,.modal-field select,.modal-field textarea{width:100%;padding:8px 12px;font-size:14px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;font-family:inherit}.modal-field textarea{resize:vertical}.modal-field input:disabled{background:#f1f5f9;color:#64748b}.modal-field input:focus,.modal-field select:focus,.modal-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e26}.modal-error{display:block;font-size:12px;color:#dc2626;margin-top:4px}.modal-field input[type=checkbox],.group-detail-field input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:24px}.btn{padding:8px 20px;font-size:14px;font-weight:500;border:none;border-radius:6px;cursor:pointer;font-family:inherit;transition:opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-secondary{background:#e2e8f0;color:#475569}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.group-detail{padding:20px}.group-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.group-detail-name{font-size:18px;font-weight:700;color:#0f172a}.group-detail-actions{display:flex;gap:8px;flex-shrink:0}.group-detail-description{font-size:14px;font-style:italic;color:#64748b;margin-bottom:8px}.group-detail-relation{font-size:14px;color:#475569;margin-bottom:12px}.group-detail-stats{display:flex;gap:16px;font-size:13px;color:#64748b;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.group-detail-field{margin-bottom:16px}.group-detail-field label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.group-detail-field .required{color:#dc2626}.group-detail-field input,.group-detail-field select,.group-detail-field textarea{width:100%;padding:8px 12px;font-size:14px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;font-family:inherit}.group-detail-field textarea{resize:vertical}.group-detail-field input:focus,.group-detail-field select:focus,.group-detail-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e26}.group-detail-error{display:block;font-size:12px;color:#dc2626;margin-top:4px}.group-detail-relation-edit{display:flex;align-items:center;gap:8px}.group-detail-relation-edit select{width:auto}.group-detail-relation-target{font-size:14px;color:#64748b}.group-detail-confirm{margin-top:16px;padding:14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.group-detail-confirm p{font-size:13px;color:#991b1b;margin-bottom:12px;line-height:1.5}.group-detail-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.attr-table-wrap{margin-top:16px}.attr-table-header{padding:12px 0 8px;font-size:14px;font-weight:600;color:#334155;border-top:1px solid #e2e8f0}.attr-table-scroll{overflow-x:auto}.attr-table{width:100%;border-collapse:collapse;font-size:13px;min-width:900px}.attr-table th{text-align:left;padding:8px 6px;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #e2e8f0;white-space:nowrap;background:#f8fafc}.attr-table td{padding:4px 6px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.attr-table .col-name{min-width:140px}.attr-table .col-type{min-width:130px}.attr-table .col-ref{min-width:140px}.attr-table .col-check{width:60px;text-align:center}.attr-table .col-scope{min-width:90px}.attr-table .col-enum{min-width:120px}.attr-table .col-desc{min-width:100px}.attr-table .col-default{min-width:90px}.attr-table .col-action{width:70px;text-align:center}.cell-center{text-align:center}.attr-row:hover{background:#fafbfc}.attr-row td input[type=text],.attr-row td select{width:100%;padding:4px 6px;font-size:13px;border:1px solid #cbd5e1;border-radius:4px;background:#fff;color:#1e293b;font-family:inherit}.attr-row td input[type=text]:focus,.attr-row td select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px #0f766e33}.attr-row td input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.attr-cell-text{display:block;padding:4px 6px;cursor:pointer;border-radius:4px;min-height:28px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attr-cell-text:hover{background:#e0f2fe}.attr-cell-na{color:#cbd5e1;padding:4px 6px}.attr-row-new{background:#f8fafc}.attr-row-new td input[type=text],.attr-row-new td select{background:#fff}.attr-row-new td input.input-error,.attr-row-new td select.input-error{border-color:#dc2626;background:#fef2f2}.attr-confirm-delete{display:flex;gap:4px}.btn-icon{padding:2px 8px;font-size:12px;border:1px solid #cbd5e1;border-radius:4px;background:#fff;cursor:pointer;font-family:inherit;color:#475569}.btn-icon:hover{background:#f1f5f9}.btn-icon-danger{color:#dc2626;border-color:#fecaca}.btn-icon-danger:hover{background:#fef2f2}.workflow-page{display:flex;flex-direction:column;height:100%;gap:16px}.workflow-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.workflow-header-left h1{margin:0 0 4px;font-size:24px;color:#1e293b}.workflow-header-left p{margin:0;color:#64748b;font-size:14px}.workflow-context-selector{display:flex;align-items:center;gap:12px}.workflow-context-label{font-weight:500;color:#475569;white-space:nowrap}.workflow-context-select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:14px;min-width:250px;cursor:pointer}.workflow-context-select:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 2px #0f766e1a}.workflow-stats{display:flex;gap:24px;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.workflow-stats-item{display:flex;align-items:center;gap:8px}.workflow-stats-dot{width:10px;height:10px;border-radius:50%}.workflow-stats-label{color:#64748b;font-size:13px}.workflow-stats-count{font-weight:600;color:#1e293b}.workflow-stats-total{margin-left:auto;padding-left:24px;border-left:1px solid #e2e8f0}.workflow-stats-total .workflow-stats-count{font-size:16px}.workflow-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px}.workflow-toolbar-left{display:flex;gap:12px}.workflow-search{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;width:250px}.workflow-search:focus{outline:none;border-color:#0f766e}.workflow-filter{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:14px;cursor:pointer}.workflow-context-info{color:#64748b;font-size:13px}.workflow-main{display:flex;gap:16px;flex:1;min-height:0}.workflow-panel-left{width:400px;flex-shrink:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.workflow-panel-right{flex:1;background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:auto;display:flex;flex-direction:column}.workflow-loading,.workflow-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#94a3b8}.workflow-placeholder-icon{font-size:48px;margin-bottom:16px}.workflow-tree{display:flex;flex-direction:column;height:100%}.workflow-tree-actions{display:flex;gap:10px;padding:10px 12px;border-bottom:1px solid #e2e8f0;background:#f8fafc;align-items:center}.workflow-tree-btn{padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;font-size:12px;cursor:pointer;color:#64748b}.workflow-tree-btn:hover{background:#f1f5f9}.workflow-tree-list{flex:1;overflow:auto;padding:8px 0}.workflow-tree-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;color:#94a3b8}.workflow-tree-node-wrapper{-webkit-user-select:none;user-select:none}.workflow-tree-node{display:flex;align-items:center;gap:6px;padding:6px 12px;cursor:pointer;border-left:3px solid transparent;transition:background .15s;position:relative}.workflow-tree-node:hover{background:#f8fafc}.workflow-tree-node.selected{background:#e0f2fe;border-left-color:#0f766e}.workflow-tree-toggle{width:16px;font-size:10px;color:#94a3b8;text-align:center;flex-shrink:0}.workflow-tree-icon{font-size:14px;flex-shrink:0}.workflow-tree-name{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;padding-left:8px;border-left:2px solid}.workflow-tree-name-row{display:flex;gap:8px;align-items:center}.workflow-tree-code{font-family:monospace;font-size:13px;color:#64748b;flex-shrink:0}.workflow-tree-label{font-size:15px;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.workflow-tree-order{font-size:10px;font-weight:700;color:#fff;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:9px;flex-shrink:0}.workflow-tree-node-card{margin:2px 4px;border-radius:6px;border:1px solid #e2e8f0;background:#f8fafc;min-height:50px}.workflow-tree-node-card.selected{border-color:#3b82f6;background:#eff6ff}.workflow-tree-deps-row{display:flex;flex-wrap:wrap;align-items:center;gap:4px;min-height:16px}.workflow-tree-deps-prefix{font-size:12px;color:#94a3b8;flex-shrink:0}.workflow-tree-dep-badge{font-size:12px;padding:1px 6px;border-radius:8px;white-space:nowrap;font-weight:500}.workflow-tree-dep-badge.dep-strict{background:#fde2e2;color:#b91c1c;border:1px solid #fca5a5}.workflow-tree-dep-badge.dep-soft{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.workflow-tree-badges{display:flex;gap:6px;flex-shrink:0;align-items:center}.workflow-badge{font-size:10px;padding:2px 4px;border-radius:3px}.workflow-badge-strict{background:#fef2f2}.workflow-badge-soft{background:#fffbeb}.workflow-badge-count{background:#f1f5f9;color:#64748b;font-weight:500}.workflow-detail{padding:20px;flex:1;overflow:auto}.workflow-detail-loading,.workflow-detail-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#94a3b8}.workflow-detail-breadcrumb{margin-bottom:16px;font-size:12px;color:#64748b}.workflow-breadcrumb-item{color:#64748b}.workflow-breadcrumb-sep{margin:0 6px;color:#cbd5e1}.workflow-detail-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.workflow-detail-icon{font-size:32px}.workflow-detail-title h2{margin:0 0 4px;font-size:20px;color:#1e293b}.workflow-detail-code{font-family:monospace;font-size:12px;color:#64748b;background:#f1f5f9;padding:2px 6px;border-radius:3px;margin-right:8px}.workflow-detail-type{font-size:12px;color:#64748b}.workflow-detail-section{margin-bottom:20px}.workflow-detail-section h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px}.workflow-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.workflow-detail-field{display:flex;flex-direction:column;gap:4px}.workflow-detail-field-full{grid-column:span 2}.workflow-detail-field label{font-size:12px;color:#64748b;font-weight:500}.workflow-detail-field span{font-size:14px;color:#1e293b}.workflow-dep-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.workflow-dep-none{background:#f1f5f9;color:#64748b}.workflow-dep-soft{background:#fffbeb;color:#b45309}.workflow-dep-strict{background:#fef2f2;color:#dc2626}.workflow-detail-deps{margin-top:12px}.workflow-detail-deps label{display:block;font-size:12px;color:#64748b;margin-bottom:8px}.workflow-dep-list{list-style:none;margin:0;padding:0}.workflow-dep-list li{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border-radius:6px;margin-bottom:6px}.workflow-dep-code{font-family:monospace;font-size:11px;color:#64748b;background:#e2e8f0;padding:2px 6px;border-radius:3px}.workflow-dep-name{flex:1;font-size:13px;color:#334155}.workflow-dep-type{font-size:11px;padding:2px 6px;border-radius:3px;font-weight:500}.workflow-detail-meta{display:flex;gap:24px;padding-top:16px;border-top:1px solid #e2e8f0;color:#94a3b8}.workflow-detail-meta .workflow-detail-field{flex-direction:row;gap:8px;align-items:center}.workflow-detail-meta label,.workflow-detail-meta span{font-size:12px;color:#94a3b8}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:#1e293b}.modal-close{width:32px;height:32px;border:none;background:transparent;border-radius:6px;font-size:22px;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close:hover{background:#f1f5f9;color:#475569}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid #e2e8f0}.modal-large{max-width:700px;width:90%}.workflow-modal-parent{display:flex;align-items:center;gap:8px;padding:12px;background:#f8fafc;border-radius:6px;margin-bottom:16px}.workflow-modal-parent-label{color:#64748b;font-size:13px}.workflow-modal-parent-name{font-weight:500;color:#1e293b}.workflow-modal-error{padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:14px;margin-bottom:16px}.workflow-modal-field{margin-bottom:16px}.workflow-modal-field label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.workflow-modal-field input[type=text],.workflow-modal-field textarea,.workflow-modal-field select{width:100%;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;box-sizing:border-box}.workflow-modal-field textarea{resize:vertical}.workflow-modal-field input:focus,.workflow-modal-field textarea:focus,.workflow-modal-field select:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 2px #0f766e1a}.workflow-modal-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.workflow-modal-section{margin-top:20px;padding-top:20px;border-top:1px solid #e2e8f0}.workflow-modal-section h4{margin:0 0 16px;font-size:14px;font-weight:600;color:#475569}.workflow-modal-checkbox label{display:flex;align-items:center;gap:8px;cursor:pointer}.workflow-modal-checkbox input[type=checkbox]{width:16px;height:16px}.workflow-type-selector{display:flex;gap:8px;flex-wrap:wrap}.workflow-type-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;transition:all .15s}.workflow-type-btn:hover{border-color:#cbd5e1;background:#f8fafc}.workflow-type-btn.active{border-color:#0f766e;background:#f0fdfa}.workflow-type-icon{font-size:18px}.workflow-type-label{font-size:13px;font-weight:500;color:#334155}.workflow-dep-editor{margin-top:16px;padding:16px;background:#f8fafc;border-radius:8px}.workflow-dep-editor h4{margin:0 0 16px;font-size:14px;font-weight:600;color:#475569}.workflow-dep-editor-loading{padding:24px;text-align:center;color:#94a3b8}.workflow-dep-join{margin-bottom:16px}.workflow-dep-join>label{display:block;font-size:12px;color:#64748b;margin-bottom:8px}.workflow-dep-join-options{display:flex;flex-direction:column;gap:8px}.workflow-dep-join-option{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer}.workflow-dep-join-option:hover{background:#f1f5f9}.workflow-dep-join-option input{margin:0}.workflow-dep-join-label{font-weight:500;color:#334155}.workflow-dep-join-desc{font-size:12px;color:#64748b}.workflow-dep-editor .workflow-dep-list{margin-bottom:16px}.workflow-dep-editor .workflow-dep-list>label{display:block;font-size:12px;color:#64748b;margin-bottom:8px}.workflow-dep-empty{color:#94a3b8;font-size:13px;font-style:italic}.workflow-dep-editor .workflow-dep-list ul{list-style:none;margin:0;padding:0}.workflow-dep-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:6px}.workflow-dep-item-code{font-family:monospace;font-size:11px;color:#64748b;background:#f1f5f9;padding:2px 6px;border-radius:3px}.workflow-dep-item-name{flex:1;font-size:13px;color:#334155}.workflow-dep-item-type{font-size:10px;padding:2px 6px;border-radius:3px;font-weight:500}.workflow-dep-item-delete{width:20px;height:20px;border:none;background:#fee2e2;color:#dc2626;border-radius:4px;cursor:pointer;font-size:14px;line-height:1}.workflow-dep-item-delete:hover{background:#fecaca}.workflow-dep-add{padding-top:16px;border-top:1px solid #e2e8f0}.workflow-dep-add>label{display:block;font-size:12px;color:#64748b;margin-bottom:8px}.workflow-dep-add-form{display:flex;gap:8px}.workflow-dep-add-form select{flex:1;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px}.workflow-dep-add-form select:first-child{flex:2}.workflow-dep-add-empty{margin-top:8px;font-size:12px;color:#94a3b8;font-style:italic}.workflow-detail-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.workflow-detail-section-header h3{margin:0}.workflow-tp-tree{border:1px solid #e2e8f0;border-radius:8px;padding:8px;background:#f8fafc;max-height:400px;overflow-y:auto}.workflow-tp-empty{text-align:center;color:#94a3b8;padding:24px;font-size:13px}.workflow-tp-node{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;font-size:13px;cursor:default;transition:background .15s}.workflow-tp-node:hover{background:#e2e8f0}.workflow-tp-icon{font-size:14px}.workflow-tp-type{font-size:11px;font-weight:600;text-transform:uppercase;min-width:80px}.workflow-tp-name{flex:1;font-weight:500;color:#1e293b}.workflow-tp-inactive{font-size:12px}.workflow-tp-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.workflow-tp-node:hover .workflow-tp-actions{opacity:1}.workflow-tp-btn{padding:2px 8px;border:1px solid #cbd5e1;background:#fff;border-radius:4px;cursor:pointer;font-size:12px;color:#475569}.workflow-tp-btn:hover{background:#f1f5f9}.workflow-tp-btn-delete{color:#ef4444;border-color:#fca5a5}.workflow-tp-btn-delete:hover{background:#fef2f2}.workflow-tp-children{margin-left:12px;border-left:1px dashed #cbd5e1}.workflow-tp-add-form{margin-bottom:12px;padding:12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;display:flex;flex-direction:column;gap:10px}.workflow-tp-add-row{display:flex;gap:10px;align-items:center}.workflow-tp-add-row select,.workflow-tp-add-row input{padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px}.workflow-tp-add-row select{flex:1;min-width:140px}.workflow-tp-add-row input{flex:1}.workflow-tp-type-select{flex:0!important;min-width:180px!important}.workflow-tp-loading-ref{color:#94a3b8;font-size:13px;font-style:italic}.workflow-detail-edit-title{width:100%;padding:4px 8px;font-size:20px;font-weight:600;border:1px solid #e2e8f0;border-radius:6px}.workflow-detail-actions{display:flex;gap:10px;margin-left:auto;flex-shrink:0}.workflow-detail-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer}.workflow-detail-checkbox input{width:16px;height:16px}.workflow-detail-confirm-delete{padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px}.workflow-detail-confirm-delete p{margin:0 0 12px;color:#dc2626;font-weight:500}.workflow-detail-confirm-actions{display:flex;gap:10px}.workflow-detail-field textarea,.workflow-detail-field input,.workflow-detail-field select{width:100%;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px}.workflow-tree-btn-add{margin-left:auto;background:#f0fdfa;border-color:#0f766e;color:#0f766e}.workflow-tree-btn-add:hover{background:#ccfbf1}.workflow-tree-add-btn{width:20px;height:20px;border:1px solid #e2e8f0;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;color:#64748b;display:flex;align-items:center;justify-content:center}.workflow-tree-add-btn:hover{background:#f0fdfa;border-color:#0f766e;color:#0f766e}.workflow-tree-edit-btn{width:20px;height:20px;border:1px solid #e2e8f0;background:#fff;border-radius:4px;cursor:pointer;font-size:13px;color:#64748b;display:flex;align-items:center;justify-content:center}.workflow-tree-edit-btn:hover{background:#fef3c7;border-color:#d97706;color:#d97706}.workflow-tree-diagram-btn{width:20px;height:20px;border:1px solid #e2e8f0;background:#fff;border-radius:4px;cursor:pointer;font-size:12px;color:#64748b;display:flex;align-items:center;justify-content:center}.workflow-tree-diagram-btn:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.workflow-tree-add-sub-wf{font-size:10px}.workflow-tree-add-sub-wf:hover{background:#f0fdfa;border-color:#0f766e}.workflow-tree-toggle-loading{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.workflow-detail-hint{color:#94a3b8;font-size:13px;font-style:italic}.workflow-tp-deps{display:flex;flex-direction:column;gap:6px}.workflow-tp-dep-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f8fafc;border-radius:4px;font-size:13px}.workflow-tp-dep-type{padding:2px 6px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase;background:#e2e8f0;color:#475569;flex-shrink:0}.workflow-tp-dep-strict{background:#fecaca;color:#991b1b}.workflow-tp-dep-soft{background:#fef3c7;color:#92400e}.workflow-tp-dep-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workflow-tp-dep-delete{width:20px;height:20px;border:1px solid #e2e8f0;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;color:#94a3b8;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity .15s}.workflow-tp-dep-item:hover .workflow-tp-dep-delete{opacity:1}.workflow-tp-dep-delete:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}.workflow-tp-dep-section{margin-top:8px;padding:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px}.workflow-tp-dep-label{display:block;font-size:12px;font-weight:600;color:#475569;margin-bottom:6px}.workflow-tp-dep-type-select{max-width:180px}.workflow-tp-dep-desc{font-size:12px;color:#94a3b8;font-style:italic;margin-top:4px}.workflow-tp-add-dep-form{margin-top:10px;padding:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:10px}.workflow-op-fields-tree{display:flex;flex-direction:column;gap:2px}.workflow-op-group-node{border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.workflow-op-group-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f1f5f9;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.workflow-op-group-header:hover{background:#e2e8f0}.workflow-op-group-toggle{font-size:10px;color:#64748b;width:14px;text-align:center}.workflow-op-group-icon{font-size:16px}.workflow-op-group-name{font-weight:600;font-size:13px;color:#1e293b}.workflow-op-group-meta{margin-left:auto;font-size:11px;color:#94a3b8}.workflow-op-group-children{display:flex;flex-direction:column}.workflow-op-field-node{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 38px;border-top:1px solid #f1f5f9;font-size:13px;transition:background .15s}.workflow-op-field-node:hover{background:#fafafa}.workflow-op-field-icon{font-size:14px}.workflow-op-field-name{color:#334155}.workflow-op-field-type{margin-left:auto;font-size:11px;color:#94a3b8;background:#f1f5f9;padding:1px 8px;border-radius:4px}.btn-sm{padding:4px 12px;font-size:13px}.btn-danger{background:#dc2626;color:#fff;border:1px solid #dc2626;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px}.btn-danger:hover{background:#b91c1c}.btn-danger.btn-sm{padding:4px 12px;font-size:13px}.workflow-view-tabs{display:flex;gap:4px;padding:4px;background:#f1f5f9;border-radius:8px;width:fit-content}.workflow-view-tab{padding:8px 16px;border:none;background:transparent;border-radius:6px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .15s}.workflow-view-tab:hover{color:#334155}.workflow-view-tab.active{background:#fff;color:#0f766e;box-shadow:0 1px 3px #0000001a}.workflow-diagram-panel{flex:1;background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.flow-diagram-container{flex:1;display:flex;flex-direction:column;position:relative}.flow-diagram-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8}.flow-diagram-empty-icon{font-size:48px;margin-bottom:16px}.flow-diagram-canvas{flex:1;overflow:hidden;position:relative;background:radial-gradient(circle at 50% 50%,rgba(15,118,110,.03) 0%,transparent 50%),linear-gradient(rgba(0,0,0,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:100% 100%,20px 20px,20px 20px}.flow-diagram-content{position:relative;transform-origin:0 0;transition:transform .1s ease-out}.flow-diagram-svg{position:absolute;top:0;left:0;pointer-events:none}.flow-connection{stroke-width:2;fill:none}.flow-connection-strict{stroke:#0ea5e9}.flow-connection-soft{stroke:#f59e0b;stroke-dasharray:6 3}.flow-connection-label{font-size:9px;font-weight:600}.flow-connection-label-strict{fill:#0ea5e9}.flow-connection-label-soft{fill:#f59e0b}.flow-node{position:absolute;background:#fff;border:2px solid;border-radius:12px;padding:10px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #00000014}.flow-node:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000001f}.flow-node-selected{box-shadow:0 0 0 3px #0f766e4d}.flow-node-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.flow-node-order{width:20px;height:20px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}.flow-node-type{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.flow-node-dep{margin-left:auto;font-size:12px}.flow-node-dep-strict{color:#0ea5e9}.flow-node-dep-soft{color:#f59e0b}.flow-node-content{display:flex;align-items:center;gap:8px}.flow-node-icon{font-size:16px}.flow-node-text{flex:1;min-width:0}.flow-node-name{display:block;font-size:12px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flow-node-code{display:block;font-size:10px;color:#94a3b8;font-family:monospace}.flow-node-children-badge{position:absolute;bottom:-8px;right:10px;padding:2px 6px;background:#f1f5f9;border-radius:4px;font-size:9px;color:#64748b}.flow-node-drillable{background:#e0f2fe;color:#0369a1;cursor:pointer}.flow-controls{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:4px;padding:4px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #00000014;z-index:10}.flow-control-btn{width:28px;height:28px;border:none;background:transparent;border-radius:4px;font-size:16px;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.flow-control-btn:hover:not(:disabled){background:#f1f5f9;color:#1e293b}.flow-control-btn:disabled{opacity:.4;cursor:not-allowed}.flow-control-zoom{padding:0 8px;font-size:12px;font-weight:500;color:#334155;min-width:45px;text-align:center}.flow-control-divider{width:1px;height:20px;background:#e2e8f0;margin:0 4px}.workflow-diagram-breadcrumb{font-size:13px;color:#334155;font-weight:500;padding:4px 10px;background:#f1f5f9;border-radius:4px;border:1px solid #e2e8f0}.flow-diagram-footer{padding:8px 16px;background:#f8fafc;border-top:1px solid #e2e8f0;font-size:12px;color:#64748b}.pfd-container{display:flex;flex-direction:column;flex:1;min-height:0;background:#fff;overflow:hidden;position:relative}.pfd-loading,.pfd-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;font-size:14px}.pfd-empty-icon{font-size:48px;margin-bottom:12px}.pfd-controls{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:4px;padding:4px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #00000014;z-index:10}.pfd-ctrl-btn{width:28px;height:28px;border:none;background:transparent;border-radius:4px;font-size:16px;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center}.pfd-ctrl-btn:hover{background:#f1f5f9;color:#1e293b}.pfd-ctrl-zoom{padding:0 6px;font-size:12px;font-weight:500;color:#334155;min-width:42px;text-align:center}.pfd-ctrl-divider{width:1px;height:18px;background:#e2e8f0;margin:0 2px}.pfd-legend{display:flex;align-items:center;gap:14px;padding:8px 16px;border-bottom:1px solid #e2e8f0;background:#f8fafc;font-size:11px;color:#64748b;flex-wrap:wrap}.pfd-legend-item{display:flex;align-items:center;gap:5px}.pfd-legend-line{display:inline-block;width:24px;height:2px}.pfd-legend-strict{background:#0ea5e9}.pfd-legend-soft{background:#f59e0b;background-image:repeating-linear-gradient(90deg,#f59e0b 0,#f59e0b 6px,transparent 6px,transparent 9px);background-color:transparent}.pfd-legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.pfd-legend-sep{width:1px;height:14px;background:#cbd5e1}.pfd-breadcrumb{display:flex;align-items:center;gap:2px;padding:8px 16px;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0;flex-wrap:wrap;min-height:36px}.pfd-breadcrumb-item{display:flex;align-items:center;gap:2px}.pfd-breadcrumb-sep{color:#94a3b8;font-size:14px;margin:0 4px}.pfd-breadcrumb-btn{border:none;background:none;padding:3px 8px;border-radius:4px;font-size:12px;color:#64748b;cursor:pointer;transition:all .15s}.pfd-breadcrumb-btn:hover{background:#f1f5f9;color:#334155}.pfd-breadcrumb-btn.active{color:#0f766e;font-weight:600;background:#f0fdfa}.pfd-breadcrumb-level{margin-left:auto;font-size:11px;color:#94a3b8;font-weight:500}.pfd-canvas{flex:1;overflow:hidden;position:relative;background:radial-gradient(circle at 50% 50%,rgba(15,118,110,.02) 0%,transparent 60%),linear-gradient(rgba(0,0,0,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.018) 1px,transparent 1px);background-size:100% 100%,24px 24px,24px 24px}.pfd-content{position:relative;transform-origin:0 0}.pfd-svg{position:absolute;top:0;left:0;pointer-events:none}.pfd-arrow{stroke-width:2;fill:none}.pfd-arrow-strict{stroke:#0ea5e9}.pfd-arrow-soft{stroke:#f59e0b;stroke-dasharray:8 4}.pfd-arrow-label{font-size:9px;font-weight:600}.pfd-arrow-label-strict{fill:#0ea5e9}.pfd-arrow-label-soft{fill:#f59e0b}.pfd-node{position:absolute;background:#fff;border:2px solid;border-radius:10px;padding:8px 10px;cursor:pointer;transition:all .15s;box-shadow:0 2px 6px #0000000f;display:flex;flex-direction:column;gap:4px}.pfd-node:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.pfd-node-selected{background:#f0fdfa;border-width:3px;border-color:#0f766e!important;box-shadow:0 0 0 3px #0f766e40,0 4px 12px #0000001a}.pfd-node-selected:hover{box-shadow:0 0 0 3px #0f766e40,0 6px 16px #0000001f}.pfd-node-active{background:#fffbeb;border-width:3px;border-color:#f59e0b!important;box-shadow:0 0 0 4px #f59e0b4d,0 4px 12px #0000001a}.pfd-node-active:hover{box-shadow:0 0 0 4px #f59e0b4d,0 6px 16px #0000001f}.pfd-node-header{display:flex;align-items:center;gap:6px}.pfd-node-order{width:18px;height:18px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.pfd-node-type{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.pfd-node-body{display:flex;align-items:center;gap:6px;min-width:0}.pfd-node-icon{font-size:14px;flex-shrink:0}.pfd-node-name{font-size:12px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pfd-node-children{position:absolute;bottom:-7px;right:8px;font-size:9px;padding:1px 5px;background:#e0f2fe;color:#0369a1;border-radius:3px}.pfd-node-drillable{cursor:pointer}.pfd-node-drillable:hover{box-shadow:0 2px 8px #0f766e33}.pfd-node-drill-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;border:none;background:#0f766e1a;color:#0f766e;border-radius:4px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.pfd-node:hover .pfd-node-drill-btn{opacity:1}.pfd-node-drill-btn:hover{background:#0f766e33}.pfd-footer{padding:6px 16px;background:#f8fafc;border-top:1px solid #e2e8f0;font-size:11px;color:#94a3b8}.confirm-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1100;animation:confirmFadeIn .15s ease-out}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}@keyframes confirmSlideIn{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;width:400px;max-width:90vw;overflow:hidden;animation:confirmSlideIn .2s ease-out}.confirm-modal-body{display:flex;gap:16px;padding:24px 24px 16px;align-items:flex-start}.confirm-modal-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.confirm-modal-text{flex:1;min-width:0}.confirm-modal-text h3{margin:0 0 6px;font-size:16px;font-weight:600;color:#1e293b}.confirm-modal-text p{margin:0;font-size:14px;color:#64748b;line-height:1.5}.confirm-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 24px 20px}.confirm-modal-btn{padding:8px 20px;font-size:14px;font-weight:500;border:none;border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s,opacity .15s}.confirm-modal-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-modal-btn-cancel{background:#f1f5f9;color:#475569}.confirm-modal-btn-cancel:hover:not(:disabled){background:#e2e8f0}.confirm-modal-btn-danger{background:#dc2626;color:#fff}.confirm-modal-btn-danger:hover:not(:disabled){background:#b91c1c}.confirm-modal-btn-warning{background:#d97706;color:#fff}.confirm-modal-btn-warning:hover:not(:disabled){background:#b45309}.workflow-detail-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.workflow-detail-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:640px;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.workflow-detail-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.workflow-detail-modal-header h3{margin:0;font-size:16px;font-weight:600;color:#1e293b}.workflow-detail-modal-close{width:32px;height:32px;border:none;background:transparent;border-radius:6px;font-size:22px;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center}.workflow-detail-modal-close:hover{background:#f1f5f9;color:#475569}.workflow-detail-modal-body{padding:0;overflow-y:auto;flex:1}.sql-modal{background:#fff;border-radius:14px;width:80vw;max-width:1000px;height:80vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0003;overflow:hidden}.sql-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #e2e8f0}.sql-modal-title{font-size:17px;font-weight:700;color:#0f172a}.sql-modal-stats{display:block;font-size:12px;color:#64748b;margin-top:2px}.sql-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#94a3b8;background:transparent;border:none;border-radius:6px;cursor:pointer;flex-shrink:0}.sql-modal-close:hover{background:#f1f5f9;color:#475569}.sql-tabs{display:flex;gap:6px;padding:12px 24px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.sql-tab{padding:5px 14px;font-size:12px;font-weight:600;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .15s}.sql-tab:hover{border-color:#cbd5e1;color:#334155}.sql-tab.active{background:var(--tab-color, var(--color-primary));color:#fff;border-color:var(--tab-color, var(--color-primary))}.sql-content{flex:1;overflow:auto;padding:20px 24px;background:#1e293b}.sql-content pre{margin:0;white-space:pre}.sql-content code{font-family:Cascadia Code,Fira Code,Consolas,Monaco,monospace;font-size:13px;line-height:1;color:#e2e8f0}.sql-keyword{color:#60a5fa;font-weight:600}.sql-constraint{color:#f472b6;font-weight:500}.sql-type{color:#a78bfa}.sql-comment{color:#64748b;font-style:italic}.sql-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid #e2e8f0}.operations-page{padding:24px;display:flex;flex-direction:column;gap:20px;height:100%;overflow-y:auto}.page-header h1{font-size:22px;font-weight:700;color:#0f172a;margin-bottom:4px}.page-description{font-size:14px;color:#64748b}.ops-tab-bar{display:flex;gap:0;border-bottom:2px solid #E2E8F0;margin-bottom:0}.ops-tab{padding:10px 24px;font-size:14px;font-weight:600;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s}.ops-tab:hover{color:#0f766e}.ops-tab.active{color:#0f766e;border-bottom-color:#0f766e}.search-filter-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;padding:16px;border-radius:8px;border:1px solid #e2e8f0}.search-filter-bar-left{display:flex;align-items:center;gap:10px;flex:1}.search-input{flex:1;max-width:320px;padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;outline:none}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e1f}.filter-select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;background:#fff;color:#1e293b;cursor:pointer;outline:none}.filter-select:focus{border-color:var(--color-primary)}.operations-table-wrapper{background:#fff;border-radius:8px;border:1px solid #e2e8f0;overflow:hidden}.operations-table{width:100%;border-collapse:collapse;font-size:14px}.operations-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.operations-table th{padding:12px 14px;text-align:left;font-weight:600;color:#475569;font-size:13px;white-space:nowrap}.operations-table td{padding:12px 14px;border-bottom:1px solid #f1f5f9;color:#1e293b}.operations-table tbody tr:hover{background:#f8fafc}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-header:hover{color:var(--color-primary)}.sort-arrow{font-size:11px;color:var(--color-primary)}.empty-row{text-align:center;color:#94a3b8;padding:40px 14px!important}.op-code{font-family:Consolas,Courier New,monospace;font-size:13px;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:4px}.op-name{font-weight:500}.op-desc{color:#64748b;font-size:13px;max-width:240px}.center{text-align:center}.core-badges{display:flex;gap:4px;flex-wrap:wrap}.core-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap}.status-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.status-draft{background:#fef3c7;color:#92400e}.status-approved{background:#dcfce7;color:#166534}.action-buttons{display:flex;gap:6px}.btn-sm{padding:4px 10px;font-size:12px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid #e2e8f0}.pagination-info{font-size:13px;color:#64748b}.pagination-controls{display:flex;align-items:center;gap:8px}.page-size-select{padding:4px 8px;border:1px solid #cbd5e1;border-radius:4px;font-size:13px;background:#fff}.page-indicator{font-size:13px;color:#475569;min-width:100px;text-align:center}.attr-tree{border-radius:8px}.core-tabs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:10px}.core-tab-card{border:2px solid #e2e8f0;border-radius:9px;padding:10px 8px;cursor:pointer;text-align:left;transition:all .15s;font-family:inherit;font-size:inherit}.core-tab-icon{font-size:22px;margin-bottom:4px}.core-tab-name{font-size:12px;font-weight:700;margin-bottom:1px}.core-tab-tiers{font-size:10px;opacity:.65}.core-tab-count{margin-top:5px;font-size:11px;font-weight:700;padding:2px 7px;border-radius:4px;display:inline-block}.core-tree-panel{background:#fff;border-radius:9px;border:2px solid #e2e8f022;overflow:hidden}.core-tree-header{padding:8px 12px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.core-tree-header-left{display:flex;align-items:center;gap:6px}.core-tree-deselect{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:4px;padding:3px 8px;font-size:10.5px;cursor:pointer;font-weight:600;font-family:inherit}.core-tree-deselect:hover{background:#fee2e2}.core-tree-body{max-height:460px;overflow-y:auto;padding:6px 2px 10px}.chk-row{display:flex;align-items:flex-start;gap:7px;padding:4px 6px;cursor:pointer;border-radius:4px;transition:background .1s}.chk-row:hover{background:#00000008}.chk-label{flex:1;line-height:1.4;-webkit-user-select:none;user-select:none}.chk-label-tier{font-size:13.5px;font-weight:700;color:#1e293b}.chk-label-group{font-size:12.5px;font-weight:600;color:#1e293b}.chk-label-attr{font-size:12px;font-weight:400;color:#1e293b}.chk-sub{font-size:11px;color:#94a3b8;white-space:nowrap;flex-shrink:0}.chk-tag{font-size:9.5px;margin-left:5px;padding:1px 5px;border-radius:3px;font-weight:600;white-space:nowrap;flex-shrink:0}.input-disabled{background:#f1f5f9!important;color:#94a3b8!important;cursor:not-allowed}.operation-form{display:flex;flex-direction:column;gap:20px}.form-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:20px}.form-section h3{font-size:17px;font-weight:600;color:#0f172a;margin-bottom:16px}.form-section h4{font-size:15px;font-weight:600;color:#0f172a}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#334155;margin-bottom:6px}.required{color:#dc2626}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e1f}.input-error{border-color:#dc2626!important}.error-text{display:block;font-size:13px;color:#dc2626;margin-top:4px}.op-form-sticky-bar{background:#fff;border-radius:9px;padding:10px 14px;border:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;position:sticky;bottom:10px;box-shadow:0 -3px 14px #0000000f;z-index:10}.op-form-sticky-left{display:flex;align-items:center;gap:10px}.op-form-sticky-right{display:flex;gap:5px}.btn-preview-toggle{background:#f1f5f9;color:#64748b;border:1px solid #cbd5e1;border-radius:6px;padding:7px 14px;font-size:12px;cursor:pointer;font-weight:600;font-family:inherit}.btn-preview-toggle.active{background:#0f172a;color:#f8fafc;border-color:#0f172a}.btn-preview-toggle:hover{opacity:.9}.preview-modal{width:620px;max-height:80vh;display:flex;flex-direction:column}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.preview-header h3{font-size:17px;font-weight:600;color:#0f172a}.btn-close{background:none;border:none;font-size:18px;cursor:pointer;color:#94a3b8;padding:4px}.btn-close:hover{color:#475569}.preview-info{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.preview-info h4{font-size:16px;font-weight:600;color:#0f172a;margin-bottom:4px}.preview-desc{font-size:14px;color:#64748b;margin-bottom:4px}.preview-count{font-size:13px;color:#94a3b8}.preview-tree{overflow-y:auto;flex:1}.preview-node{padding:4px 8px;font-size:14px;color:#334155}.preview-node-core{font-weight:700;font-size:15px;color:#0f172a;padding-top:8px}.preview-node-tier{font-weight:600;color:#1e293b}.preview-attr{color:#64748b}.preview-icon{margin-right:6px}.preview-dtype{margin-left:8px;font-size:11px;color:#94a3b8;background:#f1f5f9;padding:1px 6px;border-radius:4px}.preview-empty{text-align:center;color:#94a3b8;padding:24px}.delete-warning{background:#fef2f2;color:#991b1b;padding:10px 14px;border-radius:6px;font-size:13px;margin-bottom:16px}.btn-approve{background:#16a34a;color:#fff}.btn-approve:hover:not(:disabled){background:#15803d}.review-info-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}.review-info-card h3{font-size:16px;font-weight:600;color:#0f172a;margin-bottom:16px}.review-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.review-info-full{grid-column:1 / -1}.review-info-row label{display:block;font-size:13px;color:#64748b;margin-bottom:4px}.review-value{font-size:15px;color:#1e293b;font-weight:500}.review-core-summary{display:flex;align-items:center;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.review-core-total{font-size:14px;color:#475569;font-weight:500}.review-tree-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}.review-tree-section h3{font-size:16px;font-weight:600;color:#0f172a;margin:0 0 16px}.review-actions{display:flex;gap:12px;justify-content:flex-end}.fb-page{--fb-primary: #0d9488;--fb-primary-dark: #0f766e;--fb-primary-light: #14b8a6;--fb-primary-glow: rgba(13, 148, 136, .25);--fb-accent: #2dd4bf;--fb-success: #10b981;--fb-warning: #f59e0b;--fb-error: #ef4444;--fb-info: #3b82f6;--fb-bg-dark: #0b0f1a;--fb-surface: #0f172a;--fb-surface-2: #1e293b;--fb-border: #334155;--fb-border-light: #475569;--fb-text: #f8fafc;--fb-text-2: #cbd5e1;--fb-text-3: #94a3b8;--fb-text-muted: #64748b;--fb-radius-sm: 4px;--fb-radius-md: 6px;--fb-radius-lg: 10px;--fb-radius-xl: 14px;--fb-shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--fb-shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--fb-shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--fb-shadow-xl: 0 12px 48px rgba(0, 0, 0, .6);--fb-fast: .15s ease;--fb-normal: .25s ease;--fb-slow: .4s cubic-bezier(.4, 0, .2, 1);font-family:DM Sans,sans-serif;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);min-height:100vh;position:relative}.fb-loading{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--fb-text-muted);font-size:14px;gap:8px}.fb-header{display:flex;align-items:center;gap:16px;padding:14px 24px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 4px #0000000a}.fb-back-btn{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:var(--fb-radius-md);padding:7px 16px;font-size:12px;font-weight:600;color:var(--fb-text-muted);cursor:pointer;transition:all var(--fb-fast)}.fb-back-btn:hover{background:#e2e8f0;transform:translate(-2px)}.fb-header-title{margin:0;font-size:17px;font-weight:700;color:#0f172a;letter-spacing:-.01em}.fb-header-subtitle{margin:2px 0 0;font-size:12px;color:var(--fb-text-3)}.fb-preview-container{display:flex;justify-content:center;align-items:flex-start;padding:24px;min-height:calc(100vh - 120px);box-sizing:border-box}.fb-preview-form{background:#fff;border-radius:var(--fb-radius-lg);padding:28px;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a,0 0 0 1px #00000008;display:flex;flex-direction:column;box-sizing:border-box;transition:box-shadow var(--fb-normal)}.fb-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-shrink:0}.fb-preview-title{margin:0;font-size:16px;color:#0f172a;font-weight:700}.fb-preview-subtitle{margin:3px 0 0;font-size:11px;color:var(--fb-text-3)}.fb-preview-editing-badge{font-size:10px;color:var(--fb-primary);background:#0d948814;padding:4px 10px;border-radius:20px;font-weight:600;border:1px solid rgba(13,148,136,.15)}.fb-preview-fields{display:flex;flex-wrap:wrap;align-items:flex-start;align-content:flex-start;flex:1;overflow:auto}.fb-preview-empty{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--fb-text-3);text-align:center}.fb-preview-empty-icon{font-size:40px;margin-bottom:12px;opacity:.6}.fb-preview-empty p{margin:0;font-size:13px;color:#94a3b8}.fb-preview-empty-hint{font-size:11px!important;color:#cbd5e1!important;margin-top:4px!important}.fb-preview-field{box-sizing:border-box;cursor:pointer;transition:outline var(--fb-fast),background var(--fb-fast),box-shadow var(--fb-fast);border-radius:var(--fb-radius-sm);outline:none}.fb-preview-field:hover{outline:1.5px solid #94a3b8;outline-offset:-1px;border-radius:var(--fb-radius-sm);background:#94a3b80d;box-shadow:0 0 0 3px #94a3b814}.fb-preview-field--selected,.fb-preview-field--selected:hover{outline:2px solid var(--fb-primary);outline-offset:-1px;border-radius:var(--fb-radius-sm);box-shadow:0 0 0 4px var(--fb-primary-glow);background:#0d948808}.fb-preview-field--dragover{outline:2px dashed var(--fb-accent);outline-offset:-1px;border-radius:var(--fb-radius-sm);background:#0d94880f}.fb-preview-field[draggable]:active{cursor:grabbing;opacity:.5;transform:scale(.98)}.fb-preview-actions{display:none}.fb-sticky-actions{position:fixed;bottom:24px;left:24px;display:flex;gap:10px;z-index:999;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:12px 16px;border-radius:var(--fb-radius-md);box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,0 0 0 1px #0000000d}.fb-btn{border-radius:var(--fb-radius-md);padding:9px 24px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all var(--fb-fast)}.fb-btn:active{transform:scale(.97)}.fb-btn-secondary{background:#f1f5f9;border:1px solid #cbd5e1;color:var(--fb-text-muted)}.fb-btn-secondary:hover{background:#e2e8f0}.fb-btn-primary{background:linear-gradient(135deg,var(--fb-primary),var(--fb-primary-light));color:#fff;font-weight:700;box-shadow:0 2px 8px var(--fb-primary-glow)}.fb-btn-primary:hover{box-shadow:0 4px 16px var(--fb-primary-glow);transform:translateY(-1px)}.fb-panel{position:fixed;background:#0b0f1af2;border:1.5px solid var(--fb-primary);border-radius:var(--fb-radius-xl);box-shadow:var(--fb-shadow-xl),0 0 40px #0d948814,inset 0 1px #ffffff08;z-index:50;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;overflow:hidden}.fb-panel-titlebar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:linear-gradient(135deg,#0f172ae6,#1e293be6);cursor:move;flex-shrink:0;border-bottom:1px solid rgba(51,65,85,.6);-webkit-user-select:none;user-select:none}.fb-panel-titlebar-left{display:flex;align-items:center;gap:8px}.fb-panel-logo{width:24px;height:24px;border-radius:var(--fb-radius-md);background:linear-gradient(135deg,var(--fb-primary),var(--fb-accent));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--fb-bg-dark);box-shadow:0 2px 8px var(--fb-primary-glow)}.fb-panel-title{font-size:12px;font-weight:700;color:var(--fb-text);letter-spacing:.02em}.fb-panel-version{font-size:9px;color:var(--fb-text-muted);background:#64748b26;padding:1px 5px;border-radius:8px}.fb-panel-titlebar-right{display:flex;gap:4px;align-items:center}.fb-panel-size-inputs{display:flex;align-items:center;gap:3px;margin-right:6px}.fb-panel-size-input{width:56px;background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:4px 6px;color:var(--fb-accent);font-size:12px;text-align:center;font-family:JetBrains Mono,monospace;transition:border-color var(--fb-fast)}.fb-panel-size-input:focus{border-color:var(--fb-primary);outline:none;box-shadow:0 0 0 2px var(--fb-primary-glow)}.fb-panel-size-separator{font-size:11px;color:var(--fb-text-muted)}.fb-panel-icon-btn{background:#1e293b99;border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:4px 8px;font-size:11px;color:var(--fb-text-3);cursor:pointer;transition:all var(--fb-fast)}.fb-panel-icon-btn:hover{background:var(--fb-border);color:var(--fb-text);transform:scale(1.05)}.fb-panel-json-btn{font-family:JetBrains Mono,monospace}.fb-panel-body{flex:1;display:flex;overflow:hidden;color:var(--fb-text-2)}.fb-panel-resize{position:absolute;right:0;bottom:0;width:20px;height:20px;cursor:nwse-resize;z-index:2;display:flex;align-items:center;justify-content:center;transition:opacity var(--fb-fast)}.fb-panel-resize:hover{opacity:1}.fb-panel-resize-icon{width:10px;height:10px;border-right:2px solid var(--fb-primary);border-bottom:2px solid var(--fb-primary);opacity:.5;transition:opacity var(--fb-fast)}.fb-panel-resize:hover .fb-panel-resize-icon{opacity:1}.fb-panel-minimized{position:fixed;bottom:24px;right:24px;background:linear-gradient(135deg,var(--fb-primary),var(--fb-accent));border-radius:32px;padding:12px 24px;cursor:pointer;box-shadow:0 4px 20px #0d948859,0 8px 32px #0003;display:flex;align-items:center;gap:10px;z-index:50;-webkit-user-select:none;user-select:none;transition:all var(--fb-normal)}.fb-panel-minimized:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 6px 28px #0d948873,0 12px 40px #00000040}.fb-panel-minimized-logo{font-size:15px;font-weight:700;color:var(--fb-bg-dark)}.fb-panel-minimized-label{font-size:13px;font-weight:600;color:var(--fb-bg-dark)}.fb-panel--popout{position:static;width:100%!important;height:100vh!important;border-radius:0;display:flex;flex-direction:column}.fb-panel--popout .fb-panel-body{flex:1;overflow:hidden}.fb-field-list{width:220px;border-right:1px solid rgba(51,65,85,.5);display:flex;flex-direction:column;flex-shrink:0;background:#0f16294d}.fb-field-list-header{padding:8px 10px;border-bottom:1px solid rgba(51,65,85,.5)}.fb-field-search{width:100%;box-sizing:border-box;background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:6px 10px;color:var(--fb-text-2);font-size:11px;outline:none;transition:border-color var(--fb-fast),box-shadow var(--fb-fast)}.fb-field-search:focus{border-color:var(--fb-primary);box-shadow:0 0 0 2px var(--fb-primary-glow)}.fb-field-search::placeholder{color:var(--fb-text-muted)}.fb-field-list-actions{display:flex;gap:4px;margin-top:6px}.fb-bulk-btn{flex:1;background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:4px 0;font-size:10px;color:var(--fb-text-3);cursor:pointer;transition:all var(--fb-fast)}.fb-bulk-btn:hover{background:var(--fb-border);color:var(--fb-text)}.fb-field-list-body{flex:1;overflow-y:auto;padding:4px 0}.fb-field-list-footer{padding:6px 10px;border-top:1px solid rgba(51,65,85,.5);font-size:10px;color:var(--fb-text-muted);text-align:center}.fb-field-item{margin:2px 6px;padding:6px 8px;border-radius:var(--fb-radius-sm);cursor:grab;border:1px solid transparent;display:flex;align-items:center;gap:6px;transition:all var(--fb-fast)}.fb-field-item:hover{background:#1e293bb3;border-color:#33415566}.fb-field-item--selected{background:var(--fb-surface-2);border-color:var(--fb-border);border-left:2px solid var(--fb-primary)}.fb-field-item--hidden{opacity:.35}.fb-field-drag{color:var(--fb-text-muted);font-size:10px;-webkit-user-select:none;user-select:none;opacity:.5;transition:opacity var(--fb-fast)}.fb-field-item:hover .fb-field-drag{opacity:1}.fb-field-visibility{cursor:pointer;font-size:12px;width:18px;text-align:center;transition:transform var(--fb-fast)}.fb-field-visibility:hover{transform:scale(1.2)}.fb-field-info{flex:1;min-width:0}.fb-field-name{font-size:11px;font-weight:600;color:var(--fb-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.fb-field-item--hidden .fb-field-name{color:var(--fb-text-muted)}.fb-field-meta{font-size:9px;color:var(--fb-text-muted);display:flex;gap:4px;line-height:1.4}.fb-field-required{color:#f87171;font-size:9px;font-weight:700}.fb-field-checkbox{width:14px;height:14px;accent-color:var(--fb-primary);cursor:pointer;flex-shrink:0}.fb-field-item--checked{background:#0d94881f!important;border-color:#0d948840!important}.fb-field-bulk-bar{display:flex;align-items:center;gap:8px;padding:7px 10px;background:#1e293b80;border-bottom:1px solid rgba(51,65,85,.5)}.fb-field-check-all{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--fb-text-3);cursor:pointer;white-space:nowrap}.fb-field-check-all input{width:14px;height:14px;accent-color:var(--fb-primary);cursor:pointer}.fb-bulk-move-select{flex:1;background:var(--fb-surface);border:1px solid var(--fb-primary);border-radius:var(--fb-radius-sm);padding:4px 8px;color:var(--fb-accent);font-size:10px;cursor:pointer;min-width:0;transition:border-color var(--fb-fast)}.fb-bulk-move-select:hover{border-color:var(--fb-primary-light)}.fb-bulk-actions{display:flex;align-items:center;gap:4px;flex:1;min-width:0}.fb-bulk-action-btn{background:var(--fb-surface);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:3px 8px;font-size:12px;cursor:pointer;line-height:1;transition:all var(--fb-fast)}.fb-bulk-action-btn:hover{border-color:var(--fb-primary);background:var(--fb-surface-2);transform:scale(1.05)}.fb-props{flex:1;overflow-y:auto;background:#0f162966;padding:12px}.fb-props-empty{padding:32px 20px;text-align:center;color:var(--fb-text-muted);font-size:12px;line-height:1.5}.fb-props-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(51,65,85,.4)}.fb-props-field-name{font-size:13px;font-weight:700;color:var(--fb-text);line-height:1.3}.fb-props-field-meta{font-size:10px;margin-top:2px}.fb-props-close{background:#1e293b80;border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);color:var(--fb-text-muted);font-size:13px;cursor:pointer;padding:2px 6px;transition:all var(--fb-fast)}.fb-props-close:hover{background:var(--fb-border);color:var(--fb-text)}.fb-props-tabs{display:flex;gap:2px;margin-bottom:12px;background:#0f172a80;border-radius:var(--fb-radius-md);padding:3px}.fb-props-tab-btn{flex:1;padding:6px 4px;font-size:10px;font-weight:600;border:none;cursor:pointer;border-radius:var(--fb-radius-sm);background:transparent;color:var(--fb-text-muted);transition:all var(--fb-fast)}.fb-props-tab-btn:hover{color:var(--fb-text-3)}.fb-props-tab-btn--active{background:var(--fb-surface-2);color:var(--fb-accent);box-shadow:var(--fb-shadow-sm)}.fb-props-content{display:flex;flex-direction:column;gap:10px}.fb-props-move-page{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px;background:#1e293b66;border-radius:var(--fb-radius-md);border:1px solid rgba(51,65,85,.3)}.fb-props-move-label{font-size:11px;color:var(--fb-text-3);white-space:nowrap}.fb-props-move-select{flex:1;background:var(--fb-surface);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:5px 8px;color:var(--fb-text-2);font-size:11px;cursor:pointer;transition:border-color var(--fb-fast)}.fb-props-move-select:hover{border-color:var(--fb-primary)}.fb-props-sql-info{background:#1e293b66;border-radius:var(--fb-radius-sm);padding:8px;margin-top:12px;font-size:10px;color:var(--fb-text-3);border:1px solid rgba(51,65,85,.3)}.fb-sql-name{color:var(--fb-accent);font-family:JetBrains Mono,monospace}.fb-sql-required{color:#f87171}.fb-prop-tab{display:flex;flex-direction:column;gap:10px}.fb-prop-group{display:flex;flex-direction:column;gap:4px}.fb-prop-label{font-size:10px;font-weight:600;color:var(--fb-text-muted);text-transform:uppercase;letter-spacing:.04em}.fb-prop-input{width:100%;box-sizing:border-box;background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:6px 10px;color:var(--fb-text-2);font-size:12px;outline:none;font-family:DM Sans,sans-serif;transition:border-color var(--fb-fast),box-shadow var(--fb-fast)}.fb-prop-input:focus{border-color:var(--fb-primary);box-shadow:0 0 0 2px var(--fb-primary-glow)}.fb-toggle-group{display:flex;gap:3px}.fb-toggle-btn{flex:1;padding:5px 4px;font-size:10px;font-weight:600;border-radius:var(--fb-radius-sm);cursor:pointer;background:var(--fb-surface-2);color:var(--fb-text-3);border:1px solid var(--fb-border);transition:all var(--fb-fast)}.fb-toggle-btn:hover:not(.fb-toggle-btn--active){background:var(--fb-border);color:var(--fb-text-2)}.fb-toggle-btn--active{background:var(--fb-primary);color:var(--fb-bg-dark);border-color:var(--fb-primary);box-shadow:0 1px 4px var(--fb-primary-glow)}.fb-checkbox-label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--fb-text-2);cursor:pointer}.fb-fixed-height-badge{margin-top:4px;font-size:10px;color:#f87171;background:#dc262614;padding:4px 8px;border-radius:var(--fb-radius-sm);border:1px solid rgba(220,38,38,.12)}.fb-spacing-row{display:flex;align-items:center;gap:4px}.fb-spacing-label{font-size:10px;color:var(--fb-text-muted);min-width:12px;text-align:center;font-weight:600}.fb-spacing-input{width:44px;padding:4px;border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);background:var(--fb-surface);color:var(--fb-text-2);font-size:11px;text-align:center;font-family:JetBrains Mono,monospace;outline:none;transition:border-color var(--fb-fast)}.fb-spacing-input:focus{border-color:var(--fb-primary);box-shadow:0 0 0 2px var(--fb-primary-glow)}.fb-slider-input{display:flex;align-items:center;gap:8px}.fb-slider-input input[type=range]{flex:1;accent-color:var(--fb-primary)}.fb-slider-number{width:40px;background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:4px;font-size:11px;text-align:center;font-family:JetBrains Mono,monospace;outline:none;color:var(--fb-text-2);transition:border-color var(--fb-fast)}.fb-slider-number:focus{border-color:var(--fb-primary)}.fb-color-picker{display:flex;align-items:center;gap:6px}.fb-color-swatch{width:28px;height:24px;border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);cursor:pointer;padding:0;background:none;transition:transform var(--fb-fast)}.fb-color-swatch:hover{transform:scale(1.1)}.fb-color-text{flex:1;background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:4px 6px;color:var(--fb-text-2);font-size:10px;outline:none;font-family:JetBrains Mono,monospace;transition:border-color var(--fb-fast)}.fb-color-text:focus{border-color:var(--fb-primary)}.fb-color-transparent-btn{font-size:9px;color:var(--fb-text-muted);background:var(--fb-surface-2);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:3px 6px;cursor:pointer;transition:all var(--fb-fast)}.fb-color-transparent-btn:hover{border-color:var(--fb-primary);color:var(--fb-text-3)}.fb-icon-grid{display:flex;flex-wrap:wrap;gap:3px;max-height:130px;overflow-y:auto;padding:4px;background:#1e293b66;border-radius:var(--fb-radius-sm);margin-bottom:4px}.fb-icon-btn{width:28px;height:28px;border-radius:var(--fb-radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;color:var(--fb-text-3);padding:0;transition:all var(--fb-fast)}.fb-icon-btn:hover{background:var(--fb-surface-2);border-color:var(--fb-border);color:var(--fb-text);transform:scale(1.1)}.fb-icon-btn--active{border:1.5px solid var(--fb-primary);background:#0d948826}.fb-icon-btn--active .material-symbols-outlined,.fb-icon-btn--active{color:var(--fb-accent)}.fb-pagination{display:flex;align-items:center;gap:8px;padding:8px 24px;background:#fff;border-bottom:1px solid #e5e7eb}.fb-pagination-label{font-size:12px;font-weight:600;color:#334155}.fb-pagination-btn{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:var(--fb-radius-sm);padding:5px 12px;font-size:11px;color:var(--fb-text-muted);cursor:pointer;transition:all var(--fb-fast)}.fb-pagination-btn:hover:not(:disabled){background:#e2e8f0}.fb-pagination-btn:disabled{opacity:.35;cursor:not-allowed}.fb-pagination-tabs{display:flex;gap:4px;flex:1}.fb-pagination-tab{padding:5px 12px;font-size:11px;font-weight:600;border-radius:var(--fb-radius-md);cursor:pointer;background:#f1f5f9;color:var(--fb-text-muted);border:1px solid transparent;display:flex;align-items:center;gap:6px;transition:all var(--fb-fast)}.fb-pagination-tab:hover{background:#e2e8f0}.fb-pagination-tab--active{background:#0d948814;color:var(--fb-primary);border-color:var(--fb-primary)}.fb-pagination-edit-input{background:#fff;border:2px solid var(--fb-primary);border-radius:var(--fb-radius-sm);padding:3px 6px;font-size:11px;outline:none;width:90px}.fb-pagination-delete{background:none;border:none;color:var(--fb-text-3);cursor:pointer;font-size:14px;line-height:1;padding:0 2px;transition:color var(--fb-fast)}.fb-pagination-delete:hover{color:#f87171}.fb-pagination-add{background:linear-gradient(135deg,var(--fb-primary),var(--fb-primary-light));color:#fff;border:none;border-radius:var(--fb-radius-md);padding:5px 14px;font-size:11px;font-weight:600;cursor:pointer;transition:all var(--fb-fast);box-shadow:0 1px 4px var(--fb-primary-glow)}.fb-pagination-add:hover{transform:translateY(-1px);box-shadow:0 3px 12px var(--fb-primary-glow)}.fb-modal-overlay{position:fixed;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.fb-modal-content{background:var(--fb-surface);border:1px solid var(--fb-border);border-radius:var(--fb-radius-lg);width:640px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--fb-shadow-xl)}.fb-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--fb-surface-2)}.fb-modal-title{font-size:14px;font-weight:700;color:#7c3aed}.fb-modal-actions{display:flex;gap:8px}.fb-modal-copy-btn{background:#7c3aed;color:#fff;border:none;border-radius:var(--fb-radius-sm);padding:5px 14px;font-size:11px;font-weight:600;cursor:pointer;transition:all var(--fb-fast)}.fb-modal-copy-btn:hover{background:#6d28d9;transform:translateY(-1px)}.fb-modal-close-btn{background:none;border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:5px 10px;color:var(--fb-text-3);cursor:pointer;transition:all var(--fb-fast)}.fb-modal-close-btn:hover{background:var(--fb-surface-2);color:var(--fb-text)}.fb-modal-json{padding:18px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.6;color:#a5b4fc;overflow:auto;flex:1;white-space:pre-wrap;word-break:break-all;margin:0}.fb-field-list-body::-webkit-scrollbar,.fb-props::-webkit-scrollbar,.fb-icon-grid::-webkit-scrollbar,.fb-modal-json::-webkit-scrollbar{width:5px}.fb-field-list-body::-webkit-scrollbar-track,.fb-props::-webkit-scrollbar-track,.fb-icon-grid::-webkit-scrollbar-track,.fb-modal-json::-webkit-scrollbar-track{background:transparent}.fb-field-list-body::-webkit-scrollbar-thumb,.fb-props::-webkit-scrollbar-thumb,.fb-icon-grid::-webkit-scrollbar-thumb,.fb-modal-json::-webkit-scrollbar-thumb{background:#64748b4d;border-radius:10px}.fb-field-list-body::-webkit-scrollbar-thumb:hover,.fb-props::-webkit-scrollbar-thumb:hover,.fb-icon-grid::-webkit-scrollbar-thumb:hover,.fb-modal-json::-webkit-scrollbar-thumb:hover{background:#64748b80}.cell-input{width:100%;padding:8px 12px;font-size:14px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;font-family:inherit}.cell-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e26}.cell-input:disabled{background:#f1f5f9;color:#64748b;cursor:not-allowed}.cell-input-textarea{resize:vertical;min-height:36px}.cell-input.input-error{border-color:#dc2626;background:#fef2f2}.cell-input-error{display:block;font-size:12px;color:#dc2626;margin-top:2px}.cell-input-json-wrap{display:flex;flex-direction:column}.cell-input-list-custom{display:flex;gap:4px;align-items:center}.cell-input-list-custom .cell-input{flex:1}.cell-input-list-back{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid #cbd5e1;border-radius:4px;background:#fff;cursor:pointer;font-size:16px;color:#64748b;flex-shrink:0}.cell-input-list-back:hover{background:#f1f5f9}.cell-boolean{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #cbd5e1;border-radius:6px;background:#fff;cursor:pointer;font-size:16px;transition:border-color .15s}.cell-boolean:hover{border-color:var(--color-primary)}.cell-boolean-disabled{cursor:not-allowed;opacity:.6}.cell-boolean-null{color:#94a3b8;font-weight:600}.cell-boolean-true{color:var(--color-primary);font-weight:700}.cell-boolean-false{color:#dc2626;font-weight:700}.row-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:20px;margin-bottom:16px}.row-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.row-form-title{font-size:15px;font-weight:600;color:#0f172a}.row-form-actions{display:flex;gap:8px}.row-form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:1200px){.row-form-grid{grid-template-columns:repeat(2,1fr)}}.row-form-field{display:flex;flex-direction:column}.row-form-field label{font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.row-form-field .required{color:#dc2626}.row-form-pk-badge{display:inline-block;font-size:10px;font-weight:600;color:#64748b;background:#e2e8f0;padding:1px 6px;border-radius:4px;margin-left:6px;vertical-align:middle}.row-form-error{display:block;font-size:12px;color:#dc2626;margin-top:4px}.dt-scroll{overflow-x:auto}.dt-table{width:100%;border-collapse:collapse;font-size:13px}.dt-th{position:sticky;top:0;background:#f8fafc;padding:10px 12px;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0;white-space:nowrap;-webkit-user-select:none;user-select:none}.dt-th-sortable{cursor:pointer}.dt-th-sortable:hover{color:var(--color-primary)}.dt-th-text{margin-right:4px}.dt-th-sort{font-size:11px;color:#94a3b8}.dt-th-sort-active{color:var(--color-primary)}.dt-th-actions{width:120px;text-align:center}.dt-row{border-bottom:1px solid #f1f5f9;transition:background .1s}.dt-row:hover{background:#f8fafc}.dt-td{padding:8px 12px;color:#1e293b;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dt-td-actions{text-align:center;white-space:nowrap}.dt-action-btn{border:none;background:transparent;cursor:pointer;font-size:15px;padding:4px 6px;border-radius:4px;transition:background .1s}.dt-action-btn:hover{background:#e2e8f0}.dt-action-delete:hover{background:#fee2e2}.dt-loading{display:flex;align-items:center;justify-content:center;padding:48px 20px;color:#64748b;font-size:14px}.dt-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center}.dt-empty-icon{font-size:40px;margin-bottom:12px;opacity:.6}.dt-empty p{font-size:14px;color:#64748b}.dt-empty-hint{font-size:13px;color:#94a3b8;margin-top:4px}.cat-sidebar{width:240px;flex-shrink:0;background:#fff;border-radius:10px;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden}.cat-sidebar-list{flex:1;overflow-y:auto;padding:4px 0}.cat-sidebar-group{margin-bottom:2px}.cat-sidebar-root{display:flex;align-items:center;gap:6px;padding:10px 14px 4px;-webkit-user-select:none;user-select:none}.cat-sidebar-root-icon{font-size:14px;flex-shrink:0}.cat-sidebar-root-name{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.3px}.cat-sidebar-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 14px 7px 28px;border:none;border-left:3px solid transparent;background:transparent;cursor:pointer;font-family:inherit;font-size:13px;color:#334155;text-align:left;transition:background .1s,border-color .1s}.cat-sidebar-item:hover{background:#f1f5f9}.cat-sidebar-item.active{background:#e0f2fe;border-left-color:var(--color-primary);font-weight:500;color:#0f172a}.cat-sidebar-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-sidebar-item-badge{flex-shrink:0;font-size:12px;color:#94a3b8;margin-left:8px}.cat-sidebar-item.active .cat-sidebar-item-badge{color:var(--color-primary)}.cat-sidebar-order{border-top:1px solid #e2e8f0;padding:10px 14px 12px;background:#f8fafc}.cat-sidebar-order-title{font-size:11px;font-weight:700;color:#64748b;letter-spacing:.5px;margin-bottom:6px}.cat-sidebar-order-item{display:flex;align-items:center;gap:4px;padding:2px 0;font-size:12px;color:#475569}.cat-sidebar-order-item.clickable{cursor:pointer}.cat-sidebar-order-item.clickable:hover{color:var(--color-primary)}.cat-sidebar-order-num{width:16px;text-align:right;flex-shrink:0;color:#94a3b8}.cat-sidebar-order-check{font-size:13px;flex-shrink:0}.cat-sidebar-order-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-page{display:flex;flex-direction:column;height:100%;min-height:0}.cat-page-loading{display:flex;align-items:center;justify-content:center;height:200px;color:#64748b;font-size:14px}.cat-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cat-page-header-left h1{font-size:22px;font-weight:700;color:#0f172a}.cat-page-header-left p{font-size:13px;color:#64748b;margin-top:4px}.cat-page-header-stats{font-size:13px;color:#64748b;background:#f8fafc;padding:8px 16px;border-radius:8px;border:1px solid #e2e8f0;white-space:nowrap}.cat-page-body{display:flex;gap:16px;flex:1;min-height:0}.cat-page-main{flex:1;background:#fff;border-radius:10px;border:1px solid #e2e8f0;overflow-y:auto;padding:20px;display:flex;flex-direction:column}.cat-page-placeholder{display:flex;align-items:center;justify-content:center;height:200px;color:#94a3b8;font-size:14px}.cat-page-table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cat-page-table-header-left{display:flex;align-items:center;gap:10px}.cat-page-table-badge{font-size:11px;font-family:Consolas,Courier New,monospace;color:#64748b;background:#f1f5f9;padding:3px 8px;border-radius:4px;border:1px solid #e2e8f0}.cat-page-table-name{font-size:16px;font-weight:600;color:#0f172a}.cat-page-table-count{font-size:13px;color:#64748b}.cat-page-fk-warning{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:10px 14px;font-size:13px;color:#92400e;margin-bottom:12px}.cat-page-fk-warning-link{background:none;border:none;color:#d97706;font-weight:600;cursor:pointer;text-decoration:underline;font-family:inherit;font-size:inherit;padding:0}.cat-page-fk-warning-link:hover{color:#b45309}.cat-page-search{margin-bottom:12px}.cat-page-search-input{width:280px;padding:8px 12px;font-size:14px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;font-family:inherit}.cat-page-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e26}.cat-page-search-input::placeholder{color:#94a3b8}.cat-page-pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9}.cat-page-pg-btn{min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;padding:0 8px;font-size:13px;font-family:inherit;border:1px solid #e2e8f0;border-radius:6px;background:#fff;color:#475569;cursor:pointer;transition:background .1s,border-color .1s}.cat-page-pg-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.cat-page-pg-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.cat-page-pg-btn:disabled{opacity:.4;cursor:not-allowed}.cat-page-pg-dots{padding:0 4px;color:#94a3b8;font-size:13px}.cat-page-pg-info{font-size:12px;color:#94a3b8;margin-left:8px}.rct{display:flex;flex-direction:column;gap:6px}.rct-group{border:1px solid #E2E8F0;border-radius:8px;overflow:hidden}.rct-group-header{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;background:#fafbfc;border-left:3px solid #64748b;transition:background .15s}.rct-group-header:hover{background:#f1f5f9}.rct-group-icon{font-size:16px}.rct-group-name{font-size:13px;font-weight:700;color:#1e293b;flex:1}.rct-group-tables{font-size:11px;color:#94a3b8}.rct-group-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.rct-group-body{padding:4px 0 8px}.rct-chevron{font-size:14px;color:#94a3b8;width:18px;text-align:center;flex-shrink:0}.rct-table{margin:2px 0}.rct-table-header{display:flex;align-items:center;gap:6px;padding:6px 14px 6px 24px;cursor:pointer;transition:background .1s}.rct-table-header:hover{background:#f8fafc}.rct-table-icon{font-size:13px}.rct-table-name{font-size:12.5px;font-weight:600;color:#334155}.rct-table-count{font-size:11px;color:#94a3b8}.rct-table-body{padding:2px 0 4px 24px}.rct-search{display:flex;gap:4px;padding:4px 10px 6px}.rct-search input{flex:1;padding:5px 10px;border:1px solid #E2E8F0;border-radius:5px;font-size:12px;outline:none}.rct-search input:focus{border-color:#94a3b8}.rct-search-btn{padding:4px 12px;border:1px solid #E2E8F0;border-radius:5px;background:#fff;font-size:12px;cursor:pointer;color:#475569}.rct-search-btn:hover{background:#f1f5f9}.rct-record{display:flex;align-items:center;gap:6px;padding:3px 10px;cursor:default;transition:background .1s;border-radius:3px}.rct-record:hover{background:#f8fafc}.rct-record-sel{background:#f0fdfa}.rct-record-sel:hover{background:#e6faf5}.rct-expand-sm{font-size:14px;color:#94a3b8;cursor:pointer;width:18px;text-align:center;flex-shrink:0}.rct-expand-sm:hover{color:#475569}.rct-expand-spacer{width:18px;flex-shrink:0}.rct-record input[type=checkbox]{width:15px;height:15px;cursor:pointer;flex-shrink:0;margin-top:1px}.rct-record-label{font-size:12.5px;color:#334155}.rct-child-label{font-size:11.5px;font-weight:700;padding:4px 0 2px;opacity:.85}.rct-load-more{display:block;width:calc(100% - 20px);margin:4px 10px;padding:5px;border:1px dashed #CBD5E1;border-radius:5px;background:none;font-size:11.5px;color:#64748b;cursor:pointer;text-align:center}.rct-load-more:hover{background:#f8fafc;border-color:#94a3b8}.rct-load-more:disabled{opacity:.5;cursor:wait}.rct-empty{padding:12px 10px;text-align:center;font-size:12px;color:#94a3b8}.data-tree{display:flex;flex-direction:column;gap:12px}.dt-tier-tabs{display:flex;gap:10px}.dt-tier-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;border-radius:10px;border:1.5px solid #E2E8F0;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.dt-tier-tab:hover{box-shadow:0 2px 8px #0000000f}.dt-tier-icon{font-size:16px}.dt-tier-name{font-weight:700}.dt-tier-groups{font-size:11px;opacity:.7}.dt-tier-count{font-size:11px;font-weight:700;padding:2px 7px;border-radius:8px;margin-left:auto}.dt-tier-panel{border:1.5px solid #E2E8F0;border-radius:10px;overflow:hidden}.dt-group{border-bottom:1px solid #F1F5F9}.dt-group:last-child{border-bottom:none}.dt-group-header{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;font-size:13px}.dt-group-header:hover{filter:brightness(.97)}.dt-group-name{font-weight:700}.dt-group-tables{font-size:11px;color:#94a3b8;margin-left:auto}.dt-group-body{padding:0 4px 8px}.tool2-page{padding:24px 32px;max-width:1200px}.tool2-page h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 20px}.tool2-topbar{display:flex;align-items:center;gap:10px;margin-bottom:16px}.tool2-topbar input{flex:1;padding:8px 12px;font-size:13px;border:1px solid #E2E8F0;border-radius:8px;outline:none}.tool2-topbar input:focus{border-color:#94a3b8}.tool2-topbar select{padding:8px 12px;font-size:13px;border:1px solid #E2E8F0;border-radius:8px;outline:none;background:#fff}.tool2-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.tool2-table th{text-align:left;padding:10px 12px;font-weight:600;border-bottom:2px solid #E2E8F0;color:#64748b;font-size:12px}.tool2-table td{padding:10px 12px;border-bottom:1px solid #F1F5F9;color:#334155}.tool2-table tr:hover td{background:#f8fafc}.tool2-table .actions{display:flex;gap:6px;white-space:nowrap}.tool2-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.tool2-status{padding:3px 10px;border-radius:10px;font-size:11px;font-weight:600}.tool2-status.draft{background:#fef3c7;color:#92400e}.tool2-status.approved{background:#d1fae5;color:#065f46}.tool2-pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;font-size:13px}.tool2-editor{padding:24px 32px;max-width:1200px}.tool2-editor h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 20px}.tool2-form-section{background:#fff;border:1px solid #E2E8F0;border-radius:10px;padding:16px 20px;margin-bottom:16px}.tool2-form-section h3{font-size:14px;font-weight:700;color:#1e293b;margin:0 0 12px}.tool2-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}.tool2-form-group{display:flex;flex-direction:column;gap:4px}.tool2-form-group label{font-size:12px;font-weight:600;color:#64748b}.tool2-form-group label .required{color:#ef4444}.tool2-form-group input,.tool2-form-group textarea{padding:8px 12px;font-size:13px;border:1px solid #E2E8F0;border-radius:8px;outline:none}.tool2-form-group input:focus,.tool2-form-group textarea:focus{border-color:#94a3b8}.tool2-form-group .input-disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.tool2-form-group .error-text{font-size:11px;color:#ef4444}.tool2-selected-panel{background:#fff;border:1px solid #E2E8F0;border-radius:10px;padding:16px 20px;margin-bottom:16px}.tool2-selected-panel h3{font-size:14px;font-weight:700;margin:0 0 8px}.tool2-selected-list{max-height:200px;overflow-y:auto}.tool2-selected-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12.5px;color:#334155}.tool2-selected-item .remove-btn{font-size:10px;color:#94a3b8;cursor:pointer;margin-left:auto}.tool2-selected-item .remove-btn:hover{color:#ef4444}.tool2-sticky-bar{position:sticky;bottom:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-top:1px solid #E2E8F0;border-radius:0 0 10px 10px}.tool2-sticky-left{display:flex;align-items:center;gap:12px;font-size:13px}.tool2-sticky-right{display:flex;gap:8px}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--color-amber-50:oklch(98.7% .022 95.277);--color-teal-600:oklch(60% .118 184.704);--color-teal-700:oklch(51.1% .096 186.391);--color-teal-800:oklch(43.7% .078 188.216);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-600:oklch(54.6% .245 262.881);--color-slate-50:oklch(98.4% .003 247.858);--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-300:oklch(86.9% .022 252.894);--color-slate-400:oklch(70.4% .04 256.788);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-600:oklch(44.6% .043 257.281);--color-slate-800:oklch(27.9% .041 260.031);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-700:oklch(37.3% .034 259.733);--color-black:#000;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--tracking-wider:.05em;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--animate-spin:spin 1s linear infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1)}}@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.top-2\.5{top:calc(var(--spacing) * 2.5)}.right-0{right:calc(var(--spacing) * 0)}.right-3{right:calc(var(--spacing) * 3)}.bottom-0{bottom:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.left-2\.5{left:calc(var(--spacing) * 2.5)}.z-\[1\]{z-index:1}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.ml-auto{margin-left:auto}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-6{height:calc(var(--spacing) * 6)}.h-16{height:calc(var(--spacing) * 16)}.h-\[3px\]{height:3px}.min-h-0{min-height:calc(var(--spacing) * 0)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-10{width:calc(var(--spacing) * 10)}.w-16{width:calc(var(--spacing) * 16)}.w-\[56px\]{width:56px}.w-\[220px\]{width:220px}.w-full{width:100%}.min-w-\[120px\]{min-width:120px}.min-w-\[180px\]{min-width:180px}.flex-1{flex:1}.border-collapse{border-collapse:collapse}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-none{--tw-border-style:none;border-style:none}.border-blue-600{border-color:var(--color-blue-600)}.border-gray-200{border-color:var(--color-gray-200)}.border-slate-100{border-color:var(--color-slate-100)}.border-slate-100\/80{border-color:#f1f5f9cc}@supports (color:color-mix(in lab,red,red)){.border-slate-100\/80{border-color:color-mix(in oklab,var(--color-slate-100) 80%,transparent)}}.border-slate-200{border-color:var(--color-slate-200)}.border-transparent{border-color:#0000}.bg-amber-50\/70{background-color:#fffbebb3}@supports (color:color-mix(in lab,red,red)){.bg-amber-50\/70{background-color:color-mix(in oklab,var(--color-amber-50) 70%,transparent)}}.bg-blue-600{background-color:var(--color-blue-600)}.bg-slate-50\/30{background-color:#f8fafc4d}@supports (color:color-mix(in lab,red,red)){.bg-slate-50\/30{background-color:color-mix(in oklab,var(--color-slate-50) 30%,transparent)}}.bg-slate-50\/95{background-color:#f8fafcf2}@supports (color:color-mix(in lab,red,red)){.bg-slate-50\/95{background-color:color-mix(in oklab,var(--color-slate-50) 95%,transparent)}}.bg-slate-100{background-color:var(--color-slate-100)}.bg-teal-700{background-color:var(--color-teal-700)}.bg-white{background-color:var(--color-white)}.p-3{padding:calc(var(--spacing) * 3)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.pr-3{padding-right:calc(var(--spacing) * 3)}.pr-16{padding-right:calc(var(--spacing) * 16)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-left{text-align:left}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.whitespace-nowrap{white-space:nowrap}.text-blue-100{color:var(--color-blue-100)}.text-gray-200{color:var(--color-gray-200)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-700{color:var(--color-gray-700)}.text-slate-300{color:var(--color-slate-300)}.text-slate-400{color:var(--color-slate-400)}.text-slate-500{color:var(--color-slate-500)}.text-slate-800{color:var(--color-slate-800)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.line-through{text-decoration-line:line-through}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.opacity-100{opacity:1}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-black\/5{--tw-ring-color:#0000000d}@supports (color:color-mix(in lab,red,red)){.ring-black\/5{--tw-ring-color:color-mix(in oklab, var(--color-black) 5%, transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:border-slate-200:hover{border-color:var(--color-slate-200)}.hover\:bg-amber-50:hover{background-color:var(--color-amber-50)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-slate-50\/80:hover{background-color:#f8fafccc}@supports (color:color-mix(in lab,red,red)){.hover\:bg-slate-50\/80:hover{background-color:color-mix(in oklab,var(--color-slate-50) 80%,transparent)}}.hover\:bg-teal-800:hover{background-color:var(--color-teal-800)}.hover\:bg-white:hover{background-color:var(--color-white)}.hover\:text-slate-600:hover{color:var(--color-slate-600)}.hover\:text-teal-700:hover{color:var(--color-teal-700)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.focus\:border-teal-600:focus{border-color:var(--color-teal-600)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-teal-600\/10:focus{--tw-ring-color:#0095881a}@supports (color:color-mix(in lab,red,red)){.focus\:ring-teal-600\/10:focus{--tw-ring-color:color-mix(in oklab, var(--color-teal-600) 10%, transparent)}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}}.perm-root *,.perm-root :before,.perm-root :after{box-sizing:border-box;border-style:solid;border-width:0;border-color:var(--color-gray-200,#e5e7eb)}.perm-root button,.perm-root input,.perm-root select,.perm-root textarea{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;margin:0;padding:0}.perm-root button{cursor:pointer;background-color:#0000}.perm-root select{appearance:auto}.perm-root table{border-collapse:collapse}.perm-root img,.perm-root svg{vertical-align:middle;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
