.auth-page{width:100%;height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px;position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(139,92,246,.06) 0%,transparent 40%);animation:authBgShift 20s ease-in-out infinite alternate;pointer-events:none}@keyframes authBgShift{0%{transform:translate(0)}to{transform:translate(-5%,-5%)}}.auth-container{width:100%;max-width:420px;background:var(--bg-secondary);border-radius:var(--radius-xl);padding:40px 36px;border:1px solid var(--border);box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:slideUp .5s ease-out}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{margin-bottom:16px;display:inline-block}.auth-header h1{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:6px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{font-size:var(--font-size-sm)}.auth-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.auth-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--error);font-size:var(--font-size-sm);text-align:center}.auth-submit{margin-top:8px;padding:12px;font-size:var(--font-size-lg);font-weight:600;width:100%}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-footer a{font-weight:600}@media(max-width:480px){.auth-container{padding:32px 24px;border-radius:var(--radius-lg)}}.sidebar{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg-sidebar);position:relative}.sidebar-header{display:flex;align-items:center;gap:12px;padding:12px 16px;height:var(--header-height);border-bottom:1px solid var(--border-light)}.sidebar-title{flex:1;font-size:var(--font-size-lg);font-weight:700}.sidebar-search{padding:8px 12px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:9px 36px 9px 38px;border-radius:var(--radius-full);background:var(--bg-input);border:1px solid transparent;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.search-input:focus{border-color:var(--accent);background:var(--bg-primary)}.search-clear{position:absolute;right:10px;color:var(--text-muted);cursor:pointer;background:none;border:none;font-size:14px;padding:4px}.conversation-list{flex:1;overflow-y:auto;padding:4px 0}.list-label{padding:8px 16px 4px;font-size:var(--font-size-xs);font-weight:600;color:var(--text-accent);text-transform:uppercase;letter-spacing:.5px}.conversation-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background var(--transition-fast)}.conversation-item:hover{background:var(--bg-hover)}.conversation-item.active{background:var(--accent-light)}.conv-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.conv-top-row{display:flex;justify-content:space-between;align-items:baseline}.conv-name{font-weight:500;font-size:var(--font-size-base);color:var(--text-primary)}.conv-time{font-size:var(--font-size-xs);color:var(--text-muted);flex-shrink:0;margin-left:8px}.conv-preview{font-size:var(--font-size-sm);color:var(--text-secondary);max-width:100%}.sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-muted);text-align:center;gap:8px}.sidebar-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-modal);z-index:var(--z-overlay);animation:fadeIn .2s ease-out}.sidebar-menu{position:absolute;top:0;left:0;width:280px;max-width:85vw;height:100%;background:var(--bg-secondary);box-shadow:var(--shadow-lg);padding:16px 0;animation:slideInLeft .25s ease-out;overflow-y:auto}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-user-info{display:flex;align-items:center;gap:14px;padding:16px 20px 20px}.menu-divider{height:1px;background:var(--border);margin:4px 0}.menu-item{display:flex;align-items:center;gap:14px;width:100%;padding:12px 20px;font-size:var(--font-size-base);color:var(--text-primary);text-align:left;transition:background var(--transition-fast)}.menu-item:hover{background:var(--bg-hover)}.menu-item.danger{color:var(--error)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-modal);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease-out}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:440px;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px}.modal-header h2{font-size:var(--font-size-lg);font-weight:600}.new-chat-types{padding:8px 24px 24px;display:flex;flex-direction:column;gap:8px}.new-chat-type-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--text-primary);transition:background var(--transition-fast)}.new-chat-type-btn:hover{background:var(--bg-hover)}.type-icon{font-size:1.4rem}.new-group-form,.new-private-form{padding:0 24px 24px;display:flex;flex-direction:column;gap:12px}.selected-users{display:flex;flex-wrap:wrap;gap:6px}.selected-user-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--text-accent);font-size:var(--font-size-xs);cursor:pointer}.user-search-results{max-height:250px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.user-result-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.user-result-item:hover{background:var(--bg-hover)}.user-result-item.selected{background:var(--accent-light)}.user-result-item .check{margin-left:auto;color:var(--accent);font-weight:700}.chat-panel{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg-chat)}.chat-header{display:flex;align-items:center;gap:12px;padding:10px 16px;height:var(--header-height);background:var(--bg-sidebar);border-bottom:1px solid var(--border-light);z-index:var(--z-header)}.chat-header-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-header-name{font-weight:600;font-size:var(--font-size-base);color:var(--text-primary)}.chat-header-status{font-size:var(--font-size-xs);color:var(--text-accent)}.chat-header-actions{display:flex;gap:4px}.messages-container{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px}.messages-loading{display:flex;justify-content:center;padding:16px}.message-row{display:flex;align-items:flex-end;gap:8px;max-width:75%;animation:fadeIn .2s ease-out}.message-row.mine{margin-left:auto;flex-direction:row-reverse}.message-row.theirs{margin-right:auto}.message-bubble{padding:8px 12px;border-radius:var(--radius-lg);max-width:100%;word-wrap:break-word;overflow-wrap:break-word;position:relative}.message-bubble.sent{background:var(--bubble-sent);color:var(--bubble-sent-text);border-bottom-right-radius:4px}.message-bubble.received{background:var(--bubble-received);color:var(--bubble-received-text);border-bottom-left-radius:4px}.message-sender{font-size:var(--font-size-xs);font-weight:600;color:var(--text-accent);margin-bottom:2px}.message-text{font-size:var(--font-size-base);line-height:1.45;white-space:pre-wrap}.message-media{margin:4px 0}.message-media audio{max-width:240px;height:36px}.message-media video{max-width:320px}.message-media img{max-width:320px;cursor:pointer}.message-file{display:flex;align-items:center;gap:8px;padding:6px 0}.message-file a{color:var(--text-accent);font-size:var(--font-size-sm)}.message-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:2px}.message-time{font-size:11px;opacity:.6}.message-status{font-size:12px;opacity:.6}.message-status.read{color:var(--text-accent);opacity:1}.typing-indicator{display:flex;align-items:center;gap:8px;padding:6px 16px;font-size:var(--font-size-xs);color:var(--text-muted)}.typing-dots{display:flex;gap:3px}.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.4s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.chat-composer{display:flex;align-items:flex-end;gap:8px;padding:10px 16px;background:var(--bg-sidebar);border-top:1px solid var(--border-light)}.composer-input-wrapper{flex:1;min-width:0}.composer-input{width:100%;resize:none;border:1px solid var(--border);border-radius:var(--radius-xl);padding:10px 16px;background:var(--bg-input);color:var(--text-primary);font-size:var(--font-size-base);font-family:var(--font-family);line-height:1.4;max-height:120px;outline:none;transition:border-color var(--transition-fast)}.composer-input:focus{border-color:var(--accent)}.composer-input::placeholder{color:var(--text-muted)}.send-btn{color:var(--accent)}.send-btn:hover{background:var(--accent-light)}.mic-btn.recording{color:var(--error);animation:pulse 1s infinite;background:#ef44441a}@media(max-width:768px){.message-row{max-width:85%}.message-media video,.message-media img{max-width:250px}}.call-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;z-index:var(--z-call);display:flex;flex-direction:column;animation:fadeIn .3s ease-out}.call-remote-video{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.video-full{width:100%;height:100%;object-fit:cover}.call-placeholder{text-align:center;color:#fff;z-index:10}.call-placeholder h2{margin-top:16px;font-size:var(--font-size-2xl);font-weight:600}.call-status{margin-top:8px;opacity:.7;font-size:var(--font-size-lg)}.call-local-video{position:absolute;bottom:100px;right:20px;width:120px;height:160px;background:#222;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid rgba(255,255,255,.1);transition:all .3s ease;z-index:20}.video-pip{width:100%;height:100%;object-fit:cover}.call-controls{padding:30px;display:flex;justify-content:center;gap:24px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);position:absolute;bottom:0;width:100%;z-index:30}.btn-control{width:56px;height:56px;border-radius:50%;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .2s ease}.btn-control:hover{background:#ffffff40;transform:scale(1.05)}.btn-control.active{background:#fff;color:#000}.btn-call-action{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #0000004d;transition:transform .2s ease}.btn-call-action:hover{transform:scale(1.1)}.btn-call-action.reject{background:#ef4444}.btn-call-action.accept{background:#22c55e}@media(max-width:480px){.call-local-video{width:90px;height:120px;bottom:110px;right:16px}}.chat-page{width:100%;height:100vh;height:100dvh;overflow:hidden}.chat-layout{display:flex;width:100%;height:100%}.chat-layout.desktop .sidebar-wrapper{width:var(--sidebar-width);min-width:var(--sidebar-width);border-right:1px solid var(--border);height:100%}.chat-layout.desktop .chat-panel-wrapper{flex:1;height:100%;min-width:0}.chat-layout.mobile .sidebar-wrapper,.chat-layout.mobile .chat-panel-wrapper{width:100%;height:100%;position:absolute;top:0;left:0;transition:transform var(--transition-normal)}.chat-layout.mobile{position:relative}.chat-layout.mobile .sidebar-wrapper.hidden{transform:translate(-100%)}.chat-layout.mobile .chat-panel-wrapper.hidden{transform:translate(100%)}.chat-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-chat)}.chat-empty-content{text-align:center;animation:fadeIn .5s ease-out}.chat-empty-icon{margin-bottom:24px;opacity:.8}.chat-empty h2{font-size:var(--font-size-xl);font-weight:600;margin-bottom:8px;color:var(--text-primary)}.chat-empty p{color:var(--text-muted);font-size:var(--font-size-base)}:root{--bg-primary: #0e0e10;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--bg-chat: #0a0a0f;--bg-sidebar: #0e0e10;--bg-input: #1a1a2e;--bg-hover: rgba(255, 255, 255, .05);--bg-active: rgba(255, 255, 255, .08);--bg-modal: rgba(0, 0, 0, .7);--bubble-sent: #1e3a5f;--bubble-sent-text: #e8edf2;--bubble-received: #1a1a2e;--bubble-received-text: #d4d4d8;--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-accent: #60a5fa;--text-on-accent: #ffffff;--accent: #3b82f6;--accent-hover: #2563eb;--accent-light: rgba(59, 130, 246, .15);--accent-gradient: linear-gradient(135deg, #3b82f6, #8b5cf6);--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(59, 130, 246, .15);--sidebar-width: 360px;--header-height: 60px;--composer-height: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-lg: 1rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--z-sidebar: 100;--z-header: 200;--z-modal: 500;--z-overlay: 400;--z-toast: 600;--z-call: 700}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f4f4f5;--bg-tertiary: #e4e4e7;--bg-chat: #e8ecf1;--bg-sidebar: #ffffff;--bg-input: #f4f4f5;--bg-hover: rgba(0, 0, 0, .04);--bg-active: rgba(0, 0, 0, .06);--bg-modal: rgba(0, 0, 0, .4);--bubble-sent: #3b82f6;--bubble-sent-text: #ffffff;--bubble-received: #ffffff;--bubble-received-text: #18181b;--text-primary: #18181b;--text-secondary: #52525b;--text-muted: #a1a1aa;--text-accent: #2563eb;--border: rgba(0, 0, 0, .1);--border-light: rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(59, 130, 246, .1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--bg-primary);line-height:1.5;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}#root{width:100vw;height:100vh;height:100dvh;overflow:hidden}a{color:var(--text-accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}input,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 16px;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}input::placeholder,textarea::placeholder{color:var(--text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:12px}.gap-lg{gap:16px}.text-center{text-align:center}.text-sm{font-size:var(--font-size-sm)}.text-muted{color:var(--text-secondary)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-size-base);flex-shrink:0;overflow:hidden;text-transform:uppercase}.avatar img{width:100%;height:100%;object-fit:cover}.avatar.sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar.lg{width:56px;height:56px;font-size:var(--font-size-xl)}.avatar.xl{width:80px;height:80px;font-size:var(--font-size-2xl)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-base);transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--accent-gradient);color:var(--text-on-accent);box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-ghost{color:var(--text-secondary);padding:8px;border-radius:var(--radius-full)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--bg-hover)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--accent);color:#fff;font-size:var(--font-size-xs);font-weight:600}.online-dot{width:10px;height:10px;border-radius:var(--radius-full);background:var(--success);border:2px solid var(--bg-sidebar);position:absolute;bottom:0;right:0}.toast-container{position:fixed;top:20px;right:20px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border);box-shadow:var(--shadow-lg);color:var(--text-primary);font-size:var(--font-size-sm);animation:slideInRight .3s ease-out;max-width:360px}.toast.error{border-color:var(--error)}.toast.success{border-color:var(--success)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
