:root{color:#212121;-webkit-font-smoothing:antialiased;background:#f3f4f6;font-family:DM Sans,system-ui,sans-serif;font-size:14px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;margin:0}#root{flex-direction:column;min-height:100vh;display:flex}.vp-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000014;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.vp{background:#fffffff7;border:1px solid #e5e7eb99;border-radius:16px;flex-direction:column;width:500px;max-height:380px;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #6d28d91a,0 8px 24px -8px #00000014}.vp-search{background:#f9fafb80;border-bottom:1px solid #e5e7eb;padding:12px;position:relative}.vp-search-icon{color:#999;position:absolute;top:50%;left:24px;transform:translateY(-50%)}.vp-search-input{color:#212121;background:#fff;border:.5px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:8px 12px 8px 34px;font-family:inherit;font-size:13px}.vp-search-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 .5px #8b5cf64d}.vp-search-input::placeholder{color:#999}.vp-columns{flex:1;min-height:0;display:flex;overflow:hidden}.vp-categories{border-right:1px solid #e5e7eb;width:160px;min-width:160px;padding:4px 0;overflow-y:auto}.vp-cat{color:#737373;cursor:pointer;text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:8px;width:100%;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:flex}.vp-cat:hover{color:#212121;background:#fafafa}.vp-cat.active{color:#6d28d9;background:#f3e8ff;border-left-color:#6d28d9}.vp-cat-count{color:#999;margin-left:auto;font-size:11px;font-weight:400}.vp-cat.active .vp-cat-count{color:#a78bfa}.vp-fields{flex:1;padding:4px 0;overflow-y:auto}.vp-fields::-webkit-scrollbar{width:4px}.vp-fields::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:999px}.vp-field{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:8px 14px;font-family:inherit;transition:all .15s;display:flex}.vp-field:hover{background:#f3e8ff66}.vp-field-info{flex-direction:column;gap:1px;display:flex}.vp-field-label{color:#212121;font-size:13px;font-weight:500}.vp-field-id{color:#999;font-family:JetBrains Mono,monospace;font-size:11px}.vp-field-type{white-space:nowrap;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:500}.vp-field-type.type-string{color:#6d28d9;background:#f3e8ff}.vp-field-type.type-date{color:#b45309;background:#fef3c7}.vp-field-type.type-number{color:#2563eb;background:#dbeafe}.vp-field-type.type-array{color:#059669;background:#d1fae5}.chip-editor-wrapper{border:1px solid #e5e7eb;border-radius:16px;transition:all .2s ease-out;overflow:hidden}.chip-editor-wrapper:focus-within{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf633}.chip-editor-wrapper:hover:not(:focus-within){border-color:#8b5cf64d;box-shadow:0 1px 3px #0000000a}.chip-editor-wrapper.singleline{border-radius:16px}.chip-editor-toolbar{background:#f9fafb99;border-bottom:1px solid #e5e7eb99;gap:2px;padding:6px 8px;display:flex}.picker-btn{color:#737373;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:5px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.picker-btn:hover{color:#6d28d9;background:#f3e8ff}.chip-editor{color:#212121;cursor:text;white-space:pre-wrap;word-break:break-word;background:#fff;outline:none;padding:10px 14px;font-size:13px;line-height:1.8}.chip-editor.multiline{min-height:120px;max-height:300px;overflow-y:auto}.chip-editor.singleline{white-space:nowrap;min-height:0;max-height:40px;line-height:2;overflow:auto hidden}.chip-editor:empty:before{content:attr(data-placeholder);color:#999;pointer-events:none}.chip-editor::-webkit-scrollbar{width:6px;height:4px}.chip-editor::-webkit-scrollbar-track{background:0 0}.chip-editor::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:999px}.var-chip{color:#6d28d9;cursor:default;-webkit-user-select:none;user-select:none;vertical-align:baseline;white-space:nowrap;background:#f3e8ff;border:1px solid #e9d5ff;border-radius:4px;padding:1px 7px;font-size:12px;font-weight:600;line-height:1.6;transition:all .12s;display:inline}.var-chip:hover{background:#ede9fe;border-color:#c084fc;box-shadow:0 1px 3px #6d28d91f}.node-panel{background:#fff;border:1px solid #e5e7eb;border-radius:16px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #6d28d914,0 8px 24px -8px #0000000f}.node-panel-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;min-height:50px;padding:0 16px;display:flex}.node-panel-header-left{align-items:center;gap:10px;display:flex}.node-panel-icon{border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.node-panel-title{flex-direction:column;gap:1px;display:flex}.node-panel-title-text{color:#212121;font-size:13px;font-weight:600}.node-panel-title-sub{color:#999;font-size:11px}.node-panel-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:all .15s;display:flex}.node-panel-close:hover{color:#666;background:#f3f4f6}.node-panel-body{flex-direction:column;gap:16px;padding:16px;display:flex}.node-field{flex-direction:column;gap:6px;display:flex}.node-field-label{color:#737373;font-size:12px;font-weight:500}.node-field-readonly{color:#737373;background:#fafafa;border:1px solid #e5e7eb;border-radius:16px;align-items:center;height:40px;padding:0 14px;font-size:13px;display:flex}.node-field-chip-static{color:#6d28d9;background:#f3e8ff;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.node-panel-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;align-items:center;gap:8px;min-height:50px;padding:0 16px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#6d28d9;border:none;border-radius:999px;padding:6px 16px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.btn-primary:hover{background:#7c3aed}.btn-secondary{color:#666;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:6px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.btn-secondary:hover{background:#f9fafb}.app{min-height:100vh;position:relative}.app-bg{z-index:0;background:#f3f4f6;position:fixed;inset:0}.app-content{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex}.app-header-left,.app-logo{align-items:center;gap:8px;display:flex}.app-logo-text{color:#212121;font-family:Outfit,sans-serif;font-size:15px;font-weight:600}.app-header-sep{color:#d1d5db;font-size:16px}.app-header-crumb{color:#737373;font-size:13px;font-weight:500}.app-header-badge{color:#6d28d9;background:#f3e8ff;border-radius:999px;padding:2px 10px;font-size:11px;font-weight:600}.main-area{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:24px}.tab-bar{align-items:center;gap:6px;margin-bottom:20px;display:flex}.tab-bar-label{color:#999;margin-right:4px;font-size:12px;font-weight:500}.tab-btn{color:#666;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.tab-btn:hover{color:#6d28d9;border-color:#c084fc}.tab-btn.active{color:#fff;background:#6d28d9;border-color:#6d28d9}.tab-btn.active .tab-icon{filter:grayscale()brightness(10)}.tab-icon{font-size:14px}.comparison{align-items:flex-start;gap:20px;display:flex}.comparison-col{flex:1;min-width:0}.comparison-arrow{color:#d1d5db;flex-shrink:0;padding-top:36px;font-size:24px}.comparison-label{color:#737373;align-items:center;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.comparison-dot{border-radius:999px;width:8px;height:8px}.comparison-dot.before{background:#ef4444}.comparison-dot.after{background:#22c55e}.raw-preview{background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden}.raw-field{border-bottom:1px solid #f3f4f6;padding:12px 16px}.raw-field:last-child{border-bottom:none}.raw-field-label{color:#999;margin-bottom:4px;font-size:11px;font-weight:500}.raw-field-value{color:#212121;white-space:pre-wrap;word-break:break-word;background:#fafafa;border:1px solid #f3f4f6;border-radius:8px;padding:8px 10px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.6}.raw-field-value.single-line{white-space:nowrap;overflow-x:auto}
