*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d1117;--bg-panel: #161b22;--accent: #58a6ff;--text: #e6edf3;--text-muted: #8b949e;--border: #30363d;--height: 100vh;--max-height: 360px}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}button{cursor:pointer;font-family:inherit;border:none}input{font-family:inherit}.secure-warning{background:#f85149;color:#fff;font-size:.8rem;padding:.4rem .75rem;text-align:center;flex-shrink:0}.screen{width:100%;height:100%;min-height:280px;max-height:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.loader{color:var(--text-muted);font-size:1.1rem}.auth{justify-content:center}.auth-panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;padding:2rem 2.5rem;display:flex;flex-direction:column;gap:1rem;width:100%;max-width:480px}.auth-panel h1{font-size:1.75rem;font-weight:600}.auth-hint{color:var(--text-muted);font-size:.95rem}.auth-input{padding:.85rem 1rem;font-size:1.1rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text)}.auth-input:focus{outline:none;border-color:var(--accent)}.btn{padding:.9rem 1.5rem;font-size:1.05rem;border-radius:8px;font-weight:500;transition:opacity .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-ghost{background:transparent;color:var(--text-muted);font-size:.95rem}.btn-ghost:hover{color:var(--text)}.auth-error{color:#f85149;font-size:.9rem}.auth-qr .qr-wrap{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:.5rem 0}.auth-qr .qr-code{background:#fff;padding:12px;border-radius:8px}.auth-qr .qr-hint{font-size:.85rem;color:var(--text-muted);text-align:center}.chats{align-items:stretch;justify-content:flex-start;padding:.75rem 1rem}.chats-header{flex-shrink:0;padding-bottom:.5rem;border-bottom:1px solid var(--border);margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.chats-header h1{font-size:1.35rem;font-weight:600}.voice-btn{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:var(--bg-panel);border:2px solid var(--border);font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.voice-btn:hover:not(:disabled){border-color:var(--accent);background:#58a6ff26}.voice-btn:disabled{opacity:.5}.voice-btn.listening{border-color:var(--accent);background:#58a6ff40;animation:voice-pulse 1s ease-in-out infinite}@keyframes voice-pulse{0%,to{box-shadow:0 0 #58a6ff66}50%{box-shadow:0 0 0 12px #58a6ff00}}.voice-hint{color:var(--accent);font-size:.85rem;margin-top:.25rem;margin-bottom:-.25rem}.voice-error{color:#f85149;font-size:.9rem;margin-top:-.5rem;margin-bottom:.5rem}.chats-list{display:flex;gap:1rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem;flex:1;min-height:0}.chats-list::-webkit-scrollbar{height:6px}.chats-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.chat-card{flex:0 0 220px;min-width:200px;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:.75rem;display:flex;flex-direction:row;align-items:center;gap:.75rem;position:relative;cursor:pointer;transition:border-color .2s}.chat-card:hover{border-color:var(--accent)}.chat-avatar-wrap{flex-shrink:0;width:44px;height:44px;border-radius:50%;overflow:hidden;background:var(--border);display:flex;align-items:center;justify-content:center;position:relative}.chat-avatar{width:100%;height:100%;object-fit:cover}.chat-avatar-fallback{display:none;font-size:.9rem;font-weight:600;color:var(--text-muted)}.chat-avatar-fallback.show{display:flex;position:absolute;top:0;right:0;bottom:0;left:0;align-items:center;justify-content:center}.chat-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.chat-name{font-weight:600;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-preview{font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-unread{position:absolute;top:.75rem;right:.75rem;background:var(--accent);color:#fff;font-size:.75rem;font-weight:600;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}.chats-error,.chats-empty{color:var(--text-muted);text-align:center;padding:2rem}.chat-view{align-items:stretch;justify-content:flex-start;padding:0}.chat-view-header{flex-shrink:0;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-panel);border-bottom:1px solid var(--border)}.chat-view-title{flex:1;min-width:0;font-size:1.1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-btn-chat{width:40px;height:40px;font-size:1.25rem}.chat-back-btn{background:transparent;color:var(--text);font-size:1.5rem;padding:.25rem .5rem;line-height:1}.chat-back-btn:hover{color:var(--accent)}.chat-view-avatar-wrap{width:36px;height:36px;border-radius:50%;overflow:hidden;background:var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative}.chat-view-avatar{width:100%;height:100%;object-fit:cover}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.chat-msg{max-width:80%;align-self:flex-start;padding:.5rem .75rem;background:var(--bg-panel);border-radius:12px 12px 12px 4px}.chat-msg.out{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-left-radius:12px;border-bottom-right-radius:4px}.chat-msg-text{font-size:.95rem;word-break:break-word}.chat-msg-date{font-size:.7rem;color:var(--text-muted);margin-top:.2rem}.chat-msg.out .chat-msg-date{color:#fffc}.chat-empty{color:var(--text-muted);text-align:center;padding:2rem}
