*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{color:#e4e4e7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#18181b}#root{height:100%}.app-layout{color:#e4e4e7;background:#18181b;height:100vh;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;display:flex;overflow:hidden}.sidebar{background:#0f0f12;border-right:1px solid #27272a;flex-direction:column;width:280px;min-width:280px;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid #27272a;justify-content:space-between;align-items:center;padding:1rem;display:flex}.sidebar-header h2{color:#a78bfa;letter-spacing:-.02em;margin:0;font-size:1.25rem;font-weight:700}.btn-new{color:#0f0f12;cursor:pointer;background:#a78bfa;border:none;border-radius:6px;padding:.4rem .75rem;font-size:.8rem;font-weight:600;transition:background .15s}.btn-new:hover{background:#8b5cf6}.conversation-list{flex:1;padding:.5rem;overflow-y:auto}.sidebar-empty{color:#52525b;text-align:center;padding:1rem;font-size:.85rem}.conversation-item{cursor:pointer;border-radius:6px;align-items:center;margin-bottom:2px;padding:.6rem .75rem;transition:background .15s;display:flex}.conversation-item:hover{background:#27272a}.conversation-item.active{background:#3f3f46}.conversation-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;overflow:hidden}.btn-delete{color:#71717a;cursor:pointer;opacity:0;background:0 0;border:none;padding:0 .25rem;font-size:1.1rem;line-height:1;transition:opacity .15s,color .15s}.conversation-item:hover .btn-delete{opacity:1}.btn-delete:hover{color:#ef4444}.chat-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-header{text-align:center;border-bottom:1px solid #27272a;padding:.75rem 1.5rem}.chat-header h1{color:#fafafa;margin:0;font-size:1.25rem;font-weight:700}.chat-subtitle{color:#71717a;font-size:.75rem}.messages-container{flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.empty-state{text-align:center;color:#71717a;margin:auto}.empty-icon{margin-bottom:.5rem;font-size:3rem}.empty-state h2{color:#a1a1aa;margin:0 0 .25rem;font-size:1.2rem}.empty-state p{margin:0;font-size:.9rem}.message{gap:.75rem;width:100%;max-width:800px;margin:0 auto;display:flex}.message-user{flex-direction:row-reverse}.message-avatar{background:#27272a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;display:flex}.message-content{max-width:75%}.message-role{color:#71717a;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem;font-size:.7rem;font-weight:600}.message-user .message-role{text-align:right}.message-text{white-space:pre-wrap;word-break:break-word;border-radius:12px;padding:.75rem 1rem;font-size:.925rem;line-height:1.55}.message-user .message-text{color:#e4e4e7;background:#3b1d8e;border-bottom-right-radius:4px}.message-assistant .message-text{color:#d4d4d8;background:#27272a;border-bottom-left-radius:4px}.error-banner{color:#fca5a5;background:#450a0a;border:1px solid #7f1d1d;border-radius:8px;width:100%;max-width:800px;margin:0 auto;padding:.75rem 1rem;font-size:.875rem}.chat-input-form{box-sizing:border-box;background:#18181b;border-top:1px solid #27272a;gap:.5rem;width:100%;max-width:830px;margin:0 auto;padding:1rem 1.5rem;display:flex}.chat-input{color:#e4e4e7;resize:none;background:#27272a;border:1px solid #3f3f46;border-radius:10px;outline:none;flex:1;min-height:44px;max-height:120px;padding:.75rem 1rem;font-family:inherit;font-size:.925rem;transition:border-color .15s}.chat-input:focus{border-color:#a78bfa}.chat-input::placeholder{color:#52525b}.btn-send,.btn-stop{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-self:flex-end;height:44px;padding:0 1.25rem;font-size:.875rem;font-weight:600;transition:background .15s}.btn-send{color:#0f0f12;background:#a78bfa}.btn-send:hover:not(:disabled){background:#8b5cf6}.btn-send:disabled{opacity:.4;cursor:default}.btn-stop{color:#fff;background:#ef4444}.btn-stop:hover{background:#dc2626}@media (width<=768px){.sidebar{width:220px;min-width:220px}.message-content{max-width:85%}}@media (width<=480px){.sidebar{display:none}}
