@import"https://fonts.googleapis.com/css2?family=Google+Sans:wght@400;500;600;700&family=Roboto:wght@300;400;500&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f0fe,#f1f3f4,#e8f0fe);padding:20px}.login-card{background:#fff;border-radius:24px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 4px 24px #0000001f}.login-logo{text-align:center;margin-bottom:32px}.logo-img{width:72px;height:72px;border-radius:16px;object-fit:cover;margin-bottom:16px}.login-logo h1{font-size:28px;font-weight:700;color:#202124;margin-bottom:4px}.login-logo p{color:#5f6368;font-size:15px}.login-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:14px;font-weight:500;color:#5f6368}.remember-me{display:flex;align-items:center;gap:8px;font-size:14px;color:#5f6368;cursor:pointer}.remember-me input[type=checkbox]{accent-color:#1a73e8;width:16px;height:16px}.login-footer{margin-top:24px;text-align:center;font-size:13px;color:#9aa0a6;display:flex;flex-direction:column;gap:4px}.support-link{background:none;border:none;color:var(--primary);font-size:13px;font-weight:500;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.support-link:hover{color:var(--primary-dark, #1557b0)}.sidebar{width:320px;min-width:320px;height:100%;min-height:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;position:relative}@media (max-width: 767px){.sidebar{width:100vw;min-width:0}}.sidebar-header{display:flex;align-items:center;gap:8px;padding:14px 16px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-title{font-size:20px;font-weight:700;color:var(--primary);flex:1}.sidebar-logo{width:40px;height:40px;border-radius:4px;object-fit:contain;flex-shrink:0}.offline-dot{width:8px;height:8px;border-radius:50%;background:#e53935;flex-shrink:0}.sidebar-newchat-bar{padding:10px 12px 6px;flex-shrink:0}.newchat-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 16px;border-radius:20px;background:var(--primary-light);color:var(--primary);font-size:14px;font-weight:600;border:1.5px solid var(--primary);cursor:pointer;transition:background var(--transition),color var(--transition)}.newchat-btn:hover{background:var(--primary);color:#fff}.newchat-btn:hover svg{stroke:#fff}.newchat-fab{position:absolute;bottom:80px;right:16px;width:52px;height:52px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000040;z-index:10;cursor:pointer;transition:background var(--transition),transform 80ms ease;border:none;pointer-events:auto}.newchat-fab:hover{transform:scale(1.05)}.newchat-fab:active{transform:scale(.97)}.groups-list{flex:1;overflow-y:auto;padding:4px 0}.group-section{margin-bottom:8px}.section-label{padding:8px 16px 4px;font-size:11px;font-weight:600;color:var(--text-tertiary);letter-spacing:.8px}.group-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background var(--transition)}.group-item:hover{background:var(--background)}.group-item.active{background:var(--primary-light)}.group-item.active .group-name{color:var(--primary);font-weight:600}.group-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.group-info{display:flex;flex-direction:column;gap:2px;min-width:0}.group-name{font-size:15px;font-weight:500;color:var(--text-primary)}.group-time{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.group-last-msg{font-size:13px;color:var(--text-secondary)}.sidebar-footer{border-top:1px solid var(--border);padding:12px 8px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));position:relative;flex-shrink:0}.user-footer-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px;border-radius:var(--radius);transition:background var(--transition);color:var(--text-primary)}.user-footer-btn:hover{background:var(--background)}.footer-menu{position:absolute;bottom:68px;left:8px;right:8px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:8px;z-index:100;animation:slideUp .15s ease}.footer-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:var(--radius);font-size:14px;color:var(--text-primary);transition:background var(--transition)}.footer-menu-item:hover{background:var(--background)}.footer-menu-item.danger{color:var(--error)}.footer-menu-item.danger:hover{background:#fce8e6}.group-item.has-unread{background:var(--surface-variant)}.unread-name{font-weight:700;color:var(--text-primary)!important}.badge-unread{background:#e53935;color:#fff;font-size:11px;font-weight:600;min-width:18px;height:18px;border-radius:9px;padding:0 5px;display:flex;align-items:center;justify-content:center}.dm-real-name{font-size:11px;font-weight:400;color:var(--text-tertiary)}.group-icon-wrap{position:relative;flex-shrink:0;display:inline-flex}.online-dot{position:absolute;bottom:1px;right:1px;width:11px;height:11px;background:#34a853;border-radius:50%;border:2px solid var(--surface);pointer-events:none}.dm-context-menu{position:fixed;z-index:9999;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:4px 0;min-width:180px}.dm-context-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;font-size:13px;color:var(--text-primary);background:none;border:none;cursor:pointer;text-align:left;transition:background var(--transition)}.dm-context-menu button:hover{background:var(--surface-variant)}.date-separator{display:flex;align-items:center;justify-content:center;margin:12px 0 8px}.date-separator span{background:#0000000f;padding:4px 12px;border-radius:12px;font-size:12px;color:var(--text-secondary);font-weight:500}.system-message{text-align:center;font-size:12px;color:var(--text-tertiary);font-style:italic;margin:6px 0;padding:0 24px}[data-theme=dark] .system-message{color:var(--text-secondary)}.msg-link{color:var(--primary);text-decoration:underline;word-break:break-all}.msg-link:hover{opacity:.8}.msg-bubble.out .msg-link{color:#fff;text-decoration:underline;opacity:.9}.msg-bubble.out .msg-link:hover{opacity:1}.msg-bubble.in .msg-link{color:var(--primary-dark, #1565c0);text-decoration:underline}.message-wrapper{display:flex;align-items:flex-start;gap:8px;padding:1px 0;position:relative}.message-wrapper.own{flex-direction:row-reverse}.message-wrapper.grouped{margin-top:2px}.message-wrapper:not(.grouped){margin-top:10px}.avatar-spacer{width:32px;flex-shrink:0}.msg-avatar{flex-shrink:0}.message-body{display:flex;flex-direction:column;max-width:65%;min-width:0}.own .message-body{align-items:flex-end}.msg-name{font-size:calc(.75rem * var(--font-scale));font-weight:600;color:var(--text-secondary);margin-bottom:3px;padding:0 12px}.reply-preview{display:flex;gap:8px;background:#0000000d;border-radius:8px 8px 0 0;padding:6px 10px;margin-bottom:-4px;max-width:280px}.reply-bar{width:3px;background:var(--primary);border-radius:2px;flex-shrink:0}.reply-name{font-size:calc(.6875rem * var(--font-scale));font-weight:600;color:var(--primary)}.reply-text{font-size:calc(.75rem * var(--font-scale));color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}.msg-bubble-wrap{position:relative;display:flex;align-items:flex-start;gap:6px}.own .msg-bubble-wrap{position:relative;flex-direction:row-reverse}.msg-bubble-with-actions{position:relative;display:flex;flex-direction:column}.msg-actions{display:flex;align-items:center;gap:2px;background:#fff;border-radius:20px;padding:4px 6px;box-shadow:var(--shadow-md);position:absolute;top:-36px;z-index:20;white-space:nowrap}.msg-actions.actions-left{right:0}.msg-actions.actions-right{left:0}.quick-emoji{font-size:16px;padding:4px;border-radius:50%;transition:var(--transition);cursor:pointer;line-height:1}.quick-emoji:hover{background:var(--background);transform:scale(1.2)}.action-btn{width:28px;height:28px;color:var(--text-secondary)}.action-btn:hover{color:var(--text-primary)}.action-btn.danger:hover{color:var(--error)}.emoji-picker-wrap{position:absolute;top:-360px;z-index:100}.emoji-picker-wrap.picker-right{left:0}.emoji-picker-wrap.picker-left{right:0}.emoji-picker-wrap.picker-down{top:36px}.msg-bubble{padding:8px 12px;border-radius:18px;max-width:100%;word-break:break-word;position:relative}@media (max-width: 767px){.msg-bubble{user-select:none;-webkit-user-select:none}}.msg-bubble.out{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.msg-bubble.in{background:var(--bubble-in);color:var(--text-primary);border-bottom-left-radius:4px;box-shadow:var(--shadow-sm)}.msg-bubble.deleted{background:transparent!important;border:1px dashed var(--border)}.deleted-text{font-size:calc(.8125rem * var(--font-scale));color:var(--text-tertiary);font-style:italic}.msg-text{font-size:calc(.875rem * var(--font-scale));line-height:1.5;white-space:pre-wrap}.mention{color:#1a5ca8;font-weight:600;background:#1a5ca81a;border-radius:3px;padding:0 2px}.out .mention{color:#fff;background:#ffffff38}.msg-image{max-width:240px;max-height:240px;border-radius:12px;display:block;cursor:pointer;object-fit:cover}.msg-time{font-size:calc(.6875rem * var(--font-scale));color:var(--text-tertiary);white-space:nowrap;flex-shrink:0;padding-bottom:4px}.reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;padding:0 4px}.reaction-btn{display:flex;align-items:center;gap:3px;padding:3px 8px;border-radius:12px;background:var(--surface);border:1px solid var(--border);font-size:calc(.875rem * var(--font-scale));cursor:pointer;transition:var(--transition)}.reaction-count{font-size:calc(.75rem * var(--font-scale));color:var(--text-secondary)}.reaction-btn.active{background:var(--primary-light);border-color:var(--primary)}.reaction-btn.active .reaction-count{color:var(--primary)}.reaction-btn:hover{background:var(--primary-light)}.reaction-remove{font-size:13px;color:var(--primary);font-weight:700;margin-left:1px;line-height:1;opacity:0;transition:opacity .15s}.reaction-btn:hover .reaction-remove{opacity:1}.link-preview{display:flex;gap:10px;background:#0000000f;border-radius:10px;padding:10px;margin-top:6px;text-decoration:none;max-width:280px;overflow:hidden;transition:var(--transition)}.link-preview:hover{background:#0000001a}.link-preview-img{width:60px;height:60px;border-radius:6px;object-fit:cover;flex-shrink:0}.link-preview-content{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.link-site{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.link-title{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.link-desc{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.out .link-preview{background:#ffffff26}.out .link-title{color:#fff}.out .link-desc{color:#fffc}.msg-bubble.emoji-only{background:transparent!important;border:none!important;box-shadow:none!important;padding:2px 4px}.msg-bubble.emoji-only:after{display:none}.msg-text.emoji-msg{font-size:3em;line-height:1.1;margin:0;-webkit-user-select:text;user-select:text}.message-input-area{background:#fff;border-top:1px solid var(--border);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:8px;flex-shrink:0;position:relative;z-index:2;align-items:stretch}.message-input-area>*{max-width:1024px;width:100%;align-self:center;box-sizing:border-box}.reply-bar-input{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--primary-light);border-radius:var(--radius);border-left:3px solid var(--primary)}.reply-indicator{display:flex;align-items:center;gap:6px;flex:1;overflow:hidden;font-size:13px;color:var(--primary)}.reply-preview-text{color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.img-preview-bar{display:flex;align-items:center;gap:12px;padding:8px;background:var(--background);border-radius:var(--radius)}.img-preview{width:56px;height:56px;object-fit:cover;border-radius:var(--radius)}.link-preview-bar{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--background);border-radius:var(--radius);border:1px solid var(--border)}.link-prev-img{width:40px;height:40px;object-fit:cover;border-radius:4px;flex-shrink:0}.mention-dropdown{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;max-height:200px;overflow-y:auto}.mention-item{display:flex;align-items:center;gap:10px;padding:10px 14px;width:100%;font-size:14px;transition:var(--transition);cursor:pointer}.mention-item:hover,.mention-item.active{background:var(--primary-light)}.mention-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mention-role{margin-left:auto;font-size:11px;color:var(--text-tertiary);text-transform:capitalize}.input-row{display:flex;align-items:flex-end;gap:8px}.input-action{color:var(--text-secondary);flex-shrink:0;margin-bottom:2px}.input-action:hover{color:var(--primary)}.input-wrap{flex:1;min-width:0}.msg-input{width:100%;min-height:40px;max-height:calc(7em + 20px);padding:10px 14px;border:1px solid var(--border);border-radius:20px;font-size:calc(.875rem * var(--font-scale));line-height:1.4;font-family:var(--font);color:var(--text-primary);background:var(--surface-variant);transition:border-color var(--transition);overflow-y:hidden;resize:none}.msg-input:focus{outline:none;border-color:var(--primary);background:var(--surface-variant)}.msg-input::placeholder{color:var(--text-tertiary)}.send-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-tertiary);transition:var(--transition);background:var(--background)}.send-btn.active{background:var(--primary);color:#fff}.send-btn.active:hover{background:var(--primary-dark)}.send-btn:disabled{opacity:.4;cursor:default}.attach-wrap{position:relative;flex-shrink:0}.attach-btn{color:var(--primary)}.attach-btn:hover{color:var(--primary-dark)}.attach-menu{position:absolute;bottom:calc(100% + 8px);left:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:100;min-width:140px}.attach-item{display:flex;align-items:center;gap:10px;padding:11px 16px;width:100%;font-size:14px;color:var(--text-primary);transition:var(--transition);white-space:nowrap}.attach-item:hover{background:var(--primary-light);color:var(--primary)}.attach-item svg{flex-shrink:0;color:var(--text-secondary)}.attach-item:hover svg{color:var(--primary)}.emoji-input-picker{position:absolute;bottom:calc(100% + 4px);left:0;z-index:200}@media (pointer: fine) and (hover: hover){.input-row{min-width:480px}}.chat-window{flex:1;display:flex;flex-direction:column;background:var(--surface-variant);overflow:hidden;min-width:0;min-height:0;height:100%}.chat-window.empty{align-items:center;justify-content:center}.empty-state{text-align:center;color:var(--text-secondary)}.empty-icon{margin-bottom:16px;opacity:.3}.empty-state h3{font-size:18px;margin-bottom:8px;color:var(--text-primary)}.empty-state p{font-size:14px}.chat-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid var(--border);min-height:64px;position:relative;z-index:10}.group-icon-sm{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.chat-header-name{font-size:16px;font-weight:600;color:var(--text-primary)}.chat-header-sub{font-size:12px;color:var(--text-secondary)}.chat-header-real-name{font-size:12px;font-weight:400;color:var(--text-tertiary)}.readonly-badge{font-size:11px;padding:2px 8px;border-radius:10px;background:#fff3e0;color:#e65100;font-weight:500}.messages-container{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px;display:flex;flex-direction:column;gap:2px;scroll-padding-bottom:0;overscroll-behavior:contain;align-items:stretch}.messages-container>*{max-width:1024px;width:100%;align-self:center;box-sizing:border-box}.load-more-btn{align-self:center;font-size:13px;color:var(--primary);padding:8px 16px;border-radius:20px;background:var(--primary-light);margin-bottom:8px;transition:var(--transition)}.load-more-btn:hover{background:#d2e3fc}.typing-indicator{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--text-secondary)}.dots{display:flex;gap:3px}.dots span{width:5px;height:5px;border-radius:50%;background:var(--text-tertiary);animation:bounce 1.2s infinite}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.readonly-bar{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:#fff;border-top:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.nav-drawer-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1200;opacity:0;transition:opacity .25s}.nav-drawer-backdrop.open{display:block;opacity:1}.nav-drawer{position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--surface);border-right:1px solid var(--border);z-index:1300;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:20px 12px;overflow-y:auto;box-shadow:4px 0 24px #0000001f}.nav-drawer.open{transform:translate(0)}.nav-drawer-section-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-tertiary);padding:4px 12px 8px;margin-top:8px}.nav-drawer-section-label:first-child{margin-top:0}.nav-drawer-section-label.admin{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.nav-drawer-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:8px;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;text-align:left;transition:background var(--transition)}.nav-drawer-item:hover:not(.disabled){background:var(--background)}.nav-drawer-item.disabled{opacity:.45;cursor:default}.nav-drawer-badge{margin-left:auto;font-size:10px;font-weight:600;background:var(--surface-variant);color:var(--text-tertiary);border-radius:20px;padding:2px 7px}.nav-drawer-item.active{background:var(--primary-light);color:var(--primary)}.nav-drawer-item.active:hover{background:var(--primary-light)}.chat-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;background:var(--background)}.global-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;height:72px;min-height:72px;background:var(--surface);border-bottom:1px solid var(--border);z-index:20;flex-shrink:0}.global-bar-brand{display:flex;align-items:center;gap:10px}.global-bar-logo{width:40px;height:40px;object-fit:contain;border-radius:6px;flex-shrink:0}.global-bar-title{font-size:22px;font-weight:700;color:var(--primary)}.global-bar-offline{display:flex;align-items:center;gap:6px;color:#e53935;font-size:13px;font-weight:500}.offline-label{font-size:13px}.chat-body{display:flex;flex:1;min-height:0;overflow:hidden}@media (max-width: 767px){.chat-layout{position:relative}.chat-body{overflow:hidden;min-height:0}.global-bar{height:56px;min-height:56px}}[data-theme=dark] .global-bar{background:var(--surface);border-color:var(--border)}.no-chat-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:14px;gap:4px;-webkit-user-select:none;user-select:none}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1a73e8;--primary-dark: #1557b0;--primary-light: #e8f0fe;--surface: #ffffff;--warning-stroke: #92400e;--surface-variant: #f8f9fa;--background: #f1f3f4;--border: #e0e0e0;--text-primary: #202124;--text-secondary: #5f6368;--text-tertiary: #9aa0a6;--error: #d93025;--success: #188038;--warning: #e37400;--bubble-out: #1a73e8;--bubble-in: #f1f3f4;--radius: 8px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0,0,0,.12);--shadow-md: 0 2px 8px rgba(0,0,0,.15);--shadow-lg: 0 4px 20px rgba(0,0,0,.18);--transition: .15s cubic-bezier(.4, 0, .2, 1);--font: "Google Sans", "Roboto", sans-serif;--font-scale: 1}html,body,#root{height:100%;min-width:320px;font-family:var(--font);color:var(--text-primary);background:var(--background)}html{overscroll-behavior-y:none;font-size:100%}button{font-family:var(--font);cursor:pointer;border:none;background:none}input,textarea{font-family:var(--font)}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.flex-1{flex:1;min-width:0}.shrink-0{flex-shrink:0}.text-sm{font-size:13px}.text-xs{font-size:11px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.opacity-60{opacity:.6}.pointer{cursor:pointer}.rounded{border-radius:var(--radius)}.rounded-full{border-radius:9999px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:20px;font-size:14px;font-weight:500;transition:var(--transition);white-space:nowrap}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm)}.btn-secondary{background:transparent;color:var(--primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--primary-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--background);color:var(--text-primary)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{padding:6px 14px;font-size:13px}.btn-icon{padding:8px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--background)}.btn:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;background:#fff;transition:border-color var(--transition);color:var(--text-primary)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1a73e826}.input::placeholder{color:var(--text-tertiary)}.card{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .15s ease}.modal{background:#fff;border-radius:var(--radius-xl);padding:24px;width:100%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp .2s cubic-bezier(.4,0,.2,1);max-height:90vh;overflow-y:auto}.modal-title{font-size:20px;font-weight:600;margin-bottom:20px}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;overflow:hidden;background:var(--primary);color:#fff;-webkit-user-select:none;user-select:none}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:12px}.avatar-md{width:40px;height:40px;font-size:15px}.avatar-lg{width:48px;height:48px;font-size:18px}.avatar-xl{width:72px;height:72px;font-size:24px}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:11px;font-weight:600;background:var(--primary);color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius);background:#323232;color:#fff;font-size:14px;box-shadow:var(--shadow-md);animation:slideIn .2s ease;max-width:320px}.toast.error{background:var(--error)}.toast.success{background:var(--success)}.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:16px;font-size:12px;font-weight:500;background:var(--primary-light);color:var(--primary)}.chip-remove{cursor:pointer;opacity:.7;font-size:14px}.chip-remove:hover{opacity:1}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.warning-banner{background:#fff3e0;border:1px solid #ff9800;border-radius:var(--radius);padding:12px 16px;font-size:13px;color:#e65100;display:flex;gap:8px;align-items:flex-start}.role-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase}.role-admin{background:#fce8e6;color:#c5221f}.role-member{background:var(--primary-light);color:var(--primary)}.status-suspended{background:#fff3e0;color:#e65100}.settings-section-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:12px}[data-theme=dark]{--primary: #6ab0f5;--primary-dark: #4d9de0;--primary-light: #1a2d4a;--surface: #1e1e2e;--warning-stroke: #fde68a;--surface-variant: #252535;--background: #13131f;--border: #2e2e45;--text-primary: #e2e2f0;--text-secondary: #9898b8;--text-tertiary: #606080;--bubble-out: #4d8fd4;--bubble-in: #252535}[data-theme=dark] body,[data-theme=dark] html,[data-theme=dark] #root{background:var(--background)}[data-theme=dark] .modal,[data-theme=dark] .footer-menu,[data-theme=dark] .sidebar{background:var(--surface)}[data-theme=dark] .chat-window{background:var(--background)}[data-theme=dark] .chat-header{background:var(--surface);border-color:var(--border)}[data-theme=dark] .messages-container{background:var(--background)}[data-theme=dark] .input{background:var(--surface-variant);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .card,[data-theme=dark] .message-input-area{background:var(--surface);border-color:var(--border)}[data-theme=dark] .message-input-wrap{background:var(--surface-variant);border-color:var(--border)}[data-theme=dark] .msg-input:focus{background:var(--surface-variant);color:var(--text-primary)}[data-theme=light] .msg-input:focus,:root:not([data-theme=dark]) .msg-input:focus{background:#fff}[data-theme=dark] .btn-secondary{border-color:var(--border);color:var(--primary)}[data-theme=dark] .btn-secondary:hover{background:var(--primary-light)}[data-theme=dark] .search-input{background:var(--surface-variant);color:var(--text-primary)}[data-theme=dark] .group-item:hover{background:var(--surface-variant)}[data-theme=dark] .group-item.active{background:var(--primary-light)}[data-theme=dark] .user-footer-btn:hover,[data-theme=dark] .footer-menu-item:hover{background:var(--surface-variant)}[data-theme=dark] .footer-menu-item.danger:hover{background:#3a1a1a}[data-theme=dark] .btn-icon{color:var(--text-primary)}[data-theme=dark] .btn-icon:hover{background:var(--surface-variant)}[data-theme=dark] .sidebar-header{background:var(--surface);border-color:var(--border)}[data-theme=dark] .newchat-btn{background:var(--surface-variant);border-color:var(--primary);color:var(--primary)}[data-theme=dark] .newchat-btn:hover{background:var(--primary);color:#fff}[data-theme=dark] .newchat-fab{background:var(--primary)}[data-theme=dark] .msg-actions{background:var(--surface);border-color:var(--border)}[data-theme=dark] .reaction-btn:hover{background:var(--surface-variant)}[data-theme=dark] .emoji-picker-wrap{background:var(--surface);border-color:var(--border)}[data-theme=dark] .reply-preview{background:var(--surface-variant);border-color:var(--primary)}[data-theme=dark] .load-more-btn{background:var(--surface-variant);color:var(--text-secondary)}[data-theme=dark] .readonly-bar{background:var(--surface);border-color:var(--border);color:var(--text-secondary)}[data-theme=dark] .warning-banner{background:#2a1f00;border-color:#6a4a00;color:#ffb74d}.about-modal{max-width:420px;text-align:center;position:relative;padding:32px 28px 24px}.about-close{position:absolute;top:12px;right:12px}.about-hero{display:flex;flex-direction:column;align-items:center;margin-bottom:28px}.about-logo{width:80px;height:80px;object-fit:contain;margin-bottom:12px}.about-appname{font-size:26px;font-weight:800;color:var(--primary);margin:0 0 4px}.about-tagline{font-size:13px;color:var(--text-tertiary);font-style:italic;margin:0}.about-table{width:100%;border:1px solid var(--border);border-radius:var(--radius);overflow:visible;margin-bottom:20px;text-align:left}.about-row{display:flex;align-items:flex-start;padding:10px 14px;border-bottom:1px solid var(--border);gap:12px}.about-row:last-child{border-bottom:none}.about-label{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;min-width:90px;flex-shrink:0;padding-top:1px}.about-value{font-size:14px;color:var(--text-primary);flex:1;min-width:0;overflow-wrap:break-word;word-break:normal;white-space:normal;line-height:1.5}.about-mono{font-family:monospace;font-size:13px}.about-link{color:var(--primary);text-decoration:underline}.about-link:hover{opacity:.8}.about-footer{font-size:12px;color:var(--text-tertiary);margin:0}[data-theme=dark] .about-table,[data-theme=dark] .about-row{border-color:var(--border)}[data-theme=dark] .attach-menu{background:var(--surface);border-color:var(--border)}[data-theme=dark] .attach-item{color:var(--text-primary)}[data-theme=dark] .attach-item:hover{background:var(--primary-light);color:var(--primary)}[data-theme=dark] .attach-item svg{color:var(--text-secondary)}[data-theme=dark] .mention-dropdown{background:var(--surface);border-color:var(--border)}[data-theme=dark] .mention-item{color:var(--text-primary)}[data-theme=dark] .mention-item:hover,[data-theme=dark] .mention-item.active{background:var(--primary-light);color:var(--primary)}[data-theme=dark] .mention-role{color:var(--text-tertiary)}[data-theme=dark] .mention-avatar{background:var(--primary)}[data-theme=dark] .in .mention{color:#6ab0f5;background:#6ab0f526}[data-theme=dark] .out .mention{color:#fff;background:#ffffff40}[data-theme=dark] .reaction-btn{background:var(--surface-variant);border-color:var(--border)}[data-theme=dark] .reaction-btn:hover{background:var(--primary-light)}.help-modal{width:min(720px,94vw);max-height:85vh;display:flex;flex-direction:column}.help-content{flex:1;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;background:var(--surface-variant);margin-bottom:16px}.help-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:12px}.help-markdown h1{font-size:1.5rem;font-weight:700;margin:0 0 16px;color:var(--text-primary)}.help-markdown h2{font-size:1.15rem;font-weight:700;margin:24px 0 10px;color:var(--text-primary);border-bottom:1px solid var(--border);padding-bottom:4px}.help-markdown h3{font-size:1rem;font-weight:600;margin:16px 0 6px;color:var(--text-primary)}.help-markdown p{margin:0 0 12px;line-height:1.65;color:var(--text-secondary);font-size:14px}.help-markdown ul,.help-markdown ol{margin:0 0 12px 20px;color:var(--text-secondary);font-size:14px}.help-markdown li{margin-bottom:4px;line-height:1.6}.help-markdown strong{font-weight:600;color:var(--text-primary)}.help-markdown em{font-style:italic}.help-markdown code{font-family:monospace;font-size:13px;background:var(--background);padding:1px 5px;border-radius:4px;color:var(--primary)}.help-markdown pre{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;overflow-x:auto;margin:0 0 12px}.help-markdown pre code{background:none;padding:0;color:var(--text-primary)}.help-markdown blockquote{border-left:3px solid var(--primary);margin:0 0 12px;padding:6px 14px;background:var(--primary-light);border-radius:0 var(--radius) var(--radius) 0}.help-markdown blockquote p{margin:0;color:var(--text-secondary)}.help-markdown hr{border:none;border-top:1px solid var(--border);margin:20px 0}.help-markdown a{color:var(--primary);text-decoration:underline}[data-theme=dark] .help-markdown code,[data-theme=dark] .help-markdown pre{background:var(--surface)}[data-theme=dark] .help-markdown blockquote{background:#6366f11a}.mention-avatar-wrap{position:relative;display:inline-flex;flex-shrink:0}.mention-online-dot{position:absolute;bottom:0;right:0;width:9px;height:9px;background:#34a853;border-radius:50%;border:2px solid var(--surface);pointer-events:none}
