*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0f14;--surface:#161820;--surface2:#1e2028;--border:#2a2d3a;--text:#c9ccd6;--text-dim:#6b7280;--text-h:#f1f2f6;--accent:#6366f1;--accent-h:#818cf8;--green:#22c55e;--yellow:#eab308;--red:#ef4444;--radius:8px;--sidebar:240px}html,body,#root{height:100%;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,sans-serif;font-size:14px}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}input,textarea{font:inherit;color:inherit;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);outline:none}input:focus,textarea:focus{border-color:var(--accent)}.layout{height:100%;display:flex}.nav-sidebar{width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;padding:16px 0;display:flex}.nav-logo{color:var(--text-h);border-bottom:1px solid var(--border);margin-bottom:8px;padding:0 16px 20px;font-size:15px;font-weight:600}.nav-item{color:var(--text-dim);border-radius:0;align-items:center;gap:10px;padding:9px 16px;font-size:13.5px;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--surface2);color:var(--accent-h)}.nav-icon{text-align:center;width:20px;font-size:16px}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.page-pane{flex-direction:column;flex:1;min-height:0}.chat-layout{height:100%;display:flex;overflow:hidden}.thread-sidebar{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow:hidden}.thread-sidebar-header{border-bottom:1px solid var(--border);color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;justify-content:space-between;align-items:center;padding:12px 14px;font-size:12px;font-weight:600;display:flex}.btn-icon{color:var(--text-dim);border-radius:5px;padding:4px 8px;font-size:18px;line-height:1}.btn-icon:hover{background:var(--surface2);color:var(--text)}.thread-list{flex:1;padding:6px 0;overflow-y:auto}.thread-item{cursor:pointer;color:var(--text);white-space:nowrap;text-overflow:ellipsis;border-radius:6px;margin:1px 6px;padding:8px 14px;font-size:13px;transition:background .12s;overflow:hidden}.thread-item:hover{background:var(--surface2)}.thread-item.active{background:var(--accent);color:#fff}.chat-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.messages-area{flex-direction:column;flex:1;gap:20px;padding:24px 32px;display:flex;overflow-y:auto}.message-row{gap:12px;display:flex}.message-row.user{flex-direction:row-reverse}.msg-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:600;display:flex}.msg-avatar.user{background:var(--accent);color:#fff}.msg-avatar.assistant{background:var(--surface2);color:var(--text-h)}.msg-bubble{white-space:pre-wrap;word-break:break-word;border-radius:12px;max-width:70%;padding:10px 14px;font-size:13.5px;line-height:1.55}.msg-bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:3px}.msg-bubble.assistant{background:var(--surface2);color:var(--text-h);border-bottom-left-radius:3px}.step-timeline{flex-wrap:wrap;gap:6px;padding:4px 14px;display:flex}.step-chip{border:1px solid var(--border);color:var(--text-dim);border-radius:20px;padding:2px 8px;font-size:11px}.step-chip.running{border-color:var(--accent);color:var(--accent-h)}.step-chip.done{border-color:var(--green);color:var(--green)}.citations-bar{border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap;gap:8px;padding:8px 32px;display:flex}.citation-tag{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;border-radius:4px;max-width:200px;padding:3px 8px;font-size:11px;overflow:hidden}.grade-badge{border-radius:4px;margin-left:auto;padding:3px 8px;font-size:11px;font-weight:600}.grade-A{color:var(--green);background:#14532d33}.grade-B{color:var(--yellow);background:#422006aa}.grade-C,.grade-D{color:var(--red);background:#450a0a33}.grade-sufficient,.grade-high{color:var(--green);background:#14532d33}.grade-weak,.grade-medium{color:var(--yellow);background:#422006aa}.grade-insufficient,.grade-low{color:var(--red);background:#450a0a33}.detail-panel{border-left:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.detail-panel-header{border-bottom:1px solid var(--border);color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 14px;font-size:12px;font-weight:600;display:flex}.detail-panel-body{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.detail-panel-empty{color:var(--text-dim);text-align:center;flex:1;justify-content:center;align-items:center;padding:16px;font-size:12px;display:flex}.message-row.assistant.selected .msg-bubble{outline:1px solid var(--accent);outline-offset:2px}.resize-handle{cursor:col-resize;background:0 0;flex:0 0 5px;align-self:stretch;transition:background .15s}.resize-handle:hover,.resize-handle:active{background:var(--accent)}.msg-content{flex-direction:column;gap:6px;min-width:0;max-width:72%;display:flex}.message-row.assistant .msg-content{align-items:flex-start;max-width:86%}.message-row.user .msg-content{align-items:flex-end}.msg-content .msg-bubble{max-width:100%}.rag-detail{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;overflow:hidden}.rag-detail-summary{cursor:pointer;color:var(--text-dim);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:7px 12px;font-size:12px;display:flex}.rag-detail-summary:hover{color:var(--text)}.rag-detail.open .rag-detail-summary{border-bottom:1px solid var(--border)}.rag-detail-count{background:var(--surface2);color:var(--text);border-radius:20px;padding:1px 7px;font-size:11px}.rag-detail-summary .grade-badge{margin-left:auto}.rag-detail-body{flex-direction:column;gap:12px;padding:10px 12px;display:flex}.rag-steps{flex-wrap:wrap;gap:6px;display:flex}.rag-citations{flex-direction:column;gap:8px;list-style:none;display:flex}.rag-citation{border-left:2px solid var(--accent);padding:4px 0 4px 10px}.rag-citation-head{flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:3px;display:flex}.rag-citation-label{color:var(--accent-h);font-size:12px;font-weight:600}.rag-citation-file{color:var(--text-h);font-size:12.5px;font-weight:500}.rag-citation-loc{color:var(--text-dim);font-size:11px}.rag-citation-snippet{color:var(--text);white-space:pre-wrap;word-break:break-word;font-size:12.5px;line-height:1.5}.rag-empty{color:var(--text-dim);font-size:12px}.composer{border-top:1px solid var(--border);background:var(--surface);gap:10px;padding:16px 32px;display:flex}.composer-input{border-radius:var(--radius);resize:none;flex:1;min-height:42px;max-height:160px;padding:10px 14px;line-height:1.5}.btn-send{border-radius:var(--radius);background:var(--accent);color:#fff;align-self:flex-end;padding:10px 18px;font-size:14px;font-weight:500;transition:background .15s,opacity .15s}.btn-send:hover{background:var(--accent-h)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.empty-state{color:var(--text-dim);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;display:flex}.empty-state h2{color:var(--text);font-size:18px;font-weight:500}.kb-page{flex-direction:column;gap:24px;padding:32px;display:flex;overflow-y:auto}.kb-header{justify-content:space-between;align-items:center;display:flex}.kb-title{color:var(--text-h);font-size:18px;font-weight:600}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--text-dim);cursor:pointer;padding:32px;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:#6366f108}.upload-zone input{display:none}.doc-table{border-collapse:collapse;width:100%}.doc-table th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px;font-weight:600}.doc-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:13px}.doc-table tr:last-child td{border-bottom:none}.doc-table tr:hover td{background:var(--surface2)}.status-badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.status-ready,.status-indexed{color:var(--green);background:#14532d33}.status-processing,.status-uploaded{color:#60a5fa;background:#1e3a5f33}.status-failed{color:var(--red);background:#450a0a33}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:var(--bg);justify-content:center;align-items:center;height:100%;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:360px;padding:36px 32px}.login-card h1{color:var(--text-h);text-align:center;margin-bottom:4px;font-size:22px;font-weight:600}.login-subtitle{text-align:center;color:var(--text-dim);margin-bottom:24px;font-size:13px}.form-field{margin-bottom:16px}.form-field label{color:var(--text-dim);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-field input{width:100%;padding:10px 12px}.login-error{color:var(--red);margin-bottom:12px;font-size:13px}.login-btn{border-radius:var(--radius);background:var(--accent);color:#fff;width:100%;padding:10px;font-size:14px;font-weight:500;transition:background .15s}.login-btn:hover{background:var(--accent-h)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-switch{text-align:center;color:var(--text-dim);margin-top:16px;font-size:13px}.login-switch button{color:var(--accent-h);margin-left:4px;font-size:13px}.login-switch button:hover{text-decoration:underline}
