: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}html.dark{--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-tertiary:#0f3460;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-tertiary:#64748b;--accent:#60a5fa;--accent-hover:#3b82f6;--accent-light:#1e3a5f;--success:#34d399;--danger:#f87171;--border:#334155;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 6px -1px rgba(0,0,0,.4);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.4)}*{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}#app{display:flex;height:100vh;height:100dvh;overflow:hidden}.sidebar{width:320px;flex-shrink:0;background:var(--bg-primary);display:flex;flex-direction:column;border-right:1px solid var(--border)}.sidebar-header{padding:12px 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:13px 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:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--accent-light);color:var(--accent);text-decoration:none;flex-shrink:0;transition:var(--transition);margin-left:4px}.home-btn{background:var(--accent-light);color:var(--accent)}.help-btn:hover{background:var(--accent);color:#fff}.help-btn svg{width:22px;height:22px;flex-shrink:0}.sidebar-sections{flex:1;overflow-y:auto;min-height:0;contain:layout style;-webkit-overflow-scrolling:touch}.section-header{display:flex;align-items:center;gap:6px;padding:4px 12px;background:linear-gradient(135deg,#4a7ab5,#b8d4ea);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.section-header:hover{background:linear-gradient(135deg,#3d6a9e,#a0c4e0)}.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}.section-filter-input{flex:1;min-width:0;background:#fff3;border:1px solid #ffffff66;border-radius:4px;color:#fff;font-size:12px;padding:3px 8px;outline:none;font-family:inherit}.section-filter-input::placeholder{color:#fffa}.section-filter-input:focus{background:#ffffff4d;border-color:#fff}.section-header-sticky{position:sticky;top:0;z-index:50}.room-list{overflow-y:auto;padding:4px}.dm-virtual{overflow:visible!important}.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;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.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:12px;height:12px;border-radius:50%;flex-shrink:0;animation:unreadPulse 1.5s ease-in-out infinite;box-shadow:0 0 4px #ef444480}@keyframes unreadPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.chat-area{flex:1 1 480px;min-width:0;display:flex;flex-direction:column;background:var(--bg-primary)}.calendar-panel{flex-shrink:1000;min-width:0;overflow:hidden}.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);overflow-anchor:none}.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:100%;margin:0 4px;min-width:0;flex:1}.sender-name{font-size:11px;color:var(--bubble-sender-name, var(--text-secondary));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}@media(max-width:768px){.message-time{flex-direction:column-reverse;align-items:flex-start;gap:1px;line-height:1.1}.message-row.me .message-time{align-items:flex-end}}.time{color:var(--text-secondary)}.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;color:inherit}.file-size{font-size:11px;color:inherit;opacity:.8}.messages.dark-bg .file-name{color:#fffc}.messages.dark-bg .file-size{color:#fff9}.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;content-visibility:auto;contain-intrinsic-size:200px 150px}.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}.video-dl-btn{align-self:center;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:transparent}.video-dl-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.video-dl-btn svg{width:16px;height:16px}.message-row.me .video-dl-btn{color:#ffffffb3}.message-row.me .video-dl-btn:hover{background:#ffffff26;color:#fff}.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;inset: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:8px}.form-group label{display:block;margin-bottom:4px;font-weight:500;font-size:13px;color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:8px 12px;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:8px;margin-bottom:12px}.avatar-preview{width:72px;height:72px;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:1px 10px;gap:8px;margin-bottom:0;transition:none}.room-icon{width:22px;height:22px;font-size:12px}.room-icon .room-initial{font-size:12px}.room-name{font-size:13px}.section-header{padding:3px 12px}.user-info{padding:8px 16px}.sidebar.font-size-medium .room-item{padding:2px 10px}.sidebar.font-size-medium .room-icon{width:24px;height:24px;font-size:13px}.sidebar.font-size-large .room-item{padding:4px 10px}.sidebar.font-size-large .room-icon{width:28px;height:28px;font-size:14px}}@media(max-width:768px){html,body{overflow:hidden;position:fixed;width:100%;height:100%}.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;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;inset:0}.mobile-header{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;padding:6px 8px;padding-top:calc(6px + env(safe-area-inset-top,0px));background:var(--bg-primary);border-bottom:1px solid var(--border);gap:10px;min-height:50px;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:15px;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:34px;height:34px}.mobile-header-actions .icon-btn svg{width:20px;height:20px}.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:85%}.input-area{position:fixed;bottom:max(env(safe-area-inset-bottom,0px),20px);left:0;right:0;padding:4px 8px 8px;box-sizing:border-box;overflow:visible;background:var(--bg-primary);border-top:1px solid var(--border);z-index:101}.messages{position:fixed;top:calc(50px + env(safe-area-inset-top,0px));left:0;right:0;bottom:calc(44px + max(env(safe-area-inset-bottom,0px),20px));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:3vh}.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}.action-toolbar{display:flex;gap:2px;padding-bottom:6px;border-bottom:1px solid var(--border)}.toolbar-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);font-size:18px;cursor:pointer;transition:var(--transition);color:var(--text-secondary);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.toolbar-btn:hover{background:var(--bg-secondary);transform:scale(1.15)}.toolbar-btn svg{width:16px;height:16px}.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;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;width:100%;background:var(--bg-secondary);position:fixed;inset:0;overflow-y:auto}@media(max-width:768px){.login-view{align-items:center;justify-content:flex-start;padding-top:2vh;padding-bottom:20px}}.login-box{background:var(--bg-primary);padding:16px 24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:400px}.login-header{text-align:center;margin-bottom:16px}.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;inset: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)}.image-viewer-original{margin-top:8px;padding:12px 24px;background:#374151;color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;cursor:pointer}.image-viewer-original:hover{background:#1f2937}.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:1000;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}.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}.edit-existing-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.edit-existing-file{display:flex;align-items:center;gap:4px;background:#0000000f;border-radius:var(--radius-sm);padding:2px 6px}.edit-file-thumb{width:32px;height:32px;object-fit:cover;border-radius:var(--radius-sm)}.edit-file-name{font-size:11px;color:var(--text-secondary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edit-existing-file .remove-file-btn{width:16px;height:16px;font-size:10px;flex-shrink:0}.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}.font-size-medium .icon-btn svg{width:20px;height:20px}.font-size-medium .toolbar-btn svg{width:18px;height:18px}.font-size-medium .send-btn svg{width:20px;height:20px}.font-size-medium .sender-name{font-size:13px}.font-size-medium .time{font-size:12px}.font-size-medium .file-name{font-size:15px}.font-size-medium .avatar{width:38px;height:38px}.font-size-large .icon-btn svg{width:22px;height:22px}.font-size-large .toolbar-btn svg{width:20px;height:20px}.font-size-large .send-btn svg{width:22px;height:22px}.font-size-large .sender-name{font-size:14px}.font-size-large .time{font-size:13px}.font-size-large .file-name{font-size:16px}.font-size-large .avatar{width:42px;height:42px}.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:8px;z-index:200;animation:fadeIn .15s ease-out}.color-palette-popover .palette-label{font-size:11px;color:var(--text-tertiary);margin-bottom:4px}.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:var(--bubble-sender-name, #fff9)}.messages.dark-bg .time{color:#ffffffb3}.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:var(--bubble-other-text, #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:8px 12px;border-radius:var(--radius-sm);font-size:12px;z-index:3100;pointer-events:auto;white-space:pre-line;line-height:1.6;max-width:320px;max-height:50vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.search-modal-content{max-width:560px;max-height:calc(100dvh - 80px);height:calc(100dvh - 80px);display:flex;flex-direction:column;overflow-y:hidden}.modal-search{justify-content:flex-end;align-items:flex-start;padding-right:16px;padding-top:64px}@media(max-width:768px){.modal-search{justify-content:center;align-items:flex-start;padding-right:16px;padding-top:3vh}.search-modal-content{max-height:60vh;height:auto}.search-results{max-height:55vh}}.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;min-height:0}.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:#fff;background:var(--accent);padding:2px 8px;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap}.cancel-scheduled{color:#fffc;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;inset: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-video{width:100%;height:100%;background:#000;object-fit:contain;display:block}.file-viewer-video-close{position:absolute;top:max(12px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right));width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#000000a6;color:#fff;border:none;border-radius:50%;cursor:pointer;z-index:9999;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.file-viewer-video-close svg{width:22px;height:22px}.file-viewer-video-close:active{background:#000000d4}@media(max-width:768px),(max-height:600px){.file-viewer-video-close{display:none}}.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)}.file-viewer-office-banner{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff8e1;border-bottom:1px solid #ffe082;flex-shrink:0;font-size:12px;color:#92400e}.file-viewer-office-banner svg{width:16px;height:16px;flex-shrink:0;color:#f59e0b}.office-banner-text{flex:1;min-width:0;line-height:1.4}.office-banner-dl{flex-shrink:0;padding:5px 12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-family:inherit;cursor:pointer;white-space:nowrap}.office-banner-dl:hover{background:var(--accent-hover)}.office-banner-close{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;color:#b45309;font-size:18px;cursor:pointer;line-height:1}.office-banner-close:hover{background:#b453091a}@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:max(10px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) 10px max(12px,env(safe-area-inset-left))}.file-viewer-filename{font-size:13px}.file-viewer-office-banner{padding:7px 10px;font-size:11px;gap:6px}.office-banner-dl{padding:5px 10px}}.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:linear-gradient(135deg,#1d4ed8,#7eb6f0)!important}.section-header-main:hover{background:linear-gradient(135deg,#1e3a8a,#60a5fa)!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}@keyframes calPendingBlink{0%,to{opacity:1}50%{opacity:.3}}.cal-pending-blink{animation:calPendingBlink 3s ease-in-out infinite}.avatar-deleted{filter:grayscale(100%);opacity:.5}.text-deleted{opacity:.5;text-decoration:line-through}.message-row.deleted-user .sender-name{opacity:.5}.cal-date-btn{padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;cursor:pointer;white-space:nowrap}.cal-date-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-datepicker{position:absolute;top:100%;left:0;z-index:500;background:#fff!important;border:1px solid var(--border);border-radius:8px;padding:12px;box-shadow:0 8px 32px #00000073;width:260px;backdrop-filter:none;opacity:1!important;background-color:#fff!important}html.dark .cal-datepicker{background:#1a1a2e!important;background-color:#1a1a2e!important;box-shadow:0 8px 32px #000000b3}.cal-pick-nav{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;color:var(--text-secondary)}.cal-pick-nav:hover{color:var(--accent)}.cal-time-sel{padding:4px;border:1px solid var(--border);border-radius:4px;font-size:13px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.cal-time-sel:hover{border-color:var(--accent)}.hover-toolbar{position:absolute;bottom:100%;left:0;margin-bottom:4px;display:flex;gap:2px;background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:4px;z-index:999;animation:fadeIn .1s ease-out}.message-row.me .hover-toolbar{left:auto;right:0}.action-toolbar,.hover-toolbar{display:flex;gap:4px}.toolbar-btn{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);color:var(--text-secondary);flex-shrink:0;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.toolbar-btn:hover{background:var(--bg-secondary);transform:scale(1.15)}.toolbar-btn svg{width:18px;height:18px;flex-shrink:0}.emoji-picker-wrap{position:relative}.emoji-picker-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:6px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;display:grid;grid-template-columns:repeat(6,1fr);gap:2px;z-index:1001;min-width:220px}.emoji-pick-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);font-size:18px;cursor:pointer;transition:var(--transition)}.emoji-pick-btn:hover{background:var(--bg-secondary);transform:scale(1.2)}.emoji-picker-mobile-backdrop{position:fixed;inset:0;background:#0006;z-index:9998;-webkit-tap-highlight-color:transparent}.emoji-picker-mobile-sheet{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;display:grid;grid-template-columns:repeat(5,1fr);gap:6px;z-index:9999;max-width:90vw;animation:fadeIn .15s ease-out}.emoji-picker-mobile-sheet .emoji-pick-btn{width:48px;height:48px;font-size:24px}.room-item.pending{background:#6366f126;border-left:3px solid var(--accent);animation:pendingPulse 1.5s ease-in-out 3}@keyframes pendingPulse{0%,to{background:#6366f126}50%{background:#6366f140}}.login-qr{margin-top:20px;text-align:center}.login-qr p{font-size:12px;color:#999;margin-bottom:8px}.login-qr svg{margin:0 auto}@media(max-width:768px){.login-qr{display:none}}.messages.tinted-bubbles .message-row:not(.me):not(.bot) .bubble{background:var(--bubble-other-bg, #e5e7eb);color:var(--bubble-other-text, #1a1a1a)}.messages.tinted-bubbles .message-row.me .bubble{background:var(--bubble-me-bg, #4b5563);color:var(--bubble-me-text, #fff)}.messages.tinted-bubbles .message-row.bot:not(.me) .bubble{background:var(--bubble-other-bg, #e5e7eb);color:var(--bubble-other-text, #1a1a1a)}.messages.tinted-bubbles .message-row.bot.me .bubble{background:var(--bubble-me-bg, #4b5563);color:var(--bubble-me-text, #fff)}.messages.tinted-bubbles .message-row:not(.me):not(.bot) .body{color:var(--bubble-other-text, #1a1a1a)}.messages.tinted-bubbles .message-row.bot:not(.me) .body{color:var(--bubble-other-text, #1a1a1a)}.messages.tinted-bubbles .quote-line{background:#0000000d;color:#374151}.messages.tinted-bubbles .quote-block{background:#00000014}.messages.tinted-bubbles .quote-text{color:#374151}.messages.tinted-bubbles .message-row.me .quote-line,.messages.tinted-bubbles .message-row.me .quote-text{color:#e5e7eb}.messages.tinted-bubbles .message-row.me .quote-block{background:#ffffff21}.messages.tinted-bubbles .message-row:not(.me) .mention{background:#3b82f626;color:#1d4ed8}.messages.tinted-bubbles .message-row:not(.me) .mention.me{background:#facc154d;color:#b45309}.bg-apply-all-toggle{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid #e5e7eb;font-size:12px;color:#374151;cursor:pointer;user-select:none}.bg-apply-all-toggle input{cursor:pointer;width:14px;height:14px}.section-slide-enter-from{opacity:0;max-height:0;overflow:hidden}.section-slide-enter-active{transition:opacity .3s ease-out,max-height .3s ease-out;overflow:hidden}.section-slide-enter-to{opacity:1;max-height:2000px}.section-slide-leave-from{opacity:1;max-height:2000px;overflow:hidden}.section-slide-leave-active{transition:opacity .5s ease-in-out,max-height .5s ease-in-out;overflow:hidden}.section-slide-leave-to{opacity:0;max-height:0;overflow:hidden}.dm-virtual>*{transition:transform .25s ease-out}.calendar-panel .fc .fc-h-event,.calendar-panel .fc .fc-h-event a,.calendar-panel .fc .fc-h-event .fc-event-title,.calendar-panel .fc .fc-h-event .fc-event-time{color:#fff!important}.schedule-popup{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:280px;z-index:200;animation:fadeIn .15s ease-out}.modal-forward{align-items:flex-start;padding-top:64px}@media(max-width:768px){.modal-forward{padding-top:3vh}}.schedule-popup-title{padding:10px 16px;font-size:12px;color:var(--text-tertiary);font-weight:600;border-bottom:1px solid var(--border)}.schedule-popup-item{padding:12px 16px;font-size:14px;cursor:pointer;transition:background .15s;color:var(--text-primary)}.schedule-popup-item:hover{background:var(--bg-secondary)}.schedule-popup-item:active{background:var(--accent-light)}@media(max-width:768px){.schedule-popup{position:fixed!important;inset:50% auto auto 50%!important;margin:0!important;transform:translate(-50%,-50%)!important;width:92vw!important;max-width:380px!important;min-width:0!important;max-height:85vh!important;overflow-y:auto!important;z-index:1100!important}}html.dark .btn-cancel{color:#93c5fd;border-color:#334155}html.dark .modal-content textarea,html.dark .modal-content input,html.dark .modal-content select{background:#1e293b;color:#e2e8f0;border-color:#334155}html.dark .sender-name{color:var(--bubble-sender-name, #cbd5e1)}html.dark .time{color:#94a3b8}html.dark .read-status.sent{color:#64748b}html.dark .read-status.read,html.dark .bg-apply-all-toggle,html.dark .palette-label{color:#94a3b8}.font-size-medium .fc .fc-toolbar-title{font-size:15px!important}.font-size-large .fc .fc-toolbar-title{font-size:16px!important}html.dark{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.font-size-medium .mobile-room-info h3{font-size:16px}.font-size-large .mobile-room-info h3{font-size:18px}.font-size-medium .room-title{font-size:16px}.font-size-large .room-title{font-size:18px}html.dark .body{font-weight:400}html.dark .sender-name{font-weight:500}html.dark .room-name{font-weight:400}.reminder-modal{background:#e3f2fd}html.dark .reminder-modal{background:#1e293b}html.dark .reminder-modal input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}html.dark input[type=date]::-webkit-calendar-picker-indicator,html.dark input[type=time]::-webkit-calendar-picker-indicator,html.dark input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1)}html.dark .messages.bg-g_gray .sender-name{color:var(--bubble-sender-name, #1f2937)}html.dark .messages.bg-g_gray .time{color:#374151}html.dark .messages.bg-g_gray .read-status.sent{color:#6b7280}html.dark .messages.bg-g_gray .read-status.read{color:#1f2937}html.dark .messages.bg-g_gray .edited-label{color:#b45309}.message-row.me .bubble a{color:#e0f2fe;text-decoration:underline}.message-row.me .bubble a:visited{color:#fde68a}.message-row.me .bubble a:hover{color:#fff}.room-ctx-overlay{position:fixed;inset:0;z-index:9998}.room-ctx-menu{position:fixed;z-index:9999;background:var(--bg-primary,#fff);border:1px solid var(--border,#e5e7eb);border-radius:8px;box-shadow:0 4px 16px #00000026;padding:4px 0;min-width:160px}.room-ctx-item{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;font-size:13px;color:var(--text-primary,#111)}.room-ctx-item:hover{background:var(--bg-hover,#f3f4f6)}.message-row.me .bubble{background:var(--bubble-me-bg, var(--accent))!important;color:var(--bubble-me-text, #fff)!important}.message-row:not(.me):not(.bot) .bubble{background:var(--bubble-other-bg, var(--bg-primary))!important;color:var(--bubble-other-text, var(--text-primary))!important}.message-row.me .bubble a{color:var(--bubble-me-link, #e0f2fe)!important}.message-row.me .bubble a:visited{color:var(--bubble-me-link-visited, #fde68a)!important}.message-row:not(.me) .bubble a{color:var(--bubble-other-link, var(--accent))!important}.message-row:not(.me) .bubble a:visited{color:var(--bubble-other-link-visited, #7c3aed)!important}.message-row.me .mention{background:var(--bubble-me-mention-bg, #ffffff40)!important;color:var(--bubble-me-mention-text, #fff)!important}.message-row:not(.me) .mention{background:var(--bubble-other-mention-bg, #3b82f626)!important;color:var(--bubble-other-mention-text, var(--accent))!important}.message-row.me .quote-line{background:var(--bubble-me-quote-bg, rgba(255,255,255,.15))!important}.message-row.me .quote-line{color:var(--bubble-me-quote-text, #ffffffd9)!important}.message-row:not(.me) .quote-line{background:var(--bubble-other-quote-bg, var(--bg-secondary))!important}.message-row:not(.me) .quote-line{color:var(--bubble-other-quote-text, var(--text-secondary))!important}.message-time .time{color:var(--bubble-time, var(--text-secondary))!important}.date-separator span{color:var(--bubble-date, var(--text-tertiary))!important}.read-status{color:var(--bubble-time, var(--text-tertiary))!important}.mail-bubble{cursor:pointer}.mail-bubble.mail-read{opacity:.5}.mail-bubble.mail-open{opacity:1}.message-row:not(.me) .mail-bubble.mail-open{background:var(--bubble-me-bg, var(--accent))!important;color:var(--bubble-me-text, #fff)!important}.message-row:not(.me) .mail-bubble.mail-open span,.message-row:not(.me) .mail-bubble.mail-open div{color:inherit!important}.message-row:not(.me) .mail-bubble.mail-open a{color:var(--bubble-me-link, #e0f2fe)!important}.message-row:not(.me) .mail-bubble.mail-open a:visited{color:var(--bubble-me-link-visited, #fde68a)!important}.message-row.me .mail-self-hide{display:none!important}.mail-sync-snackbar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-secondary);border-top:1px solid var(--border);font-size:13px;color:var(--text-primary);flex-shrink:0}@media(max-width:768px){.mail-sync-snackbar{position:fixed;left:0;right:0;bottom:calc(44px + max(env(safe-area-inset-bottom,0px),20px));z-index:102;border-bottom:1px solid var(--border);padding:6px 12px;font-size:12px}.messages.has-mail-sync-bar{bottom:calc(84px + max(env(safe-area-inset-bottom,0px),20px))}}.mail-sync-snackbar .mail-sync-btn{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:4px 12px;cursor:pointer;font-size:12px}.mail-sync-snackbar .mail-sync-btn:disabled{opacity:.5;cursor:not-allowed}.mail-sync-snackbar .mail-sync-close{background:transparent;border:none;cursor:pointer;color:var(--text-tertiary);font-size:18px;margin-left:auto;padding:0 4px;line-height:1}.mail-sync-overlay{position:sticky;top:0;left:0;right:0;height:0;display:flex;justify-content:center;z-index:10;pointer-events:none}.mail-sync-spinner{width:36px;height:36px;margin-top:40vh;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.plus-btn-wrap{position:relative;display:inline-flex;flex-shrink:0}.plus-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition);flex-shrink:0}.plus-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.plus-btn svg{width:20px;height:20px}@media(max-width:768px){.plus-btn{width:32px;height:32px}.plus-btn svg{width:16px;height:16px}}.plus-menu{position:absolute;bottom:100%;left:0;margin-bottom:4px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);z-index:50;min-width:180px;padding:4px}.plus-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);font-size:13px;text-align:left;border-radius:4px}.plus-menu-item:hover{background:var(--bg-secondary)}.plus-menu-item svg{width:16px;height:16px;color:var(--text-secondary);flex-shrink:0}.template-list{max-height:50vh;overflow-y:auto}.template-item{display:flex;align-items:flex-start;gap:8px;padding:10px 20px;border-bottom:1px solid var(--border);cursor:pointer}.template-item:hover{background:var(--bg-secondary)}.template-item-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.template-item-preview{font-size:12px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.template-item-delete{background:transparent;border:none;cursor:pointer;color:var(--text-tertiary);font-size:18px;padding:0 4px;line-height:1;align-self:center}.template-item-delete:hover{color:var(--danger)}.template-ph-btn{padding:4px 10px;border:1px solid var(--accent);background:transparent;color:var(--accent);border-radius:12px;font-size:12px;cursor:pointer}.template-ph-btn:hover{background:var(--accent);color:#fff}.coachmark-overlay{position:fixed;inset:0;z-index:9998;pointer-events:none}.coachmark-svg{position:fixed;inset:0;width:100vw;height:100vh;pointer-events:auto;z-index:9998}.coachmark-mask-ring{position:fixed;border:2px solid #fbbf24;border-radius:8px;pointer-events:none;transition:top .2s,left .2s,width .2s,height .2s;z-index:9999;box-sizing:border-box}.coachmark-tooltip{position:fixed;background:#fff;color:#1a1a1a;border-radius:12px;box-shadow:0 10px 30px #0006;padding:16px 18px;width:340px;max-width:calc(100vw - 24px);pointer-events:auto;z-index:9999;border:1px solid #e5e7eb}.coachmark-tooltip h4{font-size:15px;font-weight:700;margin:0 0 8px;color:#3b82f6}.coachmark-tooltip p{font-size:13px;line-height:1.6;margin:0 0 12px;color:#1a1a1a}.coachmark-skip{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280;margin-bottom:12px;cursor:pointer;user-select:none}.coachmark-skip input{cursor:pointer}.coachmark-buttons{display:flex;justify-content:flex-end;gap:8px}.coachmark-btn-primary,.coachmark-btn-secondary{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none}.coachmark-btn-primary{background:#3b82f6;color:#fff}.coachmark-btn-primary:hover{background:#2563eb}.coachmark-btn-secondary{background:transparent;color:#6b7280}.coachmark-btn-secondary:hover{color:#1a1a1a;background:#f3f4f6}@media(max-width:768px){.calendar-panel.mobile-memo-view{position:fixed;top:var(--vvtop, 0);left:0;right:0;width:100%!important;height:var(--vvh, 100dvh);max-height:var(--vvh, 100dvh);z-index:200;background:var(--bg-primary);display:flex;flex-direction:column;overflow:hidden}body.memo-editing .sidebar.mobile-main{visibility:hidden}.calendar-panel.mobile-memo-view .calendar-resize-handle,.calendar-panel.mobile-memo-view .side-panel-header{display:none}.calendar-panel.mobile-memo-view .memo-edit-textarea{max-height:calc(var(--vvh, 100vh) - 180px)!important;overflow-y:auto!important;overscroll-behavior:contain}}@media(max-width:768px){.modal{align-items:flex-start;padding-top:1vh;padding-bottom:1vh}.modal-content{max-height:calc(var(--vvh, 100vh) - 2vh)!important}}.launcher-wrap{position:relative}.launcher-dropdown{position:fixed;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);padding:12px;width:288px;z-index:99999}.launcher-empty{padding:24px 8px;text-align:center;color:var(--text-tertiary);font-size:12px}.launcher-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.launcher-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border-radius:8px;text-decoration:none;color:var(--text-primary);transition:var(--transition)}.launcher-item:hover{background:var(--bg-secondary)}.launcher-item-icon{width:40px;height:40px;border-radius:8px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:18px;font-weight:700;color:var(--text-secondary);flex-shrink:0}.launcher-item-icon img{width:100%;height:100%;object-fit:contain;padding:4px}.launcher-item-name{font-size:11px;text-align:center;word-break:break-word;line-height:1.2;max-height:28px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.side-panel-header-icons{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:flex-end;width:100%}.code-block{margin:6px 0;border-radius:8px;overflow:hidden;background:#f6f8fa;border:1px solid #e1e4e8;font-family:JetBrains Mono,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.55}.code-block-header{display:flex;align-items:center;gap:8px;padding:4px 10px;background:#eef1f4;border-bottom:1px solid #e1e4e8;font-size:11px;color:#57606a}.code-block-lang{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.code-block-filename{color:#586069;font-weight:500}.code-block-copy{margin-left:auto;background:transparent;border:1px solid #d0d7de;border-radius:4px;padding:2px 8px;font-size:11px;color:#57606a;cursor:pointer;font-family:inherit;opacity:0;transition:opacity .15s}.code-block:hover .code-block-copy{opacity:1}.code-block-copy:hover{background:#fff;color:#24292f}.code-block pre{margin:0;padding:12px;overflow-x:auto;max-height:400px;overflow-y:auto;background:transparent}.code-block code.hljs{background:transparent;padding:0;display:block;white-space:pre;font-family:inherit;font-size:inherit;line-height:inherit;color:#24292f}code.inline-code{background:#afb8c133;padding:1px 5px;border-radius:4px;font-family:JetBrains Mono,SF Mono,Menlo,Consolas,monospace;font-size:.9em;color:#cf222e}.message-row.me code.inline-code{background:#fff3;color:#fff}@media(max-width:768px){.code-block-copy{opacity:1}}html.dark .code-block{background:#1e1e2e;border-color:#313244}html.dark .code-block-header{background:#181825;border-color:#313244;color:#a6adc8}html.dark .code-block-filename{color:#bac2de}html.dark .code-block-copy{border-color:#45475a;color:#a6adc8}html.dark .code-block-copy:hover{background:#313244;color:#cdd6f4}html.dark .code-block code.hljs{color:#cdd6f4}html.dark code.inline-code{background:#a6adc833;color:#f38ba8}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:#d73a49}.hljs-built_in,.hljs-name,.hljs-type{color:#005cc5}.hljs-string,.hljs-attr,.hljs-template-tag,.hljs-template-variable{color:#032f62}.hljs-number,.hljs-meta,.hljs-symbol,.hljs-bullet{color:#005cc5}.hljs-comment,.hljs-quote{color:#6a737d;font-style:italic}.hljs-variable,.hljs-regexp{color:#e36209}.hljs-title,.hljs-class .hljs-title,.hljs-function .hljs-title{color:#6f42c1;font-weight:600}.hljs-tag,.hljs-attribute{color:#22863a}.hljs-deletion{background:#ffeef0;color:#b31d28}.hljs-addition{background:#f0fff4;color:#22863a}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}html.dark .hljs-keyword,html.dark .hljs-selector-tag,html.dark .hljs-literal,html.dark .hljs-section,html.dark .hljs-link{color:#cba6f7}html.dark .hljs-built_in,html.dark .hljs-name,html.dark .hljs-type{color:#89b4fa}html.dark .hljs-string,html.dark .hljs-attr,html.dark .hljs-template-tag,html.dark .hljs-template-variable{color:#a6e3a1}html.dark .hljs-number,html.dark .hljs-meta,html.dark .hljs-symbol,html.dark .hljs-bullet{color:#fab387}html.dark .hljs-comment,html.dark .hljs-quote{color:#6c7086;font-style:italic}html.dark .hljs-variable,html.dark .hljs-regexp{color:#f5c2e7}html.dark .hljs-title,html.dark .hljs-class .hljs-title,html.dark .hljs-function .hljs-title{color:#f9e2af;font-weight:600}html.dark .hljs-tag,html.dark .hljs-attribute{color:#94e2d5}.dept-subheader{display:flex;align-items:center;gap:4px;padding:3px 12px;background:linear-gradient(135deg,#3b82f6,#bfdbfe);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:600}.sidebar.band-blue .section-header-main{background:linear-gradient(135deg,#2c5282,#90b4d8)!important}.sidebar.band-blue .section-header-main:hover{background:linear-gradient(135deg,#234876,#7ca8d0)!important}.sidebar.band-blue .dept-subheader{background:linear-gradient(135deg,#4a7ab5,#b8d4ea)}.sidebar.band-blue .dept-subheader:hover{background:linear-gradient(135deg,#3d6a9e,#a0c4e0)}.sidebar.band-blue .section-header{background:linear-gradient(135deg,#4a7ab5,#b8d4ea)}.sidebar.band-blue .section-header:hover{background:linear-gradient(135deg,#3d6a9e,#a0c4e0)}.sidebar.band-black .section-header-main{background:linear-gradient(135deg,#1f2937,#6b7280)!important}.sidebar.band-black .section-header-main:hover{background:linear-gradient(135deg,#111827,#4b5563)!important}.sidebar.band-black .dept-subheader{background:linear-gradient(135deg,#374151,#9ca3af)}.sidebar.band-black .dept-subheader:hover{background:linear-gradient(135deg,#1f2937,#6b7280)}.sidebar.band-black .section-header{background:linear-gradient(135deg,#374151,#9ca3af)}.sidebar.band-black .section-header:hover{background:linear-gradient(135deg,#1f2937,#6b7280)}.sidebar.band-green .section-header-main{background:linear-gradient(135deg,#2d6a4f,#74b892)!important}.sidebar.band-green .section-header-main:hover{background:linear-gradient(135deg,#245c43,#5ea87e)!important}.sidebar.band-green .dept-subheader{background:linear-gradient(135deg,#4a9068,#a8d5b8)}.sidebar.band-green .dept-subheader:hover{background:linear-gradient(135deg,#3d7d58,#8cc8a0)}.sidebar.band-green .section-header{background:linear-gradient(135deg,#4a9068,#a8d5b8)}.sidebar.band-green .section-header:hover{background:linear-gradient(135deg,#3d7d58,#8cc8a0)}.sidebar.band-red .section-header-main{background:linear-gradient(135deg,#7c3030,#c88080)!important}.sidebar.band-red .section-header-main:hover{background:linear-gradient(135deg,#6b2828,#b86e6e)!important}.sidebar.band-red .dept-subheader{background:linear-gradient(135deg,#a05050,#d8a8a8)}.sidebar.band-red .dept-subheader:hover{background:linear-gradient(135deg,#8c4040,#cc9494)}.sidebar.band-red .section-header{background:linear-gradient(135deg,#a05050,#d8a8a8)}.sidebar.band-red .section-header:hover{background:linear-gradient(135deg,#8c4040,#cc9494)}.sidebar.band-orange .section-header-main{background:linear-gradient(135deg,#8c5020,#d4a870)!important}.sidebar.band-orange .section-header-main:hover{background:linear-gradient(135deg,#7a4418,#c89860)!important}.sidebar.band-orange .dept-subheader{background:linear-gradient(135deg,#b07040,#e0c8a0)}.sidebar.band-orange .dept-subheader:hover{background:linear-gradient(135deg,#9c6030,#d4b888)}.sidebar.band-orange .section-header{background:linear-gradient(135deg,#b07040,#e0c8a0)}.sidebar.band-orange .section-header:hover{background:linear-gradient(135deg,#9c6030,#d4b888)}.sidebar.band-blue_solid .section-header-main{background:#3b6b9c!important}.sidebar.band-blue_solid .section-header-main:hover{background:#2f5a88!important}.sidebar.band-blue_solid .dept-subheader{background:#5a8ab8}.sidebar.band-blue_solid .dept-subheader:hover{background:#4a7aa8}.sidebar.band-blue_solid .section-header{background:#5a8ab8}.sidebar.band-blue_solid .section-header:hover{background:#4a7aa8}.sidebar.band-gray_solid .section-header-main{background:#4b5563!important}.sidebar.band-gray_solid .section-header-main:hover{background:#374151!important}.sidebar.band-gray_solid .dept-subheader{background:#6b7280}.sidebar.band-gray_solid .dept-subheader:hover{background:#4b5563}.sidebar.band-gray_solid .section-header{background:#6b7280}.sidebar.band-gray_solid .section-header:hover{background:#4b5563}.band-palette{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.band-swatch{width:36px;height:36px;border-radius:8px;cursor:pointer;border:2px solid transparent;transition:all .15s ease;box-shadow:0 1px 3px #0000001a}.band-swatch:hover{transform:scale(1.05)}.band-swatch.active{border-color:#1f2937;transform:scale(1.08);box-shadow:0 2px 8px #0003}.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)}.calendar-panel{background:#fafbfc;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;flex-shrink:1000;min-width:0;overflow:hidden;position:relative;height:100%}.calendar-panel-header{padding:12px 16px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;background:#fff}.side-panel-header{padding:12px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border);display:flex;align-items:center;flex-shrink:0;box-sizing:border-box;min-height:56px}.side-panel-header-icons{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.side-panel-header-icons .icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px}.side-panel-header-icons .icon-btn.active{background:#3b82f626;color:var(--accent)}.side-panel-header-icons .icon-btn:hover:not(.active){background:#0000000d}@media(max-width:768px){.calendar-panel{display:none}}@media(min-width:769px){.sidebar-search-btn{display:none}}.room-list.dm-virtual .room-item{padding-left:44px}.section-chevron,.dept-chevron{display:none!important}.sandbox-view{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);min-height:0;min-width:0;overflow:hidden}.sandbox-bar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border);font-size:12px;flex-shrink:0}.sandbox-bar-icon{flex-shrink:0;font-size:14px}.sandbox-bar-title{flex:1;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sandbox-bar-domain{color:var(--text-tertiary);font-size:11px;flex-shrink:0}.sandbox-bar-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-decoration:none;flex-shrink:0;padding:0}.sandbox-bar-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sandbox-bar-btn svg{width:16px;height:16px}.sandbox-iframe{flex:1;width:100%;border:none;background:#fff}.sandbox-link{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#0000000a;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);text-decoration:none;color:var(--text-primary);transition:var(--transition);margin:6px 0;min-width:240px}.sandbox-link:hover{background:#00000014;transform:translateY(-1px)}.sandbox-link .sb-icon{font-size:22px;flex-shrink:0;line-height:1}.sandbox-link .sb-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sandbox-link .sb-title{font-weight:600;font-size:14px;color:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sandbox-link .sb-domain{font-size:11px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sandbox-link .sb-action{font-size:12px;color:var(--accent);font-weight:600;flex-shrink:0;white-space:nowrap}.message-row.me .sandbox-link{background:#ffffff2e;border-color:#ffffff4d;color:#fff}.message-row.me .sandbox-link:hover{background:#ffffff47}.message-row.me .sandbox-link .sb-domain{color:#ffffffbf}.message-row.me .sandbox-link .sb-action{color:#fff}.messages.dark-bg .sandbox-link{background:#ffffff14;border-color:#ffffff26;color:#fff}.messages.dark-bg .sandbox-link:hover{background:#ffffff24}.messages.dark-bg .sandbox-link .sb-domain{color:#fff9}@media(max-width:768px){.section-header{padding:10px 12px!important}.dept-subheader{padding:6px 12px!important}}.palette-fold-header{display:flex;justify-content:space-between;align-items:center;padding:6px 4px;cursor:pointer;font-size:11px;font-weight:600;color:var(--text-secondary);user-select:none;border-bottom:1px solid var(--border)}.palette-fold-header:hover{background:var(--bg-secondary)}.palette-fold-body{padding:6px 0 8px}@media(max-width:768px){.palette-fold-header{padding:10px 8px;font-size:12px}}.dept-subheader,.section-header{border-radius:14px 0 0;position:relative;overflow:visible}.dept-subheader.collapsed:after,.section-header.collapsed:after{content:"";position:absolute;top:0;right:0;width:16px;height:16px;background:linear-gradient(225deg,var(--bg-primary) 50%,rgba(0,0,0,.35) 50%);box-shadow:-1px 1px 2px #00000026}html.dark .dept-subheader.collapsed:after,html.dark .section-header.collapsed:after{background:linear-gradient(225deg,var(--bg-primary) 50%,rgba(255,255,255,.18) 50%)}@media(max-width:768px){.color-palette-popover{position:fixed!important;inset:50% auto auto 50%!important;transform:translate(-50%,-50%);max-height:80vh;width:min(360px,92vw);z-index:1100;overflow-y:auto;box-shadow:0 8px 24px #0000004d}}.mobile-menu-overlay{position:fixed;inset:0;background:#0006;z-index:1000;display:flex;align-items:flex-start;justify-content:flex-end;animation:fadeIn .15s ease-out}.mobile-menu-sheet{background:var(--bg-primary);width:min(250px,70vw);height:100vh;display:flex;flex-direction:column;box-shadow:-4px 0 12px #00000026;animation:slideInRight .2s ease-out;padding-top:env(safe-area-inset-top,0px)}@media(max-width:768px){.message-actions{position:fixed!important;inset:50% auto auto 50%!important;transform:translate(-50%,-50%);max-height:80vh;width:min(320px,90vw);overflow-y:auto;z-index:1100;box-shadow:0 8px 24px #0000004d}.modal-content{padding:8px!important}.modal-header{margin-bottom:6px!important;padding:0!important}.modal-header h3{font-size:14px!important}.close-btn{width:28px!important;height:28px!important}.modal-content .btn{min-height:36px}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-menu-header{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.mobile-menu-items{flex:1;overflow-y:auto;padding:8px 0}.mobile-menu-item{display:flex;align-items:center;gap:16px;width:100%;padding:14px 20px;background:none;border:none;cursor:pointer;font-size:15px;color:var(--text-primary);text-align:left}.mobile-menu-item:hover,.mobile-menu-item:active{background:var(--bg-secondary)}.mobile-menu-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:4px 0;padding:8px 0}.mobile-menu-section-title{display:flex;align-items:center;gap:16px;padding:10px 20px;font-weight:600;font-size:14px;color:var(--text-secondary)}.image-viewer-img{transition:opacity .15s ease-out}.image-viewer-img[src=""]{opacity:0}.preview-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#00000080;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .15s}.preview-nav-btn:hover{background:#000000bf}.preview-nav-btn svg{width:28px;height:28px}.preview-nav-prev{left:16px}.preview-nav-next{right:16px}@media(max-width:768px){.preview-nav-btn{width:36px;height:36px}.preview-nav-btn svg{width:20px;height:20px}.preview-nav-prev{left:8px}.preview-nav-next{right:8px}}.calendar-panel .fc{font-size:11px;font-family:var(--font-family);color:#374151}.calendar-panel .fc .fc-toolbar{padding:8px 12px 6px;gap:6px;margin-bottom:0}.calendar-panel .fc .fc-toolbar-title{font-size:14px!important;font-weight:700;color:#111827;letter-spacing:.02em}.calendar-panel .fc .fc-button{padding:4px 10px!important;font-size:11px!important;line-height:1.3;background:#fff!important;border:1px solid #e5e7eb!important;color:#4b5563!important;border-radius:6px!important;font-weight:500!important;box-shadow:0 1px 2px #0000000a;transition:all .15s ease;text-transform:none!important}.calendar-panel .fc .fc-button:hover{background:#f3f4f6!important;border-color:#d1d5db!important;color:#111827!important;transform:translateY(-1px);box-shadow:0 2px 4px #0000000f}.calendar-panel .fc .fc-button:disabled{opacity:.5}.calendar-panel .fc .fc-button-primary:not(:disabled).fc-button-active{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;border-color:#2563eb!important;color:#fff!important;box-shadow:0 2px 6px #3b82f64d}.calendar-panel .fc .fc-button-group{gap:2px}.calendar-panel .fc .fc-button-group>.fc-button{padding:4px 10px!important;border-radius:6px!important}.calendar-panel .fc .fc-today-button{padding:4px 12px!important;background:linear-gradient(135deg,#3b82f6,#2563eb)!important;border-color:#2563eb!important;color:#fff!important;box-shadow:0 2px 6px #3b82f640}.calendar-panel .fc .fc-today-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8)!important}.calendar-panel .fc .fc-prev-button,.calendar-panel .fc .fc-next-button{padding:4px 8px!important}.calendar-panel .fc .fc-scrollgrid{border:none!important;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #0000000a;margin:4px 8px 8px}.calendar-panel .fc .fc-scrollgrid td,.calendar-panel .fc .fc-scrollgrid th{border-color:#f1f5f9!important}.calendar-panel .fc .fc-scrollgrid-section>*{border-color:#f1f5f9!important}.calendar-panel .fc table,.calendar-panel .fc th,.calendar-panel .fc td{border-color:#f1f5f9!important}.calendar-panel .fc .fc-col-header{background:#f8fafc}.calendar-panel .fc .fc-col-header-cell{padding:6px 0!important;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;border-bottom:1px solid #f1f5f9!important}.calendar-panel .fc .fc-col-header-cell-cushion{padding:0 4px;color:inherit;text-decoration:none}.calendar-panel .fc .fc-daygrid-day{transition:background .15s ease}.calendar-panel .fc .fc-daygrid-day:hover{background:#f8fafc}.calendar-panel .fc .fc-daygrid-day-number{font-size:11px;padding:4px 6px;color:#64748b;font-weight:500;text-decoration:none}.calendar-panel .fc .fc-day-other .fc-daygrid-day-number{color:#cbd5e1}.calendar-panel .fc .fc-day-today{background:linear-gradient(180deg,#eff6ff,#dbeafe)!important;border-left:none!important;border-bottom:none!important;position:relative}.calendar-panel .fc .fc-day-today .fc-daygrid-day-number{font-weight:500;background:#3b82f6;color:#fff;min-width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;margin:3px;box-shadow:0 2px 4px #3b82f64d;white-space:nowrap;line-height:1}.calendar-panel .fc .fc-day-sat,.calendar-panel .fc .fc-day-sun{background:#fafbfc!important}.calendar-panel .fc .fc-day-sun .fc-daygrid-day-number{color:#ef4444}.calendar-panel .fc .fc-day-sat .fc-daygrid-day-number{color:#3b82f6}.calendar-panel .fc .fc-day-today.fc-day-sat,.calendar-panel .fc .fc-day-today.fc-day-sun{background:linear-gradient(180deg,#eff6ff,#dbeafe)!important}.calendar-panel .fc .fc-day-today.fc-day-sat .fc-daygrid-day-number,.calendar-panel .fc .fc-day-today.fc-day-sun .fc-daygrid-day-number{color:#fff!important}.calendar-panel .fc .fc-event{font-size:10px;padding:2px 6px;border:none!important;border-radius:5px;margin:1px 2px;box-shadow:0 1px 2px #00000014;transition:transform .1s ease,box-shadow .1s ease;cursor:pointer}.calendar-panel .fc .fc-event:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.calendar-panel .fc .fc-daygrid-event{margin-top:1px}.calendar-panel .fc .fc-daygrid-event-dot{border-width:4px}.calendar-panel .fc .fc-event-title{font-weight:500}.calendar-panel .fc .fc-daygrid-more-link{font-size:10px;color:#6366f1;font-weight:600;padding:0 4px}.calendar-panel .fc .fc-timegrid-slot{height:1.8em;border-color:#f1f5f9!important}.calendar-panel .fc .fc-timegrid-slot-label{color:#94a3b8;font-size:10px}.calendar-panel .fc .fc-timegrid-now-indicator-line{border-color:#ef4444;border-width:2px}.calendar-panel .fc .fc-timegrid-now-indicator-arrow{border-color:#ef4444}.calendar-panel .fc .fc-list{border:none!important;background:transparent}.calendar-panel .fc .fc-list-day-cushion{font-size:11px;padding:6px 12px;background:#f8fafc!important;color:#475569;font-weight:600;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9}.calendar-panel .fc .fc-list-event:hover td{background:#f8fafc!important}.calendar-panel .fc .fc-list-event-title{font-size:11px}.calendar-panel .fc .fc-list-event-time{font-size:10px;color:#94a3b8}.calendar-panel .fc .fc-list-event-dot{border-width:5px}.calendar-panel .fc .fc-list-empty{padding:24px 12px;color:#94a3b8;font-size:11px}@media(max-width:768px){.gas-script-section{display:none}}.calendar-resize-handle{width:5px;cursor:col-resize;background:transparent;position:absolute;left:0;top:0;bottom:0;z-index:10;transition:background .15s}.calendar-resize-handle:hover{background:#3b82f64d}.calendar-panel{position:relative}html.dark .fc,html.dark .fc .fc-toolbar-title{color:#e2e8f0}html.dark .fc .fc-button{background:#1e293b!important;border-color:#334155!important;color:#e2e8f0!important}html.dark .fc .fc-button:hover{background:#334155!important;border-color:#475569!important;color:#fff!important}html.dark .fc .fc-button-primary:not(:disabled).fc-button-active{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;color:#fff!important}html.dark .fc .fc-today-button{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;border-color:#2563eb!important;color:#fff!important}html.dark .fc .fc-scrollgrid{background:#1a1a2e;box-shadow:0 1px 3px #0003}html.dark .fc .fc-scrollgrid td,html.dark .fc .fc-scrollgrid th{border-color:#334155!important}html.dark .fc .fc-scrollgrid-section>*{border-color:#334155!important}html.dark .fc table,html.dark .fc th,html.dark .fc td{border-color:#334155!important}html.dark .fc .fc-col-header{background:#16213e}html.dark .fc .fc-col-header-cell{color:#64748b}html.dark .fc .fc-daygrid-day:hover{background:#16213e}html.dark .fc .fc-daygrid-day-number{color:#94a3b8}html.dark .fc .fc-day-other .fc-daygrid-day-number{color:#475569}html.dark .fc .fc-day-today{background:linear-gradient(180deg,#1e3a5f,#0f3460)!important}html.dark .fc .fc-day-sat,html.dark .fc .fc-day-sun{background:#16213e!important}html.dark .fc .fc-day-today.fc-day-sat,html.dark .fc .fc-day-today.fc-day-sun{background:linear-gradient(180deg,#1e3a5f,#0f3460)!important}html.dark .fc .fc-event{box-shadow:0 1px 2px #0000004d}html.dark .fc .fc-timegrid-slot{border-color:#334155!important}html.dark .fc .fc-timegrid-slot-label{color:#64748b}html.dark .fc .fc-daygrid-more-link{color:#818cf8}html.dark .fc .fc-popover{background:#1e293b;border-color:#334155}html.dark .fc .fc-popover-header{background:#16213e;color:#e2e8f0}html.dark .calendar-panel{background:#1a1a2e;border-left-color:#334155}html.dark .calendar-panel-header{background:#16213e;border-bottom-color:#334155}html.dark .calendar-resize-handle{background:#334155}html.dark .fc .fc-daygrid-dot-event .fc-event-title,html.dark .fc .fc-daygrid-dot-event .fc-event-time,html.dark .fc .fc-timegrid-event .fc-event-title,html.dark .fc .fc-timegrid-event .fc-event-time{color:#93c5fd!important}.font-size-medium .fc{font-size:13px!important}.font-size-medium .fc .fc-toolbar-title{font-size:16px!important}.font-size-medium .fc .fc-button{font-size:13px!important}.font-size-medium .fc .fc-col-header-cell{font-size:12px!important}.font-size-medium .fc .fc-daygrid-day-number{font-size:13px!important}.font-size-medium .fc .fc-event,.font-size-medium .fc .fc-daygrid-more-link,.font-size-medium .fc .fc-timegrid-slot-label{font-size:12px!important}.font-size-medium .fc .fc-list-event-title{font-size:13px!important}.font-size-medium .fc .fc-list-event-time{font-size:12px!important}.font-size-large .fc{font-size:14px!important}.font-size-large .fc .fc-toolbar-title{font-size:18px!important}.font-size-large .fc .fc-button{font-size:14px!important}.font-size-large .fc .fc-col-header-cell{font-size:13px!important}.font-size-large .fc .fc-daygrid-day-number{font-size:14px!important}.font-size-large .fc .fc-event,.font-size-large .fc .fc-daygrid-more-link,.font-size-large .fc .fc-timegrid-slot-label{font-size:13px!important}.font-size-large .fc .fc-list-event-title{font-size:14px!important}.font-size-large .fc .fc-list-event-time{font-size:13px!important}.font-size-medium .fc .fc-daygrid-day-frame{min-height:90px}.font-size-large .fc .fc-daygrid-day-frame{min-height:100px}.font-size-medium .fc .fc-event,.font-size-large .fc .fc-event{padding:1px 4px;line-height:1.4}.font-size-medium .fc .fc-h-event,.font-size-large .fc .fc-h-event{font-weight:400!important}html.dark .fc .fc-event,html.dark .fc .fc-event-title{font-weight:400}html.dark .fc .fc-toolbar-title{font-weight:600}html.dark .fc .fc-col-header-cell{font-weight:500}html.dark .fc .fc-daygrid-day-number{font-weight:400}.fc .fc-closeCalendar-button{background:none!important;border:none!important;color:var(--text-secondary)!important;font-size:18px!important;padding:2px 6px!important;line-height:1;cursor:pointer;opacity:.7}.fc .fc-closeCalendar-button:hover{opacity:1;color:var(--text-primary)!important}.fc .fc-col-header-cell{padding:0!important;line-height:1.2}.fc .fc-toolbar{padding:4px 8px 2px!important}
