.msg-wrap{display:flex;height:calc(100vh - 60px);max-width:1000px;margin:0 auto;border-left:1px solid var(--b0);border-right:1px solid var(--b0)}.msg-sidebar{width:320px;border-right:1px solid var(--b0);display:flex;flex-direction:column;flex-shrink:0}.msg-sb-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--b0)}.msg-sb-title{font-family:Bebas Neue,monospace;font-size:20px;letter-spacing:3px}.msg-new-btn{background:var(--a);color:#000;border:none;width:30px;height:30px;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.msg-new-btn:hover{opacity:.85}.msg-search-wrap{padding:8px 12px}.msg-search{width:100%;background:var(--bg0);border:1px solid var(--b0);border-radius:8px;color:var(--t0);padding:9px 12px;font-size:12px;outline:none;box-sizing:border-box;transition:border-color .2s}.msg-search:focus{border-color:var(--a)}.msg-convos{flex:1;overflow-y:auto}.msg-convo{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--b0);cursor:pointer;transition:background .15s}.msg-convo:hover{background:#ccff000a}.msg-convo.active{background:#ccff0012;border-left:3px solid var(--a)}.msg-convo-av{width:44px;height:44px;border-radius:50%;background:var(--bg0);border:1px solid var(--b0);display:flex;align-items:center;justify-content:center;font-family:monospace;font-weight:900;font-size:14px;color:var(--a);flex-shrink:0;overflow:hidden;position:relative}.msg-convo-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}.msg-convo-info{flex:1;min-width:0}.msg-convo-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-convo-last{font-size:12px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.msg-convo-right{text-align:right;flex-shrink:0}.msg-convo-time{font-family:monospace;font-size:10px;color:var(--t2);letter-spacing:1px}.msg-convo-unread{width:18px;height:18px;border-radius:50%;background:var(--a);color:#000;font-size:9px;font-weight:900;display:flex;align-items:center;justify-content:center;margin-top:4px;margin-left:auto}.msg-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:30px;font-family:monospace;font-size:11px;color:var(--t2);letter-spacing:2px}.msg-loader{width:16px;height:16px;border:2px solid var(--b0);border-top-color:var(--a);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.msg-chat{flex:1;display:flex;flex-direction:column;min-width:0}.msg-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px}.msg-active{display:flex;flex-direction:column;height:100%}.msg-chat-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--b0);flex-shrink:0}.msg-back-btn{display:none;background:none;border:none;color:var(--t1);font-size:20px;cursor:pointer;padding:4px}.msg-chat-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg0);border:1px solid var(--b0);display:flex;align-items:center;justify-content:center;font-family:monospace;font-weight:900;font-size:13px;color:var(--a);flex-shrink:0;overflow:hidden}.msg-chat-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.msg-chat-info{flex:1}.msg-chat-name{font-weight:700;font-size:14px}.msg-chat-status{font-family:monospace;font-size:11px;letter-spacing:1.5px;color:var(--t2)}.msg-chat-status.online{color:#0f8}.msg-chat-profile-btn{font-family:monospace;font-size:9px;letter-spacing:1.5px;color:var(--a);text-decoration:none;padding:6px 12px;border:1px solid rgba(204,255,0,.2);border-radius:6px;transition:all .2s}.msg-chat-profile-btn:hover{background:#ccff000d}.msg-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth}.msg-bubble-wrap{display:flex;flex-direction:column;max-width:75%}.msg-bubble-wrap.sent{align-self:flex-end;align-items:flex-end}.msg-bubble-wrap.received{align-self:flex-start;align-items:flex-start}.msg-bubble{padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.45;word-break:break-word}.msg-bubble-wrap.sent .msg-bubble{background:var(--a);color:#000;border-bottom-right-radius:4px;box-shadow:0 2px 8px #ccff0026}.msg-bubble-wrap.received .msg-bubble{background:var(--bg1);border:1px solid var(--b0);color:var(--t0);border-bottom-left-radius:4px;box-shadow:0 2px 8px #0000004d}.msg-bubble-time{font-family:monospace;font-size:10px;color:var(--t2);margin-top:3px;letter-spacing:1px}.msg-date-sep{text-align:center;font-family:monospace;font-size:10px;letter-spacing:2px;color:var(--t2);padding:12px 0}.msg-input-area{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--b0);flex-shrink:0}.msg-input{flex:1;background:var(--bg0);border:1px solid var(--b0);border-radius:20px;color:var(--t0);padding:12px 18px;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.msg-input:focus{border-color:var(--a);box-shadow:0 0 0 3px #ccff001a}.msg-send-btn{width:40px;height:40px;border-radius:50%;background:var(--a);color:#000;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.msg-send-btn:hover{opacity:.85}.msg-attach-btn{width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid var(--b0);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.msg-attach-btn:hover{border-color:var(--a);color:var(--a)}.msg-img-preview{padding:8px 16px;border-top:1px solid var(--b0);position:relative;display:flex;align-items:center}.msg-img-preview img{max-height:120px;max-width:200px;border-radius:8px;object-fit:cover}.msg-img-preview-close{position:absolute;top:4px;right:20px;background:#000000b3;border:none;color:#fff;width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}.msg-bubble img.msg-img{max-width:240px;max-height:300px;border-radius:8px;cursor:pointer;display:block;margin-top:4px}.msg-bubble img.msg-img:hover{opacity:.9}.msg-fullscreen{position:fixed;inset:0;background:#000000e6;z-index:99999;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.msg-fullscreen img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px}.msg-modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.msg-modal{background:var(--bg1);border:1px solid var(--b0);border-radius:12px;width:100%;max-width:400px;max-height:70vh;overflow:hidden;display:flex;flex-direction:column}.msg-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--b0);font-family:monospace;font-size:11px;letter-spacing:3px;font-weight:700}.msg-modal-body{padding:14px;overflow-y:auto}.msg-user-results{max-height:300px;overflow-y:auto}.msg-user-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;cursor:pointer;transition:background .15s}.msg-user-item:hover{background:#ccff000a}.msg-user-av{width:36px;height:36px;border-radius:50%;background:var(--bg0);border:1px solid var(--b0);display:flex;align-items:center;justify-content:center;font-family:monospace;font-weight:900;font-size:12px;color:var(--a);flex-shrink:0;overflow:hidden}.msg-user-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}.msg-user-name{font-weight:600;font-size:13px}.msg-user-role{font-family:monospace;font-size:9px;letter-spacing:1.5px;color:var(--t2)}.msg-typing{display:flex;align-items:center;gap:6px;padding:8px 16px;font-family:monospace;font-size:11px;color:var(--t2);letter-spacing:1px}.msg-typing-dots span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--a);animation:typingDot 1.4s ease-in-out infinite}.msg-typing-dots span:nth-child(2){animation-delay:.2s}.msg-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.msg-emoji-btn{width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid var(--b0);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.msg-emoji-btn:hover{border-color:var(--a);color:var(--a)}.msg-emoji-picker{position:absolute;bottom:60px;left:50px;background:var(--bg1);border:1px solid var(--b0);border-radius:12px;padding:12px;display:none;flex-wrap:wrap;gap:4px;max-width:280px;box-shadow:0 8px 32px #00000080;z-index:100}.msg-emoji-picker.open{display:flex}.msg-emoji-item{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;border-radius:6px;transition:background .15s}.msg-emoji-item:hover{background:#ccff0014}.msg-read-status{font-size:12px;margin-left:4px;opacity:.6}.msg-read-status.read{color:var(--a);opacity:1}.msg-convo-online{position:absolute;bottom:1px;right:1px;width:10px;height:10px;border-radius:50%;background:#0f8;border:2px solid var(--bg0);box-shadow:0 0 6px #0f86}@media (max-width: 700px){.msg-sidebar{width:100%}.msg-chat,.msg-wrap.chat-open .msg-sidebar{display:none}.msg-wrap.chat-open .msg-chat{display:flex}.msg-wrap.chat-open .msg-back-btn{display:block}}@media (max-width: 640px){.msg-sidebar{width:100%;position:absolute;z-index:10;background:var(--bg0)}.msg-sidebar.hidden{display:none}.msg-back-btn{display:flex!important}.msg-chat-profile-btn{display:none}.msg-wrap{position:relative}}
