:root,[data-theme=light]{--bg: #f8fafc;--bg-gradient: radial-gradient(circle at top left, rgba(79, 70, 229, .1), transparent 34%), radial-gradient(circle at top right, rgba(59, 130, 246, .08), transparent 30%);--panel: #ffffff;--panel-2: #f1f5f9;--panel-3: #e2e8f0;--text: #0f172a;--muted: #64748b;--muted-soft: #94a3b8;--border: rgba(15, 23, 42, .1);--border-strong: rgba(15, 23, 42, .16);--accent: #4f46e5;--accent-2: #3b82f6;--accent-soft: rgba(79, 70, 229, .14);--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--shadow-sm: 0 12px 32px rgba(15, 23, 42, .08);--shadow-md: 0 24px 60px rgba(15, 23, 42, .12);--shadow-lg: 0 40px 120px rgba(15, 23, 42, .18);--message-own: linear-gradient(135deg, #4f46e5, #6366f1);--message-other: #eef2ff;--message-other-text: #0f172a;--backdrop: rgba(15, 23, 42, .38)}[data-theme=dark]{--bg: #0b1120;--bg-gradient: radial-gradient(circle at top left, rgba(79, 70, 229, .22), transparent 30%), radial-gradient(circle at bottom right, rgba(59, 130, 246, .18), transparent 34%);--panel: #111827;--panel-2: #151c2e;--panel-3: #1e293b;--text: #f8fafc;--muted: #94a3b8;--muted-soft: #64748b;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .14);--accent: #4f46e5;--accent-2: #3b82f6;--accent-soft: rgba(79, 70, 229, .18);--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--shadow-sm: 0 12px 32px rgba(2, 8, 20, .34);--shadow-md: 0 24px 60px rgba(2, 8, 20, .48);--shadow-lg: 0 40px 120px rgba(2, 8, 20, .66);--message-own: linear-gradient(135deg, #4f46e5, #3b82f6);--message-other: #182236;--message-other-text: #f8fafc;--backdrop: rgba(2, 8, 20, .72)}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;background:var(--bg);background-image:var(--bg-gradient);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}button,input,textarea{font:inherit}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{border:none;background:none;color:inherit;cursor:pointer}textarea{resize:none}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:grid;place-items:center;padding:32px 16px}.auth-card{width:100%;max-width:440px;padding:32px;border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.06),transparent),var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.auth-logo{display:flex;align-items:center;gap:14px;margin-bottom:24px}.auth-logo-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:800;box-shadow:inset 0 1px #ffffff3d}.auth-logo-text{font-weight:800;letter-spacing:.16em;font-size:14px}.auth-title{margin:0 0 6px;font-size:30px;line-height:1.1}.auth-subtitle{margin:0 0 24px;color:var(--muted)}.form-group,.field-label{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-label,.field-label{color:var(--muted);font-size:14px}.form-input,.search-input,.profile-input,.sidebar-search-input,.message-input{width:100%;border-radius:16px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel-2) 88%,transparent);color:var(--text);padding:14px 16px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.form-input::placeholder,.sidebar-search-input::placeholder,.message-input::placeholder{color:var(--muted-soft)}.form-input:focus,.search-input:focus,.profile-input:focus,.sidebar-search-input:focus,.message-input:focus{border-color:color-mix(in srgb,var(--accent) 66%,#fff 4%);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 18%,transparent)}.error-msg,.inline-danger{background:color-mix(in srgb,var(--danger) 14%,transparent);color:color-mix(in srgb,var(--danger) 92%,#fff 8%);border:1px solid color-mix(in srgb,var(--danger) 24%,transparent);padding:12px 14px;border-radius:14px;margin-bottom:16px}.inline-success{background:color-mix(in srgb,var(--success) 14%,transparent);color:color-mix(in srgb,var(--success) 92%,#fff 8%);border:1px solid color-mix(in srgb,var(--success) 24%,transparent);padding:12px 14px;border-radius:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:44px;padding:0 16px;border-radius:14px;border:1px solid transparent;transition:transform .18s ease,background .2s ease,border-color .2s ease,opacity .2s ease;font-weight:600}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary,.send-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 12px 30px #4f46e547}.btn-secondary{background:color-mix(in srgb,var(--panel-3) 86%,transparent);border-color:var(--border);color:var(--text)}.btn-danger{background:color-mix(in srgb,var(--danger) 88%,#631717 12%);color:#fff}.btn-block{width:100%}.btn-sm,.btn-xs{min-height:36px;padding:0 12px;border-radius:12px;font-size:13px}.messenger-shell{width:100%;min-height:100vh;background:var(--bg);background-image:var(--bg-gradient)}.messenger-layout{display:grid;grid-template-columns:minmax(320px,360px) minmax(0,1fr) 340px;min-height:100vh}.sidebar,.center-panel,.right-panel{min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:16px;padding:22px 18px;background:#1118279e;-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px);border-right:1px solid var(--border);box-shadow:inset -1px 0 #ffffff05}[data-theme=light] .sidebar{background:#ffffffd1}.center-panel{min-width:0;background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),color-mix(in srgb,var(--bg) 84%,var(--panel) 16%);display:flex}.center-panel-scroll{width:100%;overflow-y:auto;padding-right:6px}.right-panel{background:#11182775;-webkit-backdrop-filter:blur(26px);backdrop-filter:blur(26px);border-left:1px solid var(--border);padding:22px 18px;overflow-y:auto}[data-theme=light] .right-panel{background:#ffffffb8}.sidebar-brand{display:flex;align-items:center;gap:14px;padding:6px 4px 4px}.brand-mark{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-size:22px;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 18px 40px #4f46e53d}.brand-text{display:flex;flex-direction:column}.brand-title{font-size:18px;font-weight:800;letter-spacing:.18em}.brand-subtitle{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}.sidebar-search{position:relative;display:flex;align-items:center;gap:10px;padding:0 14px;min-height:52px;border-radius:18px;background:color-mix(in srgb,var(--panel-2) 82%,transparent);border:1px solid var(--border)}.sidebar-search-input{border:none;background:transparent;padding:0}.sidebar-search-input:focus{box-shadow:none}.sidebar-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.sidebar-nav-btn{position:relative;display:inline-flex;align-items:center;gap:10px;padding:14px;border-radius:16px;background:color-mix(in srgb,var(--panel-2) 75%,transparent);border:1px solid transparent;color:var(--muted);transition:background .2s ease,border-color .2s ease,color .2s ease,transform .18s ease}.sidebar-nav-btn:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--panel-3) 80%,transparent);color:var(--text)}.sidebar-nav-btn.active{color:#fff;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 70%,var(--panel-2) 30%),color-mix(in srgb,var(--accent-2) 80%,var(--panel-2) 20%));border-color:color-mix(in srgb,var(--accent) 46%,transparent);box-shadow:0 18px 40px #3b82f62e}.badge-dot{margin-left:auto;min-width:22px;height:22px;border-radius:999px;display:grid;place-items:center;padding:0 6px;background:#fff;color:var(--accent);font-size:12px;font-weight:700}.sidebar-header-row,.sidebar-section-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-section-title{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:700}.sidebar-content{flex:1;min-height:0;overflow-y:auto;padding-right:4px}.sidebar-action-row{margin-bottom:12px}.chat-items,.friends-list,.calls-list,.group-member-list{display:flex;flex-direction:column;gap:10px}.chat-list-wrap{display:flex;flex-direction:column}.chat-list-item,.user-discovery-card,.friend-item,.request-item,.call-history-item,.search-result-card{width:100%;display:flex;align-items:center;gap:14px;padding:14px;border-radius:18px;background:color-mix(in srgb,var(--panel-2) 82%,transparent);border:1px solid transparent;text-align:left;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.chat-list-item:hover,.user-discovery-card:hover,.friend-item:hover,.request-item:hover,.call-history-item:hover,.search-result-card:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--panel-3) 86%,transparent);border-color:var(--border)}.chat-list-item.active{background:linear-gradient(135deg,color-mix(in srgb,var(--accent-soft) 70%,transparent),color-mix(in srgb,var(--panel-2) 84%,transparent));border-color:color-mix(in srgb,var(--accent) 34%,transparent);box-shadow:inset 4px 0 0 var(--accent)}.chat-list-avatar-wrap,.avatar-wrap{position:relative;flex-shrink:0}.chat-avatar,.avatar-img,.avatar-sm,.avatar-md,.avatar-lg,.profile-avatar,.profile-avatar-img{display:block;flex-shrink:0;object-fit:cover}.chat-avatar{width:48px;height:48px;border-radius:18px}.avatar-sm{width:36px;height:36px;border-radius:50%}.avatar-md{width:48px;height:48px;border-radius:50%}.avatar-lg,.profile-avatar{width:120px;height:120px;border-radius:50%}.group-avatar{width:88px;height:88px;border-radius:24px;object-fit:cover;flex-shrink:0}.chat-header-avatar{width:46px;height:46px;border-radius:18px;object-fit:cover;flex-shrink:0}.avatar-fallback,.chat-avatar-fallback,.profile-avatar-placeholder,.profile-avatar-edit-overlay,.call-avatar-xl.fallback,.mini-call-avatar-fallback{display:grid;place-items:center;background:color-mix(in srgb,var(--panel-3) 88%,transparent);border:1px solid var(--border);color:var(--text);font-weight:700}.chat-avatar-fallback{width:48px;height:48px;border-radius:18px}.avatar-fallback.square{border-radius:24px}.online-dot,.status-dot,.profile-status-dot{width:10px;height:10px;border-radius:999px;background:var(--success);box-shadow:0 0 0 4px var(--panel)}.online-dot{position:absolute;right:2px;bottom:2px}.chat-list-main,.user-discovery-main,.sidebar-me-main,.call-history-main,.group-member-meta,.profile-title-block{flex:1;min-width:0}.chat-list-top,.chat-list-bottom,.call-history-top,.search-result-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-list-title-wrap,.chat-list-meta,.user-discovery-name,.call-history-meta{display:flex;align-items:center;gap:8px}.chat-list-title,.user-discovery-name,.group-member-name,.profile-title,.sidebar-me-name,.chat-window-peer-title,.section-hero-title{font-weight:700}.chat-list-title,.user-discovery-name,.sidebar-me-name,.chat-window-peer-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-preview,.user-discovery-subtitle,.sidebar-me-email,.chat-list-time,.chat-window-peer-subtitle,.call-history-time,.call-history-meta,.profile-subtitle,.profile-bio,.profile-info-row,.group-member-role,.search-result-preview,.search-modal-hint{color:var(--muted);font-size:13px}.chat-list-preview{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-list-preview.is-unread{color:var(--text);font-weight:600}.unread-badge{min-width:24px;height:24px;padding:0 7px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:12px;font-weight:700}.pin-mini-icon{color:var(--accent-2)}.chat-status-ticks{color:var(--muted-soft);font-size:12px}.chat-status-ticks.read{color:var(--accent-2)}.chat-pin-btn{opacity:.64}.chat-list-item:hover .chat-pin-btn{opacity:1}.sidebar-me{width:100%;display:flex;align-items:center;gap:14px;padding:16px;border-radius:20px;background:color-mix(in srgb,var(--panel-2) 82%,transparent);border:1px solid var(--border);margin-top:auto}.chat-window{width:100%;min-width:0;display:flex;flex-direction:column;min-height:100vh}.chat-window.empty,.center-panel.solo{align-items:stretch}.chat-empty-state,.messages-empty,.empty-state,.right-panel-empty,.admin-empty{min-height:100%;display:grid;place-items:center;text-align:center;color:var(--muted);padding:24px}.chat-empty-logo,.messages-empty-icon,.empty-state-icon{width:72px;height:72px;border-radius:24px;display:grid;place-items:center;margin:0 auto 14px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:26px;font-weight:800}.messages-empty-title{font-size:18px;font-weight:700;color:var(--text)}.messages-empty-subtitle{color:var(--muted)}.chat-window-header{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:84px;padding:20px 24px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.05),transparent),#11182738;-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px)}[data-theme=light] .chat-window-header{background:#ffffffc7}.chat-window-header-left,.chat-window-header-actions,.chat-window-peer{display:flex;align-items:center;gap:14px}.chat-window-peer{min-width:0}.chat-window-peer-meta{min-width:0;text-align:left}.chat-window-peer-subtitle.typing{color:var(--accent-2)}.icon-btn,.send-btn,.call-icon-btn,.reaction-add-btn,.image-viewer-close{width:40px;height:40px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--panel-3) 86%,transparent);border:1px solid var(--border);transition:transform .18s ease,background .18s ease,border-color .18s ease}.icon-btn:hover,.send-btn:hover,.call-icon-btn:hover,.reaction-add-btn:hover,.image-viewer-close:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--panel-3) 100%,transparent)}.icon-btn.glass{background:#0f172a57;color:#fff}.icon-btn.danger,.call-icon-btn.danger{background:color-mix(in srgb,var(--danger) 16%,transparent);color:color-mix(in srgb,var(--danger) 92%,#fff 8%);border-color:color-mix(in srgb,var(--danger) 24%,transparent)}.messages-area{flex:1;min-height:0;overflow-y:auto;padding:28px 24px 12px;display:flex;flex-direction:column;gap:10px;background:radial-gradient(circle at top center,rgba(79,70,229,.07),transparent 36%),transparent}.messages-day-divider{display:flex;justify-content:center;margin:14px 0 10px}.messages-day-divider span{padding:8px 14px;border-radius:999px;background:color-mix(in srgb,var(--panel-2) 88%,transparent);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700}.message-row{display:flex}.message-row.own{justify-content:flex-end}.message-row.other{justify-content:flex-start}.message-stack{max-width:min(78%,720px)}.message-sender{margin-bottom:6px;padding-left:4px;font-size:12px;color:var(--muted)}.message-body-wrap{display:flex;align-items:flex-end;gap:8px}.message-row.own .message-body-wrap{flex-direction:row-reverse}.message-bubble{min-width:104px;padding:12px 14px 10px;border-radius:20px;background:var(--message-other);color:var(--message-other-text);box-shadow:var(--shadow-sm);border:1px solid color-mix(in srgb,var(--border) 60%,transparent)}.message-bubble.own{background:var(--message-own);color:#fff;border-top-right-radius:8px}.message-bubble.other{border-top-left-radius:8px}.message-bubble.media{background:color-mix(in srgb,var(--panel-2) 96%,transparent)}.message-bubble-deleted{font-style:italic;color:var(--muted);background:color-mix(in srgb,var(--panel-2) 86%,transparent)}.message-deleted-text{opacity:.84}.message-text{white-space:pre-wrap;word-break:break-word}.message-reply{display:flex;gap:10px;margin-bottom:10px;padding:8px 10px;border-radius:14px;background:#ffffff14}.message-row.other .message-reply{background:color-mix(in srgb,var(--panel) 24%,transparent)}.message-reply-bar,.composer-context-bar{width:3px;border-radius:999px;background:#fff}.message-row.other .message-reply-bar{background:var(--accent-2)}.message-reply-content{display:flex;flex-direction:column;gap:2px;min-width:0}.message-reply-author{font-size:12px;font-weight:700}.message-reply-text{font-size:12px;opacity:.88;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-footer,.message-meta-inline{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-top:8px;font-size:11px;color:#ffffffd1}.message-row.other .message-footer,.message-row.other .message-meta-inline{color:var(--muted)}.message-edited{margin-right:auto;opacity:.8}.msg-status{font-size:11px;letter-spacing:-.06em}.msg-status-read{color:#dbeafe}.msg-status-delivered{color:#ffffffeb}.message-actions{position:relative}.message-menu{position:absolute;top:calc(100% + 8px);min-width:196px;padding:8px;border-radius:16px;background:color-mix(in srgb,var(--panel) 88%,transparent);border:1px solid var(--border);box-shadow:var(--shadow-md);z-index:30}.message-menu.own{right:0}.message-menu.other{left:0}.message-menu button{width:100%;display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;color:var(--text)}.message-menu button:hover{background:color-mix(in srgb,var(--panel-3) 86%,transparent)}.message-menu button.danger{color:color-mix(in srgb,var(--danger) 92%,#fff 8%)}.message-image-button{padding:0;background:none;border:none}.message-image{max-width:320px;max-height:360px;width:auto;height:auto;object-fit:contain;border-radius:16px;cursor:pointer;display:block}.audio-bubble{min-width:240px;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center}.audio-bubble-icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:#ffffff29}.message-row.other .audio-bubble-icon{background:color-mix(in srgb,var(--panel-3) 88%,transparent)}.audio-bubble-wave{display:flex;align-items:center;gap:4px;height:28px}.audio-bubble-wave span{width:4px;border-radius:999px;background:currentColor;opacity:.55;animation:wave 1.5s ease-in-out infinite}.audio-bubble-wave span:nth-child(1){height:12px;animation-delay:0s}.audio-bubble-wave span:nth-child(2){height:18px;animation-delay:.12s}.audio-bubble-wave span:nth-child(3){height:14px;animation-delay:.24s}.audio-bubble-wave span:nth-child(4){height:22px;animation-delay:.36s}.audio-bubble-wave span:nth-child(5){height:16px;animation-delay:.48s}.audio-bubble-wave span:nth-child(6){height:12px;animation-delay:.6s}@keyframes wave{0%,to{transform:scaleY(.8);opacity:.45}50%{transform:scaleY(1.1);opacity:.85}}.message-audio{grid-column:1 / -1;width:100%}.message-row.is-highlighted .message-bubble{outline:2px solid color-mix(in srgb,var(--accent) 75%,transparent);box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 12%,transparent),var(--shadow-sm)}.reactions-wrap{display:flex;align-items:center;gap:8px;margin-top:6px}.reactions-list{display:flex;flex-wrap:wrap;gap:8px}.reaction-pill{min-height:28px;display:inline-flex;align-items:center;gap:6px;padding:0 10px;border-radius:999px;background:color-mix(in srgb,var(--panel-2) 90%,transparent);border:1px solid var(--border);color:var(--text)}.reaction-pill.is-reacted{border-color:color-mix(in srgb,var(--accent) 38%,transparent);background:color-mix(in srgb,var(--accent-soft) 60%,transparent)}.reaction-picker-menu{position:absolute;bottom:calc(100% + 8px);right:0;display:flex;gap:6px;padding:8px;border-radius:16px;background:color-mix(in srgb,var(--panel) 92%,transparent);border:1px solid var(--border);box-shadow:var(--shadow-md);z-index:16}.reaction-picker-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;font-size:18px}.reaction-picker-btn:hover{background:color-mix(in srgb,var(--panel-3) 90%,transparent)}.composer-shell{padding:0 24px 22px}.composer-context{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:12px 14px;border-radius:18px;background:color-mix(in srgb,var(--panel-2) 84%,transparent);border:1px solid var(--border)}.composer-context-content{flex:1;min-width:0}.composer-context-label{font-size:12px;color:var(--accent-2);font-weight:700}.composer-context-text{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-composer{display:flex;align-items:flex-end;gap:10px;padding:12px;border-radius:24px;background:color-mix(in srgb,var(--panel) 84%,transparent);border:1px solid var(--border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-sm)}.composer-input-wrap{flex:1;min-width:0}.message-input{min-height:52px;max-height:150px;border:none;background:transparent;padding:14px 16px}.message-input:focus{box-shadow:none}.recording-panel{flex:1;display:flex;align-items:center;gap:12px;min-height:52px;padding:0 12px;border-radius:18px;background:color-mix(in srgb,var(--danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--danger) 24%,transparent)}.recording-pulse{width:12px;height:12px;border-radius:999px;background:var(--danger);box-shadow:0 0 color-mix(in srgb,var(--danger) 24%,transparent);animation:pulse 1.2s infinite ease-out}@keyframes pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--danger) 24%,transparent)}to{box-shadow:0 0 0 14px transparent}}.modal-overlay,.profile-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4000;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--backdrop);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-card,.profile-modal{width:100%;max-width:680px;max-height:min(90vh,900px);overflow:hidden;border-radius:26px;background:color-mix(in srgb,var(--panel) 94%,transparent);border:1px solid var(--border-strong);box-shadow:var(--shadow-lg)}.modal-medium{max-width:560px}.modal-topbar,.profile-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:20px 22px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:18px;font-weight:700}.modal-body,.profile-body{padding:20px 22px 24px;overflow-y:auto}.profile-panel{display:flex;flex-direction:column;gap:18px}.profile-panel.panel{min-height:calc(100vh - 44px);background:transparent}.profile-panel.modal{min-width:min(92vw,540px)}.profile-panel-top{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}.profile-panel-top.group{align-items:flex-start;text-align:left}.profile-avatar-frame{position:relative;width:120px;height:120px;cursor:pointer}.profile-avatar-frame img{width:120px;height:120px;border-radius:50%;object-fit:cover}.profile-avatar-edit-overlay{position:absolute;inset:auto 0 0 0;display:flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:0 0 60px 60px;background:#0f172aad;color:#fff}.profile-title{margin:0;font-size:28px}.profile-status{display:inline-flex;align-items:center;gap:8px;justify-content:center;color:var(--muted)}.profile-status.online{color:var(--success)}.profile-action-grid,.theme-grid,.admin-stats-grid,.profile-media-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.profile-action-btn,.theme-card,.profile-media-card,.admin-stat-card,.group-friend-card{display:flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:14px;border-radius:18px;background:color-mix(in srgb,var(--panel-2) 84%,transparent);border:1px solid var(--border);text-align:center}.profile-action-btn.danger{background:color-mix(in srgb,var(--danger) 12%,transparent);color:color-mix(in srgb,var(--danger) 92%,#fff 8%)}.theme-card.active,.group-friend-card.selected{border-color:color-mix(in srgb,var(--accent) 42%,transparent);background:color-mix(in srgb,var(--accent-soft) 64%,transparent)}.card-section,.profile-card-section{padding:18px;border-radius:22px;background:color-mix(in srgb,var(--panel-2) 80%,transparent);border:1px solid var(--border)}.section-title{margin-bottom:14px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:700}.profile-info-row,.settings-row{display:flex;align-items:center;gap:12px;padding:12px 0}.profile-info-row+.profile-info-row,.settings-row+.settings-row{border-top:1px solid var(--border)}.settings-row-content{flex:1}.settings-row-title{font-weight:600}.settings-row-subtitle{color:var(--muted);font-size:13px}.settings-row-icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:color-mix(in srgb,var(--panel-3) 90%,transparent);color:var(--accent-2)}.switch{position:relative;width:50px;height:30px;display:inline-flex}.switch input{opacity:0;width:0;height:0}.switch span{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:color-mix(in srgb,var(--panel-3) 95%,transparent);border:1px solid var(--border)}.switch span:after{content:"";position:absolute;left:3px;top:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .2s ease}.switch input:checked+span{background:linear-gradient(135deg,var(--accent),var(--accent-2))}.switch input:checked+span:after{transform:translate(19px)}.profile-textarea{min-height:108px}.profile-avatar-large{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:16px}.profile-media-card{justify-content:flex-start}.group-member-item{display:flex;align-items:center;gap:12px;padding:10px 0}.group-member-item+.group-member-item{border-top:1px solid var(--border)}.group-friends-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.group-friend-card{flex-direction:column;min-height:132px}.group-friend-name{font-weight:600}.group-friend-check{width:26px;height:26px;border-radius:999px;display:grid;place-items:center;background:#ffffff14}.form-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}.search-scope-row,.calls-filter-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.scope-pill{min-height:38px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel-2) 84%,transparent);color:var(--muted)}.scope-pill.active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2))}.search-modal-input-wrap{display:flex;align-items:center;gap:12px;padding:0 16px;min-height:54px;border-radius:18px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel-2) 84%,transparent)}.search-modal-input{border:none;background:transparent;padding:0}.search-modal-input:focus{box-shadow:none}.search-results{display:flex;flex-direction:column;gap:10px;max-height:50vh;overflow-y:auto;margin-top:12px}.search-result-card{align-items:flex-start;flex-direction:column}.search-result-title{font-weight:700}.friends-panel{display:flex;flex-direction:column;gap:16px}.friends-tabs{display:flex;gap:10px;flex-wrap:wrap}.friends-tab{min-height:38px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel-2) 84%,transparent);color:var(--muted)}.friends-tab.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}.badge,.badge-accent{margin-left:6px;min-width:20px;height:20px;border-radius:999px;display:inline-grid;place-items:center;padding:0 6px;background:color-mix(in srgb,var(--panel-3) 96%,transparent);color:var(--text);font-size:11px;font-weight:700}.badge-accent{background:color-mix(in srgb,var(--accent) 92%,#fff 8%);color:#fff}.friend-item,.request-item{justify-content:space-between}.friend-meta,.request-meta{flex:1;min-width:0;text-align:left}.friend-name,.request-name{font-weight:600}.friend-sub,.request-sub,.friend-badge-pending{color:var(--muted);font-size:13px}.friend-actions,.friend-request-actions{display:flex;gap:8px}.calls-panel{display:flex;flex-direction:column;gap:16px}.call-history-item{justify-content:flex-start}.call-history-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:color-mix(in srgb,var(--panel-3) 92%,transparent);flex-shrink:0}.call-history-icon.missed{background:color-mix(in srgb,var(--danger) 12%,transparent)}.call-history-status{display:inline-flex;align-items:center;gap:6px;text-transform:capitalize}.admin-panel{display:flex;flex-direction:column;gap:18px}.section-hero-subtitle{margin:8px 0 0;color:var(--muted)}.admin-search-input{width:min(320px,100%)}.admin-user-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 0;border-top:1px solid var(--border)}.admin-user-row:first-child{border-top:none}.admin-user-name{font-weight:700}.admin-user-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:13px}.admin-user-actions{display:flex;gap:10px;flex-shrink:0}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:grid;place-items:center;padding:28px;background:#02081473;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.call-modal{width:min(960px,96vw);border-radius:30px;border:1px solid rgba(255,255,255,.12);background:#090f1ccc;box-shadow:var(--shadow-lg);overflow:hidden;z-index:9000}.call-stage{position:relative;min-height:460px;background:radial-gradient(circle at top center,rgba(79,70,229,.18),transparent 32%),#050912;display:grid;place-items:center;padding:32px}.call-remote-surface{position:relative;width:100%;height:100%;min-height:420px;border-radius:28px;overflow:hidden;background:#020814d1;border:1px solid rgba(255,255,255,.08)}.call-remote-video,.call-local-video{width:100%;height:100%;object-fit:cover}.call-stage-caption{position:absolute;top:18px;left:18px;right:18px;display:flex;align-items:center;justify-content:space-between;color:#fff}.call-local-thumb{position:absolute;right:30px;bottom:28px;width:180px;height:120px;border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.14);background:#090f1cdb;box-shadow:0 20px 60px #00000073}.call-remote-avatar-card{display:grid;place-items:center;width:100%;height:100%}.call-avatar-xl,.call-avatar-xl.fallback{width:160px;height:160px;border-radius:40px;object-fit:cover}.call-info{padding:22px 28px 8px;text-align:center;color:#fff}.call-info h3{margin:0 0 8px;font-size:28px}.call-status-line{color:#ffffffb8}.call-actions-row{display:flex;align-items:center;justify-content:center;gap:14px;padding:22px 28px 30px}.call-icon-btn{width:52px;height:52px;border-radius:18px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#fff}.call-icon-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent-2))}.call-icon-btn.muted{background:#ef44442e;color:#fecaca}.call-action-btn{min-height:52px;padding:0 18px;border-radius:18px;display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:600}.call-action-btn.accept{background:linear-gradient(135deg,#22c55e,#16a34a)}.call-action-btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.call-error-banner{margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:16px;background:#ef444429;border:1px solid rgba(239,68,68,.24)}.mini-call-window{position:fixed;right:24px;bottom:24px;z-index:9500;display:flex;align-items:center;gap:14px;width:min(360px,calc(100vw - 32px));padding:14px;border-radius:22px;background:color-mix(in srgb,var(--panel) 92%,transparent);border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.mini-call-preview{width:96px;height:72px;border-radius:16px;overflow:hidden;background:#020617;flex-shrink:0}.mini-call-preview video,.mini-call-preview img{width:100%;height:100%;object-fit:cover}.mini-call-avatar-fallback{width:100%;height:100%;border-radius:16px}.mini-call-name{font-weight:700}.mini-call-meta,.mini-call-actions{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.mini-call-actions{margin-left:auto}.mini-call-mic.off{color:var(--danger)}.video-expanded-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#000000eb;display:flex;align-items:center;justify-content:center;padding:24px}.video-expanded-overlay video,.image-viewer-overlay img{max-width:95vw;max-height:90vh;border-radius:16px;object-fit:contain}.image-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:24px}.image-viewer-close{position:absolute;top:24px;right:24px;color:#fff;background:#ffffff1a;border-color:#ffffff29}.call-modal{z-index:9000}.message-list-loading{display:flex;align-items:center;justify-content:center;gap:12px;min-height:120px}.message-list-loading span{width:12px;height:12px;border-radius:999px;background:var(--accent-2);animation:bounce .8s infinite alternate}.message-list-loading span:nth-child(2){animation-delay:.12s}.message-list-loading span:nth-child(3){animation-delay:.24s}@keyframes bounce{0%{transform:translateY(0);opacity:.5}to{transform:translateY(-10px);opacity:1}}.mobile-only{display:none}.desktop-only{display:block}@media (max-width: 1100px){.messenger-layout{grid-template-columns:320px minmax(0,1fr)}.right-panel.desktop-only{display:none}}@media (max-width: 767px){body{overflow:auto}.messenger-layout{grid-template-columns:1fr;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:min(92vw,360px);z-index:1200;transform:translate(-105%);transition:transform .22s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.mobile-only{display:inline-flex}.center-panel{min-height:100vh}.chat-window-header{padding:16px}.messages-area{padding:20px 16px 10px}.composer-shell{padding:0 14px 18px}.message-stack{max-width:92%}.chat-window-header-actions{gap:8px}.chat-window-header-actions .icon-btn:nth-child(n+3){display:none}.group-friends-grid,.profile-action-grid,.theme-grid,.admin-stats-grid,.profile-media-grid{grid-template-columns:1fr}.call-overlay{padding:12px}.call-modal{width:100%;border-radius:24px}.call-stage{min-height:360px;padding:18px}.call-local-thumb{width:120px;height:82px;right:18px;bottom:18px}.mini-call-window{right:12px;bottom:12px}.modal-overlay,.profile-modal-overlay{padding:12px}.modal-card,.profile-modal{max-height:94vh;border-radius:22px}}html,body,#root{width:100%;height:100%;min-height:100%;margin:0}body{min-height:100dvh;overflow:hidden;background:var(--bg);color:var(--text)}.messenger-shell{width:100%;height:100dvh;min-height:100dvh;overflow:hidden}.messenger-layout{width:100%;height:100dvh;min-height:0;overflow:hidden;align-items:stretch}.sidebar,.center-panel,.right-panel{height:100%;min-height:0}.sidebar{overflow:hidden}.center-panel{min-width:0;min-height:0;height:100%;display:flex;overflow:hidden}.center-panel.solo{padding:28px}.center-panel-scroll{width:100%;height:100%;min-height:0;overflow-y:auto;padding-right:6px}.right-panel{min-height:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.right-panel-empty{flex:1;min-height:0;display:grid;place-items:center}.chat-window{width:100%;min-width:0;min-height:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.chat-window-header{flex-shrink:0}.messages-area{flex:1;min-height:0;overflow-y:auto}.composer-shell{flex-shrink:0}.profile-panel.panel{flex:1;min-height:0;height:100%;overflow-y:auto;background:transparent}.profile-panel-content{min-height:100%}@media (max-width: 1024px){.messenger-shell,.messenger-layout{height:100dvh;min-height:100dvh}}.call-hidden-audio{display:none}.right-panel{min-height:0!important;height:100dvh;overflow-y:auto;overflow-x:hidden;padding-bottom:24px}.profile-panel.panel{min-height:0!important;height:auto;overflow-y:auto;padding-right:4px}.profile-panel-content{display:flex;flex-direction:column;gap:16px;min-height:0}.profile-title-block,.group-member-meta,.profile-info-row span,.profile-subtitle,.profile-bio{min-width:0;overflow-wrap:anywhere}.profile-action-grid,.profile-media-grid{width:100%}.profile-action-btn,.profile-media-card{min-width:0;align-items:center;justify-content:center;flex-direction:row;overflow:hidden}.profile-action-btn span,.profile-media-card span{overflow-wrap:anywhere}.profile-card-section{overflow:hidden}.image-viewer-overlay,.video-expanded-overlay{padding:32px}.image-viewer-overlay img,.image-viewer-image,.profile-avatar-large{display:block;width:auto;height:auto;margin:auto;max-width:min(92vw,1200px);max-height:90vh;object-fit:contain}.messages-area{position:relative;padding-bottom:96px}.message-row,.message-stack,.message-body-wrap{overflow:visible}.message-actions{position:relative;z-index:14}.message-menu{top:auto;bottom:calc(100% + 8px);z-index:60}.message-menu.own{right:0;left:auto}.message-menu.other{left:0;right:auto}.reactions-wrap{position:relative;overflow:visible}.reaction-picker{position:relative}.reaction-picker-menu{bottom:calc(100% + 8px);right:auto;left:0;z-index:70;max-width:min(92vw,320px);flex-wrap:wrap}.reaction-picker-menu.align-right{right:0;left:auto}.reaction-picker-menu.align-left{left:0;right:auto}.emoji-picker-wrap{position:relative;display:flex;align-items:center}.emoji-picker-menu{position:absolute;right:0;bottom:calc(100% + 10px);display:grid;grid-template-columns:repeat(5,1fr);gap:8px;min-width:220px;padding:10px;border-radius:16px;background:color-mix(in srgb,var(--panel) 94%,transparent);border:1px solid var(--border);box-shadow:var(--shadow-md);z-index:80}.emoji-picker-btn{width:36px;height:36px;display:grid;place-items:center;border-radius:12px;font-size:20px}.emoji-picker-btn:hover{background:color-mix(in srgb,var(--panel-3) 88%,transparent)}.recording-panel{flex:1;min-width:0;gap:12px}.recording-actions{display:inline-flex;align-items:center;gap:8px;margin-left:auto}.call-overlay{z-index:9000}.call-modal{z-index:9001}.mini-call-window{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;overflow:hidden}.mini-call-info{min-width:0}.mini-call-name,.mini-call-meta{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-call-actions{margin-left:0;flex-shrink:0;display:inline-flex;align-items:center;gap:8px}.call-history-meta{display:flex;flex-wrap:wrap;gap:10px}@media (max-width: 768px){.right-panel{padding-bottom:0}.emoji-picker-menu,.reaction-picker-menu{max-width:calc(100vw - 32px)}.mini-call-window{right:12px;bottom:12px;width:calc(100vw - 24px)}}
