.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;opacity:0}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}#root{margin:0 auto;padding:.5rem;text-align:center}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.login-container form{display:flex;flex-direction:column;gap:1rem;width:300px}.chat-container{display:flex;flex-direction:column;height:98vh;width:100%;margin:0 auto;border:1px solid var(--border);border-radius:8px;overflow:hidden;background-color:var(--bg)}header{background:var(--bg-dark);color:var(--text);padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;background:var(--bg)}.message{max-width:80%;padding:1rem;border-radius:8px;text-align:left}.message.user{align-self:flex-end;background:var(--primary);color:var(--bg-dark)}.message.assistant{align-self:flex-start;background:var(--bg-light);border:1px solid var(--border-muted);color:var(--text)}.message.error{align-self:center;background:var(--danger);color:var(--text)}.input-area{padding:1rem;background:var(--bg-light);border-top:1px solid var(--border);display:flex;gap:1rem}input{flex:1;padding:.8rem;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:4px;font-size:1rem}input:focus{outline:2px solid var(--highlight);border-color:var(--highlight)}button{padding:.8rem 1.5rem;background:var(--primary);color:var(--bg-dark);border:none;border-radius:4px;cursor:pointer;font-weight:700}button:hover{background:var(--highlight)}button:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.logout-btn{background:var(--danger);color:var(--text);padding:.5rem 1rem;font-size:.8rem}.steps-container{margin-bottom:10px;text-align:left;background:var(--bg);border-radius:4px;padding:5px;border:1px solid var(--border-muted)}.steps-container details summary{cursor:pointer;font-size:.9em;color:var(--text-muted);padding:5px}.steps-list{margin-top:10px;padding:10px;background:var(--bg-light);border:1px solid var(--border-muted);border-radius:4px}.step-item{margin-bottom:15px;border-bottom:1px solid var(--border-muted);padding-bottom:10px}.step-item:last-child{border-bottom:none}.step-thought{font-style:italic;color:var(--text);margin-bottom:5px}.step-query-box{background:var(--bg-dark);color:var(--text);padding:10px;border-radius:4px;font-size:.85em;margin-top:5px;border:1px solid var(--border)}.step-label{font-weight:700;color:var(--text-muted);font-size:.8em;margin-bottom:2px}.step-query-box code{display:block;color:var(--info);margin-bottom:8px;white-space:pre-wrap}.step-result{margin:0;color:var(--success);white-space:pre-wrap;max-height:200px;overflow-y:auto}.message table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.message th,.message td{padding:.75rem;border:1px solid var(--border-muted);text-align:left}.message th{background-color:var(--bg-dark);color:var(--text);font-weight:700}.message tr:nth-child(2n){background-color:var(--bg-light)}.message tr:hover{background-color:var(--bg-dark)}.header-controls{display:flex;gap:10px;align-items:center}.mode-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.5rem 1rem;cursor:pointer;transition:all .2s}.mode-btn.active{background:var(--primary);color:var(--bg-dark);border-color:var(--primary)}.mode-btn:hover:not(.active){background:var(--bg-light);color:var(--text)}.sql-container{flex:1;display:flex;flex-direction:column;padding:1rem;gap:1rem;overflow:hidden}.sql-form{display:flex;flex-direction:column;gap:1rem;flex:1}.sql-input{flex:1;background:var(--bg-dark);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:1rem;font-family:Consolas,Monaco,monospace;font-size:.9rem;resize:none;min-height:150px}.sql-input:focus{outline:2px solid var(--highlight);border-color:var(--highlight)}.sql-run-btn{align-self:flex-end;background:var(--success);color:#fff}.sql-error{background:#ff00001a;border:1px solid var(--danger);color:var(--danger);padding:1rem;border-radius:4px}.sql-result{flex:2;overflow:hidden;display:flex;flex-direction:column;gap:.5rem}.sql-message{color:var(--success);font-weight:700}.table-wrapper{overflow:auto;border:1px solid var(--border);border-radius:4px;flex:1;min-height:0}.table-wrapper table{width:100%;border-collapse:collapse;font-size:.9rem}.table-wrapper th,.table-wrapper td{padding:.75rem;border:1px solid var(--border-muted);text-align:left;white-space:nowrap}.table-wrapper th{background-color:var(--bg-dark);color:var(--text);font-weight:700;position:sticky;top:0}.table-wrapper tr:nth-child(2n){background-color:var(--bg-light)}.table-wrapper tr:hover{background-color:var(--bg-dark)}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--bg-dark: oklch(.1 .025 264);--bg: oklch(.15 .025 264);--bg-light: oklch(.2 .025 264);--text: oklch(.96 .05 264);--text-muted: oklch(.76 .05 264);--highlight: oklch(.5 .05 264);--border: oklch(.4 .05 264);--border-muted: oklch(.3 .05 264);--primary: oklch(.76 .1 264);--secondary: oklch(.76 .1 84);--danger: oklch(.7 .05 30);--warning: oklch(.7 .05 100);--success: oklch(.7 .05 160);--info: oklch(.7 .05 260);color-scheme:dark;color:var(--text);background-color:var(--bg-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--primary);text-decoration:inherit}a:hover{color:var(--secondary)}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg-dark);color:var(--text)}h1{font-size:3.2em;line-height:1.1;color:var(--primary)}button{border-radius:8px;border:1px solid var(--border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-light);color:var(--text);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--primary)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}
