:root{--bg-primary: #FFFFFF;--bg-secondary: #E5E7EB;--bg-tertiary: #D1D5DB;--text-primary: #1A1A1A;--text-secondary: #6B7280;--text-tertiary: #9CA3AF;--accent: #3B82F6;--accent-hover: #2563EB;--accent-light: #EFF6FF;--success: #10B981;--danger: #EF4444;--border: #E5E7EB;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;--transition: .2s ease-out}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{font-family:var(--font-family);font-size:15px;line-height:1.6;color:var(--text-primary);background:var(--bg-secondary);overflow:hidden}body.admin-mode{--bg-primary: #E8F5E9;--bg-secondary: #C8E6C9;--bg-tertiary: #A5D6A7}#app{display:flex;height:100vh;height:100dvh;overflow:hidden}.sidebar{width:320px;background:var(--bg-primary);display:flex;flex-direction:column;border-right:1px solid var(--border)}.sidebar-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{font-size:18px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.header-actions{display:flex;gap:4px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.icon-btn svg{width:20px;height:20px}.user-info{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);object-fit:cover;background:var(--bg-tertiary)}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-status{font-size:12px;color:var(--text-tertiary)}.help-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);font-size:12px;font-weight:600;text-decoration:none;white-space:nowrap;transition:var(--transition)}.help-btn:hover{background:var(--accent);color:#fff}.help-btn svg{width:16px;height:16px;flex-shrink:0}.sidebar-sections{flex:1;overflow-y:auto;min-height:0}.section-header{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#78b4d0;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.section-header:hover{background:#6aa8c6}.section-icon{width:16px;height:16px;flex-shrink:0}.section-title{font-size:13px;font-weight:600;flex:1}.section-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:9px;padding:0 5px;flex-shrink:0}.section-chevron{width:18px;height:18px;flex-shrink:0;transition:transform .2s;padding:4px;box-sizing:content-box}.section-chevron.collapsed{transform:rotate(-90deg)}.section-action-btn{background:none;border:none;color:#fff;cursor:pointer;width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;margin-right:8px}.section-action-btn:hover{background:#fff3}.section-action-btn svg{width:16px;height:16px}.room-list{overflow-y:auto;padding:4px}.room-item{padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:10px;margin-bottom:1px}.room-item:hover{background:var(--bg-secondary)}.room-item.active{background:var(--accent-light);color:var(--accent)}.room-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:16px;overflow:hidden;flex-shrink:0}.room-icon img{width:100%;height:100%;object-fit:cover}.room-icon.text-avatar{color:#fff;font-weight:600}.room-icon .room-initial{font-size:15px;line-height:1}.room-item.active .room-icon:not(.text-avatar){background:var(--accent);color:#fff}.room-name{font-weight:500;font-size:13px;flex:1}.unread-badge{background:var(--danger);width:10px;height:10px;border-radius:50%;flex-shrink:0}.chat-area{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg-primary)}.chat-header{padding:16px 24px;background:var(--bg-primary);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.chat-header h3{font-size:16px;font-weight:600;color:var(--text-primary)}.room-title{cursor:pointer;transition:var(--transition)}.room-title:hover{color:var(--accent)}.member-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--accent);color:#fff;border-radius:var(--radius-full);font-size:11px;font-weight:600}.chat-header-info{font-size:13px;color:var(--text-tertiary);display:flex;align-items:center;gap:12px}.member-avatars{display:flex;align-items:center}.member-avatars .member-avatar{width:24px;height:24px;border-radius:50%;border:2px solid var(--bg-primary);object-fit:cover;background:var(--bg-tertiary);margin-left:-8px}.member-avatars .member-avatar:first-child{margin-left:0}.member-count{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--bg-primary);margin-left:-8px;font-size:10px;font-weight:600;color:var(--text-secondary)}.members-list{max-height:400px;overflow-y:auto}.member-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);transition:var(--transition)}.member-item:hover{background:var(--bg-secondary)}.member-item-avatar{width:40px;height:40px;border-radius:var(--radius-full);object-fit:cover;background:var(--bg-tertiary)}.member-item-info{flex:1;min-width:0}.member-item-name{font-weight:500;font-size:14px;color:var(--text-primary)}.member-item-username{font-size:12px;color:var(--text-tertiary)}.messages{flex:1;overflow-y:auto;padding:8px;background:var(--bg-secondary)}.date-separator{display:flex;align-items:center;justify-content:center;margin:12px 0}.date-separator span{background:var(--bg-primary);padding:4px 12px;border-radius:var(--radius-full);font-size:11px;color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.unread-separator{display:flex;align-items:center;margin:16px 0;gap:12px}.unread-separator:before,.unread-separator:after{content:"";flex:1;height:1px;background:var(--danger)}.unread-separator span{color:var(--danger);font-size:12px;font-weight:500;white-space:nowrap}.message-row{display:flex;margin-bottom:8px;animation:messageIn .3s ease-out}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-row.me{flex-direction:row-reverse}.message-row.sending{opacity:.7}.avatar{width:28px;height:28px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-tertiary);flex-shrink:0}.message-row.me .avatar,.message-row.bot .avatar{display:none}.message-row.bot{margin-top:-4px;margin-bottom:8px}.message-row.bot:not(.me) .message-content{margin-left:32px}.message-row.bot.me .message-content{margin-right:0}.message-row.bot:not(.me) .bubble{background:var(--bg-primary);padding:6px 10px}.message-row.bot:not(.me) .body{color:var(--text-secondary);font-size:13px}.message-row.bot.me .bubble{background:var(--accent);padding:6px 10px}.message-row.bot.me .body{color:#fff;font-size:13px}.message-content{max-width:70%;margin:0 4px;min-width:0}.sender-name{font-size:11px;color:var(--text-tertiary);margin-bottom:2px;margin-left:4px}.bubble-wrapper{display:flex;align-items:flex-end;gap:6px;max-width:100%}.message-row.me .bubble-wrapper{flex-direction:row-reverse}.bubble{padding:4px 8px;border-radius:var(--radius-lg);word-wrap:break-word;word-break:break-word;overflow-wrap:anywhere;position:relative;min-width:0;max-width:100%;overflow:hidden}.message-row.me .bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message-row:not(.me):not(.bot) .bubble{background:var(--bg-primary);border-bottom-left-radius:4px}.body{white-space:pre-wrap;font-size:15px;line-height:1.3;word-break:break-word;overflow-wrap:anywhere}.message-time{display:flex;align-items:center;gap:4px;font-size:10px;flex-shrink:0;padding-bottom:2px}.time{color:var(--text-tertiary)}.loading-older,.no-more-messages{text-align:center;padding:12px;color:var(--text-tertiary);font-size:12px}.no-my-lang-bot-notice{position:sticky;bottom:0;z-index:5;text-align:center;padding:6px 12px;margin:8px 0 0;font-size:12px;color:#b45309;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:6px 6px 0 0}.read-status{font-size:11px;display:flex;align-items:center;white-space:nowrap}.read-status.sent{color:var(--text-tertiary)}.read-status.read{color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent}.read-users-modal .members-list{max-height:60vh;overflow-y:auto}.message-row.me .read-status.sent{color:var(--text-tertiary)}.message-row.me .read-status.read{color:var(--text-secondary)}.read-status.sending{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.message-row:not(.me) .read-status{display:none}.file-attachments{margin-top:10px;overflow:hidden}.file-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#0000000d;border-radius:var(--radius-sm);margin-bottom:6px;transition:var(--transition);overflow:hidden}.message-row.me .file-item{background:#ffffff26}.file-item:hover{background:#00000014}.message-row.me .file-item:hover{background:#ffffff40}.file-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-sm)}.file-icon svg{width:18px;height:18px;color:var(--text-secondary)}.file-info{flex:1;min-width:0}.file-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:11px;opacity:.7}.file-link{text-decoration:none;color:inherit;display:flex;align-items:center;gap:10px;width:100%;min-width:0}.image-preview{margin-top:10px}.image-preview img{max-width:50%;max-height:300px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition)}.image-preview img:hover{transform:scale(1.02)}.image-preview img.sending-image{opacity:.7;filter:grayscale(30%)}.image-loading{padding:40px 60px;background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:12px;text-align:center}.video-thumbnail{margin-top:10px;cursor:pointer;display:inline-flex;flex-direction:column;gap:4px;max-width:240px}.video-thumb-wrap{position:relative;display:inline-block}.video-thumb-wrap:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#0000008c;border-radius:50%;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:55% 50%;background-size:24px 24px}.video-thumbnail:hover .video-thumb-wrap:after{background-color:#000000b3}.video-thumb-img{width:100%;border-radius:var(--radius-md);display:block}.video-thumbnail:hover .video-thumb-img{opacity:.85}.video-thumb-info{display:flex;align-items:baseline;gap:6px;padding:0 2px}.video-thumb-name{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.video-thumb-size{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.message-row.me .video-thumb-name{color:#ffffffb3}.message-row.me .video-thumb-size{color:#ffffff80}.video-loading{padding:40px 60px;background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:12px;text-align:center}.input-area{padding:16px 24px;background:var(--bg-primary);border-top:1px solid var(--border);flex-shrink:0;position:relative;z-index:1000}.input-wrapper{display:flex;gap:12px;align-items:flex-end}.input-box{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px;position:relative}.file-select-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:var(--transition)}.file-select-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.file-select-btn svg{width:16px;height:16px}input[type=file]{display:none}.selected-files{display:flex;flex-wrap:wrap;gap:8px}.selected-file{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border)}.selected-file-preview{width:32px;height:32px;object-fit:cover;border-radius:4px;background:var(--bg-tertiary)}.selected-file-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:4px;color:var(--text-secondary)}.selected-file-info{max-width:120px}.selected-file-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-file-size{font-size:11px;color:var(--text-tertiary)}.remove-file-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--text-tertiary);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;font-size:12px;transition:var(--transition)}.remove-file-btn:hover{background:var(--danger)}.text-input-wrapper{display:flex;align-items:flex-end;gap:12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px;transition:var(--transition)}.text-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}textarea{flex:1;padding:10px 12px;border:none;background:transparent;resize:none;font-size:15px;font-family:inherit;line-height:1.5;min-height:44px;max-height:120px;color:var(--text-primary);overflow-y:auto}textarea:focus{outline:none}textarea::placeholder{color:var(--text-tertiary)}.send-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);flex-shrink:0}.send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.send-btn:disabled{background:var(--text-tertiary);cursor:not-allowed}.send-btn svg{width:20px;height:20px}.drop-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#3b82f61a;border:3px dashed var(--accent);display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:none}.drop-overlay-content{background:var(--bg-primary);padding:32px 48px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center}.drop-overlay-content svg{width:48px;height:48px;color:var(--accent);margin-bottom:12px}.drop-overlay-content p{font-size:16px;font-weight:500;color:var(--text-primary)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-primary);padding:32px;border-radius:var(--radius-lg);width:90%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h3{font-size:18px;font-weight:600}.close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:none;border-radius:var(--radius-full);cursor:pointer;color:var(--text-secondary);transition:var(--transition)}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.select-text-body{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default;white-space:pre-wrap;word-break:break-word;font-size:15px;line-height:1.6;color:var(--text-primary);max-height:60vh;overflow-y:auto;padding:4px 0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:var(--transition)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.btn{padding:12px 24px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:15px;font-weight:500;font-family:inherit;transition:var(--transition)}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-tertiary)}.avatar-preview-container{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:16px}.avatar-preview{width:100px;height:100px;border-radius:var(--radius-full);object-fit:cover;background:var(--bg-tertiary)}.avatar-upload-btn{padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:var(--transition)}.avatar-upload-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}@media(min-width:769px){.room-list{padding:2px 4px}.room-item{padding:3px 10px;gap:8px;margin-bottom:0}.room-icon{width:26px;height:26px;font-size:13px}.room-name{font-size:12.5px}.section-header{padding:5px 12px}.user-info{padding:10px 16px}}@media(max-width:768px){html,body{overflow:hidden;position:fixed;width:100%;height:100%}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:100;transform:translate(-100%);transition:transform .3s ease-out;width:85%;max-width:320px}.sidebar.open{transform:translate(0)}.overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:99}.overlay.show{display:block}.chat-area{position:fixed;top:0;left:0;right:0;bottom:0}.mobile-header{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;padding:4px 8px;padding-top:calc(4px + env(safe-area-inset-top,0px));background:var(--bg-primary);border-bottom:1px solid var(--border);gap:10px;min-height:40px;box-sizing:border-box;z-index:101}.mobile-room-info{flex:1;min-width:0;display:flex;align-items:center;gap:6px;cursor:pointer}.mobile-room-info h3{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-header-actions{display:flex;gap:2px}.mobile-header-actions .icon-btn{width:28px;height:28px}.mobile-header-actions .icon-btn svg{width:16px;height:16px}.hamburger{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--text-primary)}.hamburger svg{width:18px;height:18px}.chat-header{display:none}.message-row .message-content{max-width:80%}.input-area{position:fixed;bottom:0;left:0;right:0;padding:4px 8px;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px));box-sizing:border-box;overflow:visible;background:var(--bg-primary);border-top:1px solid var(--border);z-index:101}.messages{position:fixed;top:calc(40px + env(safe-area-inset-top,0px));left:0;right:0;bottom:calc(44px + env(safe-area-inset-bottom,0px));padding:4px;overflow-y:auto;-webkit-overflow-scrolling:touch}.text-input-wrapper{padding:2px;gap:6px}textarea{padding:4px 8px;min-height:28px;font-size:14px;line-height:1.3}.send-btn{width:32px;height:32px}.send-btn svg{width:16px;height:16px}.file-select-btn{padding:4px 6px}.file-select-btn svg{width:14px;height:14px}.bubble{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.image-preview img{max-width:70%}.sidebar.mobile-main{position:static;transform:none;width:100%;max-width:none;z-index:auto}.chat-area.mobile-hidden{display:none}.modal{padding:16px;align-items:flex-start;padding-top:10vh}.modal-content{width:100%;max-width:none;padding:24px}.modal-footer{flex-direction:column;gap:8px}.modal-footer .btn{width:100%}.room-item{min-height:44px;padding:6px 10px;-webkit-tap-highlight-color:transparent}.btn,.icon-btn,.hamburger,.close-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.modal-content .btn{min-height:48px}.reaction-palette{flex-wrap:wrap;max-width:180px}.reaction-palette button{width:32px;height:32px;font-size:18px}.message-actions{max-width:calc(100vw - 80px)}.reply-preview{padding:6px 10px;width:100%;box-sizing:border-box}.reply-preview-content{overflow:hidden}.reply-preview-label{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-preview-body{font-size:12px}}@media(min-width:769px){.mobile-header{display:none}}.login-view{display:flex;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;width:100%;background:var(--bg-secondary);position:fixed;top:0;left:0;right:0;bottom:0;overflow-y:auto}@media(max-width:768px){.login-view{align-items:flex-start;padding-top:3vh;padding-bottom:20px}}.login-box{background:var(--bg-primary);padding:48px 40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-header h2{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.login-header p{font-size:14px;color:var(--text-secondary)}.error-message{background:#fef2f2;color:var(--danger);font-size:14px;padding:12px 16px;border-radius:var(--radius-sm);margin-top:16px;text-align:center}.forgot-password-link{display:block;text-align:center;margin-top:16px;color:var(--text-secondary);font-size:14px;text-decoration:none}.forgot-password-link:hover{color:var(--accent)}.alert-msg{padding:12px 16px;border-radius:var(--radius-sm);margin-top:16px;font-size:14px}.alert-msg.success{background:#d1fae5;color:#047857}.alert-msg.error{background:#fee2e2;color:#dc2626}.debug-info{margin-top:16px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px dashed var(--border)}.no-room-selected{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-tertiary);gap:16px}.no-room-selected svg{width:64px;height:64px;opacity:.5}.no-room-selected p{font-size:16px}.mention{background:#3b82f626;color:var(--accent);padding:1px 4px;border-radius:4px;font-weight:500}.mention.me{background:#facc154d;color:#b45309}.message-row.me .mention{background:#ffffff40;color:#fff}.message-row.me .mention.me{background:#facc1566;color:#fef3c7}.mention-popup{position:absolute;bottom:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:99999;margin-bottom:8px;transform:translateZ(0);-webkit-transform:translateZ(0)}.mention-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation}.mention-item:hover,.mention-item.selected{background:var(--accent-light)}.mention-item-avatar{width:32px;height:32px;border-radius:var(--radius-full);object-fit:cover;background:var(--bg-tertiary)}.mention-item-info{flex:1;min-width:0}.mention-item-name{font-weight:500;font-size:14px;color:var(--text-primary)}.mention-item-username{font-size:12px;color:var(--text-tertiary)}.text-input-wrapper{position:relative}.image-viewer-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;z-index:2000;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:20px}.image-viewer-close{position:absolute;top:20px;right:20px;width:44px;height:44px;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}.image-viewer-close:hover{background:#ffffff4d}.image-viewer-img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:var(--radius-md);touch-action:none;user-select:none;-webkit-user-select:none;transition:none}.image-viewer-download{margin-top:20px;padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;cursor:pointer}.image-viewer-download:hover{background:var(--accent-hover)}.bubble-container{position:relative;-webkit-touch-callout:none;max-width:100%;min-width:0}.message-actions{position:absolute;bottom:100%;left:0;margin-bottom:4px;background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:8px;z-index:50;display:flex;flex-direction:column;gap:6px;width:max-content;animation:fadeIn .15s ease-out;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.message-row.me .message-actions{left:auto;right:0}.reaction-palette{display:flex;gap:4px}.reaction-palette button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);font-size:20px;cursor:pointer;transition:var(--transition);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.reaction-palette button:hover{background:var(--bg-secondary);transform:scale(1.2)}.action-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;border-top:1px solid var(--border);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:var(--transition);width:100%;white-space:nowrap;font-family:inherit;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.action-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.action-btn svg{width:14px;height:14px}.action-btn.delete-btn{color:#dc3545}.action-btn.delete-btn:hover{background:#fff0f0;color:#c82333}.reaction-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;background:var(--accent-light);border:1px solid var(--accent);border-radius:var(--radius-full);font-size:13px;cursor:pointer;transition:var(--transition)}.reaction-badge:hover{background:var(--bg-tertiary)}.reaction-badge.mine{background:var(--accent-light);border-color:var(--accent);font-weight:600}.reaction-badge .emoji{font-size:14px}.reaction-badge .count{font-size:11px;color:var(--text-secondary);font-weight:500}.reply-preview{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--accent-light);border-left:3px solid var(--accent);border-radius:var(--radius-sm);margin-bottom:8px;max-width:100%;box-sizing:border-box;overflow:hidden}.reply-preview-content{flex:1;min-width:0}.reply-preview-label{font-size:12px;color:var(--accent);font-weight:600;margin-bottom:2px}.reply-preview-body{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-cancel-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);color:var(--text-secondary);font-size:18px;cursor:pointer;flex-shrink:0;margin-left:8px}.reply-cancel-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.edit-preview{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fff8e1;border-left:3px solid #F59E0B;border-radius:var(--radius-sm);margin-bottom:8px;max-width:100%;box-sizing:border-box;overflow:hidden}.edit-preview-content{flex:1;min-width:0}.edit-preview-label{font-size:12px;color:#b45309;font-weight:600}.edited-label{font-size:10px;color:#e67e22;font-weight:600;font-style:italic}.messages.dark-bg .edited-label{color:#f0ad4e}.quote-line{background:#0000000f;border-left:3px solid var(--accent);padding:4px 8px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:13px;color:var(--text-secondary)}.message-row.me .quote-line{background:#ffffff26;border-left-color:#ffffff80;color:#ffffffd9}.lang-prefix{font-weight:600;color:var(--accent);margin-right:2px}.message-row.me .lang-prefix{color:#ffffffe6}.clickable-quote{cursor:pointer;transition:var(--transition)}.clickable-quote:hover{background:#3b82f61a}.message-row.me .clickable-quote:hover{background:#ffffff1a}.highlight-flash{animation:highlightFlash 1.5s ease-out}@keyframes highlightFlash{0%,to{background:transparent}20%{background:#3b82f64d}}.quote-block{background:var(--bg-secondary);border-left:3px solid var(--accent);padding:6px 10px;margin-bottom:6px;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.quote-author{font-size:11px;color:var(--accent);font-weight:600;margin-bottom:2px}.quote-text{font-size:13px;color:var(--text-secondary)}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--text-primary);color:var(--bg-primary);padding:10px 24px;border-radius:var(--radius-full);font-size:14px;z-index:3000;animation:toastIn .3s ease-out,toastOut .3s ease-in 1.7s forwards;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.messages.font-size-medium .body{font-size:17px}.messages.font-size-medium .message-row.bot .body{font-size:15px}.messages.font-size-large .body{font-size:19px}.messages.font-size-large .message-row.bot .body,.input-area.font-size-medium textarea{font-size:17px}.input-area.font-size-large textarea{font-size:19px}.sidebar.font-size-medium .room-name{font-size:15px}.sidebar.font-size-large .room-name{font-size:17px}.color-palette-btn{position:relative}.color-palette-popover{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;z-index:200;animation:fadeIn .15s ease-out}.color-palette-popover .palette-label{font-size:12px;color:var(--text-tertiary);margin-bottom:8px}.color-palette-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.color-swatch{width:32px;height:32px;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:var(--transition)}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.color-swatch.swatch-dark{border-color:#444}.messages.dark-bg .sender-name{color:#fff9}.messages.dark-bg .time{color:#ffffff73}.messages.dark-bg .read-status.sent{color:#ffffff59}.messages.dark-bg .read-status.read{color:#fff9}.messages.dark-bg .message-row.me .read-status.sent{color:#ffffff59}.messages.dark-bg .message-row.me .read-status.read{color:#fff9}.messages.dark-bg .date-separator span{background:#ffffff26;color:#ffffffb3}.messages.dark-bg .loading-older,.messages.dark-bg .no-more-messages{color:#ffffff73}.messages.dark-bg .no-my-lang-bot-notice{background:#fffbeb26;color:#fbbf24;border-left-color:#f59e0b}.messages.dark-bg .unread-separator span{color:#fca5a5}.messages.dark-bg .unread-separator:before,.messages.dark-bg .unread-separator:after{background:#fca5a5}.messages.dark-bg .message-row.bot:not(.me) .body{color:#ffffffb3}.messages.dark-bg .message-row.me .bubble{background:#ffffff38;color:#fff}.messages.dark-bg .message-row.bot:not(.me) .bubble{background:#ffffff21}.messages.dark-bg .message-row:not(.me):not(.bot) .bubble{background:#ffffff21;color:#ffffffe6}.messages.dark-bg .quote-line{background:#ffffff14;color:#ffffffb3}.messages.dark-bg .quote-block{background:#ffffff1f}.messages.dark-bg .quote-text{color:#ffffffb3}.messages.dark-bg .file-item{background:#ffffff14}.messages.dark-bg .file-icon{background:#ffffff26}.messages.dark-bg .file-icon svg{color:#fff9}.messages.dark-bg .mention{background:#3b82f64d;color:#93c5fd}.messages.dark-bg .mention.me{background:#facc154d;color:#fde047}.reaction-tooltip{position:fixed;background:var(--text-primary);color:var(--bg-primary);padding:6px 12px;border-radius:var(--radius-sm);font-size:12px;z-index:3100;pointer-events:none;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis;box-shadow:var(--shadow-lg)}.search-modal-content{max-width:560px;max-height:80vh;display:flex;flex-direction:column}.search-input-wrapper{position:relative;margin-bottom:12px}.search-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:10px 12px 10px 40px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-primary);color:var(--text-primary);outline:none;box-sizing:border-box}.search-input:focus{border-color:var(--accent)}.search-results{flex:1;overflow-y:auto;max-height:55vh}.search-results-count{font-size:12px;color:var(--text-tertiary);margin-bottom:8px}.search-result-item{padding:10px 8px;border-radius:var(--radius-sm);cursor:pointer;border-bottom:1px solid var(--border)}.search-result-item:hover{background:var(--bg-secondary)}.search-result-room{font-size:11px;color:var(--accent);font-weight:600;margin-bottom:2px}.search-result-sender{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.search-result-body{font-size:13px;color:var(--text-primary);line-height:1.4;word-break:break-word;margin-bottom:4px}.search-result-body mark{background:#facc1566;color:inherit;padding:0 2px;border-radius:2px}.search-result-time{font-size:11px;color:var(--text-tertiary)}.search-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;font-size:13px;color:var(--text-secondary)}.dm-button-wrapper{padding:8px 12px 4px}.dm-start-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:var(--accent-light);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--accent);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:var(--transition)}.dm-start-btn:hover{background:var(--accent);color:#fff}.dm-start-btn svg{width:16px;height:16px;flex-shrink:0}.dm-modal-content{max-width:480px;max-height:80vh;display:flex;flex-direction:column}.dm-search-results{flex:1;overflow-y:auto;max-height:55vh}.dm-section-label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;padding:8px 8px 4px;letter-spacing:.5px}.dm-user-item{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.dm-user-item:hover{background:var(--bg-secondary)}.dm-user-avatar{width:40px;height:40px;border-radius:var(--radius-full);object-fit:cover;background:var(--bg-tertiary);flex-shrink:0}.dm-user-avatar-placeholder{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;background:var(--accent)}.dm-user-info{flex:1;min-width:0}.dm-user-name{font-weight:500;font-size:14px;color:var(--text-primary)}.dm-user-username{font-size:12px;color:var(--text-tertiary)}.dm-chat-btn{padding:6px 14px;font-size:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);flex-shrink:0;font-family:inherit}.dm-chat-btn:hover{background:var(--accent-hover)}.message-row.scheduled .bubble{opacity:.7;border:1px dashed var(--accent)}.scheduled-label{font-size:11px;color:var(--accent);cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap}.cancel-scheduled{color:var(--text-tertiary);cursor:pointer;font-size:16px;line-height:1}.cancel-scheduled:hover{color:#e53e3e}.reminder-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;font-size:13px}.reminder-badge-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;color:#f59e0b;animation:reminderBell .6s ease-out}.reminder-badge-icon svg{width:14px;height:14px}@keyframes reminderBell{0%{transform:rotate(0)}20%{transform:rotate(15deg)}40%{transform:rotate(-15deg)}60%{transform:rotate(8deg)}80%{transform:rotate(-8deg)}to{transform:rotate(0)}}.reminder-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin:8px 12px;background:#fff8e1;border:1px solid #ffe082;border-radius:8px;animation:toastIn .3s ease-out}.reminder-banner-content{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.reminder-banner-icon{width:20px;height:20px;flex-shrink:0;color:#f59e0b}.reminder-banner-text{flex:1;min-width:0}.reminder-banner-body{font-size:14px;font-weight:500;color:#92400e;word-break:break-word}.reminder-banner-time{font-size:11px;color:#b45309;margin-top:2px}.reminder-banner-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;color:#b45309;font-size:18px;cursor:pointer;flex-shrink:0;transition:var(--transition)}.reminder-banner-close:hover{background:#b453091a;color:#92400e}.messages.dark-bg .reminder-banner{background:#f59e0b26;border-color:#f59e0b4d}.messages.dark-bg .reminder-banner-body{color:#fde68a}.messages.dark-bg .reminder-banner-time,.messages.dark-bg .reminder-banner-close{color:#fbbf24}.messages.dark-bg .reminder-banner-close:hover{background:#fbbf2426}.onboarding-card{max-width:480px}.onboarding-tips{display:flex;flex-direction:column;gap:16px}.onboarding-tip{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:var(--radius-sm);background:var(--bg-secondary)}.onboarding-tip-icon{font-size:24px;flex-shrink:0}.onboarding-tip p{margin:4px 0 0;font-size:13px;opacity:.7}.guide-banner{margin-bottom:16px;padding:16px 20px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-sm,8px)}.guide-banner h4{margin:0 0 8px;font-size:15px;color:#1e40af}.guide-banner ul{margin:0 0 12px;padding-left:20px;font-size:13px;color:#1e3a5f;line-height:1.8}.guide-banner .btn-sm{font-size:12px;padding:6px 14px;background:#e2e8f0;border:none;border-radius:6px;cursor:pointer;color:#475569}.guide-banner .btn-sm:hover{background:#cbd5e1}.loading-older,.no-more-messages,.date-separator,.unread-separator{overflow-anchor:none}.file-viewer-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease-out}.file-viewer-container{background:var(--bg-primary);border-radius:var(--radius-lg);width:90vw;max-width:900px;height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;overflow:hidden}.file-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.file-viewer-title{display:flex;align-items:center;gap:8px;flex:1;min-width:0;color:var(--text-primary)}.file-viewer-filename{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-viewer-filesize{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.file-viewer-actions{display:flex;gap:4px;flex-shrink:0}.file-viewer-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.file-viewer-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.file-viewer-close-btn:hover{background:#fee2e2;color:var(--danger)}.file-viewer-body{flex:1;overflow:hidden;min-height:0}.file-viewer-iframe{width:100%;height:100%;border:none;background:#fff}.file-viewer-text-wrap{width:100%;height:100%;overflow:auto;background:var(--bg-secondary)}.file-viewer-text{padding:16px;margin:0;font-size:13px;line-height:1.6;font-family:SF Mono,Monaco,Cascadia Code,Consolas,monospace;white-space:pre-wrap;word-break:break-word;color:var(--text-primary);-webkit-user-select:text;user-select:text}.file-viewer-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:14px}.file-viewer-unsupported{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text-secondary)}.file-viewer-unsupported-name{font-size:16px;font-weight:600;color:var(--text-primary);word-break:break-word;text-align:center;max-width:80%}.file-viewer-unsupported-size{font-size:13px;color:var(--text-tertiary)}.file-viewer-unsupported-hint{font-size:13px;color:var(--text-tertiary);margin-top:4px}.file-viewer-unsupported-buttons{display:flex;gap:8px;margin-top:12px}.file-viewer-dl-btn{padding:10px 20px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit;cursor:pointer;transition:var(--transition)}.file-viewer-dl-btn:hover{background:var(--bg-tertiary)}.file-viewer-dl-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.file-viewer-dl-btn.primary:hover{background:var(--accent-hover)}@media(max-width:768px){.file-viewer-container{width:100%;height:100%;max-width:none;border-radius:0}.file-viewer-modal{padding:0}.file-viewer-header{padding:10px 12px}.file-viewer-filename{font-size:13px}}.clickable-avatar{cursor:pointer;transition:var(--transition)}.clickable-avatar:hover{opacity:.8;transform:scale(1.1)}.user-card-header{position:relative;background:linear-gradient(135deg,var(--accent),#8b5cf6);height:100px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:0}.user-card-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--bg-primary);background:var(--bg-tertiary);position:relative;top:40px}.user-card-link{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-primary);text-decoration:none;font-size:13px;transition:var(--transition);word-break:break-all}.user-card-link:hover{background:var(--bg-tertiary)}.user-card-link svg{color:var(--text-secondary)}.user-card-phone{display:none}@media(max-width:768px){.user-card-phone{display:flex}}.bot-popover{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;z-index:200;min-width:200px;animation:fadeIn .15s ease-out}.bot-toggle-item{display:flex;align-items:center;justify-content:space-between;padding:6px 0;cursor:pointer;font-size:13px;gap:12px;-webkit-user-select:none;user-select:none}.bot-toggle-item input{display:none}.bot-toggle-slider{position:relative;width:36px;height:20px;background:var(--border);border-radius:10px;transition:background .2s;flex-shrink:0}.bot-toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.bot-toggle-item input:checked+.bot-toggle-slider{background:var(--accent)}.bot-toggle-item input:checked+.bot-toggle-slider:after{transform:translate(16px)}.bot-waiting-indicator{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--hover-bg,#f0f4ff);border-radius:8px;margin:8px 12px}.bot-waiting-dots{display:flex;gap:4px}.bot-waiting-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent,#4a90d9);animation:botDotPulse 1.4s ease-in-out infinite}.bot-waiting-dots span:nth-child(2){animation-delay:.2s}.bot-waiting-dots span:nth-child(3){animation-delay:.4s}@keyframes botDotPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.bot-waiting-text{font-size:13px;color:var(--text-secondary,#666)}.section-header-main{background:#5a9ab5!important}.section-header-main:hover{background:#4e8da8!important}.dept-subheader{display:flex;align-items:center;gap:4px;padding:3px 12px;background:#78b4d0;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:600}.dept-subheader:hover{background:#6aa8c6}.dept-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dept-chevron{width:14px;height:14px;flex-shrink:0;transition:transform .2s}.dept-chevron.collapsed{transform:rotate(-90deg)}
