.main-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100%;width:100%;overflow:hidden}.sidebar{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;height:var(--header-height);border-bottom:1px solid var(--border-color)}.sidebar-header h1{font-size:18px;font-weight:600;color:var(--text-accent)}.sidebar-search{padding:8px 12px}.sidebar-search input{width:100%;padding:8px 12px;border-radius:var(--radius-md);background:var(--bg-primary);border:1px solid var(--border-subtle);font-size:13px}.sidebar-actions{display:flex;gap:8px}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.conversation-list{flex:1;overflow-y:auto;overflow-x:hidden}.conversation-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-subtle)}.conversation-item:hover{background:var(--bg-hover)}.conversation-item.active{background:var(--bg-tertiary)}.conversation-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;color:var(--text-primary);flex-shrink:0}.conversation-info{flex:1;min-width:0}.conversation-top-row{display:flex;justify-content:space-between;align-items:baseline}.conversation-name{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:11px;color:var(--text-muted);flex-shrink:0;margin-left:8px}.conversation-bottom-row{display:flex;justify-content:space-between;align-items:center;margin-top:2px}.conversation-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{background:var(--accent);color:#fff;font-size:11px;font-weight:600;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0;margin-left:8px}.chat-area{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden}.chat-header{display:flex;align-items:center;gap:12px;padding:0 20px;height:var(--header-height);border-bottom:1px solid var(--border-color);flex-shrink:0}.chat-header-info{flex:1}.chat-header-name{font-weight:600;font-size:15px}.chat-header-status{font-size:12px;color:var(--text-muted)}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:15px}.message-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 20px;display:flex;flex-direction:column;gap:4px}.message-date-divider{display:flex;align-items:center;justify-content:center;padding:12px 0}.message-date-divider span{font-size:12px;color:var(--text-muted);background:var(--bg-primary);padding:4px 12px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.message-row{display:flex;max-width:70%}.message-row.sent{align-self:flex-end}.message-row.received{align-self:flex-start}.message-bubble{padding:8px 12px;border-radius:var(--radius-md);max-width:100%;word-wrap:break-word;white-space:pre-wrap;position:relative}.message-row.sent .message-bubble{background:var(--bubble-sent);border-bottom-right-radius:4px}.message-row.received .message-bubble{background:var(--bubble-received);border-bottom-left-radius:4px}.message-text{font-size:14px;line-height:1.45}.message-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:4px}.message-time{font-size:11px;color:var(--text-muted)}.message-status{font-size:12px;color:var(--text-muted)}.message-status.status-blue{color:#4fc3f7}.message-status.status-error{color:var(--status-error, #f44)}.message-bubble-wrap{position:relative;display:flex;flex-direction:column;max-width:100%}.reaction-picker-bar{display:flex;align-items:center;gap:2px;padding:4px 6px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);position:absolute;top:-36px;z-index:50;box-shadow:0 2px 10px #0000004d;white-space:nowrap}.reaction-picker-bar.sent{right:0}.reaction-picker-bar.received{left:0}.reaction-picker-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:var(--radius-sm);transition:background var(--transition-fast),transform .1s ease;cursor:pointer}.reaction-picker-btn:hover{background:var(--bg-hover);transform:scale(1.2)}.reaction-picker-more{font-size:14px;font-weight:600;color:var(--text-secondary)}.reaction-full-picker{position:absolute;bottom:100%;z-index:110}.message-row.sent .reaction-full-picker{right:0}.message-row.received .reaction-full-picker{left:0}.reaction-full-picker .emoji-picker{position:static}.reaction-bar{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;padding:0 4px}.reaction-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--bg-hover);border:1px solid var(--border-subtle);border-radius:12px;font-size:13px;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.reaction-pill:hover{background:var(--bg-tertiary, var(--border-subtle))}.reaction-pill.mine{background:var(--accent-dim, rgba(79, 195, 247, .15));border-color:var(--accent, #4fc3f7)}.reaction-emoji{font-size:15px;line-height:1}.reaction-count{font-size:11px;font-weight:600;color:var(--text-secondary)}.composer{display:flex;flex-direction:column;padding:0;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.composer-row{display:flex;align-items:flex-end;gap:8px;padding:12px 20px}.composer-input-wrap{flex:1;position:relative}.composer textarea{width:100%;min-height:40px;max-height:160px;resize:none;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-primary);border:1px solid var(--border-subtle);line-height:1.4;font-size:14px;overflow-y:auto}.composer textarea:focus{border-color:var(--accent)}.composer-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.composer-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.composer-btn.send{background:var(--accent);color:#fff}.composer-btn.send:hover{background:var(--accent-hover)}.composer-btn.send:disabled{opacity:.4;cursor:default}.emoji-picker-wrap{position:relative}.emoji-picker{position:absolute;bottom:48px;left:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px;display:grid;grid-template-columns:repeat(8,1fr);gap:2px;width:280px;max-height:240px;overflow-y:auto;z-index:100;box-shadow:0 4px 20px #0006}.emoji-picker button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.emoji-picker button:hover{background:var(--bg-hover)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;width:400px;max-width:90vw;box-shadow:0 8px 32px #00000080}.modal h2{font-size:18px;margin-bottom:16px;color:var(--text-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.btn{padding:8px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;transition:background var(--transition-fast)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-color)}.trust-indicator{display:inline-flex;align-items:center;gap:4px;font-size:12px}.trust-shield{font-size:14px}.trust-shield.unverified{color:var(--trust-unverified)}.trust-shield.remote{color:var(--trust-remote)}.trust-shield.proximity{color:var(--trust-proximity)}.auth-view{display:flex;align-items:center;justify-content:center;height:100%;background:var(--bg-primary)}.auth-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:32px;width:400px;max-width:90vw}.auth-card h1{font-size:24px;color:var(--text-accent);margin-bottom:8px}.auth-card p{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input{width:100%}.form-error{color:var(--status-error);font-size:13px;margin-top:4px}.form-submit{width:100%;padding:10px;margin-top:8px}.composer-attachment-preview{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--bg-tertiary, var(--bg-hover));border-bottom:1px solid var(--border-subtle)}.composer-attachment-thumb{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.composer-attachment-file-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--bg-hover);border-radius:var(--radius-sm);flex-shrink:0}.composer-attachment-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.composer-attachment-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.composer-attachment-size{font-size:11px;color:var(--text-muted)}.composer-attachment-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;color:var(--text-secondary);transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0;cursor:pointer}.composer-attachment-remove:hover{background:var(--bg-hover);color:var(--status-error, #f44)}.composer-attachment-error{padding:6px 20px;font-size:12px;color:var(--status-error, #f44);background:var(--bg-tertiary, var(--bg-hover))}.message-image-wrap{cursor:pointer;margin-bottom:4px;border-radius:var(--radius-sm);overflow:hidden;line-height:0}.message-image-thumb{max-width:300px;max-height:300px;border-radius:var(--radius-sm);object-fit:contain}.message-image-placeholder{width:200px;height:120px;background:var(--bg-hover);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px}.message-file-wrap{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-hover);border-radius:var(--radius-sm);cursor:pointer;margin-bottom:4px;transition:background var(--transition-fast)}.message-file-wrap:hover{background:var(--bg-tertiary, var(--border-subtle))}.message-file-icon{font-size:28px;flex-shrink:0;line-height:1}.message-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.message-file-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-file-size{font-size:11px;color:var(--text-muted)}.message-file-download{font-size:20px;color:var(--text-secondary);flex-shrink:0}.lightbox-overlay{position:fixed;inset:0;background:#000000d9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:300}.lightbox-controls{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:301}.lightbox-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#ffffff26;color:#fff;border-radius:var(--radius-sm);font-size:13px;font-weight:500;backdrop-filter:blur(4px);transition:background var(--transition-fast);cursor:pointer}.lightbox-btn:hover{background:#ffffff40}.lightbox-btn:disabled{opacity:.4;cursor:default}.lightbox-close{font-size:18px;width:36px;height:36px;padding:0;justify-content:center}.lightbox-content{display:flex;align-items:center;justify-content:center;max-width:90vw;max-height:85vh}.lightbox-image{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 4px 40px #00000080}.lightbox-loading,.lightbox-error{color:#ffffffb3;font-size:15px}@media(max-width:768px){.main-layout{grid-template-columns:1fr}.main-layout .sidebar{display:none}.main-layout.show-sidebar .sidebar{display:flex;position:absolute;inset:0;z-index:50;width:100%}.main-layout.show-sidebar .chat-area{display:none}.mobile-back-btn{display:flex}.message-row{max-width:85%}}@media(min-width:769px){.mobile-back-btn{display:none}}.p2p-dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle;margin:0 2px;position:relative;cursor:help}.p2p-dot.direct{background:#4caf50}.p2p-dot.relay{background:#ffc107}.p2p-dot.offline{background:#9e9e9e}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;padding:4px 10px;font-size:11px;font-weight:400;color:#fff;background:#000000d9;border-radius:4px;pointer-events:none;z-index:1000;opacity:0;transition:opacity var(--transition-fast);line-height:1.4}.tooltip:before{content:"";position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);border:4px solid transparent;border-bottom-color:#000000d9;pointer-events:none;z-index:1000;opacity:0;transition:opacity var(--transition-fast)}.tooltip:hover:after,.tooltip:hover:before{opacity:1}.tooltip.tooltip-above:after{top:auto;bottom:calc(100% + 6px)}.tooltip.tooltip-above:before{top:auto;bottom:calc(100% + 2px);border-bottom-color:transparent;border-top-color:#000000d9}.tooltip.tooltip-align-right:after{left:0;transform:none}.tooltip.tooltip-align-right:before{left:12px;transform:none}.tooltip.tooltip-align-left:after{left:auto;right:0;transform:none}.tooltip.tooltip-align-left:before{left:auto;right:12px;transform:none}.p2p-dot.tooltip:after{left:50%;transform:translate(-50%)}.p2p-dot.tooltip:before{left:50%;transform:translate(-50%)}.typing-indicator{display:flex;align-items:center;gap:4px;padding:6px 20px;height:28px;flex-shrink:0}.typing-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--text-muted, #888);animation:typing-bounce 1.4s infinite ease-in-out both}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.16s}.typing-dot:nth-child(3){animation-delay:.32s}@keyframes typing-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}.user-profile{padding:12px 16px;border-top:1px solid var(--border-color);flex-shrink:0}.user-profile-row{display:flex;align-items:center;gap:10px}.user-profile-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:var(--text-primary);flex-shrink:0}.user-profile-info{flex:1;min-width:0}.user-profile-handle{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3}.user-profile-id-section{margin-top:8px}.user-profile-id-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px}.user-profile-id-row{display:flex;align-items:center;gap:6px}.user-profile-id-value{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);line-height:1.3;word-break:break-all;flex:1;min-width:0;user-select:all}.user-profile-copy-btn{display:flex;align-items:center;justify-content:center;padding:4px 8px;font-size:11px;font-weight:500;color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0;cursor:pointer;white-space:nowrap}.user-profile-copy-btn:hover{background:var(--accent-dim);color:var(--text-primary)}.user-profile-copy-btn.copied{background:var(--status-online);color:#fff}.conversation-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:12px}.conversation-list-empty-icon{font-size:36px;opacity:.5;margin-bottom:4px}.conversation-list-empty-title{font-size:14px;font-weight:600;color:var(--text-secondary)}.conversation-list-empty-text{font-size:13px;color:var(--text-muted);line-height:1.5;max-width:220px}.conversation-list-empty-btn{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:8px 16px;font-size:13px;font-weight:500;color:#fff;background:var(--accent);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer}.conversation-list-empty-btn:hover{background:var(--accent-hover)}.form-helper{font-size:12px;color:var(--text-muted);margin-top:4px;line-height:1.4}.form-helper-example{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);margin-top:2px;opacity:.8}.setup-complete{text-align:center}.setup-complete-icon{font-size:48px;margin-bottom:16px}.setup-complete h2{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.setup-complete p{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.setup-complete-id-section{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:20px;text-align:left}.setup-complete-id-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px}.setup-complete-id-row{display:flex;align-items:center;gap:8px}.setup-complete-id-value{font-family:var(--font-mono);font-size:13px;color:var(--text-primary);word-break:break-all;flex:1;user-select:all}.setup-complete-copy-btn{display:flex;align-items:center;justify-content:center;padding:6px 12px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0;cursor:pointer;white-space:nowrap}.setup-complete-copy-btn:hover{background:var(--accent-dim);color:var(--text-primary)}.setup-complete-copy-btn.copied{background:var(--status-online);color:#fff}.setup-complete-hint{font-size:12px;color:var(--text-muted);margin-bottom:20px;line-height:1.4}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-tab{flex:1;padding:10px 0;font-size:13px;font-weight:600;color:var(--text-secondary);text-align:center;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.sidebar-tab:hover{color:var(--text-primary)}.sidebar-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.contact-list{flex:1;display:flex;flex-direction:column;overflow:hidden}.contact-list-search{padding:8px 12px}.contact-list-search input{width:100%;padding:8px 12px;border-radius:var(--radius-md);background:var(--bg-primary);border:1px solid var(--border-subtle);font-size:13px}.contact-list-items{flex:1;overflow-y:auto;overflow-x:hidden}.contact-list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast)}.contact-list-item:hover{background:var(--bg-hover)}.contact-item-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;color:var(--text-primary);flex-shrink:0}.contact-item-info{flex:1;min-width:0}.contact-item-name{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-item-mailbox{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-top:2px}.contact-item-trust{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);margin-top:2px}.contact-item-trust .trust-shield{font-size:12px}.contact-item-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.contact-list-item:hover .contact-item-actions{opacity:1}.contact-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:8px}.contact-list-empty-icon{font-size:36px;opacity:.5;margin-bottom:4px}.contact-list-empty-title{font-size:14px;font-weight:600;color:var(--text-secondary)}.contact-list-empty-text{font-size:13px;color:var(--text-muted);line-height:1.5;max-width:220px}.contact-edit-modal .modal-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.contact-edit-modal .modal-header-row h2{margin-bottom:0}.modal-close-btn{font-size:16px;color:var(--text-secondary)}.modal-close-btn:hover{color:var(--text-primary)}.contact-edit-mailbox-row{display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:8px 10px}.contact-edit-mailbox-value{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);word-break:break-all;flex:1;user-select:all}.contact-edit-trust{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);padding:6px 0}.contact-edit-trust .trust-shield{font-size:14px}.contact-edit-danger-zone{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.contact-edit-confirm-text{font-size:13px;color:var(--text-secondary);margin-bottom:12px;line-height:1.5}.contact-edit-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.btn-danger{background:var(--status-error, #e53935);color:#fff}.btn-danger:hover{background:#c62828}.chat-header-menu-wrap{position:relative;flex-shrink:0}.chat-header-menu-btn{font-size:20px;font-weight:700;letter-spacing:1px}.chat-header-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:160px;box-shadow:0 4px 16px #0006;z-index:100;padding:4px 0}.chat-header-menu-item{display:block;width:100%;padding:10px 16px;font-size:13px;color:var(--text-primary);text-align:left;background:none;border:none;cursor:pointer;transition:background var(--transition-fast)}.chat-header-menu-item:hover{background:var(--bg-hover)}.chat-header-menu-item.danger{color:#f55}.chat-header-menu-item.danger:hover{background:#ff55551a}.confirm-dialog p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:0}.sidebar-new-chat-wrap{position:relative}.contact-picker{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:260px;max-height:320px;display:flex;flex-direction:column;box-shadow:0 4px 20px #0006;z-index:100;overflow:hidden}.contact-picker-search{padding:8px;border-bottom:1px solid var(--border-subtle)}.contact-picker-search input{width:100%;padding:6px 10px;border-radius:var(--radius-sm);background:var(--bg-primary);border:1px solid var(--border-subtle);font-size:13px}.contact-picker-list{flex:1;overflow-y:auto}.contact-picker-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background var(--transition-fast)}.contact-picker-item:hover{background:var(--bg-hover)}.contact-picker-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:var(--text-primary);flex-shrink:0}.contact-picker-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-picker-empty{padding:20px;text-align:center;font-size:13px;color:var(--text-muted)}.conversation-avatar.group-avatar{background:var(--accent);color:#fff;font-size:14px}.conversation-subtitle{font-size:11px;color:var(--text-muted);margin-top:1px}.create-group-modal{max-height:80vh;display:flex;flex-direction:column}.create-group-modal .modal-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.create-group-modal .modal-header-row h2{margin-bottom:0}.group-member-count{font-size:12px;font-weight:400;color:var(--accent);margin-left:8px}.group-contact-search{margin-bottom:0}.group-contact-list{max-height:240px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin-bottom:8px}.group-contact-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-subtle)}.group-contact-item:last-child{border-bottom:none}.group-contact-item:hover{background:var(--bg-hover)}.group-contact-item.selected{background:var(--accent-dim)}.group-contact-checkbox{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkbox-empty{display:inline-block;width:16px;height:16px;border:2px solid var(--text-muted);border-radius:3px}.checkbox-checked{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:var(--accent);color:#fff;border-radius:3px;font-size:11px;font-weight:700}.group-contact-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:var(--text-primary);flex-shrink:0}.group-contact-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-contact-empty{padding:20px;text-align:center;font-size:13px;color:var(--text-muted)}.group-info-panel{max-height:80vh;display:flex;flex-direction:column;width:420px}.group-info-panel .modal-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.group-info-panel .modal-header-row h2{margin-bottom:0}.group-info-name-section{margin-bottom:20px}.group-info-name-row{display:flex;align-items:center;gap:12px}.group-info-avatar-lg{width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;flex-shrink:0}.group-info-name-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.group-info-name{font-size:18px;font-weight:600;color:var(--text-primary)}.group-info-member-count{font-size:13px;color:var(--text-muted)}.group-info-name-edit{display:flex;flex-direction:column;gap:8px}.group-info-name-edit input{width:100%;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg-primary);border:1px solid var(--border-subtle);font-size:14px}.group-info-name-edit-actions{display:flex;justify-content:flex-end;gap:8px}.group-info-members-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-subtle)}.group-info-add-btn{font-size:12px;padding:4px 10px}.group-info-add-member{margin-bottom:12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);overflow:hidden}.group-info-add-member input{width:100%;padding:8px 12px;border:none;border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);font-size:13px}.group-info-add-member-list{max-height:140px;overflow-y:auto}.group-info-member-list{flex:1;overflow-y:auto;max-height:280px;margin-bottom:16px}.group-info-member-item{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid var(--border-subtle)}.group-info-member-item:last-child{border-bottom:none}.group-info-member-info{flex:1;min-width:0;display:flex;align-items:center;gap:6px}.group-info-member-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-admin-badge{display:inline-flex;align-items:center;padding:1px 6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);background:var(--accent-dim);border-radius:3px;flex-shrink:0}.group-remove-btn{width:28px;height:28px;font-size:12px;color:var(--text-muted);opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast)}.group-info-member-item:hover .group-remove-btn{opacity:1}.group-remove-btn:hover{color:var(--status-error, #f44)}.group-info-footer{padding-top:12px;border-top:1px solid var(--border-subtle)}.group-leave-btn{width:100%}.message-sender-name{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:2px}.chat-header-name-clickable{cursor:pointer;transition:color var(--transition-fast)}.chat-header-name-clickable:hover{color:var(--accent)}.chat-header-status-clickable{cursor:pointer}.chat-header-status-clickable:hover{color:var(--text-secondary)}.link-preview-card{display:flex;gap:0;margin-top:6px;margin-bottom:2px;border-radius:var(--radius-sm);background:var(--bg-hover);overflow:hidden;cursor:pointer;transition:background var(--transition-fast);max-width:320px}.link-preview-card:hover{background:var(--bg-tertiary, var(--border-subtle))}.link-preview-border{width:4px;flex-shrink:0;background:var(--accent);border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.link-preview-content{flex:1;min-width:0;padding:8px 10px;display:flex;flex-direction:column;gap:3px}.link-preview-site{display:flex;align-items:center;gap:6px}.link-preview-favicon{width:16px;height:16px;flex-shrink:0;border-radius:2px}.link-preview-site-name{font-size:11px;font-weight:500;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-preview-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.link-preview-description{font-size:12px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.link-preview-url{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.message-link{color:var(--accent);text-decoration:none;word-break:break-all;transition:color var(--transition-fast)}.message-link:hover{color:var(--accent-hover);text-decoration:underline}:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--bg-surface: #222244;--bg-hover: #2a2a4c;--text-primary: #e0e0e0;--text-secondary: #a0a0b8;--text-muted: #6a6a88;--text-accent: #7c83ff;--accent: #7c83ff;--accent-hover: #6b72ee;--accent-dim: #4a4f99;--bubble-sent: #3a3a5c;--bubble-received: #2a2a4c;--status-online: #4caf50;--status-offline: #757575;--status-error: #ef5350;--status-warning: #ffa726;--trust-unverified: #ef5350;--trust-remote: #ffa726;--trust-proximity: #4caf50;--border-color: #333355;--border-subtle: #2a2a44;--sidebar-width: 320px;--header-height: 56px;--composer-min-height: 52px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--transition-fast: .15s ease;--transition-normal: .25s ease;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-family);font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--text-accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 12px;outline:none;transition:border-color var(--transition-fast)}input:focus,textarea:focus{border-color:var(--accent)}input::placeholder,textarea::placeholder{color:var(--text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){:root{--sidebar-width: 100%}}
