*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--bg2: #161b27;--bg3: #1e2535;--border: #2a3347;--accent: #3b82f6;--accent2: #6366f1;--success: #22c55e;--danger: #ef4444;--warn: #f59e0b;--text: #e2e8f0;--text2: #94a3b8;--text3: #64748b;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.4);--side-w: 252px}html,body,#root{height:100%;font-family:Inter,sans-serif;background:var(--bg);color:var(--text)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}a{color:var(--accent);text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}p{margin:0}.chat-root{display:flex;height:100dvh;overflow:hidden;background:var(--bg);position:relative}.sidebar{width:var(--side-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;z-index:50}.sidebar-mobile{position:fixed;top:0;left:0;bottom:0;width:270px;transform:translate(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);box-shadow:6px 0 30px #0009}.sidebar-mobile.sidebar-open{transform:translate(0)}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:40}.side-head{display:flex;align-items:center;justify-content:space-between;padding:18px 14px 10px;flex-shrink:0}.brand{display:flex;align-items:center;gap:10px}.brand-name{font-size:17px;font-weight:700;color:var(--text)}.stage-row{padding:0 14px 10px;flex-shrink:0}.stage-pill{display:inline-block;background:#3b82f626;color:var(--accent);font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;border:1px solid rgba(59,130,246,.3);letter-spacing:.05em}.chat-list{padding:6px 10px 2px;max-height:38vh;overflow-y:auto;flex-shrink:0;border-bottom:1px solid var(--border)}.side-label{display:block;font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.1em;margin:4px 2px 6px}.chat-item{display:flex;align-items:center;border-radius:8px;margin-bottom:2px;border:1px solid transparent}.chat-item.active{background:#3b82f61a;border-color:#3b82f633}.chat-item-btn{flex:1;display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text2);padding:8px;cursor:pointer;text-align:left;min-width:0}.chat-item.active .chat-title{color:var(--text)}.chat-title{font-size:12px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.del-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:6px 8px;font-size:11px;opacity:.6;flex-shrink:0}.del-btn:hover{opacity:1;color:var(--danger)}.quick-list{flex:1;overflow-y:auto;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.suggestion{background:none;border:1px solid var(--border);border-radius:8px;padding:7px 10px;color:var(--text2);font-size:12px;text-align:left;cursor:pointer;transition:border-color .15s,color .15s}.suggestion:hover{border-color:var(--accent);color:var(--text)}.side-foot{padding:10px 12px 14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;flex-shrink:0}.admin-btn{background:#6366f126;border:1px solid rgba(99,102,241,.3);color:#818cf8;border-radius:8px;padding:8px 12px;font-size:13px;text-align:left}.user-row{display:flex;align-items:center;gap:10px}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#6366f1);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column;gap:2px;min-width:0}.user-name{font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:none;border:none;color:var(--text3);font-size:12px;padding:0;text-align:left}.icon-btn{background:var(--bg3);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text2);flex-shrink:0;transition:border-color .15s}.icon-btn:hover{border-color:var(--accent);color:var(--text)}.icon-btn-sm{background:none;border:none;font-size:16px;padding:4px 6px;border-radius:8px;color:var(--text2)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}.hamburger-btn{background:none;border:none;display:flex;flex-direction:column;gap:5px;padding:4px;flex-shrink:0}.hamburger-btn span{display:block;width:22px;height:2px;background:var(--text2);border-radius:2px;transition:background .15s}.hamburger-btn:hover span{background:var(--text)}.top-brand{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:var(--text);flex:1}.ctx-panel{background:var(--bg2);border-bottom:1px solid var(--border);padding:8px 16px;flex-shrink:0}.ctx-panel-mobile{position:absolute;top:53px;left:0;right:0;z-index:30;border-bottom:1px solid var(--border);box-shadow:0 4px 16px #0006}.ctx-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ctx-label{font-size:12px;color:var(--text2);font-weight:500;white-space:nowrap}.ctx-modes{display:flex;gap:4px}.ctx-mode-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:4px 10px;font-size:12px;transition:all .15s}.ctx-mode-btn.active{background:#3b82f626;border-color:#3b82f666;color:var(--accent);font-weight:600}.ctx-pairs{display:flex;align-items:center;gap:8px}.ctx-slider{width:90px;accent-color:var(--accent);cursor:pointer}.ctx-val{font-size:12px;color:var(--accent);font-weight:700;min-width:16px}.ctx-close{background:none;border:none;color:var(--text3);font-size:14px;margin-left:auto;padding:2px 6px}.messages{flex:1;overflow-y:auto;padding:20px 20px 8px;display:flex;flex-direction:column;gap:14px}.msg-user-wrap{display:flex;justify-content:flex-end}.msg-user{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border-radius:16px 4px 16px 16px;padding:10px 15px;max-width:min(82%,600px);font-size:14px;line-height:1.5;word-break:break-word}.msg-ai{display:flex;align-items:flex-start;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:4px 16px 16px;padding:12px 14px;max-width:min(90%,720px)}.msg-ai-text{font-size:14px;line-height:1.65;color:var(--text)}.msg-ai-text p{margin:2px 0}.msg-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:10px 14px;color:#ef4444;font-size:14px;max-width:min(90%,720px);word-break:break-word}.msg-result{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px;width:100%;min-width:0;overflow:hidden}.result-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.tags{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;border:1px solid}.tag-blue{background:#3b82f626;color:#60a5fa;border-color:#3b82f640}.tag-amber{background:#f59e0b1f;color:#f59e0b;border-color:#f59e0b40}.tag-green{background:#22c55e1f;color:#22c55e;border-color:#22c55e40}.tag-gray{background:#64748b26;color:#94a3b8;border-color:#64748b40}.table-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--border);margin-bottom:8px;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--bg3);padding:7px 12px;text-align:left;color:var(--text2);font-weight:600;font-size:11px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:7px 12px;color:var(--text);border-bottom:1px solid rgba(255,255,255,.04);white-space:nowrap}.row-alt{background:#ffffff05}.table-more{font-size:11px;color:var(--text3);padding:5px 10px}.sql-summary{font-size:12px;color:var(--text3);cursor:pointer;padding:4px 0;-webkit-user-select:none;user-select:none}.sql-pre{background:var(--bg3);border-radius:6px;padding:10px 12px;font-size:11px;font-family:JetBrains Mono,monospace;color:#93c5fd;margin-top:6px;overflow-x:auto;line-height:1.5;-webkit-overflow-scrolling:touch;white-space:pre}.bot-dot{width:22px;height:22px;flex-shrink:0;margin-top:1px}.typing-dots{display:flex;gap:4px;align-items:center;height:22px}.typing-dots span{display:block;width:6px;height:6px;border-radius:50%;background:var(--text3);animation:ba-bounce 1.2s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes ba-bounce{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.input-bar{padding:10px 16px 14px;border-top:1px solid var(--border);background:var(--bg);flex-shrink:0}.input-wrap{display:flex;gap:8px;align-items:flex-end;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:8px 8px 8px 12px;transition:border-color .2s}.input-wrap:focus-within{border-color:#3b82f680}.ctx-toggle-btn{background:none;border:none;font-size:17px;padding:2px 4px;border-radius:6px;flex-shrink:0;transition:opacity .15s;align-self:center}.input-textarea{flex:1;background:none;border:none;color:var(--text);font-size:14px;resize:none;outline:none;line-height:1.5;max-height:120px;min-width:0}.send-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}.input-hint{font-size:11px;color:var(--text3);margin-top:5px;text-align:center}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow)}.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:36px}.login-title{font-size:24px;font-weight:700}.login-sub{font-size:13px;color:var(--text2);margin-top:2px}.login-form{display:flex;flex-direction:column;gap:18px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--text2)}.form-input{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s;width:100%}.form-input:focus{border-color:#3b82f699}.form-select{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-size:14px;outline:none;width:100%}.form-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 14px;color:#ef4444;font-size:13px}.form-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:600;margin-top:4px;transition:opacity .2s;width:100%}.login-hint{margin-top:20px;font-size:12px;color:var(--text3);text-align:center}@media (max-width: 720px){.messages{padding:14px 12px 6px;gap:12px}.msg-user{max-width:88%;font-size:13px}.msg-ai{max-width:98%;font-size:13px;padding:10px 12px}.msg-error{max-width:98%}.msg-result{padding:12px}.input-bar{padding:8px 10px 12px}.login-card{padding:28px 20px}.data-table th,.data-table td{padding:6px 10px;font-size:12px}}
