:root{--bg-base:#09090b;--bg-surface:#111113;--bg-raised:#18181b;--bg-overlay:#1f1f23;--text-primary:#f4f4f5;--text-secondary:#a1a1aa;--text-tertiary:#52525b;--border:#27272a;--accent:#f43f5e;--accent-hover:#e11d48;--accent-muted:rgba(244,63,94,.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}::-webkit-scrollbar{width: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:var(--accent);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:var(--accent)}.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}@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)}}