*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s,color .3s}body[data-theme=dark]{--bg-primary: #0d0d0d;--bg-secondary: #1a1a1a;--bg-tertiary: #1e1e1e;--bg-quaternary: #2a2a2a;--border-color: #333;--border-light: #444;--text-primary: #e0e0e0;--text-secondary: #bbb;--text-tertiary: #888;--text-quaternary: #666;--accent: #6366f1;--accent-hover: #5558e3;--error-bg: #3f1a1a;--error-text: #f87171;--user-msg-bg: #6366f1;--user-msg-text: #fff;--assistant-msg-bg: #1e1e1e;--assistant-msg-text: #e0e0e0;--input-bg: #1a1a1a;--input-border: #333;--input-focus-border: #555;--button-hover: #2a2a2a;--avatar-bg: #333;--badge-bg: #222;--login-bg-start: #1a1a2e;--login-bg-end: #16213e;--login-card: #1e1e1e;--attachment-bg: rgba(255, 255, 255, .05);--shadow: rgba(0, 0, 0, .5);--drawer-overlay: rgba(0, 0, 0, .5)}body[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #f9f9f9;--bg-quaternary: #e8e8e8;--border-color: #e0e0e0;--border-light: #d0d0d0;--text-primary: #1a1a1a;--text-secondary: #333;--text-tertiary: #666;--text-quaternary: #999;--accent: #6366f1;--accent-hover: #4f46e5;--error-bg: #fef2f2;--error-text: #dc2626;--user-msg-bg: #6366f1;--user-msg-text: #fff;--assistant-msg-bg: #f3f4f6;--assistant-msg-text: #1a1a1a;--input-bg: #ffffff;--input-border: #d0d0d0;--input-focus-border: #6366f1;--button-hover: #f3f4f6;--avatar-bg: #e0e0e0;--badge-bg: #f3f4f6;--login-bg-start: #667eea;--login-bg-end: #764ba2;--login-card: #ffffff;--attachment-bg: rgba(0, 0, 0, .05);--shadow: rgba(0, 0, 0, .1);--drawer-overlay: rgba(0, 0, 0, .3)}body{background:var(--bg-primary);color:var(--text-primary)}#root{width:100vw;height:100vh;overflow:hidden}.theme-toggle{padding:8px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:20px}.theme-toggle:hover{background:var(--button-hover);color:var(--text-primary)}.mobile-menu-button{padding:8px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s;display:none;align-items:center;justify-content:center;font-size:24px}.mobile-menu-button:hover{background:var(--button-hover);color:var(--text-primary)}.login-page{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:linear-gradient(135deg,var(--login-bg-start) 0%,var(--login-bg-end) 100%)}.login-card{background:var(--login-card);border-radius:16px;padding:40px;width:400px;box-shadow:0 25px 50px -12px var(--shadow);border:1px solid var(--border-color)}.login-title{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--text-primary);text-align:center}.login-subtitle{font-size:14px;color:var(--text-tertiary);margin-bottom:32px;text-align:center}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-input{padding:12px 16px;border-radius:8px;border:1px solid var(--border-light);background:var(--bg-quaternary);color:var(--text-primary);font-size:14px;transition:all .2s}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}.login-button{padding:12px 24px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.login-button:hover{background:var(--accent-hover)}.login-button:disabled{opacity:.6;cursor:not-allowed}.error-message{padding:12px;border-radius:8px;background:var(--error-bg);color:var(--error-text);font-size:14px;text-align:center}.chat-page{display:flex;width:100%;height:100vh;overflow:hidden}.sidebar{width:300px;min-width:300px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.sidebar-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.model-select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border-light);background:var(--bg-quaternary);color:var(--text-primary);font-size:13px;cursor:pointer}.new-chat-button{width:100%;padding:10px 16px;border-radius:8px;border:1px dashed var(--text-quaternary);background:transparent;color:var(--text-tertiary);font-size:13px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.new-chat-button:hover{background:var(--bg-quaternary);color:var(--text-primary);border-color:var(--text-tertiary)}.threads-list{flex:1;overflow-y:auto;padding:8px}.thread-item{padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between;gap:8px}.thread-content{flex:1;min-width:0}.thread-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .2s}.thread-item:hover .thread-actions{opacity:1}.thread-edit{background:none;border:none;color:var(--text-quaternary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.thread-edit:hover{color:var(--text-primary);background:var(--bg-quaternary)}.thread-delete{background:none;border:none;color:var(--text-quaternary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.thread-delete:hover{color:var(--error-text);background:var(--bg-quaternary)}.thread-item:hover{background:var(--bg-quaternary)}.thread-item.active{background:var(--bg-tertiary)}.thread-item.active .thread-actions{opacity:1}.thread-title{font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thread-title-input{width:100%;padding:4px 8px;border-radius:4px;border:1px solid var(--accent);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;outline:none}.thread-meta{font-size:12px;color:var(--text-quaternary);margin-top:4px}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.user-info{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.user-name{font-size:14px;color:var(--text-secondary)}.logout-button{padding:6px 12px;border-radius:6px;border:1px solid var(--border-light);background:transparent;color:var(--text-tertiary);font-size:12px;cursor:pointer;transition:all .2s}.logout-button:hover{background:var(--bg-quaternary);color:var(--text-primary)}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary)}.chat-header{padding:16px 24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-header-left{display:flex;align-items:center;gap:12px;flex:1}.chat-title{font-size:16px;font-weight:500;color:var(--text-primary)}.chat-header-actions{display:flex;align-items:center;gap:8px}.chat-model-badge{padding:4px 10px;border-radius:12px;background:var(--badge-bg);color:var(--text-tertiary);font-size:12px}.messages-container{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px;scroll-behavior:smooth}.message{display:flex;gap:12px;max-width:800px}.message.user{flex-direction:row-reverse;margin-left:auto}.message-avatar{width:32px;height:32px;border-radius:50%;background:var(--avatar-bg);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.message.user .message-avatar{background:var(--user-msg-bg)}.message-content{padding:12px 16px;border-radius:12px;font-size:15px;line-height:1.5;max-width:600px}.message.assistant .message-content{background:var(--assistant-msg-bg);color:var(--assistant-msg-text)}.message.user .message-content{background:var(--user-msg-bg);color:var(--user-msg-text)}.message-image{max-width:300px;border-radius:8px;margin-top:8px}.message-input-area{padding:16px 24px;border-top:1px solid var(--border-color)}.input-wrapper{display:flex;gap:12px;max-width:800px;margin:0 auto}.message-input{flex:1;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:15px;resize:none;max-height:150px}.message-input:focus{outline:none;border-color:var(--input-focus-border)}.attach-button{padding:12px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-tertiary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:20px}.attach-button:hover{background:var(--bg-quaternary);color:var(--text-primary)}.send-button{padding:12px 20px;border-radius:12px;border:none;background:var(--accent);color:#fff;font-size:20px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.send-button:hover:not(:disabled){background:var(--accent-hover)}.send-button:disabled{opacity:.5;cursor:not-allowed}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-quaternary)}.empty-state-icon{font-size:48px}.empty-state-text{font-size:16px}.loading{display:flex;align-items:center;gap:8px;color:var(--text-tertiary);font-size:14px}.loading-dots:after{content:"...";animation:dots 1.5s steps(3,end) infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.drawer-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--drawer-overlay);z-index:99;opacity:0;pointer-events:none;transition:opacity .3s}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--bg-secondary);z-index:100;transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column;overflow:hidden}.drawer.open{transform:translate(0)}.drawer-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg-secondary)}.drawer-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.drawer-content .sidebar-header{display:none}.drawer-content .sidebar{width:100%;height:100%;border:none}.drawer-content .threads-list{overflow-y:auto}.drawer-content .sidebar-footer{border-top:1px solid var(--border-color)}.drawer-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.drawer-close{padding:8px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px}.drawer-close:hover{background:var(--bg-quaternary)}@media(max-width:768px){.sidebar{display:none}.drawer-overlay{display:block}.mobile-menu-button{display:flex}.chat-header{padding:12px 16px}.messages-container{padding:16px}.message-content{max-width:100%;padding:10px 14px;font-size:14px}.message-image{max-width:100%}.message-input-area{padding:12px 16px}.input-wrapper{gap:8px}.attach-button,.send-button{padding:10px;font-size:18px}.login-card{width:90%;padding:32px 24px}.chat-model-badge{display:none}}
