.code-block-container{margin:12px 0;border:1px solid #3c3c3c;border-radius:8px;background:#2d2d30;overflow:hidden;box-shadow:0 2px 8px #0000004d;max-width:100%;box-sizing:border-box}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#3c3c3c;border-bottom:1px solid #4b4b4b}.expand-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:#ccc;font-size:14px;padding:4px 8px;border-radius:4px;transition:background-color .2s}.expand-toggle:hover{background-color:#4b4b4b}.language-tag{font-weight:500;text-transform:uppercase;font-size:12px;color:#9cdcfe}.line-count{font-size:12px;color:#9ca3af;font-style:italic}.copy-button{display:flex;align-items:center;gap:4px;background:#0078d4;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.copy-button:hover{background:#106ebe}.copy-button:active{background:#005a9e}.code-content{transition:max-height .3s ease-out;overflow:hidden;position:relative}.code-content.collapsed{max-height:120px}.code-content.expanded{max-height:none}.code-content pre{margin:0;padding:16px;background:#1e1e1e;font-family:Fira Code,Monaco,Consolas,Ubuntu Mono,monospace;font-size:13px;line-height:1.5;color:#d4d4d4;overflow-x:auto;border-radius:0;white-space:pre;word-wrap:normal;box-sizing:border-box}.code-content code{background:none;padding:0;border-radius:0;font-family:inherit}.code-content .language-python{color:#d4d4d4}.code-content pre{--keyword-color: #569cd6;--string-color: #ce9178;--comment-color: #6a9955;--number-color: #b5cea8;--function-color: #dcdcaa;--variable-color: #9cdcfe;--operator-color: #d4d4d4}.code-content pre code{color:#d4d4d4}.code-content pre code.language-csv{font-family:Courier New,Monaco,Consolas,monospace;letter-spacing:.5px}.code-content pre code.language-json,.code-content pre code.language-python,.code-content pre code.language-javascript{color:#d4d4d4}.code-content pre::-webkit-scrollbar{height:8px;width:8px}.code-content pre::-webkit-scrollbar-track{background:#2d2d30}.code-content pre::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.code-content pre::-webkit-scrollbar-thumb:hover{background:#777}.code-content pre ::selection{background:#add6ff4d}.code-content pre ::-moz-selection{background:#add6ff4d}@media (prefers-color-scheme: light){.code-block-container{border-color:#e0e0e0;background:#f8f9fa}.code-block-header{background:#e9ecef;border-bottom-color:#dee2e6}.expand-toggle{color:#495057}.expand-toggle:hover{background-color:#dee2e6}.language-tag,.line-count{color:#6c757d}.code-content pre{background:#fff;color:#333}.copy-button{background:#007bff}.copy-button:hover{background:#0056b3}}@media (max-width: 768px){.code-block-container{margin:8px 0;border-radius:6px}.code-block-header{padding:6px 8px;flex-wrap:wrap;gap:4px}.code-content pre{padding:12px 8px;font-size:12px;line-height:1.4}.copy-button,.expand-toggle{padding:3px 6px;font-size:11px}.language-tag{font-size:11px}.line-count{font-size:10px}.code-content.collapsed{max-height:100px}}@media (max-width: 480px){.code-block-header{flex-direction:column;align-items:stretch}.expand-toggle,.copy-button{width:100%;justify-content:center;margin:2px 0}.code-content pre{font-size:11px;padding:8px}}.image-modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;max-width:90vw;max-height:90vh;width:auto;height:auto;overflow:hidden;animation:imageModalFadeIn .3s ease-out;display:flex;flex-direction:column}@keyframes imageModalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.image-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background-color:#f9fafb;flex-shrink:0}.image-modal-title{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.image-modal-actions{display:flex;gap:.5rem;align-items:center}.image-modal-download,.image-modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.image-modal-download:hover{background-color:#e5e7eb;color:#374151}.image-modal-close:hover{background-color:#fee2e2;color:#dc2626}.image-modal-body{padding:1rem;display:flex;justify-content:center;align-items:center;flex-grow:1;min-height:0}.image-modal-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 12px #0000001a}@media (max-width: 768px){.image-modal-content{max-width:95vw;max-height:95vh;margin:1rem}.image-modal-header{padding:.75rem 1rem}.image-modal-title{font-size:1rem}.image-modal-body{padding:.75rem}.image-modal-download,.image-modal-close{padding:.375rem}}@media (prefers-color-scheme: dark){.image-modal-content{background:#1f2937}.image-modal-header{border-bottom-color:#374151;background-color:#111827}.image-modal-title{color:#f9fafb}.image-modal-download,.image-modal-close{color:#9ca3af}.image-modal-download:hover{background-color:#374151;color:#f3f4f6}.image-modal-close:hover{background-color:#7f1d1d;color:#fca5a5}}.image-modal-backdrop{animation:backdropFadeIn .3s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.reference-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.reference-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;max-width:700px;width:100%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.reference-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.reference-modal-title{display:flex;align-items:center;gap:.75rem}.reference-modal-title h3{margin:0;font-size:1.25rem;font-weight:600}.reference-modal-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.reference-modal-close:hover{background:#fff3;border-color:#ffffff4d}.reference-modal-body{flex:1;overflow-y:auto;padding:1.5rem}.reference-content{line-height:1.6;color:#2d3748}.reference-header{color:#2b6cb0;font-size:1.1rem;font-weight:600;margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.reference-header:first-child{margin-top:0}.reference-paragraph{margin:.75rem 0;color:#4a5568}.reference-bullet{margin:.5rem 0;color:#4a5568;padding-left:1rem;position:relative}.reference-bullet:before{content:"•";color:#667eea;font-weight:700;position:absolute;left:0}.reference-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f7fafc}.reference-type-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:6px;border:none;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;font-size:.875rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}@media (max-width: 768px){.reference-modal-backdrop{padding:.5rem}.reference-modal-content{max-height:90vh}.reference-modal-header{padding:1rem}.reference-modal-title h3{font-size:1.1rem}.reference-modal-body{padding:1rem}.reference-modal-footer{padding:.75rem 1rem;flex-direction:column;gap:.75rem;align-items:stretch}.reference-type-badge{text-align:center}}.chat-interface.dark .reference-modal-content{background:#2d3748}.chat-interface.dark .reference-modal-header{border-bottom-color:#4a5568}.chat-interface.dark .reference-modal-body,.chat-interface.dark .reference-content{color:#e2e8f0}.chat-interface.dark .reference-header{color:#90cdf4;border-bottom-color:#4a5568}.chat-interface.dark .reference-paragraph,.chat-interface.dark .reference-bullet{color:#cbd5e0}.chat-interface.dark .reference-modal-footer{background:#1a202c;border-top-color:#4a5568}.reference-button-container{margin:.5rem 0;display:flex;justify-content:flex-start}.reference-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #667eea33;text-decoration:none;max-width:fit-content}.reference-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.reference-button:active{transform:translateY(0);box-shadow:0 2px 4px #667eea33}.reference-button-text{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.reference-button-container{animation:slideInFromLeft .3s ease-out}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.reference-button{padding:.4rem .6rem;font-size:.8rem}.reference-button-text{max-width:150px}}.chat-interface.dark .reference-button{background:linear-gradient(135deg,#5a67d8,#6b46c1);box-shadow:0 2px 4px #5a67d84d}.chat-interface.dark .reference-button:hover{background:linear-gradient(135deg,#4c51bf,#553c9a);box-shadow:0 4px 12px #5a67d866}.markdown-content{line-height:1.6;color:var(--text-color, #333);word-wrap:break-word;overflow-wrap:break-word}.markdown-content>*+.code-block-container,.markdown-content .code-block-container+*{margin-top:16px}.markdown-content .code-block-container:first-child{margin-top:0}.markdown-content .code-block-container:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6,.markdown-content .markdown-h1,.markdown-content .markdown-h2,.markdown-content .markdown-h3,.markdown-content .markdown-h4,.markdown-content .markdown-h5,.markdown-content .markdown-h6{color:#2c3e50!important}.markdown-h1,.markdown-h2,.markdown-h3,.markdown-h4,.markdown-h5,.markdown-h6{margin:1.5rem 0 1rem;font-weight:600;line-height:1.3;color:#2c3e50!important}.markdown-h1{font-size:2rem;border-bottom:2px solid #e1e8ed;padding-bottom:.5rem}.markdown-h2{font-size:1.6rem;border-bottom:1px solid #e1e8ed;padding-bottom:.3rem}.markdown-h3{font-size:1.4rem}.markdown-h4{font-size:1.2rem}.markdown-h5{font-size:1.1rem}.markdown-h6{font-size:1rem;color:#666}.markdown-p{margin:1rem 0;line-height:1.6}.markdown-p:first-child{margin-top:0}.markdown-p:last-child{margin-bottom:0}.markdown-strong{font-weight:600}.markdown-em{font-style:italic}.inline-code{background-color:var(--code-bg, #f8f9fa);border:1px solid var(--code-border, #e9ecef);border-radius:4px;padding:.2rem .4rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85em;color:var(--code-color, #e83e8c);white-space:nowrap;overflow-wrap:break-word;display:inline;margin:0 2px}.markdown-link{color:var(--link-color, #0366d6);text-decoration:none;transition:color .2s ease}.markdown-link:hover{color:var(--link-hover-color, #0256cc);text-decoration:underline}.markdown-link:visited{color:var(--link-visited-color, #6f42c1)}.markdown-ul,.markdown-ol{margin:1rem 0;padding-left:2rem}.markdown-ul{list-style-type:disc}.markdown-ol{list-style-type:decimal}.markdown-li{margin:.5rem 0;line-height:1.6}.markdown-li>.markdown-p{margin:.25rem 0}.markdown-ul .markdown-ul,.markdown-ol .markdown-ol,.markdown-ul .markdown-ol,.markdown-ol .markdown-ul{margin:.25rem 0}.markdown-ul .markdown-ul{list-style-type:circle}.markdown-ul .markdown-ul .markdown-ul{list-style-type:square}.markdown-blockquote{margin:1.5rem 0;padding:1rem 1.5rem;background-color:var(--blockquote-bg, #f8f9fa);border-left:4px solid var(--blockquote-border, #dee2e6);border-radius:0 4px 4px 0;color:var(--blockquote-color, #6c757d);font-style:italic}.markdown-blockquote .markdown-p{margin:.5rem 0}.markdown-blockquote .markdown-p:first-child{margin-top:0}.markdown-blockquote .markdown-p:last-child{margin-bottom:0}.table-container{overflow-x:auto;margin:1.5rem 0;border-radius:8px;border:2px solid var(--table-border, #d1d9e0);box-shadow:0 2px 8px #0000001a}.markdown-table{width:100%;border-collapse:collapse;background-color:var(--table-bg, #ffffff)}.markdown-table th,.markdown-table td{padding:.875rem 1.25rem;text-align:left;border-bottom:1px solid var(--table-border, #d1d9e0);color:var(--text-color, #212529);font-size:.95rem;line-height:1.5}.markdown-table th{background-color:var(--table-header-bg, #343a40);font-weight:700;color:var(--table-header-color, #ffffff);border-bottom:3px solid var(--table-border, #495057);text-transform:uppercase;font-size:.875rem;letter-spacing:.5px}.markdown-table tr:last-child td{border-bottom:none}.markdown-table tr:nth-child(2n){background-color:var(--table-stripe-bg, #f8f9fa)}.markdown-table tr:nth-child(odd){background-color:var(--table-bg, #ffffff)}.markdown-table tbody tr:hover{background-color:var(--table-hover-bg, #e9ecef)!important;transform:scale(1.001);transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.markdown-hr{margin:2rem 0;border:none;border-top:2px solid var(--hr-color, #e1e8ed);background:none}@media (max-width: 768px){.markdown-h1{font-size:1.6rem}.markdown-h2{font-size:1.4rem}.markdown-h3{font-size:1.2rem}.markdown-ul,.markdown-ol{padding-left:1.5rem}.table-container{font-size:.9rem}.markdown-table th,.markdown-table td{padding:.5rem .75rem}.markdown-blockquote{padding:.75rem 1rem;margin:1rem 0}}@media (prefers-color-scheme: dark){.markdown-content{color:#098ceb}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6,.markdown-content .markdown-h1,.markdown-content .markdown-h2,.markdown-content .markdown-h3,.markdown-content .markdown-h4,.markdown-content .markdown-h5,.markdown-content .markdown-h6{color:#f0f6fc!important}.markdown-h1,.markdown-h2{border-bottom-color:#30363d}.inline-code{background-color:#161b22;border-color:#30363d;color:#f85149}.markdown-link{color:#58a6ff}.markdown-link:hover{color:#79c0ff}.markdown-link:visited{color:#bc8cff}.markdown-blockquote{background-color:#161b22;border-left-color:#30363d;color:#8b949e}.markdown-table{background-color:#0d1117;border-color:#21262d;color:#f0f6fc}.markdown-table th,.markdown-table td{border-bottom-color:#21262d;color:#f0f6fc}.markdown-table th{background-color:#21262d;color:#fff;border-bottom-color:#30363d}.markdown-table tr:nth-child(2n){background-color:#161b22;color:#f0f6fc}.markdown-table tr:nth-child(odd){background-color:#0d1117;color:#f0f6fc}.markdown-table tbody tr:hover{background-color:#30363d!important;color:#fff}.markdown-hr{border-top-color:#30363d}}.message{display:flex;gap:16px;margin-bottom:24px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{flex-direction:row-reverse}.message-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:4px}.user-message .message-avatar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.assistant-message .message-avatar{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.assistant-message[data-agent=Analyst] .message-avatar{background:linear-gradient(135deg,#667eea,#764ba2)}.assistant-message[data-agent=Summarizer] .message-avatar{background:linear-gradient(135deg,#f093fb,#f5576c)}.assistant-message[data-agent="Code Interpreter"] .message-avatar{background:linear-gradient(135deg,#4facfe,#00f2fe)}.message-content{max-width:65%;width:fit-content;display:inline-block}.user-message .message-content{text-align:right;margin-left:auto;width:auto;max-width:65%}.message-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.user-message .message-header{justify-content:flex-end}.message-role{font-weight:600;font-size:14px;color:#333;text-transform:uppercase;letter-spacing:.3px}.agent-name{font-weight:700;color:#667eea}.message-time{font-size:13px;color:#888}.agent-analyst{background-color:#667eea;color:#fff}.agent-summarizer{background-color:#f093fb;color:#fff}.agent-code-interpreter{background-color:#4facfe;color:#fff}.message-text{background-color:#fff;padding:14px 18px;border-radius:18px;box-shadow:0 2px 8px #0000001a;line-height:1.6;font-size:16px;color:#333;white-space:normal;word-wrap:break-word;position:relative;display:inline-block;width:fit-content;max-width:100%}.message-text .markdown-content{color:inherit;line-height:inherit}.message-text .plain-text-content{white-space:pre-wrap;word-wrap:break-word;line-height:inherit;color:inherit}.user-message .message-text .markdown-content{color:#fff}.user-message .message-text .markdown-content .markdown-h1,.user-message .message-text .markdown-content .markdown-h2,.user-message .message-text .markdown-content .markdown-h3,.user-message .message-text .markdown-content .markdown-h4,.user-message .message-text .markdown-content .markdown-h5,.user-message .message-text .markdown-content .markdown-h6{color:#fffffff2!important;font-weight:600}.user-message .message-text .markdown-content .markdown-h1,.user-message .message-text .markdown-content .markdown-h2{border-bottom-color:#ffffff4d}.user-message .message-text .markdown-content .markdown-h3,.user-message .message-text .markdown-content .markdown-h4,.user-message .message-text .markdown-content .markdown-h5,.user-message .message-text .markdown-content .markdown-h6{color:#fffffff2!important}.user-message .message-text .markdown-content .inline-code{background-color:#fff3;border-color:#ffffff4d;color:#ffffffe6}.user-message .message-text .markdown-content .markdown-link{color:#ffffffe6;text-decoration:underline}.user-message .message-text .markdown-content .markdown-blockquote{background-color:#ffffff1a;border-left-color:#ffffff4d;color:#fffc}.user-message .message-text .markdown-content .markdown-table{background-color:#ffffff1a;border-color:#ffffff4d}.assistant-message .message-text .markdown-content .markdown-h1,.assistant-message .message-text .markdown-content .markdown-h2,.assistant-message .message-text .markdown-content .markdown-h3,.assistant-message .message-text .markdown-content .markdown-h4,.assistant-message .message-text .markdown-content .markdown-h5,.assistant-message .message-text .markdown-content .markdown-h6{color:#2c3e50!important;font-weight:600}.user-message .message-text .markdown-content .markdown-table th,.user-message .message-text .markdown-content .markdown-table td{border-bottom-color:#ffffff4d;color:inherit}.user-message .message-text .markdown-content .markdown-table th{background-color:#fff3}.user-message .message-text .markdown-content .markdown-hr{border-top-color:#ffffff4d}.user-message .message-text{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.assistant-message .message-text{background:#fff;border:1px solid #e1e5e9}.streaming-indicator{animation:spin 1s linear infinite;margin-left:4px;color:#667eea;display:inline-block;vertical-align:middle}.waiting-response{display:flex;align-items:center;gap:8px;color:#8e8e93;font-style:italic;opacity:.8}.waiting-response .streaming-indicator{margin-left:0;color:#8e8e93}.user-message .message-text:after{content:"";position:absolute;top:10px;right:-8px;width:0;height:0;border-left:8px solid;border-left-color:inherit;border-top:8px solid transparent;border-bottom:8px solid transparent}.assistant-message .message-text:after{content:"";position:absolute;top:10px;left:-8px;width:0;height:0;border-right:8px solid #e1e5e9;border-top:8px solid transparent;border-bottom:8px solid transparent}.assistant-message .message-text:before{content:"";position:absolute;top:10px;left:-7px;width:0;height:0;border-right:8px solid white;border-top:8px solid transparent;border-bottom:8px solid transparent;z-index:1}.message-images{margin-top:12px;display:flex;flex-direction:column;gap:12px}.message-code-blocks{margin-top:12px;display:flex;flex-direction:column;gap:8px}.image-container{position:relative;border-radius:12px;overflow:hidden;border:2px solid #e5e7eb;background:#f9fafb;max-width:400px;transition:transform .2s ease,box-shadow .2s ease}.image-container:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.generated-image{width:100%;height:auto;display:block;transition:transform .2s ease}.image-container:hover .generated-image{transform:scale(1.02)}.image-overlay{position:absolute;top:8px;right:8px;opacity:0;transition:opacity .2s ease;display:flex;gap:4px}.image-container:hover .image-overlay{opacity:1}.download-button,.open-button{background:#000000b3;color:#fff;border:none;border-radius:6px;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.download-button:hover,.open-button:hover{background:#000000e6}.open-button{background:#3b82f6b3}.open-button:hover{background:#3b82f6e6}.image-caption{padding:8px 12px;background:#f3f4f6;font-size:.85em;color:#6b7280;border-top:1px solid #e5e7eb;font-style:italic}@media (min-width: 1400px){.message{gap:20px;margin-bottom:28px}.message-avatar{width:48px;height:48px}.message-content{max-width:60%;min-width:300px}.message-text{padding:16px 20px;font-size:17px;border-radius:20px}.message-role{font-size:16px}.message-time{font-size:14px}}@media (max-width: 768px){.message-content{max-width:85%;min-width:150px}.message-avatar{width:36px;height:36px}.message-text{padding:10px 14px;font-size:14px}.image-container{max-width:100%}.message-images{margin-top:8px}}.message-uploaded-image{margin-top:12px}.uploaded-image-container{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#f8f9fa;max-width:400px}.uploaded-image{width:100%;max-height:300px;object-fit:cover;display:block;transition:opacity .2s ease}.uploaded-image:hover{opacity:.9}.uploaded-image-info{padding:12px;background:#fff;border-top:1px solid #e2e8f0}.uploaded-image-info .image-filename{display:block;font-weight:500;color:#2d3748;margin-bottom:4px;font-size:14px}.uploaded-image-info .image-size{display:inline-block;background:#e2e8f0;color:#4a5568;padding:2px 6px;border-radius:4px;font-size:12px;margin-right:8px}.uploaded-image-info .cache-key{display:block;font-family:Courier New,monospace;font-size:11px;color:#718096;margin-top:4px;word-break:break-all}.image-loading,.image-load-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;background:#f8f9fa;border:1px dashed #dee2e6;border-radius:8px;color:#6c757d;text-align:center;padding:20px}.image-load-error p{margin:0 0 10px;color:#dc3545}.retry-button{background:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.retry-button:hover{background:#0056b3}.message-references{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.language-selector{position:relative;display:inline-block}.language-dropdown{position:relative}.language-button{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:14px;color:#4a5568;transition:all .2s ease;min-width:60px}.language-button:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0}.language-button:disabled{opacity:.5;cursor:not-allowed}.current-language{font-size:16px;line-height:1}.language-options{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1000;min-width:150px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .2s ease}.language-dropdown:hover .language-options{opacity:1;visibility:visible;transform:translateY(0)}.language-option{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:#4a5568;transition:background-color .2s ease}.language-option:hover:not(:disabled){background:#f7fafc}.language-option:disabled{opacity:.5;cursor:not-allowed}.language-option.active{background:#ebf4ff;color:#3182ce;font-weight:500}.language-option .flag{font-size:16px;line-height:1}.language-option .name{flex:1}.language-option .checkmark{color:#3182ce;font-weight:700;font-size:12px}@media (max-width: 768px){.language-options{right:-50%;transform:translate(50%) translateY(-4px)}.language-dropdown:hover .language-options{transform:translate(50%) translateY(0)}}.image-upload-container{margin-bottom:1rem;border:1px solid #e1e5e9;border-radius:8px;background:#f8f9fa;overflow:hidden}.upload-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#fff;border-bottom:1px solid #e1e5e9}.upload-title{font-weight:600;color:#2d3748;font-size:14px}.close-upload-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#f7fafc;color:#718096;border-radius:6px;cursor:pointer;transition:all .2s ease}.close-upload-btn:hover{background:#edf2f7;color:#4a5568}.close-upload-btn:active{background:#e2e8f0}.upload-area{position:relative}.file-input{display:none}.upload-label{display:block;padding:2rem;text-align:center;cursor:pointer;transition:background-color .2s ease;border:2px dashed #cbd5e0;margin:0}.upload-label:hover{background-color:#e2e8f0;border-color:#a0aec0}.upload-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{width:2rem;height:2rem;color:#718096}.upload-label span{font-size:1rem;color:#4a5568;font-weight:500}.upload-label small{font-size:.875rem;color:#718096}.loading-spinner{width:2rem;height:2rem;border:3px solid #e2e8f0;border-top:3px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite}.uploaded-image-container{padding:1rem}.image-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0}.image-filename{font-weight:500;color:#2d3748;font-size:.9rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-actions{display:flex;gap:.5rem}.action-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid #e2e8f0;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s ease;color:#718096}.action-btn:hover{background-color:#f7fafc;border-color:#cbd5e0}.preview-btn:hover{color:#3182ce;border-color:#3182ce}.edit-btn:hover{color:#38a169;border-color:#38a169}.post-btn:hover{color:#3182ce;border-color:#3182ce}.remove-btn:hover{color:#e53e3e;border-color:#e53e3e}.image-preview-small{margin-bottom:.75rem;border-radius:6px;overflow:hidden;border:1px solid #e2e8f0;background:#fff}.preview-image{width:100%;height:120px;object-fit:cover;display:block}.image-info{display:flex;gap:1rem}.image-info small{color:#718096;font-size:.75rem}.image-info .upload-notice{color:#059669;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.edit-modal{width:500px;max-width:90vw}.preview-modal{width:auto;max-width:80vw;max-height:80vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#f8f9fa}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#2d3748}.close-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:4px;background:transparent;cursor:pointer;color:#718096;transition:all .2s ease}.close-btn:hover{background-color:#e2e8f0;color:#4a5568}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8f9fa}.edit-form{display:flex;flex-direction:column;gap:.75rem}.edit-form label{font-weight:500;color:#4a5568;font-size:.9rem}.edit-prompt-input{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;line-height:1.4;resize:vertical;font-family:inherit}.edit-prompt-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.edit-prompt-input::placeholder{color:#a0aec0}.full-preview-image{max-width:100%;max-height:60vh;object-fit:contain;display:block;margin:0 auto}.btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid transparent;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#3182ce;color:#fff;border-color:#3182ce}.btn-primary:hover:not(:disabled){background-color:#2c5282;border-color:#2c5282}.btn-secondary{background-color:#fff;color:#4a5568;border-color:#e2e8f0}.btn-secondary:hover:not(:disabled){background-color:#f7fafc;border-color:#cbd5e0}@media (max-width: 768px){.modal-content{margin:1rem;max-width:calc(100vw - 2rem)}.edit-modal{width:auto}.image-filename{max-width:150px}.modal-header h3{font-size:1rem}.modal-body,.modal-footer{padding:1rem}}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:500px;width:90%;max-height:80vh;overflow:hidden;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1.5rem;border-bottom:1px solid #e5e7eb}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:4px;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:1.5rem 2rem 2rem;color:#374151;line-height:1.6}.modal-body p{margin:0 0 1rem}.modal-body p:last-child{margin-bottom:0}.modal-body ul{margin:.75rem 0 0;padding-left:1.25rem}.modal-body li{margin-bottom:.5rem}.modal-body li:last-child{margin-bottom:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem 2rem 2rem;border-top:1px solid #e5e7eb;background-color:#f9fafb}.modal-footer button{padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.875rem;border:none;min-width:80px}.cancel-button{background-color:#fff;color:#1f2937;border:1px solid #d1d5db}.cancel-button:hover{background-color:#f9fafb;border-color:#9ca3af}.confirm-button{background-color:#b91c1c;color:#fff;font-weight:600;border:1px solid #991b1b}.confirm-button:hover{background-color:#991b1b;border-color:#7f1d1d}.confirm-button:focus{outline:none;box-shadow:0 0 0 2px #dc262680}.agent-selector-layout{padding:0;text-align:center;background:#fff;min-height:auto}.agent-selector-title{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.1)}.agent-selector-subtitle{font-size:1.125rem;color:#64748b;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.agent-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;max-width:800px;margin:0 auto}.agent-card{background:#fff;border:2px solid #e2e8f0;border-radius:1rem;padding:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #0000000d;position:relative;overflow:hidden;min-height:140px}.agent-card:hover{border-color:#6366f1;box-shadow:0 8px 25px #6366f126;transform:translateY(-4px)}.agent-card.selected{border-color:#e2e8f0;background:#fff;box-shadow:0 8px 25px #6366f133;transform:translateY(-2px)}.agent-card.selected:after{content:"✓";position:absolute;top:1rem;right:1rem;width:2rem;height:2rem;background:#6366f1;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.agent-card.disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.agent-card-icon{width:2.5rem;height:2.5rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;position:relative;z-index:1}.agent-card-name{font-size:1rem;font-weight:600;color:#1e293b;margin-bottom:.375rem;position:relative;z-index:1}.agent-card-description{font-size:.8125rem;color:#64748b;line-height:1.4;margin:0;position:relative;z-index:1}.typing-prompt{margin-top:2rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:.75rem;text-align:center;max-width:500px;margin-left:auto;margin-right:auto;animation:fadeInUp .5s ease-out;box-shadow:0 4px 12px #f59e0b26}.typing-prompt p{margin:0;color:#92400e;font-size:1rem;font-weight:600}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.agent-selector{margin-bottom:1rem}.agent-selector.disabled{opacity:.6;pointer-events:none}.agent-selector-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.agent-selector-dropdown{position:relative}.agent-selector-select{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.agent-selector-select:disabled{cursor:not-allowed}.agent-selector-display{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .2s ease;min-height:3.5rem}.agent-selector-display:hover{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.agent-selector-select:focus+.agent-selector-display{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.agent-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:#6366f11a;border-radius:.375rem;flex-shrink:0}.agent-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.agent-name{font-weight:600;color:#111827;font-size:.875rem}.agent-description{font-size:.75rem;color:#6b7280;line-height:1.3}@media (max-width: 768px){.agent-selector-display{padding:.625rem .75rem;min-height:3rem}.agent-name{font-size:.8125rem}.agent-description{font-size:.6875rem}.agent-icon{width:1.75rem;height:1.75rem}.agent-cards-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.agent-card{padding:.75rem;min-height:120px}.agent-card-icon{width:2rem;height:2rem}.agent-card-name{font-size:.9375rem}.agent-card-description{font-size:.75rem}.agent-selector-layout{padding:0}.typing-prompt{margin-top:1.5rem;padding:.75rem 1rem;box-shadow:0 3px 8px #f59e0b26}.typing-prompt p{font-size:.875rem;font-weight:600}}.version-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.version-modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;max-width:500px;width:90%;max-height:80vh;overflow:hidden;animation:fadeInScale .2s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.version-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.version-modal-title{display:flex;align-items:center;gap:8px}.version-modal-title h3{margin:0;font-size:1.2rem;font-weight:600}.version-modal-close{background:none;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s}.version-modal-close:hover{background:#ffffff1a}.version-modal-content{padding:24px;max-height:calc(80vh - 80px);overflow-y:auto}.version-section{margin-bottom:24px}.version-section:last-of-type{margin-bottom:16px}.version-section h4{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:1rem;font-weight:600;color:#2c3e50;padding-bottom:8px;border-bottom:2px solid #e9ecef}.version-details{display:flex;flex-direction:column;gap:8px}.version-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8f9fa;border-radius:6px;border-left:3px solid #667eea}.version-item svg{color:#6c757d;flex-shrink:0}.version-label{font-weight:500;color:#495057;min-width:80px}.version-value{color:#212529;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9rem;flex:1}.version-commit{background:#e7f3ff;padding:2px 6px;border-radius:4px;font-size:.8rem;border:1px solid #b3d7ff}.version-env{background:#d4edda;padding:2px 6px;border-radius:4px;font-size:.8rem;border:1px solid #c3e6cb;text-transform:capitalize}.version-footer{text-align:center;padding-top:20px;border-top:1px solid #e9ecef;color:#6c757d;font-size:.85rem}.version-footer p{margin:4px 0}.storage-monitor{position:fixed;top:20px;right:20px;z-index:1000;max-width:400px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.storage-warning{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffc107;border-radius:12px;box-shadow:0 4px 20px #ffc1074d;overflow:hidden;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.warning-header{display:flex;align-items:center;padding:12px 16px;background:#ffc1071a;border-bottom:1px solid rgba(255,193,7,.2)}.warning-icon{font-size:18px;margin-right:8px}.warning-text{font-weight:600;color:#856404;flex-grow:1}.toggle-details,.dismiss-warning{background:none;border:none;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;color:#856404;font-weight:700;transition:background-color .2s}.toggle-details:hover,.dismiss-warning:hover{background:#ffc10733}.warning-summary{padding:12px 16px;color:#856404;font-size:14px}.storage-details{padding:16px;border-top:1px solid rgba(255,193,7,.2)}.storage-metric{margin-bottom:16px}.storage-metric label{display:block;font-weight:600;color:#856404;margin-bottom:4px;font-size:13px}.progress-bar{height:8px;background:#ffc10733;border-radius:4px;overflow:hidden;margin-right:8px;flex-grow:1}.progress-fill{height:100%;background:linear-gradient(90deg,#ffc107,#ff9800);transition:width .3s ease}.progress-fill.sessions{background:linear-gradient(90deg,#17a2b8,#007bff)}.storage-metric{display:flex;align-items:center;flex-wrap:wrap}.storage-metric label{width:100%;margin-bottom:4px}.metric-value{font-weight:700;color:#856404;font-size:12px;min-width:50px;text-align:right}.storage-actions{display:flex;gap:8px;margin:16px 0}.cleanup-btn,.clear-all-btn{flex:1;padding:8px 12px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.cleanup-btn{background:#28a745;color:#fff}.cleanup-btn:hover{background:#218838;transform:translateY(-1px)}.clear-all-btn{background:#dc3545;color:#fff}.clear-all-btn:hover{background:#c82333;transform:translateY(-1px)}.storage-tips{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,193,7,.2)}.storage-tips h4{margin:0 0 8px;color:#856404;font-size:13px}.storage-tips ul{margin:0;padding-left:16px}.storage-tips li{font-size:12px;color:#856404;margin-bottom:4px;line-height:1.4}@media (max-width: 768px){.storage-monitor{top:10px;right:10px;left:10px;max-width:none}.storage-actions{flex-direction:column}.cleanup-btn,.clear-all-btn{width:100%}}.status-bar{position:relative;padding:.75rem 1rem;margin:.5rem 0;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:all .3s ease;overflow:hidden}.status-bar.processing{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.status-bar.waiting{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.status-bar.complete{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.status-bar.error{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff}.status-content{display:flex;align-items:center;gap:.75rem;position:relative;z-index:2}.status-icon{flex-shrink:0}.status-icon.spinning{animation:spin 1s linear infinite}.status-message{flex:1;font-weight:500;font-size:.9rem}.status-time{font-size:.8rem;opacity:.8;font-weight:400}.status-progress-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:#fff3;overflow:hidden}.status-progress-fill{height:100%;background:#fff9;animation:progressSlide 2s ease-in-out infinite}@keyframes progressSlide{0%{transform:translate(-100%);width:30%}50%{width:60%}to{transform:translate(100%);width:30%}}.chat-interface.dark .status-bar{box-shadow:0 2px 4px #0000004d}.chat-interface.dark .status-bar.processing{background:linear-gradient(135deg,#5a67d8,#667eea)}.chat-interface.dark .status-bar.waiting{background:linear-gradient(135deg,#ed64a6,#f093fb)}.chat-interface.dark .status-bar.complete{background:linear-gradient(135deg,#38b2ac,#4facfe)}.chat-interface.dark .status-bar.error{background:linear-gradient(135deg,#e53e3e,#fa709a)}@media (max-width: 768px){.status-bar{padding:.5rem .75rem;margin:.25rem 0}.status-content{gap:.5rem}.status-message{font-size:.85rem}.status-time{font-size:.75rem}}.status-bar{animation:statusEnter .3s ease-out}@keyframes statusEnter{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}html,body{margin:0;padding:0;height:100%;overflow:hidden}.chat-interface{display:flex;flex-direction:column;height:100vh;width:100vw;margin:0;background-color:#fff;position:fixed;top:0;left:0;right:0;bottom:0}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 10px #0000001a}.header-content{display:flex;align-items:center;gap:16px}.header-actions{display:flex;gap:8px;align-items:center}.header-icon{width:36px;height:36px}.chat-header h1{font-size:28px;font-weight:600;margin:0}.chat-header p{font-size:16px;opacity:.9;margin:4px 0 0}.clear-button,.new-session-button,.clear-all-button,.logout-button,.version-info-button{background:#fff3;border:none;border-radius:8px;padding:8px;color:#fff;cursor:pointer;transition:background-color .2s}.clear-button:hover,.new-session-button:hover,.clear-all-button:hover,.logout-button:hover,.version-info-button:hover{background:#ffffff4d}.clear-button:disabled,.new-session-button:disabled,.clear-all-button:disabled,.logout-button:disabled,.version-info-button:disabled{opacity:.5;cursor:not-allowed}.version-info-button{background:#ffffff26!important}.version-info-button:hover{background:#ffffff40!important;transform:scale(1.05)}.logout-button{background:#ef44441a!important;border:1px solid rgba(239,68,68,.3)!important}.logout-button:hover{background:#ef444433!important;border-color:#ef444480!important}.change-agent-button{background:#7c3aed1a!important;border-color:#7c3aed4d!important}.change-agent-button:hover{background:#7c3aed33!important;border-color:#7c3aed80!important}.chat-main{display:flex;flex:1;overflow:hidden}.session-sidebar{width:300px;min-width:250px;max-width:400px;background-color:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:16px 20px;border-bottom:1px solid #e9ecef;background-color:#fff}.sidebar-header h3{margin:0;font-size:16px;font-weight:600;color:#495057}.session-list{flex:1;overflow-y:auto;padding:8px}.session-list::-webkit-scrollbar{width:6px}.session-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.session-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.session-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.session-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;margin:2px 0;background-color:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s;width:100%;text-align:left}.session-item:hover{background-color:#e9ecef}.session-item.active{background-color:#667eea;color:#fff}.session-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.session-title{font-size:14px;font-weight:500;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.session-agent{font-size:11px;color:#8b5cf6;background:#8b5cf61a;padding:1px 6px;border-radius:8px;width:fit-content;max-width:100%;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.session-no-agent{font-size:11px;color:#dc2626;background:#dc26261a;padding:1px 6px;border-radius:8px;width:fit-content;max-width:100%;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.session-item.active .session-agent,.session-item.active .session-no-agent{background:#fff3;color:#ffffffe6}.delete-session{background:none;border:none;font-size:18px;color:#dc3545;cursor:pointer;padding:4px 6px;border-radius:4px;opacity:.7;transition:all .2s;flex-shrink:0;margin-left:8px}.delete-session:hover{opacity:1;background-color:#dc3545;color:#fff}.session-item.active .delete-session{color:#fffc}.session-item.active .delete-session:hover{color:#fff;background-color:#fff3}.chat-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:28px 32px;background-color:#fafafa}.welcome-message{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;color:#666;max-width:800px;margin:auto;height:100%}.welcome-message h2{color:#333;margin-bottom:24px;font-size:32px}.welcome-message p{margin-bottom:18px;font-size:18px}.welcome-message ul{text-align:left;display:inline-block;margin:24px 0;font-size:16px}.welcome-message li{margin-bottom:10px;padding-left:10px}.agent-mode-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;color:#666;max-width:700px;margin:auto;height:100%}.selected-agent-display{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000001a;border:2px solid rgba(99,102,241,.1);width:100%}.agent-mode-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;padding:1rem;background:linear-gradient(135deg,#f8faff,#e8f4ff);border-radius:12px;border:1px solid #e0f2fe}.agent-mode-label{font-size:1.125rem;font-weight:600;color:#64748b}.agent-mode-name{font-size:1.125rem;font-weight:700;color:#6366f1}.agent-guidance h3{color:#1e293b;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.agent-guidance p{color:#64748b;margin-bottom:1.5rem;font-size:1.125rem}.guidance-points ul{text-align:left;max-width:500px;margin:0 auto 1.5rem;padding:0;list-style:none}.guidance-points li{color:#374151;font-size:1rem;position:relative;padding:.5rem 0 .5rem 1.5rem}.guidance-points li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}.agent-guidance .file-hint{margin-top:1.5rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:12px;padding:1rem 1.5rem;text-align:center}.agent-guidance .file-hint p{margin:0;color:#0c4a6e;font-size:.9375rem}.agent-guidance .quick-examples{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem;justify-content:center}.agent-modes-showcase{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin:1.5rem 0}.agent-mode-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;transition:all .2s ease}.agent-mode-card:hover{border-color:#6366f1;box-shadow:0 4px 12px #6366f11a;transform:translateY(-2px)}.agent-mode-card h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#1e293b}.agent-mode-card p{margin:0;font-size:.875rem;color:#64748b;line-height:1.5}.start-prompt{font-weight:600;color:#667eea;margin-top:28px;font-size:18px}.file-hint{margin:24px 0;padding:20px;background:linear-gradient(135deg,#f8f9ff,#e8f4ff);border:1px solid #d1e7ff;border-radius:12px;text-align:left}.file-hint p{margin:0 0 12px;font-size:16px;color:#495057}.file-hint strong{color:#667eea}.hint-example{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:12px 16px;margin:12px 0;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.hint-example code{background:none;color:#495057;font-size:14px;padding:0;border:none}.hint-note{font-size:14px;color:#6c757d;font-style:italic;margin-top:8px}.quick-examples{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.example-button{background:#667eea;color:#fff;border:none;border-radius:6px;padding:8px 12px;font-size:12px;cursor:pointer;transition:all .2s ease}.example-button:hover:not(:disabled){background:#5a6fd8;transform:translateY(-1px)}.example-button:disabled{background:#ccc;cursor:not-allowed}.example-button.primary{background:#28a745}.example-button.primary:hover:not(:disabled){background:#218838}.csv-file-section{margin:16px 0;border:1px solid #d1e7ff;border-radius:8px;overflow:hidden}.csv-file-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8f9ff;border-bottom:1px solid #e9ecef}.file-icon{font-size:18px}.file-info{color:#6c757d;font-size:14px}.preview-toggle{background:#667eea;color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;margin-left:auto}.preview-toggle:hover{background:#5a6fd8}.csv-preview{padding:16px;background:#fff}.csv-table-container{max-height:300px;overflow:auto;border:1px solid #e9ecef;border-radius:4px}.csv-table{width:100%;border-collapse:collapse;font-size:12px}.csv-table th{background:#343a40;color:#fff;padding:10px 12px;text-align:left;border-bottom:2px solid #495057;font-weight:700;position:sticky;top:0;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.csv-table td{padding:8px 12px;border-bottom:1px solid #d1d9e0;word-break:break-word;color:#212529}.csv-table tr:nth-child(2n){background:#f8f9fa}.csv-table tr:nth-child(odd){background:#fff}.csv-table tbody tr:hover{background:#e9ecef!important;transform:scale(1.001);transition:all .2s ease}.more-rows{text-align:center;color:#6c757d;font-style:italic;margin:8px 0 0;font-size:14px}.chat-input-form{padding:24px 32px;background-color:#fff;border-top:1px solid #e1e5e9}.input-container{display:flex;gap:12px;align-items:flex-end}.message-input{flex:1;padding:12px 16px;border:2px solid #e1e5e9;border-radius:12px;font-size:16px;font-family:inherit;resize:none;min-height:48px;max-height:120px;transition:border-color .2s}.message-input:focus{outline:none;border-color:#667eea}.message-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.send-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;padding:12px;color:#fff;cursor:pointer;transition:opacity .2s,transform .1s;min-width:48px;height:48px;display:flex;align-items:center;justify-content:center}.send-button:hover:not(:disabled){transform:translateY(-1px);opacity:.9}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.input-hint{font-size:12px;color:#888;margin-top:8px;text-align:center}.streaming-status{color:#667eea;font-weight:500}.session-info{color:#6c757d;font-style:italic}.agent-mode-display{color:#8b5cf6;font-weight:600;background:#8b5cf61a;padding:2px 8px;border-radius:12px;font-size:11px}.no-agent-warning{color:#dc2626;font-weight:600;background:#dc26261a;padding:2px 8px;border-radius:12px;font-size:11px}.agent-selection-inline{background:#fff;border-radius:16px;padding:2rem;margin:1rem;box-shadow:0 4px 20px #0000000d;border:2px solid #e2e8f0}.agent-selection-header{text-align:center;margin-bottom:2rem}.agent-selection-header h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.agent-selection-header p{font-size:1rem;color:#64748b;margin:0}@media (max-width: 1024px){.session-sidebar{width:260px;min-width:220px}}@media (max-width: 768px){.session-sidebar{width:240px;min-width:200px}.sidebar-header{padding:12px 16px}.session-item{padding:10px 12px}.session-title{font-size:13px}.chat-messages{padding:20px 24px}.chat-input-form{padding:16px 24px}.welcome-message,.agent-mode-selected{padding:30px 20px}.selected-agent-display{padding:1.5rem}.agent-mode-header{flex-direction:column;gap:.25rem;padding:.75rem}.agent-mode-label,.agent-mode-name{font-size:1rem}.agent-guidance h3{font-size:1.25rem}.agent-guidance p{font-size:1rem}.guidance-points li{font-size:.9375rem}.welcome-message h2{font-size:28px}.welcome-message p{font-size:16px}.agent-selection-inline{padding:1.5rem;margin:.5rem}.agent-selection-header h3{font-size:1.25rem}.agent-selection-header p{font-size:.9rem}}@media (max-width: 640px){.chat-main{flex-direction:column}.session-sidebar{width:100%;height:auto;max-height:180px;min-width:unset;border-right:none;border-bottom:1px solid #e9ecef}.session-list{display:flex;overflow-x:auto;overflow-y:hidden;padding:8px;gap:4px}.session-item{flex-shrink:0;min-width:140px;max-width:180px}.session-content{flex-direction:row;align-items:center;gap:8px}.chat-messages{padding:16px}.chat-input-form{padding:12px 16px}.welcome-message{padding:20px 16px}.welcome-message h2{font-size:24px}.chat-header{padding:12px 16px}.chat-header h1{font-size:18px}.chat-header p{font-size:14px}}@media (min-width: 1200px){.session-sidebar{width:350px;min-width:300px}.chat-messages{padding:40px 60px;max-width:none}.chat-input-form{padding:24px 60px}.welcome-message{padding:60px 40px;max-width:900px}.welcome-message h2{font-size:36px}.welcome-message p,.start-prompt{font-size:20px}}@media (min-width: 1600px){.session-sidebar{width:380px;min-width:320px}.chat-messages{padding:50px 100px}.chat-input-form{padding:30px 100px}.welcome-message{max-width:1000px}}.image-upload-section{margin-bottom:1rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.image-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:8px;background:#f0f0f0;color:#666;cursor:pointer;transition:all .2s ease;flex-shrink:0}.image-button:hover{background:#e0e0e0;color:#333}.image-button:disabled{background:#f5f5f5;color:#ccc;cursor:not-allowed}.image-button.active{background:#3182ce;color:#fff}.image-button.active:hover{background:#2c5282}.image-button.active:disabled{background:#94a3b8;color:#e2e8f0}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-form{background:#fff;padding:40px;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-icon{color:#667eea;margin-bottom:16px}.login-header h1{margin:0 0 8px;color:#1f2937;font-size:24px}.login-header p{margin:0;color:#6b7280;font-size:14px}.password-field{position:relative;margin-bottom:20px}.password-field input{width:100%;padding:12px 45px 12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.password-field input:focus{outline:none;border-color:#667eea}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#6b7280;cursor:pointer}.toggle-password:hover{color:#374151}.error-message{background:#fef2f2;color:#dc2626;padding:12px;border-radius:6px;font-size:14px;margin-bottom:20px;border:1px solid #fecaca}.login-button{width:100%;background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s;display:flex;align-items:center;justify-content:center;gap:8px}.login-button:hover:not(:disabled){background:#5a67d8}.login-button:disabled{background:#9ca3af;cursor:not-allowed}.loading-icon{animation:spin 1s linear infinite}.login-info{margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb;text-align:center}.login-info p{margin:0;font-size:12px;color:#6b7280}.App{height:100vh;width:100vw;margin:0;padding:0;overflow:hidden}.app-loading{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8fafc}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-left:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-loading p{color:#6b7280;font-size:16px;margin:0}*{margin:0;padding:0;box-sizing:border-box}:root{--table-bg: #ffffff;--table-header-bg: #343a40;--table-header-color: #ffffff;--table-stripe-bg: #f8f9fa;--table-border: #d1d9e0;--table-hover-bg: #e9ecef}html,body{height:100%;width:100%;margin:0;padding:0;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{height:100vh;width:100vw}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (prefers-color-scheme: dark){:root{--table-bg: #0d1117;--table-header-bg: #21262d;--table-header-color: #ffffff;--table-stripe-bg: #161b22;--table-border: #21262d;--table-hover-bg: #30363d}}
