.react-flow{direction:ltr;--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: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--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: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--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: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--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 rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.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: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--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: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--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: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--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 rgba(0, 0, 0, .08);--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{position:absolute;width:100%;height:100%;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{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.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;-moz-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:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.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:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;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%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;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{position:absolute;z-index:5;margin:15px}.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{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.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{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.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{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;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))}.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{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.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-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.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}:root{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;--navy: #212121;--navy-mid: #2f2f2f;--navy-light: #424242;--accent: #0d0d0d;--accent-hover:#000000;--accent-soft: #f4f4f4;--bg: #f9f9f9;--surface: #ffffff;--text: #0d0d0d;--text-muted: #6b6b6b;--text-light: #8e8ea0;--border: #e5e5e5;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--radius: 10px}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:264px;background:var(--navy);display:flex;flex-direction:column;padding:16px 12px;gap:6px;flex-shrink:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 14px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:2px}.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.35rem;letter-spacing:-.03em;color:#fff}.new-chat-btn{width:100%;background:#ffffff12;border:1px solid rgba(255,255,255,.12);color:#ffffffd9;padding:9px 12px;border-radius:var(--radius);cursor:pointer;text-align:left;font-size:.875rem;font-weight:500;letter-spacing:.01em;transition:background .15s,border-color .15s}.new-chat-btn:hover{background:#ffffff1f;border-color:#fff3}.conversation-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent;margin-top:4px;padding:8px 4px;border-top:1px solid rgba(255,255,255,.08);background:#111;border-radius:10px;margin-left:-4px;margin-right:-4px}.conv-item{width:100%;background:transparent;border:none;color:#ffffff8c;padding:7px 10px;border-radius:7px;cursor:pointer;font-size:.83rem;display:flex;align-items:center;gap:6px;transition:background .12s,color .12s}.conv-item:hover{background:#ffffff14;color:#ffffffe6}.conv-item.active{background:#ffffff1a;color:#fffffff2;font-weight:500}.conv-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.rename-btn{opacity:0;background:transparent;border:none;color:#fff6;font-size:.82rem;cursor:pointer;padding:2px 5px;border-radius:4px;flex-shrink:0;line-height:1;transition:opacity .1s,color .1s,background .1s}.conv-item:hover .rename-btn{opacity:1}.rename-btn:hover{color:#fff;background:#ffffff1f}.delete-btn{opacity:0;background:transparent;border:none;color:#fff6;font-size:.82rem;cursor:pointer;padding:2px 5px;border-radius:4px;flex-shrink:0;line-height:1;transition:opacity .1s,color .1s,background .1s}.conv-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:#f87171;background:#f871711f}.conv-item-editing{padding:5px 8px;background:#ffffff14;border:1px solid rgba(255,255,255,.25);border-radius:7px}.conv-item-editing input{flex:1;background:transparent;border:none;color:#fff;font-size:.83rem;outline:none;width:100%;font-family:inherit}.sidebar-footer{padding-top:10px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:4px 6px}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-user-name{font-size:.82rem;font-weight:600;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.72rem;color:#fff6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usage-badge{display:flex;flex-direction:column;gap:5px;padding:8px 6px}.usage-badge.active{color:#86efac;font-size:.82rem;font-weight:500}.usage-label{display:flex;justify-content:space-between;font-size:.76rem;color:#ffffff73}.usage-bar{height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden}.usage-fill{height:100%;border-radius:2px;transition:width .4s ease}.upgrade-btn-small{background:var(--accent);border:none;color:#fff;padding:5px 12px;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;margin-top:2px;letter-spacing:.02em;transition:background .15s}.upgrade-btn-small:hover{background:var(--accent-hover)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.chat-container{display:flex;flex-direction:column;height:100%}.messages{flex:1;overflow-y:auto;padding:28px 32px;display:flex;flex-direction:column;width:100%;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.chat-inner{width:100%;display:flex;flex-direction:column;gap:12px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;gap:8px}.empty-state h2{font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:-.02em;margin:0}.empty-state p{font-size:.95rem;color:var(--text-muted);margin:0}.message{display:flex;gap:10px;align-items:flex-start}.message-user{flex-direction:row-reverse}.message-avatar{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;flex-shrink:0;letter-spacing:.02em}.message-assistant .message-avatar{background:var(--accent-soft);color:var(--accent);border:1px solid #c7d2fe}.message-user .message-avatar{background:var(--navy);color:#fff}.message-group{display:flex;flex-direction:column;gap:4px;max-width:92%}.message-user .message-group{max-width:78%;align-items:flex-end}.message-content{background:var(--surface);border-radius:2px 12px 12px;padding:12px 16px;font-size:.93rem;line-height:1.65;color:var(--text);box-shadow:var(--shadow-sm);border:1px solid var(--border);width:100%}.message-user .message-content{background:var(--navy);color:#ffffffeb;border-color:transparent;border-radius:12px 2px 12px 12px;box-shadow:var(--shadow-md)}.message-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s;padding:0 2px}.message:hover .message-actions{opacity:1}.message-user .message-actions{flex-direction:row-reverse}.msg-action-btn{background:transparent;border:none;color:var(--text-light);cursor:pointer;padding:3px 6px;border-radius:5px;display:flex;align-items:center;transition:color .1s,background .1s}.msg-action-btn:hover{color:var(--text);background:var(--border)}.msg-action-btn.loading{opacity:.5;cursor:wait}.export-menu{position:relative;display:inline-flex}.export-dropdown{position:absolute;bottom:calc(100% + 4px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px;display:flex;flex-direction:column;gap:2px;z-index:100;box-shadow:var(--shadow-md);min-width:140px}.export-option{display:flex;align-items:center;gap:7px;padding:6px 10px;border:none;background:transparent;color:var(--text-muted);font-size:.8rem;border-radius:5px;cursor:pointer;white-space:nowrap;transition:background .1s,color .1s}.export-option:hover{background:var(--border);color:var(--text)}.suggested-export-banner{margin-top:10px}.suggested-export-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:8px;border:1.5px solid var(--navy);background:transparent;color:var(--text);font-size:.85rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.suggested-export-btn:hover:not(:disabled){background:var(--navy);color:#fff}.suggested-export-btn.done{border-color:var(--border);color:var(--text-muted);cursor:default}.suggested-export-btn:disabled:not(.done){opacity:.6;cursor:wait}.message-edit-container{display:flex;flex-direction:column;gap:8px;max-width:78%;width:100%}.message-edit-textarea{width:100%;background:var(--surface);border:1.5px solid var(--navy);color:var(--text);border-radius:10px;padding:10px 14px;font-family:inherit;font-size:.93rem;resize:vertical;outline:none;line-height:1.5;min-height:64px;box-shadow:0 0 0 2px #00000012}.message-edit-actions{display:flex;gap:8px;justify-content:flex-end}.message-edit-actions .btn-primary,.message-edit-actions .btn-secondary{padding:6px 16px;font-size:.85rem}.message-content p{margin:0 0 8px}.message-content p:last-child{margin:0}.message-content h1,.message-content h2,.message-content h3{color:var(--text);margin:12px 0 6px;font-weight:700;letter-spacing:-.01em}.message-user .message-content h1,.message-user .message-content h2,.message-user .message-content h3{color:#fff}.message-content ul,.message-content ol{padding-left:20px;margin:6px 0}.message-content li{margin:3px 0}.message-content strong{color:var(--navy);font-weight:700}.message-user .message-content strong{color:#fff}.message-content code{font-family:Fira Code,Cascadia Code,ui-monospace,monospace;font-size:.86em;background:var(--accent-soft);color:var(--accent);padding:1px 5px;border-radius:4px}.message-user .message-content code{background:#ffffff26;color:#c7d2fe}.code-block{margin:10px 0;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.07);background:#282c34;box-shadow:0 2px 10px #00000026}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;background:#21252b;border-bottom:1px solid rgba(255,255,255,.06)}.code-block-lang{font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#ffffff4d}.copy-btn{display:flex;align-items:center;gap:4px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#ffffff73;padding:3px 10px;border-radius:5px;font-size:.71rem;font-weight:500;cursor:pointer;transition:color .1s,border-color .1s,background .1s;margin-left:auto}.copy-btn:hover{color:#fff;border-color:#ffffff59;background:#ffffff1a}.message-content table{width:100%;border-collapse:collapse;font-size:.88rem;margin:10px 0;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.message-content thead{background:var(--accent-soft)}.message-content th{padding:9px 14px;text-align:left;font-weight:700;font-size:.8rem;color:var(--text);border-bottom:1.5px solid var(--border);white-space:nowrap}.message-content td{padding:8px 14px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:top}.message-content tr:last-child td{border-bottom:none}.message-content tbody tr:hover{background:var(--bg)}.message-user .message-content table{border-color:#ffffff26}.message-user .message-content thead{background:#ffffff14}.message-user .message-content th{color:#ffffffe6;border-bottom-color:#ffffff26}.message-user .message-content td{color:#fffc;border-bottom-color:#ffffff14}.message-user .message-content tbody tr:hover{background:#ffffff0d}.searching-indicator{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:.83rem;padding:8px 4px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.cursor{animation:blink 1s step-end infinite;color:var(--accent)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .7s linear infinite}.sidebar-link{gap:8px}.upgrade-btn-small{gap:5px}.doc-back-btn{gap:6px}.btn-icon-label{display:flex;align-items:center;gap:7px}.input-area{padding:10px 32px 20px;background:var(--bg);border-top:1px solid var(--border);width:100%}.input-inner{width:100%;display:flex;flex-direction:column;gap:8px}.model-selector{display:flex;gap:6px;align-items:center}.model-pill{display:flex;align-items:center;gap:5px;background:transparent;border:1.5px solid var(--border);color:var(--text-muted);padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.model-pill:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.model-pill.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.model-pill.active:hover:not(:disabled){color:#fff}.model-pill:disabled{opacity:.5;cursor:not-allowed}.input-row{display:flex;gap:10px;align-items:center}.input-row textarea{flex:1;background:var(--surface);border:1.5px solid var(--border);color:var(--text);border-radius:12px;padding:12px 16px;font-family:inherit;font-size:.93rem;resize:none;outline:none;line-height:1.5;min-height:46px;max-height:200px;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.input-row textarea::placeholder{color:var(--text-light)}.input-row textarea:focus{border-color:#0d0d0d;box-shadow:0 0 0 2px #00000014}.input-row button{background:var(--navy);border:none;color:#fff;width:44px;height:44px;border-radius:10px;font-size:1.15rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-sm);transition:background .15s,transform .1s}.input-row button:hover:not(:disabled){background:var(--navy-mid);transform:translateY(-1px)}.input-row button:disabled{background:var(--border);color:var(--text-light);cursor:not-allowed;transform:none;box-shadow:none}.modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:420px;width:90%;box-shadow:0 20px 48px #0f172a2e}.modal h2{margin:0 0 10px;font-size:1.25rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}.modal p{color:var(--text-muted);margin:0 0 16px;font-size:.93rem}.modal ul{padding-left:20px;margin:0 0 24px;line-height:2;color:var(--text-muted)}.modal ul li{color:var(--text);font-size:.93rem;display:flex;align-items:center;gap:8px}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.btn-primary{background:var(--navy);border:none;color:#fff;padding:10px 22px;border-radius:9px;cursor:pointer;font-size:.9rem;font-weight:600;letter-spacing:.01em;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--navy-mid);transform:translateY(-1px)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-secondary{background:transparent;border:1.5px solid var(--border);color:var(--text-muted);padding:10px 22px;border-radius:9px;cursor:pointer;font-size:.9rem;font-weight:500;transition:border-color .15s,color .15s}.btn-secondary:hover{border-color:var(--navy);color:var(--text)}.settings-icon-btn{margin-left:auto;background:transparent;border:none;color:#ffffff59;font-size:1rem;cursor:pointer;padding:4px;border-radius:5px;transition:color .15s,background .15s;flex-shrink:0;line-height:1}.settings-icon-btn:hover{color:#ffffffd9;background:#ffffff14}.settings-modal{max-width:520px;width:95%;max-height:88vh;display:flex;flex-direction:column;padding:0;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.settings-header h2{margin:0;font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:4px 8px;border-radius:5px;transition:color .1s,background .1s}.close-btn:hover{color:var(--text);background:var(--bg)}.settings-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:22px;scrollbar-width:thin}.settings-loading{padding:40px;text-align:center;color:var(--text-muted)}.settings-section{display:flex;flex-direction:column;gap:8px}.settings-section label{font-size:.82rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.06em}.settings-section input,.settings-section textarea{background:var(--bg);border:1.5px solid var(--border);color:var(--text);border-radius:9px;padding:10px 13px;font-family:inherit;font-size:.9rem;outline:none;resize:none;transition:border-color .15s,box-shadow .15s}.settings-section input:focus,.settings-section textarea:focus{border-color:#0d0d0d;box-shadow:0 0 0 2px #00000012}.hint{font-size:.75rem;color:var(--text-light)}.option-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.opt-card{display:flex;flex-direction:column;gap:2px;background:var(--bg);border:1.5px solid var(--border);border-radius:9px;padding:10px 12px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.opt-card:hover,.opt-card.selected{border-color:var(--accent);background:var(--accent-soft)}.opt-label{font-size:.85rem;font-weight:600;color:var(--text)}.opt-desc{font-size:.72rem;color:var(--text-muted)}.option-row{display:flex;flex-wrap:wrap;gap:8px}.opt-pill{display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--bg);border:1.5px solid var(--border);border-radius:20px;padding:6px 16px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-muted);transition:border-color .15s,color .15s,background .15s}.opt-pill small{font-size:.7rem;color:var(--text-light)}.opt-pill:hover{border-color:var(--accent);color:var(--text)}.opt-pill.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:700}.settings-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:var(--surface)}.sidebar-links{display:flex;flex-direction:column;gap:2px;padding:4px 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-link{width:100%;background:transparent;border:none;color:#ffffff73;padding:7px 10px;border-radius:7px;cursor:pointer;font-size:.82rem;text-align:left;text-decoration:none;display:block;transition:background .1s,color .1s}.sidebar-link:hover{background:#ffffff14;color:#ffffffd9}.key-revealed{background:#fefce8;border:1.5px solid #fbbf24;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.key-revealed p{margin:0;font-size:.85rem;color:#92400e}.key-revealed-row{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #fbbf24;border-radius:7px;padding:8px 12px}.key-revealed-row code{flex:1;font-size:.8rem;word-break:break-all;color:#1c1917;background:transparent}.key-revealed-row button{background:transparent;border:none;cursor:pointer;font-size:1rem;color:#92400e;padding:2px 6px}.key-create-row{display:flex;gap:8px}.key-create-row input{flex:1}.keys-list{display:flex;flex-direction:column;gap:8px}.key-row{display:flex;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:10px 14px;gap:12px}.key-row-info{flex:1;display:flex;flex-direction:column;gap:3px}.key-name{font-size:.87rem;font-weight:600;color:var(--text)}.key-prefix{font-size:.78rem;color:var(--text-muted);background:transparent}.key-meta{font-size:.72rem;color:var(--text-light)}.key-revoke-btn{background:transparent;border:1px solid var(--border);color:var(--text-light);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:.75rem;transition:border-color .1s,color .1s,background .1s}.key-revoke-btn:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.docs-layout{display:flex;height:100vh;overflow:hidden}.docs-sidebar{gap:10px}.docs-sidebar-section{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.docs-sidebar-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d;padding:6px 10px 4px}.docs-nav{display:flex;flex-direction:column;gap:2px}.docs-sidebar-footer{padding-top:10px;border-top:1px solid rgba(255,255,255,.08)}.doc-back-btn{display:flex;align-items:center;gap:6px;color:#ffffff73;font-size:.82rem;text-decoration:none;padding:7px 10px;border-radius:7px;transition:background .1s,color .1s}.doc-back-btn:hover{background:#ffffff14;color:#ffffffd9}.docs-content{flex:1;overflow-y:auto;background:var(--bg);scrollbar-width:thin}.docs-inner{max-width:100%;margin:0;padding:40px 56px 80px;display:flex;flex-direction:column;gap:0}.docs-hero{padding-bottom:32px;border-bottom:1px solid var(--border);margin-bottom:40px}.docs-hero-badges{display:flex;gap:8px;margin-bottom:14px}.docs-hero h1{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;color:var(--text);margin:0 0 12px}.docs-hero p{color:var(--text-muted);font-size:1rem;margin:0;max-width:560px}.doc-section{padding:36px 0;border-bottom:1px solid var(--border)}.doc-section:last-child{border-bottom:none}.doc-section h2{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;color:var(--text);margin:0 0 16px}.doc-section h3{font-size:.95rem;font-weight:700;color:var(--text);margin:20px 0 10px;text-transform:uppercase;letter-spacing:.05em}.doc-section p{color:var(--text-muted);font-size:.95rem;margin:0 0 16px;line-height:1.65}.doc-section a{color:var(--accent);text-decoration:none;font-weight:500}.doc-section a:hover{text-decoration:underline}.doc-section code{background:var(--accent-soft);color:var(--accent);padding:2px 6px;border-radius:4px;font-size:.87em;font-family:Fira Code,monospace}.doc-badge{font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.04em}.doc-badge-green{background:#dcfce7;color:#15803d}.doc-badge-blue{background:#dbeafe;color:#1d4ed8}.doc-badge-purple{background:#f4f4f4;color:#0d0d0d}.doc-badge-red{background:#fee2e2;color:#dc2626}.doc-badge-gray{background:#f1f5f9;color:#64748b}.doc-badge-orange{background:#ffedd5;color:#c2410c}.doc-endpoint-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;margin:12px 0;box-shadow:var(--shadow-sm)}.doc-base-url{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.06em}.doc-endpoint-card code{background:transparent;color:var(--navy);font-size:.9rem;font-weight:600}.doc-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0}.doc-info-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.doc-info-card span{font-size:1.4rem}.doc-info-card strong{font-size:.87rem;color:var(--text)}.doc-info-card p{font-size:.8rem;color:var(--text-muted);margin:0}.doc-method-row{display:flex;align-items:center;gap:10px;margin:12px 0}.doc-method-row code{background:var(--navy);color:#e2e8f0;font-size:.9rem;padding:4px 12px;border-radius:6px}.doc-params{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden}.doc-param{padding:14px 16px;border-bottom:1px solid var(--border)}.doc-param:last-child{border-bottom:none}.doc-param-name{display:flex;align-items:center;gap:8px;margin-bottom:4px}.doc-param-name code{background:transparent;color:var(--navy);font-weight:700;font-size:.9rem;padding:0}.doc-param-desc{font-size:.85rem;color:var(--text-muted)}.doc-warning{background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;padding:14px 16px;font-size:.87rem;color:#9a3412;margin:16px 0}.doc-error-table{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden}.doc-error-row{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid var(--border);font-size:.87rem}.doc-error-row:last-child{border-bottom:none}.doc-error-row code{background:transparent;color:var(--navy);font-weight:600;min-width:140px;padding:0}.doc-error-row span{color:var(--text-muted)}.doc-code-block{border:1px solid rgba(255,255,255,.07);border-radius:10px;overflow:hidden;margin:14px 0;background:#282c34;box-shadow:0 2px 12px #0000002e}.doc-code-header{display:flex;justify-content:space-between;align-items:center;padding:9px 16px;background:#21252b;border-bottom:1px solid rgba(255,255,255,.06)}.doc-code-lang{font-size:.7rem;font-weight:700;text-transform:uppercase;color:#ffffff59;letter-spacing:.1em}.doc-code-header button{display:flex;align-items:center;gap:5px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#ffffff73;padding:4px 11px;border-radius:5px;font-size:.71rem;font-weight:500;cursor:pointer;transition:color .1s,border-color .1s,background .1s}.doc-code-header button:hover{color:#fff;border-color:#ffffff59;background:#ffffff1a}.doc-muted{color:var(--text-muted);font-size:.88rem;margin:0 0 16px}.doc-steps{display:flex;flex-direction:column;gap:0;margin:16px 0}.doc-step{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}.doc-step:last-child{border-bottom:none}.doc-step-num{width:28px;height:28px;background:var(--navy);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;margin-top:2px}.doc-step strong{display:block;font-size:.93rem;color:var(--text);margin-bottom:4px}.doc-step p{font-size:.85rem;color:var(--text-muted);margin:0 0 8px}.doc-step .doc-code-block{margin:8px 0 0}.mobile-topbar,.sidebar-close-btn,.sidebar-overlay{display:none}@media(max-width:1024px){.sidebar{width:220px}.messages{padding:20px 16px}.input-area{padding:10px 16px 16px}.option-grid,.doc-info-grid{grid-template-columns:repeat(2,1fr)}.docs-inner{padding:32px 32px 60px}.message-user .message-content{max-width:80%}}@media(max-width:640px){.sidebar{position:fixed;top:0;left:0;height:100%;width:280px;z-index:200;transform:translate(-100%);transition:transform .25s ease}.sidebar--open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000073;z-index:199}.sidebar-close-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#ffffff80;cursor:pointer;padding:4px;border-radius:6px;transition:color .15s,background .15s}.sidebar-close-btn:hover{color:#fff;background:#ffffff1a}.mobile-topbar{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.mobile-brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:1.1rem;letter-spacing:-.03em;color:var(--text)}.hamburger-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s}.hamburger-btn:hover{color:var(--text);background:var(--bg)}.main-content{width:100%}.messages{padding:12px 14px 8px}.chat-inner{gap:10px}.input-area{padding:8px 12px 16px}.message-content{max-width:92%;font-size:.9rem}.message-user .message-content{max-width:82%}.message-avatar{width:26px;height:26px;font-size:.6rem}.model-selector{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}.input-row textarea{font-size:.9rem;padding:10px 14px}.input-row button{width:40px;height:40px}.rename-btn,.delete-btn,.message-actions{opacity:1}.message-edit-container{max-width:95%}.option-grid{grid-template-columns:repeat(2,1fr)}.doc-info-grid{grid-template-columns:1fr}.docs-inner{padding:20px 16px 48px}.docs-layout{flex-direction:column}.docs-content{width:100%}.modal{padding:24px 18px}.settings-modal{max-height:92vh;width:96%}.sidebar-user-email{display:none}}
