.login-container{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.1) 0%,transparent 50%),linear-gradient(45deg,transparent 40%,rgba(255,255,255,.05) 50%,transparent 60%);z-index:1}.login-container:after{content:"🤖 AI POWERED";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-45deg);font-size:4rem;font-weight:900;color:#ffffff14;z-index:0;font-family:Arial Black,sans-serif;letter-spacing:.5rem;text-shadow:0 0 30px rgba(255,255,255,.1);-webkit-user-select:none;user-select:none;pointer-events:none}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;box-shadow:0 32px 64px #0003,0 0 0 1px #fff6,inset 0 1px #fff9;padding:3rem;width:100%;max-width:480px;animation:slideUp .8s cubic-bezier(.16,1,.3,1);position:relative;z-index:2}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2.5rem}.logo-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.login-logo{height:48px;width:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.ai-badge{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;box-shadow:0 4px 12px #4f46e54d}.ai-icon{font-size:1rem}.app-title{margin:0 0 1rem;color:#1f2937;font-size:2rem;font-weight:700;line-height:1.2;display:flex;flex-direction:column;gap:.25rem}.title-main{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.title-sub{font-size:1.2rem;color:#6b7280;font-weight:500}.app-description{margin:0 0 1.5rem;color:#6b7280;font-size:1rem;line-height:1.5}.feature-badges{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.badge{background:#677eea1a;color:#4f46e5;padding:.4rem .8rem;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid rgba(103,126,234,.2)}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group input:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.error-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;padding:1rem;border-radius:12px;margin-top:1rem;font-size:.9rem;border:1px solid #fecaca;display:flex;align-items:center;gap:.5rem;box-shadow:0 4px 12px #dc26261a}.error-icon{font-size:1.1rem}.login-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #007bff4d}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #007bff66}.login-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.demo-credentials{border-top:1px solid #e1e5e9;padding-top:1.5rem}.demo-credentials h3{margin:0 0 1rem;color:#333;font-size:.9rem;font-weight:600}.demo-user{padding:.5rem .75rem;margin-bottom:.5rem;background:#f8f9fa;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.85rem;border:1px solid #e9ecef}.demo-user:hover{background:#e9ecef;border-color:#007bff;transform:translate(2px)}.demo-user strong{color:#007bff}.demo-user .role{float:right;color:#666;font-style:italic}.sso-login{margin-bottom:2rem}.login-prompt{text-align:center;margin-bottom:2rem}.login-prompt h3{margin:0 0 .5rem;color:#1f2937;font-size:1.25rem;font-weight:600}.login-prompt p{margin:0;color:#6b7280;font-size:.95rem}.microsoft-login-button{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#0078d4,#106ebe);color:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #0078d44d,0 0 0 1px #ffffff1a;position:relative;overflow:hidden}.microsoft-login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.microsoft-login-button:hover:not(:disabled):before{left:100%}.microsoft-login-button:hover:not(:disabled){background:linear-gradient(135deg,#106ebe,#0078d4);transform:translateY(-2px);box-shadow:0 12px 32px #0078d466,0 0 0 1px #fff3}.microsoft-login-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:0 4px 12px #9ca3af4d}.button-content{display:flex;align-items:center;justify-content:center;gap:1rem;position:relative;z-index:1}.ms-logo{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.button-text{display:flex;align-items:center;gap:.5rem}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.demo-login-button{width:100%;padding:.75rem 1rem;background:#6c757d;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.demo-login-button:hover{background:#5a6268;transform:translateY(-1px)}.divider{text-align:center;margin:1.5rem 0;position:relative}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e1e5e9}.divider span{background:#fff;padding:0 1rem;color:#666;font-size:.9rem}.sso-info{border-top:1px solid rgba(107,114,128,.2);padding-top:2rem;margin-top:2rem}.sso-info h3{margin:0 0 1rem;color:#374151;font-size:1rem;font-weight:600;text-align:center}.sso-info ul{margin:0;padding:0;list-style:none;display:grid;gap:.75rem}.sso-info li{background:#677eea0d;padding:.75rem 1rem;border-radius:12px;font-size:.9rem;color:#4b5563;border:1px solid rgba(103,126,234,.1);transition:all .2s ease}.sso-info li:hover{background:#677eea1a;transform:translate(4px)}.manual-login-popup{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.manual-login-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 20px 40px #0000004d;width:100%;max-width:350px;margin:1rem}.manual-login-form h3{margin:0 0 1.5rem;color:#333;text-align:center;font-size:1.2rem}.manual-login-actions{display:flex;gap:.75rem;margin-top:1.5rem}.login-btn{flex:1;padding:.75rem;background:#007bff;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.login-btn:hover{background:#0056b3}.cancel-btn{flex:1;padding:.75rem;background:#6c757d;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.cancel-btn:hover{background:#5a6268}@media (max-width: 480px){.login-card{padding:2rem 1.5rem;margin:1rem;border-radius:20px}.app-title{font-size:1.5rem}.logo-container{flex-direction:column;gap:.75rem}.feature-badges{flex-direction:column;align-items:center}.microsoft-login-button{padding:.875rem 1.25rem;font-size:1rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h3{margin:0;color:#333}.close-button{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#333}.modal-body{padding:20px}.proposal-info{background:#f5f5f5;padding:15px;border-radius:4px;margin-bottom:20px}.proposal-info p{margin:5px 0;color:#555}.description-section{margin-bottom:20px}.description-section label{display:block;font-weight:600;margin-bottom:8px;color:#333}.current-description{background:#f9f9f9;padding:12px;border-radius:4px;border:1px solid #e0e0e0;color:#555;line-height:1.5}.description-section textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;resize:vertical}.description-section textarea:focus{outline:none;border-color:#4a90e2}.error-message{background:#fee;color:#c33;padding:10px;border-radius:4px;margin-bottom:15px}.success-message{background:#efe;color:#3c3;padding:10px;border-radius:4px;margin-bottom:15px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-actions button{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.modal-actions button[type=button]{background:#f0f0f0;color:#333}.modal-actions button[type=button]:hover:not(:disabled){background:#e0e0e0}.modal-actions button[type=submit]{background:#4a90e2;color:#fff}.modal-actions button[type=submit]:hover:not(:disabled){background:#357abd}.modal-actions button:disabled{opacity:.6;cursor:not-allowed}.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))}.table-node{background:#fff;border:2px solid #e0e0e0;border-radius:8px;min-width:220px;max-width:280px;box-shadow:0 4px 12px #0000001a;transition:all .2s ease;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative;overflow:hidden}.table-node.size-small{min-width:200px;max-width:240px}.table-node.size-medium{min-width:220px;max-width:260px}.table-node.size-large{min-width:240px;max-width:280px;box-shadow:0 6px 16px #0000001f}.table-node.size-xlarge{min-width:260px;max-width:300px;box-shadow:0 8px 20px #00000026}.table-node:hover{box-shadow:0 8px 20px #0000002e;transform:translateY(-2px)}.table-node.selected{box-shadow:0 8px 24px #00000040;transform:translateY(-2px)}.table-node.highlighted{box-shadow:0 8px 24px #28a74566}.table-node.dimmed{opacity:.35;filter:grayscale(50%)}.table-node .domain-bar{height:4px;width:100%}.table-node-header{color:#fff;padding:10px 12px;font-weight:600;display:flex;flex-direction:column;gap:6px}.table-node .header-top{display:flex;align-items:center;gap:6px}.table-node .domain-icon{font-size:14px;flex-shrink:0}.table-node-header .table-name{font-family:Courier New,monospace;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.table-node .header-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.table-node-header .column-count{font-size:10px;background:#fff3;padding:2px 6px;border-radius:4px;white-space:nowrap}.table-node-header .row-count{font-size:10px;background:#ffffff4d;padding:2px 6px;border-radius:4px;white-space:nowrap;font-weight:700}.table-node .quality-badge{font-size:12px;margin-left:auto}.table-node .quality-badge.quality-high{color:#a5d6a7}.table-node .quality-badge.quality-medium{color:#fff59d}.table-node .quality-badge.quality-low{color:#ef9a9a}.table-node-columns{padding:8px 0;max-height:160px;overflow-y:auto}.table-node .column-row{display:flex;justify-content:space-between;align-items:center;padding:4px 12px;border-bottom:1px solid #f5f5f5;font-size:12px}.table-node .column-row:last-child{border-bottom:none}.table-node .column-info{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.table-node .pk-icon{font-size:9px;font-weight:700;background:#ffc107;color:#333;padding:1px 4px;border-radius:3px;flex-shrink:0}.table-node .column-name{font-family:Courier New,monospace;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-node .column-type{font-size:10px;color:#666;background:#f0f0f0;padding:2px 6px;border-radius:4px;flex-shrink:0;margin-left:8px}.table-node .column-more{padding:6px 12px;font-size:11px;color:#666;font-style:italic;text-align:center;background:#f9f9f9}.table-handle{width:10px;height:10px;background:var(--domain-color, #007bff);border:2px solid white}.table-handle:hover{background:var(--domain-color, #0056b3);transform:scale(1.2)}.context-menu{position:fixed;background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;min-width:200px;padding:6px 0;z-index:1000;animation:contextMenuFadeIn .15s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-size:13px;color:#333;cursor:pointer;transition:background .1s ease}.context-menu-item:hover:not(.disabled){background:#f0f4ff}.context-menu-item.disabled{color:#aaa;cursor:not-allowed}.context-menu-icon{width:20px;text-align:center;font-size:14px}.context-menu-label{flex:1}.context-menu-divider{height:1px;background:#e5e5e5;margin:6px 0}.context-menu-item.has-submenu:after{content:"▸";margin-left:auto;font-size:10px;color:#888}.table-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.table-picker-modal{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.table-picker-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee}.table-picker-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.close-button{background:none;border:none;font-size:20px;color:#888;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s ease}.close-button:hover{background:#f0f0f0;color:#333}.table-picker-search{padding:16px 24px;border-bottom:1px solid #eee;position:relative}.table-picker-search input{width:100%;padding:12px 40px 12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .15s ease}.table-picker-search input:focus{outline:none;border-color:#007bff}.clear-search{position:absolute;right:32px;top:50%;transform:translateY(-50%);background:#e0e0e0;border:none;width:20px;height:20px;border-radius:50%;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666}.clear-search:hover{background:#ccc}.table-picker-content{flex:1;overflow-y:auto;padding:8px 0}.domain-group{margin-bottom:4px}.domain-header{display:flex;align-items:center;gap:10px;padding:12px 24px;cursor:pointer;transition:background .15s ease;border-left:4px solid transparent}.domain-header:hover{background:#f8f9fa}.domain-expand{font-size:10px;color:#888;width:16px}.domain-icon{font-size:16px}.domain-name{font-weight:600;color:#333;flex:1}.domain-count{display:flex;align-items:center;gap:8px;font-size:12px}.available-count{color:#28a745;font-weight:500}.total-count{color:#888}.select-all-btn{padding:4px 10px;background:#007bff;color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:background .15s ease}.select-all-btn:hover{background:#0056b3}.domain-tables{padding:4px 0 8px}.table-item{display:flex;align-items:center;gap:12px;padding:10px 24px 10px 54px;cursor:pointer;transition:background .15s ease}.table-item:hover:not(.already-visible){background:#f0f4ff}.table-item.selected{background:#e3f2fd}.table-item.already-visible{cursor:default;opacity:.6}.table-checkbox{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.check-icon{width:18px;height:18px;border:2px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s ease}.check-icon.checked{background:#007bff;border-color:#007bff;color:#fff}.check-icon.visible{background:#28a745;border-color:#28a745;color:#fff}.table-info{flex:1;min-width:0}.table-name-row{display:flex;align-items:center;gap:8px}.table-name{font-family:Courier New,monospace;font-size:13px;font-weight:600;color:#333}.visible-badge{font-size:10px;background:#e8f5e9;color:#388e3c;padding:2px 6px;border-radius:4px;font-weight:500}.table-meta{display:flex;gap:12px;font-size:11px;color:#888;margin-top:2px}.no-results{padding:40px 24px;text-align:center;color:#888}.table-picker-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:1px solid #eee;background:#f8f9fa;border-radius:0 0 12px 12px}.selection-count{font-size:13px;color:#666}.footer-buttons{display:flex;gap:12px}.cancel-button{padding:10px 20px;background:#fff;border:1px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;transition:all .15s ease}.cancel-button:hover{background:#f5f5f5}.add-button{padding:10px 24px;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease}.add-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #007bff4d}.add-button:disabled{background:#ccc;cursor:not-allowed}.related-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000}.related-picker{position:fixed;background:#fff;border-radius:10px;box-shadow:0 4px 24px #0003;min-width:280px;max-width:360px;max-height:400px;overflow:hidden;display:flex;flex-direction:column;animation:slideIn .15s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.related-picker-header{padding:14px 16px;border-bottom:1px solid #eee}.related-picker-header h3{margin:0;font-size:14px;font-weight:600;color:#333}.from-table{font-size:12px;color:#888;font-family:Courier New,monospace}.related-picker-content{overflow-y:auto;padding:8px 0}.relation-group{margin-bottom:8px}.group-header{display:flex;align-items:center;gap:8px;padding:8px 16px 4px;font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.group-icon{font-size:14px}.group-icon.explicit{color:#1976d2}.group-icon.implicit{color:#4caf50}.related-item{display:flex;flex-direction:column;gap:2px;width:100%;padding:10px 16px;border:none;background:none;text-align:left;cursor:pointer;transition:background .15s ease}.related-item:hover{background:#f0f4ff}.related-table-name{font-family:Courier New,monospace;font-size:13px;font-weight:600;color:#333}.related-detail{display:flex;align-items:center;gap:8px;font-size:11px;color:#888}.confidence-badge{padding:1px 6px;border-radius:4px;font-size:9px;font-weight:600;text-transform:uppercase}.confidence-badge.high{background:#e8f5e9;color:#388e3c}.confidence-badge.medium{background:#fff3e0;color:#f57c00}.confidence-badge.low{background:#fce4ec;color:#c2185b}.no-relations{padding:24px 16px;text-align:center;color:#888;font-size:13px}.table-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:backdropFadeIn .2s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.table-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;width:100%;max-width:640px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .25s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.table-modal-header{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-shrink:0}.table-modal-title{display:flex;align-items:center;gap:14px;min-width:0}.table-modal-icon{font-size:28px;flex-shrink:0}.table-modal-name-group{min-width:0}.table-modal-name-group h2{margin:0;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:18px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.table-modal-domain{font-size:12px;color:#ffffffd9;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.table-modal-close{width:36px;height:36px;border-radius:10px;border:none;background:#fff3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease;flex-shrink:0}.table-modal-close:hover{background:#ffffff4d}.table-modal-stats{display:flex;gap:1px;background:#e5e7eb;border-bottom:1px solid #e5e7eb}.table-modal-stat{flex:1;padding:16px 20px;background:#f9fafb;text-align:center;display:flex;flex-direction:column;gap:2px}.table-modal-stat .stat-number{font-size:22px;font-weight:700;color:#111827;font-variant-numeric:tabular-nums}.table-modal-stat .stat-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.table-modal-content{flex:1;overflow-y:auto;padding:24px}.table-modal-section{margin-bottom:28px}.table-modal-section:last-child{margin-bottom:0}.table-modal-section h3{margin:0 0 12px;font-size:13px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.05em}.table-modal-section h3 .column-count{font-weight:500;color:#9ca3af}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title-row h3{margin:0}.table-modal-description{margin:0;font-size:14px;line-height:1.65;color:#4b5563;background:#f9fafb;padding:14px 16px;border-radius:10px;border:1px solid #e5e7eb}.columns-list-modal{background:#fff;max-height:400px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:10px}.columns-list-modal::-webkit-scrollbar{width:6px}.columns-list-modal::-webkit-scrollbar-track{background:#f5f5f5}.columns-list-modal::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.column-item-modal{padding:15px 20px;border-bottom:1px solid #f0f0f0;transition:background .2s}.column-item-modal:hover{background:#f8f9fa}.column-item-modal:last-child{border-bottom:none}.column-header-modal{display:flex;align-items:center;gap:12px;margin-bottom:8px}.column-name-modal{font-weight:600;color:#333;font-family:Courier New,monospace;font-size:14px;position:relative;padding-left:20px}.column-name-modal:before{content:"├─";position:absolute;left:0;color:#007bff;font-weight:700}.column-item-modal:last-child .column-name-modal:before{content:"└─"}.pk-indicator{font-size:9px;font-weight:700;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;padding:3px 6px;border-radius:4px;margin-right:4px}.column-type-modal{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.null-indicator{display:inline-block;background:#fff3cd;color:#856404;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;margin-left:20px;margin-bottom:8px}.column-description-modal{display:flex;justify-content:space-between;align-items:center;gap:15px;padding-left:20px}.column-description-modal p{margin:0;color:#666;font-size:13px;line-height:1.5;flex:1}.propose-btn{padding:8px 16px;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:all .2s;box-shadow:0 2px 8px #007bff4d}.propose-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #007bff80}.propose-btn.small{padding:6px 12px;font-size:12px}@media (max-width: 640px){.table-modal-backdrop{padding:16px}.table-modal{max-height:calc(100vh - 32px)}.table-modal-header{padding:16px 20px}.table-modal-name-group h2{font-size:16px}.table-modal-content{padding:20px}.table-modal-stat{padding:12px 16px}.table-modal-stat .stat-number{font-size:18px}}.note-node{background:#fff9c4;border:2px solid #ffc107;border-radius:8px;min-width:150px;min-height:100px;width:100%;height:100%;display:flex;flex-direction:column;box-shadow:0 4px 12px #0000001a;transition:box-shadow .2s ease}.note-node:hover{box-shadow:0 6px 16px #00000026}.note-node.selected{box-shadow:0 8px 24px #0003}.note-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-bottom:1px solid rgba(0,0,0,.1);position:relative}.note-icon{font-size:14px}.note-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease}.note-node:hover .note-actions{opacity:1}.note-action-btn{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:4px;font-size:12px;transition:background .15s ease}.note-action-btn:hover{background:#0000001a}.delete-btn:hover{color:#dc3545}.color-picker{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:8px;display:flex;gap:6px;z-index:10}.color-option{width:24px;height:24px;border:2px solid;border-radius:50%;cursor:pointer;transition:transform .15s ease}.color-option:hover{transform:scale(1.1)}.color-option.active{transform:scale(1.2)}.note-content{flex:1;padding:10px;overflow:auto}.note-editor{width:100%;height:100%;min-height:60px;border:none;background:transparent;font-family:inherit;font-size:13px;line-height:1.5;resize:none;outline:none}.note-text{font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word;color:#333}.placeholder{color:#888;font-style:italic}.schema-graph-wrapper{display:flex;gap:0;height:calc(100vh - 280px);min-height:500px;position:relative}.graph-legend{position:absolute;top:16px;left:16px;z-index:10;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:16px;max-width:240px;max-height:calc(100% - 32px);overflow-y:auto}.legend-section{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #eee}.legend-section:last-of-type{margin-bottom:8px;padding-bottom:0;border-bottom:none}.legend-section h4{margin:0 0 10px;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.domain-filters{display:flex;flex-direction:column;gap:6px}.domain-filter{display:flex;align-items:center;gap:8px;padding:8px 10px;border:2px solid;border-radius:8px;background:transparent;cursor:pointer;transition:all .2s ease;font-size:12px}.domain-filter:hover{transform:translate(2px)}.domain-filter.active{box-shadow:0 2px 8px #0000001a}.domain-filter:not(.active){opacity:.5;border-style:dashed}.domain-filter .domain-icon{font-size:14px}.domain-filter .domain-name{flex:1;font-weight:500;color:#333;text-align:left}.domain-filter .domain-count{background:#0000001a;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600}.relationship-toggles{margin-bottom:10px}.toggle-label{display:flex;align-items:center;gap:8px;font-size:12px;color:#333;cursor:pointer}.toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.edge-legend{display:flex;flex-direction:column;gap:6px}.edge-type{display:flex;align-items:center;gap:8px;font-size:11px;color:#555}.edge-line{width:24px;height:3px;border-radius:2px}.edge-line.explicit{background:#1976d2}.edge-line.implicit-high{background:repeating-linear-gradient(90deg,#4caf50 0px,#4caf50 4px,transparent 4px,transparent 8px)}.edge-line.implicit-medium{background:repeating-linear-gradient(90deg,#ff9800 0px,#ff9800 4px,transparent 4px,transparent 8px)}.quality-legend{display:flex;flex-direction:column;gap:4px}.quality-item{display:flex;align-items:center;gap:8px;font-size:11px;color:#555}.quality-dot{font-size:14px}.quality-dot.high{color:#4caf50}.quality-dot.medium{color:#ff9800}.quality-dot.low{color:#f44336}.legend-stats{display:flex;justify-content:space-between;font-size:11px;color:#888;padding-top:8px;border-top:1px solid #eee}.schema-graph-container{flex:1;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 8px 25px #00000026;transition:all .3s ease}.schema-graph-container.with-panel{border-radius:12px 0 0 12px}.react-flow__node{cursor:pointer}.react-flow__controls{box-shadow:0 2px 8px #00000026;border-radius:8px;overflow:hidden}.react-flow__controls-button{background:#fff;border:none;color:#333}.react-flow__controls-button:hover{background:#f5f5f5}.react-flow__minimap{background:#f8f9fa;border-radius:8px;box-shadow:0 2px 8px #00000026}.table-detail-panel{width:400px;background:#fff;border-radius:0 12px 12px 0;box-shadow:0 8px 25px #00000026;display:flex;flex-direction:column;overflow:hidden}.panel-header{color:#fff;padding:16px 20px;display:flex;justify-content:space-between;align-items:flex-start}.panel-header-content{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.panel-domain-icon{font-size:24px;flex-shrink:0}.panel-header-text{flex:1;min-width:0}.panel-header h3{margin:0;font-family:Courier New,monospace;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-domain-name{font-size:11px;opacity:.9}.close-panel{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}.close-panel:hover{background:#ffffff4d}.panel-content{flex:1;overflow-y:auto;padding:16px}.panel-stats{display:flex;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #eee}.stat-item{flex:1;text-align:center;padding:12px 8px;background:#f8f9fa;border-radius:8px}.stat-value{display:block;font-size:18px;font-weight:700;color:#333}.stat-label{display:block;font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.related-tables{display:flex;flex-direction:column;gap:6px}.related-table{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.related-table:hover{background:#e9ecef;transform:translate(4px)}.related-table.explicit{border-left:3px solid #1976d2}.related-table.implicit{border-left:3px solid #4caf50}.related-table-name{font-family:Courier New,monospace;font-size:12px;font-weight:600;color:#333}.related-table-type{font-size:10px;color:#666;background:#e9ecef;padding:2px 8px;border-radius:10px}.panel-section{margin-bottom:20px}.section-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#333;margin-bottom:10px;font-size:14px}.table-detail-panel .table-description{font-size:13px;color:#555;line-height:1.5;margin:0;padding:12px;background:#f8f9fa;border-radius:8px}.table-detail-panel .columns-list{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 600px);overflow-y:auto}.column-detail{background:#f8f9fa;border-radius:8px;padding:12px}.column-detail .column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.column-detail .column-name-row{display:flex;align-items:center;gap:6px}.column-detail .pk-badge{font-size:9px;font-weight:700;background:#ffc107;color:#333;padding:2px 5px;border-radius:3px}.column-detail .column-name{font-family:Courier New,monospace;font-weight:600;font-size:13px;color:#333}.column-detail .column-type{font-size:11px;color:#666;background:#e9ecef;padding:3px 8px;border-radius:4px}.column-detail .null-badge{display:inline-block;font-size:10px;color:#666;background:#e9ecef;padding:2px 6px;border-radius:4px;margin-bottom:6px}.column-detail .null-badge.high{background:#fff3cd;color:#856404}.column-detail .column-description{font-size:12px;color:#555;line-height:1.4;margin:8px 0}.table-detail-panel .propose-button{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.table-detail-panel .propose-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #007bff4d}.table-detail-panel .propose-button.small{padding:5px 10px;font-size:11px}@media (max-width: 1024px){.graph-legend{position:static;max-width:100%;border-radius:12px 12px 0 0;flex-shrink:0}.schema-graph-wrapper{flex-direction:column}.domain-filters{flex-direction:row;flex-wrap:wrap}.domain-filter{flex:1;min-width:140px}}@media (max-width: 768px){.schema-graph-wrapper{flex-direction:column;height:auto;min-height:400px}.graph-legend{max-height:none;overflow:visible}.schema-graph-container{height:400px;border-radius:0}.schema-graph-container.with-panel{border-radius:0}.table-detail-panel{width:100%;border-radius:0 0 12px 12px;max-height:50vh}.panel-stats{flex-wrap:wrap}.stat-item{min-width:calc(50% - 6px)}}.empty-canvas-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#888;z-index:5;pointer-events:none}.empty-canvas-hint .hint-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-canvas-hint .hint-text{font-size:16px;font-weight:500;margin-bottom:8px}.empty-canvas-hint .hint-subtext{font-size:13px;color:#aaa}.graph-toolbar{position:absolute;top:16px;right:16px;z-index:10;display:flex;gap:8px;background:#fff;padding:8px 12px;border-radius:8px;box-shadow:0 2px 12px #00000026;align-items:center}.toolbar-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;cursor:pointer;font-size:13px;font-weight:500;color:#333;transition:all .2s ease}.toolbar-btn:hover{background:#f5f5f5;border-color:#ccc}.toolbar-btn.primary{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none}.toolbar-btn.primary:hover{background:linear-gradient(135deg,#0056b3,#003d82)}.toolbar-btn.danger{color:#dc3545;border-color:#dc3545}.toolbar-btn.danger:hover{background:#dc3545;color:#fff}.toolbar-btn .btn-icon{font-size:14px}.toolbar-divider{width:1px;height:24px;background:#e0e0e0;margin:0 4px}.toolbar-stats{font-size:12px;color:#666;padding:0 8px}.domain-legend{position:absolute;top:16px;left:16px;z-index:10;background:#fff;border-radius:10px;box-shadow:0 2px 12px #0000001f;padding:12px 14px;min-width:180px}.legend-title{font-size:11px;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #eee}.legend-item{display:flex;align-items:center;gap:8px;padding:5px 0}.legend-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.legend-icon{font-size:14px;flex-shrink:0}.legend-label{font-size:12px;color:#444;font-weight:500}.schema-explorer{padding:20px;height:100%;overflow-y:auto;background:linear-gradient(135deg,#007bff,#0056b3)}.schema-header{margin-bottom:30px;text-align:center;color:#fff}.schema-header h2{margin-bottom:10px;font-size:2rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.schema-header p{font-size:1.1rem;opacity:.95}.schema-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 40px;color:#fff;font-size:16px}.schema-loading .loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.schema-loading p{margin:0;font-size:18px;font-weight:500}.schema-error{text-align:center;padding:40px;color:#fcc;font-size:16px}.schema-controls{margin-bottom:30px;display:flex;align-items:center;justify-content:center;gap:20px;max-width:900px;margin-left:auto;margin-right:auto;flex-wrap:wrap}.schema-search{display:flex;align-items:center;gap:15px;flex:1;min-width:300px}.schema-search input{flex:1;padding:15px 20px;border:none;border-radius:50px;font-size:16px;box-shadow:0 4px 15px #0003}.schema-search input:focus{outline:none;box-shadow:0 4px 20px #ffffff4d}.search-results{color:#fff;font-size:14px;white-space:nowrap;font-weight:500}.view-toggle{display:flex;gap:4px;background:#ffffff26;padding:4px;border-radius:25px}.toggle-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:20px;background:transparent;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.toggle-btn:hover{background:#ffffff1a}.toggle-btn.active{background:#fff;color:#007bff}.toggle-btn svg{width:16px;height:16px}.schema-tables{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px;max-width:1400px;margin:0 auto}.table-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;position:relative}.table-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0000002e}.table-header{padding:14px 18px;background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:12px;border-bottom:1px solid #e5e5e5}.table-header:hover{background:#fafafa}.expand-icon{font-size:10px;color:#555;transition:transform .3s}.table-card.expanded .expand-icon{transform:rotate(90deg)}.table-name{font-weight:600;font-size:14px;font-family:Courier New,monospace;color:#333;background:#e8eaed;padding:6px 14px;border-radius:16px}.table-meta{font-size:13px;color:#888;margin-left:auto}.table-body{padding:0;background:#fff}.table-description{background:#fff;padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:16px}.table-description p{margin:0;color:#5a6a7a;line-height:1.6;flex:1;font-size:13px}.propose-button{padding:8px 16px;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:all .2s;box-shadow:0 2px 8px #007bff4d}.propose-button:hover{transform:scale(1.05);box-shadow:0 4px 12px #007bff80}.propose-button.small{padding:6px 12px;font-size:12px}.columns-list{background:#fff;max-height:400px;overflow-y:auto}.columns-header{display:none}.column-item{padding:15px 20px;border-bottom:1px solid #f0f0f0;transition:background .2s}.column-item:hover{background:#f8f9fa}.column-item:last-child{border-bottom:none}.column-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.column-name{font-weight:600;color:#333;font-family:Courier New,monospace;font-size:14px;position:relative;padding-left:20px}.column-name:before{content:"├─";position:absolute;left:0;color:#007bff;font-weight:700}.column-item:last-child .column-name:before{content:"└─"}.column-type{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.column-null{background:#fff3cd;color:#856404;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.column-description{display:flex;justify-content:space-between;align-items:center;gap:15px;padding-left:20px}.column-description p{margin:0;color:#666;font-size:13px;line-height:1.5;flex:1}@media (max-width: 768px){.schema-controls{flex-direction:column;align-items:stretch}.schema-search{min-width:0}.view-toggle{justify-content:center}.toggle-btn{flex:1;justify-content:center}.schema-tables{grid-template-columns:1fr}}.schema-explorer::-webkit-scrollbar{width:8px}.schema-explorer::-webkit-scrollbar-track{background:#ffffff1a}.schema-explorer::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.schema-explorer::-webkit-scrollbar-thumb:hover{background:#ffffff80}.columns-list::-webkit-scrollbar{width:6px}.columns-list::-webkit-scrollbar-track{background:#f5f5f5}.columns-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.schema-empty{grid-column:1 / -1;text-align:center;padding:60px 40px;background:#fff;border-radius:12px;color:#666;font-size:16px}.explore-container{flex:1;overflow:hidden;background:#fff;height:100%;width:100%;display:flex;flex-direction:column}.explore-tabs{display:flex;gap:0;border-bottom:2px solid #e0e0e0;background:#f8f9fa;padding:0 2rem}.explore-tab{padding:1rem 2rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#666;transition:all .2s;margin-bottom:-2px}.explore-tab:hover{color:#007bff;background:#007bff0d}.explore-tab.active{color:#007bff;border-bottom-color:#007bff;background:#fff}.explore-content{max-width:100%;margin:0;padding:2rem 3rem;box-sizing:border-box;flex:1;min-height:0;overflow-y:auto}.helix-summary{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 12px #007bff4d}.helix-summary h2{margin:0 0 1rem;font-size:1.8rem}.helix-summary p{margin:0;font-size:1.1rem;line-height:1.6;opacity:.95}.explore-section{margin-bottom:2.5rem}.explore-section h3{color:#333;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.data-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.data-card{background:#f8f9fa;padding:1.5rem;border-radius:8px;border:1px solid #e0e0e0;transition:all .2s ease}.data-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#007bff}.data-card h4{color:#007bff;margin:0 0 .75rem;font-size:1.1rem}.data-card p{margin:0;color:#666;font-size:.9rem;line-height:1.5}.example-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.example-category{background:#fff;padding:1.5rem;border-radius:8px;border:1px solid #e0e0e0}.example-category h4{color:#333;margin:0 0 1rem;font-size:1.1rem}.example-category ul{margin:0;padding-left:1.25rem;list-style:none}.example-category li{margin-bottom:.75rem;color:#495057;font-size:.9rem;line-height:1.5;position:relative;padding-left:.5rem}.example-category li:before{content:"→";position:absolute;left:-1rem;color:#007bff;font-weight:700}.rating-guide{display:flex;flex-direction:column;gap:1.5rem}.rating-item{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.rating-icon{font-size:2rem;flex-shrink:0}.rating-item strong{display:block;color:#333;margin-bottom:.5rem;font-size:1rem}.rating-item p{margin:0;color:#666;font-size:.9rem;line-height:1.5}@media (max-width: 1400px){.explore-content{padding:2rem}}@media (max-width: 1024px){.data-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.example-categories{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 768px){.explore-content,.helix-summary{padding:1.5rem}.helix-summary h2{font-size:1.5rem}.data-cards,.example-categories{grid-template-columns:1fr}}.app{height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.header{background:#fff;padding:1rem 2rem;border-bottom:1px solid #e0e0e0;display:grid;grid-template-columns:60px 1fr auto auto;align-items:center;gap:1rem;box-shadow:0 2px 4px #0000001a}.main-tabs{display:flex;gap:.5rem;margin-right:1rem}.main-tab{padding:.5rem 1.5rem;background:#fff;border:2px solid #dee2e6;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;color:#495057;transition:all .2s ease}.main-tab:hover{background:#f8f9fa;border-color:#007bff}.main-tab.active{background:#007bff;color:#fff;border-color:#007bff}.sidebar-toggle{background:#007bff;border:none;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #007bff4d}.sidebar-toggle:hover{background:#0056b3;transform:translateY(-1px)}.logo-title{display:flex;align-items:center;gap:.75rem;min-width:0;justify-self:center}.logo{height:32px;width:auto;flex-shrink:0}.header h1{margin:0;color:#333;font-size:1.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:300px}.connection-info{display:flex;align-items:center;gap:1rem;flex-shrink:0}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#f8f9fa;border-radius:20px;border:1px solid #e0e0e0}.username{font-size:.9rem;color:#333;font-weight:500}.logout-button{padding:.25rem .75rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s}.logout-button:hover{background:#c82333}.status{font-weight:500;font-size:.9rem;padding:.25rem .75rem;border-radius:12px;transition:all .3s ease}.status.connected{color:#28a745;background:#d4edda}.status.disconnected{color:#dc3545;background:#f8d7da}.status.connecting,.status.reconnecting{color:#ffc107;background:#fff3cd}.retry-button{padding:.25rem .75rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s}.retry-button:hover{background:#0056b3}.main{flex:1;display:flex;overflow:hidden;margin-top:0}.sidebar{width:300px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;transition:all .3s ease;overflow:hidden;margin-top:0}.sidebar.collapsed{width:0;border-right:none}.sidebar-header{padding:1.5rem 1rem 1rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;margin-top:.5rem}.sidebar-header h3{margin:0;font-size:1rem;color:#333}.new-chat-btn{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:8px;width:32px;height:32px;cursor:pointer;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #007bff4d}.new-chat-btn:hover{background:linear-gradient(135deg,#0056b3,#004085);transform:translateY(-1px);box-shadow:0 4px 8px #007bff66}.conversations-list{flex:1;overflow-y:auto;padding:.5rem}.conversation-item{padding:.75rem;margin-bottom:.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.conversation-item:hover{background:#f8f9fa;border-color:#e0e0e0}.conversation-item.active{background:#e3f2fd;border-color:#007bff}.conversation-title{font-weight:500;font-size:.9rem;color:#333;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#666}.message-count{opacity:.8}.delete-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;opacity:.6;transition:all .2s}.delete-btn:hover{opacity:1;background:#f8d7da}.chat-container{flex:1;display:flex;flex-direction:column;height:100%;background:#fff;overflow:hidden;margin:1rem;margin-left:0;border-radius:12px;box-shadow:0 4px 6px #0000001a}.sidebar-right{width:280px;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;margin:1rem;margin-left:0;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;overflow:hidden}.sidebar-right.collapsed{width:44px;border-left:none;margin-left:0;margin-right:0}.sidebar-right.collapsed .sidebar-right-header{padding:.5rem;justify-content:center}.sidebar-right.collapsed .sidebar-right-tabs,.sidebar-right.collapsed .sidebar-right-content{display:none}.sidebar-right-header{padding:1.5rem 1rem 1rem;border-bottom:1px solid #e0e0e0;background:#f8f9fa;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}.sidebar-right-tabs{display:flex;gap:.25rem}.sidebar-right-tab{padding:.5rem .75rem;background:#fff;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;color:#495057;transition:all .2s ease;white-space:nowrap}.sidebar-right-tab:hover{background:#e9ecef;border-color:#007bff}.sidebar-right-tab.active{background:#007bff;color:#fff;border-color:#007bff}.sidebar-right-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s;flex-shrink:0}.sidebar-right-toggle:hover{background:#e9ecef}.sidebar-right.collapsed .sidebar-right-toggle{background:#007bff;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.sidebar-right.collapsed .sidebar-right-toggle:hover{background:#0056b3}.sidebar-right-content{flex:1;overflow-y:auto;padding:.5rem}.favorite-item{padding:.75rem;margin-bottom:.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid #e9ecef;background:#f8f9fa;position:relative}.favorite-item:hover{background:#e9ecef;border-color:#007bff}.favorite-text{font-size:.85rem;color:#495057;line-height:1.4;margin-bottom:.5rem}.favorite-actions{display:flex;justify-content:space-between;align-items:center}.use-btn{background:#007bff;color:#fff;border:none;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;cursor:pointer;transition:background-color .2s}.use-btn:hover{background:#0056b3}.remove-favorite-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;opacity:.6;transition:all .2s}.remove-favorite-btn:hover{opacity:1;background:#f8d7da}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-track{background:#f1f1f1}.messages::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.welcome{text-align:center;padding:2rem;color:#666}.welcome h2{color:#333;margin-bottom:.5rem;font-size:1.8rem}.welcome p{font-size:1.1rem;margin-bottom:2rem}.samples{margin-top:2rem;text-align:center;display:flex;flex-direction:column;align-items:center}.samples h3{margin-bottom:1rem;color:#333;font-size:1.2rem;text-align:center}.sample-btn{display:block;width:100%;max-width:500px;margin:.75rem auto;padding:1rem 1.5rem;background:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;text-align:center;transition:all .2s ease;font-size:.95rem;line-height:1.4}.sample-btn:hover:not(:disabled){background:#e9ecef;border-color:#007bff;transform:translateY(-1px);box-shadow:0 2px 8px #007bff26}.sample-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.message{display:flex;margin-bottom:1rem;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.assistant,.message.error{justify-content:flex-start}.message-content{max-width:75%;padding:1rem 1.25rem;border-radius:18px;word-wrap:break-word;position:relative}.message.user .message-content{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border-bottom-right-radius:6px}.message.assistant .message-content{background:#fff;border:1px solid #e0e0e0;box-shadow:0 2px 8px #00000014;border-bottom-left-radius:6px}.message.error .message-content{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;border-bottom-left-radius:6px}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-time{font-size:.75rem;opacity:.7;font-weight:500}.add-to-favorites-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);cursor:pointer;padding:.2rem .4rem;border-radius:6px;color:#fff;transition:all .2s;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.add-to-favorites-btn:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-1px)}.sql-query{margin-bottom:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #007bff}.sql-query strong{display:block;margin-bottom:.75rem;color:#333;font-size:.9rem}.sql-query code{display:block;font-family:Consolas,Monaco,Courier New,monospace;font-size:.85rem;white-space:pre-wrap;color:#495057;line-height:1.4;background:#fff;padding:.75rem;border-radius:4px;border:1px solid #dee2e6}.text-content{line-height:1.6;font-size:.95rem}.bullet-point{margin:.25rem 0;padding-left:1rem;color:#495057}.chart-container{margin:1rem 0;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #28a745}.chart-container strong{display:block;margin-bottom:.75rem;color:#333;font-size:.9rem}.chart-wrapper{background:#fff;padding:1rem;border-radius:4px;border:1px solid #dee2e6;max-height:400px;display:flex;justify-content:center;align-items:center}.chart-wrapper.enhanced{padding:1.5rem;box-shadow:0 2px 8px #0000001a}.pie-chart-container{width:100%;height:350px;display:flex;justify-content:center;align-items:center}.error-details{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2);opacity:.8}.loading{display:flex;align-items:center;gap:.75rem;color:#666;font-style:italic}.loading-dots{display:flex;gap:4px}.loading-dots span{width:6px;height:6px;border-radius:50%;background:#007bff;animation:bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.input-area{border-top:1px solid #e0e0e0;padding:1rem;background:#f8f9fa}.connection-error{background:#f8d7da;color:#721c24;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border:1px solid #f5c6cb}.input-container{display:flex;gap:.75rem;align-items:flex-end}.message-input{flex:1;padding:.75rem 1rem;border:2px solid #dee2e6;border-radius:24px;font-size:1rem;outline:none;transition:all .2s ease;font-family:inherit;line-height:1.4}.message-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.message-input:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed}.send-button{padding:.75rem 1rem;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:1.1rem;transition:all .2s ease;width:44px;height:44px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #007bff4d}.send-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #007bff66}.send-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.bookmark-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a52);border:none;border-radius:6px;padding:.4rem .6rem;cursor:pointer;color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;box-shadow:0 2px 4px #ff6b6b4d}.bookmark-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #ff6b6b66;background:linear-gradient(135deg,#ff5252,#e53935)}.message-actions{display:flex;gap:.25rem;margin-top:.75rem;padding-top:.5rem}.action-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:6px;color:#666;transition:all .2s;font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#f0f0f0}.thumbs-btn.liked{background:#e8f5e8;color:#28a745}.thumbs-btn.liked:hover{background:#d4edda}.comment-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e9ecef}.comment-input{width:100%;padding:.5rem;border:1px solid #dee2e6;border-radius:4px;font-size:.85rem;resize:vertical;min-height:60px}.comment-actions{display:flex;gap:.5rem;margin-top:.5rem}.comment-save-btn{background:#28a745;color:#fff;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.75rem;cursor:pointer;transition:background-color .2s}.comment-save-btn:hover{background:#218838}.comment-cancel-btn{background:#6c757d;color:#fff;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.75rem;cursor:pointer;transition:background-color .2s}.comment-cancel-btn:hover{background:#5a6268}.comment-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:.5rem;margin-bottom:.5rem;font-size:.85rem}.comment-text{color:#495057;line-height:1.4;margin-bottom:.25rem}.comment-meta{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#6c757d}.comment-delete{background:none;border:none;color:#dc3545;cursor:pointer;padding:.1rem;font-size:.7rem}.comment-entry{padding:.75rem;margin-bottom:.5rem;border-radius:8px;border:1px solid #e9ecef;background:#f8f9fa;cursor:pointer;transition:all .2s ease}.comment-entry:hover{background:#e9ecef;border-color:#007bff;transform:translateY(-1px)}.comment-entry-text{font-size:.85rem;color:#495057;line-height:1.4;margin-bottom:.5rem}.comment-entry-meta{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#6c757d}.comment-entry-context{font-style:italic;opacity:.8}.thinking-box{margin:.75rem 0;padding:1rem;background:linear-gradient(135deg,#f0f4ff,#e8f0fe);border-radius:8px;border-left:4px solid #4285f4;box-shadow:0 2px 4px #4285f41a}.thinking-box.active{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 2px 4px #4285f41a}50%{box-shadow:0 4px 8px #4285f433}}.thinking-header{font-weight:600;color:#1a73e8;margin-bottom:.75rem;font-size:.9rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s ease}.thinking-header:hover{background-color:#1a73e81a}.thinking-toggle{font-size:.8rem;color:#1a73e8;transition:transform .2s ease;-webkit-user-select:none;user-select:none}.thinking-steps{display:flex;flex-direction:column;gap:.5rem}.thinking-step{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem;background:#fff;border-radius:6px;animation:slideIn .3s ease-out;border:1px solid rgba(66,133,244,.1)}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.step-number{flex-shrink:0;width:24px;height:24px;background:linear-gradient(135deg,#4285f4,#1a73e8);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px #4285f44d}.step-text{flex:1;color:#5f6368;font-size:.85rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.thinking-step.loading-step{opacity:.7}.loading-spinner{flex-shrink:0;width:24px;height:24px;border:3px solid rgba(66,133,244,.2);border-top-color:#4285f4;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.thinking-step.streaming{background:linear-gradient(90deg,#f8f9fa,#e9ecef,#f8f9fa);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.section-header{font-weight:600;margin:1.25rem 0 .75rem;color:#1a73e8;font-size:1.1rem;padding-bottom:.25rem;border-bottom:2px solid #e8f0fe}.section-header:first-child{margin-top:0}.visualization-container{margin:1rem 0;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #28a745}.visualization-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.visualization-container strong{color:#333;font-size:.9rem;margin:0}.excel-btn:hover{background:#e8f5e8;color:#28a745}.table-wrapper{background:#fff;border-radius:4px;border:1px solid #dee2e6;overflow:hidden}.table-wrapper .table-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8f9fa;border-bottom:1px solid #dee2e6}.table-wrapper .table-header h4{margin:0;font-size:.9rem;color:#333;font-weight:600}.table-wrapper .table-info{font-size:.75rem;color:#666;background:#e9ecef;padding:.25rem .5rem;border-radius:12px}.table-scroll{max-height:400px;overflow-y:auto;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th{background:#f8f9fa;padding:.75rem 1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;position:sticky;top:0;z-index:10}.data-table td{padding:.5rem 1rem;border-bottom:1px solid #e9ecef;color:#495057}.data-table tr:hover{background:#f8f9fa}.data-table tr:nth-child(2n){background:#fdfdfd}.data-table tr:nth-child(2n):hover{background:#f8f9fa}@media (max-width: 768px){.table-scroll{max-height:300px}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.5rem .75rem}.viz-header{padding:.75rem 1rem}.viz-content{padding:.75rem}}.interactive-visualization{margin:1rem 0;background:#fff;border-radius:8px;border:1px solid #dee2e6;overflow:hidden;box-shadow:0 2px 8px #0000001a}.viz-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#f8f9fa;border-bottom:1px solid #dee2e6}.viz-header h4{margin:0;font-size:1rem;color:#333;font-weight:600}.viz-tabs{display:flex;gap:.25rem}.viz-tab{padding:.5rem .75rem;background:#fff;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;color:#495057;transition:all .2s ease;white-space:nowrap}.viz-tab:hover{background:#e9ecef;border-color:#007bff}.viz-tab.active{background:#007bff;color:#fff;border-color:#007bff}.viz-content{padding:1rem}.table-container{background:#fff}.table-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.table-filter{flex:1;max-width:300px;padding:.5rem .75rem;border:1px solid #dee2e6;border-radius:6px;font-size:.85rem;outline:none;transition:border-color .2s ease}.table-filter:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.interactive-table{width:100%;border-collapse:collapse;font-size:.85rem;background:#fff}.sortable-header{background:#f8f9fa;padding:.75rem 1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease;position:sticky;top:0;z-index:10}.sortable-header:hover{background:#e9ecef}.sort-indicator{color:#007bff;font-weight:700}.interactive-table td{padding:.5rem 1rem;border-bottom:1px solid #e9ecef;color:#495057}.interactive-table tr:hover{background:#f8f9fa}.interactive-table tr:nth-child(2n){background:#fdfdfd}.interactive-table tr:nth-child(2n):hover{background:#f8f9fa}.chart-container{background:#fff;padding:1rem;border-radius:6px;height:450px;display:flex;align-items:center;justify-content:center}.pie-chart-container{height:600px}.pie-chart-container canvas{max-width:600px!important;max-height:600px!important}.chart-error{color:#6c757d;font-style:italic;text-align:center;padding:2rem}.legacy-visualization{margin:1rem 0;padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;color:#856404}@media (max-width: 768px){.viz-tabs{flex-wrap:wrap;gap:.25rem}.viz-tab{padding:.4rem .6rem;font-size:.75rem}.table-controls{flex-direction:column;align-items:stretch;gap:.5rem}.table-filter{max-width:none}.interactive-table{font-size:.8rem}.sortable-header,.interactive-table td{padding:.5rem .75rem}}@media (max-width: 768px){.header{padding:.75rem 1rem;grid-template-columns:60px 1fr;grid-template-rows:auto auto}.header h1{font-size:1.25rem}.main-tabs{grid-column:1 / -1;justify-content:center;margin:.5rem 0 0}.connection-info{grid-column:1 / -1;justify-content:center;margin-top:.5rem}.sidebar{width:250px}.chat-container{border-radius:8px;margin:.5rem;margin-left:0}.sidebar-right{display:none}.favorites-toggle-mobile{display:block;position:fixed;top:50%;right:1rem;background:#007bff;color:#fff;border:none;border-radius:50%;width:44px;height:44px;cursor:pointer;font-size:1.2rem;box-shadow:0 2px 8px #007bff4d;z-index:300}.message-content{max-width:85%;padding:.75rem 1rem}.sample-btn{padding:.75rem 1rem;font-size:.9rem}.input-area{padding:.75rem}.message-input{font-size:16px}}@media (max-width: 480px){.sidebar{position:absolute;left:0;top:0;height:100%;z-index:200;box-shadow:2px 0 8px #0000001a}.sidebar.collapsed{left:-300px}.chat-container{margin:.25rem}}.star-rating{display:flex;gap:.25rem;margin-left:.5rem;padding-left:.5rem}.star-btn{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1.2rem;color:#ffc107;transition:all .2s;line-height:1}.rating-container{position:relative;display:inline-block}.star-trigger-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:6px;font-size:1rem;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.star-trigger-btn:hover,.star-trigger-btn.rated{background:#fff3cd}.rating-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:.5rem;background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1rem;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:280px;animation:popupFadeIn .2s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.rating-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:#fff}.rating-popup-header{font-size:.85rem;color:#495057;margin-bottom:.75rem;text-align:center;line-height:1.4;font-weight:600}.star-rating{display:flex;gap:.25rem;justify-content:center}.star-btn{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1.5rem;color:#ffc107;transition:all .2s;line-height:1}.star-btn:hover{transform:scale(1.2)}.star-btn.filled{color:#ffc107;text-shadow:0 0 2px rgba(255,193,7,.5)}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5}*{box-sizing:border-box}
