.react-flow{--xy-edge-stroke-default:#b1b1b7;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#555;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#e2e2e2;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:transparent;--xy-background-pattern-dots-color-default:#91919a;--xy-background-pattern-lines-color-default:#eee;--xy-background-pattern-cross-color-default:#e2e2e2;background-color:var(--xy-background-color,var(--xy-background-color-default));--xy-node-color-default:inherit;--xy-node-border-default:1px solid #1a192b;--xy-node-background-color-default:#fff;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--xy-node-boxshadow-selected-default:0 0 0 .5px #1a192b;--xy-node-border-radius-default:3px;--xy-handle-background-color-default:#1a192b;--xy-handle-border-color-default:#fff;--xy-selection-background-color-default:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--xy-controls-button-background-color-default:#fefefe;--xy-controls-button-background-color-hover-default:#f4f4f4;--xy-controls-button-color-default:inherit;--xy-controls-button-color-hover-default:inherit;--xy-controls-button-border-color-default:#eee;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.react-flow.dark{--xy-edge-stroke-default:#3e3e3e;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#727272;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#2b2b2b;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:#141414;--xy-background-pattern-dots-color-default:#777;--xy-background-pattern-lines-color-default:#777;--xy-background-pattern-cross-color-default:#777;--xy-node-color-default:#f8f8f8;--xy-node-border-default:1px solid #3c3c3c;--xy-node-background-color-default:#1e1e1e;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--xy-node-boxshadow-selected-default:0 0 0 .5px #999;--xy-handle-background-color-default:#bebebe;--xy-handle-border-color-default:#1e1e1e;--xy-selection-background-color-default:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--xy-controls-button-background-color-default:#2b2b2b;--xy-controls-button-background-color-hover-default:#3e3e3e;--xy-controls-button-color-default:#f8f8f8;--xy-controls-button-color-hover-default:#fff;--xy-controls-button-border-color-default:#5b5b5b;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#141414;--xy-edge-label-color-default:#f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props,var(--xy-background-color,var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected,var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default;position:absolute}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background-color:var(--xy-handle-background-color,var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color,var(--xy-handle-border-color-default));border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px)translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px)translateY(-50%)}.react-flow__attribution{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__minimap{background:var(--xy-minimap-background-color-props,var(--xy-minimap-background-color,var(--xy-minimap-background-color-default)))}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var(--xy-minimap-mask-background-color-props,var(--xy-minimap-mask-background-color,var(--xy-minimap-mask-background-color-default)));stroke:var(--xy-minimap-mask-stroke-color-props,var(--xy-minimap-mask-stroke-color,var(--xy-minimap-mask-stroke-color-default)));stroke-width:var(--xy-minimap-mask-stroke-width-props,var(--xy-minimap-mask-stroke-width,var(--xy-minimap-mask-stroke-width-default)))}.react-flow__minimap-node{fill:var(--xy-minimap-node-background-color-props,var(--xy-minimap-node-background-color,var(--xy-minimap-node-background-color-default)));stroke:var(--xy-minimap-node-stroke-color-props,var(--xy-minimap-node-stroke-color,var(--xy-minimap-node-stroke-color-default)));stroke-width:var(--xy-minimap-node-stroke-width-props,var(--xy-minimap-node-stroke-width,var(--xy-minimap-node-stroke-width-default)))}.react-flow__background-pattern.dots{fill:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-dots-color-default)))}.react-flow__background-pattern.lines{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-lines-color-default)))}.react-flow__background-pattern.cross{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-cross-color-default)))}.react-flow__controls{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;color:var(--xy-node-color,var(--xy-node-color-default));text-align:center;border:var(--xy-node-border,var(--xy-node-border-default));background-color:var(--xy-node-background-color,var(--xy-node-background-color-default));padding:10px;font-size:12px}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected,var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color,var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color,var(--xy-selection-background-color-default));border:var(--xy-selection-border,var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var(--xy-controls-button-background-color-hover-props,var(--xy-controls-button-background-color-hover,var(--xy-controls-button-background-color-hover-default)));color:var(--xy-controls-button-color-hover-props,var(--xy-controls-button-color-hover,var(--xy-controls-button-color-hover-default)))}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)))}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;translate:-50% -50%}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border-style:solid;border-width:0}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color,var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color,var(--xy-edge-label-color-default))}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#222533;--border:#2a2d3a;--text:#e4e4e7;--text-muted:#8b8d98;--primary:#6366f1;--primary-hover:#818cf8;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--radius:8px;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}[data-theme=light]{--bg:#f4f6fb;--surface:#fff;--surface-hover:#eef0f8;--border:#dde1ef;--text:#111827;--text-muted:#6b7280;--primary:#6366f1;--primary-hover:#4f46e5;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#2563eb}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}.app{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:4px;width:240px;padding:24px 16px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{align-items:center;gap:8px;margin-bottom:24px;padding:0 8px;display:flex}.sidebar-logo{width:28px;height:28px}.sidebar h1{color:var(--text);font-size:16px;font-weight:700}.server-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .3s}.server-dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.server-dot.offline{background:var(--danger);box-shadow:0 0 6px var(--danger)}.sidebar a{border-radius:var(--radius);color:var(--text-muted);align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.sidebar a:hover,.sidebar a.active{background:var(--surface-hover);color:var(--text)}.sidebar-bottom{border-top:1px solid var(--border);margin-top:auto;padding-top:16px}.theme-toggle{border-radius:var(--radius);width:100%;color:var(--text-muted);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font);background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.theme-toggle:hover{background:var(--surface-hover);color:var(--text)}.theme-toggle-icon{font-size:16px;line-height:1}.main{flex:1;margin-left:240px;padding:32px}.page-header{margin-bottom:24px}.page-header h2{font-size:22px;font-weight:600}.page-header p{color:var(--text-muted);margin-top:4px;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.stat-card .value{margin-top:4px;font-size:28px;font-weight:700}.table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface);padding:12px 16px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border);padding:12px 16px;font-size:14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-hover)}.badge-success{color:var(--success);background:#22c55e26}.badge-warning{color:var(--warning);background:#f59e0b26}.badge-danger{color:var(--danger);background:#ef444426}.badge-info{color:var(--info);background:#3b82f626}.btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{background:var(--surface-hover)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.audio-player{margin-top:16px}.audio-player audio{border-radius:var(--radius);width:100%}.transcript{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);white-space:pre-wrap;max-height:500px;margin-top:16px;padding:16px;font-size:14px;line-height:1.8;overflow-y:auto}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:24px}.detail-row{gap:16px;margin-bottom:12px;display:flex}.detail-row .label{width:140px;color:var(--text-muted);flex-shrink:0;font-size:14px}.detail-row .value{font-size:14px}.loading,.empty{text-align:center;color:var(--text-muted);padding:48px;font-size:14px}.drawer-overlay{z-index:100;background:#0000008c;position:fixed;inset:0}.drawer{background:var(--surface);border-left:1px solid var(--border);z-index:101;flex-direction:column;width:480px;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden}.drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.drawer-header h3{font-size:16px;font-weight:600}.drawer-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;padding:4px 8px;font-size:18px}.drawer-close:hover{background:var(--surface-hover);color:var(--text)}.drawer-body{flex-direction:column;flex:1;gap:0;padding:20px 24px;display:flex;overflow-y:auto}.drawer-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:10px;margin-top:8px;padding:16px 24px;display:flex}.af-page{flex-direction:column;min-height:100%;display:flex}.af-topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:14px 24px;display:flex;position:sticky;top:0}.af-topbar-left{align-items:center;gap:12px;display:flex}.af-topbar-right{align-items:center;gap:8px;display:flex}.af-back{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.af-back:hover{background:var(--surface-hover);color:var(--text)}.af-title{margin:0;font-size:16px;font-weight:600}.af-subtitle{color:var(--text-muted);margin:2px 0 0;font-size:12px}.af-content{flex:1;padding:24px}.af-grid{grid-template-columns:1fr 1fr;gap:20px;max-width:1200px;display:grid}.af-col{flex-direction:column;gap:16px;display:flex}.af-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.af-card-head{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:12px 16px;transition:background .15s;display:flex}.af-card-head:hover{background:var(--surface-hover)}.af-card-title{color:var(--text);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.af-card-title svg{color:var(--primary)}.af-chevron{color:var(--text-muted);transition:transform .2s}.af-chevron--closed{transform:rotate(-90deg)}.af-card-body{padding:4px 16px 16px}.af-field{margin-bottom:12px}.af-field:last-child{margin-bottom:0}.af-label{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:5px;font-size:12px;font-weight:500;display:flex}.af-hint{color:var(--text-muted);font-size:11px;font-weight:400}.af-desc{color:var(--text-muted);margin:0 0 12px;font-size:12px;line-height:1.5}.af-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.af-input{width:100%;color:var(--text);font-size:13px;font-family:var(--font);background:var(--bg);border:1px solid var(--border);box-sizing:border-box;border-radius:8px;outline:none;padding:8px 12px;transition:border-color .15s}.af-input:focus{border-color:var(--primary)}.af-input:disabled{opacity:.5;cursor:not-allowed}select.af-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238b8d98'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.af-textarea{resize:vertical;min-height:80px}.af-switch{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:flex}.af-switch-track{background:var(--border);border-radius:10px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.af-switch-track--on{background:var(--primary)}.af-switch-thumb{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.af-switch-track--on .af-switch-thumb{transform:translate(16px)}.af-switch-label{color:var(--text);font-size:13px;font-weight:500}.af-slider-row{align-items:center;gap:10px;display:flex}.af-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;flex:1;height:4px}.af-slider::-webkit-slider-thumb{appearance:none;background:var(--primary);cursor:pointer;width:16px;height:16px;box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent);border-radius:50%}.af-slider::-moz-range-thumb{background:var(--primary);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.af-slider-val{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;min-width:32px;font-size:12px;font-weight:600}.af-checklist{flex-direction:column;gap:4px;display:flex}.af-check-row{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:all .15s;display:flex}.af-check-row:hover{background:color-mix(in srgb, var(--surface-hover) 50%, transparent)}.af-check-row--on{background:color-mix(in srgb, var(--primary) 6%, transparent);border-color:color-mix(in srgb, var(--primary) 20%, transparent)}.af-check-box{border:2px solid var(--border);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:all .15s;display:flex}.af-check-box--on{background:var(--primary);border-color:var(--primary)}.af-check-info{flex:1;min-width:0}.af-check-name{color:var(--text);font-size:13px;font-weight:500}.af-var-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.af-var-row .af-input{flex:1}.af-var-type{flex:0 0 90px!important;max-width:90px!important}.af-var-req{color:var(--text-muted);white-space:nowrap;cursor:pointer;align-items:center;gap:4px;font-size:11px;display:flex}.af-var-req input{accent-color:var(--primary)}.af-icon-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.af-icon-btn:hover{background:var(--surface-hover)}.af-icon-btn--danger:hover{background:color-mix(in srgb, var(--danger) 12%, transparent);color:var(--danger)}.af-add-btn{width:100%;color:var(--primary);background:color-mix(in srgb, var(--primary) 6%, transparent);border:1px dashed color-mix(in srgb, var(--primary) 30%, transparent);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.af-add-btn:hover{background:color-mix(in srgb, var(--primary) 12%, transparent);border-color:var(--primary)}.af-modal{z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:440px;max-height:80vh;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 60px #00000080}.af-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.af-modal-header h3{margin:0;font-size:15px;font-weight:600}.af-modal-body{flex:1;padding:20px;overflow-y:auto}.af-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:14px 20px;display:flex}.form-section{margin-bottom:28px}.form-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--primary);border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:8px;font-size:11px;font-weight:700}.form-field{margin-bottom:14px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-label{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:5px;font-size:13px;font-weight:500;display:flex}.form-hint{color:var(--text-muted);font-size:11px;font-weight:400}.form-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-size:13px;font-family:var(--font);outline:none;padding:8px 10px;transition:border-color .15s}.form-input:focus{border-color:var(--primary)}.form-textarea{resize:vertical;min-height:120px}.form-textarea-lg{min-height:220px}select.form-input{cursor:pointer}.form-error{color:var(--danger);border-radius:var(--radius);background:#ef44441a;border:1px solid #ef44444d;margin-bottom:12px;padding:10px 12px;font-size:13px}.confirm-dialog{z-index:101;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:380px;padding:28px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 60px #00000080}.confirm-dialog h3{margin-bottom:10px;font-size:17px}.confirm-dialog p{color:var(--text-muted);margin-bottom:20px;font-size:14px;line-height:1.6}.confirm-actions{justify-content:flex-end;gap:10px;display:flex}.btn-sm{padding:4px 12px;font-size:12px}.btn-danger-ghost{color:var(--danger);background:0 0;border-color:#ef44444d}.btn-danger-ghost:hover{background:#ef44441a}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.provider-badge{color:var(--primary);background:#6366f126;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600;display:inline-block}.model-label{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.builder-page{max-width:860px}.builder-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;padding:24px}.builder-input-row{grid-template-columns:1fr 200px;align-items:flex-start;gap:16px;display:grid}.builder-desc{min-height:110px}.builder-actions{justify-content:flex-end;margin-top:16px;display:flex}.builder-generate-btn{min-width:160px}.spinner{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:12px;height:12px;margin-right:6px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.builder-result-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.builder-result-title{font-size:15px;font-weight:600}.builder-result-sub{color:var(--text-muted);margin-top:2px;font-size:13px}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px 16px;margin-bottom:20px;display:grid}.preview-row{flex-direction:column;gap:2px;display:flex}.preview-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-size:11px;font-weight:700}.preview-value{color:var(--text);font-size:13px}.preview-section{margin-bottom:16px}.preview-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--primary);border-bottom:1px solid var(--border);margin-bottom:6px;padding-bottom:4px;font-size:11px;font-weight:700}.preview-text{color:var(--text);white-space:pre-wrap;font-size:13px;line-height:1.6}.preview-text-scroll{background:var(--bg);border:1px solid var(--border);border-radius:4px;max-height:140px;padding:10px 12px;overflow-y:auto}.preview-nodes{flex-wrap:wrap;gap:8px;display:flex}.preview-node{background:var(--bg);border:1px solid var(--border);border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:flex}.preview-node-key{color:var(--text);font-weight:600}.node-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--primary);color:#fff;border-radius:3px;padding:1px 5px;font-size:10px;font-weight:700}.node-badge-end{background:var(--text-muted)}.preview-node-fns{color:var(--text-muted);font-size:11px}.agent-form-page{max-width:100%}.agent-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.form-grid{grid-template-columns:1.4fr 1fr;gap:40px;display:grid}.form-col{flex-direction:column;display:flex}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:8px;padding-top:20px;display:flex}.slider-row{align-items:center;gap:10px;display:flex}.form-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;flex:1;height:4px}.form-slider::-webkit-slider-thumb{appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:14px;height:14px}.form-slider::-moz-range-thumb{background:var(--primary);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.slider-value{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;min-width:32px;font-size:12px;font-weight:600}.toggle-label{cursor:pointer;align-items:center;gap:8px;display:flex}.form-checkbox{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.toggle-text{color:var(--text-muted);font-size:13px}.flow-editor-page{flex-direction:column;height:calc(100vh - 32px);display:flex}.flow-toolbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.flow-toolbar h2{margin:0;font-size:16px}.flow-toolbar-left,.flow-toolbar-right{align-items:center;gap:8px;display:flex}.flow-editor-container{flex:1;display:flex;overflow:hidden}.flow-canvas{background:var(--bg);flex:1}.flow-canvas .react-flow__node{cursor:pointer}.flow-edge-label{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);pointer-events:none;white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:500}.flow-canvas .react-flow__controls button{background:var(--surface);color:var(--text);border-color:var(--border);fill:var(--text)}.flow-canvas .react-flow__controls button:hover{background:var(--surface-hover)}.flow-canvas .react-flow__minimap{border:1px solid var(--border);border-radius:var(--radius)}.flow-rf-node{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);min-width:180px;max-width:260px;padding:10px 14px;font-size:13px}.flow-rf-node.selected{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb, var(--primary) 30%, transparent)}.flow-rf-node.initial{border-color:var(--success)}.flow-rf-node.terminal{border-color:var(--danger)}.flow-rf-node-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.flow-rf-node-badge{letter-spacing:.5px;background:color-mix(in srgb, var(--primary) 20%, transparent);color:var(--primary);border-radius:3px;padding:1px 6px;font-size:9px;font-weight:700}.flow-rf-node.initial .flow-rf-node-badge{background:color-mix(in srgb, var(--success) 20%, transparent);color:var(--success)}.flow-rf-node.terminal .flow-rf-node-badge{background:color-mix(in srgb, var(--danger) 20%, transparent);color:var(--danger)}.flow-rf-node-name{text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.flow-rf-node-body{flex-direction:column;gap:4px;display:flex}.flow-rf-node-preview{color:var(--text-muted);font-size:11px;line-height:1.4}.flow-rf-node-funcs{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.flow-rf-func-tag{background:color-mix(in srgb, var(--info) 15%, transparent);color:var(--info);border-radius:3px;padding:1px 6px;font-size:10px}.flow-rf-func-tag.tool-tag{background:color-mix(in srgb, var(--warning) 15%, transparent);color:var(--warning)}.np{background:var(--bg);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:420px;display:flex;overflow-y:auto}.np-header{border-bottom:1px solid var(--border);background:var(--surface);padding:16px 20px 12px}.np-header-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.np-header-top h3{text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:16px;font-weight:600;overflow:hidden}.np-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:20px;transition:all .15s;display:flex}.np-close:hover{background:var(--surface-hover);color:var(--text)}.np-flags{gap:8px;display:flex}.np-flag{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.np-flag input{display:none}.np-flag:hover{border-color:var(--text-muted)}.np-flag--active.np-flag--green{border-color:var(--success);background:color-mix(in srgb, var(--success) 12%, transparent);color:var(--success)}.np-flag--active.np-flag--red{border-color:var(--danger);background:color-mix(in srgb, var(--danger) 12%, transparent);color:var(--danger)}.np-body{flex-direction:column;padding:8px 0;display:flex}.np-section{border-bottom:1px solid color-mix(in srgb, var(--border) 50%, transparent);padding:12px 20px}.np-section:last-child{border-bottom:none}.np-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:700}.np-hint{color:var(--text-muted);margin:0 0 10px;font-size:12px;line-height:1.4}.np-hint code{background:color-mix(in srgb, var(--primary) 12%, transparent);color:var(--primary);border-radius:3px;padding:1px 5px;font-size:11px}.np-hint-inline{color:var(--text-muted);font-size:11px;font-weight:400}.np-field{margin-bottom:10px}.np-field:last-child{margin-bottom:0}.np-label{color:var(--text-muted);margin-bottom:4px;font-size:12px;font-weight:500;display:block}.np-input{width:100%;color:var(--text);background:var(--surface);border:1px solid var(--border);box-sizing:border-box;border-radius:6px;outline:none;padding:8px 10px;font-size:13px;transition:border-color .15s}.np-input:focus{border-color:var(--primary)}select.np-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238b8d98'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}textarea.np-input{resize:vertical;min-height:120px}.np-mono{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px}.fn-list{flex-direction:column;gap:6px;display:flex}.fn-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;transition:border-color .15s;overflow:hidden}.fn-card--open{border-color:color-mix(in srgb, var(--primary) 50%, var(--border))}.fn-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:8px 12px;transition:background .15s;display:flex}.fn-card-header:hover{background:var(--surface-hover)}.fn-card-title{color:var(--text);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.fn-card-icon{color:var(--text-muted);font-size:9px}.fn-card-arrow{color:var(--primary);font-size:11px;font-weight:400}.fn-card-body{border-top:1px solid var(--border);flex-direction:column;gap:2px;padding:10px 12px 12px;display:flex}.np-icon-btn{cursor:pointer;width:24px;height:24px;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.np-icon-btn:hover{background:var(--surface-hover)}.np-icon-btn--danger:hover{background:color-mix(in srgb, var(--danger) 15%, transparent);color:var(--danger)}.np-add-btn{color:var(--primary);background:color-mix(in srgb, var(--primary) 8%, transparent);border:1px dashed color-mix(in srgb, var(--primary) 40%, transparent);cursor:pointer;border-radius:6px;width:100%;margin-top:8px;padding:6px 14px;font-size:12px;font-weight:500;transition:all .15s}.np-add-btn:hover{background:color-mix(in srgb, var(--primary) 15%, transparent);border-color:var(--primary)}.np-checklist{flex-direction:column;gap:4px;display:flex}.np-check-item{cursor:pointer;border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;transition:all .15s;display:flex}.np-check-item:hover{background:var(--surface)}.np-check-item--on{background:color-mix(in srgb, var(--primary) 6%, transparent);border-color:color-mix(in srgb, var(--primary) 25%, transparent)}.np-check-item input{accent-color:var(--primary)}.np-check-name{color:var(--text);font-size:13px;font-weight:500}.np-check-hint{color:var(--text-muted);margin-top:1px;font-size:11px}.var-tags{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.var-tag{color:var(--primary);background:color-mix(in srgb, var(--primary) 12%, transparent);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.form-success{background:color-mix(in srgb, var(--success) 15%, transparent);color:var(--success);border:1px solid color-mix(in srgb, var(--success) 30%, transparent);border-radius:var(--radius);margin-bottom:16px;padding:10px 14px;font-size:14px}.pagination{justify-content:center;align-items:center;gap:8px;margin-top:16px;display:flex}.trace-timeline{flex-direction:column;display:flex}.trace-event{gap:12px;min-height:48px;display:flex}.trace-time{font-variant-numeric:tabular-nums;width:72px;color:var(--text-muted);text-align:right;flex-shrink:0;padding-top:2px;font-size:11px}.trace-indicator{flex-direction:column;flex-shrink:0;align-items:center;width:20px;display:flex}.trace-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.trace-line{background:var(--border);flex:1;width:2px;margin-top:4px}.trace-event:last-child .trace-line{display:none}.trace-content{flex:1;min-width:0;padding-bottom:16px}.trace-label{text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin-bottom:4px;font-size:11px;font-weight:700;display:flex}.trace-icon{opacity:.8;font-size:10px;font-weight:800}.trace-body{color:var(--text);font-size:13px;line-height:1.5}.trace-detail{color:var(--text-muted);font-size:12px}.trace-speech{word-wrap:break-word;border-radius:12px;max-width:100%;padding:6px 12px;font-size:13px;line-height:1.4;display:inline-block}.trace-speech-user{color:var(--info);background:#3b82f61f;border-bottom-left-radius:4px}.trace-speech-agent{color:var(--success);background:#10b9811f;border-bottom-right-radius:4px}.trace-json{background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;word-break:break-all;max-height:200px;color:var(--text-muted);border-radius:6px;margin-top:6px;padding:10px 12px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;line-height:1.5;overflow:auto}.trace-context{background:var(--bg);border:1px solid var(--border);border-radius:6px;margin-top:6px;padding:10px 12px;font-size:12px;line-height:1.6}.trace-error{color:var(--danger);font-weight:500}.end-reason{border-radius:12px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.end-reason--end_call{color:var(--success);background:#22c55e1f}.end-reason--idle_timeout{color:var(--warning);background:#f59e0b1f}.end-reason--user_disconnect{color:var(--info);background:#3b82f61f}.end-reason--error{color:var(--danger);background:#ef44441f}.transcript-chat{flex-direction:column;gap:12px;display:flex}.chat-turn{flex-direction:column;max-width:80%;display:flex}.chat-user{align-self:flex-start}.chat-agent{align-self:flex-end}.chat-meta{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:4px;font-size:11px;display:flex}.chat-agent .chat-meta{justify-content:flex-end}.chat-role{text-transform:uppercase;letter-spacing:.5px;font-weight:600}.chat-time{font-variant-numeric:tabular-nums}.chat-bubble{word-wrap:break-word;border-radius:14px;padding:10px 14px;font-size:13.5px;line-height:1.5}.chat-user .chat-bubble{color:var(--text);background:#3b82f61a;border-bottom-left-radius:4px}.chat-agent .chat-bubble{color:var(--text);background:#10b9811a;border-bottom-right-radius:4px}.detail-grid{gap:0;display:grid}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:400px;padding:40px}.login-brand{align-items:center;gap:10px;margin-bottom:4px;display:flex}.login-logo{width:36px;height:36px}.login-card h1{margin-bottom:0;font-size:22px;font-weight:700}.login-card p{color:var(--text-muted);margin-bottom:24px;font-size:14px}.login-links{text-align:center;margin-top:16px}.login-links a{color:var(--accent);font-size:13px;text-decoration:none}.login-links a:hover{text-decoration:underline}.reset-success{text-align:center;padding:16px 0 8px}.reset-success svg{margin-bottom:12px}.reset-success h3{margin-bottom:8px;font-size:18px;font-weight:600}.reset-success p{color:var(--text-muted);margin-bottom:0;font-size:14px;line-height:1.5}.sidebar-user{border-radius:var(--radius);background:var(--bg);justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 12px;font-size:13px;display:flex}.sidebar-user-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.badge{border-radius:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.badge-admin{color:#a78bfa;background:#8b5cf626}.badge-viewer{color:#60a5fa;background:#3b82f626}.badge-active{color:#34d399;background:#10b98126}.badge-inactive{color:#f87171;background:#ef444426}.btn-danger{color:#f87171}.btn-danger:hover{background:#ef44441a}.sidechat-toggle{z-index:1001;background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .2s,box-shadow .2s,right .3s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #6366f166}.sidechat-toggle:hover{transform:scale(1.06);box-shadow:0 6px 28px #6366f18c}.sidechat-toggle--open{width:36px;height:36px;box-shadow:none;background:var(--surface-hover);color:var(--text-muted);border-radius:10px;top:16px;bottom:auto;right:392px}.sidechat-toggle--open:hover{color:var(--text);box-shadow:none;transform:none}.sidechat-panel{z-index:1000;background:var(--bg);border-left:1px solid var(--border);flex-direction:column;width:380px;height:100vh;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:-380px}.sidechat-panel--open{right:0}.sidechat-header{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.sidechat-header-title{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.sidechat-header-title svg{color:var(--primary)}.sidechat-header-actions{align-items:center;gap:4px;display:flex}.sidechat-new-chat,.sidechat-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.sidechat-new-chat:hover,.sidechat-close:hover{color:var(--text);background:var(--surface-hover)}.sidechat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.sidechat-empty{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:20px;display:flex}.sidechat-empty p{max-width:260px;margin:0;font-size:13px}.sidechat-suggestions{flex-direction:column;gap:8px;width:100%;margin-top:8px;display:flex}.sidechat-suggestion{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;border-radius:8px;padding:10px 14px;font-size:12px;transition:border-color .15s,background .15s}.sidechat-suggestion:hover{border-color:var(--primary);background:var(--surface-hover)}.sidechat-msg{max-width:88%;font-size:13px;line-height:1.5}.sidechat-msg-user{align-self:flex-end}.sidechat-msg-assistant{align-self:flex-start}.sidechat-msg-user .sidechat-msg-content{background:var(--primary);color:#fff;border-radius:14px 14px 4px;padding:10px 14px}.sidechat-msg-assistant .sidechat-msg-content{background:var(--surface);color:var(--text);border:1px solid var(--border);white-space:pre-wrap;border-radius:14px 14px 14px 4px;padding:10px 14px}.sidechat-actions{flex-direction:column;gap:6px;margin-top:8px;display:flex}.sidechat-action{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:11px;display:flex}.sidechat-action-success{border-left:3px solid var(--success)}.sidechat-action-success svg{color:var(--success)}.sidechat-action-error{border-left:3px solid var(--danger)}.sidechat-action-error svg{color:var(--danger)}.sidechat-action-name{color:var(--text);font-weight:600}.sidechat-action-summary{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidechat-typing{background:var(--surface);border:1px solid var(--border);border-radius:14px 14px 14px 4px;gap:4px;padding:12px 14px;display:flex}.sidechat-typing span{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite sidechat-bounce}.sidechat-typing span:nth-child(2){animation-delay:.2s}.sidechat-typing span:nth-child(3){animation-delay:.4s}@keyframes sidechat-bounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.sidechat-input-area{border-top:1px solid var(--border);background:var(--bg);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 14px;display:flex}.sidechat-input{resize:none;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-family:var(--font);border-radius:10px;outline:none;flex:1;max-height:100px;padding:10px 14px;transition:border-color .15s}.sidechat-input:focus{border-color:var(--primary)}.sidechat-input::placeholder{color:var(--text-muted)}.sidechat-send{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:opacity .15s;display:flex}.sidechat-send:disabled{opacity:.4;cursor:not-allowed}.sidechat-send:not(:disabled):hover{background:var(--primary-hover)}.spin{animation:1s linear infinite spin}
