*,*: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;--sidebar-collapsed-width: 60px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:#1e293b}.app-layout{display:flex;height:100vh;position:relative}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);color:var(--color-sidebar-text);display:flex;flex-direction:column;flex-shrink:0;transition:width .3s ease,opacity .3s ease;overflow:hidden}.sidebar-collapsed{width:var(--sidebar-collapsed-width)}.sidebar-brand{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-collapsed .sidebar-brand{padding:16px 10px;flex-direction:column;gap:6px}.sidebar-brand-text{font-size:16px;font-weight:600;letter-spacing:.5px;white-space:nowrap;overflow:hidden;transition:font-size .3s ease}.sidebar-collapsed .sidebar-brand-text{font-size:13px;letter-spacing:0}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;color:var(--color-sidebar-text);flex-shrink:0;transition:background .15s,color .15s}.sidebar-toggle-btn:hover{background:#ffffff2e;color:#fff}.sidebar-nav{display:flex;flex-direction:column;padding:8px;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;color:var(--color-sidebar-text);text-decoration:none;font-size:14px;transition:background .15s,padding .3s ease;position:relative}.sidebar-link:hover{background:#ffffff14}.sidebar-link.active{background:var(--color-sidebar-active);color:#fff;font-weight:500}.sidebar-link-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px;color:#b0bec5;transition:margin .3s ease}.sidebar-link.active .sidebar-link-icon{color:#fff}.sidebar-link-text{white-space:nowrap;overflow:hidden;opacity:1;transition:opacity .2s ease}.sidebar-collapsed .sidebar-nav{padding:8px 4px}.sidebar-collapsed .sidebar-link{justify-content:center;padding:12px 0;gap:0}.sidebar-collapsed .sidebar-link-text{opacity:0;width:0;overflow:hidden;position:absolute}.sidebar-collapsed .sidebar-link-icon{margin-right:0}.sidebar-tooltip{position:fixed;left:68px;background:#333;color:#fff;padding:6px 12px;border-radius:4px;font-size:13px;white-space:nowrap;pointer-events:none;z-index:10000;box-shadow:0 2px 8px #0003}.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;gap:16px}.tier-config-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.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}.gas-wrap{position:relative;margin-bottom:0;width:420px}.gas-input-wrap{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;transition:border-color .15s,box-shadow .15s}.gas-input-wrap:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #0f766e1a}.gas-icon-search{color:#94a3b8;flex-shrink:0;display:flex}.gas-input{flex:1;border:none;outline:none;font-size:14px;color:#1e293b;font-family:inherit;background:transparent}.gas-input::placeholder{color:#94a3b8}.gas-clear{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;background:#f1f5f9;border-radius:50%;cursor:pointer;color:#64748b;flex-shrink:0;transition:background .15s}.gas-clear:hover{background:#e2e8f0;color:#334155}.gas-spinner{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:var(--color-primary);border-radius:50%;animation:gas-spin .6s linear infinite;flex-shrink:0}@keyframes gas-spin{to{transform:rotate(360deg)}}.gas-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:200;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 12px 36px #0000001f;max-height:420px;overflow:hidden;display:flex;flex-direction:column}.gas-dropdown-header{padding:10px 14px;font-size:12px;font-weight:600;color:#64748b;border-bottom:1px solid #f1f5f9}.gas-dropdown-list{overflow-y:auto;max-height:380px}.gas-result-item{padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid #f8fafc}.gas-result-item:hover,.gas-result-active{background:#f0fdf9}.gas-result-name{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:3px}.gas-result-pin{margin-right:6px}.gas-highlight{background:#fef08a;color:inherit;border-radius:2px;padding:0 1px}.gas-result-path{font-size:12px;color:#64748b;margin-bottom:2px;padding-left:24px}.gas-result-meta{font-size:12px;color:#94a3b8;padding-left:24px}.gas-no-results{padding:24px;text-align:center;color:#64748b;font-size:14px}.gas-no-results-icon{font-size:28px;margin-bottom:8px}.gas-no-results-hint{font-size:12px;color:#94a3b8;margin-top:4px}@keyframes attr-row-flash{0%,to{background:transparent}25%{background:#fff3cd}50%{background:transparent}75%{background:#fff3cd}}.attr-row-highlight td{animation:attr-row-flash 1.5s ease;background:#fff3cd!important}.attr-row-highlight td.col-name-cell,.attr-row-highlight td.col-type-cell,.attr-row-highlight td.col-select{background:#fff3cd!important}.attr-row-editing{outline:2px solid var(--color-primary, #2a9d8f);outline-offset:-1px;border-radius:2px}.attr-row-editing td,.attr-row-editing td.col-name-cell,.attr-row-editing td.col-type-cell,.attr-row-editing td.col-select{background:#f0faf9!important}.attr-row-editing td input[type=text],.attr-row-editing td select{border:1px solid #cbd5e1;border-radius:4px;padding:3px 6px;font-size:13px;width:100%;box-sizing:border-box;font-family:inherit;background:#fff}.attr-row-editing td input[type=text]:focus,.attr-row-editing td select:focus{outline:none;border-color:var(--color-primary, #2a9d8f);box-shadow:0 0 0 1px #2a9d8f33}.attr-cell-editing{background-color:#fffde7!important;outline:2px solid #f0ad4e;outline-offset:-1px}.attr-cell-editing input[type=text],.attr-cell-editing select{border:1px solid #cbd5e1;border-radius:4px;padding:3px 6px;font-size:13px;width:100%;box-sizing:border-box;font-family:inherit;background:#fff}.attr-cell-editing input[type=text]:focus,.attr-cell-editing select:focus{outline:none;border-color:#f0ad4e;box-shadow:0 0 0 1px #f0ad4e4d}.confirm-dialog-icon-warning{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 12px;background:#fffbeb;color:#d97706}.confirm-dialog-changes{margin:12px 0;padding:10px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;text-align:left}.confirm-dialog-changes-title{font-weight:600;color:#334155;margin-bottom:6px}.confirm-dialog-changes ul{margin:0;padding-left:18px;list-style:disc}.confirm-dialog-changes li{margin-bottom:4px;color:#475569;line-height:1.5}.attr-row-hint-tooltip{background:#333;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap;pointer-events:none;z-index:10000;box-shadow:0 2px 8px #0003}.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;flex:1;min-height:0}.panel-left{flex-shrink:0;background:#fff;border-radius:10px;border:1px solid #e2e8f0;overflow-y:auto;min-width:250px}.panel-splitter{width:6px;flex-shrink:0;cursor:col-resize;background:#e2e8f0;display:flex;align-items:center;justify-content:center;transition:background .15s;position:relative;margin:0 5px;border-radius:3px}.panel-splitter:hover,.panel-splitter:active{background:var(--color-primary, #2a9d8f)}.panel-splitter-dots{display:flex;flex-direction:column;gap:3px}.panel-splitter-dots span{display:block;width:4px;height:4px;border-radius:50%;background:#94a3b8;transition:background .15s}.panel-splitter:hover .panel-splitter-dots span,.panel-splitter:active .panel-splitter-dots span{background:#fff}.panel-right{flex:1;background:#fff;border-radius:10px;border:1px solid #e2e8f0;overflow:auto;min-width:400px}.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-actions{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity .2s;margin-right:4px;flex-shrink:0}.group-node:hover .group-node-actions{opacity:1}.group-node-action{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:4px;cursor:pointer;color:#666;transition:color .15s,background .15s}.group-node-action-edit:hover{color:var(--color-primary, #2a9d8f);background:#2a9d8f1a}.group-node-action-delete:hover{color:#e74c3c;background:#e74c3c1a}.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{display:flex;align-items:center;justify-content:space-between;padding:12px 0 8px;font-size:14px;font-weight:600;color:#334155;border-top:1px solid #e2e8f0}.attr-thead-sentinel{height:0;margin:0;padding:0;border:0;visibility:hidden}.attr-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;min-width:1380px;table-layout:fixed}.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:normal;word-break:keep-all;background:#f8fafc;vertical-align:bottom;position:sticky;top:0;z-index:10;transition:box-shadow .2s ease}.attr-table thead.is-stuck th{box-shadow:0 2px 4px #0000001a}.attr-table td{padding:4px 6px;border-bottom:1px solid #f1f5f9;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attr-table .col-name{width:160px}.attr-table .col-type{width:150px}.attr-table .col-select{width:36px;text-align:center;position:sticky;left:0;z-index:5;box-sizing:border-box}.attr-table th.col-select{z-index:20;background:#f8fafc}.attr-table td.col-select{background:#fff}.attr-row:hover td.col-select{background:#e6f7f5}.attr-row-selected td.col-select{background:#e0f2fe!important}.attr-table .col-name,.attr-table td.col-name-cell,.attr-table .col-type,.attr-table td.col-type-cell{box-sizing:border-box}.attr-table .col-name,.attr-table td.col-name-cell{position:sticky;z-index:5}.attr-table .col-type,.attr-table td.col-type-cell{position:sticky;z-index:5;box-shadow:2px 0 4px #0000000f}.has-select .col-name,.has-select td.col-name-cell{left:36px}.has-select .col-type,.has-select td.col-type-cell{left:196px}.no-select .col-name,.no-select td.col-name-cell{left:0}.no-select .col-type,.no-select td.col-type-cell{left:160px}.attr-table th.col-name,.attr-table th.col-type{z-index:20;background:#f8fafc}.attr-table td.col-name-cell,.attr-table td.col-type-cell{background:#fff}.attr-row:hover td.col-name-cell,.attr-row:hover td.col-type-cell{background:#e6f7f5}.attr-row-selected td,.attr-row-selected td.col-name-cell,.attr-row-selected td.col-type-cell{background:#e0f2fe!important}.attr-table .col-ref{width:140px}.attr-table .col-check{width:80px;min-width:80px;text-align:center}.attr-table .col-perm{width:110px;min-width:110px;text-align:center}.attr-table .col-scope{width:100px;min-width:100px}.attr-table .col-enum{width:130px}.attr-table .col-desc{width:110px}.attr-table .col-default{width:95px}.attr-table .col-action{width:80px;text-align:center}.cell-center{text-align:center}.attr-row:hover{background:#e6f7f5;transition:background-color .15s ease}.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-readonly{display:block;padding:4px 6px;min-height:28px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#1e293b}.attr-cell-na{color:#cbd5e1;padding:4px 6px}.attr-action-icons{display:flex;align-items:center;justify-content:center;gap:8px}.attr-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;border-radius:4px;cursor:pointer;color:#888;transition:color .15s,background .15s}.attr-action-edit:hover{color:#2a9d8f;background:#e6f7f5}.attr-action-delete:hover{color:#e74c3c;background:#fef2f2}.attr-add-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:2px solid #0f766e;border-radius:6px;background:#fff;color:#0f766e;font-size:18px;font-weight:700;cursor:pointer;transition:background .15s,color .15s}.attr-add-btn:hover:not(:disabled){background:#0f766e;color:#fff}.attr-add-btn:disabled{border-color:#cbd5e1;color:#cbd5e1;cursor:not-allowed}.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:#e74c3c;background:#fef2f2}.attr-duplicate-error{color:#e74c3c;font-size:13px;margin-top:4px;line-height:1.3}.group-detail-duplicate-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:13px;line-height:1.4;padding:8px 14px;border-radius:6px;max-width:420px;flex-shrink:0;animation:duplicateErrorFadeIn .2s ease}@keyframes duplicateErrorFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.edit-attr-modal input.input-error{border-color:#e74c3c!important;background:#fef2f2}.attr-th-inner{display:flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.attr-th-inner:hover{color:#334155}.attr-th-label{flex:1;min-width:0}.attr-sort-icon{font-size:10px;line-height:1;color:#94a3b8;flex-shrink:0}.attr-sort-icon.active{color:var(--color-primary)}.attr-filter-icon{font-size:12px;line-height:1;color:#94a3b8;flex-shrink:0;opacity:0;transition:opacity .15s;cursor:pointer;padding:2px;border-radius:3px}.attr-th-inner:hover .attr-filter-icon,.attr-filter-icon.active{opacity:1}.attr-filter-icon.active{color:var(--color-primary)}.attr-filter-icon:hover{background:#0000000f}.attr-filter-dropdown{position:absolute;top:100%;left:0;z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;min-width:220px;max-width:280px;font-size:13px;text-transform:none;letter-spacing:0;font-weight:400;color:#334155;white-space:normal}.attr-filter-search{display:flex;align-items:center;padding:8px 10px;border-bottom:1px solid #f1f5f9;gap:6px}.attr-filter-search input{flex:1;border:none;outline:none;font-size:13px;color:#334155;font-family:inherit;background:transparent}.attr-filter-search input::placeholder{color:#94a3b8}.attr-filter-options{max-height:180px;overflow-y:auto;padding:4px 0}.attr-filter-option{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;transition:background .1s}.attr-filter-option:hover{background:#f1f5f9}.attr-filter-option input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary);cursor:pointer}.attr-filter-option label{cursor:pointer;flex:1}.attr-filter-divider{height:1px;background:#f1f5f9;margin:2px 0}.attr-filter-sort-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;transition:background .1s}.attr-filter-sort-item:hover{background:#f1f5f9}.attr-filter-sort-item.active{color:var(--color-primary);font-weight:500}.attr-filter-clear{padding:6px 12px;border-top:1px solid #f1f5f9}.attr-filter-clear button{width:100%;padding:5px 10px;font-size:12px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#64748b;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.attr-filter-clear button:hover{background:#f1f5f9;color:#334155}.attr-filter-bar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f0fdf9;border:1px solid #d1fae5;border-radius:6px;margin-bottom:8px;font-size:12px;color:#334155;flex-wrap:wrap}.attr-filter-bar-icon{color:var(--color-primary);font-size:13px}.attr-filter-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#e0f2fe;border-radius:4px;font-size:12px;color:#0369a1}.attr-filter-bar-clear{margin-left:auto;padding:2px 8px;font-size:12px;border:none;background:none;color:#dc2626;cursor:pointer;font-family:inherit}.attr-filter-bar-clear:hover{text-decoration:underline}.attr-cell-tooltip-wrap{position:relative}.attr-cell-tooltip{position:fixed;z-index:9999;max-width:400px;padding:8px 12px;background:#1a1a1a;color:#fff;font-size:13px;line-height:1.5;border-radius:6px;word-wrap:break-word;white-space:normal;pointer-events:none;box-shadow:0 4px 12px #00000040}.attr-cell-tooltip ul{list-style:none;padding:0;margin:0}.attr-cell-tooltip ul li:before{content:"• ";color:#94a3b8}.attr-truncate-cell{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;padding:4px 6px;min-height:28px;line-height:20px;color:#1e293b;cursor:default}.btn-danger-sm{padding:4px 12px;font-size:12px;border:1px solid #dc2626;border-radius:4px;background:#dc2626;color:#fff;cursor:pointer;font-family:inherit}.btn-danger-sm:hover{background:#b91c1c}.attr-selection-count{color:#0f766e;font-weight:500}.confirm-dialog{background:#fff;border-radius:12px;padding:24px;width:400px;max-width:90vw;text-align:center;box-shadow:0 20px 60px #0000004d}.confirm-dialog-icon{font-size:36px;margin-bottom:8px;color:#f59e0b}.confirm-dialog-icon-danger{color:#dc2626}.confirm-dialog h3{font-size:16px;font-weight:600;color:#1e293b;margin-bottom:8px}.confirm-dialog p{font-size:14px;color:#475569;margin-bottom:4px}.confirm-dialog-warning{font-size:12px;color:#94a3b8;margin-top:8px}.confirm-dialog-list{text-align:left;margin:8px auto;padding-left:20px;max-height:120px;overflow-y:auto;font-size:13px;color:#334155}.confirm-dialog-list li{margin-bottom:2px}.confirm-dialog-actions{display:flex;justify-content:center;gap:10px;margin-top:16px}.confirm-dialog-actions .btn-secondary{padding:8px 20px;font-size:13px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#475569;cursor:pointer;font-family:inherit}.confirm-dialog-actions .btn-secondary:hover{background:#f1f5f9}.confirm-dialog-actions .btn-primary{padding:8px 20px;font-size:13px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font-family:inherit}.confirm-dialog-actions .btn-primary:hover{background:#0d6b64}.confirm-dialog-actions .btn-danger{padding:8px 20px;font-size:13px;border:1px solid #dc2626;border-radius:6px;background:#dc2626;color:#fff;cursor:pointer;font-family:inherit}.confirm-dialog-actions .btn-danger:hover{background:#b91c1c}.edit-attr-modal{background:#fff;border-radius:12px;width:480px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.edit-attr-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e2e8f0}.edit-attr-modal-header h3{font-size:16px;font-weight:600;color:#1e293b}.edit-attr-modal-body{padding:16px 20px;overflow-y:auto;flex:1}.edit-attr-modal-error{padding:8px 12px;margin-bottom:12px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-size:13px}.edit-attr-field{margin-bottom:12px}.edit-attr-field label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:4px}.edit-attr-field .required{color:#dc2626}.edit-attr-field input[type=text],.edit-attr-field select{width:100%;padding:8px 10px;font-size:13px;border:1px solid #cbd5e1;border-radius:6px;font-family:inherit;color:#1e293b;background:#fff}.edit-attr-field input:focus,.edit-attr-field select:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 2px #0f766e26}.edit-attr-field select:disabled{background:#f1f5f9;color:#94a3b8}.edit-attr-row-3{display:flex;gap:20px;margin-bottom:12px;padding:10px 0}.edit-attr-checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;color:#334155;cursor:pointer}.edit-attr-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#0f766e;cursor:pointer}.edit-attr-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid #e2e8f0}.edit-attr-modal-footer .btn-secondary{padding:8px 20px;font-size:13px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#475569;cursor:pointer;font-family:inherit}.edit-attr-modal-footer .btn-secondary:hover{background:#f1f5f9}.edit-attr-modal-footer .btn-primary{padding:8px 20px;font-size:13px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font-family:inherit}.edit-attr-modal-footer .btn-primary:hover{background:#0d6b64}.attr-selection-bar{display:flex;align-items:center;gap:8px;font-size:13px;color:#0f766e;font-weight:500}.btn-sm{padding:4px 12px;font-size:12px;border:1px solid #cbd5e1;border-radius:4px;background:#fff;cursor:pointer;font-family:inherit;color:#475569}.btn-sm:hover{background:#f1f5f9}.btn-sm.btn-primary{background:#0f766e;color:#fff;border-color:#0f766e}.btn-sm.btn-primary:hover{background:#0d6b64}.btn-sm.btn-primary:disabled{opacity:.5;cursor:not-allowed}.attr-row-new td.col-name-cell,.attr-row-new td.col-type-cell{background:#fff}.move-modal{background:#fff;border-radius:12px;width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.move-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e2e8f0}.move-modal-header h3{font-size:16px;font-weight:600;color:#1e293b}.move-modal-body{padding:16px 20px;overflow-y:auto;flex:1}.move-modal-summary{margin-bottom:16px}.move-modal-summary-label{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.3px}.move-modal-attr-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.move-modal-attr-tag{display:inline-block;padding:2px 10px;font-size:12px;background:#e0f2fe;color:#0369a1;border-radius:12px}.move-modal-tier-selector{margin-bottom:16px}.move-modal-tier-selector>label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:8px}.move-modal-tier-tabs{display:flex;gap:8px}.move-modal-tier-tab{padding:6px 16px;font-size:13px;font-family:inherit;border:2px solid #e2e8f0;border-radius:6px;background:#fff;color:#475569;cursor:pointer;transition:all .15s}.move-modal-tier-tab:hover{border-color:var(--tier-color, #0f766e);color:var(--tier-color, #0f766e)}.move-modal-tier-tab.active{border-color:var(--tier-color, #0f766e);background:var(--tier-color, #0f766e);color:#fff}.move-modal-current-info{margin-bottom:12px;padding:8px 12px;background:#f8fafc;border-radius:6px;font-size:13px}.move-modal-current-info-label{font-weight:600;color:#64748b;margin-right:6px}.move-modal-current-info-value{color:#334155}.move-modal-search{margin-bottom:10px}.move-modal-search>label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:6px}.move-modal-search-input{width:100%;padding:7px 10px;font-size:13px;border:1px solid #cbd5e1;border-radius:6px;font-family:inherit;background:#fff;box-sizing:border-box}.move-modal-search-input:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 1px #0f766e33}.move-modal-search-input::placeholder{color:#94a3b8}.move-modal-error{margin-bottom:10px;padding:8px 12px;font-size:13px;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.move-modal-tree-indent{color:#cbd5e1;margin-right:2px}.move-modal-hint{margin-top:10px;padding:8px 12px;font-size:12px;color:#64748b;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;line-height:1.5}.move-modal-tooltip{background:#333;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;pointer-events:none;z-index:10000;box-shadow:0 2px 8px #0003}.move-modal-group-list{border:1px solid #e2e8f0;border-radius:6px;max-height:240px;overflow-y:auto}.move-modal-group-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background .1s}.move-modal-group-item:last-child{border-bottom:none}.move-modal-group-item:hover{background:#f0fdfa}.move-modal-group-item.selected{background:#ccfbf1;font-weight:600}.move-modal-group-item.current{opacity:.5;cursor:not-allowed}.move-modal-group-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.move-modal-current-badge{font-size:10px;padding:1px 6px;background:#f1f5f9;color:#64748b;border-radius:8px;flex-shrink:0}.move-modal-group-count{font-size:11px;color:#888;flex-shrink:0;cursor:help;transition:text-decoration .15s}.move-modal-group-count:hover{text-decoration:underline dotted #888}.move-modal-loading,.move-modal-empty{padding:20px;text-align:center;color:#94a3b8;font-size:13px}.move-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid #e2e8f0}.move-modal-footer .btn-secondary{padding:8px 16px;font-size:13px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#475569;cursor:pointer;font-family:inherit}.move-modal-footer .btn-secondary:hover{background:#f1f5f9}.move-modal-footer .btn-primary{padding:8px 16px;font-size:13px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font-family:inherit}.move-modal-footer .btn-primary:hover{background:#0d6b64}.move-modal-footer .btn-primary:disabled{opacity:.5;cursor:not-allowed}.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:420px;min-width:280px;max-width:70vw;flex-shrink:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:auto;display:flex;flex-direction:column;resize:horizontal;position:relative}.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-legend{display:flex;flex-wrap:wrap;gap:10px;padding:6px 12px;border-bottom:1px solid #e2e8f0;background:#fafbfc}.workflow-tree-legend-item{display:flex;align-items:center;gap:4px;font-size:11px}.workflow-tree-legend-badge{font-family:monospace;font-size:10px;font-weight:700;padding:1px 4px;border-radius:3px;background:#f1f5f9}.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;min-width:0;overflow:hidden}.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:6px;align-items:center;min-width:0;overflow:hidden}.workflow-tree-code{font-family:monospace;font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px;background:#f1f5f9;flex-shrink:0;cursor:help}.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--dragging{-webkit-user-select:none;user-select:none}.workflow-tree-node[draggable=true]{cursor:grab}.workflow-tree-node[draggable=true]:active{cursor:grabbing}.workflow-tree-drag-handle{font-size:12px;color:#94a3b8;cursor:grab;padding:0 4px;flex-shrink:0}.workflow-tree-drag-handle:hover{color:#475569}.workflow-tree-node--dragging{opacity:.35;background:#f1f5f9!important}.workflow-tree-node--drop-valid{background:#f0fdf4!important;border-color:#22c55e!important;box-shadow:0 0 0 1px #22c55e}.workflow-tree-node--drop-before.workflow-tree-node--drop-valid{border-top:2.5px solid #22c55e!important}.workflow-tree-node--drop-after.workflow-tree-node--drop-valid{border-bottom:2.5px solid #22c55e!important}.workflow-tree-node--drop-invalid{background:#fef2f2!important;border-color:#ef4444!important;box-shadow:0 0 0 1px #ef4444;cursor:not-allowed}.workflow-tree-row-group{border:1px solid #e2e8f0;border-radius:6px;background:#fafbfc;margin:6px 8px 6px 0;padding:4px 0}.workflow-tree-row-group+.workflow-tree-row-group{margin-top:8px}.workflow-tree-row-label{font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;padding:2px 12px 4px;border-bottom:1px solid #e2e8f0;margin-bottom:2px}.reorder-preview-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;padding:24px;min-width:420px;max-width:560px}.reorder-preview-header h3{margin:0 0 4px;font-size:16px;color:#1e293b}.reorder-preview-header p{margin:0 0 16px;font-size:13px;color:#64748b}.reorder-preview-body{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.reorder-preview-col{flex:1;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px}.reorder-preview-col-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;margin-bottom:8px}.reorder-preview-list{margin:0;padding:0;list-style:none;font-size:13px;line-height:1.8;color:#334155}.reorder-preview-list li.reorder-preview-changed{color:#1d4ed8;font-weight:600;background:#eff6ff;margin:0 -8px;padding:0 8px;border-radius:4px}.workflow-tree-save-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fffbeb;border-bottom:1px solid #fcd34d}.workflow-tree-save-bar-text{flex:1;font-size:12px;color:#92400e;font-weight:500}.workflow-tree-save-bar-btn{padding:4px 12px;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer}.workflow-tree-save-bar-cancel{background:#f1f5f9;color:#475569}.workflow-tree-save-bar-cancel:hover{background:#e2e8f0}.workflow-tree-save-bar-save{background:#1d4ed8;color:#fff}.workflow-tree-save-bar-save:hover{background:#1e40af}.reorder-preview-arrow{font-size:24px;color:#94a3b8;padding-top:36px;flex-shrink:0}.reorder-preview-note{font-size:12px;color:#64748b;margin:0 0 16px;padding:8px 12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px}.reorder-preview-actions{display:flex;justify-content:flex-end;gap:8px}.workflow-tree-order-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:10px;background:#e2e8f0;color:#475569;font-size:11px;font-weight:600;flex-shrink:0;margin-right:2px}.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:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;background:#64748b;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}.ss-container{position:relative;width:100%}.ss-trigger{display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left;gap:8px}.ss-trigger-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ss-placeholder{color:#94a3b8}.ss-chevron{font-size:10px;color:#64748b;flex-shrink:0}.ss-disabled .ss-trigger{background:#f1f5f9;color:#64748b;cursor:not-allowed}.ss-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:#fff;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 4px 12px #0000001f;margin-top:2px}.ss-search-wrap{padding:8px;border-bottom:1px solid #e2e8f0}.ss-search{width:100%;padding:6px 10px;font-size:13px;border:1px solid #cbd5e1;border-radius:4px;outline:none;font-family:inherit}.ss-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e26}.ss-list{list-style:none;margin:0;padding:4px 0;max-height:220px;overflow-y:auto}.ss-option{padding:7px 12px;font-size:13px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-option:hover{background:#f0fdfa}.ss-option-active{background:var(--color-primary);color:#fff}.ss-option-active:hover{background:var(--color-primary-dark, #0d6b63)}.ss-option-placeholder{color:#94a3b8}.ss-option-active .ss-option-placeholder{color:#ffffffb3}.ss-no-result{padding:12px;font-size:13px;color:#94a3b8;text-align:center}.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-tier{margin-bottom:12px}.cat-sidebar-tier-header{display:flex;align-items:center;gap:6px;width:100%;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#475569;padding:6px 10px;border:none;border-left:3px solid #0F766E;background:#f1f5f9;margin-bottom:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.cat-sidebar-tier-header:hover{background:#e2e8f0}.cat-sidebar-chevron{display:inline-block;font-size:12px;transition:transform .2s ease;flex-shrink:0}.cat-sidebar-chevron.small{font-size:10px}.cat-sidebar-chevron.collapsed{transform:rotate(-90deg)}.cat-sidebar-group{margin-bottom:2px}.cat-sidebar-root-row{display:flex;align-items:center}.cat-sidebar-root-row .cat-sidebar-root{flex:1}.cat-sidebar-group-preview{display:none;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;cursor:pointer;font-size:12px;opacity:.5;flex-shrink:0;transition:opacity .15s}.cat-sidebar-group-preview:hover{opacity:1}.cat-sidebar-root-row:hover .cat-sidebar-group-preview{display:flex}.cat-sidebar-root{display:flex;align-items:center;gap:6px;width:100%;padding:10px 14px 4px;border:none;background:transparent;-webkit-user-select:none;user-select:none;font:inherit}.cat-sidebar-root:hover{background:#f8fafc}.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;width:100%;padding:0 0 0 28px;border:none;border-left:3px solid transparent;background:transparent;font-family:inherit;font-size:13px;color:#334155;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-node-toggle{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;background:transparent;cursor:pointer;flex-shrink:0;color:#94a3b8}.cat-sidebar-node-toggle:hover{color:#475569}.cat-sidebar-item-btn{display:flex;align-items:center;justify-content:space-between;flex:1;min-width:0;padding:7px 14px 7px 4px;border:none;background:transparent;cursor:pointer;font:inherit;color:inherit;text-align:left}.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-tree-line{color:#cbd5e1;font-size:12px;margin-right:4px;flex-shrink:0}.dd-modal{width:600px!important;max-width:92vw!important;max-height:82vh;display:flex;flex-direction:column;padding:0!important;overflow:hidden}.dd-header{padding:20px 24px 16px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.dd-header-top{display:flex;align-items:center;gap:8px}.dd-title{margin:0;font-size:20px;font-weight:700;color:#0f172a}.dd-title-count{font-size:16px;font-weight:600;color:#94a3b8}.dd-close{margin-left:auto;background:transparent;border:none;font-size:22px;cursor:pointer;color:#94a3b8;padding:2px 8px;line-height:1;border-radius:6px;transition:all .15s}.dd-close:hover{color:#1e293b;background:#f1f5f9}.dd-header-sub{display:flex;align-items:center;gap:12px;margin-top:6px}.dd-header-record{font-size:14px;color:#334155;font-weight:500}.dd-body{flex:1;overflow-y:auto;padding:16px 24px 24px;min-height:0}.dd-status{text-align:center;color:#94a3b8;padding:40px 0;font-size:14px}.dd-root-group{margin-bottom:6px}.dd-root-group:last-child{margin-bottom:0}.dd-group-label{display:flex;align-items:center;gap:8px;padding:6px 10px;font-size:13px}.dd-group-label-name{font-weight:600;color:#475569}.dd-group-label-count{font-size:11px;color:#fff;background:#94a3b8;min-width:20px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;padding:0 6px;font-weight:600}.dd-group-label-root{margin-bottom:2px}.dd-node{position:relative}.dd-record{display:flex;align-items:center;gap:6px;padding:5px 8px;font-size:13px;color:#334155;border-radius:4px;transition:background .12s;margin:1px 0}.dd-expandable{cursor:pointer}.dd-expandable:hover{background:#f1f5f9}.dd-chevron{font-size:10px;color:#64748b;transition:transform .2s;width:14px;text-align:center;flex-shrink:0}.dd-chevron.collapsed{transform:rotate(-90deg)}.dd-leaf{color:#cbd5e1;font-size:11px;width:14px;text-align:center;flex-shrink:0;font-family:monospace}.dd-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dd-child-count{font-size:11px;color:#94a3b8;background:#f1f5f9;padding:1px 7px;border-radius:10px;flex-shrink:0;border:1px solid #e2e8f0}.dd-child-group{margin-top:2px}.cat-sidebar-order{border-top:1px solid #e2e8f0;padding:10px 14px 12px;background:#f8fafc}.cat-sidebar-order-header{display:flex;align-items:center;gap:6px;width:100%;padding:0 0 6px;border:none;background:transparent;cursor:pointer;-webkit-user-select:none;user-select:none}.cat-sidebar-order-title{font-size:11px;font-weight:700;color:#64748b;letter-spacing:.5px}.cat-sidebar-order-item.active{color:var(--color-primary);font-weight:600}.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}.fb-vs-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;font-family:Segoe UI,DM Sans,sans-serif;font-size:13px;user-select:none;-webkit-user-select:none;position:fixed;inset:0;z-index:1000;background:#f5f5f5}.fb-vs-layout input,.fb-vs-layout select,.fb-vs-layout textarea{user-select:text;-webkit-user-select:text}.fb-vs-toolbar{display:flex;align-items:center;gap:6px;padding:3px 8px;background:#f0f0f0;border-bottom:1px solid #ccc;min-height:30px;flex-shrink:0}.fb-vs-title{font-weight:600;font-size:13px;color:#1e293b}.fb-vs-toolbar-right{display:flex;gap:6px;margin-left:auto}.fb-vs-btn{padding:3px 10px;border:1px solid #ccc;background:#fff;border-radius:2px;cursor:pointer;font-size:12px;color:#333;white-space:nowrap}.fb-vs-btn:hover{background:#e5e5e5}.fb-vs-btn-save{background:#0078d4;color:#fff;border-color:#0078d4}.fb-vs-btn-save:hover{background:#006cbd}.fb-vs-body{display:flex;flex:1;overflow:hidden;min-height:0}.fb-vs-statusbar{display:flex;gap:24px;padding:1px 12px;background:#007acc;color:#fff;font-size:11px;min-height:18px;align-items:center;flex-shrink:0}.tb{width:220px;min-width:180px;display:flex;flex-direction:column;background:#f5f5f5;border-right:1px solid #ccc;overflow:hidden;flex-shrink:0}.tb-header{padding:5px 10px;font-weight:600;font-size:12px;color:#333;background:#e8e8e8;border-bottom:1px solid #ccc}.tb-search{padding:4px 6px;border-bottom:1px solid #ddd}.tb-search input{width:100%;padding:3px 6px;border:1px solid #ccc;border-radius:2px;font-size:12px;outline:none;box-sizing:border-box}.tb-search input:focus{border-color:#0078d4}.tb-list{flex:1;overflow-y:auto}.tb-group-header{padding:4px 8px;cursor:pointer;font-size:12px;font-weight:600;background:#e8e8e8;border-bottom:1px solid #ddd;color:#333;display:flex;align-items:center;gap:4px;-webkit-user-select:none;user-select:none}.tb-arrow{font-size:9px;width:12px;text-align:center}.tb-group-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-item{display:flex;align-items:center;gap:4px;padding:3px 8px 3px 10px;cursor:grab;font-size:12px;border-bottom:1px solid #eee}.tb-item:hover{background:#e0e8f0}.tb-item:active{cursor:grabbing}.tb-drag-handle{font-size:10px;color:#aaa;cursor:grab;flex-shrink:0;width:12px;text-align:center;letter-spacing:-1px}.tb-drag-handle:hover{color:#0078d4}.tb-item-placed{color:#666}.tb-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-item-type{font-size:10px;color:#999}.tb-item-toggle{width:18px;height:18px;border:none;background:none;cursor:pointer;font-size:12px;padding:0;display:flex;align-items:center;justify-content:center}.tb-footer{padding:4px 10px;font-size:11px;color:#666;background:#e8e8e8;border-top:1px solid #ccc}.tb-empty{padding:16px;text-align:center;color:#999;font-size:12px}.dc-viewport{flex:1;overflow:auto;background:#2d2d2d;padding:20px;min-height:0;will-change:scroll-position;display:grid;place-items:start center}.dc-viewport.dc-panning{cursor:grab}.dc-viewport.dc-panning:active{cursor:grabbing}.dc-panning .cf,.dc-panning .dc-surface{cursor:grab!important}.dc-surface{position:relative;background:#fff;box-shadow:4px 4px 16px #0006;border:1px solid #999;cursor:crosshair;flex-shrink:0}.dc-rubberband{position:absolute;border:1px dashed #0078d4;background:#0078d414;pointer-events:none;z-index:9999}.dc-resize{position:absolute;z-index:50}.dc-resize-e{top:0;right:-4px;width:6px;height:100%;cursor:ew-resize}.dc-resize-s{bottom:-4px;left:0;width:100%;height:6px;cursor:ns-resize}.dc-resize-se{bottom:-6px;right:-6px;width:16px;height:16px;cursor:nwse-resize;display:flex;align-items:center;justify-content:center}.dc-resize-e:hover,.dc-resize-s:hover{background:#0078d426}.dc-resize-se:hover svg path{stroke:#0078d4}.dc-size-label{margin-top:4px;text-align:center;font-size:11px;color:#94a3b8;font-family:JetBrains Mono,monospace}.cf{box-sizing:border-box;border:1px dotted transparent;cursor:move;overflow:hidden;will-change:left,top;contain:layout style}.cf:hover{border-color:#94a3b8}.cf-selected{border:2px solid #0078d4!important;background:#0078d408}.cf-locked{cursor:not-allowed}.cf-content{display:flex;width:100%;height:100%;overflow:hidden;box-sizing:border-box;pointer-events:none}.cf-label{font-size:12px;color:#334155;padding:2px 0;display:flex;align-items:center;gap:2px;white-space:nowrap;overflow:hidden}.cf-widget{flex:1;border:1px solid #d1d5db;border-radius:2px;padding:2px 4px;font-size:12px;color:#6b7280;background:#fff;overflow:hidden;display:flex;align-items:center;min-height:0}.cf-lock-badge{position:absolute;top:2px;right:2px;font-size:10px;opacity:.6}.cf-handle{position:absolute;width:7px;height:7px;background:#fff;border:1px solid #0078d4;z-index:10;pointer-events:auto}.cf-handle-nw{top:-4px;left:-4px}.cf-handle-n{top:-4px;left:calc(50% - 3px)}.cf-handle-ne{top:-4px;right:-4px}.cf-handle-w{top:calc(50% - 3px);left:-4px}.cf-handle-e{top:calc(50% - 3px);right:-4px}.cf-handle-sw{bottom:-4px;left:-4px}.cf-handle-s{bottom:-4px;left:calc(50% - 3px)}.cf-handle-se{bottom:-4px;right:-4px}.pw{width:280px;min-width:240px;display:flex;flex-direction:column;background:#fff;border-left:1px solid #ccc;flex-shrink:0;overflow:hidden;height:0;flex:1}.pw-toolbar{display:flex;gap:2px;padding:3px 6px;background:#f0f0f0;border-bottom:1px solid #ccc;flex-shrink:0}.pw-tb-btn{padding:2px 6px;border:1px solid transparent;background:none;cursor:pointer;border-radius:2px;font-size:12px;color:#555}.pw-tb-btn:hover{background:#e0e0e0}.pw-tb-btn.active{border-color:#0078d4;background:#d0e8ff}.pw-obj-selector{padding:3px 6px;border-bottom:1px solid #ccc;flex-shrink:0}.pw-obj-select{width:100%;padding:2px 4px;border:1px solid #ccc;border-radius:2px;font-size:12px;background:#fff;outline:none}.pw-obj-select:focus{border-color:#0078d4}.pw-grid{flex:1;overflow-y:auto;height:0}.pw-cat-header{display:flex;align-items:center;gap:4px;padding:3px 6px;font-weight:600;font-size:12px;color:#333;cursor:pointer;background:#f0f0f0;border-bottom:1px solid #ddd;-webkit-user-select:none;user-select:none}.pw-cat-arrow{font-size:9px;width:12px;text-align:center}.pw-cat-name{flex:1}.pw-row{display:flex;border-bottom:1px solid #f0f0f0;min-height:22px}.pw-row:hover{background:#e8f0fe}.pw-row-sub .pw-row-name{padding-left:20px}.pw-row-name{width:110px;min-width:110px;padding:2px 6px;font-size:12px;color:#555;display:flex;align-items:center;border-right:1px solid #f0f0f0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pw-row-value{flex:1;padding:1px 4px;display:flex;align-items:center;min-width:0}.pw-val-input{width:100%;border:none;outline:none;font-size:12px;padding:1px 2px;background:transparent}.pw-val-input:focus{background:#fff;box-shadow:inset 0 0 0 1px #0078d4}.pw-val-select{width:100%;border:none;outline:none;font-size:12px;padding:0;background:transparent;cursor:pointer}.pw-val-readonly{font-size:12px;color:#999}.pw-val-composite{font-family:JetBrains Mono,monospace;font-size:11px}.pw-val-color{display:flex;align-items:center;width:100%}.pw-desc{padding:6px 8px;border-top:1px solid #ccc;background:#f9f9f9;min-height:44px;max-height:60px;flex-shrink:0}.pw-desc-title{font-weight:600;font-size:11px;color:#333}.pw-desc-text{font-size:11px;color:#666;line-height:1.3}.at{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:2px 8px;background:#f0f0f0;border-bottom:1px solid #ccc;min-height:26px;flex-shrink:0}.at-group{display:flex;align-items:center;gap:2px;padding-right:8px;border-right:1px solid #ddd;margin-right:4px}.at-group:last-child{border-right:none;margin-right:0;padding-right:0}.at-label{font-size:11px;color:#666;margin-right:2px;white-space:nowrap}.at-btn{width:26px;height:24px;border:1px solid transparent;background:none;cursor:pointer;border-radius:2px;font-size:14px;color:#444;display:flex;align-items:center;justify-content:center;padding:0}.at-btn:hover:not(:disabled){background:#d0e8ff;border-color:#0078d4}.at-btn:active:not(:disabled){background:#b0d4f1}.at-btn:disabled{color:#bbb;cursor:default}.at-sep{width:1px;height:16px;background:#ccc;margin:0 2px}.sg-line{position:absolute;z-index:9998;pointer-events:none}.sg-line-v{width:1px;top:0;bottom:0;background:#0078d4;border-left:1px dashed #0078d4}.sg-line-h{height:1px;left:0;right:0;background:#0078d4;border-top:1px dashed #0078d4}.cm{position:fixed;z-index:10000;background:#fff;border:1px solid #ccc;border-radius:3px;box-shadow:2px 4px 12px #0000002e;min-width:180px;padding:4px 0;font-size:12px}.cm-item{padding:5px 24px;cursor:pointer;color:#1e293b;display:flex;align-items:center}.cm-item:hover{background:#0078d4;color:#fff}.cm-item-disabled{color:#aaa;cursor:default}.cm-item-disabled:hover{background:none;color:#aaa}.cm-sep{height:1px;background:#e5e5e5;margin:4px 0}.ruler{position:relative;background:#f0f0f0;overflow:hidden}.ruler-h{height:20px;border-bottom:1px solid #ccc}.ruler-v{width:20px;border-right:1px solid #ccc}.ruler-tick{position:absolute}.ruler-h .ruler-tick{border-left:1px solid #aaa;height:8px;bottom:0}.ruler-v .ruler-tick{border-top:1px solid #aaa;width:8px;right:0}.ruler-label{font-size:9px;color:#666;position:absolute}.ruler-h .ruler-label{left:3px;top:1px}.ruler-v .ruler-label{top:3px;left:1px}.fb-vs-zoom{display:flex;align-items:center;gap:4px;margin-left:auto}.fb-vs-zoom-btn{width:22px;height:22px;border:1px solid rgba(255,255,255,.3);background:#ffffff1a;cursor:pointer;border-radius:2px;font-size:12px;color:#fff;display:flex;align-items:center;justify-content:center;padding:0}.fb-vs-zoom-btn:hover{background:#ffffff40}.fb-vs-zoom-label{font-size:11px;color:#fff;min-width:36px;text-align:center;cursor:pointer}.pm-surface{position:relative;background:#fff;box-shadow:2px 2px 12px #00000026;border:1px solid #d1d5db;border-radius:4px}.pm-field{box-sizing:border-box}.pm-label{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-help{font-size:11px;color:#94a3b8;margin-top:2px}.mm{position:absolute;bottom:8px;right:8px;z-index:100;background:#1e293b;border:1px solid #475569;border-radius:3px;opacity:.85;overflow:hidden;transition:opacity .15s}.mm:hover{opacity:1}.mm-field{position:absolute;background:#94a3b8;border-radius:1px;opacity:.7}.mm-field-sel{background:#0078d4;opacity:1}.lp{display:flex;flex-direction:column;overflow:hidden;border-top:1px solid #ccc;max-height:200px}.lp-header{padding:4px 8px;font-weight:600;font-size:11px;color:#333;background:#e8e8e8;border-bottom:1px solid #ccc}.lp-list{flex:1;overflow-y:auto}.lp-item{display:flex;align-items:center;gap:4px;padding:2px 6px;font-size:11px;cursor:pointer;border-bottom:1px solid #f5f5f5}.lp-item:hover{background:#f0f0f0}.lp-item-sel{background:#d0e8ff!important}.lp-z{width:18px;font-size:10px;color:#999;text-align:center;font-family:JetBrains Mono,monospace}.lp-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1e293b}.lp-actions{display:flex;gap:1px}.lp-btn{width:20px;height:18px;border:none;background:none;cursor:pointer;font-size:10px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:2px}.lp-btn:hover{background:#e0e0e0}.lp-empty{padding:8px;text-align:center;color:#999;font-size:11px}.fb-vs-mode-toggle{display:flex;border:1px solid #ccc;border-radius:3px;overflow:hidden}.fb-vs-mode-btn{padding:2px 10px;border:none;cursor:pointer;font-size:11px;background:#fff;color:#555}.fb-vs-mode-btn:hover{background:#f0f0f0}.fb-vs-mode-btn.active{background:#0078d4;color:#fff}.fb-vs-layout-dropdown{position:relative;display:inline-flex}.fb-vs-layout-menu{position:absolute;top:100%;left:0;z-index:100;background:#fff;border:1px solid #ccc;border-radius:3px;box-shadow:2px 4px 8px #0000001f;min-width:160px;padding:4px 0}.fb-vs-layout-item{padding:5px 12px;cursor:pointer;font-size:12px;color:#333}.fb-vs-layout-item:hover{background:#0078d4;color:#fff}.fb-vs-layout-item-active{font-weight:600;color:#0078d4}.fb-vs-layout-item-active:before{content:"✓ "}.fb-vs-preset-menu{position:absolute;top:100%;right:0;z-index:100;background:#fff;border:1px solid #ccc;border-radius:3px;box-shadow:2px 4px 8px #0000001f;min-width:180px;padding:4px 0;max-height:300px;overflow-y:auto}.fb-vs-preset-item{padding:5px 12px;cursor:pointer;font-size:12px;color:#333;display:flex;justify-content:space-between;align-items:center}.fb-vs-preset-item:hover{background:#0078d4;color:#fff}.fb-vs-preset-del{font-size:10px;opacity:.6;cursor:pointer}.fb-vs-preset-del:hover{opacity:1}.fp{display:flex;align-items:center;gap:0;background:#e8e8e8;border-bottom:1px solid #ccc;min-height:26px;flex-shrink:0;padding:0 4px}.fp-tab{padding:3px 12px;cursor:pointer;font-size:12px;border:1px solid transparent;border-bottom:none;border-radius:3px 3px 0 0;color:#555;background:transparent;position:relative;top:1px}.fp-tab:hover{background:#f0f0f0}.fp-tab.active{background:#fff;border-color:#ccc;color:#1e293b;font-weight:600}.fp-add{padding:2px 8px;cursor:pointer;font-size:14px;border:none;background:none;color:#666;margin-left:4px}.fp-add:hover{color:#0078d4}@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}.start{inset-inline-start:var(--spacing)}.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}.align-bottom{vertical-align:bottom}.align-top{vertical-align:top}.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-teal-700:hover{color:var(--color-teal-700)!important}.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}
