*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #000000;--bg-surface: #1b1b1b;--bg-elevated: #2d2d2d;--bg-hover: #414141;--text: #ffffff;--text-dim: #a1a2a1;--text-faint: #767676;--accent: #31f196;--accent-dim: #1fa06a;--danger: #ff3a3a;--border: #2d2d2d;--bubble-mine: #31f196;--bubble-mine-text: #000000;--bubble-theirs: #2d2d2d;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}html,body,#root{height:100%;background:var(--bg);font-family:var(--font);font-size:15px;color:var(--text);-webkit-font-smoothing:antialiased}#app{height:100%;background:var(--bg);display:flex;flex-direction:column;position:relative;overflow:hidden}.app-split{display:flex;height:100%;overflow:hidden}.left-panel{width:380px;min-width:380px;height:100%;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:clip;position:relative;z-index:0}.right-panel{flex:1;height:100%;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-surface)}.app-single{height:100%;display:flex;flex-direction:column;overflow:hidden}.empty-panel{flex:1;display:flex;align-items:center;justify-content:center}.empty-panel-content{text-align:center}.screen{display:none;flex-direction:column;height:100%}.screen.active{display:flex}.panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.loading-screen{justify-content:center;align-items:center;gap:16px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.loading-screen .logo{animation:pulse 1.8s ease-in-out infinite}.loading-spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}#onboarding{justify-content:center;align-items:center;padding:32px 24px;gap:0}.landing-hero{text-align:center;margin-bottom:48px}.landing-features{display:flex;flex-direction:column;gap:24px;width:100%;max-width:320px;margin-bottom:48px}.landing-feature{display:flex;align-items:flex-start;gap:14px}.landing-feature-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center}.landing-feature-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}.landing-feature-desc{font-size:13px;color:var(--text-dim);line-height:1.5}.landing-cta{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:280px}.landing-cta .btn{width:100%}.landing-disclaimer{font-size:12px;color:var(--text-faint);text-align:center}.logo{font-size:26px;font-weight:700;letter-spacing:3px;color:var(--accent)}.logo-sub{font-size:13px;color:var(--text-dim);margin-top:6px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;background:var(--accent);color:#000;border:none;border-radius:999px;font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.btn:hover{opacity:.9}.btn:active{transform:scale(.97)}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--text-dim)}.btn-danger{background:var(--danger);color:#fff}#identity-screen{padding:24px;gap:16px}.identity-label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.identity-value{font-size:13px;color:var(--accent);word-break:break-all;background:var(--bg-surface);padding:14px;border-radius:12px;cursor:pointer;position:relative}.identity-value:active{background:var(--bg-elevated)}.copy-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--accent);color:#000;padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;pointer-events:none;opacity:0;transition:opacity .2s}.copy-toast.show{opacity:1}.input{width:100%;padding:14px 16px;background:var(--bg-surface);border:none;border-radius:12px;color:var(--text);font-family:var(--font);font-size:15px;outline:none;transition:box-shadow .15s}.input:focus{box-shadow:0 0 0 1.5px var(--accent-dim)}.input::placeholder{color:var(--text-faint)}.conversations-screen{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg);position:relative}.header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;min-height:56px}.header-title{font-size:18px;font-weight:700;letter-spacing:1px}.header-avatar{width:34px;height:34px;border-radius:50%;background:var(--bg-elevated);border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-btn{background:none;border:none;color:var(--text-dim);font-family:var(--font);font-size:18px;cursor:pointer;padding:6px 8px;border-radius:8px;transition:background .15s}.header-btn:hover{background:var(--bg-surface);color:var(--text)}.conversation-list{flex:1;overflow-y:auto}.conversation-item{display:flex;align-items:center;padding:8px 16px;cursor:pointer;gap:12px;transition:background .1s;border-left:4px solid transparent}.conversation-item.has-unread{background:var(--bg-elevated);border-left-color:var(--accent)}.conversation-item:hover{background:var(--bg-hover)}.conversation-avatar{width:48px;height:48px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--text);font-weight:600;flex-shrink:0}.conversation-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.conversation-top-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.conversation-name-row{display:flex;align-items:center;gap:6px;min-width:0;flex:1}.conversation-name{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-bottom-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.conversation-preview{font-size:14px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.conversation-preview.has-draft{color:var(--danger)}.conversation-time{font-size:13px;color:var(--text-faint);flex-shrink:0;white-space:nowrap}.conversation-receipt{font-size:12px;color:var(--text-faint);flex-shrink:0}.unread-badge{background:var(--accent);color:#000;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.conv-selected{background:var(--bg-elevated)!important}.pin-icon{font-size:12px;flex-shrink:0}.mute-icon{font-size:12px;opacity:.5;flex-shrink:0}.archive-link{padding:12px 16px;font-size:13px;color:var(--accent);cursor:pointer}.archive-link:hover{background:var(--bg-surface)}.search-result{padding:12px 16px;cursor:pointer}.search-result:hover{background:var(--bg-elevated)}.search-result-conv{display:flex;align-items:center;gap:10px;font-size:14px}.search-result-msg{display:flex;flex-direction:column;gap:3px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:12px;color:var(--text-dim);text-align:center}.empty-state-hint{font-size:13px;color:var(--text-faint)}#chat{flex:1;overflow:hidden}.chat-header{display:flex;align-items:center;padding:10px 12px;gap:10px;min-height:56px}.back-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-surface);border:none;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.back-btn:hover{background:var(--bg-elevated)}.chat-peer-name{font-size:16px;font-weight:600;flex:1}.chat-peer-status{font-size:12px;color:var(--text-faint)}.messages{flex:1;overflow-y:auto;padding:5px 16px 25px;display:flex;flex-direction:column;gap:2px}.message-wrapper.grouped{margin-top:0}.message-wrapper:not(.grouped){margin-top:8px}.date-break{text-align:center;font-size:12px;font-weight:700;color:var(--text);letter-spacing:.6px;padding:12px 0 4px}.message{max-width:600px;padding:7px 13px;font-size:15px;line-height:1.3;word-wrap:break-word;position:relative}.message-mine{align-self:flex-end;background:var(--bubble-mine);color:var(--bubble-mine-text);border-radius:16px}.message-mine .message-meta{color:#0006}.message-mine .message-text a{color:#000;text-decoration-color:#0006}.message-theirs{align-self:flex-start;background:var(--bubble-theirs);color:var(--text);border-radius:16px}.message-system{align-self:center;color:var(--text-faint);font-size:12px;padding:6px 0;background:none;border-radius:0}.message-meta{display:flex;justify-content:flex-end;align-items:center;gap:6px;margin-top:4px;font-size:11px;color:var(--text-faint)}.message-text a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.message-text a:hover{opacity:.8}.unread-divider{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:12px;font-weight:600;color:var(--accent)}.unread-divider:before,.unread-divider:after{content:"";flex:1;height:1px;background:var(--accent);opacity:.3}.chat-peer-status.typing{color:var(--accent)}.typing-dots{display:inline-flex;gap:3px;align-items:center;height:16px}.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:typingBounce 1.6s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.message-wrapper{display:flex;flex-direction:column}.message-wrapper.selected .message{outline:2px solid var(--accent);outline-offset:2px;border-radius:18px}.message-reply-preview{padding:6px 10px;margin-bottom:6px;border-left:3px solid rgba(255,255,255,.3);background:#ffffff0f;border-radius:6px}.message-mine .message-reply-preview{border-left-color:#0000004d;background:#00000014}.message-reply-text{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.message-mine .message-reply-text{color:#0009}.hover-reaction-bar{position:absolute;top:-20px;display:flex;gap:2px;padding:2px 4px;background:var(--bg-elevated);border-radius:300px;box-shadow:0 2px 8px #0000004d;z-index:2}.hover-reaction-bar.bar-left{right:100%;margin-right:4px}.hover-reaction-bar.bar-right{left:100%;margin-left:4px}.hover-react-btn{width:32px;height:32px;border:none;background:none;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s}.hover-react-btn:hover{background:var(--bg-hover)}.message-reactions{display:flex;gap:8px;margin:4px 0 10px;flex-wrap:wrap}.reactions-mine{justify-content:flex-end}.reaction-pill{background:var(--bg-elevated);border:1px solid var(--border);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:default}.message-context-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#0009}.message-context-menu{background:var(--bg-surface);border-radius:16px;overflow:hidden;min-width:200px;box-shadow:0 8px 32px #00000080}.context-menu-item{display:block;width:100%;padding:14px 20px;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:15px;text-align:left;cursor:pointer;transition:background .1s}.context-menu-item:last-child{border-bottom:none}.context-menu-item:hover{background:var(--bg-elevated)}.context-menu-item:active{background:var(--border)}.context-menu-danger{color:var(--danger)}.reaction-picker{display:flex;padding:10px;gap:6px}.reaction-btn{background:none;border:none;font-size:26px;cursor:pointer;padding:6px 8px;border-radius:10px;transition:background .1s}.reaction-btn:hover{background:var(--bg-elevated)}.reply-bar{display:flex;align-items:center;padding:8px 12px;background:var(--bg-surface);gap:8px}.reply-bar-text{flex:1;font-size:13px;color:var(--text-dim);border-left:3px solid var(--accent);padding-left:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-bar-close{background:none;border:none;color:var(--text-faint);font-size:20px;cursor:pointer;padding:4px;border-radius:50%}.reply-bar-close:hover{color:var(--text);background:var(--bg-elevated)}.select-toolbar{display:flex;align-items:center;padding:10px 16px;background:var(--bg-surface);gap:8px;justify-content:space-between}.select-toolbar-count{font-size:14px;color:var(--text-dim)}.select-toolbar-actions{display:flex;gap:8px}.scroll-to-bottom{position:absolute;bottom:72px;right:16px;width:40px;height:40px;border-radius:50%;background:var(--bg-surface);border:none;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;box-shadow:0 2px 12px #00000080;transition:background .15s}.scroll-to-bottom:hover{background:var(--bg-elevated)}.compose{display:flex;padding:10px 15px;gap:8px;background:var(--bg-surface);align-items:center;min-height:60px;border-top:1px solid var(--border)}.compose-input{flex:1;padding:10px 16px;background:var(--bg-surface);border:none;border-radius:20px;color:var(--text);font-family:var(--font);font-size:15px;outline:none;resize:none;min-height:40px;max-height:120px}.compose-input:focus{box-shadow:0 0 0 1px var(--border)}.compose-input::placeholder{color:var(--text-faint)}.send-btn{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#000;border:none;font-family:var(--font);font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s;padding:0}.send-btn:disabled{opacity:.25;cursor:default}#btn-attach{width:40px;height:40px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000bf;display:none;align-items:flex-end;justify-content:center;z-index:10}.modal-overlay.active{display:flex}.modal{background:var(--bg-surface);border-radius:20px 20px 0 0;padding:24px;width:100%;display:flex;flex-direction:column;gap:16px}.modal-title{font-size:18px;font-weight:700;text-align:center}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.settings-section{margin:0 16px;padding:14px 0;border-bottom:1px solid var(--border)}.settings-section:last-child{border-bottom:none}.settings-card{background:var(--bg-surface);border-radius:14px;margin:8px 16px;overflow:hidden}.settings-card .settings-section{margin:0;padding:14px 16px}.settings-label{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;margin:16px 16px 8px;font-weight:500}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0}.settings-value{font-size:13px;color:var(--accent);word-break:break-all}.settings-hint{font-size:12px;color:var(--text-faint);margin-top:6px;line-height:1.5}.settings-nav-item{cursor:pointer;border-radius:0;transition:background .1s}.settings-nav-item:hover{background:var(--bg-surface)}.settings-nav-item:active{background:var(--bg-elevated)}.settings-chevron{font-size:20px;color:var(--text-faint)}.toggle{position:relative;display:inline-block;width:48px;height:28px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-elevated);border-radius:14px;cursor:pointer;transition:background .25s}.toggle-slider:before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;background:var(--text-faint);border-radius:50%;transition:transform .25s,background .25s}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(20px);background:#fff}.status-bar{padding:8px 16px;font-size:12px;text-align:center;background:var(--bg-surface);color:var(--text-dim);display:none}.status-bar.show{display:block}.status-bar.connected{background:var(--accent);color:#000}.status-bar.error{background:var(--danger);color:#fff}.group-avatar-large{width:88px;height:88px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto;cursor:pointer}.avatar-grid{display:flex;flex-wrap:wrap;gap:10px;padding:8px 0}.avatar-option{width:44px;height:44px;border:none;border-radius:12px;background:var(--bg-elevated);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s}.avatar-option:hover,.avatar-option.selected{transform:scale(1.1)}.avatar-option.selected{background:var(--accent-dim);box-shadow:0 0 0 2px var(--accent)}.color-option{width:36px;height:36px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:transform .1s}.color-option:hover,.color-option.selected{transform:scale(1.15)}.color-option.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}.request-item{display:flex;align-items:center;padding:14px 16px;gap:12px}.request-actions{display:flex;gap:6px;flex-shrink:0}.header-btn.timer-active{color:var(--accent);font-size:13px}.fab{position:absolute;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:var(--accent);border:none;color:#000;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00f78240;z-index:5;transition:transform .15s,box-shadow .15s}.fab:hover{transform:scale(1.05);box-shadow:0 6px 24px #00f78259}.fab:active{transform:scale(.95)}@media(max-width:768px){.compose-input{font-size:16px}}
