@import"https://fonts.googleapis.com/css2?family=Comfortaa:wght@700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #3390ec;--accent-2: #3390eccc;--accent-glow: #3390ec40;--accent-dim: #3390ec1e;--bg-0: #0d1117;--bg-1: #0e1621;--bg-2: #17212b;--bg-3: #1c2733;--bg-4: #242f3d;--border: rgba(255,255,255,.06);--border-active: rgba(255,255,255,.12);--text-primary: rgba(255,255,255,.88);--text-secondary: rgba(255,255,255,.48);--text-muted: rgba(255,255,255,.26);--bubble-in: #182533;--bubble-out: #2b5278;--scrollbar: rgba(255,255,255,.06);--red: #e53935;--green: #43a047;--yellow: #ffd740;--radius: 16px;--radius-sm: 10px;--shadow: 0 8px 40px rgba(0,0,0,.45);--shadow-sm: 0 2px 14px rgba(0,0,0,.3);--glass: rgba(14,22,33,.72);--glass-border: rgba(255,255,255,.08)}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg-0);color:var(--text-primary);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#ffffff24}.app{display:flex;height:100dvh;overflow:hidden;background:var(--bg-0);position:relative}.loading-screen{height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-0)}.loading-logo{display:flex;gap:3px;animation:loadingPulse 1.4s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.4;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-0);position:relative;padding:20px;overflow:hidden}.auth-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.auth-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.12;will-change:transform}.auth-blob-1{width:600px;height:600px;background:var(--accent);top:-150px;left:-120px;animation:blobDrift 12s ease-in-out infinite alternate}.auth-blob-2{width:480px;height:480px;background:#7c3aed;bottom:-120px;right:-100px;animation:blobDrift 15s ease-in-out infinite alternate-reverse}.auth-blob-3{width:320px;height:320px;background:#0ea5e9;top:45%;left:48%;animation:blobDrift 9s ease-in-out infinite alternate;animation-delay:-3s}@keyframes blobDrift{0%{transform:translate(0) scale(1)}to{transform:translate(50px,40px) scale(1.15)}}.auth-card{background:#17212bd9;border:1px solid var(--glass-border);border-radius:22px;padding:36px 32px;width:100%;max-width:400px;position:relative;box-shadow:var(--shadow),inset 0 1px #ffffff0f;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);animation:cardIn .4s cubic-bezier(.34,1.56,.64,1)}@keyframes cardIn{0%{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px}.auth-logo-icon{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--accent) 0%,#1a6bbf 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px var(--accent-glow)}.auth-logo-text{font-size:22px}.auth-title{font-size:20px;font-weight:600;margin-bottom:6px}.auth-subtitle{font-size:13px;color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.otp-inputs{display:flex;gap:8px;justify-content:center}.otp-digit{width:48px!important;height:54px;text-align:center;font-size:22px;font-weight:600;padding:0!important;border-radius:14px!important;transition:border-color .15s,box-shadow .15s!important}.otp-digit:focus{border-color:var(--accent)!important;box-shadow:0 0 0 3px var(--accent-glow)!important}.sidebar{width:310px;min-width:310px;background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100dvh;flex-shrink:0;transition:transform .28s cubic-bezier(.4,0,.2,1);position:relative;z-index:20}.sidebar-header{padding:16px 14px 12px;display:flex;align-items:center;justify-content:space-between;background:#0e162199;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);flex-shrink:0;position:relative;z-index:2}.sidebar-logo{font-size:18px;letter-spacing:-.3px}.search-bar{padding:10px 10px 6px;flex-shrink:0}.search-input-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-3);border:1px solid var(--border);border-radius:22px;padding:9px 14px;transition:border-color .15s,box-shadow .15s}.search-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:14px}.search-input::placeholder{color:var(--text-muted)}.chat-list{flex:1;overflow-y:auto;padding:6px 6px 0}.chat-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:14px;cursor:pointer;transition:background .12s;position:relative;overflow:hidden}.chat-item:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at var(--rx,50%) var(--ry,50%),rgba(255,255,255,.08) 0%,transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none}.chat-item:active:after{opacity:1}.chat-item:hover{background:var(--bg-3)}.chat-item.active{background:linear-gradient(135deg,var(--accent-dim) 0%,rgba(51,144,236,.08) 100%);box-shadow:inset 3px 0 0 var(--accent)}.chat-info{flex:1;min-width:0}.chat-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-preview{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.chat-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.chat-time{font-size:11px;color:var(--text-muted)}.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;animation:badgePop .25s cubic-bezier(.34,1.56,.64,1)}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.sidebar-nav{display:flex;border-top:1px solid var(--border);padding:4px 8px;gap:4px;flex-shrink:0;background:#0e162199;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border-radius:12px;border:none;cursor:pointer;background:transparent;color:var(--text-muted);font-size:11px;transition:all .18s}.nav-btn:hover{background:var(--bg-3);color:var(--text-secondary)}.nav-btn.active{color:var(--accent)}.nav-btn.active svg{filter:drop-shadow(0 0 6px var(--accent-glow))}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 14px 12px;border-top:1px solid var(--border);cursor:pointer;transition:background .15s;flex-shrink:0;padding-bottom:max(12px,env(safe-area-inset-bottom))}.sidebar-user:hover{background:var(--bg-3)}.avatar{position:relative;width:42px;height:42px;min-width:42px;min-height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#ffffffeb;flex-shrink:0;overflow:hidden;background:var(--bg-3)}.avatar img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:50%}.online-dot{position:absolute;bottom:1px;right:1px;width:12px;height:12px;border-radius:50%;background:var(--green);border:2px solid var(--bg-1);z-index:2;animation:onlinePulse 2.5s ease-in-out infinite}@keyframes onlinePulse{0%,to{box-shadow:0 0 #43a04780}50%{box-shadow:0 0 0 4px #43a04700}}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:200;background:#3390ec1f;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:2px dashed var(--accent);border-radius:14px;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:dropFadeIn .18s ease}.drop-overlay-inner{display:flex;flex-direction:column;align-items:center;color:var(--accent);font-size:17px;font-weight:600;background:#17212be6;border:1px solid var(--accent-dim);border-radius:18px;padding:28px 44px;gap:8px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes dropFadeIn{0%{opacity:0}to{opacity:1}}.chat-area{flex:1;display:flex;flex-direction:column;height:100dvh;position:relative;overflow:hidden;background:var(--bg-0);background-image:var(--chat-bg, none);background-size:cover;background-position:center}.chat-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);flex-shrink:0;position:relative;z-index:50;box-shadow:0 1px 0 var(--border),0 2px 12px #00000026}.chat-header-info{flex:1;min-width:0}.chat-header-name{font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-status{font-size:12px;color:var(--text-muted);margin-top:1px}.chat-header-status.online{color:var(--green)}.header-actions{display:flex;align-items:center;gap:2px}.messages-area{flex:1;overflow-y:auto;padding:10px 14px 4px;display:flex;flex-direction:column;gap:0;scroll-behavior:smooth}.messages-date-divider{text-align:center;padding:10px 0;position:relative;-webkit-user-select:none;user-select:none}.messages-date-divider span{background:#17212bb8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text-secondary);font-size:12px;padding:4px 14px;border-radius:20px;border:1px solid var(--border)}.message-wrap{display:flex;flex-direction:column}.message-wrap.in{align-items:flex-start;padding-left:2px}.message-wrap.out{align-items:flex-end;padding-right:2px}.message-sender-name{font-size:12px;font-weight:600;color:var(--accent);margin:0 4px 2px 14px}.message-bubble{max-width:min(68%,520px);padding:8px 12px 6px;border-radius:16px;font-size:14px;line-height:1.45;position:relative;animation:msgIn .18s cubic-bezier(.34,1.2,.64,1);word-break:break-word;will-change:transform}.message-wrap.in .message-bubble{background:var(--bubble-in);border-bottom-left-radius:4px}.message-wrap.out .message-bubble{background:var(--bubble-out);border-bottom-right-radius:4px}.message-wrap.in .message-bubble.tail:after{content:"";position:absolute;bottom:0;left:-7px;width:0;height:0;border-top:9px solid transparent;border-bottom:0px solid transparent;border-right:8px solid var(--bubble-in)}.message-wrap.out .message-bubble.tail:after{content:"";position:absolute;bottom:0;right:-7px;width:0;height:0;border-top:9px solid transparent;border-bottom:0px solid transparent;border-left:8px solid var(--bubble-out)}.message-wrap.in .message-bubble.tail{border-bottom-left-radius:2px}.message-wrap.out .message-bubble.tail{border-bottom-right-radius:2px}@keyframes msgIn{0%{opacity:0;transform:scale(.94) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.message-wrap.out .message-bubble{animation-name:msgInOut}@keyframes msgInOut{0%{opacity:0;transform:scale(.94) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.message-meta{display:flex;align-items:center;gap:4px;justify-content:flex-end;margin-top:3px;min-height:14px}.message-time{font-size:11px;color:var(--text-muted)}.message-edited{font-size:11px;color:var(--text-muted);font-style:italic}.message-deleted{color:var(--text-muted);font-style:italic;font-size:13px}.message-text{white-space:pre-wrap;word-break:break-word}.twemoji-img{width:1.25em;height:1.25em;vertical-align:-.25em;display:inline;margin:0 .05em}.message-big-emoji{font-size:0;line-height:1}.message-big-emoji span[style]{margin:0 2px}.message-wrap .message-bubble:has(.message-big-emoji){background:transparent!important;box-shadow:none;padding:4px 2px}.message-wrap .message-bubble:has(.message-big-emoji):after{display:none}.message-wrap .message-bubble:has(.message-big-emoji) .message-meta{margin-top:0}.message-image{cursor:pointer;border-radius:12px;overflow:hidden;max-width:300px}.message-image img{width:100%;display:block;border-radius:12px;transition:opacity .15s,transform .15s}.message-image img:hover{opacity:.88;transform:scale(1.01)}.message-reply{background:#ffffff0f;border-left:3px solid var(--accent);border-radius:6px;padding:5px 10px;margin-bottom:7px}.message-reply-name{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:2px}.message-reply-text{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-file{display:flex;align-items:center;gap:10px;padding:4px 2px;min-width:190px;max-width:280px}.file-icon{font-size:28px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:11px;color:var(--text-muted);margin-top:2px}.file-download{width:34px;height:34px;border-radius:10px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:17px;flex-shrink:0;transition:opacity .15s,transform .15s}.file-download:hover{opacity:.85;transform:scale(1.08)}.message-voice{display:flex;align-items:center;gap:8px;padding:4px 2px;min-width:210px;max-width:290px}.voice-play-btn{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s,box-shadow .15s}.voice-play-btn:hover{transform:scale(1.08);box-shadow:0 2px 12px var(--accent-glow)}.voice-play-btn:active{transform:scale(.96)}.voice-waveform{flex:1;display:flex;align-items:center;gap:2px;height:32px}.voice-bar{width:3px;border-radius:2px;min-height:3px;transition:height .1s;flex-shrink:0}.voice-duration{font-size:11px;color:var(--text-muted);flex-shrink:0;font-variant-numeric:tabular-nums}.typing-indicator{height:22px;padding:0 18px;flex-shrink:0;display:flex;align-items:center}.typing-indicator--active{gap:6px}.typing-text{font-size:12px;color:var(--text-muted);font-style:italic}.typing-dots{display:flex;align-items:center;gap:3px}.typing-dots span{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.18s}.typing-dots span:nth-child(3){animation-delay:.36s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.35}30%{transform:translateY(-5px);opacity:1}}.input-area{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);padding:10px 12px;flex-shrink:0;padding-bottom:max(10px,env(safe-area-inset-bottom));box-shadow:0 -1px 0 var(--border)}.input-area-inner{display:flex;align-items:flex-end;gap:6px}.message-input{flex:1;background:var(--bg-3);border:1px solid var(--border);border-radius:22px;padding:10px 16px;color:var(--text-primary);font-size:14px;line-height:1.45;resize:none;outline:none;max-height:140px;font-family:inherit;transition:border-color .15s,box-shadow .15s}.message-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.message-input::placeholder{color:var(--text-muted)}.input-actions{display:flex;gap:4px;flex-shrink:0}.send-btn,.voice-btn{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s;flex-shrink:0}.send-btn{background:linear-gradient(135deg,var(--accent) 0%,#1a6bbf 100%);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.send-btn:hover{transform:scale(1.08);box-shadow:0 4px 20px var(--accent-glow)}.send-btn:active{transform:scale(.94)}.voice-btn{background:var(--bg-3);color:var(--text-secondary);border:1px solid var(--border)}.voice-btn:hover{color:var(--accent);border-color:var(--accent);transform:scale(1.05)}.voice-btn:active{transform:scale(.94)}.reply-preview{display:flex;align-items:center;gap:8px;background:var(--bg-3);border-radius:12px;padding:8px 12px;border-left:3px solid var(--accent);animation:slideDown .18s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.reply-preview-text{flex:1;min-width:0}.reply-preview-name{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:2px}.reply-preview-content{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.context-menu{position:fixed;z-index:300;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:6px;box-shadow:var(--shadow);min-width:180px;animation:ctxIn .15s cubic-bezier(.34,1.4,.64,1);transform-origin:top left}@keyframes ctxIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;font-size:14px;cursor:pointer;transition:background .1s;color:var(--text-primary)}.context-menu-item:hover{background:var(--bg-3)}.context-menu-item.danger{color:var(--red)}.context-menu-item.danger:hover{background:#e539351a}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .18s ease}.modal{background:var(--bg-2);border:1px solid var(--glass-border);border-radius:20px;padding:24px;width:100%;max-width:480px;box-shadow:var(--shadow),inset 0 1px #ffffff0d;animation:modalSpring .3s cubic-bezier(.34,1.4,.64,1)}@keyframes modalSpring{0%{opacity:0;transform:scale(.88) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-size:16px;font-weight:600;margin-bottom:16px}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;background:#0d1117f2}.call-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 50% 20%,var(--accent-glow) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 20% 80%,rgba(124,58,237,.08) 0%,transparent 60%);pointer-events:none}.call-user-info{text-align:center;position:relative;z-index:1}.call-avatar{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--bg-3),var(--bg-4));margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:600;color:var(--text-primary);border:3px solid rgba(51,144,236,.5);box-shadow:0 0 0 8px #3390ec14,0 0 40px var(--accent-glow);animation:callRing 2.5s ease-in-out infinite;overflow:hidden}@keyframes callRing{0%,to{box-shadow:0 0 0 8px #3390ec14,0 0 40px var(--accent-glow)}50%{box-shadow:0 0 0 16px #3390ec0a,0 0 60px var(--accent-glow)}}.call-name{font-size:24px;font-weight:600;letter-spacing:-.3px}.call-status{font-size:14px;color:var(--text-secondary);margin-top:6px}.call-actions{display:flex;gap:20px;position:relative;z-index:1}.call-btn{width:62px;height:62px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.call-btn:hover{transform:scale(1.1)}.call-btn:active{transform:scale(.94)}.call-btn-end{background:#e53935;color:#fff;box-shadow:0 4px 20px #e5393573}.call-btn-accept{background:var(--green);color:#fff;box-shadow:0 4px 20px #43a04773}.call-btn-mute,.call-btn-video,.call-btn-flip{background:#ffffff1a;color:var(--text-primary);border:1px solid var(--border)}.video-call-area{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0a0f14;display:flex;align-items:center;justify-content:center;overflow:hidden}.video-call-area .remote-video-bg{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;width:calc(100% + 40px);height:calc(100% + 40px);object-fit:cover;filter:blur(28px) brightness(.3) saturate(1.3);pointer-events:none}.remote-video{position:relative;z-index:1;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:6px}.local-video-wrap{z-index:10;border-radius:14px;overflow:hidden;border:2px solid rgba(255,255,255,.2);box-shadow:0 6px 24px #0009;transition:box-shadow .18s,border-color .18s}.local-video-wrap:hover{box-shadow:0 6px 28px #3390ec66;border-color:#3390ec80}.local-video-wrap:active{cursor:grabbing!important}.local-video{width:100%;height:100%;object-fit:cover}.video-controls{position:absolute;bottom:28px;left:50%;transform:translate(-50%);z-index:3;display:flex;gap:14px;align-items:center;background:#0d111799;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:50px;padding:10px 20px;border:1px solid rgba(255,255,255,.08)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:#000000f2;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:fadeIn .2s ease}.lightbox img{max-width:92vw;max-height:92vh;border-radius:8px;object-fit:contain}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-0);position:relative;gap:12px}.empty-state-icon{display:flex;gap:4px}.empty-state-text{font-size:14px;color:var(--text-muted)}.input-field{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input-field::placeholder{color:var(--text-muted)}.input-group{margin-bottom:14px}.input-label{display:block;font-size:11px;color:var(--text-muted);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.btn{width:100%;padding:12px 20px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.48;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,#1a6bbf 100%);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-3)}.btn-icon{background:transparent;border:none;cursor:pointer;color:var(--text-secondary);padding:6px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .15s;width:34px;height:34px;flex-shrink:0}.btn-icon:hover{background:var(--bg-3);color:var(--text-primary)}.btn-icon:active{transform:scale(.9)}.error-msg{background:#e539351a;color:var(--red);border:1px solid rgba(229,57,53,.2);border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:14px;animation:shakeX .4s ease}@keyframes shakeX{0%,to{transform:translate(0)}20%{transform:translate(-6px)}60%{transform:translate(6px)}}.divider{height:1px;background:var(--border);margin:12px 0}.user-result{display:flex;align-items:center;gap:10px;padding:9px 6px;border-radius:12px;transition:background .12s}.user-result:hover{background:var(--bg-3)}.user-result-info{flex:1;min-width:0}.user-result-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-result-sub{font-size:12px;color:var(--text-muted);margin-top:1px}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;display:inline-block;animation:spin .65s linear infinite}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:19;background:#00000080;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.mobile-menu-btn{display:none!important}body[data-light]{--glass: rgba(240,242,245,.85);--glass-border: rgba(0,0,0,.08)}body[data-light] .unread-badge,body[data-light] .message-wrap.out .message-bubble{color:#fff}body[data-light] .message-wrap.out .message-time{color:#ffffffb3}body[data-light] .online-dot{border-color:var(--bg-1)}body[data-light] .messages-date-divider span{background:#ffffffbf;color:var(--text-secondary)}body[data-light] .send-btn{background:var(--accent)}body[data-light] .sidebar-header,body[data-light] .sidebar-nav,body[data-light] .input-area{background:#f0f2f5d9}body[data-light] .chat-header{background:#f5f7fae0}body[data-light] .drop-overlay-inner{background:#ffffffe6}body[data-light] .auth-card{background:#ffffffd9}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes flashRed{0%,to{background:#e539351a}50%{background:#e539354d}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@media (max-width: 700px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);box-shadow:4px 0 32px #00000080;z-index:30;width:86vw;min-width:unset;max-width:340px}.sidebar.open{transform:translate(0);animation:slideInLeft .28s cubic-bezier(.4,0,.2,1)}.mobile-overlay{display:block}.mobile-menu-btn{display:flex!important}.message-bubble{max-width:84%}.auth-card{padding:28px 20px}.call-btn{width:54px;height:54px}}
