*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.message-container{display:flex;gap:12px;padding:12px 16px;max-width:100%}.message-container.user{flex-direction:row-reverse}.message-container.assistant{flex-direction:row}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;background:#f0f0f0}.message-container.user .message-avatar{background:#e3f2fd}.message-container.assistant .message-avatar{background:#f5f5f5}.message-content{max-width:70%;display:flex;flex-direction:column}.message-container.user .message-content{align-items:flex-end}.message-container.assistant .message-content{align-items:flex-start}.message-bubble{padding:12px 16px;border-radius:18px;word-wrap:break-word;white-space:pre-wrap}.message-container.user .message-bubble{background:#1976d2;color:#fff;border-bottom-right-radius:4px}.message-container.assistant .message-bubble{background:#f5f5f5;color:#333;border-bottom-left-radius:4px}.message-text{margin:0;line-height:1.5;font-size:.95rem}.message-meta{display:flex;gap:8px;margin-top:4px;padding:0 8px}.message-time{font-size:.75rem;color:#999}.message-intent{font-size:.7rem;color:#666;background:#e8e8e8;padding:2px 6px;border-radius:10px}@media(max-width:768px){.message-content{max-width:85%}.message-bubble{padding:10px 14px}}.chat-input-container{padding:16px;background:#fff;border-top:1px solid #e0e0e0}.image-preview{position:relative;display:inline-block;margin-bottom:12px}.image-preview img{max-width:150px;max-height:100px;border-radius:8px;object-fit:cover}.remove-image{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;border:none;background:#f44;color:#fff;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}.remove-image:hover{background:#c00}.input-row{display:flex;gap:8px;align-items:flex-end}.attach-button{width:44px;height:44px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.attach-button:hover:not(:disabled){background:#f5f5f5}.attach-button:disabled{opacity:.5;cursor:not-allowed}.chat-input{flex:1;min-height:44px;max-height:120px;padding:12px 16px;border:1px solid #ddd;border-radius:22px;resize:none;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#1976d2}.chat-input:disabled{background:#f5f5f5;cursor:not-allowed}.send-button{height:44px;padding:0 20px;border:none;border-radius:22px;background:#1976d2;color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s;flex-shrink:0}.send-button:hover:not(:disabled){background:#1565c0}.send-button:disabled{background:#bdbdbd;cursor:not-allowed}.input-hint{margin-top:8px;font-size:.75rem;color:#999;text-align:center}@media(max-width:768px){.chat-input-container{padding:12px}.chat-input{padding:10px 14px}.send-button{padding:0 16px}}.chat-window{display:flex;flex-direction:column;height:100%;max-width:800px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff}.header-title{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:600}.header-icon{font-size:1.5rem}.header-status{display:flex;align-items:center;gap:6px;font-size:.85rem;opacity:.9}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.online{background:#4caf50}.status-dot.loading{background:#ffc107;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.chat-messages{flex:1;overflow-y:auto;padding:16px 0;background:#fafafa}.typing-indicator{display:flex;gap:4px;padding:12px 20px;margin-left:48px}.typing-dot{width:8px;height:8px;background:#bdbdbd;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}.chat-error{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#ffebee;color:#c62828;font-size:.9rem}.chat-error button{background:none;border:none;color:#c62828;cursor:pointer;padding:4px 8px;font-size:1rem}.chat-error button:hover{background:#c628281a;border-radius:4px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#aaa}@media(max-width:768px){.chat-window{border-radius:0;height:100vh;max-width:100%}.chat-header{padding:14px 16px}.header-title{font-size:1rem}}.app{height:100%;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}@media(max-width:768px){.app{padding:0}}
