*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif;background:#fff;color:#1a1a1a;height:100vh;height:100svh;overflow:hidden}#root{height:100vh;height:100svh;display:flex;flex-direction:column}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea{font-family:inherit;outline:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ddd;border-radius:4px}.login-wrap{height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.login-box{background:#fff;border-radius:12px;padding:40px 36px;width:360px;box-shadow:0 2px 20px #00000014}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{font-size:22px;font-weight:700;color:#2563eb}.login-logo p{font-size:13px;color:#888;margin-top:4px}.login-box label{display:block;font-size:13px;color:#555;margin-bottom:6px;font-weight:500}.login-box input{width:100%;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;margin-bottom:16px;transition:border-color .2s}.login-box input:focus{border-color:#2563eb}.login-reset-btn{width:100%;margin-top:10px;padding:9px 12px;border-radius:8px;background:#f8fafc;color:#64748b;border:1px solid #e2e8f0;font-size:13px}.login-reset-btn:hover{background:#f1f5f9;color:#334155}.login-reset-btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{width:100%;padding:11px;background:#2563eb;color:#fff;border-radius:8px;font-size:15px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.messenger-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;min-width:280px;border-right:1px solid #e8e8e8;display:flex;flex-direction:column;background:#fff}.sidebar-header{padding:14px 16px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.sidebar-header h2{font-size:18px;font-weight:700}.sidebar-header-actions{display:flex;gap:8px}.icon-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#555;font-size:16px;transition:background .15s}.icon-btn:hover{background:#f0f0f0}.my-profile{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #eee;cursor:pointer;transition:background .15s}.my-profile:hover{background:#f9f9f9}.avatar{width:40px;height:40px;border-radius:50%;background:#e0e7ff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#2563eb;overflow:hidden;flex-shrink:0;position:relative}.avatar img{width:100%;height:100%;object-fit:cover}.status-dot{width:10px;height:10px;border-radius:50%;border:2px solid #fff;position:absolute;bottom:1px;right:1px}.status-dot.사용중{background:#22c55e}.status-dot.부재중{background:#f59e0b}.status-dot.휴가{background:#a78bfa}.status-dot.촬영{background:#ef4444}.status-dot.출장{background:#3b82f6}.status-dot.회의{background:#f97316}.profile-info{flex:1;min-width:0}.profile-name{font-size:14px;font-weight:600}.profile-status-msg{font-size:12px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-search{padding:10px 12px;border-bottom:1px solid #eee}.sidebar-search input{width:100%;padding:7px 12px;background:#f4f4f4;border:none;border-radius:20px;font-size:13px}.sidebar-tabs{display:flex;border-bottom:1px solid #eee}.sidebar-tab{flex:1;padding:10px;font-size:13px;font-weight:500;color:#888;text-align:center;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.sidebar-tab.active{color:#2563eb;border-bottom-color:#2563eb}.user-list{flex:1;overflow-y:auto}.user-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:background .1s}.user-item:hover{background:#f5f5f5}.user-item.active{background:#eff6ff}.user-item-info{flex:1;min-width:0}.user-item-name{font-size:14px;font-weight:500}.user-item-status{font-size:12px;color:#888}.user-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.unread-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.last-time{font-size:11px;color:#aaa}.chat-area{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#bbb;gap:12px}.chat-empty-icon{font-size:48px}.chat-header{padding:12px 16px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:10px;background:#fff}.chat-header-info{flex:1;min-width:0}.chat-header-name{font-size:15px;font-weight:600}.chat-header-sub{font-size:12px;color:#888}.chat-header-actions{display:flex;gap:6px}.mobile-back-btn{display:none;width:34px;height:34px;border-radius:50%;align-items:center;justify-content:center;color:#334155;font-size:30px;line-height:1;flex-shrink:0}.mobile-back-btn:hover{background:#f1f5f9}.chat-search-bar{padding:8px 12px;background:#f8f8f8;border-bottom:1px solid #eee;display:flex;align-items:center;gap:8px}.chat-search-bar input{flex:1;padding:6px 10px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;background:#fff}.chat-search-bar button{padding:5px 10px;border-radius:6px;font-size:13px;color:#555;background:#eee}.chat-search-bar button:hover{background:#ddd}.search-count{font-size:12px;color:#888;white-space:nowrap}.date-bar{padding:6px 12px;background:#f0f4ff;border-bottom:1px solid #dbe7ff;display:flex;align-items:center;gap:8px;font-size:13px;color:#555}.date-bar input[type=date]{padding:4px 8px;border:1px solid #c7d8ff;border-radius:6px;font-size:13px;background:#fff}.messages-list{flex:1;overflow-y:auto;padding:16px 12px;display:flex;flex-direction:column;gap:2px}.date-divider{text-align:center;margin:12px 0;position:relative}.date-divider span{background:#fff;padding:0 10px;font-size:12px;color:#aaa;position:relative;z-index:1}.date-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#eee}.msg-wrap{display:flex;flex-direction:column;margin-bottom:4px}.msg-wrap.mine{align-items:flex-end}.msg-wrap.others{align-items:flex-start}.msg-sender-name{font-size:12px;color:#888;margin-bottom:2px;padding-left:44px}.msg-row{display:flex;align-items:flex-end;gap:6px;max-width:70%}.msg-wrap.mine .msg-row{flex-direction:row-reverse}.msg-bubble{padding:8px 12px;border-radius:16px;font-size:14px;line-height:1.5;word-break:break-word;position:relative}.msg-wrap.mine .msg-bubble{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.msg-wrap.others .msg-bubble{background:#f0f0f0;color:#1a1a1a;border-bottom-left-radius:4px}.msg-bubble.highlighted{outline:2px solid #f59e0b;outline-offset:2px}.msg-bubble.deleted{color:#aaa;font-style:italic;background:#f9f9f9}.reply-preview{background:#00000012;border-left:3px solid rgba(0,0,0,.2);border-radius:6px;padding:4px 8px;margin-bottom:4px;font-size:12px;opacity:.85}.msg-wrap.mine .reply-preview{border-left-color:#ffffff80}.msg-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding-bottom:2px}.msg-time{font-size:11px;color:#aaa;white-space:nowrap}.msg-read{font-size:11px;color:#60a5fa}.context-menu{position:fixed;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px #0000001f;padding:4px 0;z-index:1000;min-width:140px}.context-menu-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;cursor:pointer;transition:background .1s}.context-menu-item:hover{background:#f5f5f5}.context-menu-item.danger{color:#ef4444}.reply-indicator{padding:6px 14px;background:#f0f4ff;border-top:1px solid #dbe7ff;display:flex;align-items:center;gap:8px;font-size:13px;color:#555}.reply-indicator-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-indicator button{color:#888;font-size:16px}.chat-input-area{border-top:1px solid #eee;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.chat-input-row{display:flex;align-items:flex-end;gap:8px}.chat-input{flex:1;padding:10px 14px;border:1px solid #e0e0e0;border-radius:20px;font-size:14px;resize:none;max-height:120px;line-height:1.5;transition:border-color .2s}.chat-input:focus{border-color:#2563eb}.send-btn{width:38px;height:38px;background:#2563eb;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:background .2s}.send-btn:hover{background:#1d4ed8}.send-btn:disabled{background:#93c5fd}.attach-btn{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:#888;flex-shrink:0;transition:background .15s}.attach-btn:hover{background:#f0f0f0}.urgent-btn{width:38px;height:38px;border-radius:50%;background:#fee2e2;color:#dc2626;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0;transition:background .15s}.urgent-btn:hover{background:#fecaca}.urgent-btn:disabled{opacity:.45;cursor:not-allowed}.file-preview{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f4f4f4;border-radius:8px;font-size:13px}.file-preview-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#444}.file-preview button{color:#888;font-size:16px}.file-msg{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#0000000f;border-radius:8px;cursor:pointer;text-decoration:none;color:inherit}.msg-wrap.mine .file-msg{background:#ffffff26;color:#fff}.file-msg-name{font-size:13px;font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-msg-size{font-size:11px;opacity:.7}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:500}.modal{background:#fff;border-radius:16px;padding:28px;width:320px;box-shadow:0 8px 40px #00000026}.modal h3{font-size:16px;font-weight:700;margin-bottom:18px}.modal input,.modal select,.modal textarea{width:100%;padding:9px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;margin-bottom:12px}.modal-avatar-upload{display:flex;flex-direction:column;align-items:center;margin-bottom:16px;cursor:pointer}.modal-avatar-upload .avatar{width:72px;height:72px;font-size:28px}.modal-avatar-upload p{font-size:12px;color:#888;margin-top:6px}.modal-btns{display:flex;gap:8px;margin-top:4px}.btn-cancel{flex:1;padding:9px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;color:#555;transition:background .15s}.btn-cancel:hover{background:#f5f5f5}.btn-save{flex:1;padding:9px;background:#2563eb;color:#fff;border-radius:8px;font-size:14px;font-weight:600;transition:background .2s}.btn-save:hover{background:#1d4ed8}.notif-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.admin-panel{width:420px;border-left:1px solid #eee;background:#fff;display:flex;flex-direction:column}.admin-header{padding:14px 16px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.admin-header h2{font-size:16px;font-weight:700}.admin-content{flex:1;overflow-y:auto;padding:16px}.admin-section-title{font-size:13px;font-weight:600;color:#888;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.admin-user-row{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #f0f0f0;border-radius:10px;margin-bottom:8px}.admin-user-info{flex:1;min-width:0}.admin-user-name{font-size:14px;font-weight:500}.admin-user-phone{font-size:12px;color:#888}.admin-actions{display:flex;gap:6px}.btn-sm{padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;transition:all .15s}.btn-sm.edit{background:#eff6ff;color:#2563eb}.btn-sm.edit:hover{background:#dbeafe}.btn-sm.reset{background:#fff7ed;color:#f97316}.btn-sm.reset:hover{background:#ffedd5}.btn-sm.del{background:#fef2f2;color:#ef4444}.btn-sm.del:hover{background:#fee2e2}.admin-add-form{background:#f9f9f9;border-radius:10px;padding:14px;margin-bottom:16px}.admin-add-form input,.admin-add-form select{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;margin-bottom:8px;background:#fff}.role-badge{font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px}.role-badge.admin{background:#dbeafe;color:#1d4ed8}.role-badge.user{background:#f0f0f0;color:#555}.create-room-modal{max-height:80vh;overflow-y:auto}.member-check-item{display:flex;align-items:center;gap:8px;padding:8px 4px;cursor:pointer}.member-check-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}@media (max-width: 640px){body{width:100%}.messenger-layout{width:100%;height:100svh}.sidebar{width:100%;min-width:0}.messenger-layout.mobile-chat-open .sidebar{display:none}.sidebar-header{padding:12px;gap:8px}.sidebar-header h2{font-size:17px}.sidebar-header-actions{gap:4px;overflow-x:auto}.my-profile{padding:10px 12px}.user-item{padding:11px 12px}.room-last-msg{max-width:42vw}.chat-area{display:none}.chat-area.mobile-open{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;width:100%;height:100svh}.mobile-back-btn{display:flex}.chat-header{padding:8px 8px 8px 6px;gap:6px;min-height:54px}.chat-header-info{min-width:96px}.chat-header-name{font-size:14px}.chat-header-sub{font-size:11px}.chat-header-actions{gap:4px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.chat-header-actions::-webkit-scrollbar,.sidebar-header-actions::-webkit-scrollbar{display:none}.icon-btn{width:34px;height:34px;min-width:34px;font-size:15px}.messages-list{padding:12px 8px}.msg-row{max-width:92%}.msg-bubble{font-size:14px;padding:8px 11px}.chat-input-area{padding:8px;padding-bottom:max(8px,env(safe-area-inset-bottom))}.chat-input-row{gap:6px}.chat-input{min-height:38px;max-height:96px;padding:9px 12px;font-size:16px}.attach-btn,.send-btn,.urgent-btn{width:36px;height:36px;min-width:36px}.chat-search-bar,.date-bar,.caution-banner{padding:8px;flex-wrap:wrap}.chat-search-bar input{min-width:0;font-size:16px}.mention-dropdown{left:8px;right:8px;bottom:64px}.file-panel{top:54px;right:8px;bottom:64px;left:8px;width:auto}.file-panel-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.modal-overlay{align-items:flex-end;padding:10px;padding-bottom:max(10px,env(safe-area-inset-bottom))}.modal{width:100%;max-width:420px;max-height:88svh;overflow-y:auto;border-radius:14px;padding:20px}.global-search-modal{width:100%}.admin-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;width:100%}.admin-user-row{align-items:flex-start;flex-wrap:wrap}.admin-actions{width:100%;justify-content:flex-end}.login-wrap,.pw-change-wrap{padding:16px;height:100svh}.login-box,.pw-change-box{width:100%;max-width:380px;padding:28px 22px}}.mention{color:#2563eb;font-weight:600}.msg-wrap.mine .mention{color:#bfdbfe}.push-notif{position:fixed;top:16px;right:16px;background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:12px 16px;box-shadow:0 4px 20px #0000001f;z-index:9999;max-width:300px;cursor:pointer;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.push-notif-name{font-size:13px;font-weight:600;margin-bottom:3px}.push-notif-msg{font-size:13px;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pw-change-wrap{height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.pw-change-box{background:#fff;border-radius:12px;padding:36px;width:360px;box-shadow:0 2px 20px #00000014}.pw-change-box h2{font-size:18px;font-weight:700;margin-bottom:6px}.pw-change-box p{font-size:13px;color:#888;margin-bottom:24px}.msg-read-status{display:flex;align-items:flex-end;margin-bottom:2px}.msg-read-label{font-size:11px;color:#60a5fa;font-weight:500;white-space:nowrap}.msg-unread-count{font-size:11px;color:#f59e0b;font-weight:700;white-space:nowrap}.mention-dropdown{position:absolute;bottom:70px;left:60px;right:60px;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 4px 20px #0000001f;z-index:200;overflow:hidden}.mention-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;font-size:14px;transition:background .1s}.mention-item:hover{background:#f0f4ff}.chat-image-wrap{position:relative;display:inline-block;cursor:pointer;border-radius:10px;overflow:hidden;max-width:220px}.chat-image-thumb{display:block;max-width:220px;max-height:200px;border-radius:10px;object-fit:cover}.chat-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;display:flex;align-items:center;justify-content:center;font-size:22px;opacity:0;transition:all .2s}.chat-image-wrap:hover .chat-image-overlay{background:#00000059;opacity:1}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;cursor:zoom-out}.lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px #00000080;cursor:default}.lightbox-close{position:absolute;top:20px;right:24px;color:#fff;font-size:28px;background:#ffffff26;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.lightbox-close:hover{background:#ffffff4d}.msg-edit-area{min-width:200px;max-width:420px}.msg-edit-input{width:100%;padding:8px 12px;border:2px solid #2563eb;border-radius:10px;font-size:14px;resize:none;min-height:60px;line-height:1.5;outline:none;background:#fff}.msg-edit-btns{display:flex;gap:6px;margin-top:6px;justify-content:flex-end}.msg-edit-btns button{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:none}.msg-edit-btns button:first-child{background:#2563eb;color:#fff}.msg-edit-btns button:first-child:hover{background:#1d4ed8}.msg-edit-btns button:last-child{background:#f0f0f0;color:#555}.msg-edit-btns button:last-child:hover{background:#e0e0e0}.room-item{position:relative}.room-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.leave-room-btn{display:none;font-size:11px;padding:3px 8px;border-radius:5px;background:#fee2e2;color:#ef4444;font-weight:600;transition:background .15s;white-space:nowrap}.leave-room-btn:hover{background:#fecaca}.room-item:hover .leave-room-btn{display:block}.chat-area{position:relative}.chat-area.shake{animation:chatShake .55s cubic-bezier(.36,.07,.19,.97) both}@keyframes chatShake{0%,to{transform:translate(0)}12%,36%,60%,84%{transform:translate(-7px)}24%,48%,72%{transform:translate(7px)}}.msg-content-area{position:relative}.reaction-picker{position:absolute;top:-38px;display:none;align-items:center;gap:2px;background:#fff;border:1px solid #e8e8e8;border-radius:20px;padding:4px 8px;box-shadow:0 3px 14px #0000001f;z-index:30;white-space:nowrap}.reaction-picker.picker-right{left:0}.reaction-picker.picker-left{right:0}.msg-content-area:hover .reaction-picker{display:flex}.reaction-pick-btn{font-size:18px;padding:2px 3px;border-radius:6px;transition:transform .1s,background .1s;line-height:1}.reaction-pick-btn:hover{transform:scale(1.25);background:#f0f0f0}.reactions-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reactions-row.mine{justify-content:flex-end}.reaction-chip{display:flex;align-items:center;gap:2px;padding:2px 8px;border-radius:12px;border:1px solid #e0e0e0;background:#f5f5f5;font-size:14px;cursor:pointer;transition:all .15s}.reaction-chip:hover{background:#e8e8e8}.reaction-chip.active{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.pinned-banner{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fffbeb;border-bottom:1px solid #fde68a;cursor:pointer;transition:background .15s}.pinned-banner:hover{background:#fef3c7}.pinned-icon{font-size:16px;flex-shrink:0}.pinned-content{flex:1;min-width:0}.pinned-label{font-size:11px;font-weight:600;color:#92400e;margin-bottom:1px}.pinned-text{font-size:13px;color:#78350f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-close{color:#a16207;font-size:16px;flex-shrink:0;padding:2px 6px;border-radius:4px;transition:background .15s}.pinned-close:hover{background:#fde68a}.drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#2563eb14;border:3px dashed #2563eb;border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none}.drag-overlay-inner{background:#fff;border-radius:12px;padding:20px 36px;font-size:16px;font-weight:600;color:#2563eb;box-shadow:0 4px 20px #2563eb26}.forward-preview{background:#f5f5f5;border-left:3px solid #2563eb;padding:8px 12px;border-radius:6px;font-size:13px;color:#555;margin-bottom:14px;max-height:60px;overflow:hidden}.forward-room-item{display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:8px;cursor:pointer;transition:background .1s}.forward-room-item:hover{background:#f0f4ff}.room-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;min-width:44px}.room-last-time{font-size:11px;color:#aaa;white-space:nowrap}.room-last-msg{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-item-actions{display:none;gap:4px}.room-item:hover .room-item-actions{display:flex}.room-item:hover .room-last-time{display:none}.room-mute-btn{font-size:13px;padding:2px 5px;border-radius:5px;background:#f0f0f0;color:#555;transition:background .15s}.room-mute-btn:hover{background:#e0e0e0}.mute-dot{position:absolute;bottom:1px;right:1px;width:9px;height:9px;background:#9ca3af;border-radius:50%;border:1.5px solid #fff}.tab-count{display:inline-flex;align-items:center;justify-content:center;background:#e0e7ff;color:#2563eb;font-size:10px;font-weight:700;border-radius:8px;padding:1px 5px;margin-left:4px}.global-search-modal{width:420px;max-height:80vh;display:flex;flex-direction:column}.global-search-input-wrap{margin-bottom:12px}.global-search-input-wrap input{width:100%;padding:10px 14px;border:2px solid #2563eb;border-radius:10px;font-size:14px}.global-results{flex:1;overflow-y:auto;max-height:380px;border:1px solid #eee;border-radius:8px}.global-result-item{padding:10px 14px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .1s}.global-result-item:hover{background:#f0f4ff}.global-result-item:last-child{border-bottom:none}.global-result-room{font-size:11px;font-weight:600;color:#2563eb;margin-bottom:3px}.global-result-content{font-size:13px;color:#333;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.global-result-sender{font-weight:600}.global-result-time{font-size:11px;color:#aaa}.icon-btn.active-warning{background:#fef3c7;color:#b45309}.caution-banner{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#fffbeb;border-bottom:1px solid #fde68a;color:#92400e;font-size:13px}.caution-banner span{font-weight:700}.caution-banner small{color:#a16207}.poll-wrap{min-width:240px}.poll-question{font-size:14px;font-weight:700;margin-bottom:10px}.poll-options{display:flex;flex-direction:column;gap:6px}.poll-option{position:relative;min-height:34px;border:1px solid rgba(37,99,235,.18);border-radius:8px;overflow:hidden;background:#ffffffb8;color:#1f2937;text-align:left}.poll-option.chosen{border-color:#2563eb}.poll-option-bar{position:absolute;inset:0 auto 0 0;background:#dbeafe;transition:width .2s}.poll-option-text,.poll-option-pct{position:relative;z-index:1;font-size:13px}.poll-option-text{display:inline-block;padding:8px 44px 8px 10px}.poll-option-pct{position:absolute;top:8px;right:10px;font-weight:700;color:#2563eb}.poll-footer{margin-top:8px;font-size:12px;opacity:.72}.poll-edit-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.poll-edit-row{display:flex;gap:6px}.poll-edit-row input{margin-bottom:0}.poll-edit-row button{width:34px;border-radius:8px;background:#f3f4f6;color:#6b7280;flex-shrink:0}.file-panel{position:absolute;top:56px;right:12px;bottom:72px;width:min(360px,calc(100% - 24px));background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 16px 40px #0f172a24;z-index:40;display:flex;flex-direction:column;overflow:hidden}.file-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #eee;font-weight:700}.file-panel-tabs{display:flex;border-bottom:1px solid #eee}.file-panel-tabs button{flex:1;padding:10px 8px;font-size:13px;color:#6b7280}.file-panel-tabs button.active{color:#2563eb;border-bottom:2px solid #2563eb;font-weight:700}.file-panel-body{flex:1;overflow-y:auto;padding:12px}.file-panel-empty{padding:28px 0;text-align:center;color:#9ca3af;font-size:13px}.file-panel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.file-panel-img{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#f3f4f6;cursor:pointer}.file-panel-img img{width:100%;height:100%;object-fit:cover}.file-panel-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000003d;color:#fff;opacity:0;transition:opacity .15s}.file-panel-img:hover .file-panel-img-overlay{opacity:1}.file-panel-list{display:flex;flex-direction:column;gap:8px}.file-panel-item{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #eef2f7;border-radius:8px;color:inherit;text-decoration:none}.file-panel-item:hover{background:#f8fafc}.file-panel-icon{font-size:20px;flex-shrink:0}.file-panel-info{flex:1;min-width:0}.file-panel-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-panel-meta{font-size:11px;color:#9ca3af;margin-top:2px}body.dark{background:#1e1e2e;color:#cdd6f4}body.dark .sidebar{background:#181825;border-color:#313244}body.dark .sidebar-header{border-color:#313244}body.dark .sidebar-header h2{color:#cdd6f4}body.dark .icon-btn{color:#a6adc8}body.dark .icon-btn:hover{background:#313244}body.dark .my-profile{border-color:#313244}body.dark .my-profile:hover{background:#24273a}body.dark .profile-name{color:#cdd6f4}body.dark .profile-status-msg{color:#6c7086}body.dark .sidebar-search input{background:#24273a;border-color:#313244;color:#cdd6f4}body.dark .sidebar-search input::placeholder{color:#6c7086}body.dark .sidebar-tabs{border-color:#313244}body.dark .sidebar-tab{color:#6c7086}body.dark .sidebar-tab.active{color:#2563eb;border-color:#2563eb}body.dark .user-item{border-color:#313244}body.dark .user-item:hover{background:#24273a}body.dark .user-item.active{background:#1e3a5f}body.dark .user-item-name{color:#cdd6f4}body.dark .user-item-status,body.dark .room-last-time{color:#6c7086}body.dark .tab-count{background:#1e3a5f}body.dark .mute-dot{border-color:#181825}body.dark .chat-area{background:#1e1e2e}body.dark .chat-header{background:#181825;border-color:#313244}body.dark .chat-header-name{color:#cdd6f4}body.dark .chat-header-sub{color:#6c7086}body.dark .chat-header-actions .icon-btn{color:#a6adc8}body.dark .pinned-banner{background:#2a2018;border-color:#78350f}body.dark .pinned-banner:hover{background:#312510}body.dark .pinned-label{color:#fcd34d}body.dark .pinned-text{color:#fde68a}body.dark .pinned-close{color:#fcd34d}body.dark .chat-search-bar{background:#24273a;border-color:#313244}body.dark .chat-search-bar input{background:#1e1e2e;border-color:#313244;color:#cdd6f4}body.dark .chat-search-bar button{color:#a6adc8}body.dark .date-bar{background:#24273a;border-color:#313244;color:#cdd6f4}body.dark .date-bar input{background:#1e1e2e;border-color:#313244;color:#cdd6f4}body.dark .date-divider{color:#6c7086}body.dark .date-divider:before,body.dark .date-divider:after{background:#313244}body.dark .msg-sender-name{color:#7c7faf}body.dark .msg-wrap.others .msg-bubble{background:#313244;color:#cdd6f4}body.dark .msg-wrap.mine .msg-bubble{background:#2563eb}body.dark .msg-bubble.deleted{background:#2a2a3e!important;color:#6c7086!important}body.dark .msg-bubble.highlighted{background:#3d3000!important}body.dark .msg-time{color:#6c7086}body.dark .msg-read-label{color:#89b4fa}body.dark .msg-unread-count{color:#f9e2af}body.dark .reply-preview{background:#24273a;border-color:#585b70;color:#a6adc8}body.dark .mention{color:#89b4fa}body.dark .msg-wrap.mine .mention{color:#bfdbfe}body.dark .reaction-picker{background:#24273a;border-color:#45475a;box-shadow:0 3px 14px #0006}body.dark .reaction-pick-btn:hover{background:#313244}body.dark .reaction-chip{background:#313244;border-color:#45475a;color:#cdd6f4}body.dark .reaction-chip:hover{background:#45475a}body.dark .reaction-chip.active{background:#1e3a5f;border-color:#3b82f6;color:#93c5fd}body.dark .reply-indicator{background:#24273a;border-color:#3b5bdb}body.dark .reply-indicator-text{color:#a6adc8}body.dark .file-preview{background:#313244}body.dark .file-preview-name{color:#cdd6f4}body.dark .file-msg{background:#ffffff14}body.dark .msg-wrap.mine .file-msg{background:#ffffff26}body.dark .chat-input-area{background:#1e1e2e;border-color:#313244}body.dark .chat-input{background:#24273a;border-color:#45475a;color:#cdd6f4}body.dark .chat-input::placeholder{color:#6c7086}body.dark .chat-input:focus{border-color:#3b82f6}body.dark .attach-btn{color:#6c7086}body.dark .attach-btn:hover{background:#313244}body.dark .mention-dropdown{background:#24273a;border-color:#45475a}body.dark .mention-item:hover{background:#313244}body.dark .mention-item span{color:#cdd6f4}body.dark .context-menu{background:#24273a;border-color:#45475a;box-shadow:0 4px 20px #0006}body.dark .context-menu-item{color:#cdd6f4}body.dark .context-menu-item:hover{background:#313244}body.dark .context-menu-item.danger{color:#f38ba8}body.dark .modal-overlay{background:#0009}body.dark .modal{background:#24273a;color:#cdd6f4;box-shadow:0 8px 40px #0006}body.dark .modal h3{color:#cdd6f4}body.dark .modal input,body.dark .modal select,body.dark .modal textarea{background:#1e1e2e;border-color:#45475a;color:#cdd6f4}body.dark .modal input::placeholder{color:#6c7086}body.dark .btn-cancel{background:#313244;color:#cdd6f4;border-color:#45475a}body.dark .btn-cancel:hover{background:#45475a}body.dark .member-check-item{color:#cdd6f4}body.dark .member-check-item:hover{background:#313244;border-radius:6px}body.dark .forward-preview{background:#313244;border-color:#3b82f6;color:#a6adc8}body.dark .forward-room-item:hover{background:#313244}body.dark .forward-room-item div{color:#cdd6f4}body.dark .global-results{border-color:#45475a}body.dark .global-result-item{border-color:#313244}body.dark .global-result-item:hover{background:#313244}body.dark .global-result-room{color:#89b4fa}body.dark .global-result-content{color:#cdd6f4}body.dark .global-result-time{color:#6c7086}body.dark .global-search-input-wrap input{background:#1e1e2e;border-color:#3b82f6;color:#cdd6f4}body.dark .icon-btn.active-warning{background:#3a2d12;color:#fcd34d}body.dark .caution-banner{background:#2a2018;border-color:#78350f;color:#fde68a}body.dark .caution-banner small{color:#fcd34d}body.dark .urgent-btn{background:#451a1a;color:#fca5a5}body.dark .urgent-btn:hover{background:#5f1f1f}body.dark .poll-option{background:#24273a;border-color:#45475a;color:#cdd6f4}body.dark .poll-option.chosen{border-color:#3b82f6}body.dark .poll-option-bar{background:#1e3a5f}body.dark .poll-option-pct{color:#93c5fd}body.dark .poll-edit-row button{background:#313244;color:#cdd6f4}body.dark .file-panel{background:#1e1e2e;border-color:#313244;box-shadow:0 16px 40px #00000059}body.dark .file-panel-header,body.dark .file-panel-tabs{border-color:#313244}body.dark .file-panel-tabs button{color:#6c7086}body.dark .file-panel-tabs button.active{color:#89b4fa;border-color:#3b82f6}body.dark .file-panel-img{background:#313244}body.dark .file-panel-item{border-color:#313244}body.dark .file-panel-item:hover{background:#24273a}body.dark .file-panel-meta,body.dark .file-panel-empty{color:#6c7086}body.dark .admin-panel{background:#1e1e2e;border-color:#313244}body.dark .admin-header{border-color:#313244}body.dark .admin-header h2{color:#cdd6f4}body.dark .admin-user-row{background:#24273a;border-color:#313244}body.dark .admin-user-name{color:#cdd6f4}body.dark .admin-user-phone{color:#6c7086}body.dark .admin-add-form{background:#24273a}body.dark .admin-add-form input,body.dark .admin-add-form select{background:#1e1e2e;border-color:#45475a;color:#cdd6f4}body.dark .push-notif{background:#24273a;border-color:#45475a}body.dark .push-notif-name{color:#cdd6f4}body.dark .push-notif-msg{color:#a6adc8}body.dark .lightbox{background:#000000eb}body.dark .lightbox-close{background:#ffffff1a}body.dark .pw-change-wrap{background:#1e1e2e}body.dark .pw-change-box{background:#24273a}body.dark .pw-change-box h2{color:#cdd6f4}body.dark .pw-change-box p{color:#6c7086}body.dark .msg-edit-input{background:#1e1e2e;border-color:#3b82f6;color:#cdd6f4}body.dark .msg-edit-btns button:last-child{background:#313244;color:#cdd6f4}body.dark .drag-overlay{background:#2563eb1f}body.dark .drag-overlay-inner{background:#24273a}body.dark .login-wrap{background:#1e1e2e}body.dark .login-box{background:#24273a;box-shadow:0 2px 20px #0000004d}body.dark .login-logo h1{color:#89b4fa}body.dark .login-logo p{color:#6c7086}body.dark .login-box label{color:#a6adc8}body.dark .login-box input{background:#1e1e2e;border-color:#45475a;color:#cdd6f4}body.dark .login-box p{color:#6c7086}body.dark .login-reset-btn{background:#313244;color:#a6adc8;border-color:#45475a}body.dark .login-reset-btn:hover{background:#45475a;color:#cdd6f4}
