:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", "JetBrains Mono", ui-monospace, monospace;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--duration-fast: .15s;--duration-base: .2s;--duration-slow: .3s}[data-theme=dark]{--bg-primary: #0e1621;--bg-secondary: #17212b;--bg-tertiary: #242f3d;--bg-elevated: #2b3945;--bg-inverse: #ffffff;--text-primary: #f5f5f5;--text-secondary: #8e99a4;--text-tertiary: #6d7f8f;--text-inverse: #0e1621;--border-primary: #0f1419;--border-secondary: #242f3d;--accent-primary: #3390ec;--accent-secondary: #2b7cd3;--accent-tertiary: #1e6bb8;--accent-soft: rgba(51, 144, 236, .14);--success: #4dcd5e;--warning: #e5a50a;--error: #e53935;--info: #3390ec;--gradient-brand: linear-gradient(135deg, #3390ec 0%, #5eb3f6 100%);--gradient-message-mine: linear-gradient(135deg, #2b5278 0%, #3390ec 100%);--gradient-hover: rgba(51, 144, 236, .08);--m-bg-app: #0e1621;--m-bg-panel: #17212b;--m-bg-rail: #0e1621;--m-bg-chat: #0e1621;--m-bg-search: #242f3d;--m-bg-hover: rgba(255, 255, 255, .04);--m-bg-elevated: #242f3d;--m-bubble-out: #2b5278;--m-bubble-in: #182533;--m-avatar-a: #5eb3f6;--m-avatar-b: #3390ec;--m-rail-width: 72px;--m-chat-pattern: radial-gradient(circle at 20% 30%, rgba(51, 144, 236, .03) 0%, transparent 50%)}[data-theme=light]{--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 6px -1px rgba(15, 23, 42, .08), 0 2px 4px -1px rgba(15, 23, 42, .05);--shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, .08), 0 4px 6px -2px rgba(15, 23, 42, .04);--shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, .08), 0 10px 10px -5px rgba(15, 23, 42, .04);--shadow-2xl: 0 25px 50px -12px rgba(15, 23, 42, .12);--bg-primary: #ffffff;--bg-secondary: #f4f4f5;--bg-tertiary: #e4e4e7;--bg-elevated: #d4d4d8;--bg-inverse: #18181b;--text-primary: #18181b;--text-secondary: #3f3f46;--text-tertiary: #71717a;--text-inverse: #fafafa;--border-primary: #e4e4e7;--border-secondary: #d4d4d8;--accent-primary: #7c3aed;--accent-secondary: #8b5cf6;--accent-tertiary: #6d28d9;--accent-soft: rgba(124, 58, 237, .08);--success: #059669;--warning: #d97706;--error: #dc2626;--info: #2563eb;--gradient-brand: linear-gradient(135deg, #3390ec 0%, #5eb3f6 100%);--gradient-message-mine: linear-gradient(135deg, #2b7cd3 0%, #5eb3f6 100%);--gradient-hover: rgba(51, 144, 236, .06);--m-bg-app: #ffffff;--m-bg-panel: #ffffff;--m-bg-rail: #f4f4f5;--m-bg-chat: #e6ebee;--m-bg-search: #f0f2f5;--m-bg-hover: rgba(0, 0, 0, .04);--m-bg-elevated: #ffffff;--m-bubble-out: #effdde;--m-bubble-in: #ffffff;--m-avatar-a: #6ab2f2;--m-avatar-b: #3390ec;--m-rail-width: 72px;--m-chat-pattern: none}[data-theme=high-contrast]{--bg-primary: #000000;--bg-secondary: #1a1a1a;--bg-tertiary: #262626;--bg-elevated: #333333;--bg-inverse: #ffffff;--text-primary: #ffffff;--text-secondary: #e5e5e5;--text-tertiary: #d4d4d4;--text-inverse: #000000;--border-primary: #ffffff;--border-secondary: #e5e5e5;--accent-primary: #ffd700;--accent-secondary: #ffec80;--accent-tertiary: #eab308;--accent-soft: rgba(255, 215, 0, .2);--success: #4ade80;--warning: #fbbf24;--error: #f87171;--info: #60a5fa;--gradient-brand: linear-gradient(135deg, #ffd700 0%, #fbbf24 100%);--gradient-message-mine: linear-gradient(135deg, #ca8a04 0%, #ffd700 100%);--gradient-hover: linear-gradient(135deg, rgba(255, 215, 0, .15) 0%, rgba(251, 191, 36, .15) 100%)}[data-theme=dark],[data-theme=light],[data-theme=high-contrast]{--bg-deep: var(--bg-primary);--bg-panel: var(--bg-secondary);--bg: var(--bg-secondary);--text: var(--text-primary);--text-muted: var(--text-secondary);--accent: var(--accent-primary);--danger: var(--error);--radius: var(--radius-md);--shadow: var(--shadow-xl);--bubble-me: var(--gradient-message-mine);--bubble-them: var(--bg-tertiary);--border: var(--border-primary)}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px)}html{background:var(--bg-deep)}body{min-height:100%;min-height:100dvh;min-height:-webkit-fill-available;background:var(--bg-deep)}#root,.main-layout{min-height:100%;min-height:100dvh;min-height:-webkit-fill-available;display:flex;flex-direction:column}.app-shell{flex:1;width:100%;min-height:0;height:100dvh;height:100svh;max-height:100dvh;max-height:100svh;box-sizing:border-box;padding-top:var(--safe-top);padding-right:var(--safe-right);padding-left:var(--safe-left)}.auth-screen,.splash-screen{box-sizing:border-box;min-height:100dvh;min-height:100svh;min-height:-webkit-fill-available;padding-top:var(--safe-top);padding-right:var(--safe-right);padding-bottom:var(--safe-bottom);padding-left:var(--safe-left)}@media(max-width:720px){.composer{padding-bottom:calc(18px + var(--safe-bottom))}.mobile-category-tabs{padding-bottom:max(8px,var(--safe-bottom));padding-left:max(8px,var(--safe-left));padding-right:max(8px,var(--safe-right));background:var(--bg-secondary)}.sidebar{padding-bottom:calc(52px + var(--safe-bottom))}.app-shell.chat-open .sidebar{padding-bottom:0}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);background:var(--bg-deep);color:var(--text);-webkit-font-smoothing:antialiased}button,input{font:inherit}.app-shell{display:grid;grid-template-columns:320px 1fr;max-width:1200px;margin:0 auto;background:var(--bg-panel);box-shadow:var(--shadow-2xl);border-radius:0}@media(max-width:720px){.app-shell{grid-template-columns:1fr}.app-shell.chat-open .sidebar{display:none}}.sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 45%)}.sidebar-header{padding:16px 18px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);background:var(--gradient-hover)}.sidebar-header-left{display:flex;flex-direction:column;gap:8px;min-width:0;flex:1}.brand{display:flex;flex-direction:column;gap:2px}.brand-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.brand-title{font-weight:700;font-size:1.05rem;letter-spacing:-.02em;background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.brand-tagline{font-size:.75rem;color:var(--text-muted)}.workspace-switcher{position:relative;align-self:flex-start}.workspace-switcher-trigger{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-primary);font-size:.8rem;cursor:pointer;max-width:100%}.workspace-switcher-trigger svg:last-of-type{flex-shrink:0;transition:transform var(--duration-fast, .15s) var(--ease-smooth, ease)}.workspace-switcher-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace-chevron-open{transform:rotate(180deg);transition:transform var(--duration-fast) var(--ease-smooth, ease)}.workspace-switcher-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:220px;max-width:min(280px,90vw);margin:0;padding:6px;list-style:none;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:20}.workspace-switcher-item{padding:8px 10px;border-radius:var(--radius-sm);font-size:.85rem;display:flex;align-items:center;justify-content:space-between;gap:8px}.workspace-switcher-item-active{background:var(--accent-soft)}.workspace-switcher-badge{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary)}.workspace-switcher-hint{padding:8px 10px;font-size:.75rem;color:var(--text-muted);line-height:1.35}.btn{border:none;border-radius:var(--radius-sm);padding:8px 14px;cursor:pointer;font-weight:500;transition:transform var(--duration-fast) var(--ease-smooth),opacity var(--duration-fast) var(--ease-smooth)}.btn:active{transform:scale(.98)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--bg-elevated)}.btn-primary{background:var(--gradient-brand);color:var(--text-inverse)}.btn-primary:hover{filter:brightness(1.08);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.conv-list{flex:1;overflow-y:auto;padding:8px}.conv-item{width:100%;text-align:left;padding:12px 14px;border-radius:var(--radius-md);border:none;background:transparent;color:inherit;cursor:pointer;display:flex;gap:12px;align-items:center}.conv-item:hover,.conv-item.active{background:var(--bg-elevated)}.avatar{width:44px;height:44px;border-radius:var(--radius-full);background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:600;font-size:.95rem;flex-shrink:0}.conv-meta{min-width:0;flex:1}.unread-pill{font-size:.7rem;font-weight:700;min-width:1.25rem;height:1.25rem;padding:0 6px;border-radius:var(--radius-full);background:var(--gradient-brand);color:var(--text-inverse);line-height:1.25rem;text-align:center}.conv-name{font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.9rem;min-width:0}.conv-preview{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.main{display:flex;flex-direction:column;min-height:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,color-mix(in srgb,var(--accent-primary) 16%,transparent),transparent)}.main-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.main-header h2{margin:0;font-size:1rem;font-weight:600}.main-header>.btn.btn-ghost:not(.back-mobile){display:inline-flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;padding:8px}.messages{flex:1;min-height:0;display:flex;flex-direction:column;padding:0}.virtuoso-scroller{flex:1;min-height:0}.msg-row{display:flex;padding:0 20px 10px}.msg-row.me{justify-content:flex-end}.msg-author{font-size:.78rem;font-weight:600;margin-bottom:4px;opacity:.92}button.msg-author-link{display:block;width:100%;margin:0 0 4px;padding:0;border:none;background:none;font:inherit;font-size:.78rem;font-weight:600;opacity:.92;color:inherit;text-align:left;cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .12s ease}button.msg-author-link:hover{text-decoration-color:currentColor}button.forward-snippet-author{margin:0;padding:0;border:none;background:none;font:inherit;font-size:inherit;color:inherit;cursor:pointer;text-decoration:underline;text-decoration-color:transparent}button.forward-snippet-author:hover{text-decoration-color:currentColor}.bubble{max-width:min(72%,420px);padding:10px 14px;border-radius:var(--radius-lg);font-size:.92rem;line-height:1.45;word-wrap:break-word}.bubble.them{background:var(--bubble-them);border-bottom-left-radius:4px}.bubble.me{background:var(--bubble-me);color:#fff;border-bottom-right-radius:4px}.msg-time{font-size:.68rem;opacity:.65;margin-top:4px}.composer{padding:14px 18px 18px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;background:color-mix(in srgb,var(--bg-secondary) 82%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.composer-row{display:flex;gap:10px;align-items:flex-end}.composer textarea,.composer .mention-wrap textarea{flex:1;width:100%;resize:none;min-height:44px;max-height:120px;border-radius:12px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);padding:11px 14px;outline:none}.composer textarea:focus,.composer .mention-wrap textarea:focus{border-color:color-mix(in srgb,var(--accent-primary) 50%,var(--border))}.auth-screen{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(ellipse 60% 40% at 50% 0%,color-mix(in srgb,var(--accent-primary) 22%,transparent),transparent),var(--bg-deep)}.auth-card{width:100%;max-width:400px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-2xl)}.auth-card h1{margin:0 0 8px;font-size:1.5rem}.auth-card p{margin:0 0 24px;color:var(--text-muted);font-size:.9rem}.field{margin-bottom:16px}.field label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:6px}.field input{width:100%;padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);outline:none}.field input:focus{border-color:color-mix(in srgb,var(--accent-primary) 50%,var(--border))}.auth-error{color:var(--danger);font-size:.85rem;margin-bottom:12px}.tabs{display:flex;gap:8px;margin-bottom:20px}.tabs button{flex:1;padding:10px;border:none;border-radius:10px;background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;font-weight:500}.tabs button.active{background:var(--accent-soft);color:var(--accent)}.journal-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.journal-tabs button{padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;font-size:.85rem;font-weight:500}.journal-tabs button.is-active{border-color:color-mix(in srgb,var(--accent-primary) 45%,var(--border));background:var(--accent-soft);color:var(--accent)}.journal-body{min-height:120px}.journal-tab-panel{min-height:100px}.journal-panel-list{list-style:none;padding:0;margin:0}.journal-photo-row{display:flex;gap:10px;align-items:center}.journal-panel-list>li{border-bottom:1px solid var(--border);padding:10px 0;font-size:.9rem}.journal-panel-list>li:first-child{padding-top:4px}.journal-thumb-link{flex-shrink:0}.journal-thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;display:block}.journal-panel-meta{min-width:0;font-size:.85rem}.journal-video{max-width:100%;max-height:200px;border-radius:8px}.journal-audio{width:100%;margin-top:6px;max-height:44px}.journal-shared-row{display:flex;justify-content:space-between;gap:8px;align-items:center}.empty-main{flex:1;display:grid;place-items:center;color:var(--text-muted);text-align:center;padding:40px}.empty-main strong{color:var(--text);display:block;margin-bottom:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:grid;place-items:center;z-index:50;padding:20px}.modal{background:var(--bg-panel);border:1px solid var(--border);border-radius:16px;width:100%;max-width:380px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden}.modal h3{margin:0;padding:16px 18px;border-bottom:1px solid var(--border);font-size:1rem}.user-picker{overflow-y:auto;padding:8px}.user-row{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border:none;border-radius:var(--radius);background:transparent;color:inherit;cursor:pointer;text-align:left}.user-row:hover{background:var(--bg-elevated)}.modal-footer{padding:12px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.back-mobile{display:none}@media(max-width:720px){.back-mobile{display:inline-flex}}.conn-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-left:6px;background:var(--danger);vertical-align:middle}.conn-dot.on{background:var(--success)}.toolbar-mini{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}.sidebar-search{padding:8px 12px 0;position:relative}.sidebar-search input{width:100%;padding:9px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:.85rem;outline:none}.search-hits{position:absolute;left:12px;right:12px;top:100%;margin-top:4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;max-height:200px;overflow-y:auto;z-index:5;box-shadow:var(--shadow)}.search-hit{display:block;width:100%;text-align:left;padding:10px 12px;border:none;background:transparent;color:var(--text);cursor:pointer;font-size:.88rem}.search-hit:hover{background:var(--bg-panel)}.badge-type{display:inline-block;margin-right:6px;font-size:.75rem;color:var(--accent);font-weight:700}.typing-bar{padding:6px 20px;font-size:.8rem;color:var(--text-muted);border-bottom:1px solid var(--border)}.forward-snippet,.reply-snippet{font-size:.78rem;color:var(--text-muted);border-left:3px solid var(--accent);padding:4px 0 4px 8px;margin-bottom:6px;opacity:.95}.msg-img{max-width:100%;max-height:240px;border-radius:10px;display:block;margin-bottom:8px}button.msg-img-btn{display:block;width:100%;max-width:100%;padding:0;margin:0 0 8px;border:none;background:transparent;cursor:zoom-in;border-radius:10px;overflow:hidden;line-height:0}button.msg-img-btn:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-primary) 70%,transparent);outline-offset:2px}button.msg-img-btn .msg-img{margin-bottom:0}.msg-img-lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3500;display:flex;align-items:center;justify-content:center;padding:min(20px,4vw);background:#000000e0;cursor:zoom-out}.msg-img-lightbox-close{position:absolute;top:12px;right:12px;width:44px;height:44px;border:none;border-radius:50%;background:color-mix(in srgb,var(--bg-elevated) 88%,transparent);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;box-shadow:var(--shadow)}.msg-img-lightbox-close:hover{background:var(--bg-panel)}.msg-img-lightbox-img{max-width:100%;max-height:min(92vh,calc(100vh - 40px));width:auto;height:auto;object-fit:contain;cursor:default;border-radius:10px;box-shadow:0 12px 48px #0000008c}.bubble.failed{opacity:.75;outline:1px dashed var(--danger)}.bubble.queued{opacity:.85;outline:1px dashed var(--text-muted)}.chat-search-panel{border-bottom:1px solid var(--border);padding:10px 16px;background:var(--bg-elevated)}.chat-search-panel input{width:100%;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:inherit}.chat-search-hits{max-height:160px;overflow-y:auto;margin-top:8px}.check-row{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;line-height:1.35}.check-row input{margin-top:3px}.reaction-row-summary-only .reaction-summary{margin-bottom:0}@media(hover:hover)and (pointer:fine){.bubble-interactive{cursor:context-menu}}.bubble-interactive{-webkit-touch-callout:none}.msg-context-menu{min-width:200px;max-width:min(280px,calc(100vw - 16px));padding:6px;border-radius:var(--radius-md);background:var(--bg-panel);border:1px solid var(--border-primary);box-shadow:var(--shadow-xl)}.msg-context-item{display:flex;width:100%;align-items:center;gap:8px;padding:10px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-size:.9rem;text-align:left;cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth)}.msg-context-item:hover{background:var(--bg-elevated)}.msg-context-item.danger{color:var(--danger)}.msg-context-item.subtle{font-size:.82rem;color:var(--text-muted)}.msg-context-sep{height:1px;margin:6px 4px;background:var(--border-primary)}.msg-context-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:4px 10px 6px}.msg-context-reactions{display:flex;flex-wrap:wrap;gap:6px;padding:4px 8px 8px}.msg-context-reaction{flex:1;min-width:2.5rem;padding:8px 6px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-tertiary);font-size:1.25rem;line-height:1;cursor:pointer;transition:background var(--duration-fast),border-color var(--duration-fast)}.msg-context-reaction:hover{background:var(--bg-elevated);border-color:var(--accent-primary)}.reaction-row{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.06)}.bubble.me .reaction-row{border-top-color:#00000014}.reaction-summary{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.reaction-pill{font-size:.78rem;background:#ffffff14;padding:2px 8px;border-radius:999px}.bubble.me .reaction-pill{background:#00000014}.reaction-n{font-size:.7rem;margin-left:2px;opacity:.85}.reaction-picks{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.reaction-pick{border:none;background:#ffffff1a;border-radius:8px;padding:2px 8px;cursor:pointer;font-size:1rem;line-height:1.2}.bubble.me .reaction-pick{background:#00000014}.reaction-pick:hover{filter:brightness(1.15)}.bubble-actions{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}.linkish{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.75rem;padding:0}.linkish.danger{color:var(--danger)}.composer-upload-progress{display:flex;flex-direction:column;gap:6px}.composer-upload-progress-label{font-size:.8rem;color:var(--text-muted)}.composer-upload-progress-track{height:4px;border-radius:999px;background:var(--border);overflow:hidden}.composer-upload-progress-fill{height:100%;border-radius:inherit;background:var(--accent-primary);transition:width .12s ease-out}.composer-banners{display:flex;flex-direction:column;gap:6px}.reply-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;background:var(--bg-elevated);border-radius:10px;font-size:.85rem;color:var(--text-muted)}.user-row-wrap{display:flex;align-items:center;gap:8px}.user-row-wrap .user-row{flex:1}.small-btn{padding:6px 10px!important;font-size:.75rem!important}.muted{color:var(--text-muted)}.small{font-size:.8rem}.check-row{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;font-size:.9rem}.select-dark{flex:1;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text)}.modal.wide{max-width:440px}.load-hint{text-align:center;font-size:.8rem;color:var(--text-muted);padding:8px}.presence-dot{color:#34d399;font-size:.75em;vertical-align:middle}.msg-mention{color:var(--accent);font-weight:600}.msg-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px;word-break:break-all}.msg-md-inline{display:inline}.msg-md .msg-md-inline{line-height:inherit}.msg-code{font-size:.88em;padding:1px 5px;border-radius:6px;background:#0003}[data-theme=light] .msg-code{background:#0000000f}.search-hit-mark{background:#facc1559;color:inherit;padding:0 2px;border-radius:3px}.toast-container{position:fixed;bottom:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:10px;max-width:min(360px,calc(100vw - 32px));pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);box-shadow:var(--shadow);font-size:.9rem;animation:toast-in .25s ease}.toast--success{border-left:3px solid #22c55e}.toast--error{border-left:3px solid var(--danger)}.toast--warning{border-left:3px solid #f59e0b}.toast--info{border-left:3px solid var(--accent)}.toast-icon{font-weight:700;opacity:.85}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.video-call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#000000eb;display:flex;align-items:center;justify-content:center}.video-call-modal{background:var(--bg-panel);border:1px solid var(--border);border-radius:16px;padding:20px 22px;max-width:400px;width:calc(100% - 32px);box-shadow:var(--shadow)}.video-call-modal h3{margin:0 0 8px;font-size:1.1rem}.video-call-modal-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.video-call-stage{position:relative;width:100%;height:100%;min-height:240px}.video-call-remote{width:100%;height:100%;min-height:50vh;object-fit:contain;background:#000}.video-call-local{position:absolute;right:12px;bottom:96px;width:min(32vw,200px);max-height:28vh;object-fit:cover;border-radius:12px;border:2px solid rgba(255,255,255,.25);background:#111;box-shadow:0 8px 24px #00000073}.video-call-waiting{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center;color:#e5e5e5;pointer-events:none}.video-call-waiting p{margin:.25rem 0}.video-call-toolbar{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:center;gap:12px;padding:16px;background:linear-gradient(transparent,#000000bf)}.video-call-tool{border-radius:50%;width:48px;height:48px;padding:0;display:inline-flex;align-items:center;justify-content:center}.video-call-hangup{background:var(--danger, #dc2626);color:#fff;border:none}.video-call-hangup:hover{filter:brightness(1.08)}.audio-call-overlay{background:linear-gradient(180deg,var(--m-bg-app, #0e1621) 0%,var(--m-bg-panel, #17212b) 100%)}.audio-call-stage{position:relative;width:100%;height:100%;min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.audio-call-peer{text-align:center;padding:24px}.audio-call-avatar{width:72px;height:72px;margin:0 auto 16px;border-radius:var(--radius-full);display:grid;place-items:center;font-size:1.5rem;font-weight:600;color:#fff;background:linear-gradient(145deg,var(--m-avatar-a, #5eb3f6),var(--m-avatar-b, #3390ec))}.audio-call-avatar--lg{width:120px;height:120px;font-size:2.25rem}.audio-call-avatar--sm{width:56px;height:56px;font-size:1.1rem;margin-bottom:12px}.audio-call-name{margin:0 0 8px;font-size:1.35rem;font-weight:600}.audio-call-status{margin:0}.audio-call-toolbar{background:linear-gradient(transparent,#00000080)}.audio-call-stage audio{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.video-call-banner{position:absolute;top:12px;left:50%;transform:translate(-50%);max-width:90%;padding:8px 14px;border-radius:10px;background:#000000a6;color:#fecaca;font-size:.875rem;text-align:center}.msg-row{animation:messageSlideIn var(--duration-slow) var(--ease-smooth)}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bubble{transition:transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth)}.bubble:hover{box-shadow:var(--shadow-sm)}.categories-nav{display:flex;flex-direction:column;gap:2px;padding:6px 10px 8px;border-bottom:1px solid var(--border-primary)}.category-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:500;cursor:pointer;text-align:left;transition:background var(--duration-fast) var(--ease-smooth),color var(--duration-fast) var(--ease-smooth)}.category-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.category-item.active{background:var(--accent-soft);color:var(--accent-primary)}.category-item .cat-icon{flex-shrink:0;opacity:.9}.category-badge{margin-left:auto;min-width:1.25rem;height:1.25rem;padding:0 5px;border-radius:var(--radius-full);font-size:.68rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-secondary)}.category-badge.accent{background:var(--accent-soft);color:var(--accent-primary)}.mobile-category-tabs{display:none}@media(max-width:720px){.categories-nav{display:none}.mobile-category-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:30;justify-content:space-around;align-items:stretch;gap:4px;padding:6px 8px max(6px,env(safe-area-inset-bottom,0px));background:var(--bg-secondary);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-primary);box-shadow:0 -8px 24px #0000001f}.app-shell.chat-open .mobile-category-tabs{display:none}.mobile-category-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:0;min-height:48px;padding:4px 2px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);cursor:pointer;position:relative;transition:color var(--duration-fast) var(--ease-smooth),background var(--duration-fast) var(--ease-smooth)}.mobile-category-tab:active{transform:scale(.96)}.mobile-category-tab.active{color:var(--accent-primary);background:var(--accent-soft)}.mobile-tab-count{position:absolute;top:5px;left:50%;transform:translate(10px);min-width:1.1rem;height:1.1rem;padding:0 4px;border-radius:var(--radius-full);font-size:.62rem;font-weight:700;line-height:1.1rem;text-align:center;background:var(--bg-tertiary);color:var(--text-secondary);pointer-events:none}.mobile-tab-count.accent{background:var(--gradient-brand);color:var(--text-inverse)}}.sidebar-search-inner{position:relative}.sidebar-search-inner .search-input-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.sidebar-search-inner input{padding-left:34px;padding-right:28px}.search-clear-sidebar{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:none;border-radius:var(--radius-full);background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:1rem;line-height:1;display:grid;place-items:center}.search-clear-sidebar:hover{background:var(--bg-tertiary);color:var(--text-primary)}.beta-badge{font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent-primary);margin-left:6px;vertical-align:middle}.main-layout{height:100%;min-height:0}.splash-screen{min-height:100%;display:grid;place-items:center;background:var(--bg-primary);color:var(--text-primary)}.splash-logo{display:flex;flex-direction:column;align-items:center;gap:12px;animation:splash-pulse 1.6s ease-in-out infinite}.splash-logo p{margin:0;font-weight:700;font-size:1.25rem;letter-spacing:.04em;background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent}@keyframes splash-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.02)}}.theme-switcher{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.theme-switcher .theme-opt{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:grid;place-items:center;padding:0;transition:border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast)}.theme-switcher .theme-opt:hover{border-color:var(--accent-primary);color:var(--text-primary)}.theme-switcher .theme-opt.active{border-color:var(--accent-primary);background:var(--accent-soft);color:var(--accent-primary)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-elevated) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeletonLoading 1.5s infinite}@keyframes skeletonLoading{0%{background-position:200% 0}to{background-position:-200% 0}}.voice-recorder-bar{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--border-primary);background:var(--bg-elevated)}.voice-recorder-head{display:flex;align-items:center;gap:10px}.voice-rec-icon{color:var(--accent-primary);flex-shrink:0}.voice-rec-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.voice-rec-title{font-size:.78rem;font-weight:600;color:var(--text-muted)}.voice-rec-time{font-size:.95rem;font-variant-numeric:tabular-nums;font-weight:600}.voice-rec-canvas{width:100%;height:56px;border-radius:8px;background:color-mix(in srgb,var(--bg-primary) 70%,transparent)}.voice-rec-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.voice-rec-btn{display:inline-flex;align-items:center;gap:6px}.voice-msg-player{position:relative;display:flex;flex-direction:row;align-items:center;gap:8px;width:100%;max-width:100%;margin-top:6px;padding:5px 8px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--bg-primary) 45%,transparent);border:1px solid color-mix(in srgb,var(--border-primary) 65%,transparent);box-sizing:border-box}.voice-msg-player--mine .voice-msg-playbtn{order:0}.voice-msg-player--mine .voice-msg-main{order:1;flex:1;min-width:0}.voice-msg-player--them .voice-msg-main{order:0;flex:1;min-width:0}.voice-msg-player--them .voice-msg-playbtn{order:1}.bubble.me .voice-msg-player{background:color-mix(in srgb,#fff 14%,transparent);border-color:color-mix(in srgb,#fff 28%,transparent)}.bubble.me .voice-msg-track{background:color-mix(in srgb,#000 22%,transparent)}.bubble.me .voice-msg-wave-bar{background:color-mix(in srgb,#fff 38%,transparent)}.voice-msg-audio-el{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.voice-msg-playbtn{flex-shrink:0;width:36px;height:36px;border-radius:var(--radius-full);border:none;display:grid;place-items:center;cursor:pointer;background:var(--accent-soft);color:var(--accent-primary);transition:background var(--duration-fast),transform var(--duration-fast),filter var(--duration-fast)}.bubble.me .voice-msg-playbtn{background:#fff;color:#18181b;box-shadow:0 1px 3px #0000001f}.bubble.me .voice-msg-playbtn.is-playing{background:color-mix(in srgb,#fff 88%,var(--accent-primary));color:#18181b}.voice-msg-playbtn:hover{filter:brightness(1.06)}.voice-msg-playbtn:active{transform:scale(.95)}.voice-msg-playbtn.is-playing{background:color-mix(in srgb,var(--accent-primary) 24%,var(--bg-elevated));color:var(--accent-primary)}.voice-msg-main{display:flex;flex-direction:column;gap:4px;justify-content:center;min-width:0}.voice-msg-track{position:relative;width:100%;height:28px;border-radius:8px;overflow:hidden;cursor:pointer;background:color-mix(in srgb,var(--bg-tertiary) 88%,transparent)}.voice-msg-wave{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:space-between;gap:1px;padding:3px 5px;pointer-events:none}.voice-msg-wave-bar{flex:1;min-width:1px;max-width:4px;align-self:center;border-radius:1px;background:color-mix(in srgb,var(--text-tertiary) 50%,transparent)}.voice-msg-progress-track{position:absolute;left:0;right:0;bottom:0;height:2px;background:color-mix(in srgb,var(--border-primary) 65%,transparent);pointer-events:none}.voice-msg-progress-fill{position:absolute;left:0;bottom:0;height:2px;width:100%;transform-origin:left center;background:var(--accent-primary);transition:transform .08s linear;pointer-events:none}.bubble.me .voice-msg-progress-fill{background:#fff}.voice-msg-times{font-size:.72rem;font-variant-numeric:tabular-nums;line-height:1.2;padding-left:1px}.voice-msg-player--them .voice-msg-times{text-align:right;padding-left:0;padding-right:1px}.video-note-recorder-bar{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--border-primary);background:var(--bg-elevated)}.video-note-recorder-head{display:flex;align-items:center;gap:10px}.video-note-rec-title{flex:1;min-width:0;font-size:.78rem;font-weight:600;color:var(--text-muted)}.video-note-rec-close{margin-left:auto;padding:6px}.video-note-rec-icon{color:var(--accent-primary);flex-shrink:0}.video-note-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;padding:4px 0 8px}.video-note-preview-wrap--compact{padding:0;gap:6px}.video-note-preview-wrap--compact .video-note-ring-stack{width:min(200px,58vw)}.video-note-ring-stack{position:relative;width:min(220px,55vw);aspect-ratio:1}.video-note-ring-stack[role=button]{cursor:pointer}.video-note-timer-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;color:var(--accent-primary)}.video-note-timer-track{stroke:color-mix(in srgb,var(--border-primary) 90%,var(--text-muted));opacity:.85}.video-note-timer-progress{stroke:currentColor;transition:stroke-dashoffset .08s linear}.video-note-video-shell{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:50%;overflow:hidden;z-index:1;background:#0a0a0a}.video-note-preview{width:100%;height:100%;object-fit:cover;transform:scale(1.03);display:block}.video-note-center-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:grid;place-items:center;pointer-events:none}.video-note-center-btn{pointer-events:auto;display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border:none;border-radius:50%;cursor:pointer;transition:transform .12s ease,background .12s ease}.video-note-center-btn:active{transform:scale(.96)}.video-note-center-btn--play{background:color-mix(in srgb,#fff 92%,transparent);color:var(--accent-primary);box-shadow:0 4px 20px #00000059}.video-note-center-btn--play:hover{background:#fff}.video-note-center-btn--pause{background:color-mix(in srgb,#fff 92%,transparent);color:var(--accent-primary);box-shadow:0 4px 20px #00000059}.video-note-center-btn--pause:hover{background:#fff}.video-note-play-icon{margin-left:4px}.video-note-center-btn--stop{background:color-mix(in srgb,var(--danger) 92%,#fff);color:#fff;box-shadow:0 4px 20px #00000059}.video-note-center-btn--stop:hover{filter:brightness(1.06)}.video-note-time-row{font-variant-numeric:tabular-nums;text-align:center}.video-note-rec-hint{margin:0;text-align:center;line-height:1.35}.msg-video-note-wrap{margin-top:6px;display:flex;justify-content:flex-start}.msg-video-note-wrap.me{justify-content:flex-end}.video-note-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3600;display:flex;align-items:center;justify-content:center;padding:min(20px,4vw);background:#000000e0;cursor:pointer}.video-note-viewer-panel{width:min(100%,360px);cursor:default;box-shadow:0 20px 50px #00000073}.bubble.me.bubble--videonote-me{background:transparent;color:var(--text);padding:0;border-radius:0;box-shadow:none}.bubble.me.bubble--videonote-me .msg-time{margin-top:6px;text-align:right;color:var(--text-muted);opacity:1}.bubble.me.bubble--videonote-me .msg-video-note-wrap{margin-top:0}.msg-row--call-service{justify-content:center;margin:10px 0}.msg-call-service{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--bg-elevated) 92%,var(--accent-primary));font-size:.85rem;color:var(--text-muted)}.msg-call-service--missed{color:var(--danger, #e53935);background:color-mix(in srgb,var(--danger) 12%,var(--bg-elevated))}.msg-time--call-service{text-align:center;width:100%;margin-top:4px}.msg-link-preview{display:flex;flex-direction:column;margin-top:8px;max-width:min(320px,100%);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);background:var(--bg-elevated);text-decoration:none;color:inherit}.msg-link-preview:hover{border-color:color-mix(in srgb,var(--accent-primary) 40%,var(--border-primary))}.msg-link-preview-img-wrap{display:block;max-height:160px;overflow:hidden}.msg-link-preview-img{width:100%;height:100%;object-fit:cover;display:block}.msg-link-preview-body{display:flex;flex-direction:column;gap:4px;padding:10px 12px}.msg-link-preview-title{font-weight:600;font-size:.9rem;line-height:1.3}.msg-link-preview-desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35}.pinned-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:color-mix(in srgb,var(--accent-primary) 10%,var(--bg-secondary));border-bottom:1px solid var(--border-primary);flex-shrink:0}.pinned-bar-text{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.88rem}.pinned-bar-unpin{padding:4px 10px;font-size:1.1rem}.m-call-clear-btn{display:block;width:calc(100% - 24px);margin:0 12px 8px;padding:8px;border:1px dashed var(--border-primary);border-radius:var(--radius-md);background:transparent;cursor:pointer;text-align:center}.m-call-delete{color:var(--text-tertiary);font-size:1.1rem}@media(max-width:768px){.composer textarea,.composer .mention-wrap textarea{font-size:16px}.bubble{max-width:min(85%,420px)}.theme-switcher .theme-opt{width:30px;height:30px}}@media(min-width:1440px){.app-shell{max-width:1280px}.bubble{max-width:min(60%,480px)}}.main-layout{height:100%;background:var(--m-bg-app)}.messenger-shell.app-shell{max-width:100%;margin:0;background:var(--m-bg-app);box-shadow:none}@media(min-width:721px){.messenger-shell.app-shell{grid-template-columns:var(--m-rail-width) min(380px,32vw) 1fr}}@media(max-width:720px){.messenger-shell.app-shell{grid-template-columns:1fr}.messenger-shell:not(.chat-open) .main{display:none}.messenger-shell.chat-open .sidebar,.messenger-shell.chat-open .m-bottom-tabs,.messenger-shell.chat-open .messenger-rail{display:none}}.messenger-rail{display:none;flex-direction:column;align-items:center;gap:4px;padding:12px 0;background:var(--m-bg-rail);border-right:1px solid var(--border-primary)}@media(min-width:721px){.messenger-rail{display:flex}}.m-rail-btn{width:48px;height:48px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-tertiary);cursor:pointer;display:grid;place-items:center;position:relative;transition:background var(--duration-fast),color var(--duration-fast)}.m-rail-btn:hover{background:var(--m-bg-hover);color:var(--text-primary)}.m-rail-btn.active{color:var(--accent-primary);background:var(--accent-soft)}.m-rail-badge{position:absolute;top:6px;right:6px;min-width:1rem;height:1rem;padding:0 4px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-size:.62rem;font-weight:700;line-height:1rem;text-align:center}.messenger-shell .sidebar{background:var(--m-bg-panel);border-right:1px solid var(--border-primary);min-height:0;display:flex;flex-direction:column}.messenger-shell .sidebar-header--legacy,.messenger-shell .categories-nav{display:none!important}.messenger-shell .sidebar-search-inner{display:none}.messenger-shell .sidebar-search{padding:0;border:none;background:transparent}.m-screen-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px 10px;padding-top:max(8px,env(safe-area-inset-top,0px));background:var(--m-bg-panel);border-bottom:1px solid var(--border-primary);flex-shrink:0}.m-screen-title{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.m-screen-actions{display:flex;align-items:center;gap:4px}.m-icon-btn{width:40px;height:40px;border:none;border-radius:var(--radius-full);background:transparent;color:var(--accent-primary);cursor:pointer;display:grid;place-items:center}.m-icon-btn:hover,.m-icon-btn--primary{background:var(--accent-soft)}.m-screen-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.m-search-wrap{padding:8px 12px 10px;flex-shrink:0}.m-search{width:100%;padding:9px 12px 9px 36px;border:none;border-radius:var(--radius-full);background:var(--m-bg-search);color:var(--text-primary);font-size:1rem;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%238e99a4' stroke-width='2'%3E%3Ccircle cx='8' cy='8' r='5'/%3E%3Cpath d='m13 13 4 4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center}.m-search::placeholder{color:var(--text-tertiary)}.m-list-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.m-section-label{padding:6px 16px 4px;font-size:.8rem;font-weight:600;color:var(--accent-primary)}.m-section-label--caps{text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;color:var(--text-tertiary)}.m-list-row{width:100%;display:flex;align-items:center;gap:12px;padding:8px 16px;border:none;background:transparent;color:inherit;cursor:pointer;text-align:left;transition:background var(--duration-fast)}.m-list-row:hover,.m-list-row:active{background:var(--m-bg-hover)}.m-list-row-main{flex:1;min-width:0}.m-list-row-title{display:block;font-size:1rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-list-row-sub{display:block;font-size:.85rem;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-list-row-sub--icon{display:flex;align-items:center;gap:6px}.m-list-row-meta{flex-shrink:0;font-size:.75rem}.m-list-row--with-action{display:flex;align-items:center;gap:0;padding:0 8px 0 0;width:100%;background:transparent}.m-list-row--with-action:hover,.m-list-row--with-action:active{background:var(--m-bg-hover)}.m-list-row--flex{flex:1;min-width:0}.m-list-row-call{flex-shrink:0;color:var(--m-accent)}.m-call-row-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.m-call-row--unread .m-list-row-title{font-weight:600}.m-call-sub--missed{color:var(--danger, #e53935);display:flex;align-items:center;gap:6px}.m-call-sub-icon{flex-shrink:0}.m-call-contacts-block{margin-top:8px;padding-top:4px;border-top:1px solid var(--border-primary)}.m-empty-hint{padding:24px 20px;text-align:center;color:var(--text-tertiary);font-size:.9rem;line-height:1.45}.m-segmented{display:flex;margin:0 12px 8px;padding:2px;background:var(--m-bg-search);border-radius:var(--radius-md);flex-shrink:0}.m-segmented-item{flex:1;border:none;background:transparent;color:var(--text-secondary);padding:8px 12px;border-radius:calc(var(--radius-md) - 2px);font-size:.9rem;font-weight:500;cursor:pointer}.m-segmented-item.active{background:var(--m-bg-panel);color:var(--accent-primary);box-shadow:var(--shadow-sm)}.m-action-row{width:calc(100% - 24px);margin:8px 12px 12px;display:flex;align-items:center;gap:14px;padding:10px 12px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--accent-primary);cursor:pointer;text-align:left}.m-action-row:hover{background:var(--m-bg-hover)}.m-action-row-icon{width:44px;height:44px;border-radius:var(--radius-full);display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-primary)}.m-action-row-icon--blue{background:color-mix(in srgb,var(--accent-primary) 18%,transparent)}.m-action-row-label{font-size:1rem;font-weight:500}.m-chats-tabs{display:flex;gap:0;padding:0 12px 8px;border-bottom:1px solid var(--border-primary);flex-shrink:0;overflow-x:auto}.m-chats-tab{flex-shrink:0;border:none;background:transparent;color:var(--text-tertiary);padding:10px 14px;font-size:.9rem;font-weight:500;cursor:pointer;position:relative}.m-chats-tab.active{color:var(--accent-primary)}.m-chats-tab.active:after{content:"";position:absolute;left:14px;right:14px;bottom:0;height:2px;background:var(--accent-primary);border-radius:2px 2px 0 0}.messenger-shell .conv-list{padding:0}.messenger-shell .conv-item{padding:9px 16px;border-radius:0;gap:14px}.messenger-shell .conv-item:hover,.messenger-shell .conv-item.active{background:var(--m-bg-hover)}.messenger-shell .conv-item.active{background:var(--accent-soft)}.messenger-shell .avatar,.avatar-lg{width:52px;height:52px;font-size:1.05rem;background:linear-gradient(145deg,var(--m-avatar-a),var(--m-avatar-b));color:#fff}.avatar-xl{width:64px;height:64px;font-size:1.25rem;border-radius:var(--radius-full);display:grid;place-items:center;font-weight:600;flex-shrink:0;background:linear-gradient(145deg,var(--m-avatar-a),var(--m-avatar-b));color:#fff}.messenger-shell .conv-name{font-size:1rem;font-weight:500}.messenger-shell .unread-pill{background:var(--accent-primary);margin-left:auto}.messenger-shell .conv-preview{font-size:.85rem;color:var(--text-tertiary)}.m-bottom-tabs{display:none}@media(max-width:720px){.m-bottom-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;justify-content:space-around;align-items:stretch;padding:4px 4px max(4px,env(safe-area-inset-bottom,0px));background:var(--m-bg-panel);border-top:1px solid var(--border-primary);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.messenger-shell .sidebar{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}.mobile-category-tabs{display:none!important}}.m-bottom-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:52px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;padding:4px}.m-bottom-tab.active{color:var(--accent-primary)}.m-bottom-tab-icon{position:relative;display:flex}.m-bottom-tab-label{font-size:.62rem;font-weight:500}.m-bottom-tab-badge{position:absolute;top:-4px;right:-10px;min-width:1.1rem;height:1.1rem;padding:0 4px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-size:.6rem;font-weight:700;line-height:1.1rem;text-align:center}.m-settings-body{overflow-y:auto}.m-profile-card{width:100%;display:flex;align-items:center;gap:16px;padding:16px;border:none;background:transparent;color:inherit;cursor:pointer;text-align:left}.m-profile-card:hover{background:var(--m-bg-hover)}.m-profile-card-text{flex:1;min-width:0}.m-profile-name{display:block;font-size:1.15rem;font-weight:600}.m-profile-sub{display:block;font-size:.9rem;color:var(--accent-primary);margin-top:2px}.m-settings-group{margin:8px 12px;background:var(--m-bg-elevated);border-radius:var(--radius-lg);overflow:hidden}.m-settings-row{width:100%;display:flex;align-items:center;gap:14px;padding:12px 16px;border:none;background:transparent;color:inherit;cursor:pointer;text-align:left;font-size:1rem}.m-settings-row+.m-settings-row,.m-settings-row+.m-settings-row--static{border-top:1px solid var(--border-primary)}.m-settings-row:hover{background:var(--m-bg-hover)}.m-settings-row--static{cursor:default}.m-settings-row-icon{color:var(--accent-primary);display:flex}.m-settings-row-label{flex:1}.m-settings-chevron{color:var(--text-tertiary);flex-shrink:0}.m-toggle-pill{font-size:.85rem;color:var(--text-tertiary)}.m-settings-logout{width:calc(100% - 24px);margin:16px 12px 24px;padding:14px;border:none;border-radius:var(--radius-lg);background:var(--m-bg-elevated);color:var(--error);font-size:1rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.messenger-shell .main{background:var(--m-bg-chat);background-image:var(--m-chat-pattern)}.messenger-shell .main-header{background:var(--m-bg-panel);border-bottom:1px solid var(--border-primary);padding:8px 12px}.messenger-shell .bubble.me{background:var(--m-bubble-out);color:#fff;border-radius:18px 18px 4px}.messenger-shell .bubble.them{background:var(--m-bubble-in);color:var(--text-primary);border-radius:18px 18px 18px 4px}.messenger-shell .composer{background:var(--m-bg-panel);border-top:1px solid var(--border-primary)}.messenger-auth.auth-screen{background:var(--m-bg-app)}.messenger-auth .auth-card{background:var(--m-bg-panel);border-radius:var(--radius-xl);border:1px solid var(--border-primary)}.messenger-auth .tabs button.active{background:var(--accent-primary);color:#fff}.messenger-auth .btn-primary{background:var(--accent-primary);border-radius:var(--radius-md)}.m-call-demo{display:flex;align-items:center;gap:8px;padding:12px 16px}.app-dialog .app-dialog-message{padding:0 18px 12px;margin:0;line-height:1.45}.app-dialog-input{display:block;width:calc(100% - 36px);margin:0 18px 12px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);font:inherit;resize:vertical}.btn-danger{background:var(--danger, #dc2626);color:#fff;border:none}.btn-danger:hover{filter:brightness(1.08)}.skeleton-block{display:block;border-radius:var(--radius-sm)}.chat-list-skeleton{padding:4px 0}.chat-list-skeleton-row{display:flex;gap:12px;padding:10px 16px;align-items:center}.chat-list-skeleton-meta{flex:1;display:flex;flex-direction:column;gap:8px}.sk-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0}.sk-line{height:12px;border-radius:6px}.sk-line--title{width:55%}.sk-line--sub{width:80%}.message-list-skeleton{padding:16px;display:flex;flex-direction:column;gap:12px}.message-list-skeleton-row{display:flex}.message-list-skeleton-row--me{justify-content:flex-end}.sk-bubble{width:min(72%,280px);height:44px;border-radius:14px}.sk-bubble--me{width:min(48%,200px)}.offline-banner{padding:8px 14px;background:color-mix(in srgb,var(--danger, #dc2626) 18%,var(--bg-secondary));color:var(--text-primary);font-size:.85rem;text-align:center;border-bottom:1px solid var(--border-primary)}.offline-banner-sub{opacity:.85}.scroll-bottom-fab{position:absolute;right:16px;bottom:88px;z-index:4;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-primary);background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-md);display:grid;place-items:center;cursor:pointer}.messages-wrap{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}.colored-avatar{color:#fff;font-weight:600}.conv-item--pinned .conv-name:before{content:"📌 ";font-size:.85em}.conv-time{font-size:.75rem;color:var(--text-muted);margin-left:auto;flex-shrink:0}.conv-list--pulling:before{content:"Отпустите для обновления";display:block;text-align:center;padding:8px;font-size:.8rem;color:var(--text-muted)}.draft-saved-hint{font-size:.75rem;color:var(--text-muted);padding:0 12px 4px}.composer-quote-stack{display:flex;flex-direction:column;gap:6px;padding:0 8px 6px}.composer-quote{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);border-left:3px solid var(--accent-primary);background:var(--bg-elevated);font-size:.88rem}.composer-quote--forward{border-left-color:var(--text-muted)}.composer-quote-label{font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--accent-primary);flex-shrink:0}.composer-quote-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.composer-quote-close{border:none;background:transparent;color:var(--text-muted);font-size:1.2rem;line-height:1;cursor:pointer;padding:0 4px}.composer-send--ready{opacity:1}.composer-send--dim{opacity:.45}.mic-record-menu{position:relative}.mic-record-menu-popover{position:absolute;bottom:calc(100% + 6px);right:0;min-width:160px;padding:4px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-elevated);box-shadow:var(--shadow-lg);z-index:20}.mic-record-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--text-primary);font:inherit;border-radius:var(--radius-sm);cursor:pointer;text-align:left}.mic-record-menu-item:hover{background:var(--bg-tertiary)}.msg-retry-btn{margin-top:6px;padding:4px 10px;font-size:.8rem;border-radius:var(--radius-sm);border:1px solid var(--danger);background:transparent;color:var(--danger);cursor:pointer}.msg-link-preview--loading{display:block;min-height:56px;margin-top:6px;border-radius:var(--radius-sm)}.video-call-overlay--incoming{z-index:10000}.video-call-overlay--incoming .video-call-modal{max-width:none;width:100%;height:100%;max-height:none;border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:max(24px,env(safe-area-inset-top)) 24px max(32px,env(safe-area-inset-bottom))}.video-call-overlay--incoming .video-call-modal-actions{flex-direction:row;gap:16px;width:100%;max-width:320px}.video-call-overlay--incoming .video-call-modal-actions .btn{flex:1;padding:14px 20px;font-size:1rem}.video-call-overlay--incoming .audio-call-avatar--lg{width:120px;height:120px;font-size:2.5rem}.onboarding-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:12000;background:#0000008c;display:grid;place-items:center;padding:24px}.onboarding-card{width:min(400px,100%);padding:24px;border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border-primary);box-shadow:var(--shadow-xl)}.onboarding-card h2{margin:8px 0}.onboarding-body{line-height:1.5;color:var(--text-secondary)}.onboarding-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.pwa-install-guide{padding:12px 16px 4px}.pwa-install-title{display:flex;align-items:center;gap:8px;font-weight:600;margin:0 0 8px}.pwa-install-steps{margin:0;padding-left:1.2rem}.pwa-install-hint{padding:8px 16px}.m-call-section-label{padding:8px 16px 4px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.m-call-filters{display:flex;gap:6px;padding:0 12px 8px;flex-wrap:wrap}.m-call-filter-chip{padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--border-primary);background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer}.m-call-filter-chip.active{border-color:var(--accent-primary);background:var(--accent-soft);color:var(--accent-primary)}.m-call-row--tap-recall .m-list-row-main{cursor:pointer}@media(prefers-reduced-motion:reduce){.skeleton,.video-call-overlay,.onboarding-backdrop{animation:none}}
