:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px}#root{height:100vh}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{font-family:inherit}.image-preview{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border:1px solid #e0e0e0;border-radius:8px;background:#fafafa}.image-preview-thumbnail{max-height:120px;max-width:120px;border-radius:6px;object-fit:cover;border:1px solid #e0e0e0}.image-preview-meta{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.image-preview-mime{font-size:.8rem;color:#666}.image-preview-size{font-size:.8rem;color:#999}.image-preview-remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid #ddd;border-radius:6px;background:transparent;color:#666;font-size:1.1rem;cursor:pointer;transition:all .2s;flex-shrink:0}.image-preview-remove:hover:not(:disabled){background:#f5f5f5;border-color:#ccc;color:#333}.image-preview-remove:disabled{color:#bbb;cursor:not-allowed}.chat-window{display:flex;flex-direction:column;width:100%;max-width:800px;height:100%;min-height:0;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 2px 8px #0000000f}.message-list{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.message{max-width:75%;padding:.75rem 1rem;border-radius:16px;word-wrap:break-word;line-height:1.6;font-size:.95rem;white-space:pre-wrap}.message-user{align-self:flex-end;background:#646cff;color:#fff;border-bottom-right-radius:4px}.message-agent{align-self:flex-start;background:#f0f0f5;color:#333;border-bottom-left-radius:4px}.message-error{align-self:flex-start;background:#fdecea;color:#b71c1c;border-left:3px solid #b71c1c;border-radius:4px;font-size:.9rem}.loading-indicator{align-self:flex-start;padding:.75rem 1rem;color:#999;font-style:italic;font-size:.9rem}.chat-input-area{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem;border-top:1px solid #e0e0e0;background:#fafafa}.chat-input{flex:1;padding:.6rem .85rem;border:1px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#646cff;box-shadow:0 0 0 2px #646cff26}.chat-send-button{padding:.6rem 1.5rem;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .2s}.chat-send-button:hover:not(:disabled){background:#535bf2}.chat-send-button:disabled{background:#bbb;cursor:not-allowed}.logout-button{padding:.4rem .85rem;background:transparent;color:#666;border:1px solid #ddd;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.logout-button:hover{background:#f5f5f5;border-color:#ccc}@media(max-width:768px){.chat-window{border-radius:0;border-left:none;border-right:none}.message{max-width:85%}}.streaming-cursor{display:inline-block;width:2px;height:1em;background:#666;margin-left:2px;vertical-align:text-bottom;animation:blink .8s step-end infinite}@keyframes blink{50%{opacity:0}}.message-image-thumbnail{display:block;max-height:120px;max-width:100%;border-radius:8px;margin-bottom:.5rem}*{box-sizing:border-box;margin:0;padding:0}.app-layout{display:flex;height:100vh}.sidebar{width:60px;background:#1e1e2e;display:flex;flex-direction:column;align-items:center;padding-top:1rem;gap:.5rem;flex-shrink:0}.sidebar-button{width:44px;height:44px;border:none;border-radius:12px;background:transparent;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.sidebar-button:hover{background:#ffffff1a;color:#ccc}.sidebar-button.active{background:#646cff;color:#fff}.app-container{flex:1;min-width:0;height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.app-header-left{display:flex;align-items:center;gap:1rem}.app-title{font-size:1.5rem;font-weight:700;color:#646cff}.app-header-right{display:flex;align-items:center;gap:1rem}.user-info{font-size:.85rem;color:#666}.app-main{flex:1;min-height:0;overflow:hidden;display:flex;justify-content:center;padding:1rem}@media(max-width:768px){.sidebar{width:48px}.sidebar-button{width:36px;height:36px;border-radius:10px}.app-header{padding:.5rem 1rem}.app-title{font-size:1.25rem}.app-main{padding:0}}
