@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0f;--panel-l:#181818;--panel-r:#121212;--surface:#242424;--surface-2:#2d2d2d;--accent:#e8622a;--accent-dim:rgba(232,98,42,.13);--text:#f0ede8;--text-dim:rgba(240,237,232,.5);--text-muted:rgba(240,237,232,.28);--border:rgba(255,255,255,.07);--border-md:rgba(255,255,255,.12);--font:"Nunito", sans-serif;--mono:"JetBrains Mono", monospace;--r:12px;--r-sm:8px;--r-xs:5px}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5;overflow:hidden}@supports (-webkit-touch-callout:none){html{height:-webkit-fill-available}body{height:-webkit-fill-available;min-height:-webkit-fill-available}#root{height:-webkit-fill-available}}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}@keyframes slideUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:translateY(10px)scale(.94)}65%{transform:translateY(-2px)scale(1.02)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes badgePop{0%{opacity:0;transform:scale(.3)}65%{transform:scale(1.28)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.sk{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.04) 75%) 0 0/600px 100%;border-radius:6px;animation:1.5s linear infinite shimmer}.login-wrap{background:var(--bg);justify-content:center;align-items:center;height:100%;display:flex;position:relative;overflow:hidden}.login-wrap:before{content:"";pointer-events:none;background:radial-gradient(rgba(232,98,42,.07) 0%,transparent 65%);width:700px;height:400px;position:absolute;top:-180px;left:50%;transform:translate(-50%)}.login-box{z-index:1;width:350px;animation:.48s cubic-bezier(.22,1,.36,1) both slideUp;position:relative}.login-logo{font-family:var(--mono);letter-spacing:.16em;color:var(--accent);text-transform:uppercase;align-items:center;gap:9px;margin-bottom:44px;font-size:10px;font-weight:500;display:flex}.login-logo-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2.2s ease-in-out infinite pulse}.login-title{color:var(--text);letter-spacing:-.6px;margin-bottom:10px;font-size:34px;font-weight:700;line-height:1.12}.login-sub{color:var(--text-dim);margin-bottom:40px;font-size:14px;line-height:1.65}.login-input{background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r);width:100%;color:var(--text);font-family:var(--font);outline:none;margin-bottom:12px;padding:15px 18px;font-size:15px;transition:border-color .2s,box-shadow .2s;display:block}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,98,42,.1)}.login-input::placeholder{color:var(--text-muted)}.login-btn{background:var(--accent);border-radius:var(--r);color:#fff;width:100%;font-family:var(--font);letter-spacing:.02em;cursor:pointer;border:none;padding:15px;font-size:15px;font-weight:700;transition:opacity .15s,transform .1s;position:relative;overflow:hidden}.login-btn:after{content:"";opacity:0;background:rgba(255,255,255,.1);transition:opacity .15s;position:absolute;top:0;bottom:0;left:0;right:0}.login-btn:hover:after{opacity:1}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.4;cursor:default}.login-error{border-radius:var(--r-sm);color:#ff7a7a;background:rgba(200,50,50,.09);border:1px solid rgba(200,50,50,.22);margin-top:14px;padding:12px 16px;font-size:13px;line-height:1.5;animation:.2s fadeIn}.login-hint{color:var(--text-muted);text-align:center;margin-top:18px;font-size:13px;line-height:1.5}.login-link{color:var(--text-dim);font-family:var(--font);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;margin:16px auto 0;padding:6px 10px;font-size:13px;text-decoration:underline;display:block}.login-link:hover{color:var(--text)}.typing-indicator{color:var(--text-dim);user-select:none;align-items:center;gap:10px;padding:6px 16px 10px;font-size:13px;animation:.18s fadeIn;display:flex}.typing-names{font-style:italic}.typing-dots{align-items:center;gap:3px;display:inline-flex}.typing-dots span{background:var(--text-dim);will-change:transform, opacity;border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite typingDot}.typing-dots span:nth-child(2){animation-delay:.18s}.typing-dots span:nth-child(3){animation-delay:.36s}@keyframes typingDot{0%,60%,to{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}.d-preview--typing{color:var(--accent);user-select:none;align-items:center;gap:6px;font-style:italic;display:inline-flex}.d-typing-name{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.d-typing-dots{flex-shrink:0;gap:2px;display:inline-flex}.d-typing-dots span{background:var(--accent);will-change:transform, opacity;border-radius:50%;width:4px;height:4px;animation:1.2s ease-in-out infinite typingDot}.d-typing-dots span:nth-child(2){animation-delay:.18s}.d-typing-dots span:nth-child(3){animation-delay:.36s}.app-shell{height:100%;animation:.28s fadeIn;display:flex;overflow:hidden}.panel-l{background:var(--panel-l);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:298px;display:flex;position:relative;overflow:hidden}.panel-l:after{content:"";background:linear-gradient(90deg, var(--accent) 0%, transparent 55%);opacity:.55;z-index:1;height:2px;position:absolute;top:0;left:0;right:0}.panel-l-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 16px 15px;display:flex}.panel-l-brand{flex-direction:column;gap:2px;display:flex}.panel-l-title{font-family:var(--mono);letter-spacing:.13em;color:var(--accent);text-transform:uppercase;font-size:12px;font-weight:500}.panel-l-count{font-family:var(--mono);color:var(--text-dim);font-size:12px}.logout-btn{border:1px solid var(--border-md);border-radius:var(--r-xs);color:var(--text-muted);font-family:var(--font);cursor:pointer;background:0 0;padding:5px 11px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s,background .15s}.logout-btn:hover{color:var(--text-dim);background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.22)}.dialog-list{flex:1;padding:5px 0;overflow-y:auto}.dialog-item{cursor:pointer;will-change:transform;align-items:center;gap:11px;padding:10px 14px;transition:background .14s;display:flex;position:relative}.dialog-item:before{content:"";background:var(--accent);opacity:0;border-radius:0 2px 2px 0;width:2.5px;transition:opacity .15s,transform .2s cubic-bezier(.34,1.56,.64,1);position:absolute;top:22%;bottom:22%;left:0;transform:scaleY(.5)}.dialog-item:hover{background:rgba(255,255,255,.03)}.dialog-item.active{background:var(--accent-dim)}.dialog-item.active:before{opacity:1;transform:scaleY(1)}.dialog-item.unread{background:rgba(232,98,42,.05)}.dialog-item.unread .d-name{color:var(--text);font-weight:700}.dialog-item.unread .d-preview{color:var(--text)}.dialog-item.unread .d-time{color:var(--text-dim)}.d-avatar{color:rgba(255,255,255,.9);letter-spacing:-.5px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:14px;font-weight:700;display:flex;position:relative;overflow:visible}.d-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.d-ch-badge{background:var(--panel-l);border:1.5px solid var(--panel-l);z-index:1;border-radius:50%;justify-content:center;align-items:center;width:17px;height:17px;font-size:8px;line-height:1;display:flex;position:absolute;bottom:-1px;right:-1px}.d-body{flex:1;min-width:0}.d-top{align-items:baseline;gap:6px;margin-bottom:3px;display:flex}.d-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:15px;font-weight:600;overflow:hidden}.d-time{font-family:var(--mono);color:var(--text-dim);flex-shrink:0;font-size:12px}.d-bottom{align-items:center;gap:6px;display:flex}.d-preview{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:14px;overflow:hidden}.d-unread{background:var(--accent);min-width:20px;height:20px;font-family:var(--mono);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0 5px;font-size:11px;font-weight:500;animation:.3s cubic-bezier(.34,1.56,.64,1) both badgePop;display:flex}.sk-dialog{align-items:center;gap:11px;padding:10px 14px;display:flex}.sk-avatar{border-radius:50%;flex-shrink:0;width:44px;height:44px}.sk-body{flex:1}.sk-line{height:10px;margin-bottom:7px}.sk-line:last-child{height:9px;margin-bottom:0}.state-center{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:32px;font-size:14px;animation:.3s fadeIn;display:flex}.state-icon{opacity:.3;font-size:30px}.panel-r{background:var(--panel-r);flex-direction:column;flex:1;min-width:0;display:flex;position:relative;overflow:hidden}.thread-hdr{border-bottom:1px solid var(--border);background:rgba(255,255,255,.01);flex-shrink:0;align-items:center;gap:12px;padding:14px 20px;display:flex}.thread-hdr-avatar{color:rgba(255,255,255,.9);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex;overflow:hidden}.thread-hdr-avatar img{object-fit:cover;width:100%;height:100%}.thread-hdr-info{flex:1;min-width:0}.thread-contact{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:17px;font-weight:600;overflow:hidden}.thread-sub{font-family:var(--mono);color:var(--text-dim);align-items:center;gap:6px;margin-top:2px;font-size:12px;display:flex}.thread-sub-dot{background:#3cba54;border-radius:50%;flex-shrink:0;width:5px;height:5px;animation:2.8s ease-in-out infinite pulse}.msg-list{flex-direction:column;flex:1;gap:3px;padding:14px 20px 6px;display:flex;overflow-y:auto}.date-div{font-family:var(--mono);letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;align-items:center;gap:10px;margin:14px 0 8px;font-size:12px;display:flex}.date-div:before,.date-div:after{content:"";background:var(--border);flex:1;height:1px}.msg-wrap{flex-direction:column;max-width:68%;animation:.22s cubic-bezier(.22,1,.36,1) both popIn;display:flex}.msg-wrap.in{align-self:flex-start;align-items:flex-start}.msg-wrap.out{align-self:flex-end;align-items:flex-end}.msg-bubble{word-break:break-word;white-space:pre-wrap;border-radius:16px;padding:9px 14px;font-size:15px;line-height:1.55}.msg-wrap.in .msg-bubble{background:var(--surface);color:var(--text);border-bottom-left-radius:4px}.msg-wrap.out .msg-bubble{color:var(--text);background:rgba(232,98,42,.16);border:1px solid rgba(232,98,42,.27);border-bottom-right-radius:4px}.msg-meta{align-items:center;gap:5px;padding:3px 3px 0;display:flex}.msg-wrap.out .msg-meta{justify-content:flex-end}.msg-time{font-family:var(--mono);color:var(--text-dim);font-size:12px}.msg-ch{font-size:12px}.msg-sender{font-family:var(--mono);color:var(--text-dim);font-size:12px}.msg-wrap.msg-pending{opacity:.65}.msg-wrap.msg-failed .msg-bubble{border-color:rgba(200,50,50,.35)!important}.msg-status-spinner{border:1.5px solid rgba(240,237,232,.18);border-top-color:var(--text-muted);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:.7s linear infinite spin;display:inline-block}.msg-status-fail{color:#fff;width:14px;height:14px;font-size:9px;font-weight:700;font-family:var(--mono);cursor:help;background:rgba(220,50,50,.85);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sk-msg-list{flex-direction:column;flex:1;gap:7px;padding:14px 20px;display:flex;overflow:hidden}.sk-msg-row{display:flex}.sk-msg-row.in{justify-content:flex-start}.sk-msg-row.out{justify-content:flex-end}.sk-bubble{border-radius:14px;height:40px}.thread-empty{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;animation:.3s fadeIn;display:flex}.thread-empty-glyph{opacity:.12;font-size:56px;line-height:1}.thread-empty-label{color:var(--text-muted);font-size:15px;font-weight:600}.thread-empty-hint{font-family:var(--mono);color:rgba(240,237,232,.16);letter-spacing:.05em;font-size:12px}.send-form{border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end;gap:10px;padding:12px 16px 14px;display:flex}.send-input-wrap{flex:1;position:relative}.send-input{resize:none;background:var(--surface);border:1.5px solid var(--border-md);width:100%;min-height:44px;max-height:110px;color:var(--text);font-family:var(--font);border-radius:22px;outline:none;padding:10px 16px;font-size:15px;line-height:1.5;transition:border-color .2s,box-shadow .2s;display:block;overflow-y:auto}.send-input:focus{border-color:rgba(232,98,42,.42);box-shadow:0 0 0 3px rgba(232,98,42,.07)}.send-input::placeholder{color:var(--text-muted)}.send-limit{font-family:var(--mono);color:var(--text-muted);font-size:11px;transition:color .2s;position:absolute;bottom:-17px;right:4px}.send-limit.warn{color:#e8a02a}.send-limit.over{color:#e84a2a}.send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .15s,transform .12s;display:flex;position:relative;overflow:hidden}.send-btn:after{content:"";opacity:0;background:rgba(255,255,255,.12);border-radius:50%;transition:opacity .15s;position:absolute;top:0;bottom:0;left:0;right:0}.send-btn:hover:not(:disabled):after{opacity:1}.send-btn:active:not(:disabled){transform:scale(.88)}.send-btn:disabled{opacity:.28;cursor:default}.pause-btn{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);cursor:pointer;white-space:nowrap;flex-shrink:0;justify-content:center;align-items:center;gap:5px;min-width:32px;height:32px;padding:0 10px;font-size:14px;transition:background .15s,border-color .15s,min-width .2s;display:flex}.pause-btn:hover:not(:disabled){border-color:var(--border-md);background:var(--surface-2)}.pause-btn--paused{border-color:var(--accent);color:var(--text);background:rgba(232,98,42,.18);animation:2.5s ease-in-out infinite pauseGlow}.pause-btn--paused:hover:not(:disabled){background:rgba(232,98,42,.28);animation:none}@keyframes pauseGlow{0%,to{box-shadow:0 0 0 2px rgba(232,98,42,.3)}50%{box-shadow:0 0 0 6px rgba(232,98,42,.05)}}.pause-btn--disabled{opacity:.3;cursor:not-allowed}.pause-btn-icon{font-size:13px}.pause-btn-timer{font-family:var(--mono);color:var(--accent);letter-spacing:.04em;font-size:13px;font-weight:500}.pause-btn-spinner{border:2px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;width:12px;height:12px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.lang-toggle{background:var(--surface);border-radius:var(--r-sm);border:1px solid var(--border);flex-shrink:0;align-items:center;gap:2px;padding:2px;display:flex}.lang-btn{font-family:var(--mono);letter-spacing:.06em;cursor:pointer;color:var(--text-dim);background:0 0;border:none;border-radius:6px;padding:5px 11px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.lang-btn:hover:not(:disabled){color:var(--text)}.lang-btn.active{background:var(--accent);color:#fff}.lang-btn:disabled{opacity:.4;cursor:default}.d-ch-badge--icon{background:0 0;border:none;width:15px;height:15px;padding:0;overflow:hidden}.d-ch-badge--icon svg{display:block}.msg-lang-badge{font-family:var(--mono);color:var(--accent);letter-spacing:.05em;background:rgba(232,98,42,.14);border-radius:3px;padding:1px 5px;font-size:11px;font-weight:500}.send-form-wrap{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex}.send-form-wrap .send-form{border-top:none}.ig-window-warning{color:var(--text-dim);background:rgba(232,98,42,.1);border-bottom:1px solid rgba(232,98,42,.25);align-items:flex-start;gap:8px;padding:8px 16px;font-size:13px;line-height:1.4;display:flex}.ig-window-icon{flex-shrink:0;margin-top:1px;font-size:15px}.ig-window-warning strong{color:#e8622a}.translate-preview{background:rgba(232,98,42,.05);border-bottom:1px solid rgba(232,98,42,.14);flex-direction:column;gap:8px;padding:10px 16px 6px;animation:.2s cubic-bezier(.22,1,.36,1) both slideUp;display:flex}.tp-header{justify-content:space-between;align-items:center;display:flex}.tp-label{font-family:var(--mono);color:var(--text-muted);letter-spacing:.05em;font-size:12px}.tp-label strong{color:var(--accent);font-weight:600}.tp-close{width:20px;height:20px;color:var(--text-muted);cursor:pointer;background:rgba(255,255,255,.07);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;line-height:1;transition:background .15s,color .15s;display:flex}.tp-close:hover{color:var(--text);background:rgba(255,255,255,.12)}.tp-textarea{resize:none;background:var(--surface);border-radius:var(--r-sm);width:100%;min-height:44px;max-height:130px;color:var(--text);font-family:var(--font);border:1.5px solid rgba(232,98,42,.28);outline:none;padding:8px 12px;font-size:15px;line-height:1.5;transition:border-color .2s;display:block;overflow-y:auto}.tp-textarea:focus{border-color:rgba(232,98,42,.55)}.tp-send-btn{border-radius:var(--r-sm);background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;border:none;align-self:flex-end;align-items:center;gap:6px;padding:7px 14px;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.tp-send-btn:hover:not(:disabled){opacity:.88}.tp-send-btn:disabled{opacity:.35;cursor:default}.translate-btn{background:var(--surface-2);border:1.5px solid var(--border-md);width:44px;height:44px;color:var(--text-dim);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex;position:relative}.translate-btn:hover:not(:disabled){color:var(--accent);background:rgba(232,98,42,.12);border-color:rgba(232,98,42,.35)}.translate-btn:disabled{opacity:.28;cursor:default}.translate-btn-spinner{border:2px solid rgba(240,237,232,.15);border-top-color:var(--text-dim);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.thread-sub svg{flex-shrink:0}.thread-hdr-clickable{cursor:pointer;border-radius:var(--r-sm);flex:1;align-items:center;gap:12px;min-width:0;margin:-4px -6px;padding:4px 6px;transition:background .15s;display:flex}.thread-hdr-clickable:hover{background:rgba(255,255,255,.05)}.thread-hdr-clickable:hover .thread-contact{color:var(--accent)}.contact-panel{background:var(--panel-l);border-left:1px solid var(--border);z-index:10;flex-direction:column;width:280px;height:calc(100% - 57px);animation:.22s cubic-bezier(.22,1,.36,1) both slideInRight;display:flex;position:absolute;top:57px;right:0;overflow-y:auto}@keyframes slideInRight{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}.cp-hdr{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.cp-hdr-title{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:12px;font-weight:500}.cp-close{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:rgba(255,255,255,.06);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;line-height:1;transition:background .15s,color .15s;display:flex}.cp-close:hover{color:var(--text);background:rgba(255,255,255,.12)}.cp-loading{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex}@keyframes spin2{to{transform:rotate(360deg)}}.cp-spinner{border:2px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin2}.cp-error{color:#ff7a7a;border-radius:var(--r-sm);background:rgba(200,50,50,.07);margin:12px;padding:16px;font-size:13px}.cp-body{padding:0 0 16px}.cp-avatar-wrap{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:8px;padding:20px 16px 16px;display:flex}.cp-avatar{color:rgba(255,255,255,.9);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:22px;font-weight:700;display:flex;overflow:hidden}.cp-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.cp-name{color:var(--text);text-align:center;word-break:break-word;font-size:15px;font-weight:600}.cp-channel{color:var(--text-muted);align-items:center;gap:5px;font-size:13px;display:flex}.cp-section{border-bottom:1px solid var(--border);padding:12px 16px 4px}.cp-section:last-child{border-bottom:none}.cp-section-title{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:500}.cp-row{align-items:flex-start;gap:8px;margin-bottom:7px;display:flex}.cp-label{color:var(--text-muted);flex-shrink:0;width:88px;padding-top:1px;font-size:13px}.cp-value{color:var(--text);word-break:break-all;flex:1;font-size:13px}.cp-tags{flex-wrap:wrap;gap:5px;display:flex}.cp-tag{background:var(--surface);border:1px solid var(--border-md);color:var(--text-dim);border-radius:4px;padding:3px 8px;font-size:12px}.lang-btn:not(.active){background:rgba(255,255,255,.04)}.translate-progress{color:var(--text-dim);background:rgba(232,98,42,.07);border-bottom:1px solid rgba(232,98,42,.14);flex-shrink:0;align-items:center;gap:10px;padding:8px 18px;font-size:14px;animation:.2s fadeIn;display:flex}.translate-progress-spinner{border:2px solid rgba(232,98,42,.2);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin}.thread-back-btn{width:34px;height:34px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:22px;line-height:1;transition:background .15s,color .15s;display:none}.thread-back-btn:hover{color:var(--text);background:rgba(255,255,255,.08)}.msg-media-img{cursor:pointer;object-fit:cover;border-radius:10px;max-width:240px;max-height:280px;display:block}.msg-media-link{border-radius:var(--r-sm);background:var(--surface-2);color:var(--accent);border:1px solid var(--border-md);align-items:center;gap:7px;padding:8px 12px;font-size:14px;text-decoration:none;transition:background .15s;display:inline-flex}.msg-media-link:hover{background:var(--surface)}.msg-audio{width:100%;min-width:180px;max-width:260px;display:block}.msg-bubble--media{padding:4px 0;background:0 0!important;border:none!important}.qr-popup{background:var(--panel-l);border:1px solid var(--border-md);border-radius:var(--r);z-index:20;max-height:220px;position:absolute;bottom:calc(100% + 6px);left:0;right:0;overflow-x:hidden;overflow-y:auto;box-shadow:0 -8px 28px rgba(0,0,0,.4)}.qr-popup-item{cursor:pointer;border-bottom:1px solid var(--border);flex-direction:column;gap:2px;padding:9px 14px;transition:background .12s;display:flex}.qr-popup-item:last-child{border-bottom:none}.qr-popup-item:hover{background:var(--accent-dim)}.qr-popup-item-key{font-family:var(--mono);color:var(--accent);font-size:12px;font-weight:600}.qr-popup-item-preview{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.qr-popup-empty{text-align:center;color:var(--text-muted);padding:14px;font-size:13px}.qr-modal-overlay{z-index:100;background:rgba(0,0,0,.6);justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.qr-modal{background:var(--panel-l);border-radius:var(--r);border:1px solid var(--border-md);flex-direction:column;width:540px;max-width:calc(100vw - 24px);max-height:80vh;animation:.2s cubic-bezier(.22,1,.36,1) both slideUp;display:flex;box-shadow:0 24px 60px rgba(0,0,0,.55)}.qr-modal-hdr{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.qr-modal-title{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:12px;font-weight:600}.qr-modal-close{width:26px;height:26px;color:var(--text-dim);cursor:pointer;background:rgba(255,255,255,.07);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:background .15s,color .15s;display:flex}.qr-modal-close:hover{color:var(--text);background:rgba(255,255,255,.13)}.qr-modal-body{flex:1;padding:12px 16px;overflow-y:auto}.qr-list{flex-direction:column;gap:8px;display:flex}.qr-list-item{border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.qr-list-item-content{flex:1;min-width:0}.qr-list-key{font-family:var(--mono);color:var(--accent);margin-bottom:4px;font-size:13px;font-weight:600}.qr-list-body{color:var(--text-dim);white-space:pre-wrap;word-break:break-word;max-height:56px;font-size:13px;overflow:hidden}.qr-list-del{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:background .15s,color .15s;display:flex}.qr-list-del:hover{color:#ff7a7a;background:rgba(200,50,50,.15)}.qr-modal-empty{text-align:center;color:var(--text-muted);padding:32px;font-size:14px}.qr-modal-ftr{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;padding:14px 16px;display:flex}.qr-add-row{align-items:flex-start;gap:8px;display:flex}.qr-add-key{background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r-sm);width:130px;color:var(--text);font-family:var(--mono);outline:none;flex-shrink:0;padding:9px 12px;font-size:13px;transition:border-color .2s}.qr-add-key:focus{border-color:var(--accent)}.qr-add-body{resize:none;background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r-sm);min-height:68px;color:var(--text);font-family:var(--font);outline:none;flex:1;padding:9px 12px;font-size:14px;transition:border-color .2s;display:block;overflow-y:auto}.qr-add-body:focus{border-color:var(--accent)}.qr-add-btn{border-radius:var(--r-sm);background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;border:none;align-self:flex-end;padding:9px 20px;font-size:14px;font-weight:600;transition:opacity .15s}.qr-add-btn:hover:not(:disabled){opacity:.88}.qr-add-btn:disabled{opacity:.35;cursor:default}.qr-btn{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-sm);width:38px;height:38px;color:var(--text-dim);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;font-size:17px;transition:background .15s,border-color .15s;display:flex}.qr-btn:hover{background:var(--surface-2);border-color:rgba(255,255,255,.18)}.attach-btn{background:var(--surface);border:1px solid var(--border-md);cursor:pointer;width:38px;height:38px;color:var(--text-dim);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.attach-btn:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:rgba(255,255,255,.18)}.attach-btn:disabled{opacity:.35;cursor:default}.attach-preview{background:var(--surface);border-bottom:1px solid var(--border);border-radius:10px 10px 0 0;align-items:center;gap:10px;padding:8px 12px;display:flex;position:relative}.attach-preview-img{object-fit:cover;border-radius:6px;max-width:120px;max-height:80px}.attach-preview-doc{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:280px;font-size:13px;overflow:hidden}.attach-preview-remove{cursor:pointer;color:var(--text-dim);background:0 0;border:none;border-radius:4px;flex-shrink:0;margin-left:auto;padding:2px 4px;font-size:18px;line-height:1;transition:color .12s}.attach-preview-remove:hover{color:var(--text)}.lang-label-short{display:none}@media (max-width:640px){html,body,#root{font-size:16px}.app-shell{flex-direction:row}.panel-l,.panel-r{flex-shrink:0;width:100%}.app-shell.mobile-thread .panel-l,.app-shell.mobile-list .panel-r{display:none}.thread-back-btn{display:flex}.panel-l-header{padding:14px 12px 12px}.dialog-item{padding:10px 12px}.thread-hdr{padding:12px}.msg-list{padding:10px 12px 6px}.translate-preview{padding:8px 12px 4px}.send-form{padding:10px 10px calc(12px + env(safe-area-inset-bottom,0px))}.panel-l-header{padding-top:max(14px, calc(14px + env(safe-area-inset-top,0px)))}.thread-hdr{padding-top:max(12px, calc(12px + env(safe-area-inset-top,0px)))}.contact-panel{width:100%;top:57px}.msg-wrap{max-width:85%}.send-btn{touch-action:manipulation;width:48px;height:48px}.send-input{scrollbar-width:none;padding:12px 16px;font-size:16px}.send-input::-webkit-scrollbar{display:none}.login-input{touch-action:manipulation;padding:14px 16px;font-size:16px}.login-btn{touch-action:manipulation;-webkit-tap-highlight-color:transparent;padding:14px}.login-link{-webkit-tap-highlight-color:transparent}.typing-indicator{padding:4px 12px 6px;font-size:13px}.d-preview--typing{font-size:14px}.logout-btn,.pause-btn,.lang-btn,.qr-btn{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.app-shell,html,body,#root{height:100vh}@supports (height:100dvh){.app-shell,html,body,#root{height:100dvh}}@supports (-webkit-touch-callout:none){.app-shell,html,body,#root{height:-webkit-fill-available}}.lang-toggle{gap:1px}.lang-btn{padding:4px 8px}.lang-label-long{display:none}.lang-label-short{display:inline}}
