html,body{margin:0;padding:0;height:100%}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #ff5577;--primary-hover: #e64d6b;--bg-color: #18181b;--chat-bg: #1f1f23;--user-msg-bg: #3f3540;--user-msg-color: #e5e5e8;--assistant-msg-bg: #2d2d33;--assistant-msg-color: #e5e5e8;--border-color: #3d3d44;--text-color: #e5e5e8;--text-muted: #808088;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .4)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-color);color:var(--text-color);height:100vh;margin:0;padding:0;overflow:hidden}#root{width:100%;height:100%}.chat-container{width:100%;height:100%;background-color:var(--chat-bg);display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background-color:var(--chat-bg);display:flex;justify-content:space-between;align-items:center}.chat-header h1{font-size:1.25rem;font-weight:600;color:var(--text-color)}.header-options{display:flex;align-items:center;gap:1rem}.model-selector{display:flex;align-items:center}.model-select{padding:.5rem .75rem;background-color:var(--assistant-msg-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;cursor:pointer;outline:none;transition:border-color .2s}.model-select:hover{border-color:var(--primary-color)}.model-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #f573}.model-select option{background-color:var(--assistant-msg-bg);color:var(--text-color)}.search-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.search-toggle input{display:none}.toggle-slider{position:relative;width:40px;height:22px;background-color:#505058;border-radius:11px;transition:background-color .3s}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#e5e5e5;border-radius:50%;transition:transform .3s;box-shadow:0 1px 3px #0000004d}.search-toggle input:checked+.toggle-slider{background-color:var(--primary-color)}.search-toggle input:checked+.toggle-slider:before{transform:translate(18px)}.toggle-label{font-size:.875rem;color:var(--text-color)}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.welcome-message{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text-color);font-size:1.25rem}.message{display:flex;max-width:80%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-content{padding:.75rem 1rem;border-radius:1rem;line-height:1.5}.message.user .message-content{background-color:var(--user-msg-bg);color:var(--user-msg-color);border-bottom-right-radius:.25rem}.message.assistant .message-content{background-color:var(--assistant-msg-bg);color:var(--assistant-msg-color);border-bottom-left-radius:.25rem}.message-content p{white-space:pre-wrap;word-wrap:break-word}.chat-input-area{padding:1rem 1.5rem;border-top:1px solid var(--border-color);background-color:var(--chat-bg)}.chat-form{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.input-options{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}.input-hint{font-size:.75rem;color:var(--text-muted)}.chat-form textarea{flex:1;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:.75rem;font-size:1rem;font-family:inherit;resize:none;outline:none;transition:border-color .2s;max-height:150px;background-color:var(--assistant-msg-bg);color:var(--text-color)}.chat-form textarea:focus{border-color:var(--primary-color)}.chat-form textarea::placeholder{color:var(--text-muted)}.chat-form button{padding:.75rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.75rem;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.chat-form button:hover:not(:disabled){background-color:var(--primary-hover)}.chat-form button:disabled{opacity:.6;cursor:not-allowed}.chat-form button svg{width:20px;height:20px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background-color:#505058;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background-color:#606068}.streaming:after{content:"|";animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.search-indicator{display:inline-block;font-size:.75rem;color:#f89;background-color:#ff557726;padding:.25rem .5rem;border-radius:.25rem;margin-bottom:.5rem;animation:pulse 1.5s ease-in-out infinite}.search-indicator.error{color:#dc2626;background-color:#dc26261a;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.search-queries{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.search-query-item{display:inline-block;font-size:.75rem;color:#a78bfa;background-color:#a78bfa26;padding:.25rem .5rem;border-radius:.25rem}.error-message{color:#dc2626;font-style:italic}.error-message:after{content:none}.markdown-body{line-height:1.6;word-wrap:break-word}.markdown-body>*:first-child{margin-top:0}.markdown-body>*:last-child{margin-bottom:0}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin-top:1em;margin-bottom:.5em;font-weight:600;line-height:1.25}.markdown-body h1{font-size:1.5em;border-bottom:1px solid var(--border-color);padding-bottom:.3em}.markdown-body h2{font-size:1.3em;border-bottom:1px solid var(--border-color);padding-bottom:.3em}.markdown-body h3{font-size:1.15em}.markdown-body h4{font-size:1em}.markdown-body p{margin-top:0;margin-bottom:.75em}.markdown-body ul,.markdown-body ol{margin-top:0;margin-bottom:.75em;padding-left:1.5em}.markdown-body li{margin-bottom:.25em}.markdown-body li>p{margin-bottom:.25em}.markdown-body blockquote{margin:.75em 0;padding:.5em 1em;border-left:4px solid var(--primary-color);background-color:#6366f11a;color:var(--text-color)}.markdown-body blockquote>*:first-child{margin-top:0}.markdown-body blockquote>*:last-child{margin-bottom:0}.markdown-body code{padding:.2em .4em;margin:0;font-size:.875em;background-color:#ffffff1a;border-radius:4px;font-family:SF Mono,Consolas,Liberation Mono,Menlo,monospace}.markdown-body pre{margin:.75em 0;padding:1em;overflow-x:auto;background-color:#16161a;border-radius:6px;border:1px solid var(--border-color)}.markdown-body pre code{padding:0;margin:0;font-size:.85em;background-color:transparent;border-radius:0;white-space:pre;word-break:normal;word-wrap:normal;line-height:1.45}.markdown-body table{width:100%;margin:.75em 0;border-collapse:collapse;border-spacing:0;overflow:auto}.markdown-body table th,.markdown-body table td{padding:.5em .75em;border:1px solid var(--border-color)}.markdown-body table th{font-weight:600;background-color:var(--assistant-msg-bg)}.markdown-body table tr:nth-child(2n){background-color:#25252a}.markdown-body hr{height:.25em;padding:0;margin:1.5em 0;background-color:var(--border-color);border:0;border-radius:2px}.markdown-body a{color:var(--primary-color);text-decoration:none}.markdown-body a:hover{text-decoration:underline}.markdown-body img{max-width:100%;height:auto;border-radius:4px}.markdown-body strong{font-weight:600}.markdown-body em{font-style:italic}.markdown-body input[type=checkbox]{margin-right:.5em;vertical-align:middle}.auth-section{display:flex;align-items:center;margin-left:1rem;padding-left:1rem;border-left:1px solid var(--border-color)}.auth-loading{font-size:.875rem;color:var(--text-muted)}.auth-button{padding:.5rem 1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.auth-button:hover{background-color:var(--primary-hover)}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background-color:transparent;border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:background-color .2s}.user-menu-button:hover{background-color:var(--assistant-msg-bg)}.user-avatar{width:28px;height:28px;background-color:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.user-name{font-size:.875rem;color:var(--text-color);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-arrow{font-size:.625rem;color:var(--text-muted)}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;min-width:150px;background-color:var(--chat-bg);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:var(--shadow);z-index:100}.user-menu-info{padding:.75rem 1rem}.user-menu-username{font-size:.875rem;font-weight:500;color:var(--text-color)}.user-menu-divider{margin:0;border:none;border-top:1px solid var(--border-color)}.user-menu-item{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;font-size:.875rem;color:var(--text-color);cursor:pointer;transition:background-color .2s}.user-menu-item:hover{background-color:var(--assistant-msg-bg)}.auth-modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{position:relative;width:100%;max-width:400px;background-color:var(--chat-bg);border-radius:1rem;box-shadow:var(--shadow);padding:2rem;margin:1rem}.auth-modal-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s}.auth-modal-close:hover{color:var(--text-color)}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.auth-tab{flex:1;padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;font-size:1rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s}.auth-tab:hover{color:var(--text-color)}.auth-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.5rem}.auth-field label{font-size:.875rem;font-weight:500;color:var(--text-color)}.auth-field input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;outline:none;transition:border-color .2s;background-color:var(--assistant-msg-bg);color:var(--text-color)}.auth-field input:focus{border-color:var(--primary-color)}.auth-field input::placeholder{color:var(--text-muted)}.auth-field input:disabled{background-color:#25252a;cursor:not-allowed}.auth-submit{padding:.875rem 1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.auth-submit:hover:not(:disabled){background-color:var(--primary-hover)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-error{padding:.75rem 1rem;background-color:#dc26261a;border:1px solid rgba(220,38,38,.2);border-radius:.5rem;color:#dc2626;font-size:.875rem}.app-layout{display:flex;width:100%;height:100%;background-color:var(--chat-bg);overflow:hidden}.app-layout .chat-container{max-width:none;max-height:none;border-radius:0;box-shadow:none}.app-layout.with-sidebar .chat-container{flex:1}.sidebar{width:280px;min-width:280px;background-color:#1a1a1f;color:#fff;display:flex;flex-direction:column;border-right:1px solid var(--border-color);transition:width .3s ease,min-width .3s ease}.sidebar.collapsed{width:50px;min-width:50px}.sidebar-header{display:flex;align-items:center;padding:.5rem;gap:.5rem}.sidebar-toggle{width:36px;height:36px;min-width:36px;background:none;border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-color);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.sidebar-toggle:hover{background-color:#ffffff1a}.new-chat-btn{flex:1;padding:.75rem 1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.new-chat-btn:hover{background-color:var(--primary-hover)}.conversation-list{flex:1;overflow-y:auto;padding:0 .5rem 1rem}.conversation-empty{padding:1rem;text-align:center;color:var(--text-muted);font-size:.875rem}.conversation-item{display:flex;align-items:center;padding:.75rem 1rem;margin:.25rem 0;border-radius:.5rem;cursor:pointer;position:relative;transition:background-color .2s}.conversation-item:hover{background-color:#ffffff1a}.conversation-item.active{background-color:#ff557740}.conversation-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.conversation-title{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-date{font-size:.75rem;color:var(--text-muted)}.conversation-item .delete-btn{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem .5rem;font-size:1.25rem;line-height:1;transition:color .2s,opacity .2s}.conversation-item:hover .delete-btn{opacity:1}.conversation-item .delete-btn:hover{color:#ef4444}.conversation-actions{display:flex;align-items:center;gap:.25rem}.conversation-item .edit-btn{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem .5rem;font-size:1rem;line-height:1;transition:color .2s,opacity .2s}.conversation-item:hover .edit-btn{opacity:1}.conversation-item .edit-btn:hover{color:var(--primary-color)}.conversation-title-input{width:100%;padding:.25rem .5rem;font-size:.9rem;background-color:var(--assistant-msg-bg);border:1px solid var(--primary-color);border-radius:.25rem;color:var(--text-color);outline:none}.conversation-title-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #f573}.conversation-list::-webkit-scrollbar{width:6px}.conversation-list::-webkit-scrollbar-track{background:transparent}.conversation-list::-webkit-scrollbar-thumb{background-color:#505058;border-radius:3px}.conversation-list::-webkit-scrollbar-thumb:hover{background-color:#606068}@media(max-width:768px){.app-layout.with-sidebar{flex-direction:column}.sidebar{width:100%;min-width:100%;height:auto;max-height:200px;border-right:none;border-bottom:1px solid var(--border-color)}.conversation-list{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:.5rem;gap:.5rem}.conversation-item{min-width:150px;max-width:200px;flex-shrink:0}}.input-wrapper{display:flex;align-items:flex-end;gap:.5rem;flex:1}.input-wrapper textarea{flex:1}.file-upload-container{position:relative;display:flex;flex-direction:column;gap:.5rem}.file-upload-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--assistant-msg-bg);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:background-color .2s,border-color .2s;flex-shrink:0}.file-upload-button:hover:not(:disabled){background-color:#35353d;border-color:var(--primary-color)}.file-upload-button:disabled{opacity:.5;cursor:not-allowed}.upload-icon{font-size:1.25rem;transition:transform .2s}.upload-icon.dragging{transform:scale(1.2)}.pending-files{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;background-color:var(--assistant-msg-bg);border-radius:.5rem;max-width:300px}.pending-file{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;background-color:#ffffff0d;border-radius:.375rem;font-size:.8rem}.pending-file.error{background-color:#dc26261a}.pending-file .file-icon{font-size:1rem}.pending-file .file-name{color:var(--text-color);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pending-file .file-warning{font-size:.875rem}.pending-file .file-error{font-size:.875rem;color:#ef4444}.pending-file .remove-file{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;font-size:.875rem;line-height:1;transition:color .2s}.pending-file .remove-file:hover{color:#ef4444}.pending-file .remove-file:disabled{cursor:not-allowed;opacity:.5}.drop-zone-overlay{position:fixed;inset:0;background-color:#ff55771a;border:2px dashed var(--primary-color);display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:none}.drop-zone-overlay span{background-color:var(--chat-bg);padding:1rem 2rem;border-radius:.5rem;font-size:1.25rem;color:var(--primary-color)}.message-attachments{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.attachment-item{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background-color:#ffffff0d;border-radius:.375rem;font-size:.8rem}.attachment-item.image{flex-direction:column;padding:.5rem}.attachment-item.unsupported{background-color:#dc26261a}.attachment-icon{font-size:1rem}.attachment-filename{color:var(--text-color);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-image-preview{max-width:200px;max-height:150px;border-radius:.375rem;object-fit:contain}.message.user{flex-direction:column;align-items:flex-end}.message.user .message-attachments{justify-content:flex-end}
