:root,[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #e0e0e0;--accent-color: #2563eb;--accent-hover: #1d4ed8;--error-color: #dc2626;--success-color: #16a34a;--warning-color: #d97706;--user-bubble: #2563eb;--user-text: #ffffff;--assistant-bubble: #f0f0f0;--assistant-text: #1a1a1a;--input-bg: #ffffff;--input-text: #1a1a1a;--select-bg: #ffffff;--select-text: #1a1a1a;--error-msg-bg: #fef2f2;--error-msg-border: #fecaca}[data-theme=dark]{--bg-primary: #1e1e2e;--bg-secondary: #282840;--bg-tertiary: #313150;--text-primary: #e0e0e0;--text-secondary: #9a9ab0;--border-color: #3a3a55;--accent-color: #6d8cff;--accent-hover: #5a7aff;--error-color: #f87171;--success-color: #4ade80;--warning-color: #fbbf24;--user-bubble: #4a6cf7;--user-text: #ffffff;--assistant-bubble: #2a2a42;--assistant-text: #e0e0e0;--input-bg: #282840;--input-text: #e0e0e0;--select-bg: #282840;--select-text: #e0e0e0;--error-msg-bg: #3b1c1c;--error-msg-border: #6b2a2a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.app-header h1{font-size:16px;font-weight:600}.app-body{display:flex;flex:1;overflow:hidden}.chat-area{display:flex;flex-direction:column;flex:1;overflow:hidden;transition:flex .2s,width .2s}.chat-area.collapsed{flex:none;width:140px;overflow-y:hidden}.message-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.message{max-width:80%;padding:10px 14px;border-radius:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.message.user{align-self:flex-end;background:var(--user-bubble);color:var(--user-text);border-bottom-right-radius:4px}.message.assistant{align-self:flex-start;background:var(--assistant-bubble);color:var(--assistant-text);border-bottom-left-radius:4px}.message.error{align-self:center;background:var(--error-msg-bg);color:var(--error-color);border:1px solid var(--error-msg-border);font-size:13px}.input-area{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-primary);align-items:flex-end;flex-shrink:0}.input-area textarea{flex:1;resize:none;border:1px solid var(--border-color);border-radius:8px;padding:10px 12px;font-size:14px;font-family:inherit;line-height:1.5;max-height:150px;outline:none;transition:border-color .2s;background:var(--input-bg);color:var(--input-text)}.input-area textarea:focus{border-color:var(--accent-color)}.input-area textarea:disabled{background:var(--bg-secondary)}.btn{padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-icon{background:none;border:1px solid var(--border-color);border-radius:8px;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-icon:hover{background:var(--bg-secondary)}.btn-icon svg{fill:var(--text-primary)}.theme-toggle{background:none;border:1px solid var(--border-color);border-radius:8px;padding:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;color:var(--text-primary)}.theme-toggle:hover{background:var(--bg-secondary)}.attachment-bar{display:flex;gap:8px;padding:8px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-wrap:wrap;align-items:center;flex-shrink:0}.attachment-item{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;font-size:12px}.attachment-item img{width:32px;height:32px;object-fit:cover;border-radius:4px}.attachment-item .remove-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:14px;padding:0 2px}.attachment-item .remove-btn:hover{color:var(--error-color)}.model-selector{display:flex;align-items:center;gap:8px}.model-selector select{padding:4px 8px;border:1px solid var(--border-color);border-radius:6px;font-size:13px;background:var(--select-bg);color:var(--select-text);outline:none}.status-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.connected{background:var(--success-color)}.status-dot.disconnected{background:var(--error-color)}.status-dot.loading{background:var(--warning-color);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.review-panel{flex:1;border-left:1px solid var(--border-color);display:flex;flex-direction:column;background:var(--bg-primary);overflow-y:auto;transition:flex .2s,width .2s}.review-panel.collapsed{flex:none;width:140px;overflow-y:hidden}.review-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--border-color)}.review-toggle{display:flex;align-items:center;gap:6px;font-size:13px}.review-content{padding:12px;flex:1;display:flex;flex-direction:column;overflow:hidden}.verdict-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.verdict-badge.pass{background:#dcfce7;color:#166534}.verdict-badge.warn{background:#fef9c3;color:#854d0e}.verdict-badge.fail{background:#fef2f2;color:#991b1b}.verdict-badge.insufficient{background:#f3f4f6;color:#4b5563}.verdict-badge.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.review-summary{margin-top:12px;font-size:13px;line-height:1.6}.review-keypoints{margin-top:12px;padding-left:16px;font-size:13px;line-height:1.8}.review-loading{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:13px}.rag-section,.review-section{margin-bottom:16px}.review-section{flex:1;overflow-y:auto}.rag-section.expanded{flex:1;display:flex;flex-direction:column;margin-bottom:0;overflow:hidden}.rag-section.expanded .rag-result{max-height:none;flex:1}.section-title{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-color)}.rag-result{font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;padding:8px;background:var(--bg-secondary);border-radius:6px}.streaming-cursor{display:inline-block;width:2px;height:1em;background:var(--text-primary);margin-left:2px;vertical-align:text-bottom;animation:blink .8s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.capture-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;cursor:crosshair;background:#0000004d}.capture-overlay canvas{position:absolute;top:0;left:0}.capture-hint{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:8px;font-size:13px;z-index:10000}.drop-zone-active{position:fixed;top:0;left:0;width:100%;height:100%;background:#2563eb1a;border:3px dashed var(--accent-color);z-index:100;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--accent-color);pointer-events:none}.token-gate-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.token-gate-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 36px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:360px;max-width:90vw}.token-gate-title{font-size:20px;font-weight:600;color:var(--text-primary)}.token-gate-desc{font-size:14px;color:var(--text-secondary);text-align:center}.token-gate-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-family:inherit;background:var(--input-bg);color:var(--input-text);outline:none;transition:border-color .2s}.token-gate-input:focus{border-color:var(--accent-color)}.token-gate-btn{width:100%}
