:root{--bg-base:#0d0f14;--bg-surface:#13161e;--bg-raised:#1a1e2a;--bg-overlay:#222736;--text-primary:#e8eaf0;--text-secondary:#8b91a8;--text-tertiary:#4a5068;--border:#252a3a;--accent:#6366f1;--accent-hover:#4f52e0;--accent-muted:rgba(99,102,241,.12);--success:#34d399;--error:#f87171;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 12px rgba(0,0,0,.4);--shadow-lg:0 8px 24px rgba(0,0,0,.5);--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"SF Mono","Fira Code","Fira Mono","Roboto Mono",monospace}*,:after,:before{margin:0;padding:0;box-sizing:border-box}body,html{height:100%;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-shell{display:flex;height:100vh;height:100dvh;overflow:hidden}.sidebar{width:260px;min-width:260px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:transform var(--transition-slow)}.sidebar-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.new-chat-btn{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;font-weight:500;transition:all var(--transition-fast)}.new-chat-btn:hover{background:var(--bg-raised);color:var(--text-primary);border-color:var(--text-tertiary)}.sidebar-list{flex:1 1;overflow-y:auto;padding:var(--space-2)}.sidebar-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border)}.conv-date-group{font-size:.6875rem;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.conv-date-group,.conv-item{padding:var(--space-2) var(--space-3)}.conv-item{display:flex;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);color:var(--text-secondary);font-size:.8125rem;position:relative;border:none;background:transparent;width:100%;text-align:left}.conv-item.active,.conv-item:hover{background:var(--bg-raised);color:var(--text-primary)}.conv-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:linear-gradient(180deg,#6366f1,#8b5cf6);border-radius:var(--radius-full)}.conv-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-delete{opacity:0;transition:opacity var(--transition-fast);background:transparent;border:none;color:var(--text-tertiary);padding:var(--space-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.conv-delete:hover{color:var(--error)}.conv-item:hover .conv-delete{opacity:1}.model-select{width:100%;padding:var(--space-2);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2352525b' viewBox='0 0 16 16'%3E%3Cpath d='M4.5 6l3.5 4 3.5-4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:var(--space-8)}.model-select:focus{border-color:var(--accent)}.model-label{font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.chat-area{flex:1 1;display:flex;flex-direction:column;min-width:0}.message-thread{flex:1 1;overflow-y:auto;padding:var(--space-6) var(--space-8)}.message-container{max-width:720px;margin:0 auto}.message{margin-bottom:var(--space-6);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.message-role{font-size:.6875rem;font-weight:600;color:var(--text-tertiary);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.message-role.assistant{color:#818cf8}.message-content{color:var(--text-secondary);line-height:1.7;font-size:.9375rem}.message-content h1,.message-content h2,.message-content h3{color:var(--text-primary);margin:var(--space-4) 0 var(--space-2);line-height:1.3}.message-content h1{font-size:1.25rem}.message-content h2{font-size:1.125rem}.message-content h3{font-size:1rem}.message-content p{margin-bottom:var(--space-3)}.message-content p:last-child{margin-bottom:0}.message-content strong{color:var(--text-primary);font-weight:600}.message-content em{font-style:italic}.message-content a{color:var(--accent)}.message-content a:hover{text-decoration:underline}.message-content ol,.message-content ul{margin:var(--space-2) 0 var(--space-3);padding-left:var(--space-6)}.message-content li{margin-bottom:var(--space-1)}.message-content code{background:var(--bg-raised);padding:.15em .4em;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85em}.message-content .code-block{position:relative;margin:var(--space-3) 0;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--bg-raised);border-bottom:1px solid var(--border);font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.code-block-copy{font-size:.6875rem;padding:var(--space-1) var(--space-2);background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans)}.code-block-copy:hover{color:var(--text-primary);border-color:var(--text-tertiary)}.code-block pre{padding:var(--space-3) var(--space-4);overflow-x:auto;font-family:var(--font-mono);font-size:.8125rem;line-height:1.6;color:var(--text-secondary);margin:0}.code-block code{background:transparent;padding:0;border-radius:0;font-size:inherit}.streaming-cursor:after{content:"\25CD";animation:blink 1s steps(2) infinite;color:var(--accent);margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-input-area{padding:var(--space-4) var(--space-8);border-top:1px solid var(--border);background:var(--bg-surface)}.chat-input-container{max-width:720px;margin:0 auto;display:flex;gap:var(--space-2);align-items:flex-end}.chat-textarea{flex:1 1;resize:none;padding:var(--space-3);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;line-height:1.5;outline:none;min-height:44px;max-height:168px;overflow-y:auto;transition:border-color var(--transition-fast)}.chat-textarea:focus{border-color:var(--text-tertiary)}.chat-textarea::placeholder{color:var(--text-tertiary)}.send-btn{width:44px;height:44px;border-radius:var(--radius-lg);background:var(--accent);color:var(--text-primary);border:none;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.send-btn:hover{background:var(--accent-hover)}.send-btn:disabled{opacity:.3;cursor:not-allowed}.send-btn.stop{background:var(--bg-raised);border:1px solid var(--border)}.send-btn.stop:hover{border-color:var(--error);color:var(--error)}.empty-state{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--text-tertiary);padding:var(--space-8)}.empty-state h2{font-size:1.25rem;color:var(--text-primary);font-weight:600}.empty-state p{font-size:.875rem;max-width:400px;text-align:center;line-height:1.6}.suggestions{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center;margin-top:var(--space-4);max-width:480px}.suggestion-chip{padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:.8125rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.suggestion-chip:hover{background:var(--bg-raised);color:var(--text-primary);border-color:var(--accent)}.mobile-toggle{display:none;position:fixed;top:var(--space-3);left:var(--space-3);z-index:100;width:36px;height:36px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;justify-content:center}.mobile-toggle:hover{color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:49}.sidebar-user{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;margin-bottom:var(--space-3);border-bottom:1px solid var(--border);padding-bottom:var(--space-3)}.sidebar-user-avatar{width:28px;height:28px;border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.sidebar-user-info{flex:1 1;min-width:0;display:flex;flex-direction:column}.sidebar-user-name{font-size:.8125rem;color:var(--text-primary);font-weight:500}.sidebar-user-email,.sidebar-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-email{font-size:.6875rem;color:var(--text-tertiary)}.sidebar-signout{background:transparent;border:none;color:var(--text-tertiary);padding:var(--space-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color var(--transition-fast)}.sidebar-signout:hover{color:var(--error)}.landing{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:var(--space-8)}.landing-content{text-align:center;max-width:420px}.landing-logo{margin-bottom:var(--space-4);border-radius:var(--radius-lg)}.landing-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em}.landing-tagline{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-8)}.landing-actions{display:flex;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-6)}.landing-btn{padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-size:.9375rem;font-weight:500;transition:all var(--transition-fast);text-decoration:none}.landing-btn.primary{background:var(--accent);color:#fff}.landing-btn.primary:hover{background:var(--accent-hover)}.landing-btn.secondary{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.landing-btn.secondary:hover{background:var(--bg-raised);color:var(--text-primary);border-color:var(--text-tertiary)}.landing-powered{font-size:.75rem;color:var(--text-tertiary)}.landing-accent{color:var(--accent);font-weight:600}.auth-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:var(--space-4)}.auth-card{width:100%;max-width:380px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8)}.auth-header{text-align:center;margin-bottom:var(--space-6)}.auth-header img{margin-bottom:var(--space-3);border-radius:var(--radius-md)}.auth-header h1{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.auth-header p{font-size:.875rem;color:var(--text-secondary)}.auth-form{gap:var(--space-4)}.auth-form,.auth-label{display:flex;flex-direction:column}.auth-label{gap:var(--space-1);font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.auth-input{padding:var(--space-3);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;outline:none;transition:border-color var(--transition-fast)}.auth-input:focus{border-color:var(--accent)}.auth-input::placeholder{color:var(--text-tertiary)}.auth-submit{padding:var(--space-3);background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;transition:background var(--transition-fast);margin-top:var(--space-2)}.auth-submit:hover{background:var(--accent-hover)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-error{padding:var(--space-3);background:hsla(0,91%,71%,.1);border:1px solid hsla(0,91%,71%,.2);border-radius:var(--radius-md);color:var(--error);font-size:.8125rem}.auth-footer-text{text-align:center;font-size:.8125rem;color:var(--text-tertiary);margin-top:var(--space-5)}.auth-link{color:var(--accent);font-weight:500}.auth-link:hover{text-decoration:underline}@media (max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:50;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-overlay.open{display:block}.mobile-toggle{display:flex}.message-thread{padding:var(--space-4)}.chat-input-area{padding:var(--space-3)}}