*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #ffffff;--color-sidebar: #f7f7f8;--color-border: #e5e5e5;--color-text: #1a1a1a;--color-text-muted: #6b7280;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-user-bubble: #eff6ff;--color-assistant-bubble: #f9fafb;--sidebar-width: 260px;--header-height: 56px}@media(prefers-color-scheme:dark){:root{--color-bg: #0f0f0f;--color-sidebar: #1a1a1a;--color-border: #2d2d2d;--color-text: #f0f0f0;--color-text-muted: #9ca3af;--color-user-bubble: #1e3a5f;--color-assistant-bubble: #1c1c1e}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--color-bg);color:var(--color-text);height:100dvh;overflow:hidden}.app{display:flex;height:100dvh}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--color-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:16px 12px 12px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px}.sidebar-title{font-size:18px;font-weight:700}.new-chat-btn{width:100%;padding:8px 12px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;text-align:left;transition:background .15s}.new-chat-btn:hover{background:var(--color-primary-hover)}.conversation-list{flex:1;overflow-y:auto;padding:8px}.list-loading,.list-empty{padding:16px;color:var(--color-text-muted);font-size:14px;text-align:center}.conversation-item{width:100%;display:flex;flex-direction:column;gap:2px;padding:8px 10px;border:none;border-radius:8px;background:transparent;color:var(--color-text);cursor:pointer;text-align:left;transition:background .1s}.conversation-item:hover{background:var(--color-border)}.conversation-item.selected{background:var(--color-border);font-weight:500}.conv-title{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-preview{font-size:12px;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.load-more-btn{width:100%;padding:8px;background:transparent;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;color:var(--color-text-muted);font-size:13px;margin-top:4px}.user-menu{position:relative;display:flex;align-items:center;gap:10px;padding:10px 12px;border-top:1px solid var(--color-border)}.user-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;object-fit:cover}.user-avatar-fallback{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:var(--color-primary);color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center}.user-info{flex:1;display:flex;flex-direction:column;min-width:0}.user-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{font-size:11px;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-btn{flex-shrink:0;width:28px;height:28px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--color-text-muted);font-size:14px;display:flex;align-items:center;justify-content:center}.user-menu-btn:hover{background:var(--color-border);color:var(--color-text)}.user-menu-popup{position:absolute;bottom:calc(100% + 4px);left:12px;right:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #0000001a;overflow:hidden;z-index:50}.user-menu-item{width:100%;padding:10px 14px;background:transparent;border:none;text-align:left;cursor:pointer;font-size:14px;color:var(--color-text);transition:background .1s}.user-menu-item:hover{background:var(--color-sidebar)}.user-menu-item--danger{color:#ef4444}.user-menu-item--danger:hover{background:#fef2f2}@media(prefers-color-scheme:dark){.user-menu-item--danger:hover{background:#2d1515}}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.chat-page{display:flex;flex-direction:column;height:100%}.chat-header{height:var(--header-height);padding:0 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:12px}.chat-title{font-size:16px;font-weight:600;cursor:pointer;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-title:hover{opacity:.7}.model-badge{font-size:11px;background:var(--color-sidebar);border:1px solid var(--color-border);padding:2px 8px;border-radius:12px;color:var(--color-text-muted);white-space:nowrap}.model-picker{font-size:12px;background:var(--color-sidebar);border:1px solid var(--color-border);padding:4px 8px;border-radius:8px;color:var(--color-text-muted);cursor:pointer;outline:none;transition:border-color .15s}.model-picker:hover,.model-picker:focus{border-color:var(--color-primary);color:var(--color-text)}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.settings-sheet{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;width:min(480px,calc(100vw - 32px));display:flex;flex-direction:column;box-shadow:0 8px 32px #00000026}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.settings-title{font-size:16px;font-weight:600}.settings-close-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;transition:background .1s}.settings-close-btn:hover{background:var(--color-sidebar);color:var(--color-text)}.settings-body{padding:20px;display:flex;flex-direction:column;gap:20px}.settings-section{display:flex;flex-direction:column;gap:6px}.settings-label{font-size:14px;font-weight:500}.settings-description{font-size:12px;color:var(--color-text-muted)}.settings-textarea{width:100%;padding:10px 12px;background:var(--color-sidebar);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:14px;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s}.settings-textarea:focus{border-color:var(--color-primary)}.settings-textarea::placeholder{color:var(--color-text-muted)}.settings-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--color-border)}.settings-cancel-btn{padding:8px 16px;background:transparent;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-size:14px;color:var(--color-text);transition:background .1s}.settings-cancel-btn:hover{background:var(--color-sidebar)}.settings-save-btn{padding:8px 16px;background:var(--color-primary);border:none;border-radius:8px;cursor:pointer;font-size:14px;color:#fff;font-weight:500;transition:background .15s}.settings-save-btn:hover:not(:disabled){background:var(--color-primary-hover)}.settings-save-btn:disabled{opacity:.6;cursor:not-allowed}.settings-fetch-error{font-size:13px;color:#ef4444;padding:8px 0}.thread-root{flex:1;display:flex;flex-direction:column;overflow:hidden}.thread-viewport{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.scroll-to-bottom{position:sticky;bottom:8px;align-self:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.message{display:flex;flex-direction:column;gap:4px;max-width:800px;margin:0 auto;width:100%}.user-message{align-items:flex-end}.assistant-message{align-items:flex-start}.message-bubble{padding:12px 16px;border-radius:12px;line-height:1.6;font-size:15px;max-width:85%}.user-bubble{background:var(--color-user-bubble);border-bottom-right-radius:4px}.assistant-bubble{background:var(--color-assistant-bubble);border:1px solid var(--color-border);border-bottom-left-radius:4px;width:100%;max-width:100%}.assistant-bubble h1,.assistant-bubble h2,.assistant-bubble h3{margin:16px 0 8px;font-weight:600}.assistant-bubble p{margin:8px 0}.assistant-bubble ul,.assistant-bubble ol{margin:8px 0;padding-left:24px}.assistant-bubble li{margin:4px 0}.assistant-bubble code{background:var(--color-border);padding:2px 5px;border-radius:4px;font-family:SF Mono,Consolas,monospace;font-size:13px}.assistant-bubble pre{background:#1e1e1e;color:#d4d4d4;padding:16px;border-radius:8px;overflow-x:auto;margin:12px 0}.assistant-bubble pre code{background:none;padding:0;color:inherit}.assistant-bubble blockquote{border-left:4px solid var(--color-border);padding-left:16px;color:var(--color-text-muted);margin:8px 0}.assistant-bubble table{border-collapse:collapse;width:100%;margin:12px 0}.assistant-bubble th,.assistant-bubble td{border:1px solid var(--color-border);padding:8px 12px;text-align:left}.assistant-bubble th{background:var(--color-sidebar);font-weight:600}.message{position:relative;padding-bottom:22px}.action-bar{position:absolute;bottom:-12px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.user-message .action-bar{right:0}.assistant-message .action-bar{left:0}.message:hover .action-bar{opacity:1}.action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;color:var(--color-text-muted)}.action-btn:hover{background:var(--color-sidebar);color:var(--color-text)}.typing-indicator{color:var(--color-text-muted);font-size:12px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.composer-area{border-top:1px solid var(--color-border);padding:16px 20px;padding-bottom:max(16px,env(safe-area-inset-bottom));background:var(--color-bg)}.composer{display:flex;align-items:flex-end;gap:8px;max-width:800px;margin:0 auto;background:var(--color-sidebar);border:1px solid var(--color-border);border-radius:12px;padding:8px}.composer-input{flex:1;background:transparent;border:none;outline:none;resize:none;font-size:15px;color:var(--color-text);line-height:1.5;padding:4px 8px;max-height:200px;overflow-y:auto;font-family:inherit}.composer-input::placeholder{color:var(--color-text-muted)}.composer-actions{flex-shrink:0}.btn{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-size:15px;font-weight:500;transition:background .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-send{background:var(--color-primary);color:#fff}.btn-send:hover{background:var(--color-primary-hover)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.btn-stop{background:#ef4444;color:#fff}.btn-stop:hover{background:#dc2626}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--color-text-muted)}.empty-state h2{font-size:24px;color:var(--color-text)}@media(max-width:768px){.sidebar{position:fixed;left:-100%;z-index:100;transition:left .2s;height:100%;box-shadow:4px 0 16px #0000001a}.sidebar.open{left:0}}
