*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f5f7fa;--surface: #ffffff;--accent: #06c755;--accent-hover: #05b34a;--text: #1a1a1a;--muted: #888;--border: #e8e8e8;--danger: #e53935}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%}.page{display:flex;flex-direction:column;min-height:100vh;max-width:480px;margin:0 auto}.page-body{flex:1;overflow-y:auto;padding-bottom:80px}.header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-back{background:none;border:none;font-size:20px;cursor:pointer;color:var(--accent);padding:4px 8px;line-height:1}.header-title{font-size:16px;font-weight:700;flex:1}.center-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.muted{color:var(--muted);font-size:14px}.error-text{color:var(--danger);font-size:13px}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.thread-card{background:var(--surface);margin:8px 12px;padding:14px 16px;border-radius:12px;box-shadow:0 1px 3px #0000000f;cursor:pointer;transition:background .15s}.thread-card:active{background:#f0f0f0}.thread-card-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.thread-card-row+.thread-card-row{margin-top:6px}.thread-company{font-size:15px;font-weight:600;color:var(--text);margin-bottom:2px}.thread-id-small,.thread-id{font-size:11px;color:var(--muted);font-family:monospace}.thread-time{font-size:11px;color:var(--muted);white-space:nowrap}.thread-preview{font-size:13px;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{width:10px;height:10px;border-radius:50%;background:var(--danger);flex-shrink:0}.fab{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;border:none;border-radius:24px;padding:12px 24px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #06c7554d;white-space:nowrap;z-index:20;transition:background .15s}.fab:active{background:var(--accent-hover)}.input-group{background:var(--surface);border-radius:12px;padding:12px;box-shadow:0 1px 3px #0000000f}.message-input{width:100%;border:none;outline:none;resize:none;font-size:14px;font-family:inherit;line-height:1.5;min-height:96px;color:var(--text)}.message-input::placeholder{color:#bbb}.input-footer{display:flex;justify-content:flex-end;margin-top:4px}.char-count{font-size:11px;color:var(--muted)}.char-count.warn{color:var(--danger)}.action-row{display:flex;gap:8px;margin-top:12px}.image-preview-list{display:flex;gap:8px;flex-wrap:wrap;padding:8px 0}.image-preview{position:relative;width:72px;height:72px;border-radius:8px;overflow:hidden;background:#e8e8e8}.image-preview img{width:100%;height:100%;object-fit:cover}.image-preview-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.btn-attach{width:38px;height:38px;border-radius:50%;border:none;background:#f0f0f0;color:#666;font-size:18px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-attach:disabled{opacity:.4;cursor:default}.btn-send{flex:1;background:var(--accent);color:#fff;border:none;border-radius:10px;padding:12px;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}.btn-send:active{background:var(--accent-hover)}.btn-send:disabled{background:#ccc;cursor:default}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:10px 20px;border-radius:20px;font-size:13px;z-index:100;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.chat-messages{flex:1;overflow-y:auto;padding:12px 12px 80px;display:flex;flex-direction:column;gap:4px}.msg-row{display:flex;flex-direction:column;margin-bottom:2px}.msg-row.customer{align-items:flex-end}.msg-row.staff{align-items:flex-start}.msg-row.system{align-items:center}.msg-sender-name{font-size:11px;color:var(--muted);margin-bottom:2px;padding-left:4px}.msg-bubble{max-width:75%;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.5;word-break:break-word;white-space:pre-wrap}.msg-bubble.customer{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.msg-bubble.staff{background:#e8e8e8;color:var(--text);border-bottom-left-radius:4px}.msg-bubble.system{background:transparent;color:var(--muted);font-size:12px;max-width:90%}.msg-original{margin-bottom:6px}.msg-translation{border-top:1px solid rgba(0,0,0,.1);padding-top:6px;font-size:13px;opacity:.85}.msg-lang-flag{margin-right:4px;font-size:12px}.msg-time{font-size:11px;color:var(--muted);margin-top:2px;padding:0 4px}.msg-time.customer{text-align:right}.msg-time.staff{text-align:left}.msg-image{max-width:200px;border-radius:12px;display:block}.chat-input-bar{display:flex;align-items:flex-end;gap:6px;padding:8px 12px;background:var(--surface);border-top:1px solid var(--border);position:sticky;bottom:0;z-index:10}.chat-textarea{flex:1;border:1px solid var(--border);border-radius:20px;padding:8px 14px;font-size:14px;font-family:inherit;line-height:1.4;resize:none;outline:none;max-height:120px;overflow-y:auto}.chat-textarea:focus{border-color:var(--accent)}.btn-chat-send{width:38px;height:38px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:18px;font-weight:700;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}.btn-chat-send:active{background:var(--accent-hover)}.btn-chat-send:disabled{background:#ccc;cursor:default}.tl-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.tl-modal{background:var(--surface);border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.tl-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.tl-title{font-weight:600;font-size:15px}.tl-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted)}.tl-body{padding:16px}.tl-section{margin-bottom:14px}.tl-lang{font-size:12px;color:var(--muted);margin-bottom:4px}.tl-text{background:#f5f5f5;padding:12px;border-radius:8px;white-space:pre-wrap;word-break:break-word;font-size:14px;line-height:1.5}.tl-loading{color:#999;font-style:italic}.tl-edit{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:8px;padding:10px;font-size:14px;font-family:inherit;resize:vertical}.tl-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.tl-btn{padding:8px 16px;border:1px solid var(--border);background:var(--surface);border-radius:8px;font-size:13px;cursor:pointer}.tl-btn:disabled{opacity:.5;cursor:default}.tl-btn.tl-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.loading-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;color:var(--muted);font-size:13px}
