:root{--bg: #fafaf8;--surface: #ffffff;--border: #e3e1da;--text: #1c1b18;--text-muted: #6b6863;--accent: #2f5d50;--accent-soft: #e7efe9;--danger: #a8403a}body[data-theme=dark]{--bg: #1a1a17;--surface: #242420;--border: #3a3a34;--text: #ece9e2;--text-muted: #9a968c;--accent: #4d9a7f;--accent-soft: #2a3530;--danger: #d2645c}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text)}#root{height:100vh}.app-shell{display:flex;height:100%}.auth-screen{display:flex;align-items:center;justify-content:center;width:100%}.auth-card{width:320px;padding:32px;background:var(--surface);border:1px solid var(--border)}.auth-card h1{font-size:20px;margin:0 0 4px;letter-spacing:-.01em}.auth-card p{color:var(--text-muted);font-size:13px;margin:0 0 20px}.field{margin-bottom:12px}.field label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:4px}.field input{width:100%;padding:9px 10px;border:1px solid var(--border);background:var(--bg);font-size:14px;color:var(--text)}.field input:focus{outline:2px solid var(--accent);outline-offset:-1px}.btn{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;font-size:14px;cursor:pointer;margin-top:8px}.btn:hover{opacity:.9}.btn-secondary{background:transparent;color:var(--accent);border:1px solid var(--accent)}.error-text{color:var(--danger);font-size:13px;margin:8px 0 0}.switch-mode{margin-top:16px;text-align:center;font-size:13px;color:var(--text-muted)}.switch-mode button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;text-decoration:underline}.sidebar{width:260px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface)}.sidebar-header{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{font-size:15px;margin:0}.icon-btn{border:1px solid var(--border);background:var(--bg);width:28px;height:28px;cursor:pointer;font-size:16px;line-height:1}.group-list{flex:1;overflow-y:auto}.group-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border);font-size:14px}.group-item:hover{background:var(--accent-soft)}.group-item.active{background:var(--accent-soft);font-weight:600}.group-item .role-tag{font-size:11px;color:var(--text-muted);margin-left:6px}.unread-badge{background:var(--accent);color:#fff;font-size:11px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0}.presence-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;flex-shrink:0}.presence-dot.online{background:#3a8a5c}.presence-dot.offline{background:#b8b5ad}.chat-header-subtitle{font-size:11px;font-weight:400;color:var(--text-muted);margin-top:2px}.chat-area{flex:1;display:flex;flex-direction:column}.chat-header{padding:14px 20px;border-bottom:1px solid var(--border);font-size:15px;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:12px}.messages-list{flex:1;overflow-y:auto;padding:16px 20px}.message-row{margin-bottom:12px;max-width:60%}.message-row.own{margin-left:auto}.message-author{font-size:12px;color:var(--text-muted);margin-bottom:2px}.message-bubble{background:var(--accent-soft);padding:8px 12px;font-size:14px;line-height:1.4;overflow-wrap:break-word;word-break:break-word}.message-row.own .message-bubble{background:var(--accent);color:#fff}.message-time{font-size:10px;color:var(--text-muted);margin-top:2px}.message-reactions{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.reaction-pill{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-size:12px;cursor:pointer;line-height:1.4}.reaction-pill.mine{border-color:var(--accent);background:var(--accent-soft)}.reaction-pill .reaction-count{color:var(--text-muted);font-size:11px}.message-row{position:relative}.message-actions{display:none;position:absolute;top:-14px;right:0;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:2px 4px;gap:2px}.message-row.own .message-actions{right:auto;left:0}.message-row:hover .message-actions{display:flex}.message-actions button{border:none;background:none;cursor:pointer;font-size:14px;padding:2px 4px;line-height:1}.message-actions button:hover{background:var(--accent-soft);border-radius:3px}.read-status{font-size:10px;color:var(--text-muted);margin-left:4px}.read-status.read{color:var(--accent)}.message-edit-input{width:100%;padding:6px 8px;font-size:14px;border:1px solid var(--accent);font-family:inherit}.message-edited-tag{font-size:10px;color:var(--text-muted);font-style:italic}.forwarded-tag{font-size:11px;color:var(--text-muted);font-style:italic;margin-bottom:2px}.message-deleted{font-style:italic;color:var(--text-muted)}.message-image{display:block;max-width:100%;max-height:300px;border-radius:4px;cursor:pointer;object-fit:cover}.message-caption{margin-top:6px}.voice-player{display:flex;align-items:center;gap:8px;min-width:220px}.voice-play-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message-row.own .voice-play-btn{background:#fff;color:var(--accent)}.voice-waveform{flex:1;height:28px;display:flex;align-items:center;gap:2px;cursor:pointer}.voice-waveform-bar{flex:1;min-width:2px;background:var(--text-muted);opacity:.4;border-radius:2px;transition:opacity .1s}.voice-waveform-bar.played{background:var(--accent);opacity:1}.message-row.own .voice-waveform-bar{background:#fff6}.message-row.own .voice-waveform-bar.played{background:#fff;opacity:1}.voice-waveform-loading{width:100%;height:2px;background:var(--border);border-radius:2px}.voice-duration{font-size:11px;color:var(--text-muted);flex-shrink:0;min-width:32px}.message-row.own .voice-duration{color:#fffc}.voice-recorder-bar{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--border);background:var(--accent-soft)}.voice-cancel-btn,.voice-send-btn{width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.voice-cancel-btn{background:var(--bg)}.voice-send-btn{background:var(--accent);color:#fff}.voice-recording-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);flex-shrink:0;animation:voice-pulse 1.2s infinite}@keyframes voice-pulse{0%,to{opacity:1}50%{opacity:.3}}.voice-live-waveform{flex:1;height:32px;display:flex;align-items:center;gap:2px}.voice-live-bar{flex:1;min-width:2px;max-width:4px;background:var(--accent);border-radius:2px}.voice-timer{font-size:13px;color:var(--text);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:36px}.mic-btn{border:1px solid var(--border);background:var(--bg);width:38px;height:38px;cursor:pointer;font-size:16px;flex-shrink:0}.mic-btn.recording{background:var(--danger);border-color:var(--danger)}.image-preview-row{display:flex;align-items:center;gap:10px;padding:10px 20px;border-top:1px solid var(--border);background:var(--accent-soft)}.image-preview-row img{height:50px;width:50px;object-fit:cover;border-radius:4px}.image-preview-remove{border:none;background:none;cursor:pointer;font-size:13px;color:var(--danger)}.attach-btn{border:1px solid var(--border);background:var(--bg);width:38px;height:38px;cursor:pointer;font-size:16px;flex-shrink:0}.avatar-large,.avatar-medium,.avatar-small{border-radius:50%;background-color:var(--accent);background-size:cover;background-position:center;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600}.avatar-small{width:28px;height:28px;font-size:12px}.avatar-medium{width:36px;height:36px;font-size:14px}.avatar-large{width:64px;height:64px;font-size:22px}.profile-trigger{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer}.profile-trigger:hover{background:var(--accent-soft)}.profile-trigger-name{font-size:13px;font-weight:600}.pinned-message-bar{padding:8px 20px;background:var(--accent-soft);border-bottom:1px solid var(--border);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emoji-picker-popover{position:absolute;right:0;z-index:20;box-shadow:0 4px 16px #00000026}.message-input-row{position:relative;display:flex;padding:14px 20px;border-top:1px solid var(--border);gap:8px}.message-input-row input{flex:1;padding:10px 12px;border:1px solid var(--border);font-size:14px}.message-input-row input:focus{outline:2px solid var(--accent);outline-offset:-1px}.typing-indicator{padding:4px 20px;font-size:12px;color:var(--text-muted);height:20px;display:flex;align-items:center;gap:4px}.typing-dots{display:inline-flex;gap:2px}.typing-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-muted);animation:typing-bounce 1.2s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-3px);opacity:1}}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center}.modal-card{background:var(--surface);border:1px solid var(--border);padding:24px;width:300px}.modal-card h3{margin:0 0 12px;font-size:16px}.modal-actions{display:flex;gap:8px;margin-top:12px}.modal-actions .btn{margin-top:0}
